diff options
Diffstat (limited to '')
178 files changed, 15506 insertions, 15538 deletions
diff --git a/_static/_sphinx_javascript_frameworks_compat.js b/_static/_sphinx_javascript_frameworks_compat.js new file mode 100644 index 00000000..8549469d --- /dev/null +++ b/_static/_sphinx_javascript_frameworks_compat.js @@ -0,0 +1,134 @@ +/* + * _sphinx_javascript_frameworks_compat.js + * ~~~~~~~~~~ + * + * Compatability shim for jQuery and underscores.js. + * + * WILL BE REMOVED IN Sphinx 6.0 + * xref RemovedInSphinx60Warning + * + */ + +/** + * select a different prefix for underscore + */ +$u = _.noConflict(); + + +/** + * small helper function to urldecode strings + * + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL + */ +jQuery.urldecode = function(x) { +    if (!x) { +        return x +    } +    return decodeURIComponent(x.replace(/\+/g, ' ')); +}; + +/** + * small helper function to urlencode strings + */ +jQuery.urlencode = encodeURIComponent; + +/** + * This function returns the parsed url parameters of the + * current request. Multiple values per key are supported, + * it will always return arrays of strings for the value parts. + */ +jQuery.getQueryParameters = function(s) { +    if (typeof s === 'undefined') +        s = document.location.search; +    var parts = s.substr(s.indexOf('?') + 1).split('&'); +    var result = {}; +    for (var i = 0; i < parts.length; i++) { +        var tmp = parts[i].split('=', 2); +        var key = jQuery.urldecode(tmp[0]); +        var value = jQuery.urldecode(tmp[1]); +        if (key in result) +            result[key].push(value); +        else +            result[key] = [value]; +    } +    return result; +}; + +/** + * highlight a given string on a jquery object by wrapping it in + * span elements with the given class name. + */ +jQuery.fn.highlightText = function(text, className) { +    function highlight(node, addItems) { +        if (node.nodeType === 3) { +            var val = node.nodeValue; +            var pos = val.toLowerCase().indexOf(text); +            if (pos >= 0 && +                !jQuery(node.parentNode).hasClass(className) && +                !jQuery(node.parentNode).hasClass("nohighlight")) { +                var span; +                var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg"); +                if (isInSVG) { +                    span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); +                } else { +                    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); +                if (isInSVG) { +                    var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"); +                    var bbox = node.parentElement.getBBox(); +                    rect.x.baseVal.value = bbox.x; +                    rect.y.baseVal.value = bbox.y; +                    rect.width.baseVal.value = bbox.width; +                    rect.height.baseVal.value = bbox.height; +                    rect.setAttribute('class', className); +                    addItems.push({ +                        "parent": node.parentNode, +                        "target": rect}); +                } +            } +        } +        else if (!jQuery(node).is("button, select, textarea")) { +            jQuery.each(node.childNodes, function() { +                highlight(this, addItems); +            }); +        } +    } +    var addItems = []; +    var result = this.each(function() { +        highlight(this, addItems); +    }); +    for (var i = 0; i < addItems.length; ++i) { +        jQuery(addItems[i].parent).before(addItems[i].target); +    } +    return result; +}; + +/* + * 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; +} diff --git a/_static/basic.css b/_static/basic.css index bf18350b..7d5974c3 100644 --- a/_static/basic.css +++ b/_static/basic.css @@ -222,7 +222,7 @@ table.modindextable td {  /* -- general body styles --------------------------------------------------- */  div.body { -    min-width: 450px; +    min-width: 360px;      max-width: 800px;  } @@ -236,7 +236,6 @@ div.body p, div.body dd, div.body li, div.body blockquote {  a.headerlink {      visibility: hidden;  } -  a.brackets:before,  span.brackets > a:before{      content: "["; @@ -247,6 +246,7 @@ span.brackets > a:after {      content: "]";  } +  h1:hover > a.headerlink,  h2:hover > a.headerlink,  h3:hover > a.headerlink, @@ -334,13 +334,11 @@ aside.sidebar {  p.sidebar-title {      font-weight: bold;  } -  div.admonition, div.topic, blockquote {      clear: left;  }  /* -- topics ---------------------------------------------------------------- */ -  div.topic {      border: 1px solid #ccc;      padding: 7px; @@ -428,10 +426,6 @@ table.docutils td, table.docutils th {      border-bottom: 1px solid #aaa;  } -table.footnote td, table.footnote th { -    border: 0 !important; -} -  th {      text-align: left;      padding-right: 5px; @@ -615,6 +609,7 @@ ul.simple p {      margin-bottom: 0;  } +/* Docutils 0.17 and older (footnotes & citations) */  dl.footnote > dt,  dl.citation > dt {      float: left; @@ -632,6 +627,33 @@ dl.citation > dd:after {      clear: both;  } +/* Docutils 0.18+ (footnotes & citations) */ +aside.footnote > span, +div.citation > span { +    float: left; +} +aside.footnote > span:last-of-type, +div.citation > span:last-of-type { +  padding-right: 0.5em; +} +aside.footnote > p { +  margin-left: 2em; +} +div.citation > p { +  margin-left: 4em; +} +aside.footnote > p:last-of-type, +div.citation > p:last-of-type { +    margin-bottom: 0em; +} +aside.footnote > p:last-of-type:after, +div.citation > p:last-of-type:after { +    content: ""; +    clear: both; +} + +/* Footnotes & citations ends */ +  dl.field-list {      display: grid;      grid-template-columns: fit-content(30%) auto; diff --git a/_static/doctools.js b/_static/doctools.js index e1bfd708..c3db08d1 100644 --- a/_static/doctools.js +++ b/_static/doctools.js @@ -2,357 +2,263 @@   * doctools.js   * ~~~~~~~~~~~   * - * Sphinx JavaScript utilities for all documentation. + * Base JavaScript utilities for all Sphinx HTML documentation.   *   * :copyright: Copyright 2007-2022 by the Sphinx team, see AUTHORS.   * :license: BSD, see LICENSE for details.   *   */ +"use strict"; -/** - * select a different prefix for underscore - */ -$u = _.noConflict(); - -/** - * make the code below compatible with browsers without - * an installed firebug like debugger -if (!window.console || !console.firebug) { -  var names = ["log", "debug", "info", "warn", "error", "assert", "dir", -    "dirxml", "group", "groupEnd", "time", "timeEnd", "count", "trace", -    "profile", "profileEnd"]; -  window.console = {}; -  for (var i = 0; i < names.length; ++i) -    window.console[names[i]] = function() {}; -} - */ - -/** - * small helper function to urldecode strings - * - * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL - */ -jQuery.urldecode = function(x) { -  if (!x) { -    return x +const _ready = (callback) => { +  if (document.readyState !== "loading") { +    callback(); +  } else { +    document.addEventListener("DOMContentLoaded", callback);    } -  return decodeURIComponent(x.replace(/\+/g, ' '));  };  /** - * small helper function to urlencode strings + * highlight a given string on a node by wrapping it in + * span elements with the given class name.   */ -jQuery.urlencode = encodeURIComponent; +const _highlight = (node, addItems, text, className) => { +  if (node.nodeType === Node.TEXT_NODE) { +    const val = node.nodeValue; +    const parent = node.parentNode; +    const pos = val.toLowerCase().indexOf(text); +    if ( +      pos >= 0 && +      !parent.classList.contains(className) && +      !parent.classList.contains("nohighlight") +    ) { +      let span; -/** - * This function returns the parsed url parameters of the - * current request. Multiple values per key are supported, - * it will always return arrays of strings for the value parts. - */ -jQuery.getQueryParameters = function(s) { -  if (typeof s === 'undefined') -    s = document.location.search; -  var parts = s.substr(s.indexOf('?') + 1).split('&'); -  var result = {}; -  for (var i = 0; i < parts.length; i++) { -    var tmp = parts[i].split('=', 2); -    var key = jQuery.urldecode(tmp[0]); -    var value = jQuery.urldecode(tmp[1]); -    if (key in result) -      result[key].push(value); -    else -      result[key] = [value]; -  } -  return result; -}; +      const closestNode = parent.closest("body, svg, foreignObject"); +      const isInSVG = closestNode && closestNode.matches("svg"); +      if (isInSVG) { +        span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); +      } else { +        span = document.createElement("span"); +        span.classList.add(className); +      } -/** - * highlight a given string on a jquery object by wrapping it in - * span elements with the given class name. - */ -jQuery.fn.highlightText = function(text, className) { -  function highlight(node, addItems) { -    if (node.nodeType === 3) { -      var val = node.nodeValue; -      var pos = val.toLowerCase().indexOf(text); -      if (pos >= 0 && -          !jQuery(node.parentNode).hasClass(className) && -          !jQuery(node.parentNode).hasClass("nohighlight")) { -        var span; -        var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg"); -        if (isInSVG) { -          span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); -        } else { -          span = document.createElement("span"); -          span.className = className; -        } -        span.appendChild(document.createTextNode(val.substr(pos, text.length))); -        node.parentNode.insertBefore(span, node.parentNode.insertBefore( +      span.appendChild(document.createTextNode(val.substr(pos, text.length))); +      parent.insertBefore( +        span, +        parent.insertBefore(            document.createTextNode(val.substr(pos + text.length)), -          node.nextSibling)); -        node.nodeValue = val.substr(0, pos); -        if (isInSVG) { -          var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"); -          var bbox = node.parentElement.getBBox(); -          rect.x.baseVal.value = bbox.x; -          rect.y.baseVal.value = bbox.y; -          rect.width.baseVal.value = bbox.width; -          rect.height.baseVal.value = bbox.height; -          rect.setAttribute('class', className); -          addItems.push({ -              "parent": node.parentNode, -              "target": rect}); -        } +          node.nextSibling +        ) +      ); +      node.nodeValue = val.substr(0, pos); + +      if (isInSVG) { +        const rect = document.createElementNS( +          "http://www.w3.org/2000/svg", +          "rect" +        ); +        const bbox = parent.getBBox(); +        rect.x.baseVal.value = bbox.x; +        rect.y.baseVal.value = bbox.y; +        rect.width.baseVal.value = bbox.width; +        rect.height.baseVal.value = bbox.height; +        rect.setAttribute("class", className); +        addItems.push({ parent: parent, target: rect });        }      } -    else if (!jQuery(node).is("button, select, textarea")) { -      jQuery.each(node.childNodes, function() { -        highlight(this, addItems); -      }); -    } +  } else if (node.matches && !node.matches("button, select, textarea")) { +    node.childNodes.forEach((el) => _highlight(el, addItems, text, className));    } -  var addItems = []; -  var result = this.each(function() { -    highlight(this, addItems); -  }); -  for (var i = 0; i < addItems.length; ++i) { -    jQuery(addItems[i].parent).before(addItems[i].target); -  } -  return result;  }; - -/* - * 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; -} +const _highlightText = (thisNode, text, className) => { +  let addItems = []; +  _highlight(thisNode, addItems, text, className); +  addItems.forEach((obj) => +    obj.parent.insertAdjacentElement("beforebegin", obj.target) +  ); +};  /**   * Small JavaScript module for the documentation.   */ -var Documentation = { - -  init : function() { -    this.fixFirefoxAnchorBug(); -    this.highlightSearchWords(); -    this.initIndexTable(); -    this.initOnKeyListeners(); +const Documentation = { +  init: () => { +    Documentation.highlightSearchWords(); +    Documentation.initDomainIndexTable(); +    Documentation.initOnKeyListeners();    },    /**     * i18n support     */ -  TRANSLATIONS : {}, -  PLURAL_EXPR : function(n) { return n === 1 ? 0 : 1; }, -  LOCALE : 'unknown', +  TRANSLATIONS: {}, +  PLURAL_EXPR: (n) => (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; +  gettext: (string) => { +    const translated = Documentation.TRANSLATIONS[string]; +    switch (typeof translated) { +      case "undefined": +        return string; // no translation +      case "string": +        return translated; // translation exists +      default: +        return translated[0]; // (singular, plural) translation tuple exists +    }    }, -  /** -   * add context elements like header anchor links -   */ -  addContextElements : function() { -    $('div[id] > :header:first').each(function() { -      $('<a class="headerlink">\u00B6</a>'). -      attr('href', '#' + this.id). -      attr('title', _('Permalink to this headline')). -      appendTo(this); -    }); -    $('dt[id]').each(function() { -      $('<a class="headerlink">\u00B6</a>'). -      attr('href', '#' + this.id). -      attr('title', _('Permalink to this definition')). -      appendTo(this); -    }); +  ngettext: (singular, plural, n) => { +    const translated = Documentation.TRANSLATIONS[singular]; +    if (typeof translated !== "undefined") +      return translated[Documentation.PLURAL_EXPR(n)]; +    return n === 1 ? singular : plural;    }, -  /** -   * workaround a firefox stupidity -   * see: https://bugzilla.mozilla.org/show_bug.cgi?id=645075 -   */ -  fixFirefoxAnchorBug : function() { -    if (document.location.hash && $.browser.mozilla) -      window.setTimeout(function() { -        document.location.href += ''; -      }, 10); +  addTranslations: (catalog) => { +    Object.assign(Documentation.TRANSLATIONS, catalog.messages); +    Documentation.PLURAL_EXPR = new Function( +      "n", +      `return (${catalog.plural_expr})` +    ); +    Documentation.LOCALE = catalog.locale;    },    /**     * 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); -      $('<p class="highlight-link"><a href="javascript:Documentation.' + -        'hideSearchWords()">' + _('Hide Search Matches') + '</a></p>') -          .appendTo($('#searchbox')); -    } -  }, +  highlightSearchWords: () => { +    const highlight = +      new URLSearchParams(window.location.search).get("highlight") || ""; +    const terms = highlight.toLowerCase().split(/\s+/).filter(x => x); +    if (terms.length === 0) return; // nothing to do -  /** -   * 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(); -    } +    // There should never be more than one element matching "div.body" +    const divBody = document.querySelectorAll("div.body"); +    const body = divBody.length ? divBody[0] : document.querySelector("body"); +    window.setTimeout(() => { +      terms.forEach((term) => _highlightText(body, term, "highlighted")); +    }, 10); + +    const searchBox = document.getElementById("searchbox"); +    if (searchBox === null) return; +    searchBox.appendChild( +      document +        .createRange() +        .createContextualFragment( +          '<p class="highlight-link">' + +            '<a href="javascript:Documentation.hideSearchWords()">' + +            Documentation.gettext("Hide Search Matches") + +            "</a></p>" +        ) +    );    },    /**     * helper function to hide the search marks again     */ -  hideSearchWords : function() { -    $('#searchbox .highlight-link').fadeOut(300); -    $('span.highlighted').removeClass('highlighted'); -    var url = new URL(window.location); -    url.searchParams.delete('highlight'); -    window.history.replaceState({}, '', url); +  hideSearchWords: () => { +    document +      .querySelectorAll("#searchbox .highlight-link") +      .forEach((el) => el.remove()); +    document +      .querySelectorAll("span.highlighted") +      .forEach((el) => el.classList.remove("highlighted")); +    const url = new URL(window.location); +    url.searchParams.delete("highlight"); +    window.history.replaceState({}, "", url);    }, -   /** +  /**     * helper function to focus on search bar     */ -  focusSearchBar : function() { -    $('input[name=q]').first().focus(); +  focusSearchBar: () => { +    document.querySelectorAll("input[name=q]")[0]?.focus();    },    /** -   * make the url absolute +   * Initialise the domain index toggle buttons     */ -  makeURL : function(relativeURL) { -    return DOCUMENTATION_OPTIONS.URL_ROOT + '/' + relativeURL; -  }, +  initDomainIndexTable: () => { +    const toggler = (el) => { +      const idNumber = el.id.substr(7); +      const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`); +      if (el.src.substr(-9) === "minus.png") { +        el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`; +        toggledRows.forEach((el) => (el.style.display = "none")); +      } else { +        el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`; +        toggledRows.forEach((el) => (el.style.display = "")); +      } +    }; -  /** -   * 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); +    const togglerElements = document.querySelectorAll("img.toggler"); +    togglerElements.forEach((el) => +      el.addEventListener("click", (event) => toggler(event.currentTarget)) +    ); +    togglerElements.forEach((el) => (el.style.display = "")); +    if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler);    }, -  initOnKeyListeners: function() { +  initOnKeyListeners: () => {      // only install a listener if it is really needed -    if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && -        !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -        return; +    if ( +      !DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && +      !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS +    ) +      return; -    $(document).keydown(function(event) { -      var activeElementType = document.activeElement.tagName; -      // don't navigate when in search box, textarea, dropdown or button -      if (activeElementType !== 'TEXTAREA' && activeElementType !== 'INPUT' && activeElementType !== 'SELECT' -          && activeElementType !== 'BUTTON') { -        if (event.altKey || event.ctrlKey || event.metaKey) -          return; +    const blacklistedElements = new Set([ +      "TEXTAREA", +      "INPUT", +      "SELECT", +      "BUTTON", +    ]); +    document.addEventListener("keydown", (event) => { +      if (blacklistedElements.has(document.activeElement.tagName)) return; // bail for input elements +      if (event.altKey || event.ctrlKey || event.metaKey) return; // bail with special keys -          if (!event.shiftKey) { -            switch (event.key) { -              case 'ArrowLeft': -                if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) -                  break; -                var prevHref = $('link[rel="prev"]').prop('href'); -                if (prevHref) { -                  window.location.href = prevHref; -                  return false; -                } -                break; -              case 'ArrowRight': -                if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) -                  break; -                var nextHref = $('link[rel="next"]').prop('href'); -                if (nextHref) { -                  window.location.href = nextHref; -                  return false; -                } -                break; -              case 'Escape': -                if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -                  break; -                Documentation.hideSearchWords(); -                return false; -          } -        } - -        // some keyboard layouts may need Shift to get / +      if (!event.shiftKey) {          switch (event.key) { -          case '/': -            if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -              break; -            Documentation.focusSearchBar(); -            return false; +          case "ArrowLeft": +            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + +            const prevLink = document.querySelector('link[rel="prev"]'); +            if (prevLink && prevLink.href) { +              window.location.href = prevLink.href; +              event.preventDefault(); +            } +            break; +          case "ArrowRight": +            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + +            const nextLink = document.querySelector('link[rel="next"]'); +            if (nextLink && nextLink.href) { +              window.location.href = nextLink.href; +              event.preventDefault(); +            } +            break; +          case "Escape": +            if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; +            Documentation.hideSearchWords(); +            event.preventDefault();          }        } + +      // some keyboard layouts may need Shift to get / +      switch (event.key) { +        case "/": +          if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; +          Documentation.focusSearchBar(); +          event.preventDefault(); +      }      }); -  } +  },  };  // quick alias for translations -_ = Documentation.gettext; +const _ = Documentation.gettext; -$(document).ready(function() { -  Documentation.init(); -}); +_ready(Documentation.init); diff --git a/_static/documentation_options.js b/_static/documentation_options.js index e4e08a75..5414fbe2 100644 --- a/_static/documentation_options.js +++ b/_static/documentation_options.js @@ -1,7 +1,7 @@  var DOCUMENTATION_OPTIONS = {      URL_ROOT: document.getElementById("documentation_options").getAttribute('data-url_root'),      VERSION: '7.1.1', -    LANGUAGE: 'None', +    LANGUAGE: 'en',      COLLAPSE_INDEX: false,      BUILDER: 'html',      FILE_SUFFIX: '.html', @@ -10,5 +10,5 @@ var DOCUMENTATION_OPTIONS = {      SOURCELINK_SUFFIX: '.txt',      NAVIGATION_WITH_KEYS: false,      SHOW_SEARCH_SUMMARY: true, -    ENABLE_SEARCH_SHORTCUTS: true, +    ENABLE_SEARCH_SHORTCUTS: false,  };
\ No newline at end of file diff --git a/_static/jquery-3.5.1.js b/_static/jquery-3.6.0.js index 50937333..fc6c299b 100644 --- a/_static/jquery-3.5.1.js +++ b/_static/jquery-3.6.0.js @@ -1,15 +1,15 @@  /*! - * jQuery JavaScript Library v3.5.1 + * jQuery JavaScript Library v3.6.0   * https://jquery.com/   *   * Includes Sizzle.js   * https://sizzlejs.com/   * - * Copyright JS Foundation and other contributors + * Copyright OpenJS Foundation and other contributors   * Released under the MIT license   * https://jquery.org/license   * - * Date: 2020-05-04T22:49Z + * Date: 2021-03-02T17:08Z   */  ( function( global, factory ) { @@ -76,12 +76,16 @@ var support = {};  var isFunction = function isFunction( obj ) { -      // Support: Chrome <=57, Firefox <=52 -      // In some browsers, typeof returns "function" for HTML <object> elements -      // (i.e., `typeof document.createElement( "object" ) === "function"`). -      // We don't want to classify *any* DOM node as a function. -      return typeof obj === "function" && typeof obj.nodeType !== "number"; -  }; +		// Support: Chrome <=57, Firefox <=52 +		// In some browsers, typeof returns "function" for HTML <object> elements +		// (i.e., `typeof document.createElement( "object" ) === "function"`). +		// We don't want to classify *any* DOM node as a function. +		// Support: QtWeb <=3.8.5, WebKit <=534.34, wkhtmltopdf tool <=0.12.5 +		// Plus for old WebKit, typeof returns "function" for HTML collections +		// (e.g., `typeof document.getElementsByTagName("div") === "function"`). (gh-4756) +		return typeof obj === "function" && typeof obj.nodeType !== "number" && +			typeof obj.item !== "function"; +	};  var isWindow = function isWindow( obj ) { @@ -147,7 +151,7 @@ function toType( obj ) {  var -	version = "3.5.1", +	version = "3.6.0",  	// Define a local copy of jQuery  	jQuery = function( selector, context ) { @@ -401,7 +405,7 @@ jQuery.extend( {  			if ( isArrayLike( Object( arr ) ) ) {  				jQuery.merge( ret,  					typeof arr === "string" ? -					[ arr ] : arr +						[ arr ] : arr  				);  			} else {  				push.call( ret, arr ); @@ -496,9 +500,9 @@ if ( typeof Symbol === "function" ) {  // Populate the class2type map  jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ), -function( _i, name ) { -	class2type[ "[object " + name + "]" ] = name.toLowerCase(); -} ); +	function( _i, name ) { +		class2type[ "[object " + name + "]" ] = name.toLowerCase(); +	} );  function isArrayLike( obj ) { @@ -518,14 +522,14 @@ function isArrayLike( obj ) {  }  var Sizzle =  /*! - * Sizzle CSS Selector Engine v2.3.5 + * Sizzle CSS Selector Engine v2.3.6   * https://sizzlejs.com/   *   * Copyright JS Foundation and other contributors   * Released under the MIT license   * https://js.foundation/   * - * Date: 2020-03-14 + * Date: 2021-02-16   */  ( function( window ) {  var i, @@ -1108,8 +1112,8 @@ support = Sizzle.support = {};   * @returns {Boolean} True iff elem is a non-HTML XML node   */  isXML = Sizzle.isXML = function( elem ) { -	var namespace = elem.namespaceURI, -		docElem = ( elem.ownerDocument || elem ).documentElement; +	var namespace = elem && elem.namespaceURI, +		docElem = elem && ( elem.ownerDocument || elem ).documentElement;  	// Support: IE <=8  	// Assume HTML when documentElement doesn't yet exist, such as inside loading iframes @@ -3024,9 +3028,9 @@ var rneedsContext = jQuery.expr.match.needsContext;  function nodeName( elem, name ) { -  return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); +	return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); -}; +}  var rsingleTag = ( /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i ); @@ -3997,8 +4001,8 @@ jQuery.extend( {  			resolveContexts = Array( i ),  			resolveValues = slice.call( arguments ), -			// the master Deferred -			master = jQuery.Deferred(), +			// the primary Deferred +			primary = jQuery.Deferred(),  			// subordinate callback factory  			updateFunc = function( i ) { @@ -4006,30 +4010,30 @@ jQuery.extend( {  					resolveContexts[ i ] = this;  					resolveValues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value;  					if ( !( --remaining ) ) { -						master.resolveWith( resolveContexts, resolveValues ); +						primary.resolveWith( resolveContexts, resolveValues );  					}  				};  			};  		// Single- and empty arguments are adopted like Promise.resolve  		if ( remaining <= 1 ) { -			adoptValue( singleValue, master.done( updateFunc( i ) ).resolve, master.reject, +			adoptValue( singleValue, primary.done( updateFunc( i ) ).resolve, primary.reject,  				!remaining );  			// Use .then() to unwrap secondary thenables (cf. gh-3000) -			if ( master.state() === "pending" || +			if ( primary.state() === "pending" ||  				isFunction( resolveValues[ i ] && resolveValues[ i ].then ) ) { -				return master.then(); +				return primary.then();  			}  		}  		// Multiple arguments are aggregated like Promise.all array elements  		while ( i-- ) { -			adoptValue( resolveValues[ i ], updateFunc( i ), master.reject ); +			adoptValue( resolveValues[ i ], updateFunc( i ), primary.reject );  		} -		return master.promise(); +		return primary.promise();  	}  } ); @@ -4180,8 +4184,8 @@ var access = function( elems, fn, key, value, chainable, emptyGet, raw ) {  			for ( ; i < len; i++ ) {  				fn(  					elems[ i ], key, raw ? -					value : -					value.call( elems[ i ], i, fn( elems[ i ], key ) ) +						value : +						value.call( elems[ i ], i, fn( elems[ i ], key ) )  				);  			}  		} @@ -5089,10 +5093,7 @@ function buildFragment( elems, context, scripts, selection, ignored ) {  } -var -	rkeyEvent = /^key/, -	rmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/, -	rtypenamespace = /^([^.]*)(?:\.(.+)|)/; +var rtypenamespace = /^([^.]*)(?:\.(.+)|)/;  function returnTrue() {  	return true; @@ -5387,8 +5388,8 @@ jQuery.event = {  			event = jQuery.event.fix( nativeEvent ),  			handlers = ( -					dataPriv.get( this, "events" ) || Object.create( null ) -				)[ event.type ] || [], +				dataPriv.get( this, "events" ) || Object.create( null ) +			)[ event.type ] || [],  			special = jQuery.event.special[ event.type ] || {};  		// Use the fix-ed jQuery.Event rather than the (read-only) native event @@ -5512,12 +5513,12 @@ jQuery.event = {  			get: isFunction( hook ) ?  				function() {  					if ( this.originalEvent ) { -							return hook( this.originalEvent ); +						return hook( this.originalEvent );  					}  				} :  				function() {  					if ( this.originalEvent ) { -							return this.originalEvent[ name ]; +						return this.originalEvent[ name ];  					}  				}, @@ -5656,7 +5657,13 @@ function leverageNative( el, type, expectSync ) {  						// Cancel the outer synthetic event  						event.stopImmediatePropagation();  						event.preventDefault(); -						return result.value; + +						// Support: Chrome 86+ +						// In Chrome, if an element having a focusout handler is blurred by +						// clicking outside of it, it invokes the handler synchronously. If +						// that handler calls `.remove()` on the element, the data is cleared, +						// leaving `result` undefined. We need to guard against this. +						return result && result.value;  					}  				// If this is an inner synthetic event for an event with a bubbling surrogate @@ -5821,34 +5828,7 @@ jQuery.each( {  	targetTouches: true,  	toElement: true,  	touches: true, - -	which: function( event ) { -		var button = event.button; - -		// Add which for key events -		if ( event.which == null && rkeyEvent.test( event.type ) ) { -			return event.charCode != null ? event.charCode : event.keyCode; -		} - -		// Add which for click: 1 === left; 2 === middle; 3 === right -		if ( !event.which && button !== undefined && rmouseEvent.test( event.type ) ) { -			if ( button & 1 ) { -				return 1; -			} - -			if ( button & 2 ) { -				return 3; -			} - -			if ( button & 4 ) { -				return 2; -			} - -			return 0; -		} - -		return event.which; -	} +	which: true  }, jQuery.event.addProp );  jQuery.each( { focus: "focusin", blur: "focusout" }, function( type, delegateType ) { @@ -5874,6 +5854,12 @@ jQuery.each( { focus: "focusin", blur: "focusout" }, function( type, delegateTyp  			return true;  		}, +		// Suppress native focus or blur as it's already being fired +		// in leverageNative. +		_default: function() { +			return true; +		}, +  		delegateType: delegateType  	};  } ); @@ -6541,6 +6527,10 @@ var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" );  		// set in CSS while `offset*` properties report correct values.  		// Behavior in IE 9 is more subtle than in newer versions & it passes  		// some versions of this test; make sure not to make it pass there! +		// +		// Support: Firefox 70+ +		// Only Firefox includes border widths +		// in computed dimensions. (gh-4529)  		reliableTrDimensions: function() {  			var table, tr, trChild, trStyle;  			if ( reliableTrDimensionsVal == null ) { @@ -6548,17 +6538,32 @@ var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" );  				tr = document.createElement( "tr" );  				trChild = document.createElement( "div" ); -				table.style.cssText = "position:absolute;left:-11111px"; +				table.style.cssText = "position:absolute;left:-11111px;border-collapse:separate"; +				tr.style.cssText = "border:1px solid"; + +				// Support: Chrome 86+ +				// Height set through cssText does not get applied. +				// Computed height then comes back as 0.  				tr.style.height = "1px";  				trChild.style.height = "9px"; +				// Support: Android 8 Chrome 86+ +				// In our bodyBackground.html iframe, +				// display for all div elements is set to "inline", +				// which causes a problem only in Android 8 Chrome 86. +				// Ensuring the div is display: block +				// gets around this issue. +				trChild.style.display = "block"; +  				documentElement  					.appendChild( table )  					.appendChild( tr )  					.appendChild( trChild );  				trStyle = window.getComputedStyle( tr ); -				reliableTrDimensionsVal = parseInt( trStyle.height ) > 3; +				reliableTrDimensionsVal = ( parseInt( trStyle.height, 10 ) + +					parseInt( trStyle.borderTopWidth, 10 ) + +					parseInt( trStyle.borderBottomWidth, 10 ) ) === tr.offsetHeight;  				documentElement.removeChild( table );  			} @@ -7022,10 +7027,10 @@ jQuery.each( [ "height", "width" ], function( _i, dimension ) {  					// Running getBoundingClientRect on a disconnected node  					// in IE throws an error.  					( !elem.getClientRects().length || !elem.getBoundingClientRect().width ) ? -						swap( elem, cssShow, function() { -							return getWidthOrHeight( elem, dimension, extra ); -						} ) : -						getWidthOrHeight( elem, dimension, extra ); +					swap( elem, cssShow, function() { +						return getWidthOrHeight( elem, dimension, extra ); +					} ) : +					getWidthOrHeight( elem, dimension, extra );  			}  		}, @@ -7084,7 +7089,7 @@ jQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft,  					swap( elem, { marginLeft: 0 }, function() {  						return elem.getBoundingClientRect().left;  					} ) -				) + "px"; +			) + "px";  		}  	}  ); @@ -7223,7 +7228,7 @@ Tween.propHooks = {  			if ( jQuery.fx.step[ tween.prop ] ) {  				jQuery.fx.step[ tween.prop ]( tween );  			} else if ( tween.elem.nodeType === 1 && ( -					jQuery.cssHooks[ tween.prop ] || +				jQuery.cssHooks[ tween.prop ] ||  					tween.elem.style[ finalPropName( tween.prop ) ] != null ) ) {  				jQuery.style( tween.elem, tween.prop, tween.now + tween.unit );  			} else { @@ -7468,7 +7473,7 @@ function defaultPrefilter( elem, props, opts ) {  			anim.done( function() { -			/* eslint-enable no-loop-func */ +				/* eslint-enable no-loop-func */  				// The final step of a "hide" animation is actually hiding the element  				if ( !hidden ) { @@ -7588,7 +7593,7 @@ function Animation( elem, properties, options ) {  			tweens: [],  			createTween: function( prop, end ) {  				var tween = jQuery.Tween( elem, animation.opts, prop, end, -						animation.opts.specialEasing[ prop ] || animation.opts.easing ); +					animation.opts.specialEasing[ prop ] || animation.opts.easing );  				animation.tweens.push( tween );  				return tween;  			}, @@ -7761,7 +7766,8 @@ jQuery.fn.extend( {  					anim.stop( true );  				}  			}; -			doAnimation.finish = doAnimation; + +		doAnimation.finish = doAnimation;  		return empty || optall.queue === false ?  			this.each( doAnimation ) : @@ -8401,8 +8407,8 @@ jQuery.fn.extend( {  				if ( this.setAttribute ) {  					this.setAttribute( "class",  						className || value === false ? -						"" : -						dataPriv.get( this, "__className__" ) || "" +							"" : +							dataPriv.get( this, "__className__" ) || ""  					);  				}  			} @@ -8417,7 +8423,7 @@ jQuery.fn.extend( {  		while ( ( elem = this[ i++ ] ) ) {  			if ( elem.nodeType === 1 &&  				( " " + stripAndCollapse( getClass( elem ) ) + " " ).indexOf( className ) > -1 ) { -					return true; +				return true;  			}  		} @@ -8707,9 +8713,7 @@ jQuery.extend( jQuery.event, {  				special.bindType || type;  			// jQuery handler -			handle = ( -					dataPriv.get( cur, "events" ) || Object.create( null ) -				)[ event.type ] && +			handle = ( dataPriv.get( cur, "events" ) || Object.create( null ) )[ event.type ] &&  				dataPriv.get( cur, "handle" );  			if ( handle ) {  				handle.apply( cur, data ); @@ -8856,7 +8860,7 @@ var rquery = ( /\?/ );  // Cross-browser xml parsing  jQuery.parseXML = function( data ) { -	var xml; +	var xml, parserErrorElem;  	if ( !data || typeof data !== "string" ) {  		return null;  	} @@ -8865,12 +8869,17 @@ jQuery.parseXML = function( data ) {  	// IE throws on parseFromString with invalid input.  	try {  		xml = ( new window.DOMParser() ).parseFromString( data, "text/xml" ); -	} catch ( e ) { -		xml = undefined; -	} +	} catch ( e ) {} -	if ( !xml || xml.getElementsByTagName( "parsererror" ).length ) { -		jQuery.error( "Invalid XML: " + data ); +	parserErrorElem = xml && xml.getElementsByTagName( "parsererror" )[ 0 ]; +	if ( !xml || parserErrorElem ) { +		jQuery.error( "Invalid XML: " + ( +			parserErrorElem ? +				jQuery.map( parserErrorElem.childNodes, function( el ) { +					return el.textContent; +				} ).join( "\n" ) : +				data +		) );  	}  	return xml;  }; @@ -8971,16 +8980,14 @@ jQuery.fn.extend( {  			// Can add propHook for "elements" to filter or add form elements  			var elements = jQuery.prop( this, "elements" );  			return elements ? jQuery.makeArray( elements ) : this; -		} ) -		.filter( function() { +		} ).filter( function() {  			var type = this.type;  			// Use .is( ":disabled" ) so that fieldset[disabled] works  			return this.name && !jQuery( this ).is( ":disabled" ) &&  				rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) &&  				( this.checked || !rcheckableType.test( type ) ); -		} ) -		.map( function( _i, elem ) { +		} ).map( function( _i, elem ) {  			var val = jQuery( this ).val();  			if ( val == null ) { @@ -9033,7 +9040,8 @@ var  	// Anchor tag for parsing the document origin  	originAnchor = document.createElement( "a" ); -	originAnchor.href = location.href; + +originAnchor.href = location.href;  // Base "constructor" for jQuery.ajaxPrefilter and jQuery.ajaxTransport  function addToPrefiltersOrTransports( structure ) { @@ -9414,8 +9422,8 @@ jQuery.extend( {  			// Context for global events is callbackContext if it is a DOM node or jQuery collection  			globalEventContext = s.context &&  				( callbackContext.nodeType || callbackContext.jquery ) ? -					jQuery( callbackContext ) : -					jQuery.event, +				jQuery( callbackContext ) : +				jQuery.event,  			// Deferreds  			deferred = jQuery.Deferred(), @@ -9727,8 +9735,10 @@ jQuery.extend( {  				response = ajaxHandleResponses( s, jqXHR, responses );  			} -			// Use a noop converter for missing script -			if ( !isSuccess && jQuery.inArray( "script", s.dataTypes ) > -1 ) { +			// Use a noop converter for missing script but not if jsonp +			if ( !isSuccess && +				jQuery.inArray( "script", s.dataTypes ) > -1 && +				jQuery.inArray( "json", s.dataTypes ) < 0 ) {  				s.converters[ "text script" ] = function() {};  			} @@ -10466,12 +10476,6 @@ jQuery.offset = {  			options.using.call( elem, props );  		} else { -			if ( typeof props.top === "number" ) { -				props.top += "px"; -			} -			if ( typeof props.left === "number" ) { -				props.left += "px"; -			}  			curElem.css( props );  		}  	} @@ -10640,8 +10644,11 @@ jQuery.each( [ "top", "left" ], function( _i, prop ) {  // Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods  jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { -	jQuery.each( { padding: "inner" + name, content: type, "": "outer" + name }, -		function( defaultExtra, funcName ) { +	jQuery.each( { +		padding: "inner" + name, +		content: type, +		"": "outer" + name +	}, function( defaultExtra, funcName ) {  		// Margin is only for outerHeight, outerWidth  		jQuery.fn[ funcName ] = function( margin, value ) { @@ -10726,7 +10733,8 @@ jQuery.fn.extend( {  	}  } ); -jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " + +jQuery.each( +	( "blur focus focusin focusout resize scroll click dblclick " +  	"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " +  	"change select submit keydown keypress keyup contextmenu" ).split( " " ),  	function( _i, name ) { @@ -10737,7 +10745,8 @@ jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " +  				this.on( name, null, data, fn ) :  				this.trigger( name );  		}; -	} ); +	} +); diff --git a/_static/jquery.js b/_static/jquery.js index b0614034..c4c6022f 100644 --- a/_static/jquery.js +++ b/_static/jquery.js @@ -1,2 +1,2 @@ -/*! jQuery v3.5.1 | (c) JS Foundation and other contributors | jquery.org/license */ -!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.5.1",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),D=function(e,t){return e===t&&(l=!0),0},j={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e.namespaceURI,n=(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&j.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(D),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(D).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function D(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(D(this,e||[],!1))},not:function(e){return this.pushStack(D(this,e||[],!0))},is:function(e){return!!D(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var j,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||j,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,j=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^key/,we=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,Te=/^([^.]*)(?:\.(.+)|)/;function Ce(){return!0}function Ee(){return!1}function Se(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function ke(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)ke(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Ee;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Ae(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,Ce)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=Te.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=Te.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Ae(t,"click",Ce),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Ae(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?Ce:Ee,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Ee,isPropagationStopped:Ee,isImmediatePropagationStopped:Ee,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=Ce,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=Ce,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=Ce,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:function(e){var t=e.button;return null==e.which&&be.test(e.type)?null!=e.charCode?e.charCode:e.keyCode:!e.which&&void 0!==t&&we.test(e.type)?1&t?1:2&t?3:4&t?2:0:e.which}},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Ae(this,e,Se),!1},trigger:function(){return Ae(this,e),!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return ke(this,e,t,n,r)},one:function(e,t,n,r){return ke(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Ee),this.each(function(){S.event.remove(this,e,n,t)})}});var Ne=/<script|<style|<link/i,De=/checked\s*(?:[^=]|=\s*.checked.)/i,je=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function qe(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function Le(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function He(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Oe(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function Pe(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&De.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),Pe(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),Le)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,He),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(je,""),u,l))}return n}function Re(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Oe(o[r],a[r]);else Oe(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Re(this,e,!0)},remove:function(e){return Re(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return Pe(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||qe(this,e).appendChild(e)})},prepend:function(){return Pe(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=qe(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return Pe(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return Pe(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!Ne.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return Pe(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Me=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Ie=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},We=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Fe=new RegExp(ne.join("|"),"i");function Be(e,t,n){var r,i,o,a,s=e.style;return(n=n||Ie(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Me.test(a)&&Fe.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function $e(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px",t.style.height="1px",n.style.height="9px",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=3<parseInt(r.height),re.removeChild(e)),a}}))}();var _e=["Webkit","Moz","ms"],ze=E.createElement("div").style,Ue={};function Xe(e){var t=S.cssProps[e]||Ue[e];return t||(e in ze?e:Ue[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=_e.length;while(n--)if((e=_e[n]+t)in ze)return e}(e)||e)}var Ve=/^(none|table(?!-c[ea]).+)/,Ge=/^--/,Ye={position:"absolute",visibility:"hidden",display:"block"},Qe={letterSpacing:"0",fontWeight:"400"};function Je(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Ke(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Ze(e,t,n){var r=Ie(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=Be(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Me.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Ke(e,t,n||(i?"border":"content"),o,r,a)+"px"}function et(e,t,n,r,i){return new et.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Be(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Ge.test(t),l=e.style;if(u||(t=Xe(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Ge.test(t)||(t=Xe(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=Be(e,t,r)),"normal"===i&&t in Qe&&(i=Qe[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ve.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Ze(e,u,n):We(e,Ye,function(){return Ze(e,u,n)})},set:function(e,t,n){var r,i=Ie(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Ke(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Ke(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Je(0,t,s)}}}),S.cssHooks.marginLeft=$e(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(Be(e,"marginLeft"))||e.getBoundingClientRect().left-We(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Je)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Ie(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=et).prototype={constructor:et,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=et.propHooks[this.prop];return e&&e.get?e.get(this):et.propHooks._default.get(this)},run:function(e){var t,n=et.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):et.propHooks._default.set(this),this}}).init.prototype=et.prototype,(et.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[Xe(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=et.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=et.prototype.init,S.fx.step={};var tt,nt,rt,it,ot=/^(?:toggle|show|hide)$/,at=/queueHooks$/;function st(){nt&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(st):C.setTimeout(st,S.fx.interval),S.fx.tick())}function ut(){return C.setTimeout(function(){tt=void 0}),tt=Date.now()}function lt(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ct(e,t,n){for(var r,i=(ft.tweeners[t]||[]).concat(ft.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function ft(o,e,t){var n,a,r=0,i=ft.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=tt||ut(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:tt||ut(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=ft.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ct,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(ft,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],ft.tweeners[n]=ft.tweeners[n]||[],ft.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],ot.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ct(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?ft.prefilters.unshift(e):ft.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=ft(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&at.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(lt(r,!0),e,t,n)}}),S.each({slideDown:lt("show"),slideUp:lt("hide"),slideToggle:lt("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(tt=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),tt=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){nt||(nt=!0,st())},S.fx.stop=function(){nt=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},rt=E.createElement("input"),it=E.createElement("select").appendChild(E.createElement("option")),rt.type="checkbox",y.checkOn=""!==rt.value,y.optSelected=it.selected,(rt=E.createElement("input")).value="t",rt.type="radio",y.radioValue="t"===rt.value;var pt,dt=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?pt:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),pt={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=dt[t]||S.find.attr;dt[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=dt[o],dt[o]=r,r=null!=a(e,t,n)?o:null,dt[o]=i),r}});var ht=/^(?:input|select|textarea|button)$/i,gt=/^(?:a|area)$/i;function vt(e){return(e.match(P)||[]).join(" ")}function yt(e){return e.getAttribute&&e.getAttribute("class")||""}function mt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):ht.test(e.nodeName)||gt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,yt(this)))});if((e=mt(t)).length)while(n=this[u++])if(i=yt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,yt(this)))});if(!arguments.length)return this.attr("class","");if((e=mt(t)).length)while(n=this[u++])if(i=yt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,yt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=mt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=yt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+vt(yt(n))+" ").indexOf(t))return!0;return!1}});var xt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(xt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:vt(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var bt=/^(?:focusinfocus|focusoutblur)$/,wt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!bt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,bt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,wt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,wt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var Tt=C.location,Ct={guid:Date.now()},Et=/\?/;S.parseXML=function(e){var t;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){t=void 0}return t&&!t.getElementsByTagName("parsererror").length||S.error("Invalid XML: "+e),t};var St=/\[\]$/,kt=/\r?\n/g,At=/^(?:submit|button|image|reset|file)$/i,Nt=/^(?:input|select|textarea|keygen)/i;function Dt(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||St.test(n)?i(n,t):Dt(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)Dt(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)Dt(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&Nt.test(this.nodeName)&&!At.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(kt,"\r\n")}}):{name:t.name,value:n.replace(kt,"\r\n")}}).get()}});var jt=/%20/g,qt=/#.*$/,Lt=/([?&])_=[^&]*/,Ht=/^(.*?):[ \t]*([^\r\n]*)$/gm,Ot=/^(?:GET|HEAD)$/,Pt=/^\/\//,Rt={},Mt={},It="*/".concat("*"),Wt=E.createElement("a");function Ft(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Bt(t,i,o,a){var s={},u=t===Mt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function $t(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Wt.href=Tt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:Tt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(Tt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":It,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?$t($t(e,S.ajaxSettings),t):$t(S.ajaxSettings,e)},ajaxPrefilter:Ft(Rt),ajaxTransport:Ft(Mt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=Ht.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||Tt.href)+"").replace(Pt,Tt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Wt.protocol+"//"+Wt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Bt(Rt,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Ot.test(v.type),f=v.url.replace(qt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(jt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Et.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Lt,"$1"),o=(Et.test(f)?"&":"?")+"_="+Ct.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+It+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Bt(Mt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var _t={0:200,1223:204},zt=S.ajaxSettings.xhr();y.cors=!!zt&&"withCredentials"in zt,y.ajax=zt=!!zt,S.ajaxTransport(function(i){var o,a;if(y.cors||zt&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(_t[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var Ut,Xt=[],Vt=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=Xt.pop()||S.expando+"_"+Ct.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Vt.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Vt.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Vt,"$1"+r):!1!==e.jsonp&&(e.url+=(Et.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,Xt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((Ut=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===Ut.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=vt(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):("number"==typeof f.top&&(f.top+="px"),"number"==typeof f.left&&(f.left+="px"),c.css(f))}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=$e(y.pixelPosition,function(e,t){if(t)return t=Be(e,n),Me.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Gt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Gt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Yt=C.jQuery,Qt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Qt),e&&C.jQuery===S&&(C.jQuery=Yt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S}); +/*! jQuery v3.6.0 | (c) OpenJS Foundation and other contributors | jquery.org/license */ +!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.6.0",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),j=function(e,t){return e===t&&(l=!0),0},D={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},j=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&D.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(j),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(j).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var D,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||D,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,D=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^([^.]*)(?:\.(.+)|)/;function we(){return!0}function Te(){return!1}function Ce(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function Ee(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)Ee(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Te;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Se(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n&&n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,we)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=be.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=be.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click",we),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?we:Te,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Te,isPropagationStopped:Te,isImmediatePropagationStopped:Te,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=we,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=we,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=we,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:!0},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Se(this,e,Ce),!1},trigger:function(){return Se(this,e),!0},_default:function(){return!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return Ee(this,e,t,n,r)},one:function(e,t,n,r){return Ee(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Te),this.each(function(){S.event.remove(this,e,n,t)})}});var ke=/<script|<style|<link/i,Ae=/checked\s*(?:[^=]|=\s*.checked.)/i,Ne=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function je(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function De(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function qe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Le(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function He(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&Ae.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),He(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),De)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,qe),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(Ne,""),u,l))}return n}function Oe(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Le(o[r],a[r]);else Le(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Oe(this,e,!0)},remove:function(e){return Oe(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return He(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||je(this,e).appendChild(e)})},prepend:function(){return He(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=je(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!ke.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return He(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Pe=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Re=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},Me=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Ie=new RegExp(ne.join("|"),"i");function We(e,t,n){var r,i,o,a,s=e.style;return(n=n||Re(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Pe.test(a)&&Ie.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function Fe(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px;border-collapse:separate",t.style.cssText="border:1px solid",t.style.height="1px",n.style.height="9px",n.style.display="block",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=parseInt(r.height,10)+parseInt(r.borderTopWidth,10)+parseInt(r.borderBottomWidth,10)===t.offsetHeight,re.removeChild(e)),a}}))}();var Be=["Webkit","Moz","ms"],$e=E.createElement("div").style,_e={};function ze(e){var t=S.cssProps[e]||_e[e];return t||(e in $e?e:_e[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=Be.length;while(n--)if((e=Be[n]+t)in $e)return e}(e)||e)}var Ue=/^(none|table(?!-c[ea]).+)/,Xe=/^--/,Ve={position:"absolute",visibility:"hidden",display:"block"},Ge={letterSpacing:"0",fontWeight:"400"};function Ye(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Qe(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Je(e,t,n){var r=Re(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=We(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Pe.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Qe(e,t,n||(i?"border":"content"),o,r,a)+"px"}function Ke(e,t,n,r,i){return new Ke.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=We(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Xe.test(t),l=e.style;if(u||(t=ze(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Xe.test(t)||(t=ze(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=We(e,t,r)),"normal"===i&&t in Ge&&(i=Ge[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ue.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Je(e,u,n):Me(e,Ve,function(){return Je(e,u,n)})},set:function(e,t,n){var r,i=Re(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Qe(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Qe(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Ye(0,t,s)}}}),S.cssHooks.marginLeft=Fe(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(We(e,"marginLeft"))||e.getBoundingClientRect().left-Me(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Ye)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Re(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=Ke).prototype={constructor:Ke,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=Ke.propHooks[this.prop];return e&&e.get?e.get(this):Ke.propHooks._default.get(this)},run:function(e){var t,n=Ke.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):Ke.propHooks._default.set(this),this}}).init.prototype=Ke.prototype,(Ke.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[ze(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=Ke.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=Ke.prototype.init,S.fx.step={};var Ze,et,tt,nt,rt=/^(?:toggle|show|hide)$/,it=/queueHooks$/;function ot(){et&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(ot):C.setTimeout(ot,S.fx.interval),S.fx.tick())}function at(){return C.setTimeout(function(){Ze=void 0}),Ze=Date.now()}function st(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ut(e,t,n){for(var r,i=(lt.tweeners[t]||[]).concat(lt.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function lt(o,e,t){var n,a,r=0,i=lt.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=Ze||at(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:Ze||at(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=lt.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ut,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(lt,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],lt.tweeners[n]=lt.tweeners[n]||[],lt.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],rt.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ut(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?lt.prefilters.unshift(e):lt.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=lt(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&it.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(st(r,!0),e,t,n)}}),S.each({slideDown:st("show"),slideUp:st("hide"),slideToggle:st("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(Ze=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),Ze=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){et||(et=!0,ot())},S.fx.stop=function(){et=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},tt=E.createElement("input"),nt=E.createElement("select").appendChild(E.createElement("option")),tt.type="checkbox",y.checkOn=""!==tt.value,y.optSelected=nt.selected,(tt=E.createElement("input")).value="t",tt.type="radio",y.radioValue="t"===tt.value;var ct,ft=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?ct:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),ct={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=ft[t]||S.find.attr;ft[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=ft[o],ft[o]=r,r=null!=a(e,t,n)?o:null,ft[o]=i),r}});var pt=/^(?:input|select|textarea|button)$/i,dt=/^(?:a|area)$/i;function ht(e){return(e.match(P)||[]).join(" ")}function gt(e){return e.getAttribute&&e.getAttribute("class")||""}function vt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):pt.test(e.nodeName)||dt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,gt(this)))});if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,gt(this)))});if(!arguments.length)return this.attr("class","");if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,gt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=vt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=gt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+ht(gt(n))+" ").indexOf(t))return!0;return!1}});var yt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(yt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:ht(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var mt=/^(?:focusinfocus|focusoutblur)$/,xt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!mt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,mt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,xt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,xt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var bt=C.location,wt={guid:Date.now()},Tt=/\?/;S.parseXML=function(e){var t,n;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){}return n=t&&t.getElementsByTagName("parsererror")[0],t&&!n||S.error("Invalid XML: "+(n?S.map(n.childNodes,function(e){return e.textContent}).join("\n"):e)),t};var Ct=/\[\]$/,Et=/\r?\n/g,St=/^(?:submit|button|image|reset|file)$/i,kt=/^(?:input|select|textarea|keygen)/i;function At(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||Ct.test(n)?i(n,t):At(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)At(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)At(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&kt.test(this.nodeName)&&!St.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(Et,"\r\n")}}):{name:t.name,value:n.replace(Et,"\r\n")}}).get()}});var Nt=/%20/g,jt=/#.*$/,Dt=/([?&])_=[^&]*/,qt=/^(.*?):[ \t]*([^\r\n]*)$/gm,Lt=/^(?:GET|HEAD)$/,Ht=/^\/\//,Ot={},Pt={},Rt="*/".concat("*"),Mt=E.createElement("a");function It(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Wt(t,i,o,a){var s={},u=t===Pt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function Ft(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Mt.href=bt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:bt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(bt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Rt,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Ft(Ft(e,S.ajaxSettings),t):Ft(S.ajaxSettings,e)},ajaxPrefilter:It(Ot),ajaxTransport:It(Pt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=qt.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||bt.href)+"").replace(Ht,bt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Mt.protocol+"//"+Mt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Wt(Ot,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Lt.test(v.type),f=v.url.replace(jt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(Nt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Tt.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Dt,"$1"),o=(Tt.test(f)?"&":"?")+"_="+wt.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+Rt+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Wt(Pt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&S.inArray("json",v.dataTypes)<0&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var Bt={0:200,1223:204},$t=S.ajaxSettings.xhr();y.cors=!!$t&&"withCredentials"in $t,y.ajax=$t=!!$t,S.ajaxTransport(function(i){var o,a;if(y.cors||$t&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(Bt[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var _t,zt=[],Ut=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=zt.pop()||S.expando+"_"+wt.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Ut.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Ut.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Ut,"$1"+r):!1!==e.jsonp&&(e.url+=(Tt.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,zt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((_t=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===_t.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=ht(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=Fe(y.pixelPosition,function(e,t){if(t)return t=We(e,n),Pe.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Xt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Xt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Vt=C.jQuery,Gt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Gt),e&&C.jQuery===S&&(C.jQuery=Vt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S}); diff --git a/_static/language_data.js b/_static/language_data.js index ebe2f03b..2e22b06a 100644 --- a/_static/language_data.js +++ b/_static/language_data.js @@ -10,7 +10,7 @@   *   */ -var stopwords = ["a","and","are","as","at","be","but","by","for","if","in","into","is","it","near","no","not","of","on","or","such","that","the","their","then","there","these","they","this","to","was","will","with"]; +var stopwords = ["a", "and", "are", "as", "at", "be", "but", "by", "for", "if", "in", "into", "is", "it", "near", "no", "not", "of", "on", "or", "such", "that", "the", "their", "then", "there", "these", "they", "this", "to", "was", "will", "with"];  /* Non-minified version is copied as a separate JS file, is available */ @@ -197,101 +197,3 @@ var Stemmer = function() {    }  } - - - -var splitChars = (function() { -    var result = {}; -    var singles = [96, 180, 187, 191, 215, 247, 749, 885, 903, 907, 909, 930, 1014, 1648, -         1748, 1809, 2416, 2473, 2481, 2526, 2601, 2609, 2612, 2615, 2653, 2702, -         2706, 2729, 2737, 2740, 2857, 2865, 2868, 2910, 2928, 2948, 2961, 2971, -         2973, 3085, 3089, 3113, 3124, 3213, 3217, 3241, 3252, 3295, 3341, 3345, -         3369, 3506, 3516, 3633, 3715, 3721, 3736, 3744, 3748, 3750, 3756, 3761, -         3781, 3912, 4239, 4347, 4681, 4695, 4697, 4745, 4785, 4799, 4801, 4823, -         4881, 5760, 5901, 5997, 6313, 7405, 8024, 8026, 8028, 8030, 8117, 8125, -         8133, 8181, 8468, 8485, 8487, 8489, 8494, 8527, 11311, 11359, 11687, 11695, -         11703, 11711, 11719, 11727, 11735, 12448, 12539, 43010, 43014, 43019, 43587, -         43696, 43713, 64286, 64297, 64311, 64317, 64319, 64322, 64325, 65141]; -    var i, j, start, end; -    for (i = 0; i < singles.length; i++) { -        result[singles[i]] = true; -    } -    var ranges = [[0, 47], [58, 64], [91, 94], [123, 169], [171, 177], [182, 184], [706, 709], -         [722, 735], [741, 747], [751, 879], [888, 889], [894, 901], [1154, 1161], -         [1318, 1328], [1367, 1368], [1370, 1376], [1416, 1487], [1515, 1519], [1523, 1568], -         [1611, 1631], [1642, 1645], [1750, 1764], [1767, 1773], [1789, 1790], [1792, 1807], -         [1840, 1868], [1958, 1968], [1970, 1983], [2027, 2035], [2038, 2041], [2043, 2047], -         [2070, 2073], [2075, 2083], [2085, 2087], [2089, 2307], [2362, 2364], [2366, 2383], -         [2385, 2391], [2402, 2405], [2419, 2424], [2432, 2436], [2445, 2446], [2449, 2450], -         [2483, 2485], [2490, 2492], [2494, 2509], [2511, 2523], [2530, 2533], [2546, 2547], -         [2554, 2564], [2571, 2574], [2577, 2578], [2618, 2648], [2655, 2661], [2672, 2673], -         [2677, 2692], [2746, 2748], [2750, 2767], [2769, 2783], [2786, 2789], [2800, 2820], -         [2829, 2830], [2833, 2834], [2874, 2876], [2878, 2907], [2914, 2917], [2930, 2946], -         [2955, 2957], [2966, 2968], [2976, 2978], [2981, 2983], [2987, 2989], [3002, 3023], -         [3025, 3045], [3059, 3076], [3130, 3132], [3134, 3159], [3162, 3167], [3170, 3173], -         [3184, 3191], [3199, 3204], [3258, 3260], [3262, 3293], [3298, 3301], [3312, 3332], -         [3386, 3388], [3390, 3423], [3426, 3429], [3446, 3449], [3456, 3460], [3479, 3481], -         [3518, 3519], [3527, 3584], [3636, 3647], [3655, 3663], [3674, 3712], [3717, 3718], -         [3723, 3724], [3726, 3731], [3752, 3753], [3764, 3772], [3774, 3775], [3783, 3791], -         [3802, 3803], [3806, 3839], [3841, 3871], [3892, 3903], [3949, 3975], [3980, 4095], -         [4139, 4158], [4170, 4175], [4182, 4185], [4190, 4192], [4194, 4196], [4199, 4205], -         [4209, 4212], [4226, 4237], [4250, 4255], [4294, 4303], [4349, 4351], [4686, 4687], -         [4702, 4703], [4750, 4751], [4790, 4791], [4806, 4807], [4886, 4887], [4955, 4968], -         [4989, 4991], [5008, 5023], [5109, 5120], [5741, 5742], [5787, 5791], [5867, 5869], -         [5873, 5887], [5906, 5919], [5938, 5951], [5970, 5983], [6001, 6015], [6068, 6102], -         [6104, 6107], [6109, 6111], [6122, 6127], [6138, 6159], [6170, 6175], [6264, 6271], -         [6315, 6319], [6390, 6399], [6429, 6469], [6510, 6511], [6517, 6527], [6572, 6592], -         [6600, 6607], [6619, 6655], [6679, 6687], [6741, 6783], [6794, 6799], [6810, 6822], -         [6824, 6916], [6964, 6980], [6988, 6991], [7002, 7042], [7073, 7085], [7098, 7167], -         [7204, 7231], [7242, 7244], [7294, 7400], [7410, 7423], [7616, 7679], [7958, 7959], -         [7966, 7967], [8006, 8007], [8014, 8015], [8062, 8063], [8127, 8129], [8141, 8143], -         [8148, 8149], [8156, 8159], [8173, 8177], [8189, 8303], [8306, 8307], [8314, 8318], -         [8330, 8335], [8341, 8449], [8451, 8454], [8456, 8457], [8470, 8472], [8478, 8483], -         [8506, 8507], [8512, 8516], [8522, 8525], [8586, 9311], [9372, 9449], [9472, 10101], -         [10132, 11263], [11493, 11498], [11503, 11516], [11518, 11519], [11558, 11567], -         [11622, 11630], [11632, 11647], [11671, 11679], [11743, 11822], [11824, 12292], -         [12296, 12320], [12330, 12336], [12342, 12343], [12349, 12352], [12439, 12444], -         [12544, 12548], [12590, 12592], [12687, 12689], [12694, 12703], [12728, 12783], -         [12800, 12831], [12842, 12880], [12896, 12927], [12938, 12976], [12992, 13311], -         [19894, 19967], [40908, 40959], [42125, 42191], [42238, 42239], [42509, 42511], -         [42540, 42559], [42592, 42593], [42607, 42622], [42648, 42655], [42736, 42774], -         [42784, 42785], [42889, 42890], [42893, 43002], [43043, 43055], [43062, 43071], -         [43124, 43137], [43188, 43215], [43226, 43249], [43256, 43258], [43260, 43263], -         [43302, 43311], [43335, 43359], [43389, 43395], [43443, 43470], [43482, 43519], -         [43561, 43583], [43596, 43599], [43610, 43615], [43639, 43641], [43643, 43647], -         [43698, 43700], [43703, 43704], [43710, 43711], [43715, 43738], [43742, 43967], -         [44003, 44015], [44026, 44031], [55204, 55215], [55239, 55242], [55292, 55295], -         [57344, 63743], [64046, 64047], [64110, 64111], [64218, 64255], [64263, 64274], -         [64280, 64284], [64434, 64466], [64830, 64847], [64912, 64913], [64968, 65007], -         [65020, 65135], [65277, 65295], [65306, 65312], [65339, 65344], [65371, 65381], -         [65471, 65473], [65480, 65481], [65488, 65489], [65496, 65497]]; -    for (i = 0; i < ranges.length; i++) { -        start = ranges[i][0]; -        end = ranges[i][1]; -        for (j = start; j <= end; j++) { -            result[j] = true; -        } -    } -    return result; -})(); - -function splitQuery(query) { -    var result = []; -    var start = -1; -    for (var i = 0; i < query.length; i++) { -        if (splitChars[query.charCodeAt(i)]) { -            if (start !== -1) { -                result.push(query.slice(start, i)); -                start = -1; -            } -        } else if (start === -1) { -            start = i; -        } -    } -    if (start !== -1) { -        result.push(query.slice(start)); -    } -    return result; -} - - diff --git a/_static/searchtools.js b/_static/searchtools.js index 0a44e858..ac4d5861 100644 --- a/_static/searchtools.js +++ b/_static/searchtools.js @@ -8,18 +8,20 @@   * :license: BSD, see LICENSE for details.   *   */ +"use strict"; -if (!Scorer) { -  /** -   * Simple result scoring code. -   */ +/** + * Simple result scoring code. + */ +if (typeof Scorer === "undefined") {    var Scorer = {      // Implement the following function to further tweak the score for each result -    // The function takes a result array [filename, title, anchor, descr, score] +    // The function takes a result array [docname, title, anchor, descr, score, filename]      // and returns the new score.      /* -    score: function(result) { -      return result[4]; +    score: result => { +      const [docname, title, anchor, descr, score, filename] = result +      return score      },      */ @@ -28,9 +30,11 @@ if (!Scorer) {      // or matches in the last dotted part of the object name      objPartialMatch: 6,      // Additive scores depending on the priority of the object -    objPrio: {0:  15,   // used to be importantResults -              1:  5,   // used to be objectResults -              2: -5},  // used to be unimportantResults +    objPrio: { +      0: 15, // used to be importantResults +      1: 5, // used to be objectResults +      2: -5, // used to be unimportantResults +    },      //  Used when the priority is not in the mapping.      objPrioDefault: 0, @@ -39,452 +43,455 @@ if (!Scorer) {      partialTitle: 7,      // query found in terms      term: 5, -    partialTerm: 2 +    partialTerm: 2,    };  } -if (!splitQuery) { -  function splitQuery(query) { -    return query.split(/\s+/); +const _removeChildren = (element) => { +  while (element && element.lastChild) element.removeChild(element.lastChild); +}; + +/** + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#escaping + */ +const _escapeRegExp = (string) => +  string.replace(/[.*+\-?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string + +const _displayItem = (item, highlightTerms, searchTerms) => { +  const docBuilder = DOCUMENTATION_OPTIONS.BUILDER; +  const docUrlRoot = DOCUMENTATION_OPTIONS.URL_ROOT; +  const docFileSuffix = DOCUMENTATION_OPTIONS.FILE_SUFFIX; +  const docLinkSuffix = DOCUMENTATION_OPTIONS.LINK_SUFFIX; +  const showSearchSummary = DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY; + +  const [docName, title, anchor, descr] = item; + +  let listItem = document.createElement("li"); +  let requestUrl; +  let linkUrl; +  if (docBuilder === "dirhtml") { +    // dirhtml builder +    let dirname = docName + "/"; +    if (dirname.match(/\/index\/$/)) +      dirname = dirname.substring(0, dirname.length - 6); +    else if (dirname === "index/") dirname = ""; +    requestUrl = docUrlRoot + dirname; +    linkUrl = requestUrl; +  } else { +    // normal html builders +    requestUrl = docUrlRoot + docName + docFileSuffix; +    linkUrl = docName + docLinkSuffix; +  } +  const params = new URLSearchParams(); +  params.set("highlight", [...highlightTerms].join(" ")); +  let linkEl = listItem.appendChild(document.createElement("a")); +  linkEl.href = linkUrl + "?" + params.toString() + anchor; +  linkEl.innerHTML = title; +  if (descr) +    listItem.appendChild(document.createElement("span")).innerText = +      " (" + descr + ")"; +  else if (showSearchSummary) +    fetch(requestUrl) +      .then((responseData) => responseData.text()) +      .then((data) => { +        if (data) +          listItem.appendChild( +            Search.makeSearchSummary(data, searchTerms, highlightTerms) +          ); +      }); +  Search.output.appendChild(listItem); +}; +const _finishSearch = (resultCount) => { +  Search.stopPulse(); +  Search.title.innerText = _("Search Results"); +  if (!resultCount) +    Search.status.innerText = Documentation.gettext( +      "Your search did not match any documents. Please make sure that all words are spelled correctly and that you've selected enough categories." +    ); +  else +    Search.status.innerText = _( +      `Search finished, found ${resultCount} page(s) matching the search query.` +    ); +}; +const _displayNextItem = ( +  results, +  resultCount, +  highlightTerms, +  searchTerms +) => { +  // results left, load the summary and display it +  // this is intended to be dynamic (don't sub resultsCount) +  if (results.length) { +    _displayItem(results.pop(), highlightTerms, searchTerms); +    setTimeout( +      () => _displayNextItem(results, resultCount, highlightTerms, searchTerms), +      5 +    );    } +  // search finished, update title and status message +  else _finishSearch(resultCount); +}; + +/** + * Default splitQuery function. Can be overridden in ``sphinx.search`` with a + * custom function per language. + * + * The regular expression works by splitting the string on consecutive characters + * that are not Unicode letters, numbers, underscores, or emoji characters. + * This is the same as ``\W+`` in Python, preserving the surrogate pair area. + */ +if (typeof splitQuery === "undefined") { +  var splitQuery = (query) => query +      .split(/[^\p{Letter}\p{Number}_\p{Emoji_Presentation}]+/gu) +      .filter(term => term)  // remove remaining empty strings  }  /**   * Search Module   */ -var Search = { - -  _index : null, -  _queued_query : null, -  _pulse_status : -1, - -  htmlToText : function(htmlString) { -      var virtualDocument = document.implementation.createHTMLDocument('virtual'); -      var htmlElement = $(htmlString, virtualDocument); -      htmlElement.find('.headerlink').remove(); -      docContent = htmlElement.find('[role=main]')[0]; -      if(docContent === undefined) { -          console.warn("Content block not found. Sphinx search tries to obtain it " + -                       "via '[role=main]'. Could you check your theme or template."); -          return ""; -      } -      return docContent.textContent || docContent.innerText; +const Search = { +  _index: null, +  _queued_query: null, +  _pulse_status: -1, + +  htmlToText: (htmlString) => { +    const htmlElement = document +      .createRange() +      .createContextualFragment(htmlString); +    _removeChildren(htmlElement.querySelectorAll(".headerlink")); +    const docContent = htmlElement.querySelector('[role="main"]'); +    if (docContent !== undefined) return docContent.textContent; +    console.warn( +      "Content block not found. Sphinx search tries to obtain it via '[role=main]'. Could you check your theme or template." +    ); +    return "";    }, -  init : function() { -      var params = $.getQueryParameters(); -      if (params.q) { -          var query = params.q[0]; -          $('input[name="q"]')[0].value = query; -          this.performSearch(query); -      } +  init: () => { +    const query = new URLSearchParams(window.location.search).get("q"); +    document +      .querySelectorAll('input[name="q"]') +      .forEach((el) => (el.value = query)); +    if (query) Search.performSearch(query);    }, -  loadIndex : function(url) { -    $.ajax({type: "GET", url: url, data: null, -            dataType: "script", cache: true, -            complete: function(jqxhr, textstatus) { -              if (textstatus != "success") { -                document.getElementById("searchindexloader").src = url; -              } -            }}); -  }, +  loadIndex: (url) => +    (document.body.appendChild(document.createElement("script")).src = url), -  setIndex : function(index) { -    var q; -    this._index = index; -    if ((q = this._queued_query) !== null) { -      this._queued_query = null; -      Search.query(q); +  setIndex: (index) => { +    Search._index = index; +    if (Search._queued_query !== null) { +      const query = Search._queued_query; +      Search._queued_query = null; +      Search.query(query);      }    }, -  hasIndex : function() { -      return this._index !== null; -  }, +  hasIndex: () => Search._index !== null, -  deferQuery : function(query) { -      this._queued_query = query; -  }, +  deferQuery: (query) => (Search._queued_query = query), -  stopPulse : function() { -      this._pulse_status = 0; -  }, +  stopPulse: () => (Search._pulse_status = -1), -  startPulse : function() { -    if (this._pulse_status >= 0) -        return; -    function pulse() { -      var i; +  startPulse: () => { +    if (Search._pulse_status >= 0) return; + +    const pulse = () => {        Search._pulse_status = (Search._pulse_status + 1) % 4; -      var dotString = ''; -      for (i = 0; i < Search._pulse_status; i++) -        dotString += '.'; -      Search.dots.text(dotString); -      if (Search._pulse_status > -1) -        window.setTimeout(pulse, 500); -    } +      Search.dots.innerText = ".".repeat(Search._pulse_status); +      if (Search._pulse_status >= 0) window.setTimeout(pulse, 500); +    };      pulse();    },    /**     * perform a search for something (or wait until index is loaded)     */ -  performSearch : function(query) { +  performSearch: (query) => {      // create the required interface elements -    this.out = $('#search-results'); -    this.title = $('<h2>' + _('Searching') + '</h2>').appendTo(this.out); -    this.dots = $('<span></span>').appendTo(this.title); -    this.status = $('<p class="search-summary"> </p>').appendTo(this.out); -    this.output = $('<ul class="search"/>').appendTo(this.out); - -    $('#search-progress').text(_('Preparing search...')); -    this.startPulse(); +    const searchText = document.createElement("h2"); +    searchText.textContent = _("Searching"); +    const searchSummary = document.createElement("p"); +    searchSummary.classList.add("search-summary"); +    searchSummary.innerText = ""; +    const searchList = document.createElement("ul"); +    searchList.classList.add("search"); + +    const out = document.getElementById("search-results"); +    Search.title = out.appendChild(searchText); +    Search.dots = Search.title.appendChild(document.createElement("span")); +    Search.status = out.appendChild(searchSummary); +    Search.output = out.appendChild(searchList); + +    const searchProgress = document.getElementById("search-progress"); +    // Some themes don't use the search progress node +    if (searchProgress) { +      searchProgress.innerText = _("Preparing search..."); +    } +    Search.startPulse();      // index already loaded, the browser was quick! -    if (this.hasIndex()) -      this.query(query); -    else -      this.deferQuery(query); +    if (Search.hasIndex()) Search.query(query); +    else Search.deferQuery(query);    },    /**     * execute search (requires search index to be loaded)     */ -  query : function(query) { -    var i; - -    // stem the searchterms and add them to the correct list -    var stemmer = new Stemmer(); -    var searchterms = []; -    var excluded = []; -    var hlterms = []; -    var tmp = splitQuery(query); -    var objectterms = []; -    for (i = 0; i < tmp.length; i++) { -      if (tmp[i] !== "") { -          objectterms.push(tmp[i].toLowerCase()); -      } +  query: (query) => { +    // stem the search terms and add them to the correct list +    const stemmer = new Stemmer(); +    const searchTerms = new Set(); +    const excludedTerms = new Set(); +    const highlightTerms = new Set(); +    const objectTerms = new Set(splitQuery(query.toLowerCase().trim())); +    splitQuery(query.trim()).forEach((queryTerm) => { +      const queryTermLower = queryTerm.toLowerCase(); + +      // maybe skip this "word" +      // stopwords array is from language_data.js +      if ( +        stopwords.indexOf(queryTermLower) !== -1 || +        queryTerm.match(/^\d+$/) +      ) +        return; -      if ($u.indexOf(stopwords, tmp[i].toLowerCase()) != -1 || tmp[i] === "") { -        // skip this "word" -        continue; -      }        // stem the word -      var word = stemmer.stemWord(tmp[i].toLowerCase()); -      var toAppend; +      let word = stemmer.stemWord(queryTermLower);        // select the correct list -      if (word[0] == '-') { -        toAppend = excluded; -        word = word.substr(1); -      } +      if (word[0] === "-") excludedTerms.add(word.substr(1));        else { -        toAppend = searchterms; -        hlterms.push(tmp[i].toLowerCase()); +        searchTerms.add(word); +        highlightTerms.add(queryTermLower);        } -      // only add if not already in the list -      if (!$u.contains(toAppend, word)) -        toAppend.push(word); -    } -    var highlightstring = '?highlight=' + $.urlencode(hlterms.join(" ")); - -    // console.debug('SEARCH: searching for:'); -    // console.info('required: ', searchterms); -    // console.info('excluded: ', excluded); +    }); -    // prepare search -    var terms = this._index.terms; -    var titleterms = this._index.titleterms; +    // console.debug("SEARCH: searching for:"); +    // console.info("required: ", [...searchTerms]); +    // console.info("excluded: ", [...excludedTerms]); -    // array of [filename, title, anchor, descr, score] -    var results = []; -    $('#search-progress').empty(); +    // array of [docname, title, anchor, descr, score, filename] +    let results = []; +    _removeChildren(document.getElementById("search-progress"));      // lookup as object -    for (i = 0; i < objectterms.length; i++) { -      var others = [].concat(objectterms.slice(0, i), -                             objectterms.slice(i+1, objectterms.length)); -      results = results.concat(this.performObjectSearch(objectterms[i], others)); -    } +    objectTerms.forEach((term) => +      results.push(...Search.performObjectSearch(term, objectTerms)) +    );      // lookup as search terms in fulltext -    results = results.concat(this.performTermsSearch(searchterms, excluded, terms, titleterms)); +    results.push(...Search.performTermsSearch(searchTerms, excludedTerms));      // let the scorer override scores with a custom scoring function -    if (Scorer.score) { -      for (i = 0; i < results.length; i++) -        results[i][4] = Scorer.score(results[i]); -    } +    if (Scorer.score) results.forEach((item) => (item[4] = Scorer.score(item)));      // now sort the results by score (in opposite order of appearance, since the      // display function below uses pop() to retrieve items) and then      // alphabetically -    results.sort(function(a, b) { -      var left = a[4]; -      var right = b[4]; -      if (left > right) { -        return 1; -      } else if (left < right) { -        return -1; -      } else { +    results.sort((a, b) => { +      const leftScore = a[4]; +      const rightScore = b[4]; +      if (leftScore === rightScore) {          // same score: sort alphabetically -        left = a[1].toLowerCase(); -        right = b[1].toLowerCase(); -        return (left > right) ? -1 : ((left < right) ? 1 : 0); +        const leftTitle = a[1].toLowerCase(); +        const rightTitle = b[1].toLowerCase(); +        if (leftTitle === rightTitle) return 0; +        return leftTitle > rightTitle ? -1 : 1; // inverted is intentional        } +      return leftScore > rightScore ? 1 : -1;      }); +    // remove duplicate search results +    // note the reversing of results, so that in the case of duplicates, the highest-scoring entry is kept +    let seen = new Set(); +    results = results.reverse().reduce((acc, result) => { +      let resultStr = result.slice(0, 4).concat([result[5]]).map(v => String(v)).join(','); +      if (!seen.has(resultStr)) { +        acc.push(result); +        seen.add(resultStr); +      } +      return acc; +    }, []); + +    results = results.reverse(); +      // for debugging      //Search.lastresults = results.slice();  // a copy -    //console.info('search results:', Search.lastresults); +    // console.info("search results:", Search.lastresults);      // print the results -    var resultCount = results.length; -    function displayNextItem() { -      // results left, load the summary and display it -      if (results.length) { -        var item = results.pop(); -        var listItem = $('<li></li>'); -        var requestUrl = ""; -        var linkUrl = ""; -        if (DOCUMENTATION_OPTIONS.BUILDER === 'dirhtml') { -          // dirhtml builder -          var dirname = item[0] + '/'; -          if (dirname.match(/\/index\/$/)) { -            dirname = dirname.substring(0, dirname.length-6); -          } else if (dirname == 'index/') { -            dirname = ''; -          } -          requestUrl = DOCUMENTATION_OPTIONS.URL_ROOT + dirname; -          linkUrl = requestUrl; - -        } else { -          // normal html builders -          requestUrl = DOCUMENTATION_OPTIONS.URL_ROOT + item[0] + DOCUMENTATION_OPTIONS.FILE_SUFFIX; -          linkUrl = item[0] + DOCUMENTATION_OPTIONS.LINK_SUFFIX; -        } -        listItem.append($('<a/>').attr('href', -            linkUrl + -            highlightstring + item[2]).html(item[1])); -        if (item[3]) { -          listItem.append($('<span> (' + item[3] + ')</span>')); -          Search.output.append(listItem); -          setTimeout(function() { -            displayNextItem(); -          }, 5); -        } else if (DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY) { -          $.ajax({url: requestUrl, -                  dataType: "text", -                  complete: function(jqxhr, textstatus) { -                    var data = jqxhr.responseText; -                    if (data !== '' && data !== undefined) { -                      var summary = Search.makeSearchSummary(data, searchterms, hlterms); -                      if (summary) { -                        listItem.append(summary); -                      } -                    } -                    Search.output.append(listItem); -                    setTimeout(function() { -                      displayNextItem(); -                    }, 5); -                  }}); -        } else { -          // just display title -          Search.output.append(listItem); -          setTimeout(function() { -            displayNextItem(); -          }, 5); -        } -      } -      // search finished, update title and status message -      else { -        Search.stopPulse(); -        Search.title.text(_('Search Results')); -        if (!resultCount) -          Search.status.text(_('Your search did not match any documents. Please make sure that all words are spelled correctly and that you\'ve selected enough categories.')); -        else -            Search.status.text(_('Search finished, found %s page(s) matching the search query.').replace('%s', resultCount)); -        Search.status.fadeIn(500); -      } -    } -    displayNextItem(); +    _displayNextItem(results, results.length, highlightTerms, searchTerms);    },    /**     * search for object names     */ -  performObjectSearch : function(object, otherterms) { -    var filenames = this._index.filenames; -    var docnames = this._index.docnames; -    var objects = this._index.objects; -    var objnames = this._index.objnames; -    var titles = this._index.titles; - -    var i; -    var results = []; - -    for (var prefix in objects) { -      for (var iMatch = 0; iMatch != objects[prefix].length; ++iMatch) { -        var match = objects[prefix][iMatch]; -        var name = match[4]; -        var fullname = (prefix ? prefix + '.' : '') + name; -        var fullnameLower = fullname.toLowerCase() -        if (fullnameLower.indexOf(object) > -1) { -          var score = 0; -          var parts = fullnameLower.split('.'); -          // check for different match types: exact matches of full name or -          // "last name" (i.e. last dotted part) -          if (fullnameLower == object || parts[parts.length - 1] == object) { -            score += Scorer.objNameMatch; -          // matches in last name -          } else if (parts[parts.length - 1].indexOf(object) > -1) { -            score += Scorer.objPartialMatch; -          } -          var objname = objnames[match[1]][2]; -          var title = titles[match[0]]; -          // If more than one term searched for, we require other words to be -          // found in the name/title/description -          if (otherterms.length > 0) { -            var haystack = (prefix + ' ' + name + ' ' + -                            objname + ' ' + title).toLowerCase(); -            var allfound = true; -            for (i = 0; i < otherterms.length; i++) { -              if (haystack.indexOf(otherterms[i]) == -1) { -                allfound = false; -                break; -              } -            } -            if (!allfound) { -              continue; -            } -          } -          var descr = objname + _(', in ') + title; - -          var anchor = match[3]; -          if (anchor === '') -            anchor = fullname; -          else if (anchor == '-') -            anchor = objnames[match[1]][1] + '-' + fullname; -          // add custom score for some objects according to scorer -          if (Scorer.objPrio.hasOwnProperty(match[2])) { -            score += Scorer.objPrio[match[2]]; -          } else { -            score += Scorer.objPrioDefault; -          } -          results.push([docnames[match[0]], fullname, '#'+anchor, descr, score, filenames[match[0]]]); -        } +  performObjectSearch: (object, objectTerms) => { +    const filenames = Search._index.filenames; +    const docNames = Search._index.docnames; +    const objects = Search._index.objects; +    const objNames = Search._index.objnames; +    const titles = Search._index.titles; + +    const results = []; + +    const objectSearchCallback = (prefix, match) => { +      const name = match[4] +      const fullname = (prefix ? prefix + "." : "") + name; +      const fullnameLower = fullname.toLowerCase(); +      if (fullnameLower.indexOf(object) < 0) return; + +      let score = 0; +      const parts = fullnameLower.split("."); + +      // check for different match types: exact matches of full name or +      // "last name" (i.e. last dotted part) +      if (fullnameLower === object || parts.slice(-1)[0] === object) +        score += Scorer.objNameMatch; +      else if (parts.slice(-1)[0].indexOf(object) > -1) +        score += Scorer.objPartialMatch; // matches in last name + +      const objName = objNames[match[1]][2]; +      const title = titles[match[0]]; + +      // If more than one term searched for, we require other words to be +      // found in the name/title/description +      const otherTerms = new Set(objectTerms); +      otherTerms.delete(object); +      if (otherTerms.size > 0) { +        const haystack = `${prefix} ${name} ${objName} ${title}`.toLowerCase(); +        if ( +          [...otherTerms].some((otherTerm) => haystack.indexOf(otherTerm) < 0) +        ) +          return;        } -    } +      let anchor = match[3]; +      if (anchor === "") anchor = fullname; +      else if (anchor === "-") anchor = objNames[match[1]][1] + "-" + fullname; + +      const descr = objName + _(", in ") + title; + +      // add custom score for some objects according to scorer +      if (Scorer.objPrio.hasOwnProperty(match[2])) +        score += Scorer.objPrio[match[2]]; +      else score += Scorer.objPrioDefault; + +      results.push([ +        docNames[match[0]], +        fullname, +        "#" + anchor, +        descr, +        score, +        filenames[match[0]], +      ]); +    }; +    Object.keys(objects).forEach((prefix) => +      objects[prefix].forEach((array) => +        objectSearchCallback(prefix, array) +      ) +    );      return results;    },    /** -   * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions -   */ -  escapeRegExp : function(string) { -    return string.replace(/[.*+\-?^${}()|[\]\\]/g, '\\$&'); // $& means the whole matched string -  }, - -  /**     * search for full-text terms in the index     */ -  performTermsSearch : function(searchterms, excluded, terms, titleterms) { -    var docnames = this._index.docnames; -    var filenames = this._index.filenames; -    var titles = this._index.titles; +  performTermsSearch: (searchTerms, excludedTerms) => { +    // prepare search +    const terms = Search._index.terms; +    const titleTerms = Search._index.titleterms; +    const docNames = Search._index.docnames; +    const filenames = Search._index.filenames; +    const titles = Search._index.titles; -    var i, j, file; -    var fileMap = {}; -    var scoreMap = {}; -    var results = []; +    const scoreMap = new Map(); +    const fileMap = new Map();      // perform the search on the required terms -    for (i = 0; i < searchterms.length; i++) { -      var word = searchterms[i]; -      var files = []; -      var _o = [ -        {files: terms[word], score: Scorer.term}, -        {files: titleterms[word], score: Scorer.title} +    searchTerms.forEach((word) => { +      const files = []; +      const arr = [ +        { files: terms[word], score: Scorer.term }, +        { files: titleTerms[word], score: Scorer.title },        ];        // add support for partial matches        if (word.length > 2) { -        var word_regex = this.escapeRegExp(word); -        for (var w in terms) { -          if (w.match(word_regex) && !terms[word]) { -            _o.push({files: terms[w], score: Scorer.partialTerm}) -          } -        } -        for (var w in titleterms) { -          if (w.match(word_regex) && !titleterms[word]) { -              _o.push({files: titleterms[w], score: Scorer.partialTitle}) -          } -        } +        const escapedWord = _escapeRegExp(word); +        Object.keys(terms).forEach((term) => { +          if (term.match(escapedWord) && !terms[word]) +            arr.push({ files: terms[term], score: Scorer.partialTerm }); +        }); +        Object.keys(titleTerms).forEach((term) => { +          if (term.match(escapedWord) && !titleTerms[word]) +            arr.push({ files: titleTerms[word], score: Scorer.partialTitle }); +        });        }        // no match but word was a required one -      if ($u.every(_o, function(o){return o.files === undefined;})) { -        break; -      } +      if (arr.every((record) => record.files === undefined)) return; +        // found search word in contents -      $u.each(_o, function(o) { -        var _files = o.files; -        if (_files === undefined) -          return - -        if (_files.length === undefined) -          _files = [_files]; -        files = files.concat(_files); - -        // set score for the word in each file to Scorer.term -        for (j = 0; j < _files.length; j++) { -          file = _files[j]; -          if (!(file in scoreMap)) -            scoreMap[file] = {}; -          scoreMap[file][word] = o.score; -        } +      arr.forEach((record) => { +        if (record.files === undefined) return; + +        let recordFiles = record.files; +        if (recordFiles.length === undefined) recordFiles = [recordFiles]; +        files.push(...recordFiles); + +        // set score for the word in each file +        recordFiles.forEach((file) => { +          if (!scoreMap.has(file)) scoreMap.set(file, {}); +          scoreMap.get(file)[word] = record.score; +        });        });        // create the mapping -      for (j = 0; j < files.length; j++) { -        file = files[j]; -        if (file in fileMap && fileMap[file].indexOf(word) === -1) -          fileMap[file].push(word); -        else -          fileMap[file] = [word]; -      } -    } +      files.forEach((file) => { +        if (fileMap.has(file) && fileMap.get(file).indexOf(word) === -1) +          fileMap.get(file).push(word); +        else fileMap.set(file, [word]); +      }); +    });      // now check if the files don't contain excluded terms -    for (file in fileMap) { -      var valid = true; - +    const results = []; +    for (const [file, wordList] of fileMap) {        // check if all requirements are matched -      var filteredTermCount = // as search terms with length < 3 are discarded: ignore -        searchterms.filter(function(term){return term.length > 2}).length + +      // as search terms with length < 3 are discarded +      const filteredTermCount = [...searchTerms].filter( +        (term) => term.length > 2 +      ).length;        if ( -        fileMap[file].length != searchterms.length && -        fileMap[file].length != filteredTermCount -      ) continue; +        wordList.length !== searchTerms.size && +        wordList.length !== filteredTermCount +      ) +        continue;        // ensure that none of the excluded terms is in the search result -      for (i = 0; i < excluded.length; i++) { -        if (terms[excluded[i]] == file || -            titleterms[excluded[i]] == file || -            $u.contains(terms[excluded[i]] || [], file) || -            $u.contains(titleterms[excluded[i]] || [], file)) { -          valid = false; -          break; -        } -      } +      if ( +        [...excludedTerms].some( +          (term) => +            terms[term] === file || +            titleTerms[term] === file || +            (terms[term] || []).includes(file) || +            (titleTerms[term] || []).includes(file) +        ) +      ) +        break; -      // if we have still a valid result we can add it to the result list -      if (valid) { -        // select one (max) score for the file. -        // for better ranking, we should calculate ranking by using words statistics like basic tf-idf... -        var score = $u.max($u.map(fileMap[file], function(w){return scoreMap[file][w]})); -        results.push([docnames[file], titles[file], '', null, score, filenames[file]]); -      } +      // select one (max) score for the file. +      const score = Math.max(...wordList.map((w) => scoreMap.get(file)[w])); +      // add result to the result list +      results.push([ +        docNames[file], +        titles[file], +        "", +        null, +        score, +        filenames[file], +      ]);      }      return results;    }, @@ -492,34 +499,33 @@ var Search = {    /**     * helper function to return a node containing the     * search summary for a given text. keywords is a list -   * of stemmed words, hlwords is the list of normal, unstemmed +   * of stemmed words, highlightWords is the list of normal, unstemmed     * words. the first one is used to find the occurrence, the     * latter for highlighting it.     */ -  makeSearchSummary : function(htmlText, keywords, hlwords) { -    var text = Search.htmlToText(htmlText); -    if (text == "") { -      return null; -    } -    var textLower = text.toLowerCase(); -    var start = 0; -    $.each(keywords, function() { -      var i = textLower.indexOf(this.toLowerCase()); -      if (i > -1) -        start = i; -    }); -    start = Math.max(start - 120, 0); -    var excerpt = ((start > 0) ? '...' : '') + -      $.trim(text.substr(start, 240)) + -      ((start + 240 - text.length) ? '...' : ''); -    var rv = $('<p class="context"></p>').text(excerpt); -    $.each(hlwords, function() { -      rv = rv.highlightText(this, 'highlighted'); -    }); -    return rv; -  } +  makeSearchSummary: (htmlText, keywords, highlightWords) => { +    const text = Search.htmlToText(htmlText).toLowerCase(); +    if (text === "") return null; + +    const actualStartPosition = [...keywords] +      .map((k) => text.indexOf(k.toLowerCase())) +      .filter((i) => i > -1) +      .slice(-1)[0]; +    const startWithContext = Math.max(actualStartPosition - 120, 0); + +    const top = startWithContext === 0 ? "" : "..."; +    const tail = startWithContext + 240 < text.length ? "..." : ""; + +    let summary = document.createElement("div"); +    summary.classList.add("context"); +    summary.innerText = top + text.substr(startWithContext, 240).trim() + tail; + +    highlightWords.forEach((highlightWord) => +      _highlightText(summary, highlightWord, "highlighted") +    ); + +    return summary; +  },  }; -$(document).ready(function() { -  Search.init(); -}); +_ready(Search.init); @@ -1,5 +1,5 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head>      <script>window.location.replace("./main/index.html")</script> @@ -7,7 +7,7 @@      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" /> @@ -57,6 +57,7 @@  <script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/main/.buildinfo b/main/.buildinfo index 2be3956f..daa2ef06 100644 --- a/main/.buildinfo +++ b/main/.buildinfo @@ -1,4 +1,4 @@  # 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: 137e9250f660d793795b8ee2e2608686 +config: 96a10fdfa79bbe2d34816588b08b0d2f  tags: 645f666f9bcd5a90fca523b33c5a78b7 diff --git a/main/.doctrees/changelog.doctree b/main/.doctrees/changelog.doctree Binary files differindex 95dc5939..23cd5528 100644 --- a/main/.doctrees/changelog.doctree +++ b/main/.doctrees/changelog.doctree diff --git a/main/.doctrees/environment.pickle b/main/.doctrees/environment.pickle Binary files differindex c771260c..fa26453d 100644 --- a/main/.doctrees/environment.pickle +++ b/main/.doctrees/environment.pickle diff --git a/main/.doctrees/index.doctree b/main/.doctrees/index.doctree Binary files differindex f670482b..b73b50a8 100644 --- a/main/.doctrees/index.doctree +++ b/main/.doctrees/index.doctree diff --git a/main/.doctrees/output/botcore.async_stats.doctree b/main/.doctrees/output/botcore.async_stats.doctree Binary files differindex 492e15c0..c04a2258 100644 --- a/main/.doctrees/output/botcore.async_stats.doctree +++ b/main/.doctrees/output/botcore.async_stats.doctree diff --git a/main/.doctrees/output/botcore.doctree b/main/.doctrees/output/botcore.doctree Binary files differindex 49558f22..912e52c1 100644 --- a/main/.doctrees/output/botcore.doctree +++ b/main/.doctrees/output/botcore.doctree diff --git a/main/.doctrees/output/botcore.exts.doctree b/main/.doctrees/output/botcore.exts.doctree Binary files differindex 9551c0e6..23d70542 100644 --- a/main/.doctrees/output/botcore.exts.doctree +++ b/main/.doctrees/output/botcore.exts.doctree diff --git a/main/.doctrees/output/botcore.site_api.doctree b/main/.doctrees/output/botcore.site_api.doctree Binary files differindex 5587442c..4b69b4de 100644 --- a/main/.doctrees/output/botcore.site_api.doctree +++ b/main/.doctrees/output/botcore.site_api.doctree diff --git a/main/.doctrees/output/botcore.utils.caching.doctree b/main/.doctrees/output/botcore.utils.caching.doctree Binary files differindex ec340b6d..9f31c3cb 100644 --- a/main/.doctrees/output/botcore.utils.caching.doctree +++ b/main/.doctrees/output/botcore.utils.caching.doctree diff --git a/main/.doctrees/output/botcore.utils.channel.doctree b/main/.doctrees/output/botcore.utils.channel.doctree Binary files differindex 2b0cbd39..04205a1a 100644 --- a/main/.doctrees/output/botcore.utils.channel.doctree +++ b/main/.doctrees/output/botcore.utils.channel.doctree diff --git a/main/.doctrees/output/botcore.utils.doctree b/main/.doctrees/output/botcore.utils.doctree Binary files differindex 99acefaa..9b63c1af 100644 --- a/main/.doctrees/output/botcore.utils.doctree +++ b/main/.doctrees/output/botcore.utils.doctree diff --git a/main/.doctrees/output/botcore.utils.logging.doctree b/main/.doctrees/output/botcore.utils.logging.doctree Binary files differindex 905f2ff3..d1366245 100644 --- a/main/.doctrees/output/botcore.utils.logging.doctree +++ b/main/.doctrees/output/botcore.utils.logging.doctree diff --git a/main/.doctrees/output/botcore.utils.members.doctree b/main/.doctrees/output/botcore.utils.members.doctree Binary files differindex a96c9f6b..7b9e73d9 100644 --- a/main/.doctrees/output/botcore.utils.members.doctree +++ b/main/.doctrees/output/botcore.utils.members.doctree diff --git a/main/.doctrees/output/botcore.utils.regex.doctree b/main/.doctrees/output/botcore.utils.regex.doctree Binary files differindex 864aee4a..598c3717 100644 --- a/main/.doctrees/output/botcore.utils.regex.doctree +++ b/main/.doctrees/output/botcore.utils.regex.doctree diff --git a/main/.doctrees/output/botcore.utils.scheduling.doctree b/main/.doctrees/output/botcore.utils.scheduling.doctree Binary files differindex 992ee017..7fa8adfb 100644 --- a/main/.doctrees/output/botcore.utils.scheduling.doctree +++ b/main/.doctrees/output/botcore.utils.scheduling.doctree diff --git a/main/_static/_sphinx_javascript_frameworks_compat.js b/main/_static/_sphinx_javascript_frameworks_compat.js new file mode 100644 index 00000000..8549469d --- /dev/null +++ b/main/_static/_sphinx_javascript_frameworks_compat.js @@ -0,0 +1,134 @@ +/* + * _sphinx_javascript_frameworks_compat.js + * ~~~~~~~~~~ + * + * Compatability shim for jQuery and underscores.js. + * + * WILL BE REMOVED IN Sphinx 6.0 + * xref RemovedInSphinx60Warning + * + */ + +/** + * select a different prefix for underscore + */ +$u = _.noConflict(); + + +/** + * small helper function to urldecode strings + * + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL + */ +jQuery.urldecode = function(x) { +    if (!x) { +        return x +    } +    return decodeURIComponent(x.replace(/\+/g, ' ')); +}; + +/** + * small helper function to urlencode strings + */ +jQuery.urlencode = encodeURIComponent; + +/** + * This function returns the parsed url parameters of the + * current request. Multiple values per key are supported, + * it will always return arrays of strings for the value parts. + */ +jQuery.getQueryParameters = function(s) { +    if (typeof s === 'undefined') +        s = document.location.search; +    var parts = s.substr(s.indexOf('?') + 1).split('&'); +    var result = {}; +    for (var i = 0; i < parts.length; i++) { +        var tmp = parts[i].split('=', 2); +        var key = jQuery.urldecode(tmp[0]); +        var value = jQuery.urldecode(tmp[1]); +        if (key in result) +            result[key].push(value); +        else +            result[key] = [value]; +    } +    return result; +}; + +/** + * highlight a given string on a jquery object by wrapping it in + * span elements with the given class name. + */ +jQuery.fn.highlightText = function(text, className) { +    function highlight(node, addItems) { +        if (node.nodeType === 3) { +            var val = node.nodeValue; +            var pos = val.toLowerCase().indexOf(text); +            if (pos >= 0 && +                !jQuery(node.parentNode).hasClass(className) && +                !jQuery(node.parentNode).hasClass("nohighlight")) { +                var span; +                var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg"); +                if (isInSVG) { +                    span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); +                } else { +                    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); +                if (isInSVG) { +                    var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"); +                    var bbox = node.parentElement.getBBox(); +                    rect.x.baseVal.value = bbox.x; +                    rect.y.baseVal.value = bbox.y; +                    rect.width.baseVal.value = bbox.width; +                    rect.height.baseVal.value = bbox.height; +                    rect.setAttribute('class', className); +                    addItems.push({ +                        "parent": node.parentNode, +                        "target": rect}); +                } +            } +        } +        else if (!jQuery(node).is("button, select, textarea")) { +            jQuery.each(node.childNodes, function() { +                highlight(this, addItems); +            }); +        } +    } +    var addItems = []; +    var result = this.each(function() { +        highlight(this, addItems); +    }); +    for (var i = 0; i < addItems.length; ++i) { +        jQuery(addItems[i].parent).before(addItems[i].target); +    } +    return result; +}; + +/* + * 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; +} diff --git a/main/_static/basic.css b/main/_static/basic.css index bf18350b..7d5974c3 100644 --- a/main/_static/basic.css +++ b/main/_static/basic.css @@ -222,7 +222,7 @@ table.modindextable td {  /* -- general body styles --------------------------------------------------- */  div.body { -    min-width: 450px; +    min-width: 360px;      max-width: 800px;  } @@ -236,7 +236,6 @@ div.body p, div.body dd, div.body li, div.body blockquote {  a.headerlink {      visibility: hidden;  } -  a.brackets:before,  span.brackets > a:before{      content: "["; @@ -247,6 +246,7 @@ span.brackets > a:after {      content: "]";  } +  h1:hover > a.headerlink,  h2:hover > a.headerlink,  h3:hover > a.headerlink, @@ -334,13 +334,11 @@ aside.sidebar {  p.sidebar-title {      font-weight: bold;  } -  div.admonition, div.topic, blockquote {      clear: left;  }  /* -- topics ---------------------------------------------------------------- */ -  div.topic {      border: 1px solid #ccc;      padding: 7px; @@ -428,10 +426,6 @@ table.docutils td, table.docutils th {      border-bottom: 1px solid #aaa;  } -table.footnote td, table.footnote th { -    border: 0 !important; -} -  th {      text-align: left;      padding-right: 5px; @@ -615,6 +609,7 @@ ul.simple p {      margin-bottom: 0;  } +/* Docutils 0.17 and older (footnotes & citations) */  dl.footnote > dt,  dl.citation > dt {      float: left; @@ -632,6 +627,33 @@ dl.citation > dd:after {      clear: both;  } +/* Docutils 0.18+ (footnotes & citations) */ +aside.footnote > span, +div.citation > span { +    float: left; +} +aside.footnote > span:last-of-type, +div.citation > span:last-of-type { +  padding-right: 0.5em; +} +aside.footnote > p { +  margin-left: 2em; +} +div.citation > p { +  margin-left: 4em; +} +aside.footnote > p:last-of-type, +div.citation > p:last-of-type { +    margin-bottom: 0em; +} +aside.footnote > p:last-of-type:after, +div.citation > p:last-of-type:after { +    content: ""; +    clear: both; +} + +/* Footnotes & citations ends */ +  dl.field-list {      display: grid;      grid-template-columns: fit-content(30%) auto; diff --git a/main/_static/doctools.js b/main/_static/doctools.js index e1bfd708..c3db08d1 100644 --- a/main/_static/doctools.js +++ b/main/_static/doctools.js @@ -2,357 +2,263 @@   * doctools.js   * ~~~~~~~~~~~   * - * Sphinx JavaScript utilities for all documentation. + * Base JavaScript utilities for all Sphinx HTML documentation.   *   * :copyright: Copyright 2007-2022 by the Sphinx team, see AUTHORS.   * :license: BSD, see LICENSE for details.   *   */ +"use strict"; -/** - * select a different prefix for underscore - */ -$u = _.noConflict(); - -/** - * make the code below compatible with browsers without - * an installed firebug like debugger -if (!window.console || !console.firebug) { -  var names = ["log", "debug", "info", "warn", "error", "assert", "dir", -    "dirxml", "group", "groupEnd", "time", "timeEnd", "count", "trace", -    "profile", "profileEnd"]; -  window.console = {}; -  for (var i = 0; i < names.length; ++i) -    window.console[names[i]] = function() {}; -} - */ - -/** - * small helper function to urldecode strings - * - * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL - */ -jQuery.urldecode = function(x) { -  if (!x) { -    return x +const _ready = (callback) => { +  if (document.readyState !== "loading") { +    callback(); +  } else { +    document.addEventListener("DOMContentLoaded", callback);    } -  return decodeURIComponent(x.replace(/\+/g, ' '));  };  /** - * small helper function to urlencode strings + * highlight a given string on a node by wrapping it in + * span elements with the given class name.   */ -jQuery.urlencode = encodeURIComponent; +const _highlight = (node, addItems, text, className) => { +  if (node.nodeType === Node.TEXT_NODE) { +    const val = node.nodeValue; +    const parent = node.parentNode; +    const pos = val.toLowerCase().indexOf(text); +    if ( +      pos >= 0 && +      !parent.classList.contains(className) && +      !parent.classList.contains("nohighlight") +    ) { +      let span; -/** - * This function returns the parsed url parameters of the - * current request. Multiple values per key are supported, - * it will always return arrays of strings for the value parts. - */ -jQuery.getQueryParameters = function(s) { -  if (typeof s === 'undefined') -    s = document.location.search; -  var parts = s.substr(s.indexOf('?') + 1).split('&'); -  var result = {}; -  for (var i = 0; i < parts.length; i++) { -    var tmp = parts[i].split('=', 2); -    var key = jQuery.urldecode(tmp[0]); -    var value = jQuery.urldecode(tmp[1]); -    if (key in result) -      result[key].push(value); -    else -      result[key] = [value]; -  } -  return result; -}; +      const closestNode = parent.closest("body, svg, foreignObject"); +      const isInSVG = closestNode && closestNode.matches("svg"); +      if (isInSVG) { +        span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); +      } else { +        span = document.createElement("span"); +        span.classList.add(className); +      } -/** - * highlight a given string on a jquery object by wrapping it in - * span elements with the given class name. - */ -jQuery.fn.highlightText = function(text, className) { -  function highlight(node, addItems) { -    if (node.nodeType === 3) { -      var val = node.nodeValue; -      var pos = val.toLowerCase().indexOf(text); -      if (pos >= 0 && -          !jQuery(node.parentNode).hasClass(className) && -          !jQuery(node.parentNode).hasClass("nohighlight")) { -        var span; -        var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg"); -        if (isInSVG) { -          span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); -        } else { -          span = document.createElement("span"); -          span.className = className; -        } -        span.appendChild(document.createTextNode(val.substr(pos, text.length))); -        node.parentNode.insertBefore(span, node.parentNode.insertBefore( +      span.appendChild(document.createTextNode(val.substr(pos, text.length))); +      parent.insertBefore( +        span, +        parent.insertBefore(            document.createTextNode(val.substr(pos + text.length)), -          node.nextSibling)); -        node.nodeValue = val.substr(0, pos); -        if (isInSVG) { -          var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"); -          var bbox = node.parentElement.getBBox(); -          rect.x.baseVal.value = bbox.x; -          rect.y.baseVal.value = bbox.y; -          rect.width.baseVal.value = bbox.width; -          rect.height.baseVal.value = bbox.height; -          rect.setAttribute('class', className); -          addItems.push({ -              "parent": node.parentNode, -              "target": rect}); -        } +          node.nextSibling +        ) +      ); +      node.nodeValue = val.substr(0, pos); + +      if (isInSVG) { +        const rect = document.createElementNS( +          "http://www.w3.org/2000/svg", +          "rect" +        ); +        const bbox = parent.getBBox(); +        rect.x.baseVal.value = bbox.x; +        rect.y.baseVal.value = bbox.y; +        rect.width.baseVal.value = bbox.width; +        rect.height.baseVal.value = bbox.height; +        rect.setAttribute("class", className); +        addItems.push({ parent: parent, target: rect });        }      } -    else if (!jQuery(node).is("button, select, textarea")) { -      jQuery.each(node.childNodes, function() { -        highlight(this, addItems); -      }); -    } +  } else if (node.matches && !node.matches("button, select, textarea")) { +    node.childNodes.forEach((el) => _highlight(el, addItems, text, className));    } -  var addItems = []; -  var result = this.each(function() { -    highlight(this, addItems); -  }); -  for (var i = 0; i < addItems.length; ++i) { -    jQuery(addItems[i].parent).before(addItems[i].target); -  } -  return result;  }; - -/* - * 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; -} +const _highlightText = (thisNode, text, className) => { +  let addItems = []; +  _highlight(thisNode, addItems, text, className); +  addItems.forEach((obj) => +    obj.parent.insertAdjacentElement("beforebegin", obj.target) +  ); +};  /**   * Small JavaScript module for the documentation.   */ -var Documentation = { - -  init : function() { -    this.fixFirefoxAnchorBug(); -    this.highlightSearchWords(); -    this.initIndexTable(); -    this.initOnKeyListeners(); +const Documentation = { +  init: () => { +    Documentation.highlightSearchWords(); +    Documentation.initDomainIndexTable(); +    Documentation.initOnKeyListeners();    },    /**     * i18n support     */ -  TRANSLATIONS : {}, -  PLURAL_EXPR : function(n) { return n === 1 ? 0 : 1; }, -  LOCALE : 'unknown', +  TRANSLATIONS: {}, +  PLURAL_EXPR: (n) => (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; +  gettext: (string) => { +    const translated = Documentation.TRANSLATIONS[string]; +    switch (typeof translated) { +      case "undefined": +        return string; // no translation +      case "string": +        return translated; // translation exists +      default: +        return translated[0]; // (singular, plural) translation tuple exists +    }    }, -  /** -   * add context elements like header anchor links -   */ -  addContextElements : function() { -    $('div[id] > :header:first').each(function() { -      $('<a class="headerlink">\u00B6</a>'). -      attr('href', '#' + this.id). -      attr('title', _('Permalink to this headline')). -      appendTo(this); -    }); -    $('dt[id]').each(function() { -      $('<a class="headerlink">\u00B6</a>'). -      attr('href', '#' + this.id). -      attr('title', _('Permalink to this definition')). -      appendTo(this); -    }); +  ngettext: (singular, plural, n) => { +    const translated = Documentation.TRANSLATIONS[singular]; +    if (typeof translated !== "undefined") +      return translated[Documentation.PLURAL_EXPR(n)]; +    return n === 1 ? singular : plural;    }, -  /** -   * workaround a firefox stupidity -   * see: https://bugzilla.mozilla.org/show_bug.cgi?id=645075 -   */ -  fixFirefoxAnchorBug : function() { -    if (document.location.hash && $.browser.mozilla) -      window.setTimeout(function() { -        document.location.href += ''; -      }, 10); +  addTranslations: (catalog) => { +    Object.assign(Documentation.TRANSLATIONS, catalog.messages); +    Documentation.PLURAL_EXPR = new Function( +      "n", +      `return (${catalog.plural_expr})` +    ); +    Documentation.LOCALE = catalog.locale;    },    /**     * 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); -      $('<p class="highlight-link"><a href="javascript:Documentation.' + -        'hideSearchWords()">' + _('Hide Search Matches') + '</a></p>') -          .appendTo($('#searchbox')); -    } -  }, +  highlightSearchWords: () => { +    const highlight = +      new URLSearchParams(window.location.search).get("highlight") || ""; +    const terms = highlight.toLowerCase().split(/\s+/).filter(x => x); +    if (terms.length === 0) return; // nothing to do -  /** -   * 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(); -    } +    // There should never be more than one element matching "div.body" +    const divBody = document.querySelectorAll("div.body"); +    const body = divBody.length ? divBody[0] : document.querySelector("body"); +    window.setTimeout(() => { +      terms.forEach((term) => _highlightText(body, term, "highlighted")); +    }, 10); + +    const searchBox = document.getElementById("searchbox"); +    if (searchBox === null) return; +    searchBox.appendChild( +      document +        .createRange() +        .createContextualFragment( +          '<p class="highlight-link">' + +            '<a href="javascript:Documentation.hideSearchWords()">' + +            Documentation.gettext("Hide Search Matches") + +            "</a></p>" +        ) +    );    },    /**     * helper function to hide the search marks again     */ -  hideSearchWords : function() { -    $('#searchbox .highlight-link').fadeOut(300); -    $('span.highlighted').removeClass('highlighted'); -    var url = new URL(window.location); -    url.searchParams.delete('highlight'); -    window.history.replaceState({}, '', url); +  hideSearchWords: () => { +    document +      .querySelectorAll("#searchbox .highlight-link") +      .forEach((el) => el.remove()); +    document +      .querySelectorAll("span.highlighted") +      .forEach((el) => el.classList.remove("highlighted")); +    const url = new URL(window.location); +    url.searchParams.delete("highlight"); +    window.history.replaceState({}, "", url);    }, -   /** +  /**     * helper function to focus on search bar     */ -  focusSearchBar : function() { -    $('input[name=q]').first().focus(); +  focusSearchBar: () => { +    document.querySelectorAll("input[name=q]")[0]?.focus();    },    /** -   * make the url absolute +   * Initialise the domain index toggle buttons     */ -  makeURL : function(relativeURL) { -    return DOCUMENTATION_OPTIONS.URL_ROOT + '/' + relativeURL; -  }, +  initDomainIndexTable: () => { +    const toggler = (el) => { +      const idNumber = el.id.substr(7); +      const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`); +      if (el.src.substr(-9) === "minus.png") { +        el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`; +        toggledRows.forEach((el) => (el.style.display = "none")); +      } else { +        el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`; +        toggledRows.forEach((el) => (el.style.display = "")); +      } +    }; -  /** -   * 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); +    const togglerElements = document.querySelectorAll("img.toggler"); +    togglerElements.forEach((el) => +      el.addEventListener("click", (event) => toggler(event.currentTarget)) +    ); +    togglerElements.forEach((el) => (el.style.display = "")); +    if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler);    }, -  initOnKeyListeners: function() { +  initOnKeyListeners: () => {      // only install a listener if it is really needed -    if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && -        !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -        return; +    if ( +      !DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && +      !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS +    ) +      return; -    $(document).keydown(function(event) { -      var activeElementType = document.activeElement.tagName; -      // don't navigate when in search box, textarea, dropdown or button -      if (activeElementType !== 'TEXTAREA' && activeElementType !== 'INPUT' && activeElementType !== 'SELECT' -          && activeElementType !== 'BUTTON') { -        if (event.altKey || event.ctrlKey || event.metaKey) -          return; +    const blacklistedElements = new Set([ +      "TEXTAREA", +      "INPUT", +      "SELECT", +      "BUTTON", +    ]); +    document.addEventListener("keydown", (event) => { +      if (blacklistedElements.has(document.activeElement.tagName)) return; // bail for input elements +      if (event.altKey || event.ctrlKey || event.metaKey) return; // bail with special keys -          if (!event.shiftKey) { -            switch (event.key) { -              case 'ArrowLeft': -                if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) -                  break; -                var prevHref = $('link[rel="prev"]').prop('href'); -                if (prevHref) { -                  window.location.href = prevHref; -                  return false; -                } -                break; -              case 'ArrowRight': -                if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) -                  break; -                var nextHref = $('link[rel="next"]').prop('href'); -                if (nextHref) { -                  window.location.href = nextHref; -                  return false; -                } -                break; -              case 'Escape': -                if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -                  break; -                Documentation.hideSearchWords(); -                return false; -          } -        } - -        // some keyboard layouts may need Shift to get / +      if (!event.shiftKey) {          switch (event.key) { -          case '/': -            if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -              break; -            Documentation.focusSearchBar(); -            return false; +          case "ArrowLeft": +            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + +            const prevLink = document.querySelector('link[rel="prev"]'); +            if (prevLink && prevLink.href) { +              window.location.href = prevLink.href; +              event.preventDefault(); +            } +            break; +          case "ArrowRight": +            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + +            const nextLink = document.querySelector('link[rel="next"]'); +            if (nextLink && nextLink.href) { +              window.location.href = nextLink.href; +              event.preventDefault(); +            } +            break; +          case "Escape": +            if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; +            Documentation.hideSearchWords(); +            event.preventDefault();          }        } + +      // some keyboard layouts may need Shift to get / +      switch (event.key) { +        case "/": +          if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; +          Documentation.focusSearchBar(); +          event.preventDefault(); +      }      }); -  } +  },  };  // quick alias for translations -_ = Documentation.gettext; +const _ = Documentation.gettext; -$(document).ready(function() { -  Documentation.init(); -}); +_ready(Documentation.init); diff --git a/main/_static/documentation_options.js b/main/_static/documentation_options.js index e4e08a75..5414fbe2 100644 --- a/main/_static/documentation_options.js +++ b/main/_static/documentation_options.js @@ -1,7 +1,7 @@  var DOCUMENTATION_OPTIONS = {      URL_ROOT: document.getElementById("documentation_options").getAttribute('data-url_root'),      VERSION: '7.1.1', -    LANGUAGE: 'None', +    LANGUAGE: 'en',      COLLAPSE_INDEX: false,      BUILDER: 'html',      FILE_SUFFIX: '.html', @@ -10,5 +10,5 @@ var DOCUMENTATION_OPTIONS = {      SOURCELINK_SUFFIX: '.txt',      NAVIGATION_WITH_KEYS: false,      SHOW_SEARCH_SUMMARY: true, -    ENABLE_SEARCH_SHORTCUTS: true, +    ENABLE_SEARCH_SHORTCUTS: false,  };
\ No newline at end of file diff --git a/main/_static/jquery-3.5.1.js b/main/_static/jquery-3.6.0.js index 50937333..fc6c299b 100644 --- a/main/_static/jquery-3.5.1.js +++ b/main/_static/jquery-3.6.0.js @@ -1,15 +1,15 @@  /*! - * jQuery JavaScript Library v3.5.1 + * jQuery JavaScript Library v3.6.0   * https://jquery.com/   *   * Includes Sizzle.js   * https://sizzlejs.com/   * - * Copyright JS Foundation and other contributors + * Copyright OpenJS Foundation and other contributors   * Released under the MIT license   * https://jquery.org/license   * - * Date: 2020-05-04T22:49Z + * Date: 2021-03-02T17:08Z   */  ( function( global, factory ) { @@ -76,12 +76,16 @@ var support = {};  var isFunction = function isFunction( obj ) { -      // Support: Chrome <=57, Firefox <=52 -      // In some browsers, typeof returns "function" for HTML <object> elements -      // (i.e., `typeof document.createElement( "object" ) === "function"`). -      // We don't want to classify *any* DOM node as a function. -      return typeof obj === "function" && typeof obj.nodeType !== "number"; -  }; +		// Support: Chrome <=57, Firefox <=52 +		// In some browsers, typeof returns "function" for HTML <object> elements +		// (i.e., `typeof document.createElement( "object" ) === "function"`). +		// We don't want to classify *any* DOM node as a function. +		// Support: QtWeb <=3.8.5, WebKit <=534.34, wkhtmltopdf tool <=0.12.5 +		// Plus for old WebKit, typeof returns "function" for HTML collections +		// (e.g., `typeof document.getElementsByTagName("div") === "function"`). (gh-4756) +		return typeof obj === "function" && typeof obj.nodeType !== "number" && +			typeof obj.item !== "function"; +	};  var isWindow = function isWindow( obj ) { @@ -147,7 +151,7 @@ function toType( obj ) {  var -	version = "3.5.1", +	version = "3.6.0",  	// Define a local copy of jQuery  	jQuery = function( selector, context ) { @@ -401,7 +405,7 @@ jQuery.extend( {  			if ( isArrayLike( Object( arr ) ) ) {  				jQuery.merge( ret,  					typeof arr === "string" ? -					[ arr ] : arr +						[ arr ] : arr  				);  			} else {  				push.call( ret, arr ); @@ -496,9 +500,9 @@ if ( typeof Symbol === "function" ) {  // Populate the class2type map  jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ), -function( _i, name ) { -	class2type[ "[object " + name + "]" ] = name.toLowerCase(); -} ); +	function( _i, name ) { +		class2type[ "[object " + name + "]" ] = name.toLowerCase(); +	} );  function isArrayLike( obj ) { @@ -518,14 +522,14 @@ function isArrayLike( obj ) {  }  var Sizzle =  /*! - * Sizzle CSS Selector Engine v2.3.5 + * Sizzle CSS Selector Engine v2.3.6   * https://sizzlejs.com/   *   * Copyright JS Foundation and other contributors   * Released under the MIT license   * https://js.foundation/   * - * Date: 2020-03-14 + * Date: 2021-02-16   */  ( function( window ) {  var i, @@ -1108,8 +1112,8 @@ support = Sizzle.support = {};   * @returns {Boolean} True iff elem is a non-HTML XML node   */  isXML = Sizzle.isXML = function( elem ) { -	var namespace = elem.namespaceURI, -		docElem = ( elem.ownerDocument || elem ).documentElement; +	var namespace = elem && elem.namespaceURI, +		docElem = elem && ( elem.ownerDocument || elem ).documentElement;  	// Support: IE <=8  	// Assume HTML when documentElement doesn't yet exist, such as inside loading iframes @@ -3024,9 +3028,9 @@ var rneedsContext = jQuery.expr.match.needsContext;  function nodeName( elem, name ) { -  return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); +	return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); -}; +}  var rsingleTag = ( /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i ); @@ -3997,8 +4001,8 @@ jQuery.extend( {  			resolveContexts = Array( i ),  			resolveValues = slice.call( arguments ), -			// the master Deferred -			master = jQuery.Deferred(), +			// the primary Deferred +			primary = jQuery.Deferred(),  			// subordinate callback factory  			updateFunc = function( i ) { @@ -4006,30 +4010,30 @@ jQuery.extend( {  					resolveContexts[ i ] = this;  					resolveValues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value;  					if ( !( --remaining ) ) { -						master.resolveWith( resolveContexts, resolveValues ); +						primary.resolveWith( resolveContexts, resolveValues );  					}  				};  			};  		// Single- and empty arguments are adopted like Promise.resolve  		if ( remaining <= 1 ) { -			adoptValue( singleValue, master.done( updateFunc( i ) ).resolve, master.reject, +			adoptValue( singleValue, primary.done( updateFunc( i ) ).resolve, primary.reject,  				!remaining );  			// Use .then() to unwrap secondary thenables (cf. gh-3000) -			if ( master.state() === "pending" || +			if ( primary.state() === "pending" ||  				isFunction( resolveValues[ i ] && resolveValues[ i ].then ) ) { -				return master.then(); +				return primary.then();  			}  		}  		// Multiple arguments are aggregated like Promise.all array elements  		while ( i-- ) { -			adoptValue( resolveValues[ i ], updateFunc( i ), master.reject ); +			adoptValue( resolveValues[ i ], updateFunc( i ), primary.reject );  		} -		return master.promise(); +		return primary.promise();  	}  } ); @@ -4180,8 +4184,8 @@ var access = function( elems, fn, key, value, chainable, emptyGet, raw ) {  			for ( ; i < len; i++ ) {  				fn(  					elems[ i ], key, raw ? -					value : -					value.call( elems[ i ], i, fn( elems[ i ], key ) ) +						value : +						value.call( elems[ i ], i, fn( elems[ i ], key ) )  				);  			}  		} @@ -5089,10 +5093,7 @@ function buildFragment( elems, context, scripts, selection, ignored ) {  } -var -	rkeyEvent = /^key/, -	rmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/, -	rtypenamespace = /^([^.]*)(?:\.(.+)|)/; +var rtypenamespace = /^([^.]*)(?:\.(.+)|)/;  function returnTrue() {  	return true; @@ -5387,8 +5388,8 @@ jQuery.event = {  			event = jQuery.event.fix( nativeEvent ),  			handlers = ( -					dataPriv.get( this, "events" ) || Object.create( null ) -				)[ event.type ] || [], +				dataPriv.get( this, "events" ) || Object.create( null ) +			)[ event.type ] || [],  			special = jQuery.event.special[ event.type ] || {};  		// Use the fix-ed jQuery.Event rather than the (read-only) native event @@ -5512,12 +5513,12 @@ jQuery.event = {  			get: isFunction( hook ) ?  				function() {  					if ( this.originalEvent ) { -							return hook( this.originalEvent ); +						return hook( this.originalEvent );  					}  				} :  				function() {  					if ( this.originalEvent ) { -							return this.originalEvent[ name ]; +						return this.originalEvent[ name ];  					}  				}, @@ -5656,7 +5657,13 @@ function leverageNative( el, type, expectSync ) {  						// Cancel the outer synthetic event  						event.stopImmediatePropagation();  						event.preventDefault(); -						return result.value; + +						// Support: Chrome 86+ +						// In Chrome, if an element having a focusout handler is blurred by +						// clicking outside of it, it invokes the handler synchronously. If +						// that handler calls `.remove()` on the element, the data is cleared, +						// leaving `result` undefined. We need to guard against this. +						return result && result.value;  					}  				// If this is an inner synthetic event for an event with a bubbling surrogate @@ -5821,34 +5828,7 @@ jQuery.each( {  	targetTouches: true,  	toElement: true,  	touches: true, - -	which: function( event ) { -		var button = event.button; - -		// Add which for key events -		if ( event.which == null && rkeyEvent.test( event.type ) ) { -			return event.charCode != null ? event.charCode : event.keyCode; -		} - -		// Add which for click: 1 === left; 2 === middle; 3 === right -		if ( !event.which && button !== undefined && rmouseEvent.test( event.type ) ) { -			if ( button & 1 ) { -				return 1; -			} - -			if ( button & 2 ) { -				return 3; -			} - -			if ( button & 4 ) { -				return 2; -			} - -			return 0; -		} - -		return event.which; -	} +	which: true  }, jQuery.event.addProp );  jQuery.each( { focus: "focusin", blur: "focusout" }, function( type, delegateType ) { @@ -5874,6 +5854,12 @@ jQuery.each( { focus: "focusin", blur: "focusout" }, function( type, delegateTyp  			return true;  		}, +		// Suppress native focus or blur as it's already being fired +		// in leverageNative. +		_default: function() { +			return true; +		}, +  		delegateType: delegateType  	};  } ); @@ -6541,6 +6527,10 @@ var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" );  		// set in CSS while `offset*` properties report correct values.  		// Behavior in IE 9 is more subtle than in newer versions & it passes  		// some versions of this test; make sure not to make it pass there! +		// +		// Support: Firefox 70+ +		// Only Firefox includes border widths +		// in computed dimensions. (gh-4529)  		reliableTrDimensions: function() {  			var table, tr, trChild, trStyle;  			if ( reliableTrDimensionsVal == null ) { @@ -6548,17 +6538,32 @@ var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" );  				tr = document.createElement( "tr" );  				trChild = document.createElement( "div" ); -				table.style.cssText = "position:absolute;left:-11111px"; +				table.style.cssText = "position:absolute;left:-11111px;border-collapse:separate"; +				tr.style.cssText = "border:1px solid"; + +				// Support: Chrome 86+ +				// Height set through cssText does not get applied. +				// Computed height then comes back as 0.  				tr.style.height = "1px";  				trChild.style.height = "9px"; +				// Support: Android 8 Chrome 86+ +				// In our bodyBackground.html iframe, +				// display for all div elements is set to "inline", +				// which causes a problem only in Android 8 Chrome 86. +				// Ensuring the div is display: block +				// gets around this issue. +				trChild.style.display = "block"; +  				documentElement  					.appendChild( table )  					.appendChild( tr )  					.appendChild( trChild );  				trStyle = window.getComputedStyle( tr ); -				reliableTrDimensionsVal = parseInt( trStyle.height ) > 3; +				reliableTrDimensionsVal = ( parseInt( trStyle.height, 10 ) + +					parseInt( trStyle.borderTopWidth, 10 ) + +					parseInt( trStyle.borderBottomWidth, 10 ) ) === tr.offsetHeight;  				documentElement.removeChild( table );  			} @@ -7022,10 +7027,10 @@ jQuery.each( [ "height", "width" ], function( _i, dimension ) {  					// Running getBoundingClientRect on a disconnected node  					// in IE throws an error.  					( !elem.getClientRects().length || !elem.getBoundingClientRect().width ) ? -						swap( elem, cssShow, function() { -							return getWidthOrHeight( elem, dimension, extra ); -						} ) : -						getWidthOrHeight( elem, dimension, extra ); +					swap( elem, cssShow, function() { +						return getWidthOrHeight( elem, dimension, extra ); +					} ) : +					getWidthOrHeight( elem, dimension, extra );  			}  		}, @@ -7084,7 +7089,7 @@ jQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft,  					swap( elem, { marginLeft: 0 }, function() {  						return elem.getBoundingClientRect().left;  					} ) -				) + "px"; +			) + "px";  		}  	}  ); @@ -7223,7 +7228,7 @@ Tween.propHooks = {  			if ( jQuery.fx.step[ tween.prop ] ) {  				jQuery.fx.step[ tween.prop ]( tween );  			} else if ( tween.elem.nodeType === 1 && ( -					jQuery.cssHooks[ tween.prop ] || +				jQuery.cssHooks[ tween.prop ] ||  					tween.elem.style[ finalPropName( tween.prop ) ] != null ) ) {  				jQuery.style( tween.elem, tween.prop, tween.now + tween.unit );  			} else { @@ -7468,7 +7473,7 @@ function defaultPrefilter( elem, props, opts ) {  			anim.done( function() { -			/* eslint-enable no-loop-func */ +				/* eslint-enable no-loop-func */  				// The final step of a "hide" animation is actually hiding the element  				if ( !hidden ) { @@ -7588,7 +7593,7 @@ function Animation( elem, properties, options ) {  			tweens: [],  			createTween: function( prop, end ) {  				var tween = jQuery.Tween( elem, animation.opts, prop, end, -						animation.opts.specialEasing[ prop ] || animation.opts.easing ); +					animation.opts.specialEasing[ prop ] || animation.opts.easing );  				animation.tweens.push( tween );  				return tween;  			}, @@ -7761,7 +7766,8 @@ jQuery.fn.extend( {  					anim.stop( true );  				}  			}; -			doAnimation.finish = doAnimation; + +		doAnimation.finish = doAnimation;  		return empty || optall.queue === false ?  			this.each( doAnimation ) : @@ -8401,8 +8407,8 @@ jQuery.fn.extend( {  				if ( this.setAttribute ) {  					this.setAttribute( "class",  						className || value === false ? -						"" : -						dataPriv.get( this, "__className__" ) || "" +							"" : +							dataPriv.get( this, "__className__" ) || ""  					);  				}  			} @@ -8417,7 +8423,7 @@ jQuery.fn.extend( {  		while ( ( elem = this[ i++ ] ) ) {  			if ( elem.nodeType === 1 &&  				( " " + stripAndCollapse( getClass( elem ) ) + " " ).indexOf( className ) > -1 ) { -					return true; +				return true;  			}  		} @@ -8707,9 +8713,7 @@ jQuery.extend( jQuery.event, {  				special.bindType || type;  			// jQuery handler -			handle = ( -					dataPriv.get( cur, "events" ) || Object.create( null ) -				)[ event.type ] && +			handle = ( dataPriv.get( cur, "events" ) || Object.create( null ) )[ event.type ] &&  				dataPriv.get( cur, "handle" );  			if ( handle ) {  				handle.apply( cur, data ); @@ -8856,7 +8860,7 @@ var rquery = ( /\?/ );  // Cross-browser xml parsing  jQuery.parseXML = function( data ) { -	var xml; +	var xml, parserErrorElem;  	if ( !data || typeof data !== "string" ) {  		return null;  	} @@ -8865,12 +8869,17 @@ jQuery.parseXML = function( data ) {  	// IE throws on parseFromString with invalid input.  	try {  		xml = ( new window.DOMParser() ).parseFromString( data, "text/xml" ); -	} catch ( e ) { -		xml = undefined; -	} +	} catch ( e ) {} -	if ( !xml || xml.getElementsByTagName( "parsererror" ).length ) { -		jQuery.error( "Invalid XML: " + data ); +	parserErrorElem = xml && xml.getElementsByTagName( "parsererror" )[ 0 ]; +	if ( !xml || parserErrorElem ) { +		jQuery.error( "Invalid XML: " + ( +			parserErrorElem ? +				jQuery.map( parserErrorElem.childNodes, function( el ) { +					return el.textContent; +				} ).join( "\n" ) : +				data +		) );  	}  	return xml;  }; @@ -8971,16 +8980,14 @@ jQuery.fn.extend( {  			// Can add propHook for "elements" to filter or add form elements  			var elements = jQuery.prop( this, "elements" );  			return elements ? jQuery.makeArray( elements ) : this; -		} ) -		.filter( function() { +		} ).filter( function() {  			var type = this.type;  			// Use .is( ":disabled" ) so that fieldset[disabled] works  			return this.name && !jQuery( this ).is( ":disabled" ) &&  				rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) &&  				( this.checked || !rcheckableType.test( type ) ); -		} ) -		.map( function( _i, elem ) { +		} ).map( function( _i, elem ) {  			var val = jQuery( this ).val();  			if ( val == null ) { @@ -9033,7 +9040,8 @@ var  	// Anchor tag for parsing the document origin  	originAnchor = document.createElement( "a" ); -	originAnchor.href = location.href; + +originAnchor.href = location.href;  // Base "constructor" for jQuery.ajaxPrefilter and jQuery.ajaxTransport  function addToPrefiltersOrTransports( structure ) { @@ -9414,8 +9422,8 @@ jQuery.extend( {  			// Context for global events is callbackContext if it is a DOM node or jQuery collection  			globalEventContext = s.context &&  				( callbackContext.nodeType || callbackContext.jquery ) ? -					jQuery( callbackContext ) : -					jQuery.event, +				jQuery( callbackContext ) : +				jQuery.event,  			// Deferreds  			deferred = jQuery.Deferred(), @@ -9727,8 +9735,10 @@ jQuery.extend( {  				response = ajaxHandleResponses( s, jqXHR, responses );  			} -			// Use a noop converter for missing script -			if ( !isSuccess && jQuery.inArray( "script", s.dataTypes ) > -1 ) { +			// Use a noop converter for missing script but not if jsonp +			if ( !isSuccess && +				jQuery.inArray( "script", s.dataTypes ) > -1 && +				jQuery.inArray( "json", s.dataTypes ) < 0 ) {  				s.converters[ "text script" ] = function() {};  			} @@ -10466,12 +10476,6 @@ jQuery.offset = {  			options.using.call( elem, props );  		} else { -			if ( typeof props.top === "number" ) { -				props.top += "px"; -			} -			if ( typeof props.left === "number" ) { -				props.left += "px"; -			}  			curElem.css( props );  		}  	} @@ -10640,8 +10644,11 @@ jQuery.each( [ "top", "left" ], function( _i, prop ) {  // Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods  jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { -	jQuery.each( { padding: "inner" + name, content: type, "": "outer" + name }, -		function( defaultExtra, funcName ) { +	jQuery.each( { +		padding: "inner" + name, +		content: type, +		"": "outer" + name +	}, function( defaultExtra, funcName ) {  		// Margin is only for outerHeight, outerWidth  		jQuery.fn[ funcName ] = function( margin, value ) { @@ -10726,7 +10733,8 @@ jQuery.fn.extend( {  	}  } ); -jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " + +jQuery.each( +	( "blur focus focusin focusout resize scroll click dblclick " +  	"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " +  	"change select submit keydown keypress keyup contextmenu" ).split( " " ),  	function( _i, name ) { @@ -10737,7 +10745,8 @@ jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " +  				this.on( name, null, data, fn ) :  				this.trigger( name );  		}; -	} ); +	} +); diff --git a/main/_static/jquery.js b/main/_static/jquery.js index b0614034..c4c6022f 100644 --- a/main/_static/jquery.js +++ b/main/_static/jquery.js @@ -1,2 +1,2 @@ -/*! jQuery v3.5.1 | (c) JS Foundation and other contributors | jquery.org/license */ -!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.5.1",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),D=function(e,t){return e===t&&(l=!0),0},j={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e.namespaceURI,n=(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&j.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(D),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(D).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function D(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(D(this,e||[],!1))},not:function(e){return this.pushStack(D(this,e||[],!0))},is:function(e){return!!D(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var j,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||j,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,j=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^key/,we=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,Te=/^([^.]*)(?:\.(.+)|)/;function Ce(){return!0}function Ee(){return!1}function Se(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function ke(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)ke(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Ee;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Ae(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,Ce)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=Te.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=Te.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Ae(t,"click",Ce),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Ae(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?Ce:Ee,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Ee,isPropagationStopped:Ee,isImmediatePropagationStopped:Ee,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=Ce,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=Ce,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=Ce,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:function(e){var t=e.button;return null==e.which&&be.test(e.type)?null!=e.charCode?e.charCode:e.keyCode:!e.which&&void 0!==t&&we.test(e.type)?1&t?1:2&t?3:4&t?2:0:e.which}},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Ae(this,e,Se),!1},trigger:function(){return Ae(this,e),!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return ke(this,e,t,n,r)},one:function(e,t,n,r){return ke(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Ee),this.each(function(){S.event.remove(this,e,n,t)})}});var Ne=/<script|<style|<link/i,De=/checked\s*(?:[^=]|=\s*.checked.)/i,je=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function qe(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function Le(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function He(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Oe(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function Pe(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&De.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),Pe(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),Le)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,He),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(je,""),u,l))}return n}function Re(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Oe(o[r],a[r]);else Oe(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Re(this,e,!0)},remove:function(e){return Re(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return Pe(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||qe(this,e).appendChild(e)})},prepend:function(){return Pe(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=qe(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return Pe(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return Pe(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!Ne.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return Pe(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Me=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Ie=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},We=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Fe=new RegExp(ne.join("|"),"i");function Be(e,t,n){var r,i,o,a,s=e.style;return(n=n||Ie(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Me.test(a)&&Fe.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function $e(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px",t.style.height="1px",n.style.height="9px",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=3<parseInt(r.height),re.removeChild(e)),a}}))}();var _e=["Webkit","Moz","ms"],ze=E.createElement("div").style,Ue={};function Xe(e){var t=S.cssProps[e]||Ue[e];return t||(e in ze?e:Ue[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=_e.length;while(n--)if((e=_e[n]+t)in ze)return e}(e)||e)}var Ve=/^(none|table(?!-c[ea]).+)/,Ge=/^--/,Ye={position:"absolute",visibility:"hidden",display:"block"},Qe={letterSpacing:"0",fontWeight:"400"};function Je(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Ke(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Ze(e,t,n){var r=Ie(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=Be(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Me.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Ke(e,t,n||(i?"border":"content"),o,r,a)+"px"}function et(e,t,n,r,i){return new et.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Be(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Ge.test(t),l=e.style;if(u||(t=Xe(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Ge.test(t)||(t=Xe(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=Be(e,t,r)),"normal"===i&&t in Qe&&(i=Qe[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ve.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Ze(e,u,n):We(e,Ye,function(){return Ze(e,u,n)})},set:function(e,t,n){var r,i=Ie(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Ke(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Ke(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Je(0,t,s)}}}),S.cssHooks.marginLeft=$e(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(Be(e,"marginLeft"))||e.getBoundingClientRect().left-We(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Je)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Ie(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=et).prototype={constructor:et,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=et.propHooks[this.prop];return e&&e.get?e.get(this):et.propHooks._default.get(this)},run:function(e){var t,n=et.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):et.propHooks._default.set(this),this}}).init.prototype=et.prototype,(et.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[Xe(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=et.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=et.prototype.init,S.fx.step={};var tt,nt,rt,it,ot=/^(?:toggle|show|hide)$/,at=/queueHooks$/;function st(){nt&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(st):C.setTimeout(st,S.fx.interval),S.fx.tick())}function ut(){return C.setTimeout(function(){tt=void 0}),tt=Date.now()}function lt(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ct(e,t,n){for(var r,i=(ft.tweeners[t]||[]).concat(ft.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function ft(o,e,t){var n,a,r=0,i=ft.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=tt||ut(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:tt||ut(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=ft.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ct,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(ft,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],ft.tweeners[n]=ft.tweeners[n]||[],ft.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],ot.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ct(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?ft.prefilters.unshift(e):ft.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=ft(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&at.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(lt(r,!0),e,t,n)}}),S.each({slideDown:lt("show"),slideUp:lt("hide"),slideToggle:lt("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(tt=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),tt=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){nt||(nt=!0,st())},S.fx.stop=function(){nt=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},rt=E.createElement("input"),it=E.createElement("select").appendChild(E.createElement("option")),rt.type="checkbox",y.checkOn=""!==rt.value,y.optSelected=it.selected,(rt=E.createElement("input")).value="t",rt.type="radio",y.radioValue="t"===rt.value;var pt,dt=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?pt:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),pt={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=dt[t]||S.find.attr;dt[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=dt[o],dt[o]=r,r=null!=a(e,t,n)?o:null,dt[o]=i),r}});var ht=/^(?:input|select|textarea|button)$/i,gt=/^(?:a|area)$/i;function vt(e){return(e.match(P)||[]).join(" ")}function yt(e){return e.getAttribute&&e.getAttribute("class")||""}function mt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):ht.test(e.nodeName)||gt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,yt(this)))});if((e=mt(t)).length)while(n=this[u++])if(i=yt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,yt(this)))});if(!arguments.length)return this.attr("class","");if((e=mt(t)).length)while(n=this[u++])if(i=yt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,yt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=mt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=yt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+vt(yt(n))+" ").indexOf(t))return!0;return!1}});var xt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(xt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:vt(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var bt=/^(?:focusinfocus|focusoutblur)$/,wt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!bt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,bt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,wt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,wt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var Tt=C.location,Ct={guid:Date.now()},Et=/\?/;S.parseXML=function(e){var t;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){t=void 0}return t&&!t.getElementsByTagName("parsererror").length||S.error("Invalid XML: "+e),t};var St=/\[\]$/,kt=/\r?\n/g,At=/^(?:submit|button|image|reset|file)$/i,Nt=/^(?:input|select|textarea|keygen)/i;function Dt(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||St.test(n)?i(n,t):Dt(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)Dt(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)Dt(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&Nt.test(this.nodeName)&&!At.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(kt,"\r\n")}}):{name:t.name,value:n.replace(kt,"\r\n")}}).get()}});var jt=/%20/g,qt=/#.*$/,Lt=/([?&])_=[^&]*/,Ht=/^(.*?):[ \t]*([^\r\n]*)$/gm,Ot=/^(?:GET|HEAD)$/,Pt=/^\/\//,Rt={},Mt={},It="*/".concat("*"),Wt=E.createElement("a");function Ft(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Bt(t,i,o,a){var s={},u=t===Mt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function $t(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Wt.href=Tt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:Tt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(Tt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":It,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?$t($t(e,S.ajaxSettings),t):$t(S.ajaxSettings,e)},ajaxPrefilter:Ft(Rt),ajaxTransport:Ft(Mt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=Ht.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||Tt.href)+"").replace(Pt,Tt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Wt.protocol+"//"+Wt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Bt(Rt,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Ot.test(v.type),f=v.url.replace(qt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(jt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Et.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Lt,"$1"),o=(Et.test(f)?"&":"?")+"_="+Ct.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+It+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Bt(Mt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var _t={0:200,1223:204},zt=S.ajaxSettings.xhr();y.cors=!!zt&&"withCredentials"in zt,y.ajax=zt=!!zt,S.ajaxTransport(function(i){var o,a;if(y.cors||zt&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(_t[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var Ut,Xt=[],Vt=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=Xt.pop()||S.expando+"_"+Ct.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Vt.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Vt.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Vt,"$1"+r):!1!==e.jsonp&&(e.url+=(Et.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,Xt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((Ut=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===Ut.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=vt(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):("number"==typeof f.top&&(f.top+="px"),"number"==typeof f.left&&(f.left+="px"),c.css(f))}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=$e(y.pixelPosition,function(e,t){if(t)return t=Be(e,n),Me.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Gt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Gt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Yt=C.jQuery,Qt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Qt),e&&C.jQuery===S&&(C.jQuery=Yt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S}); +/*! jQuery v3.6.0 | (c) OpenJS Foundation and other contributors | jquery.org/license */ +!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.6.0",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),j=function(e,t){return e===t&&(l=!0),0},D={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},j=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&D.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(j),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(j).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var D,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||D,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,D=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^([^.]*)(?:\.(.+)|)/;function we(){return!0}function Te(){return!1}function Ce(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function Ee(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)Ee(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Te;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Se(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n&&n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,we)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=be.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=be.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click",we),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?we:Te,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Te,isPropagationStopped:Te,isImmediatePropagationStopped:Te,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=we,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=we,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=we,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:!0},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Se(this,e,Ce),!1},trigger:function(){return Se(this,e),!0},_default:function(){return!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return Ee(this,e,t,n,r)},one:function(e,t,n,r){return Ee(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Te),this.each(function(){S.event.remove(this,e,n,t)})}});var ke=/<script|<style|<link/i,Ae=/checked\s*(?:[^=]|=\s*.checked.)/i,Ne=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function je(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function De(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function qe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Le(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function He(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&Ae.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),He(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),De)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,qe),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(Ne,""),u,l))}return n}function Oe(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Le(o[r],a[r]);else Le(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Oe(this,e,!0)},remove:function(e){return Oe(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return He(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||je(this,e).appendChild(e)})},prepend:function(){return He(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=je(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!ke.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return He(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Pe=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Re=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},Me=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Ie=new RegExp(ne.join("|"),"i");function We(e,t,n){var r,i,o,a,s=e.style;return(n=n||Re(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Pe.test(a)&&Ie.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function Fe(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px;border-collapse:separate",t.style.cssText="border:1px solid",t.style.height="1px",n.style.height="9px",n.style.display="block",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=parseInt(r.height,10)+parseInt(r.borderTopWidth,10)+parseInt(r.borderBottomWidth,10)===t.offsetHeight,re.removeChild(e)),a}}))}();var Be=["Webkit","Moz","ms"],$e=E.createElement("div").style,_e={};function ze(e){var t=S.cssProps[e]||_e[e];return t||(e in $e?e:_e[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=Be.length;while(n--)if((e=Be[n]+t)in $e)return e}(e)||e)}var Ue=/^(none|table(?!-c[ea]).+)/,Xe=/^--/,Ve={position:"absolute",visibility:"hidden",display:"block"},Ge={letterSpacing:"0",fontWeight:"400"};function Ye(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Qe(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Je(e,t,n){var r=Re(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=We(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Pe.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Qe(e,t,n||(i?"border":"content"),o,r,a)+"px"}function Ke(e,t,n,r,i){return new Ke.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=We(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Xe.test(t),l=e.style;if(u||(t=ze(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Xe.test(t)||(t=ze(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=We(e,t,r)),"normal"===i&&t in Ge&&(i=Ge[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ue.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Je(e,u,n):Me(e,Ve,function(){return Je(e,u,n)})},set:function(e,t,n){var r,i=Re(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Qe(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Qe(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Ye(0,t,s)}}}),S.cssHooks.marginLeft=Fe(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(We(e,"marginLeft"))||e.getBoundingClientRect().left-Me(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Ye)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Re(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=Ke).prototype={constructor:Ke,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=Ke.propHooks[this.prop];return e&&e.get?e.get(this):Ke.propHooks._default.get(this)},run:function(e){var t,n=Ke.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):Ke.propHooks._default.set(this),this}}).init.prototype=Ke.prototype,(Ke.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[ze(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=Ke.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=Ke.prototype.init,S.fx.step={};var Ze,et,tt,nt,rt=/^(?:toggle|show|hide)$/,it=/queueHooks$/;function ot(){et&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(ot):C.setTimeout(ot,S.fx.interval),S.fx.tick())}function at(){return C.setTimeout(function(){Ze=void 0}),Ze=Date.now()}function st(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ut(e,t,n){for(var r,i=(lt.tweeners[t]||[]).concat(lt.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function lt(o,e,t){var n,a,r=0,i=lt.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=Ze||at(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:Ze||at(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=lt.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ut,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(lt,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],lt.tweeners[n]=lt.tweeners[n]||[],lt.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],rt.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ut(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?lt.prefilters.unshift(e):lt.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=lt(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&it.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(st(r,!0),e,t,n)}}),S.each({slideDown:st("show"),slideUp:st("hide"),slideToggle:st("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(Ze=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),Ze=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){et||(et=!0,ot())},S.fx.stop=function(){et=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},tt=E.createElement("input"),nt=E.createElement("select").appendChild(E.createElement("option")),tt.type="checkbox",y.checkOn=""!==tt.value,y.optSelected=nt.selected,(tt=E.createElement("input")).value="t",tt.type="radio",y.radioValue="t"===tt.value;var ct,ft=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?ct:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),ct={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=ft[t]||S.find.attr;ft[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=ft[o],ft[o]=r,r=null!=a(e,t,n)?o:null,ft[o]=i),r}});var pt=/^(?:input|select|textarea|button)$/i,dt=/^(?:a|area)$/i;function ht(e){return(e.match(P)||[]).join(" ")}function gt(e){return e.getAttribute&&e.getAttribute("class")||""}function vt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):pt.test(e.nodeName)||dt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,gt(this)))});if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,gt(this)))});if(!arguments.length)return this.attr("class","");if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,gt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=vt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=gt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+ht(gt(n))+" ").indexOf(t))return!0;return!1}});var yt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(yt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:ht(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var mt=/^(?:focusinfocus|focusoutblur)$/,xt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!mt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,mt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,xt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,xt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var bt=C.location,wt={guid:Date.now()},Tt=/\?/;S.parseXML=function(e){var t,n;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){}return n=t&&t.getElementsByTagName("parsererror")[0],t&&!n||S.error("Invalid XML: "+(n?S.map(n.childNodes,function(e){return e.textContent}).join("\n"):e)),t};var Ct=/\[\]$/,Et=/\r?\n/g,St=/^(?:submit|button|image|reset|file)$/i,kt=/^(?:input|select|textarea|keygen)/i;function At(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||Ct.test(n)?i(n,t):At(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)At(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)At(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&kt.test(this.nodeName)&&!St.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(Et,"\r\n")}}):{name:t.name,value:n.replace(Et,"\r\n")}}).get()}});var Nt=/%20/g,jt=/#.*$/,Dt=/([?&])_=[^&]*/,qt=/^(.*?):[ \t]*([^\r\n]*)$/gm,Lt=/^(?:GET|HEAD)$/,Ht=/^\/\//,Ot={},Pt={},Rt="*/".concat("*"),Mt=E.createElement("a");function It(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Wt(t,i,o,a){var s={},u=t===Pt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function Ft(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Mt.href=bt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:bt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(bt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Rt,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Ft(Ft(e,S.ajaxSettings),t):Ft(S.ajaxSettings,e)},ajaxPrefilter:It(Ot),ajaxTransport:It(Pt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=qt.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||bt.href)+"").replace(Ht,bt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Mt.protocol+"//"+Mt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Wt(Ot,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Lt.test(v.type),f=v.url.replace(jt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(Nt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Tt.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Dt,"$1"),o=(Tt.test(f)?"&":"?")+"_="+wt.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+Rt+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Wt(Pt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&S.inArray("json",v.dataTypes)<0&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var Bt={0:200,1223:204},$t=S.ajaxSettings.xhr();y.cors=!!$t&&"withCredentials"in $t,y.ajax=$t=!!$t,S.ajaxTransport(function(i){var o,a;if(y.cors||$t&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(Bt[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var _t,zt=[],Ut=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=zt.pop()||S.expando+"_"+wt.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Ut.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Ut.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Ut,"$1"+r):!1!==e.jsonp&&(e.url+=(Tt.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,zt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((_t=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===_t.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=ht(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=Fe(y.pixelPosition,function(e,t){if(t)return t=We(e,n),Pe.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Xt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Xt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Vt=C.jQuery,Gt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Gt),e&&C.jQuery===S&&(C.jQuery=Vt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S}); diff --git a/main/_static/language_data.js b/main/_static/language_data.js index ebe2f03b..2e22b06a 100644 --- a/main/_static/language_data.js +++ b/main/_static/language_data.js @@ -10,7 +10,7 @@   *   */ -var stopwords = ["a","and","are","as","at","be","but","by","for","if","in","into","is","it","near","no","not","of","on","or","such","that","the","their","then","there","these","they","this","to","was","will","with"]; +var stopwords = ["a", "and", "are", "as", "at", "be", "but", "by", "for", "if", "in", "into", "is", "it", "near", "no", "not", "of", "on", "or", "such", "that", "the", "their", "then", "there", "these", "they", "this", "to", "was", "will", "with"];  /* Non-minified version is copied as a separate JS file, is available */ @@ -197,101 +197,3 @@ var Stemmer = function() {    }  } - - - -var splitChars = (function() { -    var result = {}; -    var singles = [96, 180, 187, 191, 215, 247, 749, 885, 903, 907, 909, 930, 1014, 1648, -         1748, 1809, 2416, 2473, 2481, 2526, 2601, 2609, 2612, 2615, 2653, 2702, -         2706, 2729, 2737, 2740, 2857, 2865, 2868, 2910, 2928, 2948, 2961, 2971, -         2973, 3085, 3089, 3113, 3124, 3213, 3217, 3241, 3252, 3295, 3341, 3345, -         3369, 3506, 3516, 3633, 3715, 3721, 3736, 3744, 3748, 3750, 3756, 3761, -         3781, 3912, 4239, 4347, 4681, 4695, 4697, 4745, 4785, 4799, 4801, 4823, -         4881, 5760, 5901, 5997, 6313, 7405, 8024, 8026, 8028, 8030, 8117, 8125, -         8133, 8181, 8468, 8485, 8487, 8489, 8494, 8527, 11311, 11359, 11687, 11695, -         11703, 11711, 11719, 11727, 11735, 12448, 12539, 43010, 43014, 43019, 43587, -         43696, 43713, 64286, 64297, 64311, 64317, 64319, 64322, 64325, 65141]; -    var i, j, start, end; -    for (i = 0; i < singles.length; i++) { -        result[singles[i]] = true; -    } -    var ranges = [[0, 47], [58, 64], [91, 94], [123, 169], [171, 177], [182, 184], [706, 709], -         [722, 735], [741, 747], [751, 879], [888, 889], [894, 901], [1154, 1161], -         [1318, 1328], [1367, 1368], [1370, 1376], [1416, 1487], [1515, 1519], [1523, 1568], -         [1611, 1631], [1642, 1645], [1750, 1764], [1767, 1773], [1789, 1790], [1792, 1807], -         [1840, 1868], [1958, 1968], [1970, 1983], [2027, 2035], [2038, 2041], [2043, 2047], -         [2070, 2073], [2075, 2083], [2085, 2087], [2089, 2307], [2362, 2364], [2366, 2383], -         [2385, 2391], [2402, 2405], [2419, 2424], [2432, 2436], [2445, 2446], [2449, 2450], -         [2483, 2485], [2490, 2492], [2494, 2509], [2511, 2523], [2530, 2533], [2546, 2547], -         [2554, 2564], [2571, 2574], [2577, 2578], [2618, 2648], [2655, 2661], [2672, 2673], -         [2677, 2692], [2746, 2748], [2750, 2767], [2769, 2783], [2786, 2789], [2800, 2820], -         [2829, 2830], [2833, 2834], [2874, 2876], [2878, 2907], [2914, 2917], [2930, 2946], -         [2955, 2957], [2966, 2968], [2976, 2978], [2981, 2983], [2987, 2989], [3002, 3023], -         [3025, 3045], [3059, 3076], [3130, 3132], [3134, 3159], [3162, 3167], [3170, 3173], -         [3184, 3191], [3199, 3204], [3258, 3260], [3262, 3293], [3298, 3301], [3312, 3332], -         [3386, 3388], [3390, 3423], [3426, 3429], [3446, 3449], [3456, 3460], [3479, 3481], -         [3518, 3519], [3527, 3584], [3636, 3647], [3655, 3663], [3674, 3712], [3717, 3718], -         [3723, 3724], [3726, 3731], [3752, 3753], [3764, 3772], [3774, 3775], [3783, 3791], -         [3802, 3803], [3806, 3839], [3841, 3871], [3892, 3903], [3949, 3975], [3980, 4095], -         [4139, 4158], [4170, 4175], [4182, 4185], [4190, 4192], [4194, 4196], [4199, 4205], -         [4209, 4212], [4226, 4237], [4250, 4255], [4294, 4303], [4349, 4351], [4686, 4687], -         [4702, 4703], [4750, 4751], [4790, 4791], [4806, 4807], [4886, 4887], [4955, 4968], -         [4989, 4991], [5008, 5023], [5109, 5120], [5741, 5742], [5787, 5791], [5867, 5869], -         [5873, 5887], [5906, 5919], [5938, 5951], [5970, 5983], [6001, 6015], [6068, 6102], -         [6104, 6107], [6109, 6111], [6122, 6127], [6138, 6159], [6170, 6175], [6264, 6271], -         [6315, 6319], [6390, 6399], [6429, 6469], [6510, 6511], [6517, 6527], [6572, 6592], -         [6600, 6607], [6619, 6655], [6679, 6687], [6741, 6783], [6794, 6799], [6810, 6822], -         [6824, 6916], [6964, 6980], [6988, 6991], [7002, 7042], [7073, 7085], [7098, 7167], -         [7204, 7231], [7242, 7244], [7294, 7400], [7410, 7423], [7616, 7679], [7958, 7959], -         [7966, 7967], [8006, 8007], [8014, 8015], [8062, 8063], [8127, 8129], [8141, 8143], -         [8148, 8149], [8156, 8159], [8173, 8177], [8189, 8303], [8306, 8307], [8314, 8318], -         [8330, 8335], [8341, 8449], [8451, 8454], [8456, 8457], [8470, 8472], [8478, 8483], -         [8506, 8507], [8512, 8516], [8522, 8525], [8586, 9311], [9372, 9449], [9472, 10101], -         [10132, 11263], [11493, 11498], [11503, 11516], [11518, 11519], [11558, 11567], -         [11622, 11630], [11632, 11647], [11671, 11679], [11743, 11822], [11824, 12292], -         [12296, 12320], [12330, 12336], [12342, 12343], [12349, 12352], [12439, 12444], -         [12544, 12548], [12590, 12592], [12687, 12689], [12694, 12703], [12728, 12783], -         [12800, 12831], [12842, 12880], [12896, 12927], [12938, 12976], [12992, 13311], -         [19894, 19967], [40908, 40959], [42125, 42191], [42238, 42239], [42509, 42511], -         [42540, 42559], [42592, 42593], [42607, 42622], [42648, 42655], [42736, 42774], -         [42784, 42785], [42889, 42890], [42893, 43002], [43043, 43055], [43062, 43071], -         [43124, 43137], [43188, 43215], [43226, 43249], [43256, 43258], [43260, 43263], -         [43302, 43311], [43335, 43359], [43389, 43395], [43443, 43470], [43482, 43519], -         [43561, 43583], [43596, 43599], [43610, 43615], [43639, 43641], [43643, 43647], -         [43698, 43700], [43703, 43704], [43710, 43711], [43715, 43738], [43742, 43967], -         [44003, 44015], [44026, 44031], [55204, 55215], [55239, 55242], [55292, 55295], -         [57344, 63743], [64046, 64047], [64110, 64111], [64218, 64255], [64263, 64274], -         [64280, 64284], [64434, 64466], [64830, 64847], [64912, 64913], [64968, 65007], -         [65020, 65135], [65277, 65295], [65306, 65312], [65339, 65344], [65371, 65381], -         [65471, 65473], [65480, 65481], [65488, 65489], [65496, 65497]]; -    for (i = 0; i < ranges.length; i++) { -        start = ranges[i][0]; -        end = ranges[i][1]; -        for (j = start; j <= end; j++) { -            result[j] = true; -        } -    } -    return result; -})(); - -function splitQuery(query) { -    var result = []; -    var start = -1; -    for (var i = 0; i < query.length; i++) { -        if (splitChars[query.charCodeAt(i)]) { -            if (start !== -1) { -                result.push(query.slice(start, i)); -                start = -1; -            } -        } else if (start === -1) { -            start = i; -        } -    } -    if (start !== -1) { -        result.push(query.slice(start)); -    } -    return result; -} - - diff --git a/main/_static/searchtools.js b/main/_static/searchtools.js index 0a44e858..ac4d5861 100644 --- a/main/_static/searchtools.js +++ b/main/_static/searchtools.js @@ -8,18 +8,20 @@   * :license: BSD, see LICENSE for details.   *   */ +"use strict"; -if (!Scorer) { -  /** -   * Simple result scoring code. -   */ +/** + * Simple result scoring code. + */ +if (typeof Scorer === "undefined") {    var Scorer = {      // Implement the following function to further tweak the score for each result -    // The function takes a result array [filename, title, anchor, descr, score] +    // The function takes a result array [docname, title, anchor, descr, score, filename]      // and returns the new score.      /* -    score: function(result) { -      return result[4]; +    score: result => { +      const [docname, title, anchor, descr, score, filename] = result +      return score      },      */ @@ -28,9 +30,11 @@ if (!Scorer) {      // or matches in the last dotted part of the object name      objPartialMatch: 6,      // Additive scores depending on the priority of the object -    objPrio: {0:  15,   // used to be importantResults -              1:  5,   // used to be objectResults -              2: -5},  // used to be unimportantResults +    objPrio: { +      0: 15, // used to be importantResults +      1: 5, // used to be objectResults +      2: -5, // used to be unimportantResults +    },      //  Used when the priority is not in the mapping.      objPrioDefault: 0, @@ -39,452 +43,455 @@ if (!Scorer) {      partialTitle: 7,      // query found in terms      term: 5, -    partialTerm: 2 +    partialTerm: 2,    };  } -if (!splitQuery) { -  function splitQuery(query) { -    return query.split(/\s+/); +const _removeChildren = (element) => { +  while (element && element.lastChild) element.removeChild(element.lastChild); +}; + +/** + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#escaping + */ +const _escapeRegExp = (string) => +  string.replace(/[.*+\-?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string + +const _displayItem = (item, highlightTerms, searchTerms) => { +  const docBuilder = DOCUMENTATION_OPTIONS.BUILDER; +  const docUrlRoot = DOCUMENTATION_OPTIONS.URL_ROOT; +  const docFileSuffix = DOCUMENTATION_OPTIONS.FILE_SUFFIX; +  const docLinkSuffix = DOCUMENTATION_OPTIONS.LINK_SUFFIX; +  const showSearchSummary = DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY; + +  const [docName, title, anchor, descr] = item; + +  let listItem = document.createElement("li"); +  let requestUrl; +  let linkUrl; +  if (docBuilder === "dirhtml") { +    // dirhtml builder +    let dirname = docName + "/"; +    if (dirname.match(/\/index\/$/)) +      dirname = dirname.substring(0, dirname.length - 6); +    else if (dirname === "index/") dirname = ""; +    requestUrl = docUrlRoot + dirname; +    linkUrl = requestUrl; +  } else { +    // normal html builders +    requestUrl = docUrlRoot + docName + docFileSuffix; +    linkUrl = docName + docLinkSuffix; +  } +  const params = new URLSearchParams(); +  params.set("highlight", [...highlightTerms].join(" ")); +  let linkEl = listItem.appendChild(document.createElement("a")); +  linkEl.href = linkUrl + "?" + params.toString() + anchor; +  linkEl.innerHTML = title; +  if (descr) +    listItem.appendChild(document.createElement("span")).innerText = +      " (" + descr + ")"; +  else if (showSearchSummary) +    fetch(requestUrl) +      .then((responseData) => responseData.text()) +      .then((data) => { +        if (data) +          listItem.appendChild( +            Search.makeSearchSummary(data, searchTerms, highlightTerms) +          ); +      }); +  Search.output.appendChild(listItem); +}; +const _finishSearch = (resultCount) => { +  Search.stopPulse(); +  Search.title.innerText = _("Search Results"); +  if (!resultCount) +    Search.status.innerText = Documentation.gettext( +      "Your search did not match any documents. Please make sure that all words are spelled correctly and that you've selected enough categories." +    ); +  else +    Search.status.innerText = _( +      `Search finished, found ${resultCount} page(s) matching the search query.` +    ); +}; +const _displayNextItem = ( +  results, +  resultCount, +  highlightTerms, +  searchTerms +) => { +  // results left, load the summary and display it +  // this is intended to be dynamic (don't sub resultsCount) +  if (results.length) { +    _displayItem(results.pop(), highlightTerms, searchTerms); +    setTimeout( +      () => _displayNextItem(results, resultCount, highlightTerms, searchTerms), +      5 +    );    } +  // search finished, update title and status message +  else _finishSearch(resultCount); +}; + +/** + * Default splitQuery function. Can be overridden in ``sphinx.search`` with a + * custom function per language. + * + * The regular expression works by splitting the string on consecutive characters + * that are not Unicode letters, numbers, underscores, or emoji characters. + * This is the same as ``\W+`` in Python, preserving the surrogate pair area. + */ +if (typeof splitQuery === "undefined") { +  var splitQuery = (query) => query +      .split(/[^\p{Letter}\p{Number}_\p{Emoji_Presentation}]+/gu) +      .filter(term => term)  // remove remaining empty strings  }  /**   * Search Module   */ -var Search = { - -  _index : null, -  _queued_query : null, -  _pulse_status : -1, - -  htmlToText : function(htmlString) { -      var virtualDocument = document.implementation.createHTMLDocument('virtual'); -      var htmlElement = $(htmlString, virtualDocument); -      htmlElement.find('.headerlink').remove(); -      docContent = htmlElement.find('[role=main]')[0]; -      if(docContent === undefined) { -          console.warn("Content block not found. Sphinx search tries to obtain it " + -                       "via '[role=main]'. Could you check your theme or template."); -          return ""; -      } -      return docContent.textContent || docContent.innerText; +const Search = { +  _index: null, +  _queued_query: null, +  _pulse_status: -1, + +  htmlToText: (htmlString) => { +    const htmlElement = document +      .createRange() +      .createContextualFragment(htmlString); +    _removeChildren(htmlElement.querySelectorAll(".headerlink")); +    const docContent = htmlElement.querySelector('[role="main"]'); +    if (docContent !== undefined) return docContent.textContent; +    console.warn( +      "Content block not found. Sphinx search tries to obtain it via '[role=main]'. Could you check your theme or template." +    ); +    return "";    }, -  init : function() { -      var params = $.getQueryParameters(); -      if (params.q) { -          var query = params.q[0]; -          $('input[name="q"]')[0].value = query; -          this.performSearch(query); -      } +  init: () => { +    const query = new URLSearchParams(window.location.search).get("q"); +    document +      .querySelectorAll('input[name="q"]') +      .forEach((el) => (el.value = query)); +    if (query) Search.performSearch(query);    }, -  loadIndex : function(url) { -    $.ajax({type: "GET", url: url, data: null, -            dataType: "script", cache: true, -            complete: function(jqxhr, textstatus) { -              if (textstatus != "success") { -                document.getElementById("searchindexloader").src = url; -              } -            }}); -  }, +  loadIndex: (url) => +    (document.body.appendChild(document.createElement("script")).src = url), -  setIndex : function(index) { -    var q; -    this._index = index; -    if ((q = this._queued_query) !== null) { -      this._queued_query = null; -      Search.query(q); +  setIndex: (index) => { +    Search._index = index; +    if (Search._queued_query !== null) { +      const query = Search._queued_query; +      Search._queued_query = null; +      Search.query(query);      }    }, -  hasIndex : function() { -      return this._index !== null; -  }, +  hasIndex: () => Search._index !== null, -  deferQuery : function(query) { -      this._queued_query = query; -  }, +  deferQuery: (query) => (Search._queued_query = query), -  stopPulse : function() { -      this._pulse_status = 0; -  }, +  stopPulse: () => (Search._pulse_status = -1), -  startPulse : function() { -    if (this._pulse_status >= 0) -        return; -    function pulse() { -      var i; +  startPulse: () => { +    if (Search._pulse_status >= 0) return; + +    const pulse = () => {        Search._pulse_status = (Search._pulse_status + 1) % 4; -      var dotString = ''; -      for (i = 0; i < Search._pulse_status; i++) -        dotString += '.'; -      Search.dots.text(dotString); -      if (Search._pulse_status > -1) -        window.setTimeout(pulse, 500); -    } +      Search.dots.innerText = ".".repeat(Search._pulse_status); +      if (Search._pulse_status >= 0) window.setTimeout(pulse, 500); +    };      pulse();    },    /**     * perform a search for something (or wait until index is loaded)     */ -  performSearch : function(query) { +  performSearch: (query) => {      // create the required interface elements -    this.out = $('#search-results'); -    this.title = $('<h2>' + _('Searching') + '</h2>').appendTo(this.out); -    this.dots = $('<span></span>').appendTo(this.title); -    this.status = $('<p class="search-summary"> </p>').appendTo(this.out); -    this.output = $('<ul class="search"/>').appendTo(this.out); - -    $('#search-progress').text(_('Preparing search...')); -    this.startPulse(); +    const searchText = document.createElement("h2"); +    searchText.textContent = _("Searching"); +    const searchSummary = document.createElement("p"); +    searchSummary.classList.add("search-summary"); +    searchSummary.innerText = ""; +    const searchList = document.createElement("ul"); +    searchList.classList.add("search"); + +    const out = document.getElementById("search-results"); +    Search.title = out.appendChild(searchText); +    Search.dots = Search.title.appendChild(document.createElement("span")); +    Search.status = out.appendChild(searchSummary); +    Search.output = out.appendChild(searchList); + +    const searchProgress = document.getElementById("search-progress"); +    // Some themes don't use the search progress node +    if (searchProgress) { +      searchProgress.innerText = _("Preparing search..."); +    } +    Search.startPulse();      // index already loaded, the browser was quick! -    if (this.hasIndex()) -      this.query(query); -    else -      this.deferQuery(query); +    if (Search.hasIndex()) Search.query(query); +    else Search.deferQuery(query);    },    /**     * execute search (requires search index to be loaded)     */ -  query : function(query) { -    var i; - -    // stem the searchterms and add them to the correct list -    var stemmer = new Stemmer(); -    var searchterms = []; -    var excluded = []; -    var hlterms = []; -    var tmp = splitQuery(query); -    var objectterms = []; -    for (i = 0; i < tmp.length; i++) { -      if (tmp[i] !== "") { -          objectterms.push(tmp[i].toLowerCase()); -      } +  query: (query) => { +    // stem the search terms and add them to the correct list +    const stemmer = new Stemmer(); +    const searchTerms = new Set(); +    const excludedTerms = new Set(); +    const highlightTerms = new Set(); +    const objectTerms = new Set(splitQuery(query.toLowerCase().trim())); +    splitQuery(query.trim()).forEach((queryTerm) => { +      const queryTermLower = queryTerm.toLowerCase(); + +      // maybe skip this "word" +      // stopwords array is from language_data.js +      if ( +        stopwords.indexOf(queryTermLower) !== -1 || +        queryTerm.match(/^\d+$/) +      ) +        return; -      if ($u.indexOf(stopwords, tmp[i].toLowerCase()) != -1 || tmp[i] === "") { -        // skip this "word" -        continue; -      }        // stem the word -      var word = stemmer.stemWord(tmp[i].toLowerCase()); -      var toAppend; +      let word = stemmer.stemWord(queryTermLower);        // select the correct list -      if (word[0] == '-') { -        toAppend = excluded; -        word = word.substr(1); -      } +      if (word[0] === "-") excludedTerms.add(word.substr(1));        else { -        toAppend = searchterms; -        hlterms.push(tmp[i].toLowerCase()); +        searchTerms.add(word); +        highlightTerms.add(queryTermLower);        } -      // only add if not already in the list -      if (!$u.contains(toAppend, word)) -        toAppend.push(word); -    } -    var highlightstring = '?highlight=' + $.urlencode(hlterms.join(" ")); - -    // console.debug('SEARCH: searching for:'); -    // console.info('required: ', searchterms); -    // console.info('excluded: ', excluded); +    }); -    // prepare search -    var terms = this._index.terms; -    var titleterms = this._index.titleterms; +    // console.debug("SEARCH: searching for:"); +    // console.info("required: ", [...searchTerms]); +    // console.info("excluded: ", [...excludedTerms]); -    // array of [filename, title, anchor, descr, score] -    var results = []; -    $('#search-progress').empty(); +    // array of [docname, title, anchor, descr, score, filename] +    let results = []; +    _removeChildren(document.getElementById("search-progress"));      // lookup as object -    for (i = 0; i < objectterms.length; i++) { -      var others = [].concat(objectterms.slice(0, i), -                             objectterms.slice(i+1, objectterms.length)); -      results = results.concat(this.performObjectSearch(objectterms[i], others)); -    } +    objectTerms.forEach((term) => +      results.push(...Search.performObjectSearch(term, objectTerms)) +    );      // lookup as search terms in fulltext -    results = results.concat(this.performTermsSearch(searchterms, excluded, terms, titleterms)); +    results.push(...Search.performTermsSearch(searchTerms, excludedTerms));      // let the scorer override scores with a custom scoring function -    if (Scorer.score) { -      for (i = 0; i < results.length; i++) -        results[i][4] = Scorer.score(results[i]); -    } +    if (Scorer.score) results.forEach((item) => (item[4] = Scorer.score(item)));      // now sort the results by score (in opposite order of appearance, since the      // display function below uses pop() to retrieve items) and then      // alphabetically -    results.sort(function(a, b) { -      var left = a[4]; -      var right = b[4]; -      if (left > right) { -        return 1; -      } else if (left < right) { -        return -1; -      } else { +    results.sort((a, b) => { +      const leftScore = a[4]; +      const rightScore = b[4]; +      if (leftScore === rightScore) {          // same score: sort alphabetically -        left = a[1].toLowerCase(); -        right = b[1].toLowerCase(); -        return (left > right) ? -1 : ((left < right) ? 1 : 0); +        const leftTitle = a[1].toLowerCase(); +        const rightTitle = b[1].toLowerCase(); +        if (leftTitle === rightTitle) return 0; +        return leftTitle > rightTitle ? -1 : 1; // inverted is intentional        } +      return leftScore > rightScore ? 1 : -1;      }); +    // remove duplicate search results +    // note the reversing of results, so that in the case of duplicates, the highest-scoring entry is kept +    let seen = new Set(); +    results = results.reverse().reduce((acc, result) => { +      let resultStr = result.slice(0, 4).concat([result[5]]).map(v => String(v)).join(','); +      if (!seen.has(resultStr)) { +        acc.push(result); +        seen.add(resultStr); +      } +      return acc; +    }, []); + +    results = results.reverse(); +      // for debugging      //Search.lastresults = results.slice();  // a copy -    //console.info('search results:', Search.lastresults); +    // console.info("search results:", Search.lastresults);      // print the results -    var resultCount = results.length; -    function displayNextItem() { -      // results left, load the summary and display it -      if (results.length) { -        var item = results.pop(); -        var listItem = $('<li></li>'); -        var requestUrl = ""; -        var linkUrl = ""; -        if (DOCUMENTATION_OPTIONS.BUILDER === 'dirhtml') { -          // dirhtml builder -          var dirname = item[0] + '/'; -          if (dirname.match(/\/index\/$/)) { -            dirname = dirname.substring(0, dirname.length-6); -          } else if (dirname == 'index/') { -            dirname = ''; -          } -          requestUrl = DOCUMENTATION_OPTIONS.URL_ROOT + dirname; -          linkUrl = requestUrl; - -        } else { -          // normal html builders -          requestUrl = DOCUMENTATION_OPTIONS.URL_ROOT + item[0] + DOCUMENTATION_OPTIONS.FILE_SUFFIX; -          linkUrl = item[0] + DOCUMENTATION_OPTIONS.LINK_SUFFIX; -        } -        listItem.append($('<a/>').attr('href', -            linkUrl + -            highlightstring + item[2]).html(item[1])); -        if (item[3]) { -          listItem.append($('<span> (' + item[3] + ')</span>')); -          Search.output.append(listItem); -          setTimeout(function() { -            displayNextItem(); -          }, 5); -        } else if (DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY) { -          $.ajax({url: requestUrl, -                  dataType: "text", -                  complete: function(jqxhr, textstatus) { -                    var data = jqxhr.responseText; -                    if (data !== '' && data !== undefined) { -                      var summary = Search.makeSearchSummary(data, searchterms, hlterms); -                      if (summary) { -                        listItem.append(summary); -                      } -                    } -                    Search.output.append(listItem); -                    setTimeout(function() { -                      displayNextItem(); -                    }, 5); -                  }}); -        } else { -          // just display title -          Search.output.append(listItem); -          setTimeout(function() { -            displayNextItem(); -          }, 5); -        } -      } -      // search finished, update title and status message -      else { -        Search.stopPulse(); -        Search.title.text(_('Search Results')); -        if (!resultCount) -          Search.status.text(_('Your search did not match any documents. Please make sure that all words are spelled correctly and that you\'ve selected enough categories.')); -        else -            Search.status.text(_('Search finished, found %s page(s) matching the search query.').replace('%s', resultCount)); -        Search.status.fadeIn(500); -      } -    } -    displayNextItem(); +    _displayNextItem(results, results.length, highlightTerms, searchTerms);    },    /**     * search for object names     */ -  performObjectSearch : function(object, otherterms) { -    var filenames = this._index.filenames; -    var docnames = this._index.docnames; -    var objects = this._index.objects; -    var objnames = this._index.objnames; -    var titles = this._index.titles; - -    var i; -    var results = []; - -    for (var prefix in objects) { -      for (var iMatch = 0; iMatch != objects[prefix].length; ++iMatch) { -        var match = objects[prefix][iMatch]; -        var name = match[4]; -        var fullname = (prefix ? prefix + '.' : '') + name; -        var fullnameLower = fullname.toLowerCase() -        if (fullnameLower.indexOf(object) > -1) { -          var score = 0; -          var parts = fullnameLower.split('.'); -          // check for different match types: exact matches of full name or -          // "last name" (i.e. last dotted part) -          if (fullnameLower == object || parts[parts.length - 1] == object) { -            score += Scorer.objNameMatch; -          // matches in last name -          } else if (parts[parts.length - 1].indexOf(object) > -1) { -            score += Scorer.objPartialMatch; -          } -          var objname = objnames[match[1]][2]; -          var title = titles[match[0]]; -          // If more than one term searched for, we require other words to be -          // found in the name/title/description -          if (otherterms.length > 0) { -            var haystack = (prefix + ' ' + name + ' ' + -                            objname + ' ' + title).toLowerCase(); -            var allfound = true; -            for (i = 0; i < otherterms.length; i++) { -              if (haystack.indexOf(otherterms[i]) == -1) { -                allfound = false; -                break; -              } -            } -            if (!allfound) { -              continue; -            } -          } -          var descr = objname + _(', in ') + title; - -          var anchor = match[3]; -          if (anchor === '') -            anchor = fullname; -          else if (anchor == '-') -            anchor = objnames[match[1]][1] + '-' + fullname; -          // add custom score for some objects according to scorer -          if (Scorer.objPrio.hasOwnProperty(match[2])) { -            score += Scorer.objPrio[match[2]]; -          } else { -            score += Scorer.objPrioDefault; -          } -          results.push([docnames[match[0]], fullname, '#'+anchor, descr, score, filenames[match[0]]]); -        } +  performObjectSearch: (object, objectTerms) => { +    const filenames = Search._index.filenames; +    const docNames = Search._index.docnames; +    const objects = Search._index.objects; +    const objNames = Search._index.objnames; +    const titles = Search._index.titles; + +    const results = []; + +    const objectSearchCallback = (prefix, match) => { +      const name = match[4] +      const fullname = (prefix ? prefix + "." : "") + name; +      const fullnameLower = fullname.toLowerCase(); +      if (fullnameLower.indexOf(object) < 0) return; + +      let score = 0; +      const parts = fullnameLower.split("."); + +      // check for different match types: exact matches of full name or +      // "last name" (i.e. last dotted part) +      if (fullnameLower === object || parts.slice(-1)[0] === object) +        score += Scorer.objNameMatch; +      else if (parts.slice(-1)[0].indexOf(object) > -1) +        score += Scorer.objPartialMatch; // matches in last name + +      const objName = objNames[match[1]][2]; +      const title = titles[match[0]]; + +      // If more than one term searched for, we require other words to be +      // found in the name/title/description +      const otherTerms = new Set(objectTerms); +      otherTerms.delete(object); +      if (otherTerms.size > 0) { +        const haystack = `${prefix} ${name} ${objName} ${title}`.toLowerCase(); +        if ( +          [...otherTerms].some((otherTerm) => haystack.indexOf(otherTerm) < 0) +        ) +          return;        } -    } +      let anchor = match[3]; +      if (anchor === "") anchor = fullname; +      else if (anchor === "-") anchor = objNames[match[1]][1] + "-" + fullname; + +      const descr = objName + _(", in ") + title; + +      // add custom score for some objects according to scorer +      if (Scorer.objPrio.hasOwnProperty(match[2])) +        score += Scorer.objPrio[match[2]]; +      else score += Scorer.objPrioDefault; + +      results.push([ +        docNames[match[0]], +        fullname, +        "#" + anchor, +        descr, +        score, +        filenames[match[0]], +      ]); +    }; +    Object.keys(objects).forEach((prefix) => +      objects[prefix].forEach((array) => +        objectSearchCallback(prefix, array) +      ) +    );      return results;    },    /** -   * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions -   */ -  escapeRegExp : function(string) { -    return string.replace(/[.*+\-?^${}()|[\]\\]/g, '\\$&'); // $& means the whole matched string -  }, - -  /**     * search for full-text terms in the index     */ -  performTermsSearch : function(searchterms, excluded, terms, titleterms) { -    var docnames = this._index.docnames; -    var filenames = this._index.filenames; -    var titles = this._index.titles; +  performTermsSearch: (searchTerms, excludedTerms) => { +    // prepare search +    const terms = Search._index.terms; +    const titleTerms = Search._index.titleterms; +    const docNames = Search._index.docnames; +    const filenames = Search._index.filenames; +    const titles = Search._index.titles; -    var i, j, file; -    var fileMap = {}; -    var scoreMap = {}; -    var results = []; +    const scoreMap = new Map(); +    const fileMap = new Map();      // perform the search on the required terms -    for (i = 0; i < searchterms.length; i++) { -      var word = searchterms[i]; -      var files = []; -      var _o = [ -        {files: terms[word], score: Scorer.term}, -        {files: titleterms[word], score: Scorer.title} +    searchTerms.forEach((word) => { +      const files = []; +      const arr = [ +        { files: terms[word], score: Scorer.term }, +        { files: titleTerms[word], score: Scorer.title },        ];        // add support for partial matches        if (word.length > 2) { -        var word_regex = this.escapeRegExp(word); -        for (var w in terms) { -          if (w.match(word_regex) && !terms[word]) { -            _o.push({files: terms[w], score: Scorer.partialTerm}) -          } -        } -        for (var w in titleterms) { -          if (w.match(word_regex) && !titleterms[word]) { -              _o.push({files: titleterms[w], score: Scorer.partialTitle}) -          } -        } +        const escapedWord = _escapeRegExp(word); +        Object.keys(terms).forEach((term) => { +          if (term.match(escapedWord) && !terms[word]) +            arr.push({ files: terms[term], score: Scorer.partialTerm }); +        }); +        Object.keys(titleTerms).forEach((term) => { +          if (term.match(escapedWord) && !titleTerms[word]) +            arr.push({ files: titleTerms[word], score: Scorer.partialTitle }); +        });        }        // no match but word was a required one -      if ($u.every(_o, function(o){return o.files === undefined;})) { -        break; -      } +      if (arr.every((record) => record.files === undefined)) return; +        // found search word in contents -      $u.each(_o, function(o) { -        var _files = o.files; -        if (_files === undefined) -          return - -        if (_files.length === undefined) -          _files = [_files]; -        files = files.concat(_files); - -        // set score for the word in each file to Scorer.term -        for (j = 0; j < _files.length; j++) { -          file = _files[j]; -          if (!(file in scoreMap)) -            scoreMap[file] = {}; -          scoreMap[file][word] = o.score; -        } +      arr.forEach((record) => { +        if (record.files === undefined) return; + +        let recordFiles = record.files; +        if (recordFiles.length === undefined) recordFiles = [recordFiles]; +        files.push(...recordFiles); + +        // set score for the word in each file +        recordFiles.forEach((file) => { +          if (!scoreMap.has(file)) scoreMap.set(file, {}); +          scoreMap.get(file)[word] = record.score; +        });        });        // create the mapping -      for (j = 0; j < files.length; j++) { -        file = files[j]; -        if (file in fileMap && fileMap[file].indexOf(word) === -1) -          fileMap[file].push(word); -        else -          fileMap[file] = [word]; -      } -    } +      files.forEach((file) => { +        if (fileMap.has(file) && fileMap.get(file).indexOf(word) === -1) +          fileMap.get(file).push(word); +        else fileMap.set(file, [word]); +      }); +    });      // now check if the files don't contain excluded terms -    for (file in fileMap) { -      var valid = true; - +    const results = []; +    for (const [file, wordList] of fileMap) {        // check if all requirements are matched -      var filteredTermCount = // as search terms with length < 3 are discarded: ignore -        searchterms.filter(function(term){return term.length > 2}).length + +      // as search terms with length < 3 are discarded +      const filteredTermCount = [...searchTerms].filter( +        (term) => term.length > 2 +      ).length;        if ( -        fileMap[file].length != searchterms.length && -        fileMap[file].length != filteredTermCount -      ) continue; +        wordList.length !== searchTerms.size && +        wordList.length !== filteredTermCount +      ) +        continue;        // ensure that none of the excluded terms is in the search result -      for (i = 0; i < excluded.length; i++) { -        if (terms[excluded[i]] == file || -            titleterms[excluded[i]] == file || -            $u.contains(terms[excluded[i]] || [], file) || -            $u.contains(titleterms[excluded[i]] || [], file)) { -          valid = false; -          break; -        } -      } +      if ( +        [...excludedTerms].some( +          (term) => +            terms[term] === file || +            titleTerms[term] === file || +            (terms[term] || []).includes(file) || +            (titleTerms[term] || []).includes(file) +        ) +      ) +        break; -      // if we have still a valid result we can add it to the result list -      if (valid) { -        // select one (max) score for the file. -        // for better ranking, we should calculate ranking by using words statistics like basic tf-idf... -        var score = $u.max($u.map(fileMap[file], function(w){return scoreMap[file][w]})); -        results.push([docnames[file], titles[file], '', null, score, filenames[file]]); -      } +      // select one (max) score for the file. +      const score = Math.max(...wordList.map((w) => scoreMap.get(file)[w])); +      // add result to the result list +      results.push([ +        docNames[file], +        titles[file], +        "", +        null, +        score, +        filenames[file], +      ]);      }      return results;    }, @@ -492,34 +499,33 @@ var Search = {    /**     * helper function to return a node containing the     * search summary for a given text. keywords is a list -   * of stemmed words, hlwords is the list of normal, unstemmed +   * of stemmed words, highlightWords is the list of normal, unstemmed     * words. the first one is used to find the occurrence, the     * latter for highlighting it.     */ -  makeSearchSummary : function(htmlText, keywords, hlwords) { -    var text = Search.htmlToText(htmlText); -    if (text == "") { -      return null; -    } -    var textLower = text.toLowerCase(); -    var start = 0; -    $.each(keywords, function() { -      var i = textLower.indexOf(this.toLowerCase()); -      if (i > -1) -        start = i; -    }); -    start = Math.max(start - 120, 0); -    var excerpt = ((start > 0) ? '...' : '') + -      $.trim(text.substr(start, 240)) + -      ((start + 240 - text.length) ? '...' : ''); -    var rv = $('<p class="context"></p>').text(excerpt); -    $.each(hlwords, function() { -      rv = rv.highlightText(this, 'highlighted'); -    }); -    return rv; -  } +  makeSearchSummary: (htmlText, keywords, highlightWords) => { +    const text = Search.htmlToText(htmlText).toLowerCase(); +    if (text === "") return null; + +    const actualStartPosition = [...keywords] +      .map((k) => text.indexOf(k.toLowerCase())) +      .filter((i) => i > -1) +      .slice(-1)[0]; +    const startWithContext = Math.max(actualStartPosition - 120, 0); + +    const top = startWithContext === 0 ? "" : "..."; +    const tail = startWithContext + 240 < text.length ? "..." : ""; + +    let summary = document.createElement("div"); +    summary.classList.add("context"); +    summary.innerText = top + text.substr(startWithContext, 240).trim() + tail; + +    highlightWords.forEach((highlightWord) => +      _highlightText(summary, highlightWord, "highlighted") +    ); + +    return summary; +  },  }; -$(document).ready(function() { -  Search.init(); -}); +_ready(Search.init); diff --git a/main/changelog.html b/main/changelog.html index e9c411fc..c1a7d530 100644 --- a/main/changelog.html +++ b/main/changelog.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /><link rel="prev" title="site_api" href="output/botcore.site_api.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Changelog - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="changelog"> -<h1>Changelog<a class="headerlink" href="#changelog" title="Permalink to this headline">#</a></h1> +<h1>Changelog<a class="headerlink" href="#changelog" title="Permalink to this heading">#</a></h1>  <section id="Next 7.x feature release">  <h2 style="margin-bottom: 0.3em;"><a class="reference external" href="https://github.com/python-discord/bot-core/releases/tag/vmaster">Next 7.x feature release</a></h2><ul class="simple">  <li><p>[<span style="color: #4070A0;">Support</span>]<span> </span><a class="reference external" href="https://github.com/python-discord/bot-core/issues/79">#79</a><span>:</span> Restore on-site changelog.</p></li> @@ -468,6 +468,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/main/genindex.html b/main/genindex.html index 97a71f0b..4529a150 100644 --- a/main/genindex.html +++ b/main/genindex.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="#" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Index - Bot Core Latest (7.1.1)</title> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Index - Bot Core Latest (7.1.1)</title>  <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" /> @@ -700,6 +700,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/main/index.html b/main/index.html index 6f5a1b36..4138cc4c 100644 --- a/main/index.html +++ b/main/index.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /><link rel="next" title="Botcore" href="output/botcore.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,10 +271,10 @@          </div>          <article role="main">            <section id="bot-core-project-documentation"> -<h1>Bot Core Project Documentation<a class="headerlink" href="#bot-core-project-documentation" title="Permalink to this headline">#</a></h1> +<h1>Bot Core Project Documentation<a class="headerlink" href="#bot-core-project-documentation" title="Permalink to this heading">#</a></h1>  </section>  <section id="reference"> -<h1>Reference<a class="headerlink" href="#reference" title="Permalink to this headline">#</a></h1> +<h1>Reference<a class="headerlink" href="#reference" title="Permalink to this heading">#</a></h1>  <div class="toctree-wrapper compound">  <p class="caption" role="heading"><span class="caption-text">Modules:</span></p>  <ul> @@ -300,7 +300,7 @@  </div>  </section>  <section id="extras"> -<h1>Extras<a class="headerlink" href="#extras" title="Permalink to this headline">#</a></h1> +<h1>Extras<a class="headerlink" href="#extras" title="Permalink to this heading">#</a></h1>  <ul class="simple">  <li><p><a class="reference internal" href="genindex.html"><span class="std std-ref">Index</span></a></p></li>  <li><p><a class="reference internal" href="search.html"><span class="std std-ref">Search Page</span></a></p></li> @@ -353,6 +353,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/main/index_redirect.html b/main/index_redirect.html index c008500c..7f087bcf 100644 --- a/main/index_redirect.html +++ b/main/index_redirect.html @@ -1,5 +1,5 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head>      <script>window.location.replace("./main/index.html")</script> @@ -7,7 +7,7 @@      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" /> @@ -57,6 +57,7 @@  <script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/main/output/botcore.async_stats.html b/main/output/botcore.async_stats.html index fade9931..74e5e503 100644 --- a/main/output/botcore.async_stats.html +++ b/main/output/botcore.async_stats.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="site_api" href="botcore.site_api.html" /><link rel="prev" title="scheduling" href="botcore.utils.scheduling.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>async_stats - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,16 +271,16 @@          </div>          <article role="main">            <section id="module-botcore.async_stats"> -<span id="async-stats"></span><h1>async_stats<a class="headerlink" href="#module-botcore.async_stats" title="Permalink to this headline">#</a></h1> +<span id="async-stats"></span><h1>async_stats<a class="headerlink" href="#module-botcore.async_stats" title="Permalink to this heading">#</a></h1>  <p>An async transport method for statsd communication.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.async_stats.AsyncStatsClient"> -<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">AsyncStatsClient</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">loop</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">host</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">'localhost'</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">port</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">8125</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">prefix</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/async_stats.py#L12-L55"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.async_stats.AsyncStatsClient" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-class docutils literal notranslate"><span class="pre">statsd.client.base.StatsClientBase</span></code></a></p> +<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">AsyncStatsClient</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">loop</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">host</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">'localhost'</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">port</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">8125</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">prefix</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/async_stats.py#L12-L55"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.async_stats.AsyncStatsClient" title="Permalink to this definition">#</a></dt> +<dd><p>Bases: <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-class docutils literal notranslate"><span class="pre">StatsClientBase</span></code></a></p>  <p>An async implementation of <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">statsd.client.base.StatsClientBase</span></code></a> that supports async stat communication.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.async_stats.AsyncStatsClient.__init__"> -<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">loop</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">host</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">'localhost'</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">port</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">8125</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">prefix</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/async_stats.py#L15-L39"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.async_stats.AsyncStatsClient.__init__" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">loop</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">host</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">'localhost'</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">port</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">8125</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">prefix</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/async_stats.py#L15-L39"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.async_stats.AsyncStatsClient.__init__" title="Permalink to this definition">#</a></dt>  <dd><p>Create a new <a class="reference internal" href="#botcore.async_stats.AsyncStatsClient" title="botcore.async_stats.AsyncStatsClient"><code class="xref py py-obj docutils literal notranslate"><span class="pre">AsyncStatsClient</span></code></a>.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -297,7 +297,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.async_stats.AsyncStatsClient.create_socket"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">create_socket</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/async_stats.py#L40-L47"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.async_stats.AsyncStatsClient.create_socket" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">create_socket</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/async_stats.py#L40-L47"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.async_stats.AsyncStatsClient.create_socket" title="Permalink to this definition">#</a></dt>  <dd><p>Use <a class="reference external" href="https://docs.python.org/3/library/asyncio-eventloop.html#asyncio.loop.create_datagram_endpoint" title="(in Python v3.10)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">asyncio.loop.create_datagram_endpoint</span></code></a> from the loop given on init to create a socket.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -364,6 +364,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/main/output/botcore.exts.html b/main/output/botcore.exts.html index 98e650cb..d598e750 100644 --- a/main/output/botcore.exts.html +++ b/main/output/botcore.exts.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Utils" href="botcore.utils.html" /><link rel="prev" title="Botcore" href="botcore.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Exts - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.exts"> -<span id="exts"></span><h1>Exts<a class="headerlink" href="#module-botcore.exts" title="Permalink to this headline">#</a></h1> +<span id="exts"></span><h1>Exts<a class="headerlink" href="#module-botcore.exts" title="Permalink to this heading">#</a></h1>  <p>Reusable Discord cogs.</p>  </section> @@ -329,6 +329,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/main/output/botcore.html b/main/output/botcore.html index fa00e3eb..1e478274 100644 --- a/main/output/botcore.html +++ b/main/output/botcore.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Exts" href="botcore.exts.html" /><link rel="prev" title="Bot Core Project Documentation" href="../index.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Botcore - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,16 +271,16 @@          </div>          <article role="main">            <section id="module-botcore"> -<span id="botcore"></span><h1>Botcore<a class="headerlink" href="#module-botcore" title="Permalink to this headline">#</a></h1> +<span id="botcore"></span><h1>Botcore<a class="headerlink" href="#module-botcore" title="Permalink to this heading">#</a></h1>  <p>Useful utilities and tools for Discord bot development.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.BotBase"> -<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">BotBase</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">guild_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">allowed_roles</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">http_session</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">redis_session</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">api_client</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">statsd_url</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L36-L290"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Bot" title="(in discord.py v2.0.0a)"><code class="xref py py-class docutils literal notranslate"><span class="pre">discord.ext.commands.bot.Bot</span></code></a></p> +<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">BotBase</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">guild_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">allowed_roles</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">http_session</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">redis_session</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">api_client</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">statsd_url</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L36-L290"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase" title="Permalink to this definition">#</a></dt> +<dd><p>Bases: <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Bot" title="(in discord.py v2.0.0a)"><code class="xref py py-class docutils literal notranslate"><span class="pre">Bot</span></code></a></p>  <p>A sub-class that implements many common features that Python Discord bots use.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.__init__"> -<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">guild_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">allowed_roles</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">http_session</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">redis_session</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">api_client</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">statsd_url</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L39-L89"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.__init__" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">guild_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">allowed_roles</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">http_session</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">redis_session</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">api_client</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">statsd_url</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L39-L89"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.__init__" title="Permalink to this definition">#</a></dt>  <dd><p>Initialise the base bot instance.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -299,7 +299,7 @@ a dummy statsd client will be created.</p></li>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.add_cog"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">add_cog</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">cog</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L152-L156"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.add_cog" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">add_cog</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">cog</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L152-L156"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.add_cog" title="Permalink to this definition">#</a></dt>  <dd><p>Add the given <code class="docutils literal notranslate"><span class="pre">cog</span></code> to the bot and log the operation.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -310,7 +310,7 @@ a dummy statsd client will be created.</p></li>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.add_command"> -<span class="sig-name descname"><span class="pre">add_command</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">command</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L157-L161"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.add_command" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">add_command</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">command</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L157-L161"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.add_command" title="Permalink to this definition">#</a></dt>  <dd><p>Add <code class="docutils literal notranslate"><span class="pre">command</span></code> as normal and then add its root aliases to the bot.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -321,7 +321,7 @@ a dummy statsd client will be created.</p></li>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.clear"> -<span class="sig-name descname"><span class="pre">clear</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L177-L180"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.clear" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">clear</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L177-L180"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.clear" title="Permalink to this definition">#</a></dt>  <dd><p>Not implemented! Re-instantiate the bot instead of attempting to re-use a closed one.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -332,7 +332,7 @@ a dummy statsd client will be created.</p></li>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.close"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">close</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L256-L290"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.close" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">close</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L256-L290"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.close" title="Permalink to this definition">#</a></dt>  <dd><p>Close the Discord connection, and the aiohttp session, connector, statsd client, and resolver.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -343,7 +343,7 @@ a dummy statsd client will be created.</p></li>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.load_extensions"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">load_extensions</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">module</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L119-L130"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.load_extensions" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">load_extensions</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">module</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L119-L130"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.load_extensions" title="Permalink to this definition">#</a></dt>  <dd><p>Load all the extensions within the given module and save them to <code class="docutils literal notranslate"><span class="pre">self.all_extensions</span></code>.</p>  <p>This should be ran in a task on the event loop to avoid deadlocks caused by <code class="docutils literal notranslate"><span class="pre">wait_for</span></code> calls.</p>  <dl class="field-list simple"> @@ -355,7 +355,7 @@ a dummy statsd client will be created.</p></li>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.log_to_dev_log"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">log_to_dev_log</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">message</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L205-L208"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.log_to_dev_log" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">log_to_dev_log</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">message</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L205-L208"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.log_to_dev_log" title="Permalink to this definition">#</a></dt>  <dd><p>Log the given message to #dev-log.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -366,7 +366,7 @@ a dummy statsd client will be created.</p></li>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.on_guild_available"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">on_guild_available</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">guild</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L188-L204"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.on_guild_available" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">on_guild_available</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">guild</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L188-L204"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.on_guild_available" title="Permalink to this definition">#</a></dt>  <dd><p>Set the internal guild available event when self.guild_id becomes available.</p>  <p>If the cache appears to still be empty (no members, no channels, or no roles), the event  will not be set and <cite>guild_available_but_cache_empty</cite> event will be emitted.</p> @@ -379,7 +379,7 @@ will not be set and <cite>guild_available_but_cache_empty</cite> event will be e  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.on_guild_unavailable"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">on_guild_unavailable</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">guild</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L181-L187"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.on_guild_unavailable" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">on_guild_unavailable</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">guild</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L181-L187"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.on_guild_unavailable" title="Permalink to this definition">#</a></dt>  <dd><p>Clear the internal guild available event when self.guild_id becomes unavailable.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -390,7 +390,7 @@ will not be set and <cite>guild_available_but_cache_empty</cite> event will be e  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.ping_services"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">ping_services</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L252-L255"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.ping_services" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">ping_services</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L252-L255"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.ping_services" title="Permalink to this definition">#</a></dt>  <dd><p>Ping all required services on setup to ensure they are up before starting.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -401,7 +401,7 @@ will not be set and <cite>guild_available_but_cache_empty</cite> event will be e  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.remove_command"> -<span class="sig-name descname"><span class="pre">remove_command</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L162-L176"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.remove_command" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">remove_command</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L162-L176"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.remove_command" title="Permalink to this definition">#</a></dt>  <dd><p>Remove a command/alias as normal and then remove its root aliases from the bot.</p>  <p>Individual root aliases cannot be removed by this function.  To remove them, either remove the entire command or manually edit <cite>bot.all_commands</cite>.</p> @@ -414,7 +414,7 @@ To remove them, either remove the entire command or manually edit <cite>bot.all_  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.setup_hook"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">setup_hook</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L218-L251"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.setup_hook" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">setup_hook</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L218-L251"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.setup_hook" title="Permalink to this definition">#</a></dt>  <dd><p>An async init to startup generic services.</p>  <p>Connects to statsd, and calls  <a class="reference internal" href="botcore.async_stats.html#botcore.async_stats.AsyncStatsClient.create_socket" title="botcore.async_stats.AsyncStatsClient.create_socket"><code class="xref py py-func docutils literal notranslate"><span class="pre">AsyncStatsClient.create_socket</span></code></a> @@ -428,7 +428,7 @@ and <a class="reference internal" href="#botcore.BotBase.ping_services" title="b  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.wait_until_guild_available"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">wait_until_guild_available</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L209-L217"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.wait_until_guild_available" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">wait_until_guild_available</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L209-L217"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase.wait_until_guild_available" title="Permalink to this definition">#</a></dt>  <dd><p>Wait until the guild that matches the <code class="docutils literal notranslate"><span class="pre">guild_id</span></code> given at init is available (and the cache is ready).</p>  <p>The on_ready event is inadequate because it only waits 2 seconds for a GUILD_CREATE  gateway event before giving up and thus not populating the cache for unavailable guilds.</p> @@ -443,18 +443,18 @@ gateway event before giving up and thus not populating the cache for unavailable  <dl class="py exception">  <dt class="sig sig-object py" id="botcore.StartupError"> -<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">StartupError</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">base</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L28-L34"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.StartupError" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">StartupError</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">base</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L28-L34"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.StartupError" title="Permalink to this definition">#</a></dt>  <dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/exceptions.html#Exception" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">Exception</span></code></a></p>  <p>Exception class for startup errors.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.StartupError.__init__"> -<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">base</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/__init__.py#L31-L34"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.StartupError.__init__" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">base</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/__init__.py#L31-L34"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.StartupError.__init__" title="Permalink to this definition">#</a></dt>  <dd></dd></dl>  </dd></dl>  <section id="subpackages"> -<h2>Subpackages<a class="headerlink" href="#subpackages" title="Permalink to this headline">#</a></h2> +<h2>Subpackages<a class="headerlink" href="#subpackages" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.exts.html">Exts</a></li> @@ -474,7 +474,7 @@ gateway event before giving up and thus not populating the cache for unavailable  </div>  </section>  <section id="submodules"> -<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this headline">#</a></h2> +<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.async_stats.html">async_stats</a></li> @@ -558,6 +558,7 @@ gateway event before giving up and thus not populating the cache for unavailable  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/main/output/botcore.site_api.html b/main/output/botcore.site_api.html index 699fc57e..c25b27b4 100644 --- a/main/output/botcore.site_api.html +++ b/main/output/botcore.site_api.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Changelog" href="../changelog.html" /><link rel="prev" title="async_stats" href="botcore.async_stats.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>site_api - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,16 +271,16 @@          </div>          <article role="main">            <section id="module-botcore.site_api"> -<span id="site-api"></span><h1>site_api<a class="headerlink" href="#module-botcore.site_api" title="Permalink to this headline">#</a></h1> +<span id="site-api"></span><h1>site_api<a class="headerlink" href="#module-botcore.site_api" title="Permalink to this heading">#</a></h1>  <p>An API wrapper around the Site API.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.site_api.APIClient"> -<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">APIClient</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">site_api_url</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">site_api_token</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">session_kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L42-L154"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">APIClient</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">site_api_url</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">site_api_token</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">session_kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L42-L154"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient" title="Permalink to this definition">#</a></dt>  <dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/functions.html#object" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></a></p>  <p>A wrapper for the Django Site API.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.site_api.APIClient.__init__"> -<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">site_api_url</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">site_api_token</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">session_kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L48-L71"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.__init__" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">site_api_url</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">site_api_token</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">session_kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L48-L71"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.__init__" title="Permalink to this definition">#</a></dt>  <dd><p>Initialize a new <a class="reference internal" href="#botcore.site_api.APIClient" title="botcore.site_api.APIClient"><code class="xref py py-obj docutils literal notranslate"><span class="pre">APIClient</span></code></a> instance.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -295,7 +295,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.site_api.APIClient.close"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">close</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L75-L78"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.close" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">close</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L75-L78"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.close" title="Permalink to this definition">#</a></dt>  <dd><p>Close the aiohttp session.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -306,7 +306,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.site_api.APIClient.delete"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">delete</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L136-L154"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.delete" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">delete</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L136-L154"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.delete" title="Permalink to this definition">#</a></dt>  <dd><p>Send a DELETE request to the site API and return the JSON response.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -327,7 +327,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.site_api.APIClient.get"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">get</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L120-L123"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.get" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">get</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L120-L123"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.get" title="Permalink to this definition">#</a></dt>  <dd><p>Equivalent to <a class="reference internal" href="#botcore.site_api.APIClient.request" title="botcore.site_api.APIClient.request"><code class="xref py py-meth docutils literal notranslate"><span class="pre">APIClient.request()</span></code></a> with GET passed as the method.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -338,7 +338,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.site_api.APIClient.maybe_raise_for_status"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">maybe_raise_for_status</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">response</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">should_raise</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L79-L98"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.maybe_raise_for_status" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">maybe_raise_for_status</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">response</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">should_raise</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L79-L98"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.maybe_raise_for_status" title="Permalink to this definition">#</a></dt>  <dd><p>Raise <a class="reference internal" href="#botcore.site_api.ResponseCodeError" title="botcore.site_api.ResponseCodeError"><code class="xref py py-exc docutils literal notranslate"><span class="pre">ResponseCodeError</span></code></a> for non-OK response if an exception should be raised.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -358,7 +358,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.site_api.APIClient.patch"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">patch</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L124-L127"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.patch" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">patch</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L124-L127"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.patch" title="Permalink to this definition">#</a></dt>  <dd><p>Equivalent to <a class="reference internal" href="#botcore.site_api.APIClient.request" title="botcore.site_api.APIClient.request"><code class="xref py py-meth docutils literal notranslate"><span class="pre">APIClient.request()</span></code></a> with PATCH passed as the method.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -369,7 +369,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.site_api.APIClient.post"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">post</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L128-L131"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.post" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">post</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L128-L131"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.post" title="Permalink to this definition">#</a></dt>  <dd><p>Equivalent to <a class="reference internal" href="#botcore.site_api.APIClient.request" title="botcore.site_api.APIClient.request"><code class="xref py py-meth docutils literal notranslate"><span class="pre">APIClient.request()</span></code></a> with POST passed as the method.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -380,7 +380,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.site_api.APIClient.put"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">put</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L132-L135"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.put" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">put</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L132-L135"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.put" title="Permalink to this definition">#</a></dt>  <dd><p>Equivalent to <a class="reference internal" href="#botcore.site_api.APIClient.request" title="botcore.site_api.APIClient.request"><code class="xref py py-meth docutils literal notranslate"><span class="pre">APIClient.request()</span></code></a> with PUT passed as the method.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -391,7 +391,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.site_api.APIClient.request"> -<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">request</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">method</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L99-L119"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.request" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">async</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">request</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">method</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">endpoint</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">raise_for_status</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">True</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L99-L119"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.APIClient.request" title="Permalink to this definition">#</a></dt>  <dd><p>Send an HTTP request to the site API and return the JSON response.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -418,12 +418,12 @@  <dl class="py exception">  <dt class="sig sig-object py" id="botcore.site_api.ResponseCodeError"> -<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">ResponseCodeError</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">response</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">response_json</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">response_text</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L14-L40"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.ResponseCodeError" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">exception</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">ResponseCodeError</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">response</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">response_json</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">response_text</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L14-L40"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.ResponseCodeError" title="Permalink to this definition">#</a></dt>  <dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/exceptions.html#ValueError" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">ValueError</span></code></a></p>  <p>Raised in <a class="reference internal" href="#botcore.site_api.APIClient.request" title="botcore.site_api.APIClient.request"><code class="xref py py-meth docutils literal notranslate"><span class="pre">APIClient.request()</span></code></a> when a non-OK HTTP response is received.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.site_api.ResponseCodeError.__init__"> -<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">response</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">response_json</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">response_text</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L17-L35"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.ResponseCodeError.__init__" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">response</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">response_json</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">response_text</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L17-L35"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.ResponseCodeError.__init__" title="Permalink to this definition">#</a></dt>  <dd><p>Initialize a new <a class="reference internal" href="#botcore.site_api.ResponseCodeError" title="botcore.site_api.ResponseCodeError"><code class="xref py py-obj docutils literal notranslate"><span class="pre">ResponseCodeError</span></code></a> instance.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -438,7 +438,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.site_api.ResponseCodeError.__str__"> -<span class="sig-name descname"><span class="pre">__str__</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/site_api.py#L36-L40"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.ResponseCodeError.__str__" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">__str__</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/site_api.py#L36-L40"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.site_api.ResponseCodeError.__str__" title="Permalink to this definition">#</a></dt>  <dd><p>Return a string representation of the error.</p>  </dd></dl> @@ -500,6 +500,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/main/output/botcore.utils.caching.html b/main/output/botcore.utils.caching.html index 27dcbebf..60c7a3f5 100644 --- a/main/output/botcore.utils.caching.html +++ b/main/output/botcore.utils.caching.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="channel" href="botcore.utils.channel.html" /><link rel="prev" title="Utils" href="botcore.utils.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>caching - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,18 +271,18 @@          </div>          <article role="main">            <section id="module-botcore.utils.caching"> -<span id="caching"></span><h1>caching<a class="headerlink" href="#module-botcore.utils.caching" title="Permalink to this headline">#</a></h1> +<span id="caching"></span><h1>caching<a class="headerlink" href="#module-botcore.utils.caching" title="Permalink to this heading">#</a></h1>  <p>Utilities related to custom caches.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.caching.AsyncCache"> -<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">AsyncCache</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">max_size</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">128</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/caching.py#L8-L66"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.caching.AsyncCache" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">AsyncCache</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">max_size</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">128</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/caching.py#L8-L66"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.caching.AsyncCache" title="Permalink to this definition">#</a></dt>  <dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/functions.html#object" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></a></p>  <p>LRU cache implementation for coroutines.</p>  <p>Once the cache exceeds the maximum size, keys are deleted in FIFO order.</p>  <p>An offset may be optionally provided to be applied to the coroutine’s arguments when creating the cache key.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.caching.AsyncCache.__call__"> -<span class="sig-name descname"><span class="pre">__call__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">arg_offset</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">0</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/caching.py#L27-L62"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.caching.AsyncCache.__call__" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">__call__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">arg_offset</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">0</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/caching.py#L27-L62"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.caching.AsyncCache.__call__" title="Permalink to this definition">#</a></dt>  <dd><p>Decorator for async cache.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -299,7 +299,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.caching.AsyncCache.__init__"> -<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">max_size</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">128</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/caching.py#L17-L26"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.caching.AsyncCache.__init__" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">max_size</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">128</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/caching.py#L17-L26"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.caching.AsyncCache.__init__" title="Permalink to this definition">#</a></dt>  <dd><p>Initialise a new <a class="reference internal" href="#botcore.utils.caching.AsyncCache" title="botcore.utils.caching.AsyncCache"><code class="xref py py-obj docutils literal notranslate"><span class="pre">AsyncCache</span></code></a> instance.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -310,7 +310,7 @@  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.caching.AsyncCache.clear"> -<span class="sig-name descname"><span class="pre">clear</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/caching.py#L63-L66"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.caching.AsyncCache.clear" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">clear</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/caching.py#L63-L66"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.caching.AsyncCache.clear" title="Permalink to this definition">#</a></dt>  <dd><p>Clear cache instance.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -377,6 +377,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/main/output/botcore.utils.channel.html b/main/output/botcore.utils.channel.html index d1f8fe0e..2eb2f5e6 100644 --- a/main/output/botcore.utils.channel.html +++ b/main/output/botcore.utils.channel.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="logging" href="botcore.utils.logging.html" /><link rel="prev" title="caching" href="botcore.utils.caching.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>channel - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,11 +271,11 @@          </div>          <article role="main">            <section id="module-botcore.utils.channel"> -<span id="channel"></span><h1>channel<a class="headerlink" href="#module-botcore.utils.channel" title="Permalink to this headline">#</a></h1> +<span id="channel"></span><h1>channel<a class="headerlink" href="#module-botcore.utils.channel" title="Permalink to this heading">#</a></h1>  <p>Useful helper functions for interacting with various discord channel objects.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.channel.get_or_fetch_channel"> -<em class="property"><span class="k"><span class="pre">async</span></span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">get_or_fetch_channel</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">bot</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">channel_id</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/channel.py#L25-L55"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.channel.get_or_fetch_channel" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="k"><span class="pre">async</span></span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">get_or_fetch_channel</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">bot</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">channel_id</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/channel.py#L25-L55"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.channel.get_or_fetch_channel" title="Permalink to this definition">#</a></dt>  <dd><p>Attempt to get or fetch the given <code class="docutils literal notranslate"><span class="pre">channel_id</span></code> from the bots cache, and return it.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -303,7 +303,7 @@  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.channel.is_in_category"> -<span class="sig-name descname"><span class="pre">is_in_category</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">channel</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">category_id</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/channel.py#L11-L23"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.channel.is_in_category" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">is_in_category</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">channel</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">category_id</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/channel.py#L11-L23"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.channel.is_in_category" title="Permalink to this definition">#</a></dt>  <dd><p>Return whether the given <code class="docutils literal notranslate"><span class="pre">channel</span></code> in the the category with the id <code class="docutils literal notranslate"><span class="pre">category_id</span></code>.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -377,6 +377,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/main/output/botcore.utils.html b/main/output/botcore.utils.html index 326ea9b6..9d39c689 100644 --- a/main/output/botcore.utils.html +++ b/main/output/botcore.utils.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="caching" href="botcore.utils.caching.html" /><link rel="prev" title="Exts" href="botcore.exts.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Utils - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,11 +271,11 @@          </div>          <article role="main">            <section id="module-botcore.utils"> -<span id="utils"></span><h1>Utils<a class="headerlink" href="#module-botcore.utils" title="Permalink to this headline">#</a></h1> +<span id="utils"></span><h1>Utils<a class="headerlink" href="#module-botcore.utils" title="Permalink to this heading">#</a></h1>  <p>Useful utilities and tools for Discord bot development.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.apply_monkey_patches"> -<span class="sig-name descname"><span class="pre">apply_monkey_patches</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/__init__.py#L7-L21"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.apply_monkey_patches" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">apply_monkey_patches</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/__init__.py#L7-L21"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.apply_monkey_patches" title="Permalink to this definition">#</a></dt>  <dd><p>Applies all common monkey patches for our bots.</p>  <dl>  <dt>Patches <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Command" title="(in discord.py v2.0.0a)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">discord.ext.commands.Command</span></code></a> and <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Group" title="(in discord.py v2.0.0a)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">discord.ext.commands.Group</span></code></a> to support root aliases.</dt><dd><p>A <code class="docutils literal notranslate"><span class="pre">root_aliases</span></code> keyword argument is added to these two objects, which is a sequence of alias names @@ -294,7 +294,7 @@ that will act as top-level groups rather than being aliases of the command’s g  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.unqualify"> -<span class="sig-name descname"><span class="pre">unqualify</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/__init__.py#L10-L21"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.unqualify" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">unqualify</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/__init__.py#L10-L21"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.unqualify" title="Permalink to this definition">#</a></dt>  <dd><p>Return an unqualified name given a qualified module/package <code class="docutils literal notranslate"><span class="pre">name</span></code>.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -310,7 +310,7 @@ that will act as top-level groups rather than being aliases of the command’s g  </dd></dl>  <section id="submodules"> -<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this headline">#</a></h2> +<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.utils.caching.html">caching</a></li> @@ -397,6 +397,7 @@ that will act as top-level groups rather than being aliases of the command’s g  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/main/output/botcore.utils.logging.html b/main/output/botcore.utils.logging.html index ed1331e0..d7aad0c8 100644 --- a/main/output/botcore.utils.logging.html +++ b/main/output/botcore.utils.logging.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="members" href="botcore.utils.members.html" /><link rel="prev" title="channel" href="botcore.utils.channel.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>logging - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,16 +271,16 @@          </div>          <article role="main">            <section id="module-botcore.utils.logging"> -<span id="logging"></span><h1>logging<a class="headerlink" href="#module-botcore.utils.logging" title="Permalink to this headline">#</a></h1> +<span id="logging"></span><h1>logging<a class="headerlink" href="#module-botcore.utils.logging" title="Permalink to this heading">#</a></h1>  <p>Common logging related functions.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.logging.CustomLogger"> -<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">CustomLogger</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">level</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">0</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/logging.py#L14-L33"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.logging.CustomLogger" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">logging.Logger</span></code></a></p> +<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">CustomLogger</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">level</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">0</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/logging.py#L14-L33"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.logging.CustomLogger" title="Permalink to this definition">#</a></dt> +<dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">Logger</span></code></a></p>  <p>Custom implementation of the <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">logging.Logger</span></code></a> class with an added <a class="reference internal" href="#botcore.utils.logging.CustomLogger.trace" title="botcore.utils.logging.CustomLogger.trace"><code class="xref py py-obj docutils literal notranslate"><span class="pre">trace</span></code></a> method.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.logging.CustomLogger.trace"> -<span class="sig-name descname"><span class="pre">trace</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">msg</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/logging.py#L17-L33"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.logging.CustomLogger.trace" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">trace</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">msg</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/logging.py#L17-L33"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.logging.CustomLogger.trace" title="Permalink to this definition">#</a></dt>  <dd><p>Log the given message with the severity <code class="docutils literal notranslate"><span class="pre">"TRACE"</span></code>.</p>  <p>To pass exception information, use the keyword argument exc_info with a true value:</p>  <div class="highlight-py notranslate"><div class="highlight"><pre><span></span><span class="n">logger</span><span class="o">.</span><span class="n">trace</span><span class="p">(</span><span class="s2">"Houston, we have an </span><span class="si">%s</span><span class="s2">"</span><span class="p">,</span> <span class="s2">"interesting problem"</span><span class="p">,</span> <span class="n">exc_info</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span> @@ -304,7 +304,7 @@  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.logging.get_logger"> -<span class="sig-name descname"><span class="pre">get_logger</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/logging.py#L35-L46"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.logging.get_logger" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">get_logger</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/logging.py#L35-L46"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.logging.get_logger" title="Permalink to this definition">#</a></dt>  <dd><p>Utility to make mypy recognise that logger is of type <a class="reference internal" href="#botcore.utils.logging.CustomLogger" title="botcore.utils.logging.CustomLogger"><code class="xref py py-obj docutils literal notranslate"><span class="pre">CustomLogger</span></code></a>.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -375,6 +375,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/main/output/botcore.utils.members.html b/main/output/botcore.utils.members.html index 20b8c6bf..8a0d6062 100644 --- a/main/output/botcore.utils.members.html +++ b/main/output/botcore.utils.members.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="regex" href="botcore.utils.regex.html" /><link rel="prev" title="logging" href="botcore.utils.logging.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>members - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,11 +271,11 @@          </div>          <article role="main">            <section id="module-botcore.utils.members"> -<span id="members"></span><h1>members<a class="headerlink" href="#module-botcore.utils.members" title="Permalink to this headline">#</a></h1> +<span id="members"></span><h1>members<a class="headerlink" href="#module-botcore.utils.members" title="Permalink to this heading">#</a></h1>  <p>Useful helper functions for interactin with <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/api.html#discord.Member" title="(in discord.py v2.0.0a)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">discord.Member</span></code></a> objects.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.members.get_or_fetch_member"> -<em class="property"><span class="k"><span class="pre">async</span></span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">get_or_fetch_member</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">guild</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">member_id</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/members.py#L12-L29"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.members.get_or_fetch_member" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="k"><span class="pre">async</span></span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">get_or_fetch_member</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">guild</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">member_id</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/members.py#L12-L29"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.members.get_or_fetch_member" title="Permalink to this definition">#</a></dt>  <dd><p>Attempt to get a member from cache; on failure fetch from the API.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -289,7 +289,7 @@  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.members.handle_role_change"> -<em class="property"><span class="k"><span class="pre">async</span></span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">handle_role_change</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">member</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">coro</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">role</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/members.py#L31-L57"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.members.handle_role_change" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="k"><span class="pre">async</span></span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">handle_role_change</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">member</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">coro</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">role</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/members.py#L31-L57"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.members.handle_role_change" title="Permalink to this definition">#</a></dt>  <dd><p>Await the given <code class="docutils literal notranslate"><span class="pre">coro</span></code> with <code class="docutils literal notranslate"><span class="pre">member</span></code> as the sole argument.</p>  <p>Handle errors that we expect to be raised from  <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/api.html#discord.Member.add_roles" title="(in discord.py v2.0.0a)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">discord.Member.add_roles</span></code></a> and <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/api.html#discord.Member.remove_roles" title="(in discord.py v2.0.0a)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">discord.Member.remove_roles</span></code></a>.</p> @@ -362,6 +362,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/main/output/botcore.utils.regex.html b/main/output/botcore.utils.regex.html index 01590538..f89ed330 100644 --- a/main/output/botcore.utils.regex.html +++ b/main/output/botcore.utils.regex.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="scheduling" href="botcore.utils.scheduling.html" /><link rel="prev" title="members" href="botcore.utils.members.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>regex - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,11 +271,11 @@          </div>          <article role="main">            <section id="module-botcore.utils.regex"> -<span id="regex"></span><h1>regex<a class="headerlink" href="#module-botcore.utils.regex" title="Permalink to this headline">#</a></h1> +<span id="regex"></span><h1>regex<a class="headerlink" href="#module-botcore.utils.regex" title="Permalink to this heading">#</a></h1>  <p>Common regular expressions.</p>  <dl class="py data">  <dt class="sig sig-object py" id="botcore.utils.regex.DISCORD_INVITE"> -<span class="sig-name descname"><span class="pre">DISCORD_INVITE</span></span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/regex.py#L5-L16"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.regex.DISCORD_INVITE" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">DISCORD_INVITE</span></span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/regex.py#L5-L16"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.regex.DISCORD_INVITE" title="Permalink to this definition">#</a></dt>  <dd><p>Regex for Discord server invites.</p>  <div class="admonition warning">  <p class="admonition-title">Warning</p> @@ -289,7 +289,7 @@ such as <a class="reference external" href="https://docs.python.org/3/library/ur  <dl class="py data">  <dt class="sig sig-object py" id="botcore.utils.regex.FORMATTED_CODE_REGEX"> -<span class="sig-name descname"><span class="pre">FORMATTED_CODE_REGEX</span></span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/regex.py#L28-L36"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.regex.FORMATTED_CODE_REGEX" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">FORMATTED_CODE_REGEX</span></span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/regex.py#L28-L36"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.regex.FORMATTED_CODE_REGEX" title="Permalink to this definition">#</a></dt>  <dd><p>Regex for formatted code, using Discord’s code blocks.</p>  <dl class="field-list simple">  </dl> @@ -297,7 +297,7 @@ such as <a class="reference external" href="https://docs.python.org/3/library/ur  <dl class="py data">  <dt class="sig sig-object py" id="botcore.utils.regex.RAW_CODE_REGEX"> -<span class="sig-name descname"><span class="pre">RAW_CODE_REGEX</span></span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/regex.py#L43-L48"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.regex.RAW_CODE_REGEX" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">RAW_CODE_REGEX</span></span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/regex.py#L43-L48"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.regex.RAW_CODE_REGEX" title="Permalink to this definition">#</a></dt>  <dd><p>Regex for raw code, <em>not</em> using Discord’s code blocks.</p>  <dl class="field-list simple">  </dl> @@ -359,6 +359,7 @@ such as <a class="reference external" href="https://docs.python.org/3/library/ur  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/main/output/botcore.utils.scheduling.html b/main/output/botcore.utils.scheduling.html index 8a3bf1b9..7a6c4350 100644 --- a/main/output/botcore.utils.scheduling.html +++ b/main/output/botcore.utils.scheduling.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="async_stats" href="botcore.async_stats.html" /><link rel="prev" title="regex" href="botcore.utils.regex.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>scheduling - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,11 +271,11 @@          </div>          <article role="main">            <section id="module-botcore.utils.scheduling"> -<span id="scheduling"></span><h1>scheduling<a class="headerlink" href="#module-botcore.utils.scheduling" title="Permalink to this headline">#</a></h1> +<span id="scheduling"></span><h1>scheduling<a class="headerlink" href="#module-botcore.utils.scheduling" title="Permalink to this heading">#</a></h1>  <p>Generic python scheduler.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.scheduling.Scheduler"> -<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">Scheduler</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/scheduling.py#L13-L209"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler" title="Permalink to this definition">#</a></dt> +<em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">Scheduler</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/scheduling.py#L13-L209"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler" title="Permalink to this definition">#</a></dt>  <dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/functions.html#object" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></a></p>  <p>Schedule the execution of coroutines and keep track of them.</p>  <p>When instantiating a <a class="reference internal" href="#botcore.utils.scheduling.Scheduler" title="botcore.utils.scheduling.Scheduler"><code class="xref py py-obj docutils literal notranslate"><span class="pre">Scheduler</span></code></a>, a name must be provided. This name is used to distinguish the @@ -289,7 +289,7 @@ the same ID used to schedule it.</p>  <p>Any exception raised in a scheduled task is logged when the task is done.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.scheduling.Scheduler.__contains__"> -<span class="sig-name descname"><span class="pre">__contains__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">task_id</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/scheduling.py#L43-L54"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.__contains__" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">__contains__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">task_id</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/scheduling.py#L43-L54"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.__contains__" title="Permalink to this definition">#</a></dt>  <dd><p>Return <a class="reference external" href="https://docs.python.org/3/library/constants.html#True" title="(in Python v3.10)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">True</span></code></a> if a task with the given <code class="docutils literal notranslate"><span class="pre">task_id</span></code> is currently scheduled.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -306,7 +306,7 @@ the same ID used to schedule it.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.scheduling.Scheduler.__init__"> -<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/scheduling.py#L31-L42"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.__init__" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">__init__</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/scheduling.py#L31-L42"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.__init__" title="Permalink to this definition">#</a></dt>  <dd><p>Initialize a new <a class="reference internal" href="#botcore.utils.scheduling.Scheduler" title="botcore.utils.scheduling.Scheduler"><code class="xref py py-obj docutils literal notranslate"><span class="pre">Scheduler</span></code></a> instance.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -317,7 +317,7 @@ the same ID used to schedule it.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.scheduling.Scheduler.cancel"> -<span class="sig-name descname"><span class="pre">cancel</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">task_id</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/scheduling.py#L125-L142"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.cancel" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">cancel</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">task_id</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/scheduling.py#L125-L142"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.cancel" title="Permalink to this definition">#</a></dt>  <dd><p>Unschedule the task identified by <code class="docutils literal notranslate"><span class="pre">task_id</span></code>. Log a warning if the task doesn’t exist.</p>  <dl class="field-list simple">  <dt class="field-odd">Parameters</dt> @@ -331,7 +331,7 @@ the same ID used to schedule it.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.scheduling.Scheduler.cancel_all"> -<span class="sig-name descname"><span class="pre">cancel_all</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/scheduling.py#L143-L149"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.cancel_all" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">cancel_all</span></span><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/scheduling.py#L143-L149"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.cancel_all" title="Permalink to this definition">#</a></dt>  <dd><p>Unschedule all known tasks.</p>  <dl class="field-list simple">  <dt class="field-odd">Return type</dt> @@ -342,7 +342,7 @@ the same ID used to schedule it.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.scheduling.Scheduler.schedule"> -<span class="sig-name descname"><span class="pre">schedule</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">task_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">coroutine</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/scheduling.py#L55-L81"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.schedule" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">schedule</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">task_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">coroutine</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/scheduling.py#L55-L81"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.schedule" title="Permalink to this definition">#</a></dt>  <dd><p>Schedule the execution of a <code class="docutils literal notranslate"><span class="pre">coroutine</span></code>.</p>  <p>If a task with <code class="docutils literal notranslate"><span class="pre">task_id</span></code> already exists, close <code class="docutils literal notranslate"><span class="pre">coroutine</span></code> instead of scheduling it. This  prevents unawaited coroutine warnings. Don’t pass a coroutine that’ll be re-used elsewhere.</p> @@ -361,7 +361,7 @@ prevents unawaited coroutine warnings. Don’t pass a coroutine that’ll be re-  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.scheduling.Scheduler.schedule_at"> -<span class="sig-name descname"><span class="pre">schedule_at</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">time</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">task_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">coroutine</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/scheduling.py#L82-L105"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.schedule_at" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">schedule_at</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">time</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">task_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">coroutine</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/scheduling.py#L82-L105"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.schedule_at" title="Permalink to this definition">#</a></dt>  <dd><p>Schedule <code class="docutils literal notranslate"><span class="pre">coroutine</span></code> to be executed at the given <code class="docutils literal notranslate"><span class="pre">time</span></code>.</p>  <p>If <code class="docutils literal notranslate"><span class="pre">time</span></code> is timezone aware, then use that timezone to calculate now() when subtracting.  If <code class="docutils literal notranslate"><span class="pre">time</span></code> is naĂŻve, then use UTC.</p> @@ -384,7 +384,7 @@ prevents unawaited coroutine warnings. Don’t pass a coroutine that’ll be re-  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.scheduling.Scheduler.schedule_later"> -<span class="sig-name descname"><span class="pre">schedule_later</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">delay</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">task_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">coroutine</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/scheduling.py#L106-L124"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.schedule_later" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">schedule_later</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">delay</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">task_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">coroutine</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/scheduling.py#L106-L124"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.Scheduler.schedule_later" title="Permalink to this definition">#</a></dt>  <dd><p>Schedule <code class="docutils literal notranslate"><span class="pre">coroutine</span></code> to be executed after <code class="docutils literal notranslate"><span class="pre">delay</span></code> seconds.</p>  <p>If a task with <code class="docutils literal notranslate"><span class="pre">task_id</span></code> already exists, close <code class="docutils literal notranslate"><span class="pre">coroutine</span></code> instead of scheduling it. This  prevents unawaited coroutine warnings. Don’t pass a coroutine that’ll be re-used elsewhere.</p> @@ -406,7 +406,7 @@ prevents unawaited coroutine warnings. Don’t pass a coroutine that’ll be re-  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.scheduling.create_task"> -<span class="sig-name descname"><span class="pre">create_task</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">coro</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">suppressed_exceptions</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">()</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">event_loop</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/0c01973c33554f7da5e6c812ebaca5774f0bff57/botcore/utils/scheduling.py#L211-L239"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.create_task" title="Permalink to this definition">#</a></dt> +<span class="sig-name descname"><span class="pre">create_task</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">coro</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">*</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">suppressed_exceptions</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">()</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">event_loop</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/109da8bdde367e85d334b8f96dfaf28e7a52afee/botcore/utils/scheduling.py#L211-L239"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.scheduling.create_task" title="Permalink to this definition">#</a></dt>  <dd><p>Wrapper for creating an <a class="reference external" href="https://docs.python.org/3/library/asyncio-task.html#asyncio.Task" title="(in Python v3.10)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">asyncio.Task</span></code></a> which logs exceptions raised in the task.</p>  <p>If the <code class="docutils literal notranslate"><span class="pre">event_loop</span></code> kwarg is provided, the task is created from that event loop,  otherwise the running loop is used.</p> @@ -484,6 +484,7 @@ otherwise the running loop is used.</p>  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/main/py-modindex.html b/main/py-modindex.html index ca71d097..bb382d81 100644 --- a/main/py-modindex.html +++ b/main/py-modindex.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Python Module Index - Bot Core Latest (7.1.1)</title> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Python Module Index - Bot Core Latest (7.1.1)</title>  <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" /> @@ -385,6 +385,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/main/search.html b/main/search.html index c2374225..708dd74c 100644 --- a/main/search.html +++ b/main/search.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="#" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Search - Bot Core Latest (7.1.1)</title><link rel="stylesheet" type="text/css" href="_static/pygments.css" /> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Search - Bot Core Latest (7.1.1)</title><link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" />      <link rel="stylesheet" type="text/css" href="_static/changelog.css" /> @@ -315,6 +315,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/main/searchindex.js b/main/searchindex.js index 5141746f..35f6269d 100644 --- a/main/searchindex.js +++ b/main/searchindex.js @@ -1 +1 @@ -Search.setIndex({docnames:["changelog","index","output/botcore","output/botcore.async_stats","output/botcore.exts","output/botcore.site_api","output/botcore.utils","output/botcore.utils.caching","output/botcore.utils.channel","output/botcore.utils.logging","output/botcore.utils.members","output/botcore.utils.regex","output/botcore.utils.scheduling"],envversion:{"sphinx.domains.c":2,"sphinx.domains.changeset":1,"sphinx.domains.citation":1,"sphinx.domains.cpp":5,"sphinx.domains.index":1,"sphinx.domains.javascript":2,"sphinx.domains.math":2,"sphinx.domains.python":3,"sphinx.domains.rst":2,"sphinx.domains.std":2,"sphinx.ext.intersphinx":1,"sphinx.ext.todo":2,sphinx:56},filenames:["changelog.rst","index.rst","output/botcore.rst","output/botcore.async_stats.rst","output/botcore.exts.rst","output/botcore.site_api.rst","output/botcore.utils.rst","output/botcore.utils.caching.rst","output/botcore.utils.channel.rst","output/botcore.utils.logging.rst","output/botcore.utils.members.rst","output/botcore.utils.regex.rst","output/botcore.utils.scheduling.rst"],objects:{"":[[2,0,0,"-","botcore"]],"botcore.BotBase":[[2,2,1,"","__init__"],[2,2,1,"","add_cog"],[2,2,1,"","add_command"],[2,2,1,"","clear"],[2,2,1,"","close"],[2,2,1,"","load_extensions"],[2,2,1,"","log_to_dev_log"],[2,2,1,"","on_guild_available"],[2,2,1,"","on_guild_unavailable"],[2,2,1,"","ping_services"],[2,2,1,"","remove_command"],[2,2,1,"","setup_hook"],[2,2,1,"","wait_until_guild_available"]],"botcore.StartupError":[[2,2,1,"","__init__"]],"botcore.async_stats":[[3,1,1,"","AsyncStatsClient"]],"botcore.async_stats.AsyncStatsClient":[[3,2,1,"","__init__"],[3,2,1,"","create_socket"]],"botcore.site_api":[[5,1,1,"","APIClient"],[5,3,1,"","ResponseCodeError"]],"botcore.site_api.APIClient":[[5,2,1,"","__init__"],[5,2,1,"","close"],[5,2,1,"","delete"],[5,2,1,"","get"],[5,2,1,"","maybe_raise_for_status"],[5,2,1,"","patch"],[5,2,1,"","post"],[5,2,1,"","put"],[5,2,1,"","request"]],"botcore.site_api.ResponseCodeError":[[5,2,1,"","__init__"],[5,2,1,"","__str__"]],"botcore.utils":[[6,4,1,"","apply_monkey_patches"],[7,0,0,"-","caching"],[8,0,0,"-","channel"],[9,0,0,"-","logging"],[10,0,0,"-","members"],[11,0,0,"-","regex"],[12,0,0,"-","scheduling"],[6,4,1,"","unqualify"]],"botcore.utils.caching":[[7,1,1,"","AsyncCache"]],"botcore.utils.caching.AsyncCache":[[7,2,1,"","__call__"],[7,2,1,"","__init__"],[7,2,1,"","clear"]],"botcore.utils.channel":[[8,4,1,"","get_or_fetch_channel"],[8,4,1,"","is_in_category"]],"botcore.utils.logging":[[9,1,1,"","CustomLogger"],[9,4,1,"","get_logger"]],"botcore.utils.logging.CustomLogger":[[9,2,1,"","trace"]],"botcore.utils.members":[[10,4,1,"","get_or_fetch_member"],[10,4,1,"","handle_role_change"]],"botcore.utils.regex":[[11,5,1,"","DISCORD_INVITE"],[11,5,1,"","FORMATTED_CODE_REGEX"],[11,5,1,"","RAW_CODE_REGEX"]],"botcore.utils.scheduling":[[12,1,1,"","Scheduler"],[12,4,1,"","create_task"]],"botcore.utils.scheduling.Scheduler":[[12,2,1,"","__contains__"],[12,2,1,"","__init__"],[12,2,1,"","cancel"],[12,2,1,"","cancel_all"],[12,2,1,"","schedule"],[12,2,1,"","schedule_at"],[12,2,1,"","schedule_later"]],botcore:[[2,1,1,"","BotBase"],[2,3,1,"","StartupError"],[3,0,0,"-","async_stats"],[4,0,0,"-","exts"],[5,0,0,"-","site_api"],[6,0,0,"-","utils"]]},objnames:{"0":["py","module","Python module"],"1":["py","class","Python class"],"2":["py","method","Python method"],"3":["py","exception","Python exception"],"4":["py","function","Python function"],"5":["py","data","Python data"]},objtypes:{"0":"py:module","1":"py:class","2":"py:method","3":"py:exception","4":"py:function","5":"py:data"},terms:{"0":[0,7,9],"0a0":0,"1":[0,9],"10th":0,"12":0,"128":7,"14th":0,"17th":0,"18th":0,"19th":0,"2":[0,2],"2021":0,"2022":0,"204":5,"20th":0,"21st":0,"22nd":0,"24th":0,"25th":0,"26th":0,"29":0,"2nd":0,"3":0,"32":0,"34":0,"35":0,"37":0,"39":0,"3rd":0,"4":0,"403":6,"42":0,"4cbe8f5":0,"5":0,"54":0,"56":0,"5a06fa5":0,"5th":0,"6":0,"61":0,"63":0,"64":0,"65":0,"66":0,"68":0,"69":0,"7":0,"72":0,"75":0,"78":0,"79":0,"8125":3,"987235d":0,"9th":0,"abstract":0,"break":0,"case":0,"class":[0,2,3,5,7,9,12],"do":8,"float":12,"function":[0,2,7,8,9,10,12],"import":0,"int":[2,3,7,8,12],"long":12,"na\u00efv":12,"new":[3,5,7,12],"public":0,"return":[0,2,3,5,6,7,8,9,10,12],"true":[5,9,12],A:[2,5,6,7,8,12],If:[2,5,12],It:6,No:5,Not:2,The:[2,3,5,6,7,8,9,10,12],To:[2,9],_:0,__call__:7,__contains__:12,__init__:[0,2,3,5,7,12],__str__:5,_guild_avail:0,abstracteventloop:[3,12],act:6,actual:0,ad:[0,6,9],add:[0,2],add_cog:2,add_command:2,add_rol:10,after:12,aiohttp:[0,2,5],alia:[2,6],alias:[2,6],all:[0,2,3,6,12],all_command:2,all_extens:2,allow:[0,2],allowed_rol:2,alpha:0,alreadi:12,also:[0,6],an:[0,2,3,5,6,7,8,9,12],ani:[5,11,12],api:[0,5,10],api_cli:[0,2],apicli:[0,2,5],appear:2,appli:[6,7],apply_monkey_patch:[0,6],april:0,ar:[2,7,11],arg:[2,9],arg_offset:7,argument:[5,6,7,9,10],around:5,async:[0,2,3,5,7,8,10],async_rediscach:2,async_stat:[1,2],asynccach:7,asyncio:[0,3,12],asyncresolv:0,asyncstatscli:[2,3],asyncstatsdcli:0,attempt:[2,8,10],attribut:6,authent:5,autogener:0,avail:[0,2],avoid:[0,2],await:[10,12],awar:12,back:0,base:[0,2,3,5,7,9,12],basic:0,becaus:2,becom:2,befor:[0,2,12],behaviour:0,being:6,between:0,block:[0,11],bool:[5,8,12],bot:[0,2,6,8],botbas:[0,2],botcor:[0,1],broke:0,bug:0,bump:0,cach:[0,2,6,8,10],calcul:12,call:[2,12],callabl:[7,10],can:[0,12],cancel:12,cancel_al:12,cannot:[0,2],captur:[0,11],categori:8,category_id:8,caus:[2,6],chang:0,changelog:1,channel:[0,2,6],channel_id:8,charact:0,check:[5,8,12],chunk:0,ci:0,clear:[2,7],client:[0,2,3],clientrespons:5,clientsess:[2,5],close:[0,2,5,12],cloudflar:6,code:[0,11],cog:[0,2,4],command:[0,2,6,8],commit:0,common:[0,2,6,9,11],commun:3,connect:[0,2,3],connector:2,constructor:5,contain:12,content:5,core:0,coro:[10,12],coroutin:[7,10,12],correct:0,could:10,crash:0,creat:[0,2,3,7,12],create_datagram_endpoint:3,create_socket:[2,3],create_task:12,creation:0,current:12,custom:[0,7,9],customlogg:9,datetim:12,deadlock:2,deal:0,decemb:0,decor:7,delai:12,delet:[5,7],depend:8,deprec:0,detect:0,dev:2,develop:[2,6],dict:5,directli:0,discord:[0,2,4,6,8,10,11],discord_invit:11,disnak:0,distinguish:12,django:5,doc:0,document:0,doesn:12,don:[0,12],done:12,dummi:[0,2],dynam:0,each:0,edit:2,either:2,elsewher:12,emit:2,empti:2,endpoint:5,ensur:[2,11],entir:[0,2],equival:5,error:[2,5,6,10],event:[0,2,3,12],event_loop:12,exc_info:9,exce:7,except:[2,5,9,12],execut:12,exist:12,expect:10,express:11,ext:[0,1,2,6,8],extend:0,extens:[0,2],extra:5,fail:8,failur:10,featur:[0,2],februari:0,fetch:[8,10],fifo:7,fix:0,forbidden:8,format:11,formatted_code_regex:11,forum:0,found:[10,12],from:[0,2,3,5,6,8,10,12],futur:12,gatewai:2,gener:[2,12],get:[0,5,8,10],get_logg:9,get_or_fetch_channel:8,get_or_fetch_memb:10,give:2,given:[2,3,6,8,9,10,12],group:[6,11],guild:[0,2,10],guild_available_but_cache_empti:2,guild_creat:2,guild_id:2,guildchannel:8,ha:6,handl:[0,10,12],handle_role_chang:10,hashabl:12,have:[8,9],heavi:6,help:0,helper:[8,10],hook:0,host:3,houston:9,how:[7,12],http:[5,11],http_session:2,httpexcept:8,id:[2,8,12],identifi:12,ignor:6,immedi:12,implement:[2,3,7,9],inadequ:2,index:1,indic:10,individu:2,inform:[1,9],init:[0,2,3],initi:[5,12],initialis:[2,7],instanc:[0,2,5,7,8,9,12],instanti:[2,12],instead:[2,12],intend:10,interact:8,interactin:10,interest:9,intern:[2,6],intersphinx:0,invalid:8,invaliddata:8,invit:[0,11],is_in_categori:8,item:7,its:2,januari:0,json:5,keep:12,kei:7,keyword:[5,6,9],known:12,kwarg:[2,5,9,12],latest:0,level:[6,9],lint:0,list:2,ll:12,load:[0,2,6],load_extens:2,localhost:3,log:[0,2,6,12],log_to_dev_log:2,logger:[0,9],logic:0,longer:0,look:12,loop:[2,3,12],lot:0,lru:7,made:0,mai:[0,7],main:0,make:[0,9],mani:[0,2,7],manipul:0,manual:2,march:0,match:2,max_siz:7,maximum:7,maybe_raise_for_statu:5,member:[0,2,6],member_id:10,mention:2,messag:[2,9,12],method:[3,5,6,9],migrat:0,modul:[0,2,6,12],monkei:[0,6],move:0,msg:9,multivers:0,must:12,mypi:9,name:[2,6,9,12],namespac:[0,12],next:0,non:5,none:[2,3,5,6,7,9,10,12],normal:2,notabl:0,notfound:8,notic:0,novemb:0,now:[0,12],number:0,object:[5,6,7,8,10,12],offset:7,ok:5,older:0,on_guild_avail:2,on_guild_unavail:2,on_readi:2,onc:7,one:[0,2],onli:2,oper:[2,12],option:[2,3,5,7,9,10],order:[7,12],other:12,otherwis:12,our:[0,6],out:0,output:11,own:0,packag:[0,6],page:1,pagin:0,paramet:[2,3,5,6,7,8,9,10,12],pars:11,pass:[0,5,9,10,12],past:12,patch:[0,5,6],pattern:11,permiss:[0,8],ping:2,ping_servic:2,pleas:11,poetri:0,popul:2,port:[0,3],posit:7,post:5,prefix:3,prematur:12,prevent:12,problem:9,process:0,provid:[7,12],put:5,py:0,pyproject:0,python:[2,12],qualifi:6,quot:11,rais:[5,8,10,12],raise_for_statu:5,ran:2,rather:6,raw:11,raw_code_regex:11,re:[2,12],readi:2,real:0,receiv:[5,8],recognis:9,reconnect:0,redi:0,redis_sess:2,redissess:2,refer:0,regex:[0,2,6],regular:11,relat:[7,9],releas:0,remov:[0,2],remove_command:2,remove_rol:10,repo:0,represent:5,request:[5,11],request_text:5,requir:[2,12],resolut:0,resolv:2,respons:5,response_json:5,response_text:5,responsecodeerror:5,restor:0,result:[0,12],retriev:8,reusabl:4,revert:0,role:[2,10],root:[2,6],root_alias:6,rout:6,run:12,s:[0,6,7,9,11,12],safe:0,same:12,sanitis:11,save:2,schedul:[0,2,6],schedule_at:12,schedule_lat:12,search:1,second:[2,12],self:2,send:5,send_typ:6,sequenc:6,server:[2,11],servic:2,session:[0,2,5],session_kwarg:5,set:2,setup:[0,2],setup_hook:2,sever:9,share:0,should:[0,2,5],should_rais:5,similar:11,singl:0,site:[0,5],site_api:[0,1,2],site_api_token:5,site_api_url:5,size:7,so:[0,6],socket:3,sole:10,someth:11,sourc:[2,3,5,6,7,8,9,10,11,12],specifi:0,sphinx:0,start:[0,2,12],startup:2,startuperror:2,stat:3,statsclientbas:3,statsd:[0,2,3],statsd_url:[0,2],still:2,store:[6,7],str:[2,3,5,6,9,12],string:5,sub:[0,2],submodul:1,subpackag:1,subtract:12,suggest:12,support:[0,3,6,12],suppressed_except:12,t:[0,12],target:7,task:[0,2,12],task_id:12,text:5,textchannel:8,than:6,thei:2,them:[2,12],thi:[0,2,6,8,10,11,12],thrown:6,thu:2,time:[0,12],timeout:0,timezon:12,token:5,toml:0,tool:[2,6],top:6,trace:[0,9],track:12,transport:3,tupl:12,two:6,type:[2,3,5,6,7,8,9,10,12],unavail:2,unawait:12,under:6,union:12,uniqu:12,unknown:8,unqualifi:[0,6],unschedul:12,until:[2,11],up:[0,2],url:[0,2,5],urllib:11,us:[0,2,3,5,6,8,9,10,11,12],utc:12,util:[0,1,2,7,9],valu:9,valueerror:5,variou:8,version:0,wa:[8,12],wait:[2,12],wait_for:2,wait_until_guild_avail:2,warn:12,we:[9,10],when:[0,2,3,5,6,7,12],whether:[5,8],which:[0,6,12],whitespac:[0,11],within:[0,2],work:0,worker:6,wrap:[7,12],wrapper:[0,5,12],x:0,you:[8,11]},titles:["Changelog","Bot Core Project Documentation","Botcore","async_stats","Exts","site_api","Utils","caching","channel","logging","members","regex","scheduling"],titleterms:{async_stat:3,bot:1,botcor:2,cach:7,changelog:0,channel:8,core:1,document:1,ext:4,extra:1,log:9,member:10,modul:1,project:1,refer:1,regex:11,schedul:12,site_api:5,submodul:[2,6],subpackag:2,util:6}})
\ No newline at end of file +Search.setIndex({"docnames": ["changelog", "index", "output/botcore", "output/botcore.async_stats", "output/botcore.exts", "output/botcore.site_api", "output/botcore.utils", "output/botcore.utils.caching", "output/botcore.utils.channel", "output/botcore.utils.logging", "output/botcore.utils.members", "output/botcore.utils.regex", "output/botcore.utils.scheduling"], "filenames": ["changelog.rst", "index.rst", "output/botcore.rst", "output/botcore.async_stats.rst", "output/botcore.exts.rst", "output/botcore.site_api.rst", "output/botcore.utils.rst", "output/botcore.utils.caching.rst", "output/botcore.utils.channel.rst", "output/botcore.utils.logging.rst", "output/botcore.utils.members.rst", "output/botcore.utils.regex.rst", "output/botcore.utils.scheduling.rst"], "titles": ["Changelog", "Bot Core Project Documentation", "Botcore", "async_stats", "Exts", "site_api", "Utils", "caching", "channel", "logging", "members", "regex", "scheduling"], "terms": {"next": 0, "7": 0, "x": 0, "featur": [0, 2], "releas": 0, "support": [0, 3, 6, 12], "79": 0, "restor": 0, "site": [0, 5], "add": [0, 2], "sphinx": 0, "multivers": 0, "make": [0, 9], "avail": [0, 2], "older": 0, "doc": 0, "version": 0, "1": [0, 9], "0": [0, 7, 9], "24th": 0, "mai": [0, 7], "2022": 0, "78": 0, "bump": 0, "discord": [0, 2, 4, 6, 8, 10, 11], "py": 0, "4cbe8f5": 0, "thi": [0, 2, 6, 8, 10, 11, 12], "fix": 0, "bug": 0, "permiss": [0, 8], "resolut": 0, "when": [0, 2, 3, 5, 6, 7, 12], "deal": 0, "time": [0, 12], "out": 0, "member": [0, 2, 6], "10th": 0, "break": 0, "75": 0, "invit": [0, 11], "regex": [0, 2, 6], "longer": 0, "return": [0, 2, 3, 5, 6, 7, 8, 9, 10, 12], "url": [0, 2, 5], "safe": 0, "result": [0, 12], "refer": 0, "document": 0, "handl": [0, 10, 12], "captur": [0, 11], "all": [0, 2, 3, 6, 12], "charact": 0, "up": [0, 2], "whitespac": [0, 11], "6": 0, "4": 0, "26th": 0, "april": 0, "72": 0, "5a06fa5": 0, "notabl": 0, "one": [0, 2], "commit": 0, "dynam": 0, "extend": 0, "timeout": 0, "guild": [0, 2, 10], "chunk": 0, "base": [0, 2, 3, 5, 7, 9, 12], "number": 0, "so": [0, 6], "should": [0, 2, 5], "actual": 0, "work": 0, "our": [0, 6], "now": [0, 12], "3": 0, "2": [0, 2], "25th": 0, "69": 0, "us": [0, 2, 3, 5, 6, 8, 9, 10, 11, 12], "statsd_url": [0, 2], "get": [0, 5, 8, 10], "pass": [0, 5, 9, 10, 12], "botbas": [0, 2], "21st": 0, "68": 0, "correct": 0, "pyproject": 0, "toml": 0, "directli": 0, "main": 0, "don": [0, 12], "t": [0, 12], "load": [0, 2, 6], "modul": [0, 2, 6, 12], "start": [0, 2, 12], "_": 0, "66": 0, "each": 0, "cog": [0, 2, 4], "s": [0, 6, 7, 9, 11, 12], "own": 0, "task": [0, 2, 12], "avoid": [0, 2], "singl": 0, "crash": 0, "entir": [0, 2], "process": 0, "20th": 0, "65": 0, "unqualifi": [0, 6], "botcor": [0, 1], "util": [0, 1, 2, 7, 9], "namespac": [0, 12], "bot": [0, 2, 6, 8], "manipul": 0, "extens": [0, 2], "19th": 0, "64": 0, "987235d": 0, "revert": 0, "chang": 0, "help": 0, "command": [0, 2, 6, 8], "behaviour": 0, "broke": 0, "custom": [0, 7, 9], "pagin": 0, "also": [0, 6], "basic": 0, "forum": 0, "channel": [0, 2, 6], "5": 0, "18th": 0, "63": 0, "allow": [0, 2], "an": [0, 2, 3, 5, 6, 7, 8, 9, 12], "api_cli": [0, 2], "__init__": [0, 2, 3, 5, 7, 12], "specifi": 0, "site_api": [0, 1, 2], "apicli": [0, 2, 5], "instanc": [0, 2, 5, 7, 8, 9, 12], "61": 0, "reconnect": 0, "redi": 0, "session": [0, 2, 5], "setup": [0, 2], "close": [0, 2, 5, 12], "5th": 0, "56": 0, "move": 0, "creation": 0, "asyncio": [0, 3, 12], "event": [0, 2, 3, 12], "_guild_avail": 0, "within": [0, 2], "hook": 0, "deprec": 0, "notic": 0, "creat": [0, 2, 3, 7, 12], "dummi": [0, 2], "asyncstatsdcli": 0, "befor": [0, 2, 12], "connect": [0, 2, 3], "real": 0, "case": 0, "cannot": [0, 2], "made": 0, "init": [0, 2, 3], "2nd": 0, "54": 0, "aiohttp": [0, 2, 5], "asyncresolv": 0, "async": [0, 2, 3, 5, 7, 8, 10], "42": 0, "remov": [0, 2], "public": 0, "statsd": [0, 2, 3], "client": [0, 2, 3], "ext": [0, 1, 2, 6, 8], "sub": [0, 2], "class": [0, 2, 3, 5, 7, 9, 12], "which": [0, 6, 12], "abstract": 0, "lot": 0, "logic": 0, "share": 0, "between": 0, "latest": 0, "alpha": 0, "14th": 0, "march": 0, "39": 0, "migrat": 0, "back": 0, "37": 0, "log": [0, 2, 6, 12], "trace": [0, 9], "import": 0, "can": [0, 12], "function": [0, 2, 7, 8, 9, 10, 12], "3rd": 0, "35": 0, "apply_monkey_patch": [0, 6], "februari": 0, "34": 0, "port": [0, 3], "api": [0, 5, 10], "wrapper": [0, 5, 12], "from": [0, 2, 3, 5, 6, 8, 10, 12], "repo": 0, "22nd": 0, "32": 0, "0a0": 0, "disnak": 0, "29": 0, "mani": [0, 2, 7], "common": [0, 2, 6, 9, 11], "cach": [0, 2, 6, 8, 10], "logger": [0, 9], "schedul": [0, 2, 6], "monkei": [0, 6], "patch": [0, 5, 6], "ad": [0, 6, 9], "intersphinx": 0, "9th": 0, "januari": 0, "12": 0, "code": [0, 11], "block": [0, 11], "detect": 0, "decemb": 0, "2021": 0, "autogener": 0, "17th": 0, "novemb": 0, "core": 0, "packag": [0, 6], "poetri": 0, "lint": 0, "ci": 0, "subpackag": 1, "submodul": 1, "async_stat": [1, 2], "index": 1, "search": 1, "page": 1, "inform": [1, 9], "changelog": 1, "tool": [2, 6], "develop": [2, 6], "arg": [2, 9], "guild_id": 2, "allowed_rol": 2, "http_session": 2, "redis_sess": 2, "none": [2, 3, 5, 6, 7, 9, 10, 12], "kwarg": [2, 5, 9, 12], "sourc": [2, 3, 5, 6, 7, 8, 9, 10, 11, 12], "A": [2, 5, 6, 7, 8, 12], "implement": [2, 3, 7, 9], "python": [2, 12], "initialis": [2, 7], "paramet": [2, 3, 5, 6, 7, 8, 9, 10, 12], "int": [2, 3, 7, 8, 12], "The": [2, 3, 5, 6, 7, 8, 9, 10, 12], "id": [2, 8, 12], "wait_until_guild_avail": 2, "list": 2, "role": [2, 10], "mention": 2, "clientsess": [2, 5], "option": [2, 3, 5, 7, 9, 10], "redissess": 2, "async_rediscach": 2, "str": [2, 3, 5, 6, 9, 12], "server": [2, 11], "If": [2, 5, 12], "given": [2, 3, 6, 8, 9, 10, 12], "add_cog": 2, "oper": [2, 12], "type": [2, 3, 5, 6, 7, 8, 9, 10, 12], "add_command": 2, "normal": 2, "its": 2, "root": [2, 6], "alias": [2, 6], "clear": [2, 7], "Not": 2, "re": [2, 12], "instanti": [2, 12], "instead": [2, 12], "attempt": [2, 8, 10], "connector": 2, "resolv": 2, "load_extens": 2, "save": 2, "them": [2, 12], "self": 2, "all_extens": 2, "ran": 2, "loop": [2, 3, 12], "deadlock": 2, "caus": [2, 6], "wait_for": 2, "call": [2, 12], "log_to_dev_log": 2, "messag": [2, 9, 12], "dev": 2, "on_guild_avail": 2, "set": 2, "intern": [2, 6], "becom": 2, "appear": 2, "still": 2, "empti": 2, "guild_available_but_cache_empti": 2, "emit": 2, "on_guild_unavail": 2, "unavail": 2, "ping_servic": 2, "ping": 2, "requir": [2, 12], "servic": 2, "ensur": [2, 11], "thei": 2, "ar": [2, 7, 11], "remove_command": 2, "name": [2, 6, 9, 12], "alia": [2, 6], "individu": 2, "To": [2, 9], "either": 2, "manual": 2, "edit": 2, "all_command": 2, "setup_hook": 2, "startup": 2, "gener": [2, 12], "asyncstatscli": [2, 3], "create_socket": [2, 3], "wait": [2, 12], "until": [2, 11], "match": 2, "readi": 2, "on_readi": 2, "inadequ": 2, "becaus": 2, "onli": 2, "second": [2, 12], "guild_creat": 2, "gatewai": 2, "give": 2, "thu": 2, "popul": 2, "except": [2, 5, 9, 12], "startuperror": 2, "error": [2, 5, 6, 10], "transport": 3, "method": [3, 5, 6, 9], "commun": 3, "host": 3, "localhost": 3, "8125": 3, "prefix": 3, "statsclientbas": 3, "stat": 3, "new": [3, 5, 7, 12], "abstracteventloop": [3, 12], "create_datagram_endpoint": 3, "socket": 3, "reusabl": 4, "around": 5, "site_api_url": 5, "site_api_token": 5, "session_kwarg": 5, "object": [5, 6, 7, 8, 10, 12], "django": 5, "initi": [5, 12], "token": 5, "authent": 5, "keyword": [5, 6, 9], "argument": [5, 6, 7, 9, 10], "constructor": 5, "delet": [5, 7], "endpoint": 5, "raise_for_statu": 5, "true": [5, 9, 12], "send": 5, "request": [5, 11], "json": 5, "respons": 5, "bool": [5, 8, 12], "whether": [5, 8], "rais": [5, 8, 10, 12], "ok": 5, "ani": [5, 11, 12], "extra": 5, "dict": 5, "204": 5, "No": 5, "content": 5, "equival": 5, "maybe_raise_for_statu": 5, "should_rais": 5, "responsecodeerror": 5, "non": 5, "clientrespons": 5, "check": [5, 8, 12], "post": 5, "put": 5, "http": [5, 11], "response_json": 5, "response_text": 5, "valueerror": 5, "receiv": [5, 8], "request_text": 5, "text": 5, "__str__": 5, "string": 5, "represent": 5, "appli": [6, 7], "group": [6, 11], "root_alias": 6, "two": 6, "sequenc": 6, "act": 6, "top": 6, "level": [6, 9], "rather": 6, "than": 6, "being": 6, "It": 6, "store": [6, 7], "attribut": 6, "send_typ": 6, "ignor": 6, "403": 6, "under": 6, "heavi": 6, "ha": 6, "cloudflar": 6, "worker": 6, "rout": 6, "thrown": 6, "qualifi": 6, "relat": [7, 9], "asynccach": 7, "max_siz": 7, "128": 7, "lru": 7, "coroutin": [7, 10, 12], "onc": 7, "exce": 7, "maximum": 7, "size": 7, "kei": 7, "fifo": 7, "order": [7, 12], "offset": 7, "provid": [7, 12], "__call__": 7, "arg_offset": 7, "decor": 7, "posit": 7, "callabl": [7, 10], "wrap": [7, 12], "target": 7, "how": [7, 12], "item": 7, "helper": [8, 10], "interact": 8, "variou": 8, "get_or_fetch_channel": 8, "channel_id": 8, "fetch": [8, 10], "invaliddata": 8, "unknown": 8, "wa": [8, 12], "httpexcept": 8, "retriev": 8, "fail": 8, "notfound": 8, "invalid": 8, "forbidden": 8, "you": [8, 11], "do": 8, "have": [8, 9], "guildchannel": 8, "is_in_categori": 8, "category_id": 8, "categori": 8, "textchannel": 8, "depend": 8, "customlogg": 9, "msg": 9, "sever": 9, "exc_info": 9, "valu": 9, "houston": 9, "we": [9, 10], "interest": 9, "problem": 9, "get_logg": 9, "mypi": 9, "recognis": 9, "interactin": 10, "get_or_fetch_memb": 10, "member_id": 10, "failur": 10, "indic": 10, "could": 10, "found": [10, 12], "handle_role_chang": 10, "coro": [10, 12], "await": [10, 12], "sole": 10, "expect": 10, "add_rol": 10, "remove_rol": 10, "intend": 10, "regular": 11, "express": 11, "discord_invit": 11, "pattern": 11, "similar": 11, "pleas": 11, "sanitis": 11, "output": 11, "someth": 11, "urllib": 11, "pars": 11, "quot": 11, "formatted_code_regex": 11, "format": 11, "raw_code_regex": 11, "raw": 11, "execut": 12, "keep": 12, "track": 12, "must": 12, "distinguish": 12, "other": 12, "contain": 12, "suggest": 12, "immedi": 12, "futur": 12, "schedule_at": 12, "schedule_lat": 12, "uniqu": 12, "cancel": 12, "prematur": 12, "same": 12, "current": 12, "done": 12, "__contains__": 12, "task_id": 12, "hashabl": 12, "look": 12, "unschedul": 12, "identifi": 12, "warn": 12, "doesn": 12, "exist": 12, "cancel_al": 12, "known": 12, "alreadi": 12, "prevent": 12, "unawait": 12, "ll": 12, "elsewher": 12, "timezon": 12, "awar": 12, "calcul": 12, "subtract": 12, "na\u00efv": 12, "utc": 12, "past": 12, "datetim": 12, "delai": 12, "after": 12, "union": 12, "float": 12, "long": 12, "create_task": 12, "suppressed_except": 12, "event_loop": 12, "otherwis": 12, "run": 12, "tupl": 12}, "objects": {"": [[2, 0, 0, "-", "botcore"]], "botcore": [[2, 1, 1, "", "BotBase"], [2, 3, 1, "", "StartupError"], [3, 0, 0, "-", "async_stats"], [4, 0, 0, "-", "exts"], [5, 0, 0, "-", "site_api"], [6, 0, 0, "-", "utils"]], "botcore.BotBase": [[2, 2, 1, "", "__init__"], [2, 2, 1, "", "add_cog"], [2, 2, 1, "", "add_command"], [2, 2, 1, "", "clear"], [2, 2, 1, "", "close"], [2, 2, 1, "", "load_extensions"], [2, 2, 1, "", "log_to_dev_log"], [2, 2, 1, "", "on_guild_available"], [2, 2, 1, "", "on_guild_unavailable"], [2, 2, 1, "", "ping_services"], [2, 2, 1, "", "remove_command"], [2, 2, 1, "", "setup_hook"], [2, 2, 1, "", "wait_until_guild_available"]], "botcore.StartupError": [[2, 2, 1, "", "__init__"]], "botcore.async_stats": [[3, 1, 1, "", "AsyncStatsClient"]], "botcore.async_stats.AsyncStatsClient": [[3, 2, 1, "", "__init__"], [3, 2, 1, "", "create_socket"]], "botcore.site_api": [[5, 1, 1, "", "APIClient"], [5, 3, 1, "", "ResponseCodeError"]], "botcore.site_api.APIClient": [[5, 2, 1, "", "__init__"], [5, 2, 1, "", "close"], [5, 2, 1, "", "delete"], [5, 2, 1, "", "get"], [5, 2, 1, "", "maybe_raise_for_status"], [5, 2, 1, "", "patch"], [5, 2, 1, "", "post"], [5, 2, 1, "", "put"], [5, 2, 1, "", "request"]], "botcore.site_api.ResponseCodeError": [[5, 2, 1, "", "__init__"], [5, 2, 1, "", "__str__"]], "botcore.utils": [[6, 4, 1, "", "apply_monkey_patches"], [7, 0, 0, "-", "caching"], [8, 0, 0, "-", "channel"], [9, 0, 0, "-", "logging"], [10, 0, 0, "-", "members"], [11, 0, 0, "-", "regex"], [12, 0, 0, "-", "scheduling"], [6, 4, 1, "", "unqualify"]], "botcore.utils.caching": [[7, 1, 1, "", "AsyncCache"]], "botcore.utils.caching.AsyncCache": [[7, 2, 1, "", "__call__"], [7, 2, 1, "", "__init__"], [7, 2, 1, "", "clear"]], "botcore.utils.channel": [[8, 4, 1, "", "get_or_fetch_channel"], [8, 4, 1, "", "is_in_category"]], "botcore.utils.logging": [[9, 1, 1, "", "CustomLogger"], [9, 4, 1, "", "get_logger"]], "botcore.utils.logging.CustomLogger": [[9, 2, 1, "", "trace"]], "botcore.utils.members": [[10, 4, 1, "", "get_or_fetch_member"], [10, 4, 1, "", "handle_role_change"]], "botcore.utils.regex": [[11, 5, 1, "", "DISCORD_INVITE"], [11, 5, 1, "", "FORMATTED_CODE_REGEX"], [11, 5, 1, "", "RAW_CODE_REGEX"]], "botcore.utils.scheduling": [[12, 1, 1, "", "Scheduler"], [12, 4, 1, "", "create_task"]], "botcore.utils.scheduling.Scheduler": [[12, 2, 1, "", "__contains__"], [12, 2, 1, "", "__init__"], [12, 2, 1, "", "cancel"], [12, 2, 1, "", "cancel_all"], [12, 2, 1, "", "schedule"], [12, 2, 1, "", "schedule_at"], [12, 2, 1, "", "schedule_later"]]}, "objtypes": {"0": "py:module", "1": "py:class", "2": "py:method", "3": "py:exception", "4": "py:function", "5": "py:data"}, "objnames": {"0": ["py", "module", "Python module"], "1": ["py", "class", "Python class"], "2": ["py", "method", "Python method"], "3": ["py", "exception", "Python exception"], "4": ["py", "function", "Python function"], "5": ["py", "data", "Python data"]}, "titleterms": {"changelog": 0, "bot": 1, "core": 1, "project": 1, "document": 1, "refer": 1, "modul": 1, "extra": 1, "botcor": 2, "subpackag": 2, "submodul": [2, 6], "async_stat": 3, "ext": 4, "site_api": 5, "util": 6, "cach": 7, "channel": 8, "log": 9, "member": 10, "regex": 11, "schedul": 12}, "envversion": {"sphinx.domains.c": 2, "sphinx.domains.changeset": 1, "sphinx.domains.citation": 1, "sphinx.domains.cpp": 6, "sphinx.domains.index": 1, "sphinx.domains.javascript": 2, "sphinx.domains.math": 2, "sphinx.domains.python": 3, "sphinx.domains.rst": 2, "sphinx.domains.std": 2, "sphinx.ext.intersphinx": 1, "sphinx.ext.todo": 2, "sphinx": 56}})
\ No newline at end of file diff --git a/main/versions.html b/main/versions.html index 6af99eab..77ffb7d5 100644 --- a/main/versions.html +++ b/main/versions.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Versions - Bot Core Latest (7.1.1)</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -339,6 +339,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.1/.buildinfo b/v7.1.1/.buildinfo index e0ae0e84..8ab8a4de 100644 --- a/v7.1.1/.buildinfo +++ b/v7.1.1/.buildinfo @@ -1,4 +1,4 @@  # 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: 7d1be4893d6f414385e737feb526f547 +config: 322aa93a3956ef16f8e4f797dc6f886e  tags: 645f666f9bcd5a90fca523b33c5a78b7 diff --git a/v7.1.1/.doctrees/changelog.doctree b/v7.1.1/.doctrees/changelog.doctree Binary files differindex cce27ff5..efc91512 100644 --- a/v7.1.1/.doctrees/changelog.doctree +++ b/v7.1.1/.doctrees/changelog.doctree diff --git a/v7.1.1/.doctrees/environment.pickle b/v7.1.1/.doctrees/environment.pickle Binary files differindex dae8513a..7dfa53f8 100644 --- a/v7.1.1/.doctrees/environment.pickle +++ b/v7.1.1/.doctrees/environment.pickle diff --git a/v7.1.1/.doctrees/index.doctree b/v7.1.1/.doctrees/index.doctree Binary files differindex dcd091a7..f9b97d17 100644 --- a/v7.1.1/.doctrees/index.doctree +++ b/v7.1.1/.doctrees/index.doctree diff --git a/v7.1.1/.doctrees/output/botcore.async_stats.doctree b/v7.1.1/.doctrees/output/botcore.async_stats.doctree Binary files differindex 9b7ff62e..5bda6086 100644 --- a/v7.1.1/.doctrees/output/botcore.async_stats.doctree +++ b/v7.1.1/.doctrees/output/botcore.async_stats.doctree diff --git a/v7.1.1/.doctrees/output/botcore.doctree b/v7.1.1/.doctrees/output/botcore.doctree Binary files differindex 4958da2a..e132fa66 100644 --- a/v7.1.1/.doctrees/output/botcore.doctree +++ b/v7.1.1/.doctrees/output/botcore.doctree diff --git a/v7.1.1/.doctrees/output/botcore.exts.doctree b/v7.1.1/.doctrees/output/botcore.exts.doctree Binary files differindex 20e55ede..083f0d40 100644 --- a/v7.1.1/.doctrees/output/botcore.exts.doctree +++ b/v7.1.1/.doctrees/output/botcore.exts.doctree diff --git a/v7.1.1/.doctrees/output/botcore.site_api.doctree b/v7.1.1/.doctrees/output/botcore.site_api.doctree Binary files differindex a06552c2..e8d21587 100644 --- a/v7.1.1/.doctrees/output/botcore.site_api.doctree +++ b/v7.1.1/.doctrees/output/botcore.site_api.doctree diff --git a/v7.1.1/.doctrees/output/botcore.utils.caching.doctree b/v7.1.1/.doctrees/output/botcore.utils.caching.doctree Binary files differindex 5b7242df..c1ff573a 100644 --- a/v7.1.1/.doctrees/output/botcore.utils.caching.doctree +++ b/v7.1.1/.doctrees/output/botcore.utils.caching.doctree diff --git a/v7.1.1/.doctrees/output/botcore.utils.channel.doctree b/v7.1.1/.doctrees/output/botcore.utils.channel.doctree Binary files differindex 56ffa5c7..81a4134e 100644 --- a/v7.1.1/.doctrees/output/botcore.utils.channel.doctree +++ b/v7.1.1/.doctrees/output/botcore.utils.channel.doctree diff --git a/v7.1.1/.doctrees/output/botcore.utils.doctree b/v7.1.1/.doctrees/output/botcore.utils.doctree Binary files differindex a9421b8e..c263d8d0 100644 --- a/v7.1.1/.doctrees/output/botcore.utils.doctree +++ b/v7.1.1/.doctrees/output/botcore.utils.doctree diff --git a/v7.1.1/.doctrees/output/botcore.utils.logging.doctree b/v7.1.1/.doctrees/output/botcore.utils.logging.doctree Binary files differindex 2a0e91c9..4b9eccb1 100644 --- a/v7.1.1/.doctrees/output/botcore.utils.logging.doctree +++ b/v7.1.1/.doctrees/output/botcore.utils.logging.doctree diff --git a/v7.1.1/.doctrees/output/botcore.utils.members.doctree b/v7.1.1/.doctrees/output/botcore.utils.members.doctree Binary files differindex 94cd6de6..10321205 100644 --- a/v7.1.1/.doctrees/output/botcore.utils.members.doctree +++ b/v7.1.1/.doctrees/output/botcore.utils.members.doctree diff --git a/v7.1.1/.doctrees/output/botcore.utils.regex.doctree b/v7.1.1/.doctrees/output/botcore.utils.regex.doctree Binary files differindex b0c56f33..7176c448 100644 --- a/v7.1.1/.doctrees/output/botcore.utils.regex.doctree +++ b/v7.1.1/.doctrees/output/botcore.utils.regex.doctree diff --git a/v7.1.1/.doctrees/output/botcore.utils.scheduling.doctree b/v7.1.1/.doctrees/output/botcore.utils.scheduling.doctree Binary files differindex 00a56c3e..0c5aece6 100644 --- a/v7.1.1/.doctrees/output/botcore.utils.scheduling.doctree +++ b/v7.1.1/.doctrees/output/botcore.utils.scheduling.doctree diff --git a/v7.1.1/_static/_sphinx_javascript_frameworks_compat.js b/v7.1.1/_static/_sphinx_javascript_frameworks_compat.js new file mode 100644 index 00000000..8549469d --- /dev/null +++ b/v7.1.1/_static/_sphinx_javascript_frameworks_compat.js @@ -0,0 +1,134 @@ +/* + * _sphinx_javascript_frameworks_compat.js + * ~~~~~~~~~~ + * + * Compatability shim for jQuery and underscores.js. + * + * WILL BE REMOVED IN Sphinx 6.0 + * xref RemovedInSphinx60Warning + * + */ + +/** + * select a different prefix for underscore + */ +$u = _.noConflict(); + + +/** + * small helper function to urldecode strings + * + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL + */ +jQuery.urldecode = function(x) { +    if (!x) { +        return x +    } +    return decodeURIComponent(x.replace(/\+/g, ' ')); +}; + +/** + * small helper function to urlencode strings + */ +jQuery.urlencode = encodeURIComponent; + +/** + * This function returns the parsed url parameters of the + * current request. Multiple values per key are supported, + * it will always return arrays of strings for the value parts. + */ +jQuery.getQueryParameters = function(s) { +    if (typeof s === 'undefined') +        s = document.location.search; +    var parts = s.substr(s.indexOf('?') + 1).split('&'); +    var result = {}; +    for (var i = 0; i < parts.length; i++) { +        var tmp = parts[i].split('=', 2); +        var key = jQuery.urldecode(tmp[0]); +        var value = jQuery.urldecode(tmp[1]); +        if (key in result) +            result[key].push(value); +        else +            result[key] = [value]; +    } +    return result; +}; + +/** + * highlight a given string on a jquery object by wrapping it in + * span elements with the given class name. + */ +jQuery.fn.highlightText = function(text, className) { +    function highlight(node, addItems) { +        if (node.nodeType === 3) { +            var val = node.nodeValue; +            var pos = val.toLowerCase().indexOf(text); +            if (pos >= 0 && +                !jQuery(node.parentNode).hasClass(className) && +                !jQuery(node.parentNode).hasClass("nohighlight")) { +                var span; +                var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg"); +                if (isInSVG) { +                    span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); +                } else { +                    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); +                if (isInSVG) { +                    var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"); +                    var bbox = node.parentElement.getBBox(); +                    rect.x.baseVal.value = bbox.x; +                    rect.y.baseVal.value = bbox.y; +                    rect.width.baseVal.value = bbox.width; +                    rect.height.baseVal.value = bbox.height; +                    rect.setAttribute('class', className); +                    addItems.push({ +                        "parent": node.parentNode, +                        "target": rect}); +                } +            } +        } +        else if (!jQuery(node).is("button, select, textarea")) { +            jQuery.each(node.childNodes, function() { +                highlight(this, addItems); +            }); +        } +    } +    var addItems = []; +    var result = this.each(function() { +        highlight(this, addItems); +    }); +    for (var i = 0; i < addItems.length; ++i) { +        jQuery(addItems[i].parent).before(addItems[i].target); +    } +    return result; +}; + +/* + * 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; +} diff --git a/v7.1.1/_static/basic.css b/v7.1.1/_static/basic.css index bf18350b..7d5974c3 100644 --- a/v7.1.1/_static/basic.css +++ b/v7.1.1/_static/basic.css @@ -222,7 +222,7 @@ table.modindextable td {  /* -- general body styles --------------------------------------------------- */  div.body { -    min-width: 450px; +    min-width: 360px;      max-width: 800px;  } @@ -236,7 +236,6 @@ div.body p, div.body dd, div.body li, div.body blockquote {  a.headerlink {      visibility: hidden;  } -  a.brackets:before,  span.brackets > a:before{      content: "["; @@ -247,6 +246,7 @@ span.brackets > a:after {      content: "]";  } +  h1:hover > a.headerlink,  h2:hover > a.headerlink,  h3:hover > a.headerlink, @@ -334,13 +334,11 @@ aside.sidebar {  p.sidebar-title {      font-weight: bold;  } -  div.admonition, div.topic, blockquote {      clear: left;  }  /* -- topics ---------------------------------------------------------------- */ -  div.topic {      border: 1px solid #ccc;      padding: 7px; @@ -428,10 +426,6 @@ table.docutils td, table.docutils th {      border-bottom: 1px solid #aaa;  } -table.footnote td, table.footnote th { -    border: 0 !important; -} -  th {      text-align: left;      padding-right: 5px; @@ -615,6 +609,7 @@ ul.simple p {      margin-bottom: 0;  } +/* Docutils 0.17 and older (footnotes & citations) */  dl.footnote > dt,  dl.citation > dt {      float: left; @@ -632,6 +627,33 @@ dl.citation > dd:after {      clear: both;  } +/* Docutils 0.18+ (footnotes & citations) */ +aside.footnote > span, +div.citation > span { +    float: left; +} +aside.footnote > span:last-of-type, +div.citation > span:last-of-type { +  padding-right: 0.5em; +} +aside.footnote > p { +  margin-left: 2em; +} +div.citation > p { +  margin-left: 4em; +} +aside.footnote > p:last-of-type, +div.citation > p:last-of-type { +    margin-bottom: 0em; +} +aside.footnote > p:last-of-type:after, +div.citation > p:last-of-type:after { +    content: ""; +    clear: both; +} + +/* Footnotes & citations ends */ +  dl.field-list {      display: grid;      grid-template-columns: fit-content(30%) auto; diff --git a/v7.1.1/_static/doctools.js b/v7.1.1/_static/doctools.js index e1bfd708..c3db08d1 100644 --- a/v7.1.1/_static/doctools.js +++ b/v7.1.1/_static/doctools.js @@ -2,357 +2,263 @@   * doctools.js   * ~~~~~~~~~~~   * - * Sphinx JavaScript utilities for all documentation. + * Base JavaScript utilities for all Sphinx HTML documentation.   *   * :copyright: Copyright 2007-2022 by the Sphinx team, see AUTHORS.   * :license: BSD, see LICENSE for details.   *   */ +"use strict"; -/** - * select a different prefix for underscore - */ -$u = _.noConflict(); - -/** - * make the code below compatible with browsers without - * an installed firebug like debugger -if (!window.console || !console.firebug) { -  var names = ["log", "debug", "info", "warn", "error", "assert", "dir", -    "dirxml", "group", "groupEnd", "time", "timeEnd", "count", "trace", -    "profile", "profileEnd"]; -  window.console = {}; -  for (var i = 0; i < names.length; ++i) -    window.console[names[i]] = function() {}; -} - */ - -/** - * small helper function to urldecode strings - * - * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL - */ -jQuery.urldecode = function(x) { -  if (!x) { -    return x +const _ready = (callback) => { +  if (document.readyState !== "loading") { +    callback(); +  } else { +    document.addEventListener("DOMContentLoaded", callback);    } -  return decodeURIComponent(x.replace(/\+/g, ' '));  };  /** - * small helper function to urlencode strings + * highlight a given string on a node by wrapping it in + * span elements with the given class name.   */ -jQuery.urlencode = encodeURIComponent; +const _highlight = (node, addItems, text, className) => { +  if (node.nodeType === Node.TEXT_NODE) { +    const val = node.nodeValue; +    const parent = node.parentNode; +    const pos = val.toLowerCase().indexOf(text); +    if ( +      pos >= 0 && +      !parent.classList.contains(className) && +      !parent.classList.contains("nohighlight") +    ) { +      let span; -/** - * This function returns the parsed url parameters of the - * current request. Multiple values per key are supported, - * it will always return arrays of strings for the value parts. - */ -jQuery.getQueryParameters = function(s) { -  if (typeof s === 'undefined') -    s = document.location.search; -  var parts = s.substr(s.indexOf('?') + 1).split('&'); -  var result = {}; -  for (var i = 0; i < parts.length; i++) { -    var tmp = parts[i].split('=', 2); -    var key = jQuery.urldecode(tmp[0]); -    var value = jQuery.urldecode(tmp[1]); -    if (key in result) -      result[key].push(value); -    else -      result[key] = [value]; -  } -  return result; -}; +      const closestNode = parent.closest("body, svg, foreignObject"); +      const isInSVG = closestNode && closestNode.matches("svg"); +      if (isInSVG) { +        span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); +      } else { +        span = document.createElement("span"); +        span.classList.add(className); +      } -/** - * highlight a given string on a jquery object by wrapping it in - * span elements with the given class name. - */ -jQuery.fn.highlightText = function(text, className) { -  function highlight(node, addItems) { -    if (node.nodeType === 3) { -      var val = node.nodeValue; -      var pos = val.toLowerCase().indexOf(text); -      if (pos >= 0 && -          !jQuery(node.parentNode).hasClass(className) && -          !jQuery(node.parentNode).hasClass("nohighlight")) { -        var span; -        var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg"); -        if (isInSVG) { -          span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); -        } else { -          span = document.createElement("span"); -          span.className = className; -        } -        span.appendChild(document.createTextNode(val.substr(pos, text.length))); -        node.parentNode.insertBefore(span, node.parentNode.insertBefore( +      span.appendChild(document.createTextNode(val.substr(pos, text.length))); +      parent.insertBefore( +        span, +        parent.insertBefore(            document.createTextNode(val.substr(pos + text.length)), -          node.nextSibling)); -        node.nodeValue = val.substr(0, pos); -        if (isInSVG) { -          var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"); -          var bbox = node.parentElement.getBBox(); -          rect.x.baseVal.value = bbox.x; -          rect.y.baseVal.value = bbox.y; -          rect.width.baseVal.value = bbox.width; -          rect.height.baseVal.value = bbox.height; -          rect.setAttribute('class', className); -          addItems.push({ -              "parent": node.parentNode, -              "target": rect}); -        } +          node.nextSibling +        ) +      ); +      node.nodeValue = val.substr(0, pos); + +      if (isInSVG) { +        const rect = document.createElementNS( +          "http://www.w3.org/2000/svg", +          "rect" +        ); +        const bbox = parent.getBBox(); +        rect.x.baseVal.value = bbox.x; +        rect.y.baseVal.value = bbox.y; +        rect.width.baseVal.value = bbox.width; +        rect.height.baseVal.value = bbox.height; +        rect.setAttribute("class", className); +        addItems.push({ parent: parent, target: rect });        }      } -    else if (!jQuery(node).is("button, select, textarea")) { -      jQuery.each(node.childNodes, function() { -        highlight(this, addItems); -      }); -    } +  } else if (node.matches && !node.matches("button, select, textarea")) { +    node.childNodes.forEach((el) => _highlight(el, addItems, text, className));    } -  var addItems = []; -  var result = this.each(function() { -    highlight(this, addItems); -  }); -  for (var i = 0; i < addItems.length; ++i) { -    jQuery(addItems[i].parent).before(addItems[i].target); -  } -  return result;  }; - -/* - * 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; -} +const _highlightText = (thisNode, text, className) => { +  let addItems = []; +  _highlight(thisNode, addItems, text, className); +  addItems.forEach((obj) => +    obj.parent.insertAdjacentElement("beforebegin", obj.target) +  ); +};  /**   * Small JavaScript module for the documentation.   */ -var Documentation = { - -  init : function() { -    this.fixFirefoxAnchorBug(); -    this.highlightSearchWords(); -    this.initIndexTable(); -    this.initOnKeyListeners(); +const Documentation = { +  init: () => { +    Documentation.highlightSearchWords(); +    Documentation.initDomainIndexTable(); +    Documentation.initOnKeyListeners();    },    /**     * i18n support     */ -  TRANSLATIONS : {}, -  PLURAL_EXPR : function(n) { return n === 1 ? 0 : 1; }, -  LOCALE : 'unknown', +  TRANSLATIONS: {}, +  PLURAL_EXPR: (n) => (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; +  gettext: (string) => { +    const translated = Documentation.TRANSLATIONS[string]; +    switch (typeof translated) { +      case "undefined": +        return string; // no translation +      case "string": +        return translated; // translation exists +      default: +        return translated[0]; // (singular, plural) translation tuple exists +    }    }, -  /** -   * add context elements like header anchor links -   */ -  addContextElements : function() { -    $('div[id] > :header:first').each(function() { -      $('<a class="headerlink">\u00B6</a>'). -      attr('href', '#' + this.id). -      attr('title', _('Permalink to this headline')). -      appendTo(this); -    }); -    $('dt[id]').each(function() { -      $('<a class="headerlink">\u00B6</a>'). -      attr('href', '#' + this.id). -      attr('title', _('Permalink to this definition')). -      appendTo(this); -    }); +  ngettext: (singular, plural, n) => { +    const translated = Documentation.TRANSLATIONS[singular]; +    if (typeof translated !== "undefined") +      return translated[Documentation.PLURAL_EXPR(n)]; +    return n === 1 ? singular : plural;    }, -  /** -   * workaround a firefox stupidity -   * see: https://bugzilla.mozilla.org/show_bug.cgi?id=645075 -   */ -  fixFirefoxAnchorBug : function() { -    if (document.location.hash && $.browser.mozilla) -      window.setTimeout(function() { -        document.location.href += ''; -      }, 10); +  addTranslations: (catalog) => { +    Object.assign(Documentation.TRANSLATIONS, catalog.messages); +    Documentation.PLURAL_EXPR = new Function( +      "n", +      `return (${catalog.plural_expr})` +    ); +    Documentation.LOCALE = catalog.locale;    },    /**     * 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); -      $('<p class="highlight-link"><a href="javascript:Documentation.' + -        'hideSearchWords()">' + _('Hide Search Matches') + '</a></p>') -          .appendTo($('#searchbox')); -    } -  }, +  highlightSearchWords: () => { +    const highlight = +      new URLSearchParams(window.location.search).get("highlight") || ""; +    const terms = highlight.toLowerCase().split(/\s+/).filter(x => x); +    if (terms.length === 0) return; // nothing to do -  /** -   * 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(); -    } +    // There should never be more than one element matching "div.body" +    const divBody = document.querySelectorAll("div.body"); +    const body = divBody.length ? divBody[0] : document.querySelector("body"); +    window.setTimeout(() => { +      terms.forEach((term) => _highlightText(body, term, "highlighted")); +    }, 10); + +    const searchBox = document.getElementById("searchbox"); +    if (searchBox === null) return; +    searchBox.appendChild( +      document +        .createRange() +        .createContextualFragment( +          '<p class="highlight-link">' + +            '<a href="javascript:Documentation.hideSearchWords()">' + +            Documentation.gettext("Hide Search Matches") + +            "</a></p>" +        ) +    );    },    /**     * helper function to hide the search marks again     */ -  hideSearchWords : function() { -    $('#searchbox .highlight-link').fadeOut(300); -    $('span.highlighted').removeClass('highlighted'); -    var url = new URL(window.location); -    url.searchParams.delete('highlight'); -    window.history.replaceState({}, '', url); +  hideSearchWords: () => { +    document +      .querySelectorAll("#searchbox .highlight-link") +      .forEach((el) => el.remove()); +    document +      .querySelectorAll("span.highlighted") +      .forEach((el) => el.classList.remove("highlighted")); +    const url = new URL(window.location); +    url.searchParams.delete("highlight"); +    window.history.replaceState({}, "", url);    }, -   /** +  /**     * helper function to focus on search bar     */ -  focusSearchBar : function() { -    $('input[name=q]').first().focus(); +  focusSearchBar: () => { +    document.querySelectorAll("input[name=q]")[0]?.focus();    },    /** -   * make the url absolute +   * Initialise the domain index toggle buttons     */ -  makeURL : function(relativeURL) { -    return DOCUMENTATION_OPTIONS.URL_ROOT + '/' + relativeURL; -  }, +  initDomainIndexTable: () => { +    const toggler = (el) => { +      const idNumber = el.id.substr(7); +      const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`); +      if (el.src.substr(-9) === "minus.png") { +        el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`; +        toggledRows.forEach((el) => (el.style.display = "none")); +      } else { +        el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`; +        toggledRows.forEach((el) => (el.style.display = "")); +      } +    }; -  /** -   * 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); +    const togglerElements = document.querySelectorAll("img.toggler"); +    togglerElements.forEach((el) => +      el.addEventListener("click", (event) => toggler(event.currentTarget)) +    ); +    togglerElements.forEach((el) => (el.style.display = "")); +    if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler);    }, -  initOnKeyListeners: function() { +  initOnKeyListeners: () => {      // only install a listener if it is really needed -    if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && -        !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -        return; +    if ( +      !DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && +      !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS +    ) +      return; -    $(document).keydown(function(event) { -      var activeElementType = document.activeElement.tagName; -      // don't navigate when in search box, textarea, dropdown or button -      if (activeElementType !== 'TEXTAREA' && activeElementType !== 'INPUT' && activeElementType !== 'SELECT' -          && activeElementType !== 'BUTTON') { -        if (event.altKey || event.ctrlKey || event.metaKey) -          return; +    const blacklistedElements = new Set([ +      "TEXTAREA", +      "INPUT", +      "SELECT", +      "BUTTON", +    ]); +    document.addEventListener("keydown", (event) => { +      if (blacklistedElements.has(document.activeElement.tagName)) return; // bail for input elements +      if (event.altKey || event.ctrlKey || event.metaKey) return; // bail with special keys -          if (!event.shiftKey) { -            switch (event.key) { -              case 'ArrowLeft': -                if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) -                  break; -                var prevHref = $('link[rel="prev"]').prop('href'); -                if (prevHref) { -                  window.location.href = prevHref; -                  return false; -                } -                break; -              case 'ArrowRight': -                if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) -                  break; -                var nextHref = $('link[rel="next"]').prop('href'); -                if (nextHref) { -                  window.location.href = nextHref; -                  return false; -                } -                break; -              case 'Escape': -                if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -                  break; -                Documentation.hideSearchWords(); -                return false; -          } -        } - -        // some keyboard layouts may need Shift to get / +      if (!event.shiftKey) {          switch (event.key) { -          case '/': -            if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -              break; -            Documentation.focusSearchBar(); -            return false; +          case "ArrowLeft": +            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + +            const prevLink = document.querySelector('link[rel="prev"]'); +            if (prevLink && prevLink.href) { +              window.location.href = prevLink.href; +              event.preventDefault(); +            } +            break; +          case "ArrowRight": +            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + +            const nextLink = document.querySelector('link[rel="next"]'); +            if (nextLink && nextLink.href) { +              window.location.href = nextLink.href; +              event.preventDefault(); +            } +            break; +          case "Escape": +            if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; +            Documentation.hideSearchWords(); +            event.preventDefault();          }        } + +      // some keyboard layouts may need Shift to get / +      switch (event.key) { +        case "/": +          if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; +          Documentation.focusSearchBar(); +          event.preventDefault(); +      }      }); -  } +  },  };  // quick alias for translations -_ = Documentation.gettext; +const _ = Documentation.gettext; -$(document).ready(function() { -  Documentation.init(); -}); +_ready(Documentation.init); diff --git a/v7.1.1/_static/documentation_options.js b/v7.1.1/_static/documentation_options.js index e4e08a75..5414fbe2 100644 --- a/v7.1.1/_static/documentation_options.js +++ b/v7.1.1/_static/documentation_options.js @@ -1,7 +1,7 @@  var DOCUMENTATION_OPTIONS = {      URL_ROOT: document.getElementById("documentation_options").getAttribute('data-url_root'),      VERSION: '7.1.1', -    LANGUAGE: 'None', +    LANGUAGE: 'en',      COLLAPSE_INDEX: false,      BUILDER: 'html',      FILE_SUFFIX: '.html', @@ -10,5 +10,5 @@ var DOCUMENTATION_OPTIONS = {      SOURCELINK_SUFFIX: '.txt',      NAVIGATION_WITH_KEYS: false,      SHOW_SEARCH_SUMMARY: true, -    ENABLE_SEARCH_SHORTCUTS: true, +    ENABLE_SEARCH_SHORTCUTS: false,  };
\ No newline at end of file diff --git a/v7.1.1/_static/jquery-3.5.1.js b/v7.1.1/_static/jquery-3.6.0.js index 50937333..fc6c299b 100644 --- a/v7.1.1/_static/jquery-3.5.1.js +++ b/v7.1.1/_static/jquery-3.6.0.js @@ -1,15 +1,15 @@  /*! - * jQuery JavaScript Library v3.5.1 + * jQuery JavaScript Library v3.6.0   * https://jquery.com/   *   * Includes Sizzle.js   * https://sizzlejs.com/   * - * Copyright JS Foundation and other contributors + * Copyright OpenJS Foundation and other contributors   * Released under the MIT license   * https://jquery.org/license   * - * Date: 2020-05-04T22:49Z + * Date: 2021-03-02T17:08Z   */  ( function( global, factory ) { @@ -76,12 +76,16 @@ var support = {};  var isFunction = function isFunction( obj ) { -      // Support: Chrome <=57, Firefox <=52 -      // In some browsers, typeof returns "function" for HTML <object> elements -      // (i.e., `typeof document.createElement( "object" ) === "function"`). -      // We don't want to classify *any* DOM node as a function. -      return typeof obj === "function" && typeof obj.nodeType !== "number"; -  }; +		// Support: Chrome <=57, Firefox <=52 +		// In some browsers, typeof returns "function" for HTML <object> elements +		// (i.e., `typeof document.createElement( "object" ) === "function"`). +		// We don't want to classify *any* DOM node as a function. +		// Support: QtWeb <=3.8.5, WebKit <=534.34, wkhtmltopdf tool <=0.12.5 +		// Plus for old WebKit, typeof returns "function" for HTML collections +		// (e.g., `typeof document.getElementsByTagName("div") === "function"`). (gh-4756) +		return typeof obj === "function" && typeof obj.nodeType !== "number" && +			typeof obj.item !== "function"; +	};  var isWindow = function isWindow( obj ) { @@ -147,7 +151,7 @@ function toType( obj ) {  var -	version = "3.5.1", +	version = "3.6.0",  	// Define a local copy of jQuery  	jQuery = function( selector, context ) { @@ -401,7 +405,7 @@ jQuery.extend( {  			if ( isArrayLike( Object( arr ) ) ) {  				jQuery.merge( ret,  					typeof arr === "string" ? -					[ arr ] : arr +						[ arr ] : arr  				);  			} else {  				push.call( ret, arr ); @@ -496,9 +500,9 @@ if ( typeof Symbol === "function" ) {  // Populate the class2type map  jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ), -function( _i, name ) { -	class2type[ "[object " + name + "]" ] = name.toLowerCase(); -} ); +	function( _i, name ) { +		class2type[ "[object " + name + "]" ] = name.toLowerCase(); +	} );  function isArrayLike( obj ) { @@ -518,14 +522,14 @@ function isArrayLike( obj ) {  }  var Sizzle =  /*! - * Sizzle CSS Selector Engine v2.3.5 + * Sizzle CSS Selector Engine v2.3.6   * https://sizzlejs.com/   *   * Copyright JS Foundation and other contributors   * Released under the MIT license   * https://js.foundation/   * - * Date: 2020-03-14 + * Date: 2021-02-16   */  ( function( window ) {  var i, @@ -1108,8 +1112,8 @@ support = Sizzle.support = {};   * @returns {Boolean} True iff elem is a non-HTML XML node   */  isXML = Sizzle.isXML = function( elem ) { -	var namespace = elem.namespaceURI, -		docElem = ( elem.ownerDocument || elem ).documentElement; +	var namespace = elem && elem.namespaceURI, +		docElem = elem && ( elem.ownerDocument || elem ).documentElement;  	// Support: IE <=8  	// Assume HTML when documentElement doesn't yet exist, such as inside loading iframes @@ -3024,9 +3028,9 @@ var rneedsContext = jQuery.expr.match.needsContext;  function nodeName( elem, name ) { -  return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); +	return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); -}; +}  var rsingleTag = ( /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i ); @@ -3997,8 +4001,8 @@ jQuery.extend( {  			resolveContexts = Array( i ),  			resolveValues = slice.call( arguments ), -			// the master Deferred -			master = jQuery.Deferred(), +			// the primary Deferred +			primary = jQuery.Deferred(),  			// subordinate callback factory  			updateFunc = function( i ) { @@ -4006,30 +4010,30 @@ jQuery.extend( {  					resolveContexts[ i ] = this;  					resolveValues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value;  					if ( !( --remaining ) ) { -						master.resolveWith( resolveContexts, resolveValues ); +						primary.resolveWith( resolveContexts, resolveValues );  					}  				};  			};  		// Single- and empty arguments are adopted like Promise.resolve  		if ( remaining <= 1 ) { -			adoptValue( singleValue, master.done( updateFunc( i ) ).resolve, master.reject, +			adoptValue( singleValue, primary.done( updateFunc( i ) ).resolve, primary.reject,  				!remaining );  			// Use .then() to unwrap secondary thenables (cf. gh-3000) -			if ( master.state() === "pending" || +			if ( primary.state() === "pending" ||  				isFunction( resolveValues[ i ] && resolveValues[ i ].then ) ) { -				return master.then(); +				return primary.then();  			}  		}  		// Multiple arguments are aggregated like Promise.all array elements  		while ( i-- ) { -			adoptValue( resolveValues[ i ], updateFunc( i ), master.reject ); +			adoptValue( resolveValues[ i ], updateFunc( i ), primary.reject );  		} -		return master.promise(); +		return primary.promise();  	}  } ); @@ -4180,8 +4184,8 @@ var access = function( elems, fn, key, value, chainable, emptyGet, raw ) {  			for ( ; i < len; i++ ) {  				fn(  					elems[ i ], key, raw ? -					value : -					value.call( elems[ i ], i, fn( elems[ i ], key ) ) +						value : +						value.call( elems[ i ], i, fn( elems[ i ], key ) )  				);  			}  		} @@ -5089,10 +5093,7 @@ function buildFragment( elems, context, scripts, selection, ignored ) {  } -var -	rkeyEvent = /^key/, -	rmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/, -	rtypenamespace = /^([^.]*)(?:\.(.+)|)/; +var rtypenamespace = /^([^.]*)(?:\.(.+)|)/;  function returnTrue() {  	return true; @@ -5387,8 +5388,8 @@ jQuery.event = {  			event = jQuery.event.fix( nativeEvent ),  			handlers = ( -					dataPriv.get( this, "events" ) || Object.create( null ) -				)[ event.type ] || [], +				dataPriv.get( this, "events" ) || Object.create( null ) +			)[ event.type ] || [],  			special = jQuery.event.special[ event.type ] || {};  		// Use the fix-ed jQuery.Event rather than the (read-only) native event @@ -5512,12 +5513,12 @@ jQuery.event = {  			get: isFunction( hook ) ?  				function() {  					if ( this.originalEvent ) { -							return hook( this.originalEvent ); +						return hook( this.originalEvent );  					}  				} :  				function() {  					if ( this.originalEvent ) { -							return this.originalEvent[ name ]; +						return this.originalEvent[ name ];  					}  				}, @@ -5656,7 +5657,13 @@ function leverageNative( el, type, expectSync ) {  						// Cancel the outer synthetic event  						event.stopImmediatePropagation();  						event.preventDefault(); -						return result.value; + +						// Support: Chrome 86+ +						// In Chrome, if an element having a focusout handler is blurred by +						// clicking outside of it, it invokes the handler synchronously. If +						// that handler calls `.remove()` on the element, the data is cleared, +						// leaving `result` undefined. We need to guard against this. +						return result && result.value;  					}  				// If this is an inner synthetic event for an event with a bubbling surrogate @@ -5821,34 +5828,7 @@ jQuery.each( {  	targetTouches: true,  	toElement: true,  	touches: true, - -	which: function( event ) { -		var button = event.button; - -		// Add which for key events -		if ( event.which == null && rkeyEvent.test( event.type ) ) { -			return event.charCode != null ? event.charCode : event.keyCode; -		} - -		// Add which for click: 1 === left; 2 === middle; 3 === right -		if ( !event.which && button !== undefined && rmouseEvent.test( event.type ) ) { -			if ( button & 1 ) { -				return 1; -			} - -			if ( button & 2 ) { -				return 3; -			} - -			if ( button & 4 ) { -				return 2; -			} - -			return 0; -		} - -		return event.which; -	} +	which: true  }, jQuery.event.addProp );  jQuery.each( { focus: "focusin", blur: "focusout" }, function( type, delegateType ) { @@ -5874,6 +5854,12 @@ jQuery.each( { focus: "focusin", blur: "focusout" }, function( type, delegateTyp  			return true;  		}, +		// Suppress native focus or blur as it's already being fired +		// in leverageNative. +		_default: function() { +			return true; +		}, +  		delegateType: delegateType  	};  } ); @@ -6541,6 +6527,10 @@ var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" );  		// set in CSS while `offset*` properties report correct values.  		// Behavior in IE 9 is more subtle than in newer versions & it passes  		// some versions of this test; make sure not to make it pass there! +		// +		// Support: Firefox 70+ +		// Only Firefox includes border widths +		// in computed dimensions. (gh-4529)  		reliableTrDimensions: function() {  			var table, tr, trChild, trStyle;  			if ( reliableTrDimensionsVal == null ) { @@ -6548,17 +6538,32 @@ var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" );  				tr = document.createElement( "tr" );  				trChild = document.createElement( "div" ); -				table.style.cssText = "position:absolute;left:-11111px"; +				table.style.cssText = "position:absolute;left:-11111px;border-collapse:separate"; +				tr.style.cssText = "border:1px solid"; + +				// Support: Chrome 86+ +				// Height set through cssText does not get applied. +				// Computed height then comes back as 0.  				tr.style.height = "1px";  				trChild.style.height = "9px"; +				// Support: Android 8 Chrome 86+ +				// In our bodyBackground.html iframe, +				// display for all div elements is set to "inline", +				// which causes a problem only in Android 8 Chrome 86. +				// Ensuring the div is display: block +				// gets around this issue. +				trChild.style.display = "block"; +  				documentElement  					.appendChild( table )  					.appendChild( tr )  					.appendChild( trChild );  				trStyle = window.getComputedStyle( tr ); -				reliableTrDimensionsVal = parseInt( trStyle.height ) > 3; +				reliableTrDimensionsVal = ( parseInt( trStyle.height, 10 ) + +					parseInt( trStyle.borderTopWidth, 10 ) + +					parseInt( trStyle.borderBottomWidth, 10 ) ) === tr.offsetHeight;  				documentElement.removeChild( table );  			} @@ -7022,10 +7027,10 @@ jQuery.each( [ "height", "width" ], function( _i, dimension ) {  					// Running getBoundingClientRect on a disconnected node  					// in IE throws an error.  					( !elem.getClientRects().length || !elem.getBoundingClientRect().width ) ? -						swap( elem, cssShow, function() { -							return getWidthOrHeight( elem, dimension, extra ); -						} ) : -						getWidthOrHeight( elem, dimension, extra ); +					swap( elem, cssShow, function() { +						return getWidthOrHeight( elem, dimension, extra ); +					} ) : +					getWidthOrHeight( elem, dimension, extra );  			}  		}, @@ -7084,7 +7089,7 @@ jQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft,  					swap( elem, { marginLeft: 0 }, function() {  						return elem.getBoundingClientRect().left;  					} ) -				) + "px"; +			) + "px";  		}  	}  ); @@ -7223,7 +7228,7 @@ Tween.propHooks = {  			if ( jQuery.fx.step[ tween.prop ] ) {  				jQuery.fx.step[ tween.prop ]( tween );  			} else if ( tween.elem.nodeType === 1 && ( -					jQuery.cssHooks[ tween.prop ] || +				jQuery.cssHooks[ tween.prop ] ||  					tween.elem.style[ finalPropName( tween.prop ) ] != null ) ) {  				jQuery.style( tween.elem, tween.prop, tween.now + tween.unit );  			} else { @@ -7468,7 +7473,7 @@ function defaultPrefilter( elem, props, opts ) {  			anim.done( function() { -			/* eslint-enable no-loop-func */ +				/* eslint-enable no-loop-func */  				// The final step of a "hide" animation is actually hiding the element  				if ( !hidden ) { @@ -7588,7 +7593,7 @@ function Animation( elem, properties, options ) {  			tweens: [],  			createTween: function( prop, end ) {  				var tween = jQuery.Tween( elem, animation.opts, prop, end, -						animation.opts.specialEasing[ prop ] || animation.opts.easing ); +					animation.opts.specialEasing[ prop ] || animation.opts.easing );  				animation.tweens.push( tween );  				return tween;  			}, @@ -7761,7 +7766,8 @@ jQuery.fn.extend( {  					anim.stop( true );  				}  			}; -			doAnimation.finish = doAnimation; + +		doAnimation.finish = doAnimation;  		return empty || optall.queue === false ?  			this.each( doAnimation ) : @@ -8401,8 +8407,8 @@ jQuery.fn.extend( {  				if ( this.setAttribute ) {  					this.setAttribute( "class",  						className || value === false ? -						"" : -						dataPriv.get( this, "__className__" ) || "" +							"" : +							dataPriv.get( this, "__className__" ) || ""  					);  				}  			} @@ -8417,7 +8423,7 @@ jQuery.fn.extend( {  		while ( ( elem = this[ i++ ] ) ) {  			if ( elem.nodeType === 1 &&  				( " " + stripAndCollapse( getClass( elem ) ) + " " ).indexOf( className ) > -1 ) { -					return true; +				return true;  			}  		} @@ -8707,9 +8713,7 @@ jQuery.extend( jQuery.event, {  				special.bindType || type;  			// jQuery handler -			handle = ( -					dataPriv.get( cur, "events" ) || Object.create( null ) -				)[ event.type ] && +			handle = ( dataPriv.get( cur, "events" ) || Object.create( null ) )[ event.type ] &&  				dataPriv.get( cur, "handle" );  			if ( handle ) {  				handle.apply( cur, data ); @@ -8856,7 +8860,7 @@ var rquery = ( /\?/ );  // Cross-browser xml parsing  jQuery.parseXML = function( data ) { -	var xml; +	var xml, parserErrorElem;  	if ( !data || typeof data !== "string" ) {  		return null;  	} @@ -8865,12 +8869,17 @@ jQuery.parseXML = function( data ) {  	// IE throws on parseFromString with invalid input.  	try {  		xml = ( new window.DOMParser() ).parseFromString( data, "text/xml" ); -	} catch ( e ) { -		xml = undefined; -	} +	} catch ( e ) {} -	if ( !xml || xml.getElementsByTagName( "parsererror" ).length ) { -		jQuery.error( "Invalid XML: " + data ); +	parserErrorElem = xml && xml.getElementsByTagName( "parsererror" )[ 0 ]; +	if ( !xml || parserErrorElem ) { +		jQuery.error( "Invalid XML: " + ( +			parserErrorElem ? +				jQuery.map( parserErrorElem.childNodes, function( el ) { +					return el.textContent; +				} ).join( "\n" ) : +				data +		) );  	}  	return xml;  }; @@ -8971,16 +8980,14 @@ jQuery.fn.extend( {  			// Can add propHook for "elements" to filter or add form elements  			var elements = jQuery.prop( this, "elements" );  			return elements ? jQuery.makeArray( elements ) : this; -		} ) -		.filter( function() { +		} ).filter( function() {  			var type = this.type;  			// Use .is( ":disabled" ) so that fieldset[disabled] works  			return this.name && !jQuery( this ).is( ":disabled" ) &&  				rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) &&  				( this.checked || !rcheckableType.test( type ) ); -		} ) -		.map( function( _i, elem ) { +		} ).map( function( _i, elem ) {  			var val = jQuery( this ).val();  			if ( val == null ) { @@ -9033,7 +9040,8 @@ var  	// Anchor tag for parsing the document origin  	originAnchor = document.createElement( "a" ); -	originAnchor.href = location.href; + +originAnchor.href = location.href;  // Base "constructor" for jQuery.ajaxPrefilter and jQuery.ajaxTransport  function addToPrefiltersOrTransports( structure ) { @@ -9414,8 +9422,8 @@ jQuery.extend( {  			// Context for global events is callbackContext if it is a DOM node or jQuery collection  			globalEventContext = s.context &&  				( callbackContext.nodeType || callbackContext.jquery ) ? -					jQuery( callbackContext ) : -					jQuery.event, +				jQuery( callbackContext ) : +				jQuery.event,  			// Deferreds  			deferred = jQuery.Deferred(), @@ -9727,8 +9735,10 @@ jQuery.extend( {  				response = ajaxHandleResponses( s, jqXHR, responses );  			} -			// Use a noop converter for missing script -			if ( !isSuccess && jQuery.inArray( "script", s.dataTypes ) > -1 ) { +			// Use a noop converter for missing script but not if jsonp +			if ( !isSuccess && +				jQuery.inArray( "script", s.dataTypes ) > -1 && +				jQuery.inArray( "json", s.dataTypes ) < 0 ) {  				s.converters[ "text script" ] = function() {};  			} @@ -10466,12 +10476,6 @@ jQuery.offset = {  			options.using.call( elem, props );  		} else { -			if ( typeof props.top === "number" ) { -				props.top += "px"; -			} -			if ( typeof props.left === "number" ) { -				props.left += "px"; -			}  			curElem.css( props );  		}  	} @@ -10640,8 +10644,11 @@ jQuery.each( [ "top", "left" ], function( _i, prop ) {  // Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods  jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { -	jQuery.each( { padding: "inner" + name, content: type, "": "outer" + name }, -		function( defaultExtra, funcName ) { +	jQuery.each( { +		padding: "inner" + name, +		content: type, +		"": "outer" + name +	}, function( defaultExtra, funcName ) {  		// Margin is only for outerHeight, outerWidth  		jQuery.fn[ funcName ] = function( margin, value ) { @@ -10726,7 +10733,8 @@ jQuery.fn.extend( {  	}  } ); -jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " + +jQuery.each( +	( "blur focus focusin focusout resize scroll click dblclick " +  	"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " +  	"change select submit keydown keypress keyup contextmenu" ).split( " " ),  	function( _i, name ) { @@ -10737,7 +10745,8 @@ jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " +  				this.on( name, null, data, fn ) :  				this.trigger( name );  		}; -	} ); +	} +); diff --git a/v7.1.1/_static/jquery.js b/v7.1.1/_static/jquery.js index b0614034..c4c6022f 100644 --- a/v7.1.1/_static/jquery.js +++ b/v7.1.1/_static/jquery.js @@ -1,2 +1,2 @@ -/*! jQuery v3.5.1 | (c) JS Foundation and other contributors | jquery.org/license */ -!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.5.1",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),D=function(e,t){return e===t&&(l=!0),0},j={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e.namespaceURI,n=(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&j.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(D),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(D).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function D(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(D(this,e||[],!1))},not:function(e){return this.pushStack(D(this,e||[],!0))},is:function(e){return!!D(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var j,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||j,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,j=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^key/,we=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,Te=/^([^.]*)(?:\.(.+)|)/;function Ce(){return!0}function Ee(){return!1}function Se(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function ke(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)ke(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Ee;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Ae(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,Ce)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=Te.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=Te.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Ae(t,"click",Ce),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Ae(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?Ce:Ee,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Ee,isPropagationStopped:Ee,isImmediatePropagationStopped:Ee,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=Ce,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=Ce,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=Ce,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:function(e){var t=e.button;return null==e.which&&be.test(e.type)?null!=e.charCode?e.charCode:e.keyCode:!e.which&&void 0!==t&&we.test(e.type)?1&t?1:2&t?3:4&t?2:0:e.which}},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Ae(this,e,Se),!1},trigger:function(){return Ae(this,e),!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return ke(this,e,t,n,r)},one:function(e,t,n,r){return ke(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Ee),this.each(function(){S.event.remove(this,e,n,t)})}});var Ne=/<script|<style|<link/i,De=/checked\s*(?:[^=]|=\s*.checked.)/i,je=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function qe(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function Le(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function He(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Oe(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function Pe(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&De.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),Pe(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),Le)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,He),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(je,""),u,l))}return n}function Re(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Oe(o[r],a[r]);else Oe(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Re(this,e,!0)},remove:function(e){return Re(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return Pe(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||qe(this,e).appendChild(e)})},prepend:function(){return Pe(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=qe(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return Pe(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return Pe(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!Ne.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return Pe(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Me=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Ie=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},We=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Fe=new RegExp(ne.join("|"),"i");function Be(e,t,n){var r,i,o,a,s=e.style;return(n=n||Ie(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Me.test(a)&&Fe.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function $e(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px",t.style.height="1px",n.style.height="9px",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=3<parseInt(r.height),re.removeChild(e)),a}}))}();var _e=["Webkit","Moz","ms"],ze=E.createElement("div").style,Ue={};function Xe(e){var t=S.cssProps[e]||Ue[e];return t||(e in ze?e:Ue[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=_e.length;while(n--)if((e=_e[n]+t)in ze)return e}(e)||e)}var Ve=/^(none|table(?!-c[ea]).+)/,Ge=/^--/,Ye={position:"absolute",visibility:"hidden",display:"block"},Qe={letterSpacing:"0",fontWeight:"400"};function Je(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Ke(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Ze(e,t,n){var r=Ie(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=Be(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Me.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Ke(e,t,n||(i?"border":"content"),o,r,a)+"px"}function et(e,t,n,r,i){return new et.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Be(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Ge.test(t),l=e.style;if(u||(t=Xe(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Ge.test(t)||(t=Xe(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=Be(e,t,r)),"normal"===i&&t in Qe&&(i=Qe[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ve.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Ze(e,u,n):We(e,Ye,function(){return Ze(e,u,n)})},set:function(e,t,n){var r,i=Ie(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Ke(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Ke(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Je(0,t,s)}}}),S.cssHooks.marginLeft=$e(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(Be(e,"marginLeft"))||e.getBoundingClientRect().left-We(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Je)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Ie(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=et).prototype={constructor:et,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=et.propHooks[this.prop];return e&&e.get?e.get(this):et.propHooks._default.get(this)},run:function(e){var t,n=et.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):et.propHooks._default.set(this),this}}).init.prototype=et.prototype,(et.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[Xe(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=et.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=et.prototype.init,S.fx.step={};var tt,nt,rt,it,ot=/^(?:toggle|show|hide)$/,at=/queueHooks$/;function st(){nt&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(st):C.setTimeout(st,S.fx.interval),S.fx.tick())}function ut(){return C.setTimeout(function(){tt=void 0}),tt=Date.now()}function lt(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ct(e,t,n){for(var r,i=(ft.tweeners[t]||[]).concat(ft.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function ft(o,e,t){var n,a,r=0,i=ft.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=tt||ut(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:tt||ut(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=ft.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ct,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(ft,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],ft.tweeners[n]=ft.tweeners[n]||[],ft.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],ot.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ct(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?ft.prefilters.unshift(e):ft.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=ft(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&at.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(lt(r,!0),e,t,n)}}),S.each({slideDown:lt("show"),slideUp:lt("hide"),slideToggle:lt("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(tt=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),tt=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){nt||(nt=!0,st())},S.fx.stop=function(){nt=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},rt=E.createElement("input"),it=E.createElement("select").appendChild(E.createElement("option")),rt.type="checkbox",y.checkOn=""!==rt.value,y.optSelected=it.selected,(rt=E.createElement("input")).value="t",rt.type="radio",y.radioValue="t"===rt.value;var pt,dt=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?pt:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),pt={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=dt[t]||S.find.attr;dt[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=dt[o],dt[o]=r,r=null!=a(e,t,n)?o:null,dt[o]=i),r}});var ht=/^(?:input|select|textarea|button)$/i,gt=/^(?:a|area)$/i;function vt(e){return(e.match(P)||[]).join(" ")}function yt(e){return e.getAttribute&&e.getAttribute("class")||""}function mt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):ht.test(e.nodeName)||gt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,yt(this)))});if((e=mt(t)).length)while(n=this[u++])if(i=yt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,yt(this)))});if(!arguments.length)return this.attr("class","");if((e=mt(t)).length)while(n=this[u++])if(i=yt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,yt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=mt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=yt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+vt(yt(n))+" ").indexOf(t))return!0;return!1}});var xt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(xt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:vt(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var bt=/^(?:focusinfocus|focusoutblur)$/,wt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!bt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,bt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,wt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,wt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var Tt=C.location,Ct={guid:Date.now()},Et=/\?/;S.parseXML=function(e){var t;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){t=void 0}return t&&!t.getElementsByTagName("parsererror").length||S.error("Invalid XML: "+e),t};var St=/\[\]$/,kt=/\r?\n/g,At=/^(?:submit|button|image|reset|file)$/i,Nt=/^(?:input|select|textarea|keygen)/i;function Dt(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||St.test(n)?i(n,t):Dt(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)Dt(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)Dt(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&Nt.test(this.nodeName)&&!At.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(kt,"\r\n")}}):{name:t.name,value:n.replace(kt,"\r\n")}}).get()}});var jt=/%20/g,qt=/#.*$/,Lt=/([?&])_=[^&]*/,Ht=/^(.*?):[ \t]*([^\r\n]*)$/gm,Ot=/^(?:GET|HEAD)$/,Pt=/^\/\//,Rt={},Mt={},It="*/".concat("*"),Wt=E.createElement("a");function Ft(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Bt(t,i,o,a){var s={},u=t===Mt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function $t(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Wt.href=Tt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:Tt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(Tt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":It,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?$t($t(e,S.ajaxSettings),t):$t(S.ajaxSettings,e)},ajaxPrefilter:Ft(Rt),ajaxTransport:Ft(Mt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=Ht.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||Tt.href)+"").replace(Pt,Tt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Wt.protocol+"//"+Wt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Bt(Rt,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Ot.test(v.type),f=v.url.replace(qt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(jt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Et.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Lt,"$1"),o=(Et.test(f)?"&":"?")+"_="+Ct.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+It+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Bt(Mt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var _t={0:200,1223:204},zt=S.ajaxSettings.xhr();y.cors=!!zt&&"withCredentials"in zt,y.ajax=zt=!!zt,S.ajaxTransport(function(i){var o,a;if(y.cors||zt&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(_t[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var Ut,Xt=[],Vt=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=Xt.pop()||S.expando+"_"+Ct.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Vt.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Vt.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Vt,"$1"+r):!1!==e.jsonp&&(e.url+=(Et.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,Xt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((Ut=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===Ut.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=vt(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):("number"==typeof f.top&&(f.top+="px"),"number"==typeof f.left&&(f.left+="px"),c.css(f))}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=$e(y.pixelPosition,function(e,t){if(t)return t=Be(e,n),Me.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Gt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Gt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Yt=C.jQuery,Qt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Qt),e&&C.jQuery===S&&(C.jQuery=Yt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S}); +/*! jQuery v3.6.0 | (c) OpenJS Foundation and other contributors | jquery.org/license */ +!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.6.0",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),j=function(e,t){return e===t&&(l=!0),0},D={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},j=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&D.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(j),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(j).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var D,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||D,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,D=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^([^.]*)(?:\.(.+)|)/;function we(){return!0}function Te(){return!1}function Ce(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function Ee(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)Ee(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Te;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Se(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n&&n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,we)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=be.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=be.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click",we),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?we:Te,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Te,isPropagationStopped:Te,isImmediatePropagationStopped:Te,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=we,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=we,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=we,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:!0},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Se(this,e,Ce),!1},trigger:function(){return Se(this,e),!0},_default:function(){return!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return Ee(this,e,t,n,r)},one:function(e,t,n,r){return Ee(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Te),this.each(function(){S.event.remove(this,e,n,t)})}});var ke=/<script|<style|<link/i,Ae=/checked\s*(?:[^=]|=\s*.checked.)/i,Ne=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function je(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function De(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function qe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Le(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function He(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&Ae.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),He(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),De)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,qe),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(Ne,""),u,l))}return n}function Oe(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Le(o[r],a[r]);else Le(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Oe(this,e,!0)},remove:function(e){return Oe(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return He(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||je(this,e).appendChild(e)})},prepend:function(){return He(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=je(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!ke.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return He(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Pe=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Re=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},Me=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Ie=new RegExp(ne.join("|"),"i");function We(e,t,n){var r,i,o,a,s=e.style;return(n=n||Re(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Pe.test(a)&&Ie.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function Fe(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px;border-collapse:separate",t.style.cssText="border:1px solid",t.style.height="1px",n.style.height="9px",n.style.display="block",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=parseInt(r.height,10)+parseInt(r.borderTopWidth,10)+parseInt(r.borderBottomWidth,10)===t.offsetHeight,re.removeChild(e)),a}}))}();var Be=["Webkit","Moz","ms"],$e=E.createElement("div").style,_e={};function ze(e){var t=S.cssProps[e]||_e[e];return t||(e in $e?e:_e[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=Be.length;while(n--)if((e=Be[n]+t)in $e)return e}(e)||e)}var Ue=/^(none|table(?!-c[ea]).+)/,Xe=/^--/,Ve={position:"absolute",visibility:"hidden",display:"block"},Ge={letterSpacing:"0",fontWeight:"400"};function Ye(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Qe(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Je(e,t,n){var r=Re(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=We(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Pe.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Qe(e,t,n||(i?"border":"content"),o,r,a)+"px"}function Ke(e,t,n,r,i){return new Ke.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=We(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Xe.test(t),l=e.style;if(u||(t=ze(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Xe.test(t)||(t=ze(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=We(e,t,r)),"normal"===i&&t in Ge&&(i=Ge[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ue.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Je(e,u,n):Me(e,Ve,function(){return Je(e,u,n)})},set:function(e,t,n){var r,i=Re(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Qe(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Qe(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Ye(0,t,s)}}}),S.cssHooks.marginLeft=Fe(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(We(e,"marginLeft"))||e.getBoundingClientRect().left-Me(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Ye)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Re(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=Ke).prototype={constructor:Ke,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=Ke.propHooks[this.prop];return e&&e.get?e.get(this):Ke.propHooks._default.get(this)},run:function(e){var t,n=Ke.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):Ke.propHooks._default.set(this),this}}).init.prototype=Ke.prototype,(Ke.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[ze(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=Ke.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=Ke.prototype.init,S.fx.step={};var Ze,et,tt,nt,rt=/^(?:toggle|show|hide)$/,it=/queueHooks$/;function ot(){et&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(ot):C.setTimeout(ot,S.fx.interval),S.fx.tick())}function at(){return C.setTimeout(function(){Ze=void 0}),Ze=Date.now()}function st(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ut(e,t,n){for(var r,i=(lt.tweeners[t]||[]).concat(lt.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function lt(o,e,t){var n,a,r=0,i=lt.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=Ze||at(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:Ze||at(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=lt.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ut,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(lt,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],lt.tweeners[n]=lt.tweeners[n]||[],lt.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],rt.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ut(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?lt.prefilters.unshift(e):lt.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=lt(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&it.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(st(r,!0),e,t,n)}}),S.each({slideDown:st("show"),slideUp:st("hide"),slideToggle:st("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(Ze=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),Ze=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){et||(et=!0,ot())},S.fx.stop=function(){et=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},tt=E.createElement("input"),nt=E.createElement("select").appendChild(E.createElement("option")),tt.type="checkbox",y.checkOn=""!==tt.value,y.optSelected=nt.selected,(tt=E.createElement("input")).value="t",tt.type="radio",y.radioValue="t"===tt.value;var ct,ft=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?ct:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),ct={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=ft[t]||S.find.attr;ft[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=ft[o],ft[o]=r,r=null!=a(e,t,n)?o:null,ft[o]=i),r}});var pt=/^(?:input|select|textarea|button)$/i,dt=/^(?:a|area)$/i;function ht(e){return(e.match(P)||[]).join(" ")}function gt(e){return e.getAttribute&&e.getAttribute("class")||""}function vt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):pt.test(e.nodeName)||dt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,gt(this)))});if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,gt(this)))});if(!arguments.length)return this.attr("class","");if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,gt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=vt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=gt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+ht(gt(n))+" ").indexOf(t))return!0;return!1}});var yt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(yt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:ht(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var mt=/^(?:focusinfocus|focusoutblur)$/,xt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!mt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,mt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,xt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,xt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var bt=C.location,wt={guid:Date.now()},Tt=/\?/;S.parseXML=function(e){var t,n;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){}return n=t&&t.getElementsByTagName("parsererror")[0],t&&!n||S.error("Invalid XML: "+(n?S.map(n.childNodes,function(e){return e.textContent}).join("\n"):e)),t};var Ct=/\[\]$/,Et=/\r?\n/g,St=/^(?:submit|button|image|reset|file)$/i,kt=/^(?:input|select|textarea|keygen)/i;function At(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||Ct.test(n)?i(n,t):At(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)At(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)At(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&kt.test(this.nodeName)&&!St.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(Et,"\r\n")}}):{name:t.name,value:n.replace(Et,"\r\n")}}).get()}});var Nt=/%20/g,jt=/#.*$/,Dt=/([?&])_=[^&]*/,qt=/^(.*?):[ \t]*([^\r\n]*)$/gm,Lt=/^(?:GET|HEAD)$/,Ht=/^\/\//,Ot={},Pt={},Rt="*/".concat("*"),Mt=E.createElement("a");function It(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Wt(t,i,o,a){var s={},u=t===Pt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function Ft(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Mt.href=bt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:bt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(bt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Rt,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Ft(Ft(e,S.ajaxSettings),t):Ft(S.ajaxSettings,e)},ajaxPrefilter:It(Ot),ajaxTransport:It(Pt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=qt.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||bt.href)+"").replace(Ht,bt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Mt.protocol+"//"+Mt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Wt(Ot,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Lt.test(v.type),f=v.url.replace(jt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(Nt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Tt.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Dt,"$1"),o=(Tt.test(f)?"&":"?")+"_="+wt.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+Rt+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Wt(Pt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&S.inArray("json",v.dataTypes)<0&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var Bt={0:200,1223:204},$t=S.ajaxSettings.xhr();y.cors=!!$t&&"withCredentials"in $t,y.ajax=$t=!!$t,S.ajaxTransport(function(i){var o,a;if(y.cors||$t&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(Bt[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var _t,zt=[],Ut=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=zt.pop()||S.expando+"_"+wt.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Ut.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Ut.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Ut,"$1"+r):!1!==e.jsonp&&(e.url+=(Tt.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,zt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((_t=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===_t.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=ht(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=Fe(y.pixelPosition,function(e,t){if(t)return t=We(e,n),Pe.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Xt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Xt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Vt=C.jQuery,Gt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Gt),e&&C.jQuery===S&&(C.jQuery=Vt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S}); diff --git a/v7.1.1/_static/language_data.js b/v7.1.1/_static/language_data.js index ebe2f03b..2e22b06a 100644 --- a/v7.1.1/_static/language_data.js +++ b/v7.1.1/_static/language_data.js @@ -10,7 +10,7 @@   *   */ -var stopwords = ["a","and","are","as","at","be","but","by","for","if","in","into","is","it","near","no","not","of","on","or","such","that","the","their","then","there","these","they","this","to","was","will","with"]; +var stopwords = ["a", "and", "are", "as", "at", "be", "but", "by", "for", "if", "in", "into", "is", "it", "near", "no", "not", "of", "on", "or", "such", "that", "the", "their", "then", "there", "these", "they", "this", "to", "was", "will", "with"];  /* Non-minified version is copied as a separate JS file, is available */ @@ -197,101 +197,3 @@ var Stemmer = function() {    }  } - - - -var splitChars = (function() { -    var result = {}; -    var singles = [96, 180, 187, 191, 215, 247, 749, 885, 903, 907, 909, 930, 1014, 1648, -         1748, 1809, 2416, 2473, 2481, 2526, 2601, 2609, 2612, 2615, 2653, 2702, -         2706, 2729, 2737, 2740, 2857, 2865, 2868, 2910, 2928, 2948, 2961, 2971, -         2973, 3085, 3089, 3113, 3124, 3213, 3217, 3241, 3252, 3295, 3341, 3345, -         3369, 3506, 3516, 3633, 3715, 3721, 3736, 3744, 3748, 3750, 3756, 3761, -         3781, 3912, 4239, 4347, 4681, 4695, 4697, 4745, 4785, 4799, 4801, 4823, -         4881, 5760, 5901, 5997, 6313, 7405, 8024, 8026, 8028, 8030, 8117, 8125, -         8133, 8181, 8468, 8485, 8487, 8489, 8494, 8527, 11311, 11359, 11687, 11695, -         11703, 11711, 11719, 11727, 11735, 12448, 12539, 43010, 43014, 43019, 43587, -         43696, 43713, 64286, 64297, 64311, 64317, 64319, 64322, 64325, 65141]; -    var i, j, start, end; -    for (i = 0; i < singles.length; i++) { -        result[singles[i]] = true; -    } -    var ranges = [[0, 47], [58, 64], [91, 94], [123, 169], [171, 177], [182, 184], [706, 709], -         [722, 735], [741, 747], [751, 879], [888, 889], [894, 901], [1154, 1161], -         [1318, 1328], [1367, 1368], [1370, 1376], [1416, 1487], [1515, 1519], [1523, 1568], -         [1611, 1631], [1642, 1645], [1750, 1764], [1767, 1773], [1789, 1790], [1792, 1807], -         [1840, 1868], [1958, 1968], [1970, 1983], [2027, 2035], [2038, 2041], [2043, 2047], -         [2070, 2073], [2075, 2083], [2085, 2087], [2089, 2307], [2362, 2364], [2366, 2383], -         [2385, 2391], [2402, 2405], [2419, 2424], [2432, 2436], [2445, 2446], [2449, 2450], -         [2483, 2485], [2490, 2492], [2494, 2509], [2511, 2523], [2530, 2533], [2546, 2547], -         [2554, 2564], [2571, 2574], [2577, 2578], [2618, 2648], [2655, 2661], [2672, 2673], -         [2677, 2692], [2746, 2748], [2750, 2767], [2769, 2783], [2786, 2789], [2800, 2820], -         [2829, 2830], [2833, 2834], [2874, 2876], [2878, 2907], [2914, 2917], [2930, 2946], -         [2955, 2957], [2966, 2968], [2976, 2978], [2981, 2983], [2987, 2989], [3002, 3023], -         [3025, 3045], [3059, 3076], [3130, 3132], [3134, 3159], [3162, 3167], [3170, 3173], -         [3184, 3191], [3199, 3204], [3258, 3260], [3262, 3293], [3298, 3301], [3312, 3332], -         [3386, 3388], [3390, 3423], [3426, 3429], [3446, 3449], [3456, 3460], [3479, 3481], -         [3518, 3519], [3527, 3584], [3636, 3647], [3655, 3663], [3674, 3712], [3717, 3718], -         [3723, 3724], [3726, 3731], [3752, 3753], [3764, 3772], [3774, 3775], [3783, 3791], -         [3802, 3803], [3806, 3839], [3841, 3871], [3892, 3903], [3949, 3975], [3980, 4095], -         [4139, 4158], [4170, 4175], [4182, 4185], [4190, 4192], [4194, 4196], [4199, 4205], -         [4209, 4212], [4226, 4237], [4250, 4255], [4294, 4303], [4349, 4351], [4686, 4687], -         [4702, 4703], [4750, 4751], [4790, 4791], [4806, 4807], [4886, 4887], [4955, 4968], -         [4989, 4991], [5008, 5023], [5109, 5120], [5741, 5742], [5787, 5791], [5867, 5869], -         [5873, 5887], [5906, 5919], [5938, 5951], [5970, 5983], [6001, 6015], [6068, 6102], -         [6104, 6107], [6109, 6111], [6122, 6127], [6138, 6159], [6170, 6175], [6264, 6271], -         [6315, 6319], [6390, 6399], [6429, 6469], [6510, 6511], [6517, 6527], [6572, 6592], -         [6600, 6607], [6619, 6655], [6679, 6687], [6741, 6783], [6794, 6799], [6810, 6822], -         [6824, 6916], [6964, 6980], [6988, 6991], [7002, 7042], [7073, 7085], [7098, 7167], -         [7204, 7231], [7242, 7244], [7294, 7400], [7410, 7423], [7616, 7679], [7958, 7959], -         [7966, 7967], [8006, 8007], [8014, 8015], [8062, 8063], [8127, 8129], [8141, 8143], -         [8148, 8149], [8156, 8159], [8173, 8177], [8189, 8303], [8306, 8307], [8314, 8318], -         [8330, 8335], [8341, 8449], [8451, 8454], [8456, 8457], [8470, 8472], [8478, 8483], -         [8506, 8507], [8512, 8516], [8522, 8525], [8586, 9311], [9372, 9449], [9472, 10101], -         [10132, 11263], [11493, 11498], [11503, 11516], [11518, 11519], [11558, 11567], -         [11622, 11630], [11632, 11647], [11671, 11679], [11743, 11822], [11824, 12292], -         [12296, 12320], [12330, 12336], [12342, 12343], [12349, 12352], [12439, 12444], -         [12544, 12548], [12590, 12592], [12687, 12689], [12694, 12703], [12728, 12783], -         [12800, 12831], [12842, 12880], [12896, 12927], [12938, 12976], [12992, 13311], -         [19894, 19967], [40908, 40959], [42125, 42191], [42238, 42239], [42509, 42511], -         [42540, 42559], [42592, 42593], [42607, 42622], [42648, 42655], [42736, 42774], -         [42784, 42785], [42889, 42890], [42893, 43002], [43043, 43055], [43062, 43071], -         [43124, 43137], [43188, 43215], [43226, 43249], [43256, 43258], [43260, 43263], -         [43302, 43311], [43335, 43359], [43389, 43395], [43443, 43470], [43482, 43519], -         [43561, 43583], [43596, 43599], [43610, 43615], [43639, 43641], [43643, 43647], -         [43698, 43700], [43703, 43704], [43710, 43711], [43715, 43738], [43742, 43967], -         [44003, 44015], [44026, 44031], [55204, 55215], [55239, 55242], [55292, 55295], -         [57344, 63743], [64046, 64047], [64110, 64111], [64218, 64255], [64263, 64274], -         [64280, 64284], [64434, 64466], [64830, 64847], [64912, 64913], [64968, 65007], -         [65020, 65135], [65277, 65295], [65306, 65312], [65339, 65344], [65371, 65381], -         [65471, 65473], [65480, 65481], [65488, 65489], [65496, 65497]]; -    for (i = 0; i < ranges.length; i++) { -        start = ranges[i][0]; -        end = ranges[i][1]; -        for (j = start; j <= end; j++) { -            result[j] = true; -        } -    } -    return result; -})(); - -function splitQuery(query) { -    var result = []; -    var start = -1; -    for (var i = 0; i < query.length; i++) { -        if (splitChars[query.charCodeAt(i)]) { -            if (start !== -1) { -                result.push(query.slice(start, i)); -                start = -1; -            } -        } else if (start === -1) { -            start = i; -        } -    } -    if (start !== -1) { -        result.push(query.slice(start)); -    } -    return result; -} - - diff --git a/v7.1.1/_static/searchtools.js b/v7.1.1/_static/searchtools.js index 0a44e858..ac4d5861 100644 --- a/v7.1.1/_static/searchtools.js +++ b/v7.1.1/_static/searchtools.js @@ -8,18 +8,20 @@   * :license: BSD, see LICENSE for details.   *   */ +"use strict"; -if (!Scorer) { -  /** -   * Simple result scoring code. -   */ +/** + * Simple result scoring code. + */ +if (typeof Scorer === "undefined") {    var Scorer = {      // Implement the following function to further tweak the score for each result -    // The function takes a result array [filename, title, anchor, descr, score] +    // The function takes a result array [docname, title, anchor, descr, score, filename]      // and returns the new score.      /* -    score: function(result) { -      return result[4]; +    score: result => { +      const [docname, title, anchor, descr, score, filename] = result +      return score      },      */ @@ -28,9 +30,11 @@ if (!Scorer) {      // or matches in the last dotted part of the object name      objPartialMatch: 6,      // Additive scores depending on the priority of the object -    objPrio: {0:  15,   // used to be importantResults -              1:  5,   // used to be objectResults -              2: -5},  // used to be unimportantResults +    objPrio: { +      0: 15, // used to be importantResults +      1: 5, // used to be objectResults +      2: -5, // used to be unimportantResults +    },      //  Used when the priority is not in the mapping.      objPrioDefault: 0, @@ -39,452 +43,455 @@ if (!Scorer) {      partialTitle: 7,      // query found in terms      term: 5, -    partialTerm: 2 +    partialTerm: 2,    };  } -if (!splitQuery) { -  function splitQuery(query) { -    return query.split(/\s+/); +const _removeChildren = (element) => { +  while (element && element.lastChild) element.removeChild(element.lastChild); +}; + +/** + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#escaping + */ +const _escapeRegExp = (string) => +  string.replace(/[.*+\-?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string + +const _displayItem = (item, highlightTerms, searchTerms) => { +  const docBuilder = DOCUMENTATION_OPTIONS.BUILDER; +  const docUrlRoot = DOCUMENTATION_OPTIONS.URL_ROOT; +  const docFileSuffix = DOCUMENTATION_OPTIONS.FILE_SUFFIX; +  const docLinkSuffix = DOCUMENTATION_OPTIONS.LINK_SUFFIX; +  const showSearchSummary = DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY; + +  const [docName, title, anchor, descr] = item; + +  let listItem = document.createElement("li"); +  let requestUrl; +  let linkUrl; +  if (docBuilder === "dirhtml") { +    // dirhtml builder +    let dirname = docName + "/"; +    if (dirname.match(/\/index\/$/)) +      dirname = dirname.substring(0, dirname.length - 6); +    else if (dirname === "index/") dirname = ""; +    requestUrl = docUrlRoot + dirname; +    linkUrl = requestUrl; +  } else { +    // normal html builders +    requestUrl = docUrlRoot + docName + docFileSuffix; +    linkUrl = docName + docLinkSuffix; +  } +  const params = new URLSearchParams(); +  params.set("highlight", [...highlightTerms].join(" ")); +  let linkEl = listItem.appendChild(document.createElement("a")); +  linkEl.href = linkUrl + "?" + params.toString() + anchor; +  linkEl.innerHTML = title; +  if (descr) +    listItem.appendChild(document.createElement("span")).innerText = +      " (" + descr + ")"; +  else if (showSearchSummary) +    fetch(requestUrl) +      .then((responseData) => responseData.text()) +      .then((data) => { +        if (data) +          listItem.appendChild( +            Search.makeSearchSummary(data, searchTerms, highlightTerms) +          ); +      }); +  Search.output.appendChild(listItem); +}; +const _finishSearch = (resultCount) => { +  Search.stopPulse(); +  Search.title.innerText = _("Search Results"); +  if (!resultCount) +    Search.status.innerText = Documentation.gettext( +      "Your search did not match any documents. Please make sure that all words are spelled correctly and that you've selected enough categories." +    ); +  else +    Search.status.innerText = _( +      `Search finished, found ${resultCount} page(s) matching the search query.` +    ); +}; +const _displayNextItem = ( +  results, +  resultCount, +  highlightTerms, +  searchTerms +) => { +  // results left, load the summary and display it +  // this is intended to be dynamic (don't sub resultsCount) +  if (results.length) { +    _displayItem(results.pop(), highlightTerms, searchTerms); +    setTimeout( +      () => _displayNextItem(results, resultCount, highlightTerms, searchTerms), +      5 +    );    } +  // search finished, update title and status message +  else _finishSearch(resultCount); +}; + +/** + * Default splitQuery function. Can be overridden in ``sphinx.search`` with a + * custom function per language. + * + * The regular expression works by splitting the string on consecutive characters + * that are not Unicode letters, numbers, underscores, or emoji characters. + * This is the same as ``\W+`` in Python, preserving the surrogate pair area. + */ +if (typeof splitQuery === "undefined") { +  var splitQuery = (query) => query +      .split(/[^\p{Letter}\p{Number}_\p{Emoji_Presentation}]+/gu) +      .filter(term => term)  // remove remaining empty strings  }  /**   * Search Module   */ -var Search = { - -  _index : null, -  _queued_query : null, -  _pulse_status : -1, - -  htmlToText : function(htmlString) { -      var virtualDocument = document.implementation.createHTMLDocument('virtual'); -      var htmlElement = $(htmlString, virtualDocument); -      htmlElement.find('.headerlink').remove(); -      docContent = htmlElement.find('[role=main]')[0]; -      if(docContent === undefined) { -          console.warn("Content block not found. Sphinx search tries to obtain it " + -                       "via '[role=main]'. Could you check your theme or template."); -          return ""; -      } -      return docContent.textContent || docContent.innerText; +const Search = { +  _index: null, +  _queued_query: null, +  _pulse_status: -1, + +  htmlToText: (htmlString) => { +    const htmlElement = document +      .createRange() +      .createContextualFragment(htmlString); +    _removeChildren(htmlElement.querySelectorAll(".headerlink")); +    const docContent = htmlElement.querySelector('[role="main"]'); +    if (docContent !== undefined) return docContent.textContent; +    console.warn( +      "Content block not found. Sphinx search tries to obtain it via '[role=main]'. Could you check your theme or template." +    ); +    return "";    }, -  init : function() { -      var params = $.getQueryParameters(); -      if (params.q) { -          var query = params.q[0]; -          $('input[name="q"]')[0].value = query; -          this.performSearch(query); -      } +  init: () => { +    const query = new URLSearchParams(window.location.search).get("q"); +    document +      .querySelectorAll('input[name="q"]') +      .forEach((el) => (el.value = query)); +    if (query) Search.performSearch(query);    }, -  loadIndex : function(url) { -    $.ajax({type: "GET", url: url, data: null, -            dataType: "script", cache: true, -            complete: function(jqxhr, textstatus) { -              if (textstatus != "success") { -                document.getElementById("searchindexloader").src = url; -              } -            }}); -  }, +  loadIndex: (url) => +    (document.body.appendChild(document.createElement("script")).src = url), -  setIndex : function(index) { -    var q; -    this._index = index; -    if ((q = this._queued_query) !== null) { -      this._queued_query = null; -      Search.query(q); +  setIndex: (index) => { +    Search._index = index; +    if (Search._queued_query !== null) { +      const query = Search._queued_query; +      Search._queued_query = null; +      Search.query(query);      }    }, -  hasIndex : function() { -      return this._index !== null; -  }, +  hasIndex: () => Search._index !== null, -  deferQuery : function(query) { -      this._queued_query = query; -  }, +  deferQuery: (query) => (Search._queued_query = query), -  stopPulse : function() { -      this._pulse_status = 0; -  }, +  stopPulse: () => (Search._pulse_status = -1), -  startPulse : function() { -    if (this._pulse_status >= 0) -        return; -    function pulse() { -      var i; +  startPulse: () => { +    if (Search._pulse_status >= 0) return; + +    const pulse = () => {        Search._pulse_status = (Search._pulse_status + 1) % 4; -      var dotString = ''; -      for (i = 0; i < Search._pulse_status; i++) -        dotString += '.'; -      Search.dots.text(dotString); -      if (Search._pulse_status > -1) -        window.setTimeout(pulse, 500); -    } +      Search.dots.innerText = ".".repeat(Search._pulse_status); +      if (Search._pulse_status >= 0) window.setTimeout(pulse, 500); +    };      pulse();    },    /**     * perform a search for something (or wait until index is loaded)     */ -  performSearch : function(query) { +  performSearch: (query) => {      // create the required interface elements -    this.out = $('#search-results'); -    this.title = $('<h2>' + _('Searching') + '</h2>').appendTo(this.out); -    this.dots = $('<span></span>').appendTo(this.title); -    this.status = $('<p class="search-summary"> </p>').appendTo(this.out); -    this.output = $('<ul class="search"/>').appendTo(this.out); - -    $('#search-progress').text(_('Preparing search...')); -    this.startPulse(); +    const searchText = document.createElement("h2"); +    searchText.textContent = _("Searching"); +    const searchSummary = document.createElement("p"); +    searchSummary.classList.add("search-summary"); +    searchSummary.innerText = ""; +    const searchList = document.createElement("ul"); +    searchList.classList.add("search"); + +    const out = document.getElementById("search-results"); +    Search.title = out.appendChild(searchText); +    Search.dots = Search.title.appendChild(document.createElement("span")); +    Search.status = out.appendChild(searchSummary); +    Search.output = out.appendChild(searchList); + +    const searchProgress = document.getElementById("search-progress"); +    // Some themes don't use the search progress node +    if (searchProgress) { +      searchProgress.innerText = _("Preparing search..."); +    } +    Search.startPulse();      // index already loaded, the browser was quick! -    if (this.hasIndex()) -      this.query(query); -    else -      this.deferQuery(query); +    if (Search.hasIndex()) Search.query(query); +    else Search.deferQuery(query);    },    /**     * execute search (requires search index to be loaded)     */ -  query : function(query) { -    var i; - -    // stem the searchterms and add them to the correct list -    var stemmer = new Stemmer(); -    var searchterms = []; -    var excluded = []; -    var hlterms = []; -    var tmp = splitQuery(query); -    var objectterms = []; -    for (i = 0; i < tmp.length; i++) { -      if (tmp[i] !== "") { -          objectterms.push(tmp[i].toLowerCase()); -      } +  query: (query) => { +    // stem the search terms and add them to the correct list +    const stemmer = new Stemmer(); +    const searchTerms = new Set(); +    const excludedTerms = new Set(); +    const highlightTerms = new Set(); +    const objectTerms = new Set(splitQuery(query.toLowerCase().trim())); +    splitQuery(query.trim()).forEach((queryTerm) => { +      const queryTermLower = queryTerm.toLowerCase(); + +      // maybe skip this "word" +      // stopwords array is from language_data.js +      if ( +        stopwords.indexOf(queryTermLower) !== -1 || +        queryTerm.match(/^\d+$/) +      ) +        return; -      if ($u.indexOf(stopwords, tmp[i].toLowerCase()) != -1 || tmp[i] === "") { -        // skip this "word" -        continue; -      }        // stem the word -      var word = stemmer.stemWord(tmp[i].toLowerCase()); -      var toAppend; +      let word = stemmer.stemWord(queryTermLower);        // select the correct list -      if (word[0] == '-') { -        toAppend = excluded; -        word = word.substr(1); -      } +      if (word[0] === "-") excludedTerms.add(word.substr(1));        else { -        toAppend = searchterms; -        hlterms.push(tmp[i].toLowerCase()); +        searchTerms.add(word); +        highlightTerms.add(queryTermLower);        } -      // only add if not already in the list -      if (!$u.contains(toAppend, word)) -        toAppend.push(word); -    } -    var highlightstring = '?highlight=' + $.urlencode(hlterms.join(" ")); - -    // console.debug('SEARCH: searching for:'); -    // console.info('required: ', searchterms); -    // console.info('excluded: ', excluded); +    }); -    // prepare search -    var terms = this._index.terms; -    var titleterms = this._index.titleterms; +    // console.debug("SEARCH: searching for:"); +    // console.info("required: ", [...searchTerms]); +    // console.info("excluded: ", [...excludedTerms]); -    // array of [filename, title, anchor, descr, score] -    var results = []; -    $('#search-progress').empty(); +    // array of [docname, title, anchor, descr, score, filename] +    let results = []; +    _removeChildren(document.getElementById("search-progress"));      // lookup as object -    for (i = 0; i < objectterms.length; i++) { -      var others = [].concat(objectterms.slice(0, i), -                             objectterms.slice(i+1, objectterms.length)); -      results = results.concat(this.performObjectSearch(objectterms[i], others)); -    } +    objectTerms.forEach((term) => +      results.push(...Search.performObjectSearch(term, objectTerms)) +    );      // lookup as search terms in fulltext -    results = results.concat(this.performTermsSearch(searchterms, excluded, terms, titleterms)); +    results.push(...Search.performTermsSearch(searchTerms, excludedTerms));      // let the scorer override scores with a custom scoring function -    if (Scorer.score) { -      for (i = 0; i < results.length; i++) -        results[i][4] = Scorer.score(results[i]); -    } +    if (Scorer.score) results.forEach((item) => (item[4] = Scorer.score(item)));      // now sort the results by score (in opposite order of appearance, since the      // display function below uses pop() to retrieve items) and then      // alphabetically -    results.sort(function(a, b) { -      var left = a[4]; -      var right = b[4]; -      if (left > right) { -        return 1; -      } else if (left < right) { -        return -1; -      } else { +    results.sort((a, b) => { +      const leftScore = a[4]; +      const rightScore = b[4]; +      if (leftScore === rightScore) {          // same score: sort alphabetically -        left = a[1].toLowerCase(); -        right = b[1].toLowerCase(); -        return (left > right) ? -1 : ((left < right) ? 1 : 0); +        const leftTitle = a[1].toLowerCase(); +        const rightTitle = b[1].toLowerCase(); +        if (leftTitle === rightTitle) return 0; +        return leftTitle > rightTitle ? -1 : 1; // inverted is intentional        } +      return leftScore > rightScore ? 1 : -1;      }); +    // remove duplicate search results +    // note the reversing of results, so that in the case of duplicates, the highest-scoring entry is kept +    let seen = new Set(); +    results = results.reverse().reduce((acc, result) => { +      let resultStr = result.slice(0, 4).concat([result[5]]).map(v => String(v)).join(','); +      if (!seen.has(resultStr)) { +        acc.push(result); +        seen.add(resultStr); +      } +      return acc; +    }, []); + +    results = results.reverse(); +      // for debugging      //Search.lastresults = results.slice();  // a copy -    //console.info('search results:', Search.lastresults); +    // console.info("search results:", Search.lastresults);      // print the results -    var resultCount = results.length; -    function displayNextItem() { -      // results left, load the summary and display it -      if (results.length) { -        var item = results.pop(); -        var listItem = $('<li></li>'); -        var requestUrl = ""; -        var linkUrl = ""; -        if (DOCUMENTATION_OPTIONS.BUILDER === 'dirhtml') { -          // dirhtml builder -          var dirname = item[0] + '/'; -          if (dirname.match(/\/index\/$/)) { -            dirname = dirname.substring(0, dirname.length-6); -          } else if (dirname == 'index/') { -            dirname = ''; -          } -          requestUrl = DOCUMENTATION_OPTIONS.URL_ROOT + dirname; -          linkUrl = requestUrl; - -        } else { -          // normal html builders -          requestUrl = DOCUMENTATION_OPTIONS.URL_ROOT + item[0] + DOCUMENTATION_OPTIONS.FILE_SUFFIX; -          linkUrl = item[0] + DOCUMENTATION_OPTIONS.LINK_SUFFIX; -        } -        listItem.append($('<a/>').attr('href', -            linkUrl + -            highlightstring + item[2]).html(item[1])); -        if (item[3]) { -          listItem.append($('<span> (' + item[3] + ')</span>')); -          Search.output.append(listItem); -          setTimeout(function() { -            displayNextItem(); -          }, 5); -        } else if (DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY) { -          $.ajax({url: requestUrl, -                  dataType: "text", -                  complete: function(jqxhr, textstatus) { -                    var data = jqxhr.responseText; -                    if (data !== '' && data !== undefined) { -                      var summary = Search.makeSearchSummary(data, searchterms, hlterms); -                      if (summary) { -                        listItem.append(summary); -                      } -                    } -                    Search.output.append(listItem); -                    setTimeout(function() { -                      displayNextItem(); -                    }, 5); -                  }}); -        } else { -          // just display title -          Search.output.append(listItem); -          setTimeout(function() { -            displayNextItem(); -          }, 5); -        } -      } -      // search finished, update title and status message -      else { -        Search.stopPulse(); -        Search.title.text(_('Search Results')); -        if (!resultCount) -          Search.status.text(_('Your search did not match any documents. Please make sure that all words are spelled correctly and that you\'ve selected enough categories.')); -        else -            Search.status.text(_('Search finished, found %s page(s) matching the search query.').replace('%s', resultCount)); -        Search.status.fadeIn(500); -      } -    } -    displayNextItem(); +    _displayNextItem(results, results.length, highlightTerms, searchTerms);    },    /**     * search for object names     */ -  performObjectSearch : function(object, otherterms) { -    var filenames = this._index.filenames; -    var docnames = this._index.docnames; -    var objects = this._index.objects; -    var objnames = this._index.objnames; -    var titles = this._index.titles; - -    var i; -    var results = []; - -    for (var prefix in objects) { -      for (var iMatch = 0; iMatch != objects[prefix].length; ++iMatch) { -        var match = objects[prefix][iMatch]; -        var name = match[4]; -        var fullname = (prefix ? prefix + '.' : '') + name; -        var fullnameLower = fullname.toLowerCase() -        if (fullnameLower.indexOf(object) > -1) { -          var score = 0; -          var parts = fullnameLower.split('.'); -          // check for different match types: exact matches of full name or -          // "last name" (i.e. last dotted part) -          if (fullnameLower == object || parts[parts.length - 1] == object) { -            score += Scorer.objNameMatch; -          // matches in last name -          } else if (parts[parts.length - 1].indexOf(object) > -1) { -            score += Scorer.objPartialMatch; -          } -          var objname = objnames[match[1]][2]; -          var title = titles[match[0]]; -          // If more than one term searched for, we require other words to be -          // found in the name/title/description -          if (otherterms.length > 0) { -            var haystack = (prefix + ' ' + name + ' ' + -                            objname + ' ' + title).toLowerCase(); -            var allfound = true; -            for (i = 0; i < otherterms.length; i++) { -              if (haystack.indexOf(otherterms[i]) == -1) { -                allfound = false; -                break; -              } -            } -            if (!allfound) { -              continue; -            } -          } -          var descr = objname + _(', in ') + title; - -          var anchor = match[3]; -          if (anchor === '') -            anchor = fullname; -          else if (anchor == '-') -            anchor = objnames[match[1]][1] + '-' + fullname; -          // add custom score for some objects according to scorer -          if (Scorer.objPrio.hasOwnProperty(match[2])) { -            score += Scorer.objPrio[match[2]]; -          } else { -            score += Scorer.objPrioDefault; -          } -          results.push([docnames[match[0]], fullname, '#'+anchor, descr, score, filenames[match[0]]]); -        } +  performObjectSearch: (object, objectTerms) => { +    const filenames = Search._index.filenames; +    const docNames = Search._index.docnames; +    const objects = Search._index.objects; +    const objNames = Search._index.objnames; +    const titles = Search._index.titles; + +    const results = []; + +    const objectSearchCallback = (prefix, match) => { +      const name = match[4] +      const fullname = (prefix ? prefix + "." : "") + name; +      const fullnameLower = fullname.toLowerCase(); +      if (fullnameLower.indexOf(object) < 0) return; + +      let score = 0; +      const parts = fullnameLower.split("."); + +      // check for different match types: exact matches of full name or +      // "last name" (i.e. last dotted part) +      if (fullnameLower === object || parts.slice(-1)[0] === object) +        score += Scorer.objNameMatch; +      else if (parts.slice(-1)[0].indexOf(object) > -1) +        score += Scorer.objPartialMatch; // matches in last name + +      const objName = objNames[match[1]][2]; +      const title = titles[match[0]]; + +      // If more than one term searched for, we require other words to be +      // found in the name/title/description +      const otherTerms = new Set(objectTerms); +      otherTerms.delete(object); +      if (otherTerms.size > 0) { +        const haystack = `${prefix} ${name} ${objName} ${title}`.toLowerCase(); +        if ( +          [...otherTerms].some((otherTerm) => haystack.indexOf(otherTerm) < 0) +        ) +          return;        } -    } +      let anchor = match[3]; +      if (anchor === "") anchor = fullname; +      else if (anchor === "-") anchor = objNames[match[1]][1] + "-" + fullname; + +      const descr = objName + _(", in ") + title; + +      // add custom score for some objects according to scorer +      if (Scorer.objPrio.hasOwnProperty(match[2])) +        score += Scorer.objPrio[match[2]]; +      else score += Scorer.objPrioDefault; + +      results.push([ +        docNames[match[0]], +        fullname, +        "#" + anchor, +        descr, +        score, +        filenames[match[0]], +      ]); +    }; +    Object.keys(objects).forEach((prefix) => +      objects[prefix].forEach((array) => +        objectSearchCallback(prefix, array) +      ) +    );      return results;    },    /** -   * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions -   */ -  escapeRegExp : function(string) { -    return string.replace(/[.*+\-?^${}()|[\]\\]/g, '\\$&'); // $& means the whole matched string -  }, - -  /**     * search for full-text terms in the index     */ -  performTermsSearch : function(searchterms, excluded, terms, titleterms) { -    var docnames = this._index.docnames; -    var filenames = this._index.filenames; -    var titles = this._index.titles; +  performTermsSearch: (searchTerms, excludedTerms) => { +    // prepare search +    const terms = Search._index.terms; +    const titleTerms = Search._index.titleterms; +    const docNames = Search._index.docnames; +    const filenames = Search._index.filenames; +    const titles = Search._index.titles; -    var i, j, file; -    var fileMap = {}; -    var scoreMap = {}; -    var results = []; +    const scoreMap = new Map(); +    const fileMap = new Map();      // perform the search on the required terms -    for (i = 0; i < searchterms.length; i++) { -      var word = searchterms[i]; -      var files = []; -      var _o = [ -        {files: terms[word], score: Scorer.term}, -        {files: titleterms[word], score: Scorer.title} +    searchTerms.forEach((word) => { +      const files = []; +      const arr = [ +        { files: terms[word], score: Scorer.term }, +        { files: titleTerms[word], score: Scorer.title },        ];        // add support for partial matches        if (word.length > 2) { -        var word_regex = this.escapeRegExp(word); -        for (var w in terms) { -          if (w.match(word_regex) && !terms[word]) { -            _o.push({files: terms[w], score: Scorer.partialTerm}) -          } -        } -        for (var w in titleterms) { -          if (w.match(word_regex) && !titleterms[word]) { -              _o.push({files: titleterms[w], score: Scorer.partialTitle}) -          } -        } +        const escapedWord = _escapeRegExp(word); +        Object.keys(terms).forEach((term) => { +          if (term.match(escapedWord) && !terms[word]) +            arr.push({ files: terms[term], score: Scorer.partialTerm }); +        }); +        Object.keys(titleTerms).forEach((term) => { +          if (term.match(escapedWord) && !titleTerms[word]) +            arr.push({ files: titleTerms[word], score: Scorer.partialTitle }); +        });        }        // no match but word was a required one -      if ($u.every(_o, function(o){return o.files === undefined;})) { -        break; -      } +      if (arr.every((record) => record.files === undefined)) return; +        // found search word in contents -      $u.each(_o, function(o) { -        var _files = o.files; -        if (_files === undefined) -          return - -        if (_files.length === undefined) -          _files = [_files]; -        files = files.concat(_files); - -        // set score for the word in each file to Scorer.term -        for (j = 0; j < _files.length; j++) { -          file = _files[j]; -          if (!(file in scoreMap)) -            scoreMap[file] = {}; -          scoreMap[file][word] = o.score; -        } +      arr.forEach((record) => { +        if (record.files === undefined) return; + +        let recordFiles = record.files; +        if (recordFiles.length === undefined) recordFiles = [recordFiles]; +        files.push(...recordFiles); + +        // set score for the word in each file +        recordFiles.forEach((file) => { +          if (!scoreMap.has(file)) scoreMap.set(file, {}); +          scoreMap.get(file)[word] = record.score; +        });        });        // create the mapping -      for (j = 0; j < files.length; j++) { -        file = files[j]; -        if (file in fileMap && fileMap[file].indexOf(word) === -1) -          fileMap[file].push(word); -        else -          fileMap[file] = [word]; -      } -    } +      files.forEach((file) => { +        if (fileMap.has(file) && fileMap.get(file).indexOf(word) === -1) +          fileMap.get(file).push(word); +        else fileMap.set(file, [word]); +      }); +    });      // now check if the files don't contain excluded terms -    for (file in fileMap) { -      var valid = true; - +    const results = []; +    for (const [file, wordList] of fileMap) {        // check if all requirements are matched -      var filteredTermCount = // as search terms with length < 3 are discarded: ignore -        searchterms.filter(function(term){return term.length > 2}).length + +      // as search terms with length < 3 are discarded +      const filteredTermCount = [...searchTerms].filter( +        (term) => term.length > 2 +      ).length;        if ( -        fileMap[file].length != searchterms.length && -        fileMap[file].length != filteredTermCount -      ) continue; +        wordList.length !== searchTerms.size && +        wordList.length !== filteredTermCount +      ) +        continue;        // ensure that none of the excluded terms is in the search result -      for (i = 0; i < excluded.length; i++) { -        if (terms[excluded[i]] == file || -            titleterms[excluded[i]] == file || -            $u.contains(terms[excluded[i]] || [], file) || -            $u.contains(titleterms[excluded[i]] || [], file)) { -          valid = false; -          break; -        } -      } +      if ( +        [...excludedTerms].some( +          (term) => +            terms[term] === file || +            titleTerms[term] === file || +            (terms[term] || []).includes(file) || +            (titleTerms[term] || []).includes(file) +        ) +      ) +        break; -      // if we have still a valid result we can add it to the result list -      if (valid) { -        // select one (max) score for the file. -        // for better ranking, we should calculate ranking by using words statistics like basic tf-idf... -        var score = $u.max($u.map(fileMap[file], function(w){return scoreMap[file][w]})); -        results.push([docnames[file], titles[file], '', null, score, filenames[file]]); -      } +      // select one (max) score for the file. +      const score = Math.max(...wordList.map((w) => scoreMap.get(file)[w])); +      // add result to the result list +      results.push([ +        docNames[file], +        titles[file], +        "", +        null, +        score, +        filenames[file], +      ]);      }      return results;    }, @@ -492,34 +499,33 @@ var Search = {    /**     * helper function to return a node containing the     * search summary for a given text. keywords is a list -   * of stemmed words, hlwords is the list of normal, unstemmed +   * of stemmed words, highlightWords is the list of normal, unstemmed     * words. the first one is used to find the occurrence, the     * latter for highlighting it.     */ -  makeSearchSummary : function(htmlText, keywords, hlwords) { -    var text = Search.htmlToText(htmlText); -    if (text == "") { -      return null; -    } -    var textLower = text.toLowerCase(); -    var start = 0; -    $.each(keywords, function() { -      var i = textLower.indexOf(this.toLowerCase()); -      if (i > -1) -        start = i; -    }); -    start = Math.max(start - 120, 0); -    var excerpt = ((start > 0) ? '...' : '') + -      $.trim(text.substr(start, 240)) + -      ((start + 240 - text.length) ? '...' : ''); -    var rv = $('<p class="context"></p>').text(excerpt); -    $.each(hlwords, function() { -      rv = rv.highlightText(this, 'highlighted'); -    }); -    return rv; -  } +  makeSearchSummary: (htmlText, keywords, highlightWords) => { +    const text = Search.htmlToText(htmlText).toLowerCase(); +    if (text === "") return null; + +    const actualStartPosition = [...keywords] +      .map((k) => text.indexOf(k.toLowerCase())) +      .filter((i) => i > -1) +      .slice(-1)[0]; +    const startWithContext = Math.max(actualStartPosition - 120, 0); + +    const top = startWithContext === 0 ? "" : "..."; +    const tail = startWithContext + 240 < text.length ? "..." : ""; + +    let summary = document.createElement("div"); +    summary.classList.add("context"); +    summary.innerText = top + text.substr(startWithContext, 240).trim() + tail; + +    highlightWords.forEach((highlightWord) => +      _highlightText(summary, highlightWord, "highlighted") +    ); + +    return summary; +  },  }; -$(document).ready(function() { -  Search.init(); -}); +_ready(Search.init); diff --git a/v7.1.1/changelog.html b/v7.1.1/changelog.html index 42006e37..5e8720c2 100644 --- a/v7.1.1/changelog.html +++ b/v7.1.1/changelog.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /><link rel="prev" title="site_api" href="output/botcore.site_api.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Changelog - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="changelog"> -<h1>Changelog<a class="headerlink" href="#changelog" title="Permalink to this headline">#</a></h1> +<h1>Changelog<a class="headerlink" href="#changelog" title="Permalink to this heading">#</a></h1>  <section id="Next 7.x feature release">  <h2 style="margin-bottom: 0.3em;"><a class="reference external" href="https://github.com/python-discord/bot-core/releases/tag/vmaster">Next 7.x feature release</a></h2><ul class="simple">  <li><p>[<span style="color: #4070A0;">Support</span>]<span> </span><a class="reference external" href="https://github.com/python-discord/bot-core/issues/79">#79</a><span>:</span> Restore on-site changelog.</p></li> @@ -468,6 +468,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.1/genindex.html b/v7.1.1/genindex.html index f76f72b8..3e0b188b 100644 --- a/v7.1.1/genindex.html +++ b/v7.1.1/genindex.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="#" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Index - Bot Core v7.1.1</title> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Index - Bot Core v7.1.1</title>  <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" /> @@ -700,6 +700,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.1/index.html b/v7.1.1/index.html index eae6fe03..69d5547e 100644 --- a/v7.1.1/index.html +++ b/v7.1.1/index.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /><link rel="next" title="Botcore" href="output/botcore.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,10 +271,10 @@          </div>          <article role="main">            <section id="bot-core-project-documentation"> -<h1>Bot Core Project Documentation<a class="headerlink" href="#bot-core-project-documentation" title="Permalink to this headline">#</a></h1> +<h1>Bot Core Project Documentation<a class="headerlink" href="#bot-core-project-documentation" title="Permalink to this heading">#</a></h1>  </section>  <section id="reference"> -<h1>Reference<a class="headerlink" href="#reference" title="Permalink to this headline">#</a></h1> +<h1>Reference<a class="headerlink" href="#reference" title="Permalink to this heading">#</a></h1>  <div class="toctree-wrapper compound">  <p class="caption" role="heading"><span class="caption-text">Modules:</span></p>  <ul> @@ -300,7 +300,7 @@  </div>  </section>  <section id="extras"> -<h1>Extras<a class="headerlink" href="#extras" title="Permalink to this headline">#</a></h1> +<h1>Extras<a class="headerlink" href="#extras" title="Permalink to this heading">#</a></h1>  <ul class="simple">  <li><p><a class="reference internal" href="genindex.html"><span class="std std-ref">Index</span></a></p></li>  <li><p><a class="reference internal" href="search.html"><span class="std std-ref">Search Page</span></a></p></li> @@ -353,6 +353,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.1/index_redirect.html b/v7.1.1/index_redirect.html index 739acee9..94231786 100644 --- a/v7.1.1/index_redirect.html +++ b/v7.1.1/index_redirect.html @@ -1,5 +1,5 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head>      <script>window.location.replace("./main/index.html")</script> @@ -7,7 +7,7 @@      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" /> @@ -57,6 +57,7 @@  <script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.1/output/botcore.async_stats.html b/v7.1.1/output/botcore.async_stats.html index 3743e897..8b22c09c 100644 --- a/v7.1.1/output/botcore.async_stats.html +++ b/v7.1.1/output/botcore.async_stats.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="site_api" href="botcore.site_api.html" /><link rel="prev" title="scheduling" href="botcore.utils.scheduling.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>async_stats - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,12 +271,12 @@          </div>          <article role="main">            <section id="module-botcore.async_stats"> -<span id="async-stats"></span><h1>async_stats<a class="headerlink" href="#module-botcore.async_stats" title="Permalink to this headline">#</a></h1> +<span id="async-stats"></span><h1>async_stats<a class="headerlink" href="#module-botcore.async_stats" title="Permalink to this heading">#</a></h1>  <p>An async transport method for statsd communication.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.async_stats.AsyncStatsClient">  <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">AsyncStatsClient</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">loop</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">host</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">'localhost'</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">port</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">8125</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">prefix</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/6659680429eec1dd0d45a6332a329a8b5e5a0d0b/botcore/async_stats.py#L12-L55"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.async_stats.AsyncStatsClient" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-class docutils literal notranslate"><span class="pre">statsd.client.base.StatsClientBase</span></code></a></p> +<dd><p>Bases: <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-class docutils literal notranslate"><span class="pre">StatsClientBase</span></code></a></p>  <p>An async implementation of <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">statsd.client.base.StatsClientBase</span></code></a> that supports async stat communication.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.async_stats.AsyncStatsClient.__init__"> @@ -364,6 +364,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.1/output/botcore.exts.html b/v7.1.1/output/botcore.exts.html index 54770c26..95a68398 100644 --- a/v7.1.1/output/botcore.exts.html +++ b/v7.1.1/output/botcore.exts.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Utils" href="botcore.utils.html" /><link rel="prev" title="Botcore" href="botcore.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Exts - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.exts"> -<span id="exts"></span><h1>Exts<a class="headerlink" href="#module-botcore.exts" title="Permalink to this headline">#</a></h1> +<span id="exts"></span><h1>Exts<a class="headerlink" href="#module-botcore.exts" title="Permalink to this heading">#</a></h1>  <p>Reusable Discord cogs.</p>  </section> @@ -329,6 +329,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.1/output/botcore.html b/v7.1.1/output/botcore.html index 00d400d2..34fa7be8 100644 --- a/v7.1.1/output/botcore.html +++ b/v7.1.1/output/botcore.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Exts" href="botcore.exts.html" /><link rel="prev" title="Bot Core Project Documentation" href="../index.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Botcore - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,12 +271,12 @@          </div>          <article role="main">            <section id="module-botcore"> -<span id="botcore"></span><h1>Botcore<a class="headerlink" href="#module-botcore" title="Permalink to this headline">#</a></h1> +<span id="botcore"></span><h1>Botcore<a class="headerlink" href="#module-botcore" title="Permalink to this heading">#</a></h1>  <p>Useful utilities and tools for Discord bot development.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.BotBase">  <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">BotBase</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">guild_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">allowed_roles</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">http_session</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">redis_session</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">api_client</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">statsd_url</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/6659680429eec1dd0d45a6332a329a8b5e5a0d0b/botcore/__init__.py#L36-L290"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Bot" title="(in discord.py v2.0.0a)"><code class="xref py py-class docutils literal notranslate"><span class="pre">discord.ext.commands.bot.Bot</span></code></a></p> +<dd><p>Bases: <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Bot" title="(in discord.py v2.0.0a)"><code class="xref py py-class docutils literal notranslate"><span class="pre">Bot</span></code></a></p>  <p>A sub-class that implements many common features that Python Discord bots use.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.__init__"> @@ -454,7 +454,7 @@ gateway event before giving up and thus not populating the cache for unavailable  </dd></dl>  <section id="subpackages"> -<h2>Subpackages<a class="headerlink" href="#subpackages" title="Permalink to this headline">#</a></h2> +<h2>Subpackages<a class="headerlink" href="#subpackages" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.exts.html">Exts</a></li> @@ -474,7 +474,7 @@ gateway event before giving up and thus not populating the cache for unavailable  </div>  </section>  <section id="submodules"> -<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this headline">#</a></h2> +<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.async_stats.html">async_stats</a></li> @@ -558,6 +558,7 @@ gateway event before giving up and thus not populating the cache for unavailable  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.1/output/botcore.site_api.html b/v7.1.1/output/botcore.site_api.html index 47c58db4..e3f7d10d 100644 --- a/v7.1.1/output/botcore.site_api.html +++ b/v7.1.1/output/botcore.site_api.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Changelog" href="../changelog.html" /><link rel="prev" title="async_stats" href="botcore.async_stats.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>site_api - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.site_api"> -<span id="site-api"></span><h1>site_api<a class="headerlink" href="#module-botcore.site_api" title="Permalink to this headline">#</a></h1> +<span id="site-api"></span><h1>site_api<a class="headerlink" href="#module-botcore.site_api" title="Permalink to this heading">#</a></h1>  <p>An API wrapper around the Site API.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.site_api.APIClient"> @@ -500,6 +500,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.1/output/botcore.utils.caching.html b/v7.1.1/output/botcore.utils.caching.html index db5430ee..daf9bb3d 100644 --- a/v7.1.1/output/botcore.utils.caching.html +++ b/v7.1.1/output/botcore.utils.caching.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="channel" href="botcore.utils.channel.html" /><link rel="prev" title="Utils" href="botcore.utils.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>caching - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.caching"> -<span id="caching"></span><h1>caching<a class="headerlink" href="#module-botcore.utils.caching" title="Permalink to this headline">#</a></h1> +<span id="caching"></span><h1>caching<a class="headerlink" href="#module-botcore.utils.caching" title="Permalink to this heading">#</a></h1>  <p>Utilities related to custom caches.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.caching.AsyncCache"> @@ -377,6 +377,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.1/output/botcore.utils.channel.html b/v7.1.1/output/botcore.utils.channel.html index 11095d8e..ad657666 100644 --- a/v7.1.1/output/botcore.utils.channel.html +++ b/v7.1.1/output/botcore.utils.channel.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="logging" href="botcore.utils.logging.html" /><link rel="prev" title="caching" href="botcore.utils.caching.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>channel - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.channel"> -<span id="channel"></span><h1>channel<a class="headerlink" href="#module-botcore.utils.channel" title="Permalink to this headline">#</a></h1> +<span id="channel"></span><h1>channel<a class="headerlink" href="#module-botcore.utils.channel" title="Permalink to this heading">#</a></h1>  <p>Useful helper functions for interacting with various discord channel objects.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.channel.get_or_fetch_channel"> @@ -377,6 +377,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.1/output/botcore.utils.html b/v7.1.1/output/botcore.utils.html index 5cf88d03..0fc54dca 100644 --- a/v7.1.1/output/botcore.utils.html +++ b/v7.1.1/output/botcore.utils.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="caching" href="botcore.utils.caching.html" /><link rel="prev" title="Exts" href="botcore.exts.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Utils - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils"> -<span id="utils"></span><h1>Utils<a class="headerlink" href="#module-botcore.utils" title="Permalink to this headline">#</a></h1> +<span id="utils"></span><h1>Utils<a class="headerlink" href="#module-botcore.utils" title="Permalink to this heading">#</a></h1>  <p>Useful utilities and tools for Discord bot development.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.apply_monkey_patches"> @@ -310,7 +310,7 @@ that will act as top-level groups rather than being aliases of the command’s g  </dd></dl>  <section id="submodules"> -<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this headline">#</a></h2> +<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.utils.caching.html">caching</a></li> @@ -397,6 +397,7 @@ that will act as top-level groups rather than being aliases of the command’s g  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.1/output/botcore.utils.logging.html b/v7.1.1/output/botcore.utils.logging.html index 20aec9c7..ea28c125 100644 --- a/v7.1.1/output/botcore.utils.logging.html +++ b/v7.1.1/output/botcore.utils.logging.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="members" href="botcore.utils.members.html" /><link rel="prev" title="channel" href="botcore.utils.channel.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>logging - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,12 +271,12 @@          </div>          <article role="main">            <section id="module-botcore.utils.logging"> -<span id="logging"></span><h1>logging<a class="headerlink" href="#module-botcore.utils.logging" title="Permalink to this headline">#</a></h1> +<span id="logging"></span><h1>logging<a class="headerlink" href="#module-botcore.utils.logging" title="Permalink to this heading">#</a></h1>  <p>Common logging related functions.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.logging.CustomLogger">  <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">CustomLogger</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">level</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">0</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/6659680429eec1dd0d45a6332a329a8b5e5a0d0b/botcore/utils/logging.py#L14-L33"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.logging.CustomLogger" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">logging.Logger</span></code></a></p> +<dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">Logger</span></code></a></p>  <p>Custom implementation of the <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">logging.Logger</span></code></a> class with an added <a class="reference internal" href="#botcore.utils.logging.CustomLogger.trace" title="botcore.utils.logging.CustomLogger.trace"><code class="xref py py-obj docutils literal notranslate"><span class="pre">trace</span></code></a> method.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.logging.CustomLogger.trace"> @@ -375,6 +375,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.1/output/botcore.utils.members.html b/v7.1.1/output/botcore.utils.members.html index 4a5bbbf5..f5c12754 100644 --- a/v7.1.1/output/botcore.utils.members.html +++ b/v7.1.1/output/botcore.utils.members.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="regex" href="botcore.utils.regex.html" /><link rel="prev" title="logging" href="botcore.utils.logging.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>members - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.members"> -<span id="members"></span><h1>members<a class="headerlink" href="#module-botcore.utils.members" title="Permalink to this headline">#</a></h1> +<span id="members"></span><h1>members<a class="headerlink" href="#module-botcore.utils.members" title="Permalink to this heading">#</a></h1>  <p>Useful helper functions for interactin with <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/api.html#discord.Member" title="(in discord.py v2.0.0a)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">discord.Member</span></code></a> objects.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.members.get_or_fetch_member"> @@ -362,6 +362,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.1/output/botcore.utils.regex.html b/v7.1.1/output/botcore.utils.regex.html index 42eab2d2..b334b2ee 100644 --- a/v7.1.1/output/botcore.utils.regex.html +++ b/v7.1.1/output/botcore.utils.regex.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="scheduling" href="botcore.utils.scheduling.html" /><link rel="prev" title="members" href="botcore.utils.members.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>regex - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.regex"> -<span id="regex"></span><h1>regex<a class="headerlink" href="#module-botcore.utils.regex" title="Permalink to this headline">#</a></h1> +<span id="regex"></span><h1>regex<a class="headerlink" href="#module-botcore.utils.regex" title="Permalink to this heading">#</a></h1>  <p>Common regular expressions.</p>  <dl class="py data">  <dt class="sig sig-object py" id="botcore.utils.regex.DISCORD_INVITE"> @@ -359,6 +359,7 @@ such as <a class="reference external" href="https://docs.python.org/3/library/ur  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.1/output/botcore.utils.scheduling.html b/v7.1.1/output/botcore.utils.scheduling.html index 73f25854..153e102e 100644 --- a/v7.1.1/output/botcore.utils.scheduling.html +++ b/v7.1.1/output/botcore.utils.scheduling.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="async_stats" href="botcore.async_stats.html" /><link rel="prev" title="regex" href="botcore.utils.regex.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>scheduling - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.scheduling"> -<span id="scheduling"></span><h1>scheduling<a class="headerlink" href="#module-botcore.utils.scheduling" title="Permalink to this headline">#</a></h1> +<span id="scheduling"></span><h1>scheduling<a class="headerlink" href="#module-botcore.utils.scheduling" title="Permalink to this heading">#</a></h1>  <p>Generic python scheduler.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.scheduling.Scheduler"> @@ -484,6 +484,7 @@ otherwise the running loop is used.</p>  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.1/py-modindex.html b/v7.1.1/py-modindex.html index a1b46030..ed64da32 100644 --- a/v7.1.1/py-modindex.html +++ b/v7.1.1/py-modindex.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Python Module Index - Bot Core v7.1.1</title> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Python Module Index - Bot Core v7.1.1</title>  <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" /> @@ -385,6 +385,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.1/search.html b/v7.1.1/search.html index 55d3228e..4fe03dff 100644 --- a/v7.1.1/search.html +++ b/v7.1.1/search.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="#" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Search - Bot Core v7.1.1</title><link rel="stylesheet" type="text/css" href="_static/pygments.css" /> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Search - Bot Core v7.1.1</title><link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" />      <link rel="stylesheet" type="text/css" href="_static/changelog.css" /> @@ -315,6 +315,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.1/searchindex.js b/v7.1.1/searchindex.js index 5141746f..35f6269d 100644 --- a/v7.1.1/searchindex.js +++ b/v7.1.1/searchindex.js @@ -1 +1 @@ -Search.setIndex({docnames:["changelog","index","output/botcore","output/botcore.async_stats","output/botcore.exts","output/botcore.site_api","output/botcore.utils","output/botcore.utils.caching","output/botcore.utils.channel","output/botcore.utils.logging","output/botcore.utils.members","output/botcore.utils.regex","output/botcore.utils.scheduling"],envversion:{"sphinx.domains.c":2,"sphinx.domains.changeset":1,"sphinx.domains.citation":1,"sphinx.domains.cpp":5,"sphinx.domains.index":1,"sphinx.domains.javascript":2,"sphinx.domains.math":2,"sphinx.domains.python":3,"sphinx.domains.rst":2,"sphinx.domains.std":2,"sphinx.ext.intersphinx":1,"sphinx.ext.todo":2,sphinx:56},filenames:["changelog.rst","index.rst","output/botcore.rst","output/botcore.async_stats.rst","output/botcore.exts.rst","output/botcore.site_api.rst","output/botcore.utils.rst","output/botcore.utils.caching.rst","output/botcore.utils.channel.rst","output/botcore.utils.logging.rst","output/botcore.utils.members.rst","output/botcore.utils.regex.rst","output/botcore.utils.scheduling.rst"],objects:{"":[[2,0,0,"-","botcore"]],"botcore.BotBase":[[2,2,1,"","__init__"],[2,2,1,"","add_cog"],[2,2,1,"","add_command"],[2,2,1,"","clear"],[2,2,1,"","close"],[2,2,1,"","load_extensions"],[2,2,1,"","log_to_dev_log"],[2,2,1,"","on_guild_available"],[2,2,1,"","on_guild_unavailable"],[2,2,1,"","ping_services"],[2,2,1,"","remove_command"],[2,2,1,"","setup_hook"],[2,2,1,"","wait_until_guild_available"]],"botcore.StartupError":[[2,2,1,"","__init__"]],"botcore.async_stats":[[3,1,1,"","AsyncStatsClient"]],"botcore.async_stats.AsyncStatsClient":[[3,2,1,"","__init__"],[3,2,1,"","create_socket"]],"botcore.site_api":[[5,1,1,"","APIClient"],[5,3,1,"","ResponseCodeError"]],"botcore.site_api.APIClient":[[5,2,1,"","__init__"],[5,2,1,"","close"],[5,2,1,"","delete"],[5,2,1,"","get"],[5,2,1,"","maybe_raise_for_status"],[5,2,1,"","patch"],[5,2,1,"","post"],[5,2,1,"","put"],[5,2,1,"","request"]],"botcore.site_api.ResponseCodeError":[[5,2,1,"","__init__"],[5,2,1,"","__str__"]],"botcore.utils":[[6,4,1,"","apply_monkey_patches"],[7,0,0,"-","caching"],[8,0,0,"-","channel"],[9,0,0,"-","logging"],[10,0,0,"-","members"],[11,0,0,"-","regex"],[12,0,0,"-","scheduling"],[6,4,1,"","unqualify"]],"botcore.utils.caching":[[7,1,1,"","AsyncCache"]],"botcore.utils.caching.AsyncCache":[[7,2,1,"","__call__"],[7,2,1,"","__init__"],[7,2,1,"","clear"]],"botcore.utils.channel":[[8,4,1,"","get_or_fetch_channel"],[8,4,1,"","is_in_category"]],"botcore.utils.logging":[[9,1,1,"","CustomLogger"],[9,4,1,"","get_logger"]],"botcore.utils.logging.CustomLogger":[[9,2,1,"","trace"]],"botcore.utils.members":[[10,4,1,"","get_or_fetch_member"],[10,4,1,"","handle_role_change"]],"botcore.utils.regex":[[11,5,1,"","DISCORD_INVITE"],[11,5,1,"","FORMATTED_CODE_REGEX"],[11,5,1,"","RAW_CODE_REGEX"]],"botcore.utils.scheduling":[[12,1,1,"","Scheduler"],[12,4,1,"","create_task"]],"botcore.utils.scheduling.Scheduler":[[12,2,1,"","__contains__"],[12,2,1,"","__init__"],[12,2,1,"","cancel"],[12,2,1,"","cancel_all"],[12,2,1,"","schedule"],[12,2,1,"","schedule_at"],[12,2,1,"","schedule_later"]],botcore:[[2,1,1,"","BotBase"],[2,3,1,"","StartupError"],[3,0,0,"-","async_stats"],[4,0,0,"-","exts"],[5,0,0,"-","site_api"],[6,0,0,"-","utils"]]},objnames:{"0":["py","module","Python module"],"1":["py","class","Python class"],"2":["py","method","Python method"],"3":["py","exception","Python exception"],"4":["py","function","Python function"],"5":["py","data","Python data"]},objtypes:{"0":"py:module","1":"py:class","2":"py:method","3":"py:exception","4":"py:function","5":"py:data"},terms:{"0":[0,7,9],"0a0":0,"1":[0,9],"10th":0,"12":0,"128":7,"14th":0,"17th":0,"18th":0,"19th":0,"2":[0,2],"2021":0,"2022":0,"204":5,"20th":0,"21st":0,"22nd":0,"24th":0,"25th":0,"26th":0,"29":0,"2nd":0,"3":0,"32":0,"34":0,"35":0,"37":0,"39":0,"3rd":0,"4":0,"403":6,"42":0,"4cbe8f5":0,"5":0,"54":0,"56":0,"5a06fa5":0,"5th":0,"6":0,"61":0,"63":0,"64":0,"65":0,"66":0,"68":0,"69":0,"7":0,"72":0,"75":0,"78":0,"79":0,"8125":3,"987235d":0,"9th":0,"abstract":0,"break":0,"case":0,"class":[0,2,3,5,7,9,12],"do":8,"float":12,"function":[0,2,7,8,9,10,12],"import":0,"int":[2,3,7,8,12],"long":12,"na\u00efv":12,"new":[3,5,7,12],"public":0,"return":[0,2,3,5,6,7,8,9,10,12],"true":[5,9,12],A:[2,5,6,7,8,12],If:[2,5,12],It:6,No:5,Not:2,The:[2,3,5,6,7,8,9,10,12],To:[2,9],_:0,__call__:7,__contains__:12,__init__:[0,2,3,5,7,12],__str__:5,_guild_avail:0,abstracteventloop:[3,12],act:6,actual:0,ad:[0,6,9],add:[0,2],add_cog:2,add_command:2,add_rol:10,after:12,aiohttp:[0,2,5],alia:[2,6],alias:[2,6],all:[0,2,3,6,12],all_command:2,all_extens:2,allow:[0,2],allowed_rol:2,alpha:0,alreadi:12,also:[0,6],an:[0,2,3,5,6,7,8,9,12],ani:[5,11,12],api:[0,5,10],api_cli:[0,2],apicli:[0,2,5],appear:2,appli:[6,7],apply_monkey_patch:[0,6],april:0,ar:[2,7,11],arg:[2,9],arg_offset:7,argument:[5,6,7,9,10],around:5,async:[0,2,3,5,7,8,10],async_rediscach:2,async_stat:[1,2],asynccach:7,asyncio:[0,3,12],asyncresolv:0,asyncstatscli:[2,3],asyncstatsdcli:0,attempt:[2,8,10],attribut:6,authent:5,autogener:0,avail:[0,2],avoid:[0,2],await:[10,12],awar:12,back:0,base:[0,2,3,5,7,9,12],basic:0,becaus:2,becom:2,befor:[0,2,12],behaviour:0,being:6,between:0,block:[0,11],bool:[5,8,12],bot:[0,2,6,8],botbas:[0,2],botcor:[0,1],broke:0,bug:0,bump:0,cach:[0,2,6,8,10],calcul:12,call:[2,12],callabl:[7,10],can:[0,12],cancel:12,cancel_al:12,cannot:[0,2],captur:[0,11],categori:8,category_id:8,caus:[2,6],chang:0,changelog:1,channel:[0,2,6],channel_id:8,charact:0,check:[5,8,12],chunk:0,ci:0,clear:[2,7],client:[0,2,3],clientrespons:5,clientsess:[2,5],close:[0,2,5,12],cloudflar:6,code:[0,11],cog:[0,2,4],command:[0,2,6,8],commit:0,common:[0,2,6,9,11],commun:3,connect:[0,2,3],connector:2,constructor:5,contain:12,content:5,core:0,coro:[10,12],coroutin:[7,10,12],correct:0,could:10,crash:0,creat:[0,2,3,7,12],create_datagram_endpoint:3,create_socket:[2,3],create_task:12,creation:0,current:12,custom:[0,7,9],customlogg:9,datetim:12,deadlock:2,deal:0,decemb:0,decor:7,delai:12,delet:[5,7],depend:8,deprec:0,detect:0,dev:2,develop:[2,6],dict:5,directli:0,discord:[0,2,4,6,8,10,11],discord_invit:11,disnak:0,distinguish:12,django:5,doc:0,document:0,doesn:12,don:[0,12],done:12,dummi:[0,2],dynam:0,each:0,edit:2,either:2,elsewher:12,emit:2,empti:2,endpoint:5,ensur:[2,11],entir:[0,2],equival:5,error:[2,5,6,10],event:[0,2,3,12],event_loop:12,exc_info:9,exce:7,except:[2,5,9,12],execut:12,exist:12,expect:10,express:11,ext:[0,1,2,6,8],extend:0,extens:[0,2],extra:5,fail:8,failur:10,featur:[0,2],februari:0,fetch:[8,10],fifo:7,fix:0,forbidden:8,format:11,formatted_code_regex:11,forum:0,found:[10,12],from:[0,2,3,5,6,8,10,12],futur:12,gatewai:2,gener:[2,12],get:[0,5,8,10],get_logg:9,get_or_fetch_channel:8,get_or_fetch_memb:10,give:2,given:[2,3,6,8,9,10,12],group:[6,11],guild:[0,2,10],guild_available_but_cache_empti:2,guild_creat:2,guild_id:2,guildchannel:8,ha:6,handl:[0,10,12],handle_role_chang:10,hashabl:12,have:[8,9],heavi:6,help:0,helper:[8,10],hook:0,host:3,houston:9,how:[7,12],http:[5,11],http_session:2,httpexcept:8,id:[2,8,12],identifi:12,ignor:6,immedi:12,implement:[2,3,7,9],inadequ:2,index:1,indic:10,individu:2,inform:[1,9],init:[0,2,3],initi:[5,12],initialis:[2,7],instanc:[0,2,5,7,8,9,12],instanti:[2,12],instead:[2,12],intend:10,interact:8,interactin:10,interest:9,intern:[2,6],intersphinx:0,invalid:8,invaliddata:8,invit:[0,11],is_in_categori:8,item:7,its:2,januari:0,json:5,keep:12,kei:7,keyword:[5,6,9],known:12,kwarg:[2,5,9,12],latest:0,level:[6,9],lint:0,list:2,ll:12,load:[0,2,6],load_extens:2,localhost:3,log:[0,2,6,12],log_to_dev_log:2,logger:[0,9],logic:0,longer:0,look:12,loop:[2,3,12],lot:0,lru:7,made:0,mai:[0,7],main:0,make:[0,9],mani:[0,2,7],manipul:0,manual:2,march:0,match:2,max_siz:7,maximum:7,maybe_raise_for_statu:5,member:[0,2,6],member_id:10,mention:2,messag:[2,9,12],method:[3,5,6,9],migrat:0,modul:[0,2,6,12],monkei:[0,6],move:0,msg:9,multivers:0,must:12,mypi:9,name:[2,6,9,12],namespac:[0,12],next:0,non:5,none:[2,3,5,6,7,9,10,12],normal:2,notabl:0,notfound:8,notic:0,novemb:0,now:[0,12],number:0,object:[5,6,7,8,10,12],offset:7,ok:5,older:0,on_guild_avail:2,on_guild_unavail:2,on_readi:2,onc:7,one:[0,2],onli:2,oper:[2,12],option:[2,3,5,7,9,10],order:[7,12],other:12,otherwis:12,our:[0,6],out:0,output:11,own:0,packag:[0,6],page:1,pagin:0,paramet:[2,3,5,6,7,8,9,10,12],pars:11,pass:[0,5,9,10,12],past:12,patch:[0,5,6],pattern:11,permiss:[0,8],ping:2,ping_servic:2,pleas:11,poetri:0,popul:2,port:[0,3],posit:7,post:5,prefix:3,prematur:12,prevent:12,problem:9,process:0,provid:[7,12],put:5,py:0,pyproject:0,python:[2,12],qualifi:6,quot:11,rais:[5,8,10,12],raise_for_statu:5,ran:2,rather:6,raw:11,raw_code_regex:11,re:[2,12],readi:2,real:0,receiv:[5,8],recognis:9,reconnect:0,redi:0,redis_sess:2,redissess:2,refer:0,regex:[0,2,6],regular:11,relat:[7,9],releas:0,remov:[0,2],remove_command:2,remove_rol:10,repo:0,represent:5,request:[5,11],request_text:5,requir:[2,12],resolut:0,resolv:2,respons:5,response_json:5,response_text:5,responsecodeerror:5,restor:0,result:[0,12],retriev:8,reusabl:4,revert:0,role:[2,10],root:[2,6],root_alias:6,rout:6,run:12,s:[0,6,7,9,11,12],safe:0,same:12,sanitis:11,save:2,schedul:[0,2,6],schedule_at:12,schedule_lat:12,search:1,second:[2,12],self:2,send:5,send_typ:6,sequenc:6,server:[2,11],servic:2,session:[0,2,5],session_kwarg:5,set:2,setup:[0,2],setup_hook:2,sever:9,share:0,should:[0,2,5],should_rais:5,similar:11,singl:0,site:[0,5],site_api:[0,1,2],site_api_token:5,site_api_url:5,size:7,so:[0,6],socket:3,sole:10,someth:11,sourc:[2,3,5,6,7,8,9,10,11,12],specifi:0,sphinx:0,start:[0,2,12],startup:2,startuperror:2,stat:3,statsclientbas:3,statsd:[0,2,3],statsd_url:[0,2],still:2,store:[6,7],str:[2,3,5,6,9,12],string:5,sub:[0,2],submodul:1,subpackag:1,subtract:12,suggest:12,support:[0,3,6,12],suppressed_except:12,t:[0,12],target:7,task:[0,2,12],task_id:12,text:5,textchannel:8,than:6,thei:2,them:[2,12],thi:[0,2,6,8,10,11,12],thrown:6,thu:2,time:[0,12],timeout:0,timezon:12,token:5,toml:0,tool:[2,6],top:6,trace:[0,9],track:12,transport:3,tupl:12,two:6,type:[2,3,5,6,7,8,9,10,12],unavail:2,unawait:12,under:6,union:12,uniqu:12,unknown:8,unqualifi:[0,6],unschedul:12,until:[2,11],up:[0,2],url:[0,2,5],urllib:11,us:[0,2,3,5,6,8,9,10,11,12],utc:12,util:[0,1,2,7,9],valu:9,valueerror:5,variou:8,version:0,wa:[8,12],wait:[2,12],wait_for:2,wait_until_guild_avail:2,warn:12,we:[9,10],when:[0,2,3,5,6,7,12],whether:[5,8],which:[0,6,12],whitespac:[0,11],within:[0,2],work:0,worker:6,wrap:[7,12],wrapper:[0,5,12],x:0,you:[8,11]},titles:["Changelog","Bot Core Project Documentation","Botcore","async_stats","Exts","site_api","Utils","caching","channel","logging","members","regex","scheduling"],titleterms:{async_stat:3,bot:1,botcor:2,cach:7,changelog:0,channel:8,core:1,document:1,ext:4,extra:1,log:9,member:10,modul:1,project:1,refer:1,regex:11,schedul:12,site_api:5,submodul:[2,6],subpackag:2,util:6}})
\ No newline at end of file +Search.setIndex({"docnames": ["changelog", "index", "output/botcore", "output/botcore.async_stats", "output/botcore.exts", "output/botcore.site_api", "output/botcore.utils", "output/botcore.utils.caching", "output/botcore.utils.channel", "output/botcore.utils.logging", "output/botcore.utils.members", "output/botcore.utils.regex", "output/botcore.utils.scheduling"], "filenames": ["changelog.rst", "index.rst", "output/botcore.rst", "output/botcore.async_stats.rst", "output/botcore.exts.rst", "output/botcore.site_api.rst", "output/botcore.utils.rst", "output/botcore.utils.caching.rst", "output/botcore.utils.channel.rst", "output/botcore.utils.logging.rst", "output/botcore.utils.members.rst", "output/botcore.utils.regex.rst", "output/botcore.utils.scheduling.rst"], "titles": ["Changelog", "Bot Core Project Documentation", "Botcore", "async_stats", "Exts", "site_api", "Utils", "caching", "channel", "logging", "members", "regex", "scheduling"], "terms": {"next": 0, "7": 0, "x": 0, "featur": [0, 2], "releas": 0, "support": [0, 3, 6, 12], "79": 0, "restor": 0, "site": [0, 5], "add": [0, 2], "sphinx": 0, "multivers": 0, "make": [0, 9], "avail": [0, 2], "older": 0, "doc": 0, "version": 0, "1": [0, 9], "0": [0, 7, 9], "24th": 0, "mai": [0, 7], "2022": 0, "78": 0, "bump": 0, "discord": [0, 2, 4, 6, 8, 10, 11], "py": 0, "4cbe8f5": 0, "thi": [0, 2, 6, 8, 10, 11, 12], "fix": 0, "bug": 0, "permiss": [0, 8], "resolut": 0, "when": [0, 2, 3, 5, 6, 7, 12], "deal": 0, "time": [0, 12], "out": 0, "member": [0, 2, 6], "10th": 0, "break": 0, "75": 0, "invit": [0, 11], "regex": [0, 2, 6], "longer": 0, "return": [0, 2, 3, 5, 6, 7, 8, 9, 10, 12], "url": [0, 2, 5], "safe": 0, "result": [0, 12], "refer": 0, "document": 0, "handl": [0, 10, 12], "captur": [0, 11], "all": [0, 2, 3, 6, 12], "charact": 0, "up": [0, 2], "whitespac": [0, 11], "6": 0, "4": 0, "26th": 0, "april": 0, "72": 0, "5a06fa5": 0, "notabl": 0, "one": [0, 2], "commit": 0, "dynam": 0, "extend": 0, "timeout": 0, "guild": [0, 2, 10], "chunk": 0, "base": [0, 2, 3, 5, 7, 9, 12], "number": 0, "so": [0, 6], "should": [0, 2, 5], "actual": 0, "work": 0, "our": [0, 6], "now": [0, 12], "3": 0, "2": [0, 2], "25th": 0, "69": 0, "us": [0, 2, 3, 5, 6, 8, 9, 10, 11, 12], "statsd_url": [0, 2], "get": [0, 5, 8, 10], "pass": [0, 5, 9, 10, 12], "botbas": [0, 2], "21st": 0, "68": 0, "correct": 0, "pyproject": 0, "toml": 0, "directli": 0, "main": 0, "don": [0, 12], "t": [0, 12], "load": [0, 2, 6], "modul": [0, 2, 6, 12], "start": [0, 2, 12], "_": 0, "66": 0, "each": 0, "cog": [0, 2, 4], "s": [0, 6, 7, 9, 11, 12], "own": 0, "task": [0, 2, 12], "avoid": [0, 2], "singl": 0, "crash": 0, "entir": [0, 2], "process": 0, "20th": 0, "65": 0, "unqualifi": [0, 6], "botcor": [0, 1], "util": [0, 1, 2, 7, 9], "namespac": [0, 12], "bot": [0, 2, 6, 8], "manipul": 0, "extens": [0, 2], "19th": 0, "64": 0, "987235d": 0, "revert": 0, "chang": 0, "help": 0, "command": [0, 2, 6, 8], "behaviour": 0, "broke": 0, "custom": [0, 7, 9], "pagin": 0, "also": [0, 6], "basic": 0, "forum": 0, "channel": [0, 2, 6], "5": 0, "18th": 0, "63": 0, "allow": [0, 2], "an": [0, 2, 3, 5, 6, 7, 8, 9, 12], "api_cli": [0, 2], "__init__": [0, 2, 3, 5, 7, 12], "specifi": 0, "site_api": [0, 1, 2], "apicli": [0, 2, 5], "instanc": [0, 2, 5, 7, 8, 9, 12], "61": 0, "reconnect": 0, "redi": 0, "session": [0, 2, 5], "setup": [0, 2], "close": [0, 2, 5, 12], "5th": 0, "56": 0, "move": 0, "creation": 0, "asyncio": [0, 3, 12], "event": [0, 2, 3, 12], "_guild_avail": 0, "within": [0, 2], "hook": 0, "deprec": 0, "notic": 0, "creat": [0, 2, 3, 7, 12], "dummi": [0, 2], "asyncstatsdcli": 0, "befor": [0, 2, 12], "connect": [0, 2, 3], "real": 0, "case": 0, "cannot": [0, 2], "made": 0, "init": [0, 2, 3], "2nd": 0, "54": 0, "aiohttp": [0, 2, 5], "asyncresolv": 0, "async": [0, 2, 3, 5, 7, 8, 10], "42": 0, "remov": [0, 2], "public": 0, "statsd": [0, 2, 3], "client": [0, 2, 3], "ext": [0, 1, 2, 6, 8], "sub": [0, 2], "class": [0, 2, 3, 5, 7, 9, 12], "which": [0, 6, 12], "abstract": 0, "lot": 0, "logic": 0, "share": 0, "between": 0, "latest": 0, "alpha": 0, "14th": 0, "march": 0, "39": 0, "migrat": 0, "back": 0, "37": 0, "log": [0, 2, 6, 12], "trace": [0, 9], "import": 0, "can": [0, 12], "function": [0, 2, 7, 8, 9, 10, 12], "3rd": 0, "35": 0, "apply_monkey_patch": [0, 6], "februari": 0, "34": 0, "port": [0, 3], "api": [0, 5, 10], "wrapper": [0, 5, 12], "from": [0, 2, 3, 5, 6, 8, 10, 12], "repo": 0, "22nd": 0, "32": 0, "0a0": 0, "disnak": 0, "29": 0, "mani": [0, 2, 7], "common": [0, 2, 6, 9, 11], "cach": [0, 2, 6, 8, 10], "logger": [0, 9], "schedul": [0, 2, 6], "monkei": [0, 6], "patch": [0, 5, 6], "ad": [0, 6, 9], "intersphinx": 0, "9th": 0, "januari": 0, "12": 0, "code": [0, 11], "block": [0, 11], "detect": 0, "decemb": 0, "2021": 0, "autogener": 0, "17th": 0, "novemb": 0, "core": 0, "packag": [0, 6], "poetri": 0, "lint": 0, "ci": 0, "subpackag": 1, "submodul": 1, "async_stat": [1, 2], "index": 1, "search": 1, "page": 1, "inform": [1, 9], "changelog": 1, "tool": [2, 6], "develop": [2, 6], "arg": [2, 9], "guild_id": 2, "allowed_rol": 2, "http_session": 2, "redis_sess": 2, "none": [2, 3, 5, 6, 7, 9, 10, 12], "kwarg": [2, 5, 9, 12], "sourc": [2, 3, 5, 6, 7, 8, 9, 10, 11, 12], "A": [2, 5, 6, 7, 8, 12], "implement": [2, 3, 7, 9], "python": [2, 12], "initialis": [2, 7], "paramet": [2, 3, 5, 6, 7, 8, 9, 10, 12], "int": [2, 3, 7, 8, 12], "The": [2, 3, 5, 6, 7, 8, 9, 10, 12], "id": [2, 8, 12], "wait_until_guild_avail": 2, "list": 2, "role": [2, 10], "mention": 2, "clientsess": [2, 5], "option": [2, 3, 5, 7, 9, 10], "redissess": 2, "async_rediscach": 2, "str": [2, 3, 5, 6, 9, 12], "server": [2, 11], "If": [2, 5, 12], "given": [2, 3, 6, 8, 9, 10, 12], "add_cog": 2, "oper": [2, 12], "type": [2, 3, 5, 6, 7, 8, 9, 10, 12], "add_command": 2, "normal": 2, "its": 2, "root": [2, 6], "alias": [2, 6], "clear": [2, 7], "Not": 2, "re": [2, 12], "instanti": [2, 12], "instead": [2, 12], "attempt": [2, 8, 10], "connector": 2, "resolv": 2, "load_extens": 2, "save": 2, "them": [2, 12], "self": 2, "all_extens": 2, "ran": 2, "loop": [2, 3, 12], "deadlock": 2, "caus": [2, 6], "wait_for": 2, "call": [2, 12], "log_to_dev_log": 2, "messag": [2, 9, 12], "dev": 2, "on_guild_avail": 2, "set": 2, "intern": [2, 6], "becom": 2, "appear": 2, "still": 2, "empti": 2, "guild_available_but_cache_empti": 2, "emit": 2, "on_guild_unavail": 2, "unavail": 2, "ping_servic": 2, "ping": 2, "requir": [2, 12], "servic": 2, "ensur": [2, 11], "thei": 2, "ar": [2, 7, 11], "remove_command": 2, "name": [2, 6, 9, 12], "alia": [2, 6], "individu": 2, "To": [2, 9], "either": 2, "manual": 2, "edit": 2, "all_command": 2, "setup_hook": 2, "startup": 2, "gener": [2, 12], "asyncstatscli": [2, 3], "create_socket": [2, 3], "wait": [2, 12], "until": [2, 11], "match": 2, "readi": 2, "on_readi": 2, "inadequ": 2, "becaus": 2, "onli": 2, "second": [2, 12], "guild_creat": 2, "gatewai": 2, "give": 2, "thu": 2, "popul": 2, "except": [2, 5, 9, 12], "startuperror": 2, "error": [2, 5, 6, 10], "transport": 3, "method": [3, 5, 6, 9], "commun": 3, "host": 3, "localhost": 3, "8125": 3, "prefix": 3, "statsclientbas": 3, "stat": 3, "new": [3, 5, 7, 12], "abstracteventloop": [3, 12], "create_datagram_endpoint": 3, "socket": 3, "reusabl": 4, "around": 5, "site_api_url": 5, "site_api_token": 5, "session_kwarg": 5, "object": [5, 6, 7, 8, 10, 12], "django": 5, "initi": [5, 12], "token": 5, "authent": 5, "keyword": [5, 6, 9], "argument": [5, 6, 7, 9, 10], "constructor": 5, "delet": [5, 7], "endpoint": 5, "raise_for_statu": 5, "true": [5, 9, 12], "send": 5, "request": [5, 11], "json": 5, "respons": 5, "bool": [5, 8, 12], "whether": [5, 8], "rais": [5, 8, 10, 12], "ok": 5, "ani": [5, 11, 12], "extra": 5, "dict": 5, "204": 5, "No": 5, "content": 5, "equival": 5, "maybe_raise_for_statu": 5, "should_rais": 5, "responsecodeerror": 5, "non": 5, "clientrespons": 5, "check": [5, 8, 12], "post": 5, "put": 5, "http": [5, 11], "response_json": 5, "response_text": 5, "valueerror": 5, "receiv": [5, 8], "request_text": 5, "text": 5, "__str__": 5, "string": 5, "represent": 5, "appli": [6, 7], "group": [6, 11], "root_alias": 6, "two": 6, "sequenc": 6, "act": 6, "top": 6, "level": [6, 9], "rather": 6, "than": 6, "being": 6, "It": 6, "store": [6, 7], "attribut": 6, "send_typ": 6, "ignor": 6, "403": 6, "under": 6, "heavi": 6, "ha": 6, "cloudflar": 6, "worker": 6, "rout": 6, "thrown": 6, "qualifi": 6, "relat": [7, 9], "asynccach": 7, "max_siz": 7, "128": 7, "lru": 7, "coroutin": [7, 10, 12], "onc": 7, "exce": 7, "maximum": 7, "size": 7, "kei": 7, "fifo": 7, "order": [7, 12], "offset": 7, "provid": [7, 12], "__call__": 7, "arg_offset": 7, "decor": 7, "posit": 7, "callabl": [7, 10], "wrap": [7, 12], "target": 7, "how": [7, 12], "item": 7, "helper": [8, 10], "interact": 8, "variou": 8, "get_or_fetch_channel": 8, "channel_id": 8, "fetch": [8, 10], "invaliddata": 8, "unknown": 8, "wa": [8, 12], "httpexcept": 8, "retriev": 8, "fail": 8, "notfound": 8, "invalid": 8, "forbidden": 8, "you": [8, 11], "do": 8, "have": [8, 9], "guildchannel": 8, "is_in_categori": 8, "category_id": 8, "categori": 8, "textchannel": 8, "depend": 8, "customlogg": 9, "msg": 9, "sever": 9, "exc_info": 9, "valu": 9, "houston": 9, "we": [9, 10], "interest": 9, "problem": 9, "get_logg": 9, "mypi": 9, "recognis": 9, "interactin": 10, "get_or_fetch_memb": 10, "member_id": 10, "failur": 10, "indic": 10, "could": 10, "found": [10, 12], "handle_role_chang": 10, "coro": [10, 12], "await": [10, 12], "sole": 10, "expect": 10, "add_rol": 10, "remove_rol": 10, "intend": 10, "regular": 11, "express": 11, "discord_invit": 11, "pattern": 11, "similar": 11, "pleas": 11, "sanitis": 11, "output": 11, "someth": 11, "urllib": 11, "pars": 11, "quot": 11, "formatted_code_regex": 11, "format": 11, "raw_code_regex": 11, "raw": 11, "execut": 12, "keep": 12, "track": 12, "must": 12, "distinguish": 12, "other": 12, "contain": 12, "suggest": 12, "immedi": 12, "futur": 12, "schedule_at": 12, "schedule_lat": 12, "uniqu": 12, "cancel": 12, "prematur": 12, "same": 12, "current": 12, "done": 12, "__contains__": 12, "task_id": 12, "hashabl": 12, "look": 12, "unschedul": 12, "identifi": 12, "warn": 12, "doesn": 12, "exist": 12, "cancel_al": 12, "known": 12, "alreadi": 12, "prevent": 12, "unawait": 12, "ll": 12, "elsewher": 12, "timezon": 12, "awar": 12, "calcul": 12, "subtract": 12, "na\u00efv": 12, "utc": 12, "past": 12, "datetim": 12, "delai": 12, "after": 12, "union": 12, "float": 12, "long": 12, "create_task": 12, "suppressed_except": 12, "event_loop": 12, "otherwis": 12, "run": 12, "tupl": 12}, "objects": {"": [[2, 0, 0, "-", "botcore"]], "botcore": [[2, 1, 1, "", "BotBase"], [2, 3, 1, "", "StartupError"], [3, 0, 0, "-", "async_stats"], [4, 0, 0, "-", "exts"], [5, 0, 0, "-", "site_api"], [6, 0, 0, "-", "utils"]], "botcore.BotBase": [[2, 2, 1, "", "__init__"], [2, 2, 1, "", "add_cog"], [2, 2, 1, "", "add_command"], [2, 2, 1, "", "clear"], [2, 2, 1, "", "close"], [2, 2, 1, "", "load_extensions"], [2, 2, 1, "", "log_to_dev_log"], [2, 2, 1, "", "on_guild_available"], [2, 2, 1, "", "on_guild_unavailable"], [2, 2, 1, "", "ping_services"], [2, 2, 1, "", "remove_command"], [2, 2, 1, "", "setup_hook"], [2, 2, 1, "", "wait_until_guild_available"]], "botcore.StartupError": [[2, 2, 1, "", "__init__"]], "botcore.async_stats": [[3, 1, 1, "", "AsyncStatsClient"]], "botcore.async_stats.AsyncStatsClient": [[3, 2, 1, "", "__init__"], [3, 2, 1, "", "create_socket"]], "botcore.site_api": [[5, 1, 1, "", "APIClient"], [5, 3, 1, "", "ResponseCodeError"]], "botcore.site_api.APIClient": [[5, 2, 1, "", "__init__"], [5, 2, 1, "", "close"], [5, 2, 1, "", "delete"], [5, 2, 1, "", "get"], [5, 2, 1, "", "maybe_raise_for_status"], [5, 2, 1, "", "patch"], [5, 2, 1, "", "post"], [5, 2, 1, "", "put"], [5, 2, 1, "", "request"]], "botcore.site_api.ResponseCodeError": [[5, 2, 1, "", "__init__"], [5, 2, 1, "", "__str__"]], "botcore.utils": [[6, 4, 1, "", "apply_monkey_patches"], [7, 0, 0, "-", "caching"], [8, 0, 0, "-", "channel"], [9, 0, 0, "-", "logging"], [10, 0, 0, "-", "members"], [11, 0, 0, "-", "regex"], [12, 0, 0, "-", "scheduling"], [6, 4, 1, "", "unqualify"]], "botcore.utils.caching": [[7, 1, 1, "", "AsyncCache"]], "botcore.utils.caching.AsyncCache": [[7, 2, 1, "", "__call__"], [7, 2, 1, "", "__init__"], [7, 2, 1, "", "clear"]], "botcore.utils.channel": [[8, 4, 1, "", "get_or_fetch_channel"], [8, 4, 1, "", "is_in_category"]], "botcore.utils.logging": [[9, 1, 1, "", "CustomLogger"], [9, 4, 1, "", "get_logger"]], "botcore.utils.logging.CustomLogger": [[9, 2, 1, "", "trace"]], "botcore.utils.members": [[10, 4, 1, "", "get_or_fetch_member"], [10, 4, 1, "", "handle_role_change"]], "botcore.utils.regex": [[11, 5, 1, "", "DISCORD_INVITE"], [11, 5, 1, "", "FORMATTED_CODE_REGEX"], [11, 5, 1, "", "RAW_CODE_REGEX"]], "botcore.utils.scheduling": [[12, 1, 1, "", "Scheduler"], [12, 4, 1, "", "create_task"]], "botcore.utils.scheduling.Scheduler": [[12, 2, 1, "", "__contains__"], [12, 2, 1, "", "__init__"], [12, 2, 1, "", "cancel"], [12, 2, 1, "", "cancel_all"], [12, 2, 1, "", "schedule"], [12, 2, 1, "", "schedule_at"], [12, 2, 1, "", "schedule_later"]]}, "objtypes": {"0": "py:module", "1": "py:class", "2": "py:method", "3": "py:exception", "4": "py:function", "5": "py:data"}, "objnames": {"0": ["py", "module", "Python module"], "1": ["py", "class", "Python class"], "2": ["py", "method", "Python method"], "3": ["py", "exception", "Python exception"], "4": ["py", "function", "Python function"], "5": ["py", "data", "Python data"]}, "titleterms": {"changelog": 0, "bot": 1, "core": 1, "project": 1, "document": 1, "refer": 1, "modul": 1, "extra": 1, "botcor": 2, "subpackag": 2, "submodul": [2, 6], "async_stat": 3, "ext": 4, "site_api": 5, "util": 6, "cach": 7, "channel": 8, "log": 9, "member": 10, "regex": 11, "schedul": 12}, "envversion": {"sphinx.domains.c": 2, "sphinx.domains.changeset": 1, "sphinx.domains.citation": 1, "sphinx.domains.cpp": 6, "sphinx.domains.index": 1, "sphinx.domains.javascript": 2, "sphinx.domains.math": 2, "sphinx.domains.python": 3, "sphinx.domains.rst": 2, "sphinx.domains.std": 2, "sphinx.ext.intersphinx": 1, "sphinx.ext.todo": 2, "sphinx": 56}})
\ No newline at end of file diff --git a/v7.1.1/versions.html b/v7.1.1/versions.html index 1b2d9baf..4da77a9d 100644 --- a/v7.1.1/versions.html +++ b/v7.1.1/versions.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Versions - Bot Core v7.1.1</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -339,6 +339,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.2/.buildinfo b/v7.1.2/.buildinfo index daca605d..f1c76abb 100644 --- a/v7.1.2/.buildinfo +++ b/v7.1.2/.buildinfo @@ -1,4 +1,4 @@  # 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: f0bbf9a24db8c4cbc8a2218127d856e2 +config: 73d33c619b26bb1a372924abc4921fa8  tags: 645f666f9bcd5a90fca523b33c5a78b7 diff --git a/v7.1.2/.doctrees/changelog.doctree b/v7.1.2/.doctrees/changelog.doctree Binary files differindex a9887f3c..4d6a9960 100644 --- a/v7.1.2/.doctrees/changelog.doctree +++ b/v7.1.2/.doctrees/changelog.doctree diff --git a/v7.1.2/.doctrees/environment.pickle b/v7.1.2/.doctrees/environment.pickle Binary files differindex 601853a3..2f1316f8 100644 --- a/v7.1.2/.doctrees/environment.pickle +++ b/v7.1.2/.doctrees/environment.pickle diff --git a/v7.1.2/.doctrees/index.doctree b/v7.1.2/.doctrees/index.doctree Binary files differindex 55b0dff0..b1bb569d 100644 --- a/v7.1.2/.doctrees/index.doctree +++ b/v7.1.2/.doctrees/index.doctree diff --git a/v7.1.2/.doctrees/output/botcore.async_stats.doctree b/v7.1.2/.doctrees/output/botcore.async_stats.doctree Binary files differindex 91336044..7df23801 100644 --- a/v7.1.2/.doctrees/output/botcore.async_stats.doctree +++ b/v7.1.2/.doctrees/output/botcore.async_stats.doctree diff --git a/v7.1.2/.doctrees/output/botcore.doctree b/v7.1.2/.doctrees/output/botcore.doctree Binary files differindex 258e6a42..ce190c74 100644 --- a/v7.1.2/.doctrees/output/botcore.doctree +++ b/v7.1.2/.doctrees/output/botcore.doctree diff --git a/v7.1.2/.doctrees/output/botcore.exts.doctree b/v7.1.2/.doctrees/output/botcore.exts.doctree Binary files differindex 1bd02fd7..eb5c8dea 100644 --- a/v7.1.2/.doctrees/output/botcore.exts.doctree +++ b/v7.1.2/.doctrees/output/botcore.exts.doctree diff --git a/v7.1.2/.doctrees/output/botcore.site_api.doctree b/v7.1.2/.doctrees/output/botcore.site_api.doctree Binary files differindex 3b4d5741..31ed544f 100644 --- a/v7.1.2/.doctrees/output/botcore.site_api.doctree +++ b/v7.1.2/.doctrees/output/botcore.site_api.doctree diff --git a/v7.1.2/.doctrees/output/botcore.utils.caching.doctree b/v7.1.2/.doctrees/output/botcore.utils.caching.doctree Binary files differindex 6f7fa48f..1beca51c 100644 --- a/v7.1.2/.doctrees/output/botcore.utils.caching.doctree +++ b/v7.1.2/.doctrees/output/botcore.utils.caching.doctree diff --git a/v7.1.2/.doctrees/output/botcore.utils.channel.doctree b/v7.1.2/.doctrees/output/botcore.utils.channel.doctree Binary files differindex 0787af70..47c701de 100644 --- a/v7.1.2/.doctrees/output/botcore.utils.channel.doctree +++ b/v7.1.2/.doctrees/output/botcore.utils.channel.doctree diff --git a/v7.1.2/.doctrees/output/botcore.utils.doctree b/v7.1.2/.doctrees/output/botcore.utils.doctree Binary files differindex 49ce07a2..22635af7 100644 --- a/v7.1.2/.doctrees/output/botcore.utils.doctree +++ b/v7.1.2/.doctrees/output/botcore.utils.doctree diff --git a/v7.1.2/.doctrees/output/botcore.utils.logging.doctree b/v7.1.2/.doctrees/output/botcore.utils.logging.doctree Binary files differindex 94b569fa..c6d302f9 100644 --- a/v7.1.2/.doctrees/output/botcore.utils.logging.doctree +++ b/v7.1.2/.doctrees/output/botcore.utils.logging.doctree diff --git a/v7.1.2/.doctrees/output/botcore.utils.members.doctree b/v7.1.2/.doctrees/output/botcore.utils.members.doctree Binary files differindex 37aabfdf..d4207b9c 100644 --- a/v7.1.2/.doctrees/output/botcore.utils.members.doctree +++ b/v7.1.2/.doctrees/output/botcore.utils.members.doctree diff --git a/v7.1.2/.doctrees/output/botcore.utils.regex.doctree b/v7.1.2/.doctrees/output/botcore.utils.regex.doctree Binary files differindex ded78023..47299393 100644 --- a/v7.1.2/.doctrees/output/botcore.utils.regex.doctree +++ b/v7.1.2/.doctrees/output/botcore.utils.regex.doctree diff --git a/v7.1.2/.doctrees/output/botcore.utils.scheduling.doctree b/v7.1.2/.doctrees/output/botcore.utils.scheduling.doctree Binary files differindex 3be8fa48..11589500 100644 --- a/v7.1.2/.doctrees/output/botcore.utils.scheduling.doctree +++ b/v7.1.2/.doctrees/output/botcore.utils.scheduling.doctree diff --git a/v7.1.2/_static/_sphinx_javascript_frameworks_compat.js b/v7.1.2/_static/_sphinx_javascript_frameworks_compat.js new file mode 100644 index 00000000..8549469d --- /dev/null +++ b/v7.1.2/_static/_sphinx_javascript_frameworks_compat.js @@ -0,0 +1,134 @@ +/* + * _sphinx_javascript_frameworks_compat.js + * ~~~~~~~~~~ + * + * Compatability shim for jQuery and underscores.js. + * + * WILL BE REMOVED IN Sphinx 6.0 + * xref RemovedInSphinx60Warning + * + */ + +/** + * select a different prefix for underscore + */ +$u = _.noConflict(); + + +/** + * small helper function to urldecode strings + * + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL + */ +jQuery.urldecode = function(x) { +    if (!x) { +        return x +    } +    return decodeURIComponent(x.replace(/\+/g, ' ')); +}; + +/** + * small helper function to urlencode strings + */ +jQuery.urlencode = encodeURIComponent; + +/** + * This function returns the parsed url parameters of the + * current request. Multiple values per key are supported, + * it will always return arrays of strings for the value parts. + */ +jQuery.getQueryParameters = function(s) { +    if (typeof s === 'undefined') +        s = document.location.search; +    var parts = s.substr(s.indexOf('?') + 1).split('&'); +    var result = {}; +    for (var i = 0; i < parts.length; i++) { +        var tmp = parts[i].split('=', 2); +        var key = jQuery.urldecode(tmp[0]); +        var value = jQuery.urldecode(tmp[1]); +        if (key in result) +            result[key].push(value); +        else +            result[key] = [value]; +    } +    return result; +}; + +/** + * highlight a given string on a jquery object by wrapping it in + * span elements with the given class name. + */ +jQuery.fn.highlightText = function(text, className) { +    function highlight(node, addItems) { +        if (node.nodeType === 3) { +            var val = node.nodeValue; +            var pos = val.toLowerCase().indexOf(text); +            if (pos >= 0 && +                !jQuery(node.parentNode).hasClass(className) && +                !jQuery(node.parentNode).hasClass("nohighlight")) { +                var span; +                var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg"); +                if (isInSVG) { +                    span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); +                } else { +                    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); +                if (isInSVG) { +                    var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"); +                    var bbox = node.parentElement.getBBox(); +                    rect.x.baseVal.value = bbox.x; +                    rect.y.baseVal.value = bbox.y; +                    rect.width.baseVal.value = bbox.width; +                    rect.height.baseVal.value = bbox.height; +                    rect.setAttribute('class', className); +                    addItems.push({ +                        "parent": node.parentNode, +                        "target": rect}); +                } +            } +        } +        else if (!jQuery(node).is("button, select, textarea")) { +            jQuery.each(node.childNodes, function() { +                highlight(this, addItems); +            }); +        } +    } +    var addItems = []; +    var result = this.each(function() { +        highlight(this, addItems); +    }); +    for (var i = 0; i < addItems.length; ++i) { +        jQuery(addItems[i].parent).before(addItems[i].target); +    } +    return result; +}; + +/* + * 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; +} diff --git a/v7.1.2/_static/basic.css b/v7.1.2/_static/basic.css index bf18350b..7d5974c3 100644 --- a/v7.1.2/_static/basic.css +++ b/v7.1.2/_static/basic.css @@ -222,7 +222,7 @@ table.modindextable td {  /* -- general body styles --------------------------------------------------- */  div.body { -    min-width: 450px; +    min-width: 360px;      max-width: 800px;  } @@ -236,7 +236,6 @@ div.body p, div.body dd, div.body li, div.body blockquote {  a.headerlink {      visibility: hidden;  } -  a.brackets:before,  span.brackets > a:before{      content: "["; @@ -247,6 +246,7 @@ span.brackets > a:after {      content: "]";  } +  h1:hover > a.headerlink,  h2:hover > a.headerlink,  h3:hover > a.headerlink, @@ -334,13 +334,11 @@ aside.sidebar {  p.sidebar-title {      font-weight: bold;  } -  div.admonition, div.topic, blockquote {      clear: left;  }  /* -- topics ---------------------------------------------------------------- */ -  div.topic {      border: 1px solid #ccc;      padding: 7px; @@ -428,10 +426,6 @@ table.docutils td, table.docutils th {      border-bottom: 1px solid #aaa;  } -table.footnote td, table.footnote th { -    border: 0 !important; -} -  th {      text-align: left;      padding-right: 5px; @@ -615,6 +609,7 @@ ul.simple p {      margin-bottom: 0;  } +/* Docutils 0.17 and older (footnotes & citations) */  dl.footnote > dt,  dl.citation > dt {      float: left; @@ -632,6 +627,33 @@ dl.citation > dd:after {      clear: both;  } +/* Docutils 0.18+ (footnotes & citations) */ +aside.footnote > span, +div.citation > span { +    float: left; +} +aside.footnote > span:last-of-type, +div.citation > span:last-of-type { +  padding-right: 0.5em; +} +aside.footnote > p { +  margin-left: 2em; +} +div.citation > p { +  margin-left: 4em; +} +aside.footnote > p:last-of-type, +div.citation > p:last-of-type { +    margin-bottom: 0em; +} +aside.footnote > p:last-of-type:after, +div.citation > p:last-of-type:after { +    content: ""; +    clear: both; +} + +/* Footnotes & citations ends */ +  dl.field-list {      display: grid;      grid-template-columns: fit-content(30%) auto; diff --git a/v7.1.2/_static/doctools.js b/v7.1.2/_static/doctools.js index e1bfd708..c3db08d1 100644 --- a/v7.1.2/_static/doctools.js +++ b/v7.1.2/_static/doctools.js @@ -2,357 +2,263 @@   * doctools.js   * ~~~~~~~~~~~   * - * Sphinx JavaScript utilities for all documentation. + * Base JavaScript utilities for all Sphinx HTML documentation.   *   * :copyright: Copyright 2007-2022 by the Sphinx team, see AUTHORS.   * :license: BSD, see LICENSE for details.   *   */ +"use strict"; -/** - * select a different prefix for underscore - */ -$u = _.noConflict(); - -/** - * make the code below compatible with browsers without - * an installed firebug like debugger -if (!window.console || !console.firebug) { -  var names = ["log", "debug", "info", "warn", "error", "assert", "dir", -    "dirxml", "group", "groupEnd", "time", "timeEnd", "count", "trace", -    "profile", "profileEnd"]; -  window.console = {}; -  for (var i = 0; i < names.length; ++i) -    window.console[names[i]] = function() {}; -} - */ - -/** - * small helper function to urldecode strings - * - * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL - */ -jQuery.urldecode = function(x) { -  if (!x) { -    return x +const _ready = (callback) => { +  if (document.readyState !== "loading") { +    callback(); +  } else { +    document.addEventListener("DOMContentLoaded", callback);    } -  return decodeURIComponent(x.replace(/\+/g, ' '));  };  /** - * small helper function to urlencode strings + * highlight a given string on a node by wrapping it in + * span elements with the given class name.   */ -jQuery.urlencode = encodeURIComponent; +const _highlight = (node, addItems, text, className) => { +  if (node.nodeType === Node.TEXT_NODE) { +    const val = node.nodeValue; +    const parent = node.parentNode; +    const pos = val.toLowerCase().indexOf(text); +    if ( +      pos >= 0 && +      !parent.classList.contains(className) && +      !parent.classList.contains("nohighlight") +    ) { +      let span; -/** - * This function returns the parsed url parameters of the - * current request. Multiple values per key are supported, - * it will always return arrays of strings for the value parts. - */ -jQuery.getQueryParameters = function(s) { -  if (typeof s === 'undefined') -    s = document.location.search; -  var parts = s.substr(s.indexOf('?') + 1).split('&'); -  var result = {}; -  for (var i = 0; i < parts.length; i++) { -    var tmp = parts[i].split('=', 2); -    var key = jQuery.urldecode(tmp[0]); -    var value = jQuery.urldecode(tmp[1]); -    if (key in result) -      result[key].push(value); -    else -      result[key] = [value]; -  } -  return result; -}; +      const closestNode = parent.closest("body, svg, foreignObject"); +      const isInSVG = closestNode && closestNode.matches("svg"); +      if (isInSVG) { +        span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); +      } else { +        span = document.createElement("span"); +        span.classList.add(className); +      } -/** - * highlight a given string on a jquery object by wrapping it in - * span elements with the given class name. - */ -jQuery.fn.highlightText = function(text, className) { -  function highlight(node, addItems) { -    if (node.nodeType === 3) { -      var val = node.nodeValue; -      var pos = val.toLowerCase().indexOf(text); -      if (pos >= 0 && -          !jQuery(node.parentNode).hasClass(className) && -          !jQuery(node.parentNode).hasClass("nohighlight")) { -        var span; -        var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg"); -        if (isInSVG) { -          span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); -        } else { -          span = document.createElement("span"); -          span.className = className; -        } -        span.appendChild(document.createTextNode(val.substr(pos, text.length))); -        node.parentNode.insertBefore(span, node.parentNode.insertBefore( +      span.appendChild(document.createTextNode(val.substr(pos, text.length))); +      parent.insertBefore( +        span, +        parent.insertBefore(            document.createTextNode(val.substr(pos + text.length)), -          node.nextSibling)); -        node.nodeValue = val.substr(0, pos); -        if (isInSVG) { -          var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"); -          var bbox = node.parentElement.getBBox(); -          rect.x.baseVal.value = bbox.x; -          rect.y.baseVal.value = bbox.y; -          rect.width.baseVal.value = bbox.width; -          rect.height.baseVal.value = bbox.height; -          rect.setAttribute('class', className); -          addItems.push({ -              "parent": node.parentNode, -              "target": rect}); -        } +          node.nextSibling +        ) +      ); +      node.nodeValue = val.substr(0, pos); + +      if (isInSVG) { +        const rect = document.createElementNS( +          "http://www.w3.org/2000/svg", +          "rect" +        ); +        const bbox = parent.getBBox(); +        rect.x.baseVal.value = bbox.x; +        rect.y.baseVal.value = bbox.y; +        rect.width.baseVal.value = bbox.width; +        rect.height.baseVal.value = bbox.height; +        rect.setAttribute("class", className); +        addItems.push({ parent: parent, target: rect });        }      } -    else if (!jQuery(node).is("button, select, textarea")) { -      jQuery.each(node.childNodes, function() { -        highlight(this, addItems); -      }); -    } +  } else if (node.matches && !node.matches("button, select, textarea")) { +    node.childNodes.forEach((el) => _highlight(el, addItems, text, className));    } -  var addItems = []; -  var result = this.each(function() { -    highlight(this, addItems); -  }); -  for (var i = 0; i < addItems.length; ++i) { -    jQuery(addItems[i].parent).before(addItems[i].target); -  } -  return result;  }; - -/* - * 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; -} +const _highlightText = (thisNode, text, className) => { +  let addItems = []; +  _highlight(thisNode, addItems, text, className); +  addItems.forEach((obj) => +    obj.parent.insertAdjacentElement("beforebegin", obj.target) +  ); +};  /**   * Small JavaScript module for the documentation.   */ -var Documentation = { - -  init : function() { -    this.fixFirefoxAnchorBug(); -    this.highlightSearchWords(); -    this.initIndexTable(); -    this.initOnKeyListeners(); +const Documentation = { +  init: () => { +    Documentation.highlightSearchWords(); +    Documentation.initDomainIndexTable(); +    Documentation.initOnKeyListeners();    },    /**     * i18n support     */ -  TRANSLATIONS : {}, -  PLURAL_EXPR : function(n) { return n === 1 ? 0 : 1; }, -  LOCALE : 'unknown', +  TRANSLATIONS: {}, +  PLURAL_EXPR: (n) => (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; +  gettext: (string) => { +    const translated = Documentation.TRANSLATIONS[string]; +    switch (typeof translated) { +      case "undefined": +        return string; // no translation +      case "string": +        return translated; // translation exists +      default: +        return translated[0]; // (singular, plural) translation tuple exists +    }    }, -  /** -   * add context elements like header anchor links -   */ -  addContextElements : function() { -    $('div[id] > :header:first').each(function() { -      $('<a class="headerlink">\u00B6</a>'). -      attr('href', '#' + this.id). -      attr('title', _('Permalink to this headline')). -      appendTo(this); -    }); -    $('dt[id]').each(function() { -      $('<a class="headerlink">\u00B6</a>'). -      attr('href', '#' + this.id). -      attr('title', _('Permalink to this definition')). -      appendTo(this); -    }); +  ngettext: (singular, plural, n) => { +    const translated = Documentation.TRANSLATIONS[singular]; +    if (typeof translated !== "undefined") +      return translated[Documentation.PLURAL_EXPR(n)]; +    return n === 1 ? singular : plural;    }, -  /** -   * workaround a firefox stupidity -   * see: https://bugzilla.mozilla.org/show_bug.cgi?id=645075 -   */ -  fixFirefoxAnchorBug : function() { -    if (document.location.hash && $.browser.mozilla) -      window.setTimeout(function() { -        document.location.href += ''; -      }, 10); +  addTranslations: (catalog) => { +    Object.assign(Documentation.TRANSLATIONS, catalog.messages); +    Documentation.PLURAL_EXPR = new Function( +      "n", +      `return (${catalog.plural_expr})` +    ); +    Documentation.LOCALE = catalog.locale;    },    /**     * 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); -      $('<p class="highlight-link"><a href="javascript:Documentation.' + -        'hideSearchWords()">' + _('Hide Search Matches') + '</a></p>') -          .appendTo($('#searchbox')); -    } -  }, +  highlightSearchWords: () => { +    const highlight = +      new URLSearchParams(window.location.search).get("highlight") || ""; +    const terms = highlight.toLowerCase().split(/\s+/).filter(x => x); +    if (terms.length === 0) return; // nothing to do -  /** -   * 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(); -    } +    // There should never be more than one element matching "div.body" +    const divBody = document.querySelectorAll("div.body"); +    const body = divBody.length ? divBody[0] : document.querySelector("body"); +    window.setTimeout(() => { +      terms.forEach((term) => _highlightText(body, term, "highlighted")); +    }, 10); + +    const searchBox = document.getElementById("searchbox"); +    if (searchBox === null) return; +    searchBox.appendChild( +      document +        .createRange() +        .createContextualFragment( +          '<p class="highlight-link">' + +            '<a href="javascript:Documentation.hideSearchWords()">' + +            Documentation.gettext("Hide Search Matches") + +            "</a></p>" +        ) +    );    },    /**     * helper function to hide the search marks again     */ -  hideSearchWords : function() { -    $('#searchbox .highlight-link').fadeOut(300); -    $('span.highlighted').removeClass('highlighted'); -    var url = new URL(window.location); -    url.searchParams.delete('highlight'); -    window.history.replaceState({}, '', url); +  hideSearchWords: () => { +    document +      .querySelectorAll("#searchbox .highlight-link") +      .forEach((el) => el.remove()); +    document +      .querySelectorAll("span.highlighted") +      .forEach((el) => el.classList.remove("highlighted")); +    const url = new URL(window.location); +    url.searchParams.delete("highlight"); +    window.history.replaceState({}, "", url);    }, -   /** +  /**     * helper function to focus on search bar     */ -  focusSearchBar : function() { -    $('input[name=q]').first().focus(); +  focusSearchBar: () => { +    document.querySelectorAll("input[name=q]")[0]?.focus();    },    /** -   * make the url absolute +   * Initialise the domain index toggle buttons     */ -  makeURL : function(relativeURL) { -    return DOCUMENTATION_OPTIONS.URL_ROOT + '/' + relativeURL; -  }, +  initDomainIndexTable: () => { +    const toggler = (el) => { +      const idNumber = el.id.substr(7); +      const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`); +      if (el.src.substr(-9) === "minus.png") { +        el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`; +        toggledRows.forEach((el) => (el.style.display = "none")); +      } else { +        el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`; +        toggledRows.forEach((el) => (el.style.display = "")); +      } +    }; -  /** -   * 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); +    const togglerElements = document.querySelectorAll("img.toggler"); +    togglerElements.forEach((el) => +      el.addEventListener("click", (event) => toggler(event.currentTarget)) +    ); +    togglerElements.forEach((el) => (el.style.display = "")); +    if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler);    }, -  initOnKeyListeners: function() { +  initOnKeyListeners: () => {      // only install a listener if it is really needed -    if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && -        !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -        return; +    if ( +      !DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && +      !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS +    ) +      return; -    $(document).keydown(function(event) { -      var activeElementType = document.activeElement.tagName; -      // don't navigate when in search box, textarea, dropdown or button -      if (activeElementType !== 'TEXTAREA' && activeElementType !== 'INPUT' && activeElementType !== 'SELECT' -          && activeElementType !== 'BUTTON') { -        if (event.altKey || event.ctrlKey || event.metaKey) -          return; +    const blacklistedElements = new Set([ +      "TEXTAREA", +      "INPUT", +      "SELECT", +      "BUTTON", +    ]); +    document.addEventListener("keydown", (event) => { +      if (blacklistedElements.has(document.activeElement.tagName)) return; // bail for input elements +      if (event.altKey || event.ctrlKey || event.metaKey) return; // bail with special keys -          if (!event.shiftKey) { -            switch (event.key) { -              case 'ArrowLeft': -                if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) -                  break; -                var prevHref = $('link[rel="prev"]').prop('href'); -                if (prevHref) { -                  window.location.href = prevHref; -                  return false; -                } -                break; -              case 'ArrowRight': -                if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) -                  break; -                var nextHref = $('link[rel="next"]').prop('href'); -                if (nextHref) { -                  window.location.href = nextHref; -                  return false; -                } -                break; -              case 'Escape': -                if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -                  break; -                Documentation.hideSearchWords(); -                return false; -          } -        } - -        // some keyboard layouts may need Shift to get / +      if (!event.shiftKey) {          switch (event.key) { -          case '/': -            if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -              break; -            Documentation.focusSearchBar(); -            return false; +          case "ArrowLeft": +            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + +            const prevLink = document.querySelector('link[rel="prev"]'); +            if (prevLink && prevLink.href) { +              window.location.href = prevLink.href; +              event.preventDefault(); +            } +            break; +          case "ArrowRight": +            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + +            const nextLink = document.querySelector('link[rel="next"]'); +            if (nextLink && nextLink.href) { +              window.location.href = nextLink.href; +              event.preventDefault(); +            } +            break; +          case "Escape": +            if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; +            Documentation.hideSearchWords(); +            event.preventDefault();          }        } + +      // some keyboard layouts may need Shift to get / +      switch (event.key) { +        case "/": +          if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; +          Documentation.focusSearchBar(); +          event.preventDefault(); +      }      }); -  } +  },  };  // quick alias for translations -_ = Documentation.gettext; +const _ = Documentation.gettext; -$(document).ready(function() { -  Documentation.init(); -}); +_ready(Documentation.init); diff --git a/v7.1.2/_static/documentation_options.js b/v7.1.2/_static/documentation_options.js index 759a8630..7e1e752d 100644 --- a/v7.1.2/_static/documentation_options.js +++ b/v7.1.2/_static/documentation_options.js @@ -1,7 +1,7 @@  var DOCUMENTATION_OPTIONS = {      URL_ROOT: document.getElementById("documentation_options").getAttribute('data-url_root'),      VERSION: '7.1.2', -    LANGUAGE: 'None', +    LANGUAGE: 'en',      COLLAPSE_INDEX: false,      BUILDER: 'html',      FILE_SUFFIX: '.html', @@ -10,5 +10,5 @@ var DOCUMENTATION_OPTIONS = {      SOURCELINK_SUFFIX: '.txt',      NAVIGATION_WITH_KEYS: false,      SHOW_SEARCH_SUMMARY: true, -    ENABLE_SEARCH_SHORTCUTS: true, +    ENABLE_SEARCH_SHORTCUTS: false,  };
\ No newline at end of file diff --git a/v7.1.2/_static/jquery-3.5.1.js b/v7.1.2/_static/jquery-3.6.0.js index 50937333..fc6c299b 100644 --- a/v7.1.2/_static/jquery-3.5.1.js +++ b/v7.1.2/_static/jquery-3.6.0.js @@ -1,15 +1,15 @@  /*! - * jQuery JavaScript Library v3.5.1 + * jQuery JavaScript Library v3.6.0   * https://jquery.com/   *   * Includes Sizzle.js   * https://sizzlejs.com/   * - * Copyright JS Foundation and other contributors + * Copyright OpenJS Foundation and other contributors   * Released under the MIT license   * https://jquery.org/license   * - * Date: 2020-05-04T22:49Z + * Date: 2021-03-02T17:08Z   */  ( function( global, factory ) { @@ -76,12 +76,16 @@ var support = {};  var isFunction = function isFunction( obj ) { -      // Support: Chrome <=57, Firefox <=52 -      // In some browsers, typeof returns "function" for HTML <object> elements -      // (i.e., `typeof document.createElement( "object" ) === "function"`). -      // We don't want to classify *any* DOM node as a function. -      return typeof obj === "function" && typeof obj.nodeType !== "number"; -  }; +		// Support: Chrome <=57, Firefox <=52 +		// In some browsers, typeof returns "function" for HTML <object> elements +		// (i.e., `typeof document.createElement( "object" ) === "function"`). +		// We don't want to classify *any* DOM node as a function. +		// Support: QtWeb <=3.8.5, WebKit <=534.34, wkhtmltopdf tool <=0.12.5 +		// Plus for old WebKit, typeof returns "function" for HTML collections +		// (e.g., `typeof document.getElementsByTagName("div") === "function"`). (gh-4756) +		return typeof obj === "function" && typeof obj.nodeType !== "number" && +			typeof obj.item !== "function"; +	};  var isWindow = function isWindow( obj ) { @@ -147,7 +151,7 @@ function toType( obj ) {  var -	version = "3.5.1", +	version = "3.6.0",  	// Define a local copy of jQuery  	jQuery = function( selector, context ) { @@ -401,7 +405,7 @@ jQuery.extend( {  			if ( isArrayLike( Object( arr ) ) ) {  				jQuery.merge( ret,  					typeof arr === "string" ? -					[ arr ] : arr +						[ arr ] : arr  				);  			} else {  				push.call( ret, arr ); @@ -496,9 +500,9 @@ if ( typeof Symbol === "function" ) {  // Populate the class2type map  jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ), -function( _i, name ) { -	class2type[ "[object " + name + "]" ] = name.toLowerCase(); -} ); +	function( _i, name ) { +		class2type[ "[object " + name + "]" ] = name.toLowerCase(); +	} );  function isArrayLike( obj ) { @@ -518,14 +522,14 @@ function isArrayLike( obj ) {  }  var Sizzle =  /*! - * Sizzle CSS Selector Engine v2.3.5 + * Sizzle CSS Selector Engine v2.3.6   * https://sizzlejs.com/   *   * Copyright JS Foundation and other contributors   * Released under the MIT license   * https://js.foundation/   * - * Date: 2020-03-14 + * Date: 2021-02-16   */  ( function( window ) {  var i, @@ -1108,8 +1112,8 @@ support = Sizzle.support = {};   * @returns {Boolean} True iff elem is a non-HTML XML node   */  isXML = Sizzle.isXML = function( elem ) { -	var namespace = elem.namespaceURI, -		docElem = ( elem.ownerDocument || elem ).documentElement; +	var namespace = elem && elem.namespaceURI, +		docElem = elem && ( elem.ownerDocument || elem ).documentElement;  	// Support: IE <=8  	// Assume HTML when documentElement doesn't yet exist, such as inside loading iframes @@ -3024,9 +3028,9 @@ var rneedsContext = jQuery.expr.match.needsContext;  function nodeName( elem, name ) { -  return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); +	return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); -}; +}  var rsingleTag = ( /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i ); @@ -3997,8 +4001,8 @@ jQuery.extend( {  			resolveContexts = Array( i ),  			resolveValues = slice.call( arguments ), -			// the master Deferred -			master = jQuery.Deferred(), +			// the primary Deferred +			primary = jQuery.Deferred(),  			// subordinate callback factory  			updateFunc = function( i ) { @@ -4006,30 +4010,30 @@ jQuery.extend( {  					resolveContexts[ i ] = this;  					resolveValues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value;  					if ( !( --remaining ) ) { -						master.resolveWith( resolveContexts, resolveValues ); +						primary.resolveWith( resolveContexts, resolveValues );  					}  				};  			};  		// Single- and empty arguments are adopted like Promise.resolve  		if ( remaining <= 1 ) { -			adoptValue( singleValue, master.done( updateFunc( i ) ).resolve, master.reject, +			adoptValue( singleValue, primary.done( updateFunc( i ) ).resolve, primary.reject,  				!remaining );  			// Use .then() to unwrap secondary thenables (cf. gh-3000) -			if ( master.state() === "pending" || +			if ( primary.state() === "pending" ||  				isFunction( resolveValues[ i ] && resolveValues[ i ].then ) ) { -				return master.then(); +				return primary.then();  			}  		}  		// Multiple arguments are aggregated like Promise.all array elements  		while ( i-- ) { -			adoptValue( resolveValues[ i ], updateFunc( i ), master.reject ); +			adoptValue( resolveValues[ i ], updateFunc( i ), primary.reject );  		} -		return master.promise(); +		return primary.promise();  	}  } ); @@ -4180,8 +4184,8 @@ var access = function( elems, fn, key, value, chainable, emptyGet, raw ) {  			for ( ; i < len; i++ ) {  				fn(  					elems[ i ], key, raw ? -					value : -					value.call( elems[ i ], i, fn( elems[ i ], key ) ) +						value : +						value.call( elems[ i ], i, fn( elems[ i ], key ) )  				);  			}  		} @@ -5089,10 +5093,7 @@ function buildFragment( elems, context, scripts, selection, ignored ) {  } -var -	rkeyEvent = /^key/, -	rmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/, -	rtypenamespace = /^([^.]*)(?:\.(.+)|)/; +var rtypenamespace = /^([^.]*)(?:\.(.+)|)/;  function returnTrue() {  	return true; @@ -5387,8 +5388,8 @@ jQuery.event = {  			event = jQuery.event.fix( nativeEvent ),  			handlers = ( -					dataPriv.get( this, "events" ) || Object.create( null ) -				)[ event.type ] || [], +				dataPriv.get( this, "events" ) || Object.create( null ) +			)[ event.type ] || [],  			special = jQuery.event.special[ event.type ] || {};  		// Use the fix-ed jQuery.Event rather than the (read-only) native event @@ -5512,12 +5513,12 @@ jQuery.event = {  			get: isFunction( hook ) ?  				function() {  					if ( this.originalEvent ) { -							return hook( this.originalEvent ); +						return hook( this.originalEvent );  					}  				} :  				function() {  					if ( this.originalEvent ) { -							return this.originalEvent[ name ]; +						return this.originalEvent[ name ];  					}  				}, @@ -5656,7 +5657,13 @@ function leverageNative( el, type, expectSync ) {  						// Cancel the outer synthetic event  						event.stopImmediatePropagation();  						event.preventDefault(); -						return result.value; + +						// Support: Chrome 86+ +						// In Chrome, if an element having a focusout handler is blurred by +						// clicking outside of it, it invokes the handler synchronously. If +						// that handler calls `.remove()` on the element, the data is cleared, +						// leaving `result` undefined. We need to guard against this. +						return result && result.value;  					}  				// If this is an inner synthetic event for an event with a bubbling surrogate @@ -5821,34 +5828,7 @@ jQuery.each( {  	targetTouches: true,  	toElement: true,  	touches: true, - -	which: function( event ) { -		var button = event.button; - -		// Add which for key events -		if ( event.which == null && rkeyEvent.test( event.type ) ) { -			return event.charCode != null ? event.charCode : event.keyCode; -		} - -		// Add which for click: 1 === left; 2 === middle; 3 === right -		if ( !event.which && button !== undefined && rmouseEvent.test( event.type ) ) { -			if ( button & 1 ) { -				return 1; -			} - -			if ( button & 2 ) { -				return 3; -			} - -			if ( button & 4 ) { -				return 2; -			} - -			return 0; -		} - -		return event.which; -	} +	which: true  }, jQuery.event.addProp );  jQuery.each( { focus: "focusin", blur: "focusout" }, function( type, delegateType ) { @@ -5874,6 +5854,12 @@ jQuery.each( { focus: "focusin", blur: "focusout" }, function( type, delegateTyp  			return true;  		}, +		// Suppress native focus or blur as it's already being fired +		// in leverageNative. +		_default: function() { +			return true; +		}, +  		delegateType: delegateType  	};  } ); @@ -6541,6 +6527,10 @@ var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" );  		// set in CSS while `offset*` properties report correct values.  		// Behavior in IE 9 is more subtle than in newer versions & it passes  		// some versions of this test; make sure not to make it pass there! +		// +		// Support: Firefox 70+ +		// Only Firefox includes border widths +		// in computed dimensions. (gh-4529)  		reliableTrDimensions: function() {  			var table, tr, trChild, trStyle;  			if ( reliableTrDimensionsVal == null ) { @@ -6548,17 +6538,32 @@ var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" );  				tr = document.createElement( "tr" );  				trChild = document.createElement( "div" ); -				table.style.cssText = "position:absolute;left:-11111px"; +				table.style.cssText = "position:absolute;left:-11111px;border-collapse:separate"; +				tr.style.cssText = "border:1px solid"; + +				// Support: Chrome 86+ +				// Height set through cssText does not get applied. +				// Computed height then comes back as 0.  				tr.style.height = "1px";  				trChild.style.height = "9px"; +				// Support: Android 8 Chrome 86+ +				// In our bodyBackground.html iframe, +				// display for all div elements is set to "inline", +				// which causes a problem only in Android 8 Chrome 86. +				// Ensuring the div is display: block +				// gets around this issue. +				trChild.style.display = "block"; +  				documentElement  					.appendChild( table )  					.appendChild( tr )  					.appendChild( trChild );  				trStyle = window.getComputedStyle( tr ); -				reliableTrDimensionsVal = parseInt( trStyle.height ) > 3; +				reliableTrDimensionsVal = ( parseInt( trStyle.height, 10 ) + +					parseInt( trStyle.borderTopWidth, 10 ) + +					parseInt( trStyle.borderBottomWidth, 10 ) ) === tr.offsetHeight;  				documentElement.removeChild( table );  			} @@ -7022,10 +7027,10 @@ jQuery.each( [ "height", "width" ], function( _i, dimension ) {  					// Running getBoundingClientRect on a disconnected node  					// in IE throws an error.  					( !elem.getClientRects().length || !elem.getBoundingClientRect().width ) ? -						swap( elem, cssShow, function() { -							return getWidthOrHeight( elem, dimension, extra ); -						} ) : -						getWidthOrHeight( elem, dimension, extra ); +					swap( elem, cssShow, function() { +						return getWidthOrHeight( elem, dimension, extra ); +					} ) : +					getWidthOrHeight( elem, dimension, extra );  			}  		}, @@ -7084,7 +7089,7 @@ jQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft,  					swap( elem, { marginLeft: 0 }, function() {  						return elem.getBoundingClientRect().left;  					} ) -				) + "px"; +			) + "px";  		}  	}  ); @@ -7223,7 +7228,7 @@ Tween.propHooks = {  			if ( jQuery.fx.step[ tween.prop ] ) {  				jQuery.fx.step[ tween.prop ]( tween );  			} else if ( tween.elem.nodeType === 1 && ( -					jQuery.cssHooks[ tween.prop ] || +				jQuery.cssHooks[ tween.prop ] ||  					tween.elem.style[ finalPropName( tween.prop ) ] != null ) ) {  				jQuery.style( tween.elem, tween.prop, tween.now + tween.unit );  			} else { @@ -7468,7 +7473,7 @@ function defaultPrefilter( elem, props, opts ) {  			anim.done( function() { -			/* eslint-enable no-loop-func */ +				/* eslint-enable no-loop-func */  				// The final step of a "hide" animation is actually hiding the element  				if ( !hidden ) { @@ -7588,7 +7593,7 @@ function Animation( elem, properties, options ) {  			tweens: [],  			createTween: function( prop, end ) {  				var tween = jQuery.Tween( elem, animation.opts, prop, end, -						animation.opts.specialEasing[ prop ] || animation.opts.easing ); +					animation.opts.specialEasing[ prop ] || animation.opts.easing );  				animation.tweens.push( tween );  				return tween;  			}, @@ -7761,7 +7766,8 @@ jQuery.fn.extend( {  					anim.stop( true );  				}  			}; -			doAnimation.finish = doAnimation; + +		doAnimation.finish = doAnimation;  		return empty || optall.queue === false ?  			this.each( doAnimation ) : @@ -8401,8 +8407,8 @@ jQuery.fn.extend( {  				if ( this.setAttribute ) {  					this.setAttribute( "class",  						className || value === false ? -						"" : -						dataPriv.get( this, "__className__" ) || "" +							"" : +							dataPriv.get( this, "__className__" ) || ""  					);  				}  			} @@ -8417,7 +8423,7 @@ jQuery.fn.extend( {  		while ( ( elem = this[ i++ ] ) ) {  			if ( elem.nodeType === 1 &&  				( " " + stripAndCollapse( getClass( elem ) ) + " " ).indexOf( className ) > -1 ) { -					return true; +				return true;  			}  		} @@ -8707,9 +8713,7 @@ jQuery.extend( jQuery.event, {  				special.bindType || type;  			// jQuery handler -			handle = ( -					dataPriv.get( cur, "events" ) || Object.create( null ) -				)[ event.type ] && +			handle = ( dataPriv.get( cur, "events" ) || Object.create( null ) )[ event.type ] &&  				dataPriv.get( cur, "handle" );  			if ( handle ) {  				handle.apply( cur, data ); @@ -8856,7 +8860,7 @@ var rquery = ( /\?/ );  // Cross-browser xml parsing  jQuery.parseXML = function( data ) { -	var xml; +	var xml, parserErrorElem;  	if ( !data || typeof data !== "string" ) {  		return null;  	} @@ -8865,12 +8869,17 @@ jQuery.parseXML = function( data ) {  	// IE throws on parseFromString with invalid input.  	try {  		xml = ( new window.DOMParser() ).parseFromString( data, "text/xml" ); -	} catch ( e ) { -		xml = undefined; -	} +	} catch ( e ) {} -	if ( !xml || xml.getElementsByTagName( "parsererror" ).length ) { -		jQuery.error( "Invalid XML: " + data ); +	parserErrorElem = xml && xml.getElementsByTagName( "parsererror" )[ 0 ]; +	if ( !xml || parserErrorElem ) { +		jQuery.error( "Invalid XML: " + ( +			parserErrorElem ? +				jQuery.map( parserErrorElem.childNodes, function( el ) { +					return el.textContent; +				} ).join( "\n" ) : +				data +		) );  	}  	return xml;  }; @@ -8971,16 +8980,14 @@ jQuery.fn.extend( {  			// Can add propHook for "elements" to filter or add form elements  			var elements = jQuery.prop( this, "elements" );  			return elements ? jQuery.makeArray( elements ) : this; -		} ) -		.filter( function() { +		} ).filter( function() {  			var type = this.type;  			// Use .is( ":disabled" ) so that fieldset[disabled] works  			return this.name && !jQuery( this ).is( ":disabled" ) &&  				rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) &&  				( this.checked || !rcheckableType.test( type ) ); -		} ) -		.map( function( _i, elem ) { +		} ).map( function( _i, elem ) {  			var val = jQuery( this ).val();  			if ( val == null ) { @@ -9033,7 +9040,8 @@ var  	// Anchor tag for parsing the document origin  	originAnchor = document.createElement( "a" ); -	originAnchor.href = location.href; + +originAnchor.href = location.href;  // Base "constructor" for jQuery.ajaxPrefilter and jQuery.ajaxTransport  function addToPrefiltersOrTransports( structure ) { @@ -9414,8 +9422,8 @@ jQuery.extend( {  			// Context for global events is callbackContext if it is a DOM node or jQuery collection  			globalEventContext = s.context &&  				( callbackContext.nodeType || callbackContext.jquery ) ? -					jQuery( callbackContext ) : -					jQuery.event, +				jQuery( callbackContext ) : +				jQuery.event,  			// Deferreds  			deferred = jQuery.Deferred(), @@ -9727,8 +9735,10 @@ jQuery.extend( {  				response = ajaxHandleResponses( s, jqXHR, responses );  			} -			// Use a noop converter for missing script -			if ( !isSuccess && jQuery.inArray( "script", s.dataTypes ) > -1 ) { +			// Use a noop converter for missing script but not if jsonp +			if ( !isSuccess && +				jQuery.inArray( "script", s.dataTypes ) > -1 && +				jQuery.inArray( "json", s.dataTypes ) < 0 ) {  				s.converters[ "text script" ] = function() {};  			} @@ -10466,12 +10476,6 @@ jQuery.offset = {  			options.using.call( elem, props );  		} else { -			if ( typeof props.top === "number" ) { -				props.top += "px"; -			} -			if ( typeof props.left === "number" ) { -				props.left += "px"; -			}  			curElem.css( props );  		}  	} @@ -10640,8 +10644,11 @@ jQuery.each( [ "top", "left" ], function( _i, prop ) {  // Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods  jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { -	jQuery.each( { padding: "inner" + name, content: type, "": "outer" + name }, -		function( defaultExtra, funcName ) { +	jQuery.each( { +		padding: "inner" + name, +		content: type, +		"": "outer" + name +	}, function( defaultExtra, funcName ) {  		// Margin is only for outerHeight, outerWidth  		jQuery.fn[ funcName ] = function( margin, value ) { @@ -10726,7 +10733,8 @@ jQuery.fn.extend( {  	}  } ); -jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " + +jQuery.each( +	( "blur focus focusin focusout resize scroll click dblclick " +  	"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " +  	"change select submit keydown keypress keyup contextmenu" ).split( " " ),  	function( _i, name ) { @@ -10737,7 +10745,8 @@ jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " +  				this.on( name, null, data, fn ) :  				this.trigger( name );  		}; -	} ); +	} +); diff --git a/v7.1.2/_static/jquery.js b/v7.1.2/_static/jquery.js index b0614034..c4c6022f 100644 --- a/v7.1.2/_static/jquery.js +++ b/v7.1.2/_static/jquery.js @@ -1,2 +1,2 @@ -/*! jQuery v3.5.1 | (c) JS Foundation and other contributors | jquery.org/license */ -!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.5.1",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),D=function(e,t){return e===t&&(l=!0),0},j={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e.namespaceURI,n=(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&j.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(D),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(D).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function D(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(D(this,e||[],!1))},not:function(e){return this.pushStack(D(this,e||[],!0))},is:function(e){return!!D(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var j,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||j,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,j=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^key/,we=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,Te=/^([^.]*)(?:\.(.+)|)/;function Ce(){return!0}function Ee(){return!1}function Se(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function ke(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)ke(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Ee;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Ae(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,Ce)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=Te.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=Te.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Ae(t,"click",Ce),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Ae(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?Ce:Ee,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Ee,isPropagationStopped:Ee,isImmediatePropagationStopped:Ee,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=Ce,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=Ce,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=Ce,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:function(e){var t=e.button;return null==e.which&&be.test(e.type)?null!=e.charCode?e.charCode:e.keyCode:!e.which&&void 0!==t&&we.test(e.type)?1&t?1:2&t?3:4&t?2:0:e.which}},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Ae(this,e,Se),!1},trigger:function(){return Ae(this,e),!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return ke(this,e,t,n,r)},one:function(e,t,n,r){return ke(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Ee),this.each(function(){S.event.remove(this,e,n,t)})}});var Ne=/<script|<style|<link/i,De=/checked\s*(?:[^=]|=\s*.checked.)/i,je=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function qe(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function Le(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function He(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Oe(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function Pe(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&De.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),Pe(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),Le)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,He),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(je,""),u,l))}return n}function Re(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Oe(o[r],a[r]);else Oe(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Re(this,e,!0)},remove:function(e){return Re(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return Pe(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||qe(this,e).appendChild(e)})},prepend:function(){return Pe(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=qe(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return Pe(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return Pe(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!Ne.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return Pe(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Me=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Ie=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},We=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Fe=new RegExp(ne.join("|"),"i");function Be(e,t,n){var r,i,o,a,s=e.style;return(n=n||Ie(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Me.test(a)&&Fe.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function $e(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px",t.style.height="1px",n.style.height="9px",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=3<parseInt(r.height),re.removeChild(e)),a}}))}();var _e=["Webkit","Moz","ms"],ze=E.createElement("div").style,Ue={};function Xe(e){var t=S.cssProps[e]||Ue[e];return t||(e in ze?e:Ue[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=_e.length;while(n--)if((e=_e[n]+t)in ze)return e}(e)||e)}var Ve=/^(none|table(?!-c[ea]).+)/,Ge=/^--/,Ye={position:"absolute",visibility:"hidden",display:"block"},Qe={letterSpacing:"0",fontWeight:"400"};function Je(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Ke(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Ze(e,t,n){var r=Ie(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=Be(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Me.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Ke(e,t,n||(i?"border":"content"),o,r,a)+"px"}function et(e,t,n,r,i){return new et.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Be(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Ge.test(t),l=e.style;if(u||(t=Xe(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Ge.test(t)||(t=Xe(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=Be(e,t,r)),"normal"===i&&t in Qe&&(i=Qe[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ve.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Ze(e,u,n):We(e,Ye,function(){return Ze(e,u,n)})},set:function(e,t,n){var r,i=Ie(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Ke(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Ke(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Je(0,t,s)}}}),S.cssHooks.marginLeft=$e(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(Be(e,"marginLeft"))||e.getBoundingClientRect().left-We(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Je)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Ie(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=et).prototype={constructor:et,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=et.propHooks[this.prop];return e&&e.get?e.get(this):et.propHooks._default.get(this)},run:function(e){var t,n=et.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):et.propHooks._default.set(this),this}}).init.prototype=et.prototype,(et.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[Xe(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=et.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=et.prototype.init,S.fx.step={};var tt,nt,rt,it,ot=/^(?:toggle|show|hide)$/,at=/queueHooks$/;function st(){nt&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(st):C.setTimeout(st,S.fx.interval),S.fx.tick())}function ut(){return C.setTimeout(function(){tt=void 0}),tt=Date.now()}function lt(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ct(e,t,n){for(var r,i=(ft.tweeners[t]||[]).concat(ft.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function ft(o,e,t){var n,a,r=0,i=ft.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=tt||ut(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:tt||ut(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=ft.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ct,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(ft,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],ft.tweeners[n]=ft.tweeners[n]||[],ft.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],ot.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ct(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?ft.prefilters.unshift(e):ft.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=ft(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&at.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(lt(r,!0),e,t,n)}}),S.each({slideDown:lt("show"),slideUp:lt("hide"),slideToggle:lt("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(tt=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),tt=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){nt||(nt=!0,st())},S.fx.stop=function(){nt=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},rt=E.createElement("input"),it=E.createElement("select").appendChild(E.createElement("option")),rt.type="checkbox",y.checkOn=""!==rt.value,y.optSelected=it.selected,(rt=E.createElement("input")).value="t",rt.type="radio",y.radioValue="t"===rt.value;var pt,dt=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?pt:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),pt={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=dt[t]||S.find.attr;dt[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=dt[o],dt[o]=r,r=null!=a(e,t,n)?o:null,dt[o]=i),r}});var ht=/^(?:input|select|textarea|button)$/i,gt=/^(?:a|area)$/i;function vt(e){return(e.match(P)||[]).join(" ")}function yt(e){return e.getAttribute&&e.getAttribute("class")||""}function mt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):ht.test(e.nodeName)||gt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,yt(this)))});if((e=mt(t)).length)while(n=this[u++])if(i=yt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,yt(this)))});if(!arguments.length)return this.attr("class","");if((e=mt(t)).length)while(n=this[u++])if(i=yt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,yt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=mt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=yt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+vt(yt(n))+" ").indexOf(t))return!0;return!1}});var xt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(xt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:vt(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var bt=/^(?:focusinfocus|focusoutblur)$/,wt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!bt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,bt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,wt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,wt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var Tt=C.location,Ct={guid:Date.now()},Et=/\?/;S.parseXML=function(e){var t;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){t=void 0}return t&&!t.getElementsByTagName("parsererror").length||S.error("Invalid XML: "+e),t};var St=/\[\]$/,kt=/\r?\n/g,At=/^(?:submit|button|image|reset|file)$/i,Nt=/^(?:input|select|textarea|keygen)/i;function Dt(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||St.test(n)?i(n,t):Dt(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)Dt(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)Dt(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&Nt.test(this.nodeName)&&!At.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(kt,"\r\n")}}):{name:t.name,value:n.replace(kt,"\r\n")}}).get()}});var jt=/%20/g,qt=/#.*$/,Lt=/([?&])_=[^&]*/,Ht=/^(.*?):[ \t]*([^\r\n]*)$/gm,Ot=/^(?:GET|HEAD)$/,Pt=/^\/\//,Rt={},Mt={},It="*/".concat("*"),Wt=E.createElement("a");function Ft(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Bt(t,i,o,a){var s={},u=t===Mt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function $t(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Wt.href=Tt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:Tt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(Tt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":It,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?$t($t(e,S.ajaxSettings),t):$t(S.ajaxSettings,e)},ajaxPrefilter:Ft(Rt),ajaxTransport:Ft(Mt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=Ht.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||Tt.href)+"").replace(Pt,Tt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Wt.protocol+"//"+Wt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Bt(Rt,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Ot.test(v.type),f=v.url.replace(qt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(jt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Et.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Lt,"$1"),o=(Et.test(f)?"&":"?")+"_="+Ct.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+It+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Bt(Mt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var _t={0:200,1223:204},zt=S.ajaxSettings.xhr();y.cors=!!zt&&"withCredentials"in zt,y.ajax=zt=!!zt,S.ajaxTransport(function(i){var o,a;if(y.cors||zt&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(_t[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var Ut,Xt=[],Vt=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=Xt.pop()||S.expando+"_"+Ct.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Vt.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Vt.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Vt,"$1"+r):!1!==e.jsonp&&(e.url+=(Et.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,Xt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((Ut=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===Ut.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=vt(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):("number"==typeof f.top&&(f.top+="px"),"number"==typeof f.left&&(f.left+="px"),c.css(f))}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=$e(y.pixelPosition,function(e,t){if(t)return t=Be(e,n),Me.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Gt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Gt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Yt=C.jQuery,Qt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Qt),e&&C.jQuery===S&&(C.jQuery=Yt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S}); +/*! jQuery v3.6.0 | (c) OpenJS Foundation and other contributors | jquery.org/license */ +!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.6.0",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),j=function(e,t){return e===t&&(l=!0),0},D={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},j=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&D.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(j),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(j).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var D,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||D,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,D=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^([^.]*)(?:\.(.+)|)/;function we(){return!0}function Te(){return!1}function Ce(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function Ee(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)Ee(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Te;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Se(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n&&n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,we)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=be.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=be.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click",we),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?we:Te,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Te,isPropagationStopped:Te,isImmediatePropagationStopped:Te,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=we,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=we,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=we,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:!0},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Se(this,e,Ce),!1},trigger:function(){return Se(this,e),!0},_default:function(){return!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return Ee(this,e,t,n,r)},one:function(e,t,n,r){return Ee(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Te),this.each(function(){S.event.remove(this,e,n,t)})}});var ke=/<script|<style|<link/i,Ae=/checked\s*(?:[^=]|=\s*.checked.)/i,Ne=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function je(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function De(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function qe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Le(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function He(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&Ae.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),He(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),De)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,qe),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(Ne,""),u,l))}return n}function Oe(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Le(o[r],a[r]);else Le(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Oe(this,e,!0)},remove:function(e){return Oe(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return He(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||je(this,e).appendChild(e)})},prepend:function(){return He(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=je(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!ke.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return He(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Pe=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Re=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},Me=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Ie=new RegExp(ne.join("|"),"i");function We(e,t,n){var r,i,o,a,s=e.style;return(n=n||Re(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Pe.test(a)&&Ie.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function Fe(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px;border-collapse:separate",t.style.cssText="border:1px solid",t.style.height="1px",n.style.height="9px",n.style.display="block",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=parseInt(r.height,10)+parseInt(r.borderTopWidth,10)+parseInt(r.borderBottomWidth,10)===t.offsetHeight,re.removeChild(e)),a}}))}();var Be=["Webkit","Moz","ms"],$e=E.createElement("div").style,_e={};function ze(e){var t=S.cssProps[e]||_e[e];return t||(e in $e?e:_e[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=Be.length;while(n--)if((e=Be[n]+t)in $e)return e}(e)||e)}var Ue=/^(none|table(?!-c[ea]).+)/,Xe=/^--/,Ve={position:"absolute",visibility:"hidden",display:"block"},Ge={letterSpacing:"0",fontWeight:"400"};function Ye(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Qe(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Je(e,t,n){var r=Re(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=We(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Pe.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Qe(e,t,n||(i?"border":"content"),o,r,a)+"px"}function Ke(e,t,n,r,i){return new Ke.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=We(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Xe.test(t),l=e.style;if(u||(t=ze(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Xe.test(t)||(t=ze(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=We(e,t,r)),"normal"===i&&t in Ge&&(i=Ge[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ue.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Je(e,u,n):Me(e,Ve,function(){return Je(e,u,n)})},set:function(e,t,n){var r,i=Re(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Qe(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Qe(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Ye(0,t,s)}}}),S.cssHooks.marginLeft=Fe(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(We(e,"marginLeft"))||e.getBoundingClientRect().left-Me(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Ye)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Re(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=Ke).prototype={constructor:Ke,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=Ke.propHooks[this.prop];return e&&e.get?e.get(this):Ke.propHooks._default.get(this)},run:function(e){var t,n=Ke.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):Ke.propHooks._default.set(this),this}}).init.prototype=Ke.prototype,(Ke.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[ze(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=Ke.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=Ke.prototype.init,S.fx.step={};var Ze,et,tt,nt,rt=/^(?:toggle|show|hide)$/,it=/queueHooks$/;function ot(){et&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(ot):C.setTimeout(ot,S.fx.interval),S.fx.tick())}function at(){return C.setTimeout(function(){Ze=void 0}),Ze=Date.now()}function st(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ut(e,t,n){for(var r,i=(lt.tweeners[t]||[]).concat(lt.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function lt(o,e,t){var n,a,r=0,i=lt.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=Ze||at(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:Ze||at(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=lt.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ut,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(lt,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],lt.tweeners[n]=lt.tweeners[n]||[],lt.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],rt.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ut(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?lt.prefilters.unshift(e):lt.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=lt(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&it.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(st(r,!0),e,t,n)}}),S.each({slideDown:st("show"),slideUp:st("hide"),slideToggle:st("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(Ze=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),Ze=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){et||(et=!0,ot())},S.fx.stop=function(){et=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},tt=E.createElement("input"),nt=E.createElement("select").appendChild(E.createElement("option")),tt.type="checkbox",y.checkOn=""!==tt.value,y.optSelected=nt.selected,(tt=E.createElement("input")).value="t",tt.type="radio",y.radioValue="t"===tt.value;var ct,ft=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?ct:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),ct={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=ft[t]||S.find.attr;ft[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=ft[o],ft[o]=r,r=null!=a(e,t,n)?o:null,ft[o]=i),r}});var pt=/^(?:input|select|textarea|button)$/i,dt=/^(?:a|area)$/i;function ht(e){return(e.match(P)||[]).join(" ")}function gt(e){return e.getAttribute&&e.getAttribute("class")||""}function vt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):pt.test(e.nodeName)||dt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,gt(this)))});if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,gt(this)))});if(!arguments.length)return this.attr("class","");if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,gt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=vt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=gt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+ht(gt(n))+" ").indexOf(t))return!0;return!1}});var yt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(yt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:ht(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var mt=/^(?:focusinfocus|focusoutblur)$/,xt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!mt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,mt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,xt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,xt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var bt=C.location,wt={guid:Date.now()},Tt=/\?/;S.parseXML=function(e){var t,n;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){}return n=t&&t.getElementsByTagName("parsererror")[0],t&&!n||S.error("Invalid XML: "+(n?S.map(n.childNodes,function(e){return e.textContent}).join("\n"):e)),t};var Ct=/\[\]$/,Et=/\r?\n/g,St=/^(?:submit|button|image|reset|file)$/i,kt=/^(?:input|select|textarea|keygen)/i;function At(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||Ct.test(n)?i(n,t):At(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)At(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)At(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&kt.test(this.nodeName)&&!St.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(Et,"\r\n")}}):{name:t.name,value:n.replace(Et,"\r\n")}}).get()}});var Nt=/%20/g,jt=/#.*$/,Dt=/([?&])_=[^&]*/,qt=/^(.*?):[ \t]*([^\r\n]*)$/gm,Lt=/^(?:GET|HEAD)$/,Ht=/^\/\//,Ot={},Pt={},Rt="*/".concat("*"),Mt=E.createElement("a");function It(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Wt(t,i,o,a){var s={},u=t===Pt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function Ft(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Mt.href=bt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:bt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(bt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Rt,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Ft(Ft(e,S.ajaxSettings),t):Ft(S.ajaxSettings,e)},ajaxPrefilter:It(Ot),ajaxTransport:It(Pt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=qt.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||bt.href)+"").replace(Ht,bt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Mt.protocol+"//"+Mt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Wt(Ot,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Lt.test(v.type),f=v.url.replace(jt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(Nt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Tt.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Dt,"$1"),o=(Tt.test(f)?"&":"?")+"_="+wt.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+Rt+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Wt(Pt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&S.inArray("json",v.dataTypes)<0&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var Bt={0:200,1223:204},$t=S.ajaxSettings.xhr();y.cors=!!$t&&"withCredentials"in $t,y.ajax=$t=!!$t,S.ajaxTransport(function(i){var o,a;if(y.cors||$t&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(Bt[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var _t,zt=[],Ut=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=zt.pop()||S.expando+"_"+wt.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Ut.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Ut.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Ut,"$1"+r):!1!==e.jsonp&&(e.url+=(Tt.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,zt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((_t=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===_t.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=ht(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=Fe(y.pixelPosition,function(e,t){if(t)return t=We(e,n),Pe.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Xt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Xt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Vt=C.jQuery,Gt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Gt),e&&C.jQuery===S&&(C.jQuery=Vt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S}); diff --git a/v7.1.2/_static/language_data.js b/v7.1.2/_static/language_data.js index ebe2f03b..2e22b06a 100644 --- a/v7.1.2/_static/language_data.js +++ b/v7.1.2/_static/language_data.js @@ -10,7 +10,7 @@   *   */ -var stopwords = ["a","and","are","as","at","be","but","by","for","if","in","into","is","it","near","no","not","of","on","or","such","that","the","their","then","there","these","they","this","to","was","will","with"]; +var stopwords = ["a", "and", "are", "as", "at", "be", "but", "by", "for", "if", "in", "into", "is", "it", "near", "no", "not", "of", "on", "or", "such", "that", "the", "their", "then", "there", "these", "they", "this", "to", "was", "will", "with"];  /* Non-minified version is copied as a separate JS file, is available */ @@ -197,101 +197,3 @@ var Stemmer = function() {    }  } - - - -var splitChars = (function() { -    var result = {}; -    var singles = [96, 180, 187, 191, 215, 247, 749, 885, 903, 907, 909, 930, 1014, 1648, -         1748, 1809, 2416, 2473, 2481, 2526, 2601, 2609, 2612, 2615, 2653, 2702, -         2706, 2729, 2737, 2740, 2857, 2865, 2868, 2910, 2928, 2948, 2961, 2971, -         2973, 3085, 3089, 3113, 3124, 3213, 3217, 3241, 3252, 3295, 3341, 3345, -         3369, 3506, 3516, 3633, 3715, 3721, 3736, 3744, 3748, 3750, 3756, 3761, -         3781, 3912, 4239, 4347, 4681, 4695, 4697, 4745, 4785, 4799, 4801, 4823, -         4881, 5760, 5901, 5997, 6313, 7405, 8024, 8026, 8028, 8030, 8117, 8125, -         8133, 8181, 8468, 8485, 8487, 8489, 8494, 8527, 11311, 11359, 11687, 11695, -         11703, 11711, 11719, 11727, 11735, 12448, 12539, 43010, 43014, 43019, 43587, -         43696, 43713, 64286, 64297, 64311, 64317, 64319, 64322, 64325, 65141]; -    var i, j, start, end; -    for (i = 0; i < singles.length; i++) { -        result[singles[i]] = true; -    } -    var ranges = [[0, 47], [58, 64], [91, 94], [123, 169], [171, 177], [182, 184], [706, 709], -         [722, 735], [741, 747], [751, 879], [888, 889], [894, 901], [1154, 1161], -         [1318, 1328], [1367, 1368], [1370, 1376], [1416, 1487], [1515, 1519], [1523, 1568], -         [1611, 1631], [1642, 1645], [1750, 1764], [1767, 1773], [1789, 1790], [1792, 1807], -         [1840, 1868], [1958, 1968], [1970, 1983], [2027, 2035], [2038, 2041], [2043, 2047], -         [2070, 2073], [2075, 2083], [2085, 2087], [2089, 2307], [2362, 2364], [2366, 2383], -         [2385, 2391], [2402, 2405], [2419, 2424], [2432, 2436], [2445, 2446], [2449, 2450], -         [2483, 2485], [2490, 2492], [2494, 2509], [2511, 2523], [2530, 2533], [2546, 2547], -         [2554, 2564], [2571, 2574], [2577, 2578], [2618, 2648], [2655, 2661], [2672, 2673], -         [2677, 2692], [2746, 2748], [2750, 2767], [2769, 2783], [2786, 2789], [2800, 2820], -         [2829, 2830], [2833, 2834], [2874, 2876], [2878, 2907], [2914, 2917], [2930, 2946], -         [2955, 2957], [2966, 2968], [2976, 2978], [2981, 2983], [2987, 2989], [3002, 3023], -         [3025, 3045], [3059, 3076], [3130, 3132], [3134, 3159], [3162, 3167], [3170, 3173], -         [3184, 3191], [3199, 3204], [3258, 3260], [3262, 3293], [3298, 3301], [3312, 3332], -         [3386, 3388], [3390, 3423], [3426, 3429], [3446, 3449], [3456, 3460], [3479, 3481], -         [3518, 3519], [3527, 3584], [3636, 3647], [3655, 3663], [3674, 3712], [3717, 3718], -         [3723, 3724], [3726, 3731], [3752, 3753], [3764, 3772], [3774, 3775], [3783, 3791], -         [3802, 3803], [3806, 3839], [3841, 3871], [3892, 3903], [3949, 3975], [3980, 4095], -         [4139, 4158], [4170, 4175], [4182, 4185], [4190, 4192], [4194, 4196], [4199, 4205], -         [4209, 4212], [4226, 4237], [4250, 4255], [4294, 4303], [4349, 4351], [4686, 4687], -         [4702, 4703], [4750, 4751], [4790, 4791], [4806, 4807], [4886, 4887], [4955, 4968], -         [4989, 4991], [5008, 5023], [5109, 5120], [5741, 5742], [5787, 5791], [5867, 5869], -         [5873, 5887], [5906, 5919], [5938, 5951], [5970, 5983], [6001, 6015], [6068, 6102], -         [6104, 6107], [6109, 6111], [6122, 6127], [6138, 6159], [6170, 6175], [6264, 6271], -         [6315, 6319], [6390, 6399], [6429, 6469], [6510, 6511], [6517, 6527], [6572, 6592], -         [6600, 6607], [6619, 6655], [6679, 6687], [6741, 6783], [6794, 6799], [6810, 6822], -         [6824, 6916], [6964, 6980], [6988, 6991], [7002, 7042], [7073, 7085], [7098, 7167], -         [7204, 7231], [7242, 7244], [7294, 7400], [7410, 7423], [7616, 7679], [7958, 7959], -         [7966, 7967], [8006, 8007], [8014, 8015], [8062, 8063], [8127, 8129], [8141, 8143], -         [8148, 8149], [8156, 8159], [8173, 8177], [8189, 8303], [8306, 8307], [8314, 8318], -         [8330, 8335], [8341, 8449], [8451, 8454], [8456, 8457], [8470, 8472], [8478, 8483], -         [8506, 8507], [8512, 8516], [8522, 8525], [8586, 9311], [9372, 9449], [9472, 10101], -         [10132, 11263], [11493, 11498], [11503, 11516], [11518, 11519], [11558, 11567], -         [11622, 11630], [11632, 11647], [11671, 11679], [11743, 11822], [11824, 12292], -         [12296, 12320], [12330, 12336], [12342, 12343], [12349, 12352], [12439, 12444], -         [12544, 12548], [12590, 12592], [12687, 12689], [12694, 12703], [12728, 12783], -         [12800, 12831], [12842, 12880], [12896, 12927], [12938, 12976], [12992, 13311], -         [19894, 19967], [40908, 40959], [42125, 42191], [42238, 42239], [42509, 42511], -         [42540, 42559], [42592, 42593], [42607, 42622], [42648, 42655], [42736, 42774], -         [42784, 42785], [42889, 42890], [42893, 43002], [43043, 43055], [43062, 43071], -         [43124, 43137], [43188, 43215], [43226, 43249], [43256, 43258], [43260, 43263], -         [43302, 43311], [43335, 43359], [43389, 43395], [43443, 43470], [43482, 43519], -         [43561, 43583], [43596, 43599], [43610, 43615], [43639, 43641], [43643, 43647], -         [43698, 43700], [43703, 43704], [43710, 43711], [43715, 43738], [43742, 43967], -         [44003, 44015], [44026, 44031], [55204, 55215], [55239, 55242], [55292, 55295], -         [57344, 63743], [64046, 64047], [64110, 64111], [64218, 64255], [64263, 64274], -         [64280, 64284], [64434, 64466], [64830, 64847], [64912, 64913], [64968, 65007], -         [65020, 65135], [65277, 65295], [65306, 65312], [65339, 65344], [65371, 65381], -         [65471, 65473], [65480, 65481], [65488, 65489], [65496, 65497]]; -    for (i = 0; i < ranges.length; i++) { -        start = ranges[i][0]; -        end = ranges[i][1]; -        for (j = start; j <= end; j++) { -            result[j] = true; -        } -    } -    return result; -})(); - -function splitQuery(query) { -    var result = []; -    var start = -1; -    for (var i = 0; i < query.length; i++) { -        if (splitChars[query.charCodeAt(i)]) { -            if (start !== -1) { -                result.push(query.slice(start, i)); -                start = -1; -            } -        } else if (start === -1) { -            start = i; -        } -    } -    if (start !== -1) { -        result.push(query.slice(start)); -    } -    return result; -} - - diff --git a/v7.1.2/_static/searchtools.js b/v7.1.2/_static/searchtools.js index 0a44e858..ac4d5861 100644 --- a/v7.1.2/_static/searchtools.js +++ b/v7.1.2/_static/searchtools.js @@ -8,18 +8,20 @@   * :license: BSD, see LICENSE for details.   *   */ +"use strict"; -if (!Scorer) { -  /** -   * Simple result scoring code. -   */ +/** + * Simple result scoring code. + */ +if (typeof Scorer === "undefined") {    var Scorer = {      // Implement the following function to further tweak the score for each result -    // The function takes a result array [filename, title, anchor, descr, score] +    // The function takes a result array [docname, title, anchor, descr, score, filename]      // and returns the new score.      /* -    score: function(result) { -      return result[4]; +    score: result => { +      const [docname, title, anchor, descr, score, filename] = result +      return score      },      */ @@ -28,9 +30,11 @@ if (!Scorer) {      // or matches in the last dotted part of the object name      objPartialMatch: 6,      // Additive scores depending on the priority of the object -    objPrio: {0:  15,   // used to be importantResults -              1:  5,   // used to be objectResults -              2: -5},  // used to be unimportantResults +    objPrio: { +      0: 15, // used to be importantResults +      1: 5, // used to be objectResults +      2: -5, // used to be unimportantResults +    },      //  Used when the priority is not in the mapping.      objPrioDefault: 0, @@ -39,452 +43,455 @@ if (!Scorer) {      partialTitle: 7,      // query found in terms      term: 5, -    partialTerm: 2 +    partialTerm: 2,    };  } -if (!splitQuery) { -  function splitQuery(query) { -    return query.split(/\s+/); +const _removeChildren = (element) => { +  while (element && element.lastChild) element.removeChild(element.lastChild); +}; + +/** + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#escaping + */ +const _escapeRegExp = (string) => +  string.replace(/[.*+\-?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string + +const _displayItem = (item, highlightTerms, searchTerms) => { +  const docBuilder = DOCUMENTATION_OPTIONS.BUILDER; +  const docUrlRoot = DOCUMENTATION_OPTIONS.URL_ROOT; +  const docFileSuffix = DOCUMENTATION_OPTIONS.FILE_SUFFIX; +  const docLinkSuffix = DOCUMENTATION_OPTIONS.LINK_SUFFIX; +  const showSearchSummary = DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY; + +  const [docName, title, anchor, descr] = item; + +  let listItem = document.createElement("li"); +  let requestUrl; +  let linkUrl; +  if (docBuilder === "dirhtml") { +    // dirhtml builder +    let dirname = docName + "/"; +    if (dirname.match(/\/index\/$/)) +      dirname = dirname.substring(0, dirname.length - 6); +    else if (dirname === "index/") dirname = ""; +    requestUrl = docUrlRoot + dirname; +    linkUrl = requestUrl; +  } else { +    // normal html builders +    requestUrl = docUrlRoot + docName + docFileSuffix; +    linkUrl = docName + docLinkSuffix; +  } +  const params = new URLSearchParams(); +  params.set("highlight", [...highlightTerms].join(" ")); +  let linkEl = listItem.appendChild(document.createElement("a")); +  linkEl.href = linkUrl + "?" + params.toString() + anchor; +  linkEl.innerHTML = title; +  if (descr) +    listItem.appendChild(document.createElement("span")).innerText = +      " (" + descr + ")"; +  else if (showSearchSummary) +    fetch(requestUrl) +      .then((responseData) => responseData.text()) +      .then((data) => { +        if (data) +          listItem.appendChild( +            Search.makeSearchSummary(data, searchTerms, highlightTerms) +          ); +      }); +  Search.output.appendChild(listItem); +}; +const _finishSearch = (resultCount) => { +  Search.stopPulse(); +  Search.title.innerText = _("Search Results"); +  if (!resultCount) +    Search.status.innerText = Documentation.gettext( +      "Your search did not match any documents. Please make sure that all words are spelled correctly and that you've selected enough categories." +    ); +  else +    Search.status.innerText = _( +      `Search finished, found ${resultCount} page(s) matching the search query.` +    ); +}; +const _displayNextItem = ( +  results, +  resultCount, +  highlightTerms, +  searchTerms +) => { +  // results left, load the summary and display it +  // this is intended to be dynamic (don't sub resultsCount) +  if (results.length) { +    _displayItem(results.pop(), highlightTerms, searchTerms); +    setTimeout( +      () => _displayNextItem(results, resultCount, highlightTerms, searchTerms), +      5 +    );    } +  // search finished, update title and status message +  else _finishSearch(resultCount); +}; + +/** + * Default splitQuery function. Can be overridden in ``sphinx.search`` with a + * custom function per language. + * + * The regular expression works by splitting the string on consecutive characters + * that are not Unicode letters, numbers, underscores, or emoji characters. + * This is the same as ``\W+`` in Python, preserving the surrogate pair area. + */ +if (typeof splitQuery === "undefined") { +  var splitQuery = (query) => query +      .split(/[^\p{Letter}\p{Number}_\p{Emoji_Presentation}]+/gu) +      .filter(term => term)  // remove remaining empty strings  }  /**   * Search Module   */ -var Search = { - -  _index : null, -  _queued_query : null, -  _pulse_status : -1, - -  htmlToText : function(htmlString) { -      var virtualDocument = document.implementation.createHTMLDocument('virtual'); -      var htmlElement = $(htmlString, virtualDocument); -      htmlElement.find('.headerlink').remove(); -      docContent = htmlElement.find('[role=main]')[0]; -      if(docContent === undefined) { -          console.warn("Content block not found. Sphinx search tries to obtain it " + -                       "via '[role=main]'. Could you check your theme or template."); -          return ""; -      } -      return docContent.textContent || docContent.innerText; +const Search = { +  _index: null, +  _queued_query: null, +  _pulse_status: -1, + +  htmlToText: (htmlString) => { +    const htmlElement = document +      .createRange() +      .createContextualFragment(htmlString); +    _removeChildren(htmlElement.querySelectorAll(".headerlink")); +    const docContent = htmlElement.querySelector('[role="main"]'); +    if (docContent !== undefined) return docContent.textContent; +    console.warn( +      "Content block not found. Sphinx search tries to obtain it via '[role=main]'. Could you check your theme or template." +    ); +    return "";    }, -  init : function() { -      var params = $.getQueryParameters(); -      if (params.q) { -          var query = params.q[0]; -          $('input[name="q"]')[0].value = query; -          this.performSearch(query); -      } +  init: () => { +    const query = new URLSearchParams(window.location.search).get("q"); +    document +      .querySelectorAll('input[name="q"]') +      .forEach((el) => (el.value = query)); +    if (query) Search.performSearch(query);    }, -  loadIndex : function(url) { -    $.ajax({type: "GET", url: url, data: null, -            dataType: "script", cache: true, -            complete: function(jqxhr, textstatus) { -              if (textstatus != "success") { -                document.getElementById("searchindexloader").src = url; -              } -            }}); -  }, +  loadIndex: (url) => +    (document.body.appendChild(document.createElement("script")).src = url), -  setIndex : function(index) { -    var q; -    this._index = index; -    if ((q = this._queued_query) !== null) { -      this._queued_query = null; -      Search.query(q); +  setIndex: (index) => { +    Search._index = index; +    if (Search._queued_query !== null) { +      const query = Search._queued_query; +      Search._queued_query = null; +      Search.query(query);      }    }, -  hasIndex : function() { -      return this._index !== null; -  }, +  hasIndex: () => Search._index !== null, -  deferQuery : function(query) { -      this._queued_query = query; -  }, +  deferQuery: (query) => (Search._queued_query = query), -  stopPulse : function() { -      this._pulse_status = 0; -  }, +  stopPulse: () => (Search._pulse_status = -1), -  startPulse : function() { -    if (this._pulse_status >= 0) -        return; -    function pulse() { -      var i; +  startPulse: () => { +    if (Search._pulse_status >= 0) return; + +    const pulse = () => {        Search._pulse_status = (Search._pulse_status + 1) % 4; -      var dotString = ''; -      for (i = 0; i < Search._pulse_status; i++) -        dotString += '.'; -      Search.dots.text(dotString); -      if (Search._pulse_status > -1) -        window.setTimeout(pulse, 500); -    } +      Search.dots.innerText = ".".repeat(Search._pulse_status); +      if (Search._pulse_status >= 0) window.setTimeout(pulse, 500); +    };      pulse();    },    /**     * perform a search for something (or wait until index is loaded)     */ -  performSearch : function(query) { +  performSearch: (query) => {      // create the required interface elements -    this.out = $('#search-results'); -    this.title = $('<h2>' + _('Searching') + '</h2>').appendTo(this.out); -    this.dots = $('<span></span>').appendTo(this.title); -    this.status = $('<p class="search-summary"> </p>').appendTo(this.out); -    this.output = $('<ul class="search"/>').appendTo(this.out); - -    $('#search-progress').text(_('Preparing search...')); -    this.startPulse(); +    const searchText = document.createElement("h2"); +    searchText.textContent = _("Searching"); +    const searchSummary = document.createElement("p"); +    searchSummary.classList.add("search-summary"); +    searchSummary.innerText = ""; +    const searchList = document.createElement("ul"); +    searchList.classList.add("search"); + +    const out = document.getElementById("search-results"); +    Search.title = out.appendChild(searchText); +    Search.dots = Search.title.appendChild(document.createElement("span")); +    Search.status = out.appendChild(searchSummary); +    Search.output = out.appendChild(searchList); + +    const searchProgress = document.getElementById("search-progress"); +    // Some themes don't use the search progress node +    if (searchProgress) { +      searchProgress.innerText = _("Preparing search..."); +    } +    Search.startPulse();      // index already loaded, the browser was quick! -    if (this.hasIndex()) -      this.query(query); -    else -      this.deferQuery(query); +    if (Search.hasIndex()) Search.query(query); +    else Search.deferQuery(query);    },    /**     * execute search (requires search index to be loaded)     */ -  query : function(query) { -    var i; - -    // stem the searchterms and add them to the correct list -    var stemmer = new Stemmer(); -    var searchterms = []; -    var excluded = []; -    var hlterms = []; -    var tmp = splitQuery(query); -    var objectterms = []; -    for (i = 0; i < tmp.length; i++) { -      if (tmp[i] !== "") { -          objectterms.push(tmp[i].toLowerCase()); -      } +  query: (query) => { +    // stem the search terms and add them to the correct list +    const stemmer = new Stemmer(); +    const searchTerms = new Set(); +    const excludedTerms = new Set(); +    const highlightTerms = new Set(); +    const objectTerms = new Set(splitQuery(query.toLowerCase().trim())); +    splitQuery(query.trim()).forEach((queryTerm) => { +      const queryTermLower = queryTerm.toLowerCase(); + +      // maybe skip this "word" +      // stopwords array is from language_data.js +      if ( +        stopwords.indexOf(queryTermLower) !== -1 || +        queryTerm.match(/^\d+$/) +      ) +        return; -      if ($u.indexOf(stopwords, tmp[i].toLowerCase()) != -1 || tmp[i] === "") { -        // skip this "word" -        continue; -      }        // stem the word -      var word = stemmer.stemWord(tmp[i].toLowerCase()); -      var toAppend; +      let word = stemmer.stemWord(queryTermLower);        // select the correct list -      if (word[0] == '-') { -        toAppend = excluded; -        word = word.substr(1); -      } +      if (word[0] === "-") excludedTerms.add(word.substr(1));        else { -        toAppend = searchterms; -        hlterms.push(tmp[i].toLowerCase()); +        searchTerms.add(word); +        highlightTerms.add(queryTermLower);        } -      // only add if not already in the list -      if (!$u.contains(toAppend, word)) -        toAppend.push(word); -    } -    var highlightstring = '?highlight=' + $.urlencode(hlterms.join(" ")); - -    // console.debug('SEARCH: searching for:'); -    // console.info('required: ', searchterms); -    // console.info('excluded: ', excluded); +    }); -    // prepare search -    var terms = this._index.terms; -    var titleterms = this._index.titleterms; +    // console.debug("SEARCH: searching for:"); +    // console.info("required: ", [...searchTerms]); +    // console.info("excluded: ", [...excludedTerms]); -    // array of [filename, title, anchor, descr, score] -    var results = []; -    $('#search-progress').empty(); +    // array of [docname, title, anchor, descr, score, filename] +    let results = []; +    _removeChildren(document.getElementById("search-progress"));      // lookup as object -    for (i = 0; i < objectterms.length; i++) { -      var others = [].concat(objectterms.slice(0, i), -                             objectterms.slice(i+1, objectterms.length)); -      results = results.concat(this.performObjectSearch(objectterms[i], others)); -    } +    objectTerms.forEach((term) => +      results.push(...Search.performObjectSearch(term, objectTerms)) +    );      // lookup as search terms in fulltext -    results = results.concat(this.performTermsSearch(searchterms, excluded, terms, titleterms)); +    results.push(...Search.performTermsSearch(searchTerms, excludedTerms));      // let the scorer override scores with a custom scoring function -    if (Scorer.score) { -      for (i = 0; i < results.length; i++) -        results[i][4] = Scorer.score(results[i]); -    } +    if (Scorer.score) results.forEach((item) => (item[4] = Scorer.score(item)));      // now sort the results by score (in opposite order of appearance, since the      // display function below uses pop() to retrieve items) and then      // alphabetically -    results.sort(function(a, b) { -      var left = a[4]; -      var right = b[4]; -      if (left > right) { -        return 1; -      } else if (left < right) { -        return -1; -      } else { +    results.sort((a, b) => { +      const leftScore = a[4]; +      const rightScore = b[4]; +      if (leftScore === rightScore) {          // same score: sort alphabetically -        left = a[1].toLowerCase(); -        right = b[1].toLowerCase(); -        return (left > right) ? -1 : ((left < right) ? 1 : 0); +        const leftTitle = a[1].toLowerCase(); +        const rightTitle = b[1].toLowerCase(); +        if (leftTitle === rightTitle) return 0; +        return leftTitle > rightTitle ? -1 : 1; // inverted is intentional        } +      return leftScore > rightScore ? 1 : -1;      }); +    // remove duplicate search results +    // note the reversing of results, so that in the case of duplicates, the highest-scoring entry is kept +    let seen = new Set(); +    results = results.reverse().reduce((acc, result) => { +      let resultStr = result.slice(0, 4).concat([result[5]]).map(v => String(v)).join(','); +      if (!seen.has(resultStr)) { +        acc.push(result); +        seen.add(resultStr); +      } +      return acc; +    }, []); + +    results = results.reverse(); +      // for debugging      //Search.lastresults = results.slice();  // a copy -    //console.info('search results:', Search.lastresults); +    // console.info("search results:", Search.lastresults);      // print the results -    var resultCount = results.length; -    function displayNextItem() { -      // results left, load the summary and display it -      if (results.length) { -        var item = results.pop(); -        var listItem = $('<li></li>'); -        var requestUrl = ""; -        var linkUrl = ""; -        if (DOCUMENTATION_OPTIONS.BUILDER === 'dirhtml') { -          // dirhtml builder -          var dirname = item[0] + '/'; -          if (dirname.match(/\/index\/$/)) { -            dirname = dirname.substring(0, dirname.length-6); -          } else if (dirname == 'index/') { -            dirname = ''; -          } -          requestUrl = DOCUMENTATION_OPTIONS.URL_ROOT + dirname; -          linkUrl = requestUrl; - -        } else { -          // normal html builders -          requestUrl = DOCUMENTATION_OPTIONS.URL_ROOT + item[0] + DOCUMENTATION_OPTIONS.FILE_SUFFIX; -          linkUrl = item[0] + DOCUMENTATION_OPTIONS.LINK_SUFFIX; -        } -        listItem.append($('<a/>').attr('href', -            linkUrl + -            highlightstring + item[2]).html(item[1])); -        if (item[3]) { -          listItem.append($('<span> (' + item[3] + ')</span>')); -          Search.output.append(listItem); -          setTimeout(function() { -            displayNextItem(); -          }, 5); -        } else if (DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY) { -          $.ajax({url: requestUrl, -                  dataType: "text", -                  complete: function(jqxhr, textstatus) { -                    var data = jqxhr.responseText; -                    if (data !== '' && data !== undefined) { -                      var summary = Search.makeSearchSummary(data, searchterms, hlterms); -                      if (summary) { -                        listItem.append(summary); -                      } -                    } -                    Search.output.append(listItem); -                    setTimeout(function() { -                      displayNextItem(); -                    }, 5); -                  }}); -        } else { -          // just display title -          Search.output.append(listItem); -          setTimeout(function() { -            displayNextItem(); -          }, 5); -        } -      } -      // search finished, update title and status message -      else { -        Search.stopPulse(); -        Search.title.text(_('Search Results')); -        if (!resultCount) -          Search.status.text(_('Your search did not match any documents. Please make sure that all words are spelled correctly and that you\'ve selected enough categories.')); -        else -            Search.status.text(_('Search finished, found %s page(s) matching the search query.').replace('%s', resultCount)); -        Search.status.fadeIn(500); -      } -    } -    displayNextItem(); +    _displayNextItem(results, results.length, highlightTerms, searchTerms);    },    /**     * search for object names     */ -  performObjectSearch : function(object, otherterms) { -    var filenames = this._index.filenames; -    var docnames = this._index.docnames; -    var objects = this._index.objects; -    var objnames = this._index.objnames; -    var titles = this._index.titles; - -    var i; -    var results = []; - -    for (var prefix in objects) { -      for (var iMatch = 0; iMatch != objects[prefix].length; ++iMatch) { -        var match = objects[prefix][iMatch]; -        var name = match[4]; -        var fullname = (prefix ? prefix + '.' : '') + name; -        var fullnameLower = fullname.toLowerCase() -        if (fullnameLower.indexOf(object) > -1) { -          var score = 0; -          var parts = fullnameLower.split('.'); -          // check for different match types: exact matches of full name or -          // "last name" (i.e. last dotted part) -          if (fullnameLower == object || parts[parts.length - 1] == object) { -            score += Scorer.objNameMatch; -          // matches in last name -          } else if (parts[parts.length - 1].indexOf(object) > -1) { -            score += Scorer.objPartialMatch; -          } -          var objname = objnames[match[1]][2]; -          var title = titles[match[0]]; -          // If more than one term searched for, we require other words to be -          // found in the name/title/description -          if (otherterms.length > 0) { -            var haystack = (prefix + ' ' + name + ' ' + -                            objname + ' ' + title).toLowerCase(); -            var allfound = true; -            for (i = 0; i < otherterms.length; i++) { -              if (haystack.indexOf(otherterms[i]) == -1) { -                allfound = false; -                break; -              } -            } -            if (!allfound) { -              continue; -            } -          } -          var descr = objname + _(', in ') + title; - -          var anchor = match[3]; -          if (anchor === '') -            anchor = fullname; -          else if (anchor == '-') -            anchor = objnames[match[1]][1] + '-' + fullname; -          // add custom score for some objects according to scorer -          if (Scorer.objPrio.hasOwnProperty(match[2])) { -            score += Scorer.objPrio[match[2]]; -          } else { -            score += Scorer.objPrioDefault; -          } -          results.push([docnames[match[0]], fullname, '#'+anchor, descr, score, filenames[match[0]]]); -        } +  performObjectSearch: (object, objectTerms) => { +    const filenames = Search._index.filenames; +    const docNames = Search._index.docnames; +    const objects = Search._index.objects; +    const objNames = Search._index.objnames; +    const titles = Search._index.titles; + +    const results = []; + +    const objectSearchCallback = (prefix, match) => { +      const name = match[4] +      const fullname = (prefix ? prefix + "." : "") + name; +      const fullnameLower = fullname.toLowerCase(); +      if (fullnameLower.indexOf(object) < 0) return; + +      let score = 0; +      const parts = fullnameLower.split("."); + +      // check for different match types: exact matches of full name or +      // "last name" (i.e. last dotted part) +      if (fullnameLower === object || parts.slice(-1)[0] === object) +        score += Scorer.objNameMatch; +      else if (parts.slice(-1)[0].indexOf(object) > -1) +        score += Scorer.objPartialMatch; // matches in last name + +      const objName = objNames[match[1]][2]; +      const title = titles[match[0]]; + +      // If more than one term searched for, we require other words to be +      // found in the name/title/description +      const otherTerms = new Set(objectTerms); +      otherTerms.delete(object); +      if (otherTerms.size > 0) { +        const haystack = `${prefix} ${name} ${objName} ${title}`.toLowerCase(); +        if ( +          [...otherTerms].some((otherTerm) => haystack.indexOf(otherTerm) < 0) +        ) +          return;        } -    } +      let anchor = match[3]; +      if (anchor === "") anchor = fullname; +      else if (anchor === "-") anchor = objNames[match[1]][1] + "-" + fullname; + +      const descr = objName + _(", in ") + title; + +      // add custom score for some objects according to scorer +      if (Scorer.objPrio.hasOwnProperty(match[2])) +        score += Scorer.objPrio[match[2]]; +      else score += Scorer.objPrioDefault; + +      results.push([ +        docNames[match[0]], +        fullname, +        "#" + anchor, +        descr, +        score, +        filenames[match[0]], +      ]); +    }; +    Object.keys(objects).forEach((prefix) => +      objects[prefix].forEach((array) => +        objectSearchCallback(prefix, array) +      ) +    );      return results;    },    /** -   * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions -   */ -  escapeRegExp : function(string) { -    return string.replace(/[.*+\-?^${}()|[\]\\]/g, '\\$&'); // $& means the whole matched string -  }, - -  /**     * search for full-text terms in the index     */ -  performTermsSearch : function(searchterms, excluded, terms, titleterms) { -    var docnames = this._index.docnames; -    var filenames = this._index.filenames; -    var titles = this._index.titles; +  performTermsSearch: (searchTerms, excludedTerms) => { +    // prepare search +    const terms = Search._index.terms; +    const titleTerms = Search._index.titleterms; +    const docNames = Search._index.docnames; +    const filenames = Search._index.filenames; +    const titles = Search._index.titles; -    var i, j, file; -    var fileMap = {}; -    var scoreMap = {}; -    var results = []; +    const scoreMap = new Map(); +    const fileMap = new Map();      // perform the search on the required terms -    for (i = 0; i < searchterms.length; i++) { -      var word = searchterms[i]; -      var files = []; -      var _o = [ -        {files: terms[word], score: Scorer.term}, -        {files: titleterms[word], score: Scorer.title} +    searchTerms.forEach((word) => { +      const files = []; +      const arr = [ +        { files: terms[word], score: Scorer.term }, +        { files: titleTerms[word], score: Scorer.title },        ];        // add support for partial matches        if (word.length > 2) { -        var word_regex = this.escapeRegExp(word); -        for (var w in terms) { -          if (w.match(word_regex) && !terms[word]) { -            _o.push({files: terms[w], score: Scorer.partialTerm}) -          } -        } -        for (var w in titleterms) { -          if (w.match(word_regex) && !titleterms[word]) { -              _o.push({files: titleterms[w], score: Scorer.partialTitle}) -          } -        } +        const escapedWord = _escapeRegExp(word); +        Object.keys(terms).forEach((term) => { +          if (term.match(escapedWord) && !terms[word]) +            arr.push({ files: terms[term], score: Scorer.partialTerm }); +        }); +        Object.keys(titleTerms).forEach((term) => { +          if (term.match(escapedWord) && !titleTerms[word]) +            arr.push({ files: titleTerms[word], score: Scorer.partialTitle }); +        });        }        // no match but word was a required one -      if ($u.every(_o, function(o){return o.files === undefined;})) { -        break; -      } +      if (arr.every((record) => record.files === undefined)) return; +        // found search word in contents -      $u.each(_o, function(o) { -        var _files = o.files; -        if (_files === undefined) -          return - -        if (_files.length === undefined) -          _files = [_files]; -        files = files.concat(_files); - -        // set score for the word in each file to Scorer.term -        for (j = 0; j < _files.length; j++) { -          file = _files[j]; -          if (!(file in scoreMap)) -            scoreMap[file] = {}; -          scoreMap[file][word] = o.score; -        } +      arr.forEach((record) => { +        if (record.files === undefined) return; + +        let recordFiles = record.files; +        if (recordFiles.length === undefined) recordFiles = [recordFiles]; +        files.push(...recordFiles); + +        // set score for the word in each file +        recordFiles.forEach((file) => { +          if (!scoreMap.has(file)) scoreMap.set(file, {}); +          scoreMap.get(file)[word] = record.score; +        });        });        // create the mapping -      for (j = 0; j < files.length; j++) { -        file = files[j]; -        if (file in fileMap && fileMap[file].indexOf(word) === -1) -          fileMap[file].push(word); -        else -          fileMap[file] = [word]; -      } -    } +      files.forEach((file) => { +        if (fileMap.has(file) && fileMap.get(file).indexOf(word) === -1) +          fileMap.get(file).push(word); +        else fileMap.set(file, [word]); +      }); +    });      // now check if the files don't contain excluded terms -    for (file in fileMap) { -      var valid = true; - +    const results = []; +    for (const [file, wordList] of fileMap) {        // check if all requirements are matched -      var filteredTermCount = // as search terms with length < 3 are discarded: ignore -        searchterms.filter(function(term){return term.length > 2}).length + +      // as search terms with length < 3 are discarded +      const filteredTermCount = [...searchTerms].filter( +        (term) => term.length > 2 +      ).length;        if ( -        fileMap[file].length != searchterms.length && -        fileMap[file].length != filteredTermCount -      ) continue; +        wordList.length !== searchTerms.size && +        wordList.length !== filteredTermCount +      ) +        continue;        // ensure that none of the excluded terms is in the search result -      for (i = 0; i < excluded.length; i++) { -        if (terms[excluded[i]] == file || -            titleterms[excluded[i]] == file || -            $u.contains(terms[excluded[i]] || [], file) || -            $u.contains(titleterms[excluded[i]] || [], file)) { -          valid = false; -          break; -        } -      } +      if ( +        [...excludedTerms].some( +          (term) => +            terms[term] === file || +            titleTerms[term] === file || +            (terms[term] || []).includes(file) || +            (titleTerms[term] || []).includes(file) +        ) +      ) +        break; -      // if we have still a valid result we can add it to the result list -      if (valid) { -        // select one (max) score for the file. -        // for better ranking, we should calculate ranking by using words statistics like basic tf-idf... -        var score = $u.max($u.map(fileMap[file], function(w){return scoreMap[file][w]})); -        results.push([docnames[file], titles[file], '', null, score, filenames[file]]); -      } +      // select one (max) score for the file. +      const score = Math.max(...wordList.map((w) => scoreMap.get(file)[w])); +      // add result to the result list +      results.push([ +        docNames[file], +        titles[file], +        "", +        null, +        score, +        filenames[file], +      ]);      }      return results;    }, @@ -492,34 +499,33 @@ var Search = {    /**     * helper function to return a node containing the     * search summary for a given text. keywords is a list -   * of stemmed words, hlwords is the list of normal, unstemmed +   * of stemmed words, highlightWords is the list of normal, unstemmed     * words. the first one is used to find the occurrence, the     * latter for highlighting it.     */ -  makeSearchSummary : function(htmlText, keywords, hlwords) { -    var text = Search.htmlToText(htmlText); -    if (text == "") { -      return null; -    } -    var textLower = text.toLowerCase(); -    var start = 0; -    $.each(keywords, function() { -      var i = textLower.indexOf(this.toLowerCase()); -      if (i > -1) -        start = i; -    }); -    start = Math.max(start - 120, 0); -    var excerpt = ((start > 0) ? '...' : '') + -      $.trim(text.substr(start, 240)) + -      ((start + 240 - text.length) ? '...' : ''); -    var rv = $('<p class="context"></p>').text(excerpt); -    $.each(hlwords, function() { -      rv = rv.highlightText(this, 'highlighted'); -    }); -    return rv; -  } +  makeSearchSummary: (htmlText, keywords, highlightWords) => { +    const text = Search.htmlToText(htmlText).toLowerCase(); +    if (text === "") return null; + +    const actualStartPosition = [...keywords] +      .map((k) => text.indexOf(k.toLowerCase())) +      .filter((i) => i > -1) +      .slice(-1)[0]; +    const startWithContext = Math.max(actualStartPosition - 120, 0); + +    const top = startWithContext === 0 ? "" : "..."; +    const tail = startWithContext + 240 < text.length ? "..." : ""; + +    let summary = document.createElement("div"); +    summary.classList.add("context"); +    summary.innerText = top + text.substr(startWithContext, 240).trim() + tail; + +    highlightWords.forEach((highlightWord) => +      _highlightText(summary, highlightWord, "highlighted") +    ); + +    return summary; +  },  }; -$(document).ready(function() { -  Search.init(); -}); +_ready(Search.init); diff --git a/v7.1.2/changelog.html b/v7.1.2/changelog.html index c3131f34..817101bd 100644 --- a/v7.1.2/changelog.html +++ b/v7.1.2/changelog.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /><link rel="prev" title="site_api" href="output/botcore.site_api.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Changelog - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="changelog"> -<h1>Changelog<a class="headerlink" href="#changelog" title="Permalink to this headline">#</a></h1> +<h1>Changelog<a class="headerlink" href="#changelog" title="Permalink to this heading">#</a></h1>  <section id="Next 7.x feature release">  <h2 style="margin-bottom: 0.3em;"><a class="reference external" href="https://github.com/python-discord/bot-core/releases/tag/vmaster">Next 7.x feature release</a></h2><ul class="simple">  <li><p>[<span style="color: #4070A0;">Support</span>]<span> </span><a class="reference external" href="https://github.com/python-discord/bot-core/issues/79">#79</a><span>:</span> Restore on-site changelog.</p></li> @@ -476,6 +476,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.2/genindex.html b/v7.1.2/genindex.html index 4fde689b..e1a3af9c 100644 --- a/v7.1.2/genindex.html +++ b/v7.1.2/genindex.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="#" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Index - Bot Core v7.1.2</title> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Index - Bot Core v7.1.2</title>  <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" /> @@ -700,6 +700,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.2/index.html b/v7.1.2/index.html index 65370772..d3b541a2 100644 --- a/v7.1.2/index.html +++ b/v7.1.2/index.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /><link rel="next" title="Botcore" href="output/botcore.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,10 +271,10 @@          </div>          <article role="main">            <section id="bot-core-project-documentation"> -<h1>Bot Core Project Documentation<a class="headerlink" href="#bot-core-project-documentation" title="Permalink to this headline">#</a></h1> +<h1>Bot Core Project Documentation<a class="headerlink" href="#bot-core-project-documentation" title="Permalink to this heading">#</a></h1>  </section>  <section id="reference"> -<h1>Reference<a class="headerlink" href="#reference" title="Permalink to this headline">#</a></h1> +<h1>Reference<a class="headerlink" href="#reference" title="Permalink to this heading">#</a></h1>  <div class="toctree-wrapper compound">  <p class="caption" role="heading"><span class="caption-text">Modules:</span></p>  <ul> @@ -300,7 +300,7 @@  </div>  </section>  <section id="extras"> -<h1>Extras<a class="headerlink" href="#extras" title="Permalink to this headline">#</a></h1> +<h1>Extras<a class="headerlink" href="#extras" title="Permalink to this heading">#</a></h1>  <ul class="simple">  <li><p><a class="reference internal" href="genindex.html"><span class="std std-ref">Index</span></a></p></li>  <li><p><a class="reference internal" href="search.html"><span class="std std-ref">Search Page</span></a></p></li> @@ -353,6 +353,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.2/index_redirect.html b/v7.1.2/index_redirect.html index 99c06a8e..1325e322 100644 --- a/v7.1.2/index_redirect.html +++ b/v7.1.2/index_redirect.html @@ -1,5 +1,5 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head>      <script>window.location.replace("./main/index.html")</script> @@ -7,7 +7,7 @@      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" /> @@ -57,6 +57,7 @@  <script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.2/output/botcore.async_stats.html b/v7.1.2/output/botcore.async_stats.html index a9496488..7d4f1554 100644 --- a/v7.1.2/output/botcore.async_stats.html +++ b/v7.1.2/output/botcore.async_stats.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="site_api" href="botcore.site_api.html" /><link rel="prev" title="scheduling" href="botcore.utils.scheduling.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>async_stats - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,12 +271,12 @@          </div>          <article role="main">            <section id="module-botcore.async_stats"> -<span id="async-stats"></span><h1>async_stats<a class="headerlink" href="#module-botcore.async_stats" title="Permalink to this headline">#</a></h1> +<span id="async-stats"></span><h1>async_stats<a class="headerlink" href="#module-botcore.async_stats" title="Permalink to this heading">#</a></h1>  <p>An async transport method for statsd communication.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.async_stats.AsyncStatsClient">  <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">AsyncStatsClient</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">loop</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">host</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">'localhost'</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">port</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">8125</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">prefix</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/88373772f264ee359d60072aea1578cbf50ff4ff/botcore/async_stats.py#L12-L55"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.async_stats.AsyncStatsClient" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-class docutils literal notranslate"><span class="pre">statsd.client.base.StatsClientBase</span></code></a></p> +<dd><p>Bases: <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-class docutils literal notranslate"><span class="pre">StatsClientBase</span></code></a></p>  <p>An async implementation of <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">statsd.client.base.StatsClientBase</span></code></a> that supports async stat communication.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.async_stats.AsyncStatsClient.__init__"> @@ -364,6 +364,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.2/output/botcore.exts.html b/v7.1.2/output/botcore.exts.html index 5f44ed5f..b65d5879 100644 --- a/v7.1.2/output/botcore.exts.html +++ b/v7.1.2/output/botcore.exts.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Utils" href="botcore.utils.html" /><link rel="prev" title="Botcore" href="botcore.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Exts - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.exts"> -<span id="exts"></span><h1>Exts<a class="headerlink" href="#module-botcore.exts" title="Permalink to this headline">#</a></h1> +<span id="exts"></span><h1>Exts<a class="headerlink" href="#module-botcore.exts" title="Permalink to this heading">#</a></h1>  <p>Reusable Discord cogs.</p>  </section> @@ -329,6 +329,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.2/output/botcore.html b/v7.1.2/output/botcore.html index 6742ab2c..7070cf2b 100644 --- a/v7.1.2/output/botcore.html +++ b/v7.1.2/output/botcore.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Exts" href="botcore.exts.html" /><link rel="prev" title="Bot Core Project Documentation" href="../index.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Botcore - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,12 +271,12 @@          </div>          <article role="main">            <section id="module-botcore"> -<span id="botcore"></span><h1>Botcore<a class="headerlink" href="#module-botcore" title="Permalink to this headline">#</a></h1> +<span id="botcore"></span><h1>Botcore<a class="headerlink" href="#module-botcore" title="Permalink to this heading">#</a></h1>  <p>Useful utilities and tools for Discord bot development.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.BotBase">  <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">BotBase</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">guild_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">allowed_roles</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">http_session</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">redis_session</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">api_client</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">statsd_url</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/88373772f264ee359d60072aea1578cbf50ff4ff/botcore/__init__.py#L36-L290"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Bot" title="(in discord.py v2.0.0a)"><code class="xref py py-class docutils literal notranslate"><span class="pre">discord.ext.commands.bot.Bot</span></code></a></p> +<dd><p>Bases: <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Bot" title="(in discord.py v2.0.0a)"><code class="xref py py-class docutils literal notranslate"><span class="pre">Bot</span></code></a></p>  <p>A sub-class that implements many common features that Python Discord bots use.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.__init__"> @@ -454,7 +454,7 @@ gateway event before giving up and thus not populating the cache for unavailable  </dd></dl>  <section id="subpackages"> -<h2>Subpackages<a class="headerlink" href="#subpackages" title="Permalink to this headline">#</a></h2> +<h2>Subpackages<a class="headerlink" href="#subpackages" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.exts.html">Exts</a></li> @@ -474,7 +474,7 @@ gateway event before giving up and thus not populating the cache for unavailable  </div>  </section>  <section id="submodules"> -<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this headline">#</a></h2> +<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.async_stats.html">async_stats</a></li> @@ -558,6 +558,7 @@ gateway event before giving up and thus not populating the cache for unavailable  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.2/output/botcore.site_api.html b/v7.1.2/output/botcore.site_api.html index 5e1ba0db..f3c15376 100644 --- a/v7.1.2/output/botcore.site_api.html +++ b/v7.1.2/output/botcore.site_api.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Changelog" href="../changelog.html" /><link rel="prev" title="async_stats" href="botcore.async_stats.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>site_api - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.site_api"> -<span id="site-api"></span><h1>site_api<a class="headerlink" href="#module-botcore.site_api" title="Permalink to this headline">#</a></h1> +<span id="site-api"></span><h1>site_api<a class="headerlink" href="#module-botcore.site_api" title="Permalink to this heading">#</a></h1>  <p>An API wrapper around the Site API.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.site_api.APIClient"> @@ -500,6 +500,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.2/output/botcore.utils.caching.html b/v7.1.2/output/botcore.utils.caching.html index 0aac42d7..fa098055 100644 --- a/v7.1.2/output/botcore.utils.caching.html +++ b/v7.1.2/output/botcore.utils.caching.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="channel" href="botcore.utils.channel.html" /><link rel="prev" title="Utils" href="botcore.utils.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>caching - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.caching"> -<span id="caching"></span><h1>caching<a class="headerlink" href="#module-botcore.utils.caching" title="Permalink to this headline">#</a></h1> +<span id="caching"></span><h1>caching<a class="headerlink" href="#module-botcore.utils.caching" title="Permalink to this heading">#</a></h1>  <p>Utilities related to custom caches.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.caching.AsyncCache"> @@ -377,6 +377,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.2/output/botcore.utils.channel.html b/v7.1.2/output/botcore.utils.channel.html index 477c536d..8d8f2206 100644 --- a/v7.1.2/output/botcore.utils.channel.html +++ b/v7.1.2/output/botcore.utils.channel.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="logging" href="botcore.utils.logging.html" /><link rel="prev" title="caching" href="botcore.utils.caching.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>channel - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.channel"> -<span id="channel"></span><h1>channel<a class="headerlink" href="#module-botcore.utils.channel" title="Permalink to this headline">#</a></h1> +<span id="channel"></span><h1>channel<a class="headerlink" href="#module-botcore.utils.channel" title="Permalink to this heading">#</a></h1>  <p>Useful helper functions for interacting with various discord channel objects.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.channel.get_or_fetch_channel"> @@ -377,6 +377,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.2/output/botcore.utils.html b/v7.1.2/output/botcore.utils.html index 5b5355b4..3731b37e 100644 --- a/v7.1.2/output/botcore.utils.html +++ b/v7.1.2/output/botcore.utils.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="caching" href="botcore.utils.caching.html" /><link rel="prev" title="Exts" href="botcore.exts.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Utils - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils"> -<span id="utils"></span><h1>Utils<a class="headerlink" href="#module-botcore.utils" title="Permalink to this headline">#</a></h1> +<span id="utils"></span><h1>Utils<a class="headerlink" href="#module-botcore.utils" title="Permalink to this heading">#</a></h1>  <p>Useful utilities and tools for Discord bot development.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.apply_monkey_patches"> @@ -310,7 +310,7 @@ that will act as top-level groups rather than being aliases of the command’s g  </dd></dl>  <section id="submodules"> -<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this headline">#</a></h2> +<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.utils.caching.html">caching</a></li> @@ -397,6 +397,7 @@ that will act as top-level groups rather than being aliases of the command’s g  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.2/output/botcore.utils.logging.html b/v7.1.2/output/botcore.utils.logging.html index 1037b53e..ad9a8a54 100644 --- a/v7.1.2/output/botcore.utils.logging.html +++ b/v7.1.2/output/botcore.utils.logging.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="members" href="botcore.utils.members.html" /><link rel="prev" title="channel" href="botcore.utils.channel.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>logging - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,12 +271,12 @@          </div>          <article role="main">            <section id="module-botcore.utils.logging"> -<span id="logging"></span><h1>logging<a class="headerlink" href="#module-botcore.utils.logging" title="Permalink to this headline">#</a></h1> +<span id="logging"></span><h1>logging<a class="headerlink" href="#module-botcore.utils.logging" title="Permalink to this heading">#</a></h1>  <p>Common logging related functions.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.logging.CustomLogger">  <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">CustomLogger</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">level</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">0</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/88373772f264ee359d60072aea1578cbf50ff4ff/botcore/utils/logging.py#L14-L33"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.logging.CustomLogger" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">logging.Logger</span></code></a></p> +<dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">Logger</span></code></a></p>  <p>Custom implementation of the <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">logging.Logger</span></code></a> class with an added <a class="reference internal" href="#botcore.utils.logging.CustomLogger.trace" title="botcore.utils.logging.CustomLogger.trace"><code class="xref py py-obj docutils literal notranslate"><span class="pre">trace</span></code></a> method.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.logging.CustomLogger.trace"> @@ -375,6 +375,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.2/output/botcore.utils.members.html b/v7.1.2/output/botcore.utils.members.html index 28beb288..8fbb5cd4 100644 --- a/v7.1.2/output/botcore.utils.members.html +++ b/v7.1.2/output/botcore.utils.members.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="regex" href="botcore.utils.regex.html" /><link rel="prev" title="logging" href="botcore.utils.logging.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>members - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.members"> -<span id="members"></span><h1>members<a class="headerlink" href="#module-botcore.utils.members" title="Permalink to this headline">#</a></h1> +<span id="members"></span><h1>members<a class="headerlink" href="#module-botcore.utils.members" title="Permalink to this heading">#</a></h1>  <p>Useful helper functions for interactin with <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/api.html#discord.Member" title="(in discord.py v2.0.0a)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">discord.Member</span></code></a> objects.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.members.get_or_fetch_member"> @@ -362,6 +362,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.2/output/botcore.utils.regex.html b/v7.1.2/output/botcore.utils.regex.html index d1e3e6a9..dfe6f1a7 100644 --- a/v7.1.2/output/botcore.utils.regex.html +++ b/v7.1.2/output/botcore.utils.regex.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="scheduling" href="botcore.utils.scheduling.html" /><link rel="prev" title="members" href="botcore.utils.members.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>regex - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.regex"> -<span id="regex"></span><h1>regex<a class="headerlink" href="#module-botcore.utils.regex" title="Permalink to this headline">#</a></h1> +<span id="regex"></span><h1>regex<a class="headerlink" href="#module-botcore.utils.regex" title="Permalink to this heading">#</a></h1>  <p>Common regular expressions.</p>  <dl class="py data">  <dt class="sig sig-object py" id="botcore.utils.regex.DISCORD_INVITE"> @@ -359,6 +359,7 @@ such as <a class="reference external" href="https://docs.python.org/3/library/ur  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.2/output/botcore.utils.scheduling.html b/v7.1.2/output/botcore.utils.scheduling.html index a8e4d366..22ebce25 100644 --- a/v7.1.2/output/botcore.utils.scheduling.html +++ b/v7.1.2/output/botcore.utils.scheduling.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="async_stats" href="botcore.async_stats.html" /><link rel="prev" title="regex" href="botcore.utils.regex.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>scheduling - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.scheduling"> -<span id="scheduling"></span><h1>scheduling<a class="headerlink" href="#module-botcore.utils.scheduling" title="Permalink to this headline">#</a></h1> +<span id="scheduling"></span><h1>scheduling<a class="headerlink" href="#module-botcore.utils.scheduling" title="Permalink to this heading">#</a></h1>  <p>Generic python scheduler.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.scheduling.Scheduler"> @@ -484,6 +484,7 @@ otherwise the running loop is used.</p>  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.2/py-modindex.html b/v7.1.2/py-modindex.html index 004914d5..5a31ecaa 100644 --- a/v7.1.2/py-modindex.html +++ b/v7.1.2/py-modindex.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Python Module Index - Bot Core v7.1.2</title> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Python Module Index - Bot Core v7.1.2</title>  <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" /> @@ -385,6 +385,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.2/search.html b/v7.1.2/search.html index 312af42e..1429366b 100644 --- a/v7.1.2/search.html +++ b/v7.1.2/search.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="#" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Search - Bot Core v7.1.2</title><link rel="stylesheet" type="text/css" href="_static/pygments.css" /> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Search - Bot Core v7.1.2</title><link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" />      <link rel="stylesheet" type="text/css" href="_static/changelog.css" /> @@ -315,6 +315,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.2/searchindex.js b/v7.1.2/searchindex.js index f95dfcf5..ac545305 100644 --- a/v7.1.2/searchindex.js +++ b/v7.1.2/searchindex.js @@ -1 +1 @@ -Search.setIndex({docnames:["changelog","index","output/botcore","output/botcore.async_stats","output/botcore.exts","output/botcore.site_api","output/botcore.utils","output/botcore.utils.caching","output/botcore.utils.channel","output/botcore.utils.logging","output/botcore.utils.members","output/botcore.utils.regex","output/botcore.utils.scheduling"],envversion:{"sphinx.domains.c":2,"sphinx.domains.changeset":1,"sphinx.domains.citation":1,"sphinx.domains.cpp":5,"sphinx.domains.index":1,"sphinx.domains.javascript":2,"sphinx.domains.math":2,"sphinx.domains.python":3,"sphinx.domains.rst":2,"sphinx.domains.std":2,"sphinx.ext.intersphinx":1,"sphinx.ext.todo":2,sphinx:56},filenames:["changelog.rst","index.rst","output/botcore.rst","output/botcore.async_stats.rst","output/botcore.exts.rst","output/botcore.site_api.rst","output/botcore.utils.rst","output/botcore.utils.caching.rst","output/botcore.utils.channel.rst","output/botcore.utils.logging.rst","output/botcore.utils.members.rst","output/botcore.utils.regex.rst","output/botcore.utils.scheduling.rst"],objects:{"":[[2,0,0,"-","botcore"]],"botcore.BotBase":[[2,2,1,"","__init__"],[2,2,1,"","add_cog"],[2,2,1,"","add_command"],[2,2,1,"","clear"],[2,2,1,"","close"],[2,2,1,"","load_extensions"],[2,2,1,"","log_to_dev_log"],[2,2,1,"","on_guild_available"],[2,2,1,"","on_guild_unavailable"],[2,2,1,"","ping_services"],[2,2,1,"","remove_command"],[2,2,1,"","setup_hook"],[2,2,1,"","wait_until_guild_available"]],"botcore.StartupError":[[2,2,1,"","__init__"]],"botcore.async_stats":[[3,1,1,"","AsyncStatsClient"]],"botcore.async_stats.AsyncStatsClient":[[3,2,1,"","__init__"],[3,2,1,"","create_socket"]],"botcore.site_api":[[5,1,1,"","APIClient"],[5,3,1,"","ResponseCodeError"]],"botcore.site_api.APIClient":[[5,2,1,"","__init__"],[5,2,1,"","close"],[5,2,1,"","delete"],[5,2,1,"","get"],[5,2,1,"","maybe_raise_for_status"],[5,2,1,"","patch"],[5,2,1,"","post"],[5,2,1,"","put"],[5,2,1,"","request"]],"botcore.site_api.ResponseCodeError":[[5,2,1,"","__init__"],[5,2,1,"","__str__"]],"botcore.utils":[[6,4,1,"","apply_monkey_patches"],[7,0,0,"-","caching"],[8,0,0,"-","channel"],[9,0,0,"-","logging"],[10,0,0,"-","members"],[11,0,0,"-","regex"],[12,0,0,"-","scheduling"],[6,4,1,"","unqualify"]],"botcore.utils.caching":[[7,1,1,"","AsyncCache"]],"botcore.utils.caching.AsyncCache":[[7,2,1,"","__call__"],[7,2,1,"","__init__"],[7,2,1,"","clear"]],"botcore.utils.channel":[[8,4,1,"","get_or_fetch_channel"],[8,4,1,"","is_in_category"]],"botcore.utils.logging":[[9,1,1,"","CustomLogger"],[9,4,1,"","get_logger"]],"botcore.utils.logging.CustomLogger":[[9,2,1,"","trace"]],"botcore.utils.members":[[10,4,1,"","get_or_fetch_member"],[10,4,1,"","handle_role_change"]],"botcore.utils.regex":[[11,5,1,"","DISCORD_INVITE"],[11,5,1,"","FORMATTED_CODE_REGEX"],[11,5,1,"","RAW_CODE_REGEX"]],"botcore.utils.scheduling":[[12,1,1,"","Scheduler"],[12,4,1,"","create_task"]],"botcore.utils.scheduling.Scheduler":[[12,2,1,"","__contains__"],[12,2,1,"","__init__"],[12,2,1,"","cancel"],[12,2,1,"","cancel_all"],[12,2,1,"","schedule"],[12,2,1,"","schedule_at"],[12,2,1,"","schedule_later"]],botcore:[[2,1,1,"","BotBase"],[2,3,1,"","StartupError"],[3,0,0,"-","async_stats"],[4,0,0,"-","exts"],[5,0,0,"-","site_api"],[6,0,0,"-","utils"]]},objnames:{"0":["py","module","Python module"],"1":["py","class","Python class"],"2":["py","method","Python method"],"3":["py","exception","Python exception"],"4":["py","function","Python function"],"5":["py","data","Python data"]},objtypes:{"0":"py:module","1":"py:class","2":"py:method","3":"py:exception","4":"py:function","5":"py:data"},terms:{"0":[0,7,9],"0a0":0,"1":[0,5,9],"10th":0,"12":0,"128":7,"14th":0,"17th":0,"18th":0,"19th":0,"2":[0,2,5],"2021":0,"2022":0,"204":5,"20th":0,"21st":0,"22nd":0,"24th":0,"25th":0,"26th":0,"29":0,"2nd":0,"3":0,"32":0,"34":0,"35":0,"37":0,"39":0,"3rd":0,"4":0,"403":6,"42":0,"4cbe8f5":0,"5":0,"54":0,"56":0,"5a06fa5":0,"5th":0,"6":0,"61":0,"63":0,"64":0,"65":0,"66":0,"68":0,"69":0,"7":[0,5],"72":0,"75":0,"78":0,"79":0,"8125":3,"987235d":0,"9th":0,"abstract":0,"break":0,"case":0,"class":[0,2,3,5,7,9,12],"do":8,"float":12,"function":[0,2,7,8,9,10,12],"import":0,"int":[2,3,7,8,12],"long":12,"na\u00efv":12,"new":[3,5,7,12],"public":0,"return":[0,2,3,5,6,7,8,9,10,12],"true":[5,9,12],A:[2,5,6,7,8,12],If:[2,5,12],It:6,No:5,Not:2,The:[2,3,5,6,7,8,9,10,12],To:[2,9],_:0,__call__:7,__contains__:12,__init__:[0,2,3,5,7,12],__str__:5,_guild_avail:0,abstracteventloop:[3,12],act:6,actual:0,ad:[0,6,9],add:[0,2],add_cog:2,add_command:2,add_rol:10,after:12,aiohttp:[0,2,5],alia:[2,6],alias:[2,6],all:[0,2,3,6,12],all_command:2,all_extens:2,allow:[0,2],allowed_rol:2,alpha:0,alreadi:12,also:[0,6],an:[0,2,3,5,6,7,8,9,12],ani:[5,11,12],api:[0,5,10],api_cli:[0,2],apicli:[0,2,5],appear:2,appli:[6,7],apply_monkey_patch:[0,6],april:0,ar:[2,7,11],arg:[2,9],arg_offset:7,argument:[5,6,7,9,10],around:5,async:[0,2,3,5,7,8,10],async_rediscach:2,async_stat:[1,2],asynccach:7,asyncio:[0,3,12],asyncresolv:0,asyncstatscli:[2,3],asyncstatsdcli:0,attempt:[2,8,10],attribut:6,authent:5,autogener:0,avail:[0,2],avoid:[0,2],await:[10,12],awar:12,back:0,base:[0,2,3,5,7,9,12],basic:0,becaus:2,becom:2,befor:[0,2,12],behaviour:0,being:6,between:0,block:[0,11],bool:[5,8,12],bot:[0,2,6,8],botbas:[0,2],botcor:[0,1],broke:0,bug:0,bump:0,cach:[0,2,6,8,10],calcul:12,call:[2,12],callabl:[7,10],can:[0,12],cancel:12,cancel_al:12,cannot:[0,2],captur:[0,11],categori:8,category_id:8,caus:[2,6],chang:[0,5],changelog:1,channel:[0,2,6],channel_id:8,charact:0,check:[5,8,12],chunk:0,ci:0,clear:[2,7],client:[0,2,3],clientrespons:5,clientsess:[2,5],close:[0,2,5,12],cloudflar:6,code:[0,11],cog:[0,2,4],command:[0,2,6,8],commit:0,common:[0,2,6,9,11],commun:3,connect:[0,2,3],connector:2,constructor:5,contain:12,content:5,core:0,coro:[10,12],coroutin:[7,10,12],correct:0,could:10,crash:0,creat:[0,2,3,7,12],create_datagram_endpoint:3,create_socket:[2,3],create_task:12,creation:0,current:12,custom:[0,7,9],customlogg:9,datetim:12,deadlock:2,deal:0,decemb:0,decor:7,delai:12,delet:[5,7],depend:8,deprec:0,detect:0,dev:2,develop:[2,6],dict:5,directli:0,discord:[0,2,4,6,8,10,11],discord_invit:11,disnak:0,distinguish:12,django:5,doc:0,document:0,doesn:12,don:[0,12],done:12,dummi:[0,2],dynam:0,each:0,edit:2,either:2,elsewher:12,emit:2,empti:2,endpoint:5,ensur:[2,11],entir:[0,2],equival:5,error:[2,5,6,10],event:[0,2,3,12],event_loop:12,exc_info:9,exce:7,except:[2,5,9,12],execut:12,exist:12,expect:10,express:11,ext:[0,1,2,6,8],extend:0,extens:[0,2],extra:5,fail:8,failur:10,featur:[0,2],februari:0,fetch:[8,10],fifo:7,fix:0,forbidden:8,format:11,formatted_code_regex:11,forum:0,found:[10,12],from:[0,2,3,5,6,8,10,12],futur:12,gatewai:2,gener:[2,12],get:[0,5,8,10],get_logg:9,get_or_fetch_channel:8,get_or_fetch_memb:10,give:2,given:[2,3,6,8,9,10,12],group:[6,11],guild:[0,2,10],guild_available_but_cache_empti:2,guild_creat:2,guild_id:2,guildchannel:8,ha:6,handl:[0,10,12],handle_role_chang:10,hashabl:12,have:[8,9],heavi:6,help:0,helper:[8,10],hook:0,host:3,houston:9,how:[7,12],http:[5,11],http_session:2,httpexcept:8,id:[2,8,12],identifi:12,ignor:6,immedi:12,implement:[2,3,7,9],inadequ:2,index:1,indic:10,individu:2,inform:[1,9],init:[0,2,3],initi:[5,12],initialis:[2,7],instanc:[0,2,5,7,8,9,12],instanti:[2,12],instead:[2,12],intend:10,interact:8,interactin:10,interest:9,intern:[2,6],intersphinx:0,invalid:8,invaliddata:8,invit:[0,11],is_in_categori:8,item:7,its:2,januari:0,json:5,keep:12,kei:7,keyword:[5,6,9],known:12,kwarg:[2,5,9,12],latest:0,level:[6,9],lint:0,list:2,ll:12,load:[0,2,6],load_extens:2,localhost:3,log:[0,2,6,12],log_to_dev_log:2,logger:[0,9],logic:0,longer:0,look:12,loop:[2,3,12],lot:0,lru:7,made:0,mai:[0,7],main:0,make:[0,9],mani:[0,2,7],manipul:0,manual:2,march:0,match:2,max_siz:7,maximum:7,maybe_raise_for_statu:5,member:[0,2,6],member_id:10,mention:2,messag:[2,9,12],method:[3,5,6,9],migrat:0,modul:[0,2,6,12],monkei:[0,6],move:0,msg:9,multivers:0,must:12,mypi:9,name:[2,6,9,12],namespac:[0,12],next:0,non:5,none:[2,3,5,6,7,9,10,12],normal:2,notabl:0,notfound:8,notic:0,novemb:0,now:[0,12],number:0,object:[5,6,7,8,10,12],offset:7,ok:5,older:0,on_guild_avail:2,on_guild_unavail:2,on_readi:2,onc:7,one:[0,2],onli:2,oper:[2,12],option:[2,3,5,7,9,10],order:[7,12],other:12,otherwis:12,our:[0,6],out:0,output:11,own:0,packag:[0,6],page:1,pagin:0,paramet:[2,3,5,6,7,8,9,10,12],pars:11,pass:[0,5,9,10,12],past:12,patch:[0,5,6],pattern:11,permiss:[0,8],ping:2,ping_servic:2,pleas:11,poetri:0,popul:2,port:[0,3],posit:7,post:5,prefix:3,prematur:12,prevent:12,problem:9,process:0,provid:[7,12],put:5,py:0,pyproject:0,python:[2,12],qualifi:6,quot:11,rais:[5,8,10,12],raise_for_statu:5,ran:2,rather:6,raw:11,raw_code_regex:11,re:[2,12],readi:2,real:0,receiv:[5,8],recognis:9,reconnect:0,redi:0,redis_sess:2,redissess:2,refer:0,regex:[0,2,6],regular:11,relat:[7,9],releas:0,remov:[0,2],remove_command:2,remove_rol:10,repo:0,represent:5,request:[5,11],request_text:5,requir:[2,12],resolut:0,resolv:2,respons:5,response_json:5,response_text:5,responsecodeerror:5,restor:0,result:[0,12],retriev:8,reusabl:4,revert:0,role:[2,10],root:[2,6],root_alias:6,rout:6,run:12,s:[0,6,7,9,11,12],safe:0,same:12,sanitis:11,save:2,schedul:[0,2,6],schedule_at:12,schedule_lat:12,search:1,second:[2,12],self:2,send:5,send_typ:6,sequenc:6,server:[2,11],servic:2,session:[0,2,5],session_kwarg:5,set:2,setup:[0,2],setup_hook:2,sever:9,share:0,should:[0,2,5],should_rais:5,similar:11,singl:0,site:[0,5],site_api:[0,1,2],site_api_token:5,site_api_url:5,size:7,so:[0,6],socket:3,sole:10,someth:11,sourc:[2,3,5,6,7,8,9,10,11,12],specifi:0,sphinx:0,start:[0,2,12],startup:2,startuperror:2,stat:3,statsclientbas:3,statsd:[0,2,3],statsd_url:[0,2],still:2,store:[6,7],str:[2,3,5,6,9,12],string:5,sub:[0,2],submodul:1,subpackag:1,subtract:12,suggest:12,support:[0,3,6,12],suppressed_except:12,t:[0,12],target:7,task:[0,2,12],task_id:12,text:5,textchannel:8,than:6,thei:2,them:[2,12],thi:[0,2,5,6,8,10,11,12],thrown:6,thu:2,time:[0,12],timeout:0,timezon:12,token:5,toml:0,tool:[2,6],top:6,trace:[0,9],track:12,transport:3,tupl:12,two:6,type:[2,3,5,6,7,8,9,10,12],unavail:2,unawait:12,under:6,union:12,uniqu:12,unknown:8,unqualifi:[0,6],unschedul:12,until:[2,11],up:[0,2],url:[0,2,5],urllib:11,us:[0,2,3,5,6,8,9,10,11,12],utc:12,util:[0,1,2,7,9],valu:9,valueerror:5,variou:8,version:0,wa:[5,8,12],wait:[2,12],wait_for:2,wait_until_guild_avail:2,warn:12,we:[9,10],when:[0,2,3,5,6,7,12],whether:[5,8],which:[0,6,12],whitespac:[0,11],within:[0,2],work:0,worker:6,wrap:[7,12],wrapper:[0,5,12],x:0,you:[8,11]},titles:["Changelog","Bot Core Project Documentation","Botcore","async_stats","Exts","site_api","Utils","caching","channel","logging","members","regex","scheduling"],titleterms:{async_stat:3,bot:1,botcor:2,cach:7,changelog:0,channel:8,core:1,document:1,ext:4,extra:1,log:9,member:10,modul:1,project:1,refer:1,regex:11,schedul:12,site_api:5,submodul:[2,6],subpackag:2,util:6}})
\ No newline at end of file +Search.setIndex({"docnames": ["changelog", "index", "output/botcore", "output/botcore.async_stats", "output/botcore.exts", "output/botcore.site_api", "output/botcore.utils", "output/botcore.utils.caching", "output/botcore.utils.channel", "output/botcore.utils.logging", "output/botcore.utils.members", "output/botcore.utils.regex", "output/botcore.utils.scheduling"], "filenames": ["changelog.rst", "index.rst", "output/botcore.rst", "output/botcore.async_stats.rst", "output/botcore.exts.rst", "output/botcore.site_api.rst", "output/botcore.utils.rst", "output/botcore.utils.caching.rst", "output/botcore.utils.channel.rst", "output/botcore.utils.logging.rst", "output/botcore.utils.members.rst", "output/botcore.utils.regex.rst", "output/botcore.utils.scheduling.rst"], "titles": ["Changelog", "Bot Core Project Documentation", "Botcore", "async_stats", "Exts", "site_api", "Utils", "caching", "channel", "logging", "members", "regex", "scheduling"], "terms": {"next": 0, "7": [0, 5], "x": 0, "featur": [0, 2], "releas": 0, "support": [0, 3, 6, 12], "79": 0, "restor": 0, "site": [0, 5], "add": [0, 2], "sphinx": 0, "multivers": 0, "make": [0, 9], "avail": [0, 2], "older": 0, "doc": 0, "version": 0, "1": [0, 5, 9], "0": [0, 7, 9], "24th": 0, "mai": [0, 7], "2022": 0, "78": 0, "bump": 0, "discord": [0, 2, 4, 6, 8, 10, 11], "py": 0, "4cbe8f5": 0, "thi": [0, 2, 5, 6, 8, 10, 11, 12], "fix": 0, "bug": 0, "permiss": [0, 8], "resolut": 0, "when": [0, 2, 3, 5, 6, 7, 12], "deal": 0, "time": [0, 12], "out": 0, "member": [0, 2, 6], "10th": 0, "break": 0, "75": 0, "invit": [0, 11], "regex": [0, 2, 6], "longer": 0, "return": [0, 2, 3, 5, 6, 7, 8, 9, 10, 12], "url": [0, 2, 5], "safe": 0, "result": [0, 12], "refer": 0, "document": 0, "handl": [0, 10, 12], "captur": [0, 11], "all": [0, 2, 3, 6, 12], "charact": 0, "up": [0, 2], "whitespac": [0, 11], "6": 0, "4": 0, "26th": 0, "april": 0, "72": 0, "5a06fa5": 0, "notabl": 0, "one": [0, 2], "commit": 0, "dynam": 0, "extend": 0, "timeout": 0, "guild": [0, 2, 10], "chunk": 0, "base": [0, 2, 3, 5, 7, 9, 12], "number": 0, "so": [0, 6], "should": [0, 2, 5], "actual": 0, "work": 0, "our": [0, 6], "now": [0, 12], "3": 0, "2": [0, 2, 5], "25th": 0, "69": 0, "us": [0, 2, 3, 5, 6, 8, 9, 10, 11, 12], "statsd_url": [0, 2], "get": [0, 5, 8, 10], "pass": [0, 5, 9, 10, 12], "botbas": [0, 2], "21st": 0, "68": 0, "correct": 0, "pyproject": 0, "toml": 0, "directli": 0, "main": 0, "don": [0, 12], "t": [0, 12], "load": [0, 2, 6], "modul": [0, 2, 6, 12], "start": [0, 2, 12], "_": 0, "66": 0, "each": 0, "cog": [0, 2, 4], "s": [0, 6, 7, 9, 11, 12], "own": 0, "task": [0, 2, 12], "avoid": [0, 2], "singl": 0, "crash": 0, "entir": [0, 2], "process": 0, "20th": 0, "65": 0, "unqualifi": [0, 6], "botcor": [0, 1], "util": [0, 1, 2, 7, 9], "namespac": [0, 12], "bot": [0, 2, 6, 8], "manipul": 0, "extens": [0, 2], "19th": 0, "64": 0, "987235d": 0, "revert": 0, "chang": [0, 5], "help": 0, "command": [0, 2, 6, 8], "behaviour": 0, "broke": 0, "custom": [0, 7, 9], "pagin": 0, "also": [0, 6], "basic": 0, "forum": 0, "channel": [0, 2, 6], "5": 0, "18th": 0, "63": 0, "allow": [0, 2], "an": [0, 2, 3, 5, 6, 7, 8, 9, 12], "api_cli": [0, 2], "__init__": [0, 2, 3, 5, 7, 12], "specifi": 0, "site_api": [0, 1, 2], "apicli": [0, 2, 5], "instanc": [0, 2, 5, 7, 8, 9, 12], "61": 0, "reconnect": 0, "redi": 0, "session": [0, 2, 5], "setup": [0, 2], "close": [0, 2, 5, 12], "5th": 0, "56": 0, "move": 0, "creation": 0, "asyncio": [0, 3, 12], "event": [0, 2, 3, 12], "_guild_avail": 0, "within": [0, 2], "hook": 0, "deprec": 0, "notic": 0, "creat": [0, 2, 3, 7, 12], "dummi": [0, 2], "asyncstatsdcli": 0, "befor": [0, 2, 12], "connect": [0, 2, 3], "real": 0, "case": 0, "cannot": [0, 2], "made": 0, "init": [0, 2, 3], "2nd": 0, "54": 0, "aiohttp": [0, 2, 5], "asyncresolv": 0, "async": [0, 2, 3, 5, 7, 8, 10], "42": 0, "remov": [0, 2], "public": 0, "statsd": [0, 2, 3], "client": [0, 2, 3], "ext": [0, 1, 2, 6, 8], "sub": [0, 2], "class": [0, 2, 3, 5, 7, 9, 12], "which": [0, 6, 12], "abstract": 0, "lot": 0, "logic": 0, "share": 0, "between": 0, "latest": 0, "alpha": 0, "14th": 0, "march": 0, "39": 0, "migrat": 0, "back": 0, "37": 0, "log": [0, 2, 6, 12], "trace": [0, 9], "import": 0, "can": [0, 12], "function": [0, 2, 7, 8, 9, 10, 12], "3rd": 0, "35": 0, "apply_monkey_patch": [0, 6], "februari": 0, "34": 0, "port": [0, 3], "api": [0, 5, 10], "wrapper": [0, 5, 12], "from": [0, 2, 3, 5, 6, 8, 10, 12], "repo": 0, "22nd": 0, "32": 0, "0a0": 0, "disnak": 0, "29": 0, "mani": [0, 2, 7], "common": [0, 2, 6, 9, 11], "cach": [0, 2, 6, 8, 10], "logger": [0, 9], "schedul": [0, 2, 6], "monkei": [0, 6], "patch": [0, 5, 6], "ad": [0, 6, 9], "intersphinx": 0, "9th": 0, "januari": 0, "12": 0, "code": [0, 11], "block": [0, 11], "detect": 0, "decemb": 0, "2021": 0, "autogener": 0, "17th": 0, "novemb": 0, "core": 0, "packag": [0, 6], "poetri": 0, "lint": 0, "ci": 0, "subpackag": 1, "submodul": 1, "async_stat": [1, 2], "index": 1, "search": 1, "page": 1, "inform": [1, 9], "changelog": 1, "tool": [2, 6], "develop": [2, 6], "arg": [2, 9], "guild_id": 2, "allowed_rol": 2, "http_session": 2, "redis_sess": 2, "none": [2, 3, 5, 6, 7, 9, 10, 12], "kwarg": [2, 5, 9, 12], "sourc": [2, 3, 5, 6, 7, 8, 9, 10, 11, 12], "A": [2, 5, 6, 7, 8, 12], "implement": [2, 3, 7, 9], "python": [2, 12], "initialis": [2, 7], "paramet": [2, 3, 5, 6, 7, 8, 9, 10, 12], "int": [2, 3, 7, 8, 12], "The": [2, 3, 5, 6, 7, 8, 9, 10, 12], "id": [2, 8, 12], "wait_until_guild_avail": 2, "list": 2, "role": [2, 10], "mention": 2, "clientsess": [2, 5], "option": [2, 3, 5, 7, 9, 10], "redissess": 2, "async_rediscach": 2, "str": [2, 3, 5, 6, 9, 12], "server": [2, 11], "If": [2, 5, 12], "given": [2, 3, 6, 8, 9, 10, 12], "add_cog": 2, "oper": [2, 12], "type": [2, 3, 5, 6, 7, 8, 9, 10, 12], "add_command": 2, "normal": 2, "its": 2, "root": [2, 6], "alias": [2, 6], "clear": [2, 7], "Not": 2, "re": [2, 12], "instanti": [2, 12], "instead": [2, 12], "attempt": [2, 8, 10], "connector": 2, "resolv": 2, "load_extens": 2, "save": 2, "them": [2, 12], "self": 2, "all_extens": 2, "ran": 2, "loop": [2, 3, 12], "deadlock": 2, "caus": [2, 6], "wait_for": 2, "call": [2, 12], "log_to_dev_log": 2, "messag": [2, 9, 12], "dev": 2, "on_guild_avail": 2, "set": 2, "intern": [2, 6], "becom": 2, "appear": 2, "still": 2, "empti": 2, "guild_available_but_cache_empti": 2, "emit": 2, "on_guild_unavail": 2, "unavail": 2, "ping_servic": 2, "ping": 2, "requir": [2, 12], "servic": 2, "ensur": [2, 11], "thei": 2, "ar": [2, 7, 11], "remove_command": 2, "name": [2, 6, 9, 12], "alia": [2, 6], "individu": 2, "To": [2, 9], "either": 2, "manual": 2, "edit": 2, "all_command": 2, "setup_hook": 2, "startup": 2, "gener": [2, 12], "asyncstatscli": [2, 3], "create_socket": [2, 3], "wait": [2, 12], "until": [2, 11], "match": 2, "readi": 2, "on_readi": 2, "inadequ": 2, "becaus": 2, "onli": 2, "second": [2, 12], "guild_creat": 2, "gatewai": 2, "give": 2, "thu": 2, "popul": 2, "except": [2, 5, 9, 12], "startuperror": 2, "error": [2, 5, 6, 10], "transport": 3, "method": [3, 5, 6, 9], "commun": 3, "host": 3, "localhost": 3, "8125": 3, "prefix": 3, "statsclientbas": 3, "stat": 3, "new": [3, 5, 7, 12], "abstracteventloop": [3, 12], "create_datagram_endpoint": 3, "socket": 3, "reusabl": 4, "around": 5, "site_api_url": 5, "site_api_token": 5, "session_kwarg": 5, "object": [5, 6, 7, 8, 10, 12], "django": 5, "initi": [5, 12], "token": 5, "authent": 5, "keyword": [5, 6, 9], "argument": [5, 6, 7, 9, 10], "constructor": 5, "delet": [5, 7], "endpoint": 5, "raise_for_statu": 5, "true": [5, 9, 12], "send": 5, "request": [5, 11], "json": 5, "respons": 5, "bool": [5, 8, 12], "whether": [5, 8], "rais": [5, 8, 10, 12], "ok": 5, "ani": [5, 11, 12], "extra": 5, "dict": 5, "204": 5, "No": 5, "content": 5, "equival": 5, "maybe_raise_for_statu": 5, "should_rais": 5, "responsecodeerror": 5, "non": 5, "clientrespons": 5, "check": [5, 8, 12], "post": 5, "put": 5, "http": [5, 11], "response_json": 5, "response_text": 5, "valueerror": 5, "receiv": [5, 8], "wa": [5, 8, 12], "request_text": 5, "text": 5, "__str__": 5, "string": 5, "represent": 5, "appli": [6, 7], "group": [6, 11], "root_alias": 6, "two": 6, "sequenc": 6, "act": 6, "top": 6, "level": [6, 9], "rather": 6, "than": 6, "being": 6, "It": 6, "store": [6, 7], "attribut": 6, "send_typ": 6, "ignor": 6, "403": 6, "under": 6, "heavi": 6, "ha": 6, "cloudflar": 6, "worker": 6, "rout": 6, "thrown": 6, "qualifi": 6, "relat": [7, 9], "asynccach": 7, "max_siz": 7, "128": 7, "lru": 7, "coroutin": [7, 10, 12], "onc": 7, "exce": 7, "maximum": 7, "size": 7, "kei": 7, "fifo": 7, "order": [7, 12], "offset": 7, "provid": [7, 12], "__call__": 7, "arg_offset": 7, "decor": 7, "posit": 7, "callabl": [7, 10], "wrap": [7, 12], "target": 7, "how": [7, 12], "item": 7, "helper": [8, 10], "interact": 8, "variou": 8, "get_or_fetch_channel": 8, "channel_id": 8, "fetch": [8, 10], "invaliddata": 8, "unknown": 8, "httpexcept": 8, "retriev": 8, "fail": 8, "notfound": 8, "invalid": 8, "forbidden": 8, "you": [8, 11], "do": 8, "have": [8, 9], "guildchannel": 8, "is_in_categori": 8, "category_id": 8, "categori": 8, "textchannel": 8, "depend": 8, "customlogg": 9, "msg": 9, "sever": 9, "exc_info": 9, "valu": 9, "houston": 9, "we": [9, 10], "interest": 9, "problem": 9, "get_logg": 9, "mypi": 9, "recognis": 9, "interactin": 10, "get_or_fetch_memb": 10, "member_id": 10, "failur": 10, "indic": 10, "could": 10, "found": [10, 12], "handle_role_chang": 10, "coro": [10, 12], "await": [10, 12], "sole": 10, "expect": 10, "add_rol": 10, "remove_rol": 10, "intend": 10, "regular": 11, "express": 11, "discord_invit": 11, "pattern": 11, "similar": 11, "pleas": 11, "sanitis": 11, "output": 11, "someth": 11, "urllib": 11, "pars": 11, "quot": 11, "formatted_code_regex": 11, "format": 11, "raw_code_regex": 11, "raw": 11, "execut": 12, "keep": 12, "track": 12, "must": 12, "distinguish": 12, "other": 12, "contain": 12, "suggest": 12, "immedi": 12, "futur": 12, "schedule_at": 12, "schedule_lat": 12, "uniqu": 12, "cancel": 12, "prematur": 12, "same": 12, "current": 12, "done": 12, "__contains__": 12, "task_id": 12, "hashabl": 12, "look": 12, "unschedul": 12, "identifi": 12, "warn": 12, "doesn": 12, "exist": 12, "cancel_al": 12, "known": 12, "alreadi": 12, "prevent": 12, "unawait": 12, "ll": 12, "elsewher": 12, "timezon": 12, "awar": 12, "calcul": 12, "subtract": 12, "na\u00efv": 12, "utc": 12, "past": 12, "datetim": 12, "delai": 12, "after": 12, "union": 12, "float": 12, "long": 12, "create_task": 12, "suppressed_except": 12, "event_loop": 12, "otherwis": 12, "run": 12, "tupl": 12}, "objects": {"": [[2, 0, 0, "-", "botcore"]], "botcore": [[2, 1, 1, "", "BotBase"], [2, 3, 1, "", "StartupError"], [3, 0, 0, "-", "async_stats"], [4, 0, 0, "-", "exts"], [5, 0, 0, "-", "site_api"], [6, 0, 0, "-", "utils"]], "botcore.BotBase": [[2, 2, 1, "", "__init__"], [2, 2, 1, "", "add_cog"], [2, 2, 1, "", "add_command"], [2, 2, 1, "", "clear"], [2, 2, 1, "", "close"], [2, 2, 1, "", "load_extensions"], [2, 2, 1, "", "log_to_dev_log"], [2, 2, 1, "", "on_guild_available"], [2, 2, 1, "", "on_guild_unavailable"], [2, 2, 1, "", "ping_services"], [2, 2, 1, "", "remove_command"], [2, 2, 1, "", "setup_hook"], [2, 2, 1, "", "wait_until_guild_available"]], "botcore.StartupError": [[2, 2, 1, "", "__init__"]], "botcore.async_stats": [[3, 1, 1, "", "AsyncStatsClient"]], "botcore.async_stats.AsyncStatsClient": [[3, 2, 1, "", "__init__"], [3, 2, 1, "", "create_socket"]], "botcore.site_api": [[5, 1, 1, "", "APIClient"], [5, 3, 1, "", "ResponseCodeError"]], "botcore.site_api.APIClient": [[5, 2, 1, "", "__init__"], [5, 2, 1, "", "close"], [5, 2, 1, "", "delete"], [5, 2, 1, "", "get"], [5, 2, 1, "", "maybe_raise_for_status"], [5, 2, 1, "", "patch"], [5, 2, 1, "", "post"], [5, 2, 1, "", "put"], [5, 2, 1, "", "request"]], "botcore.site_api.ResponseCodeError": [[5, 2, 1, "", "__init__"], [5, 2, 1, "", "__str__"]], "botcore.utils": [[6, 4, 1, "", "apply_monkey_patches"], [7, 0, 0, "-", "caching"], [8, 0, 0, "-", "channel"], [9, 0, 0, "-", "logging"], [10, 0, 0, "-", "members"], [11, 0, 0, "-", "regex"], [12, 0, 0, "-", "scheduling"], [6, 4, 1, "", "unqualify"]], "botcore.utils.caching": [[7, 1, 1, "", "AsyncCache"]], "botcore.utils.caching.AsyncCache": [[7, 2, 1, "", "__call__"], [7, 2, 1, "", "__init__"], [7, 2, 1, "", "clear"]], "botcore.utils.channel": [[8, 4, 1, "", "get_or_fetch_channel"], [8, 4, 1, "", "is_in_category"]], "botcore.utils.logging": [[9, 1, 1, "", "CustomLogger"], [9, 4, 1, "", "get_logger"]], "botcore.utils.logging.CustomLogger": [[9, 2, 1, "", "trace"]], "botcore.utils.members": [[10, 4, 1, "", "get_or_fetch_member"], [10, 4, 1, "", "handle_role_change"]], "botcore.utils.regex": [[11, 5, 1, "", "DISCORD_INVITE"], [11, 5, 1, "", "FORMATTED_CODE_REGEX"], [11, 5, 1, "", "RAW_CODE_REGEX"]], "botcore.utils.scheduling": [[12, 1, 1, "", "Scheduler"], [12, 4, 1, "", "create_task"]], "botcore.utils.scheduling.Scheduler": [[12, 2, 1, "", "__contains__"], [12, 2, 1, "", "__init__"], [12, 2, 1, "", "cancel"], [12, 2, 1, "", "cancel_all"], [12, 2, 1, "", "schedule"], [12, 2, 1, "", "schedule_at"], [12, 2, 1, "", "schedule_later"]]}, "objtypes": {"0": "py:module", "1": "py:class", "2": "py:method", "3": "py:exception", "4": "py:function", "5": "py:data"}, "objnames": {"0": ["py", "module", "Python module"], "1": ["py", "class", "Python class"], "2": ["py", "method", "Python method"], "3": ["py", "exception", "Python exception"], "4": ["py", "function", "Python function"], "5": ["py", "data", "Python data"]}, "titleterms": {"changelog": 0, "bot": 1, "core": 1, "project": 1, "document": 1, "refer": 1, "modul": 1, "extra": 1, "botcor": 2, "subpackag": 2, "submodul": [2, 6], "async_stat": 3, "ext": 4, "site_api": 5, "util": 6, "cach": 7, "channel": 8, "log": 9, "member": 10, "regex": 11, "schedul": 12}, "envversion": {"sphinx.domains.c": 2, "sphinx.domains.changeset": 1, "sphinx.domains.citation": 1, "sphinx.domains.cpp": 6, "sphinx.domains.index": 1, "sphinx.domains.javascript": 2, "sphinx.domains.math": 2, "sphinx.domains.python": 3, "sphinx.domains.rst": 2, "sphinx.domains.std": 2, "sphinx.ext.intersphinx": 1, "sphinx.ext.todo": 2, "sphinx": 56}})
\ No newline at end of file diff --git a/v7.1.2/versions.html b/v7.1.2/versions.html index 75d1f91d..68c43b82 100644 --- a/v7.1.2/versions.html +++ b/v7.1.2/versions.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Versions - Bot Core v7.1.2</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -339,6 +339,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.3/.buildinfo b/v7.1.3/.buildinfo index f5269ff5..d4efcd40 100644 --- a/v7.1.3/.buildinfo +++ b/v7.1.3/.buildinfo @@ -1,4 +1,4 @@  # 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: 93f913a22bedc44b90da3da37f304c12 +config: b71ab7cf64022f5fa67af3123befe59f  tags: 645f666f9bcd5a90fca523b33c5a78b7 diff --git a/v7.1.3/.doctrees/changelog.doctree b/v7.1.3/.doctrees/changelog.doctree Binary files differindex 1d304554..08540d2b 100644 --- a/v7.1.3/.doctrees/changelog.doctree +++ b/v7.1.3/.doctrees/changelog.doctree diff --git a/v7.1.3/.doctrees/environment.pickle b/v7.1.3/.doctrees/environment.pickle Binary files differindex c40b2109..954c00ac 100644 --- a/v7.1.3/.doctrees/environment.pickle +++ b/v7.1.3/.doctrees/environment.pickle diff --git a/v7.1.3/.doctrees/index.doctree b/v7.1.3/.doctrees/index.doctree Binary files differindex 1c14dd7f..2227f28a 100644 --- a/v7.1.3/.doctrees/index.doctree +++ b/v7.1.3/.doctrees/index.doctree diff --git a/v7.1.3/.doctrees/output/botcore.async_stats.doctree b/v7.1.3/.doctrees/output/botcore.async_stats.doctree Binary files differindex 86f2f8a6..d06418f5 100644 --- a/v7.1.3/.doctrees/output/botcore.async_stats.doctree +++ b/v7.1.3/.doctrees/output/botcore.async_stats.doctree diff --git a/v7.1.3/.doctrees/output/botcore.doctree b/v7.1.3/.doctrees/output/botcore.doctree Binary files differindex b5032955..0dc52578 100644 --- a/v7.1.3/.doctrees/output/botcore.doctree +++ b/v7.1.3/.doctrees/output/botcore.doctree diff --git a/v7.1.3/.doctrees/output/botcore.exts.doctree b/v7.1.3/.doctrees/output/botcore.exts.doctree Binary files differindex 163a1441..34264ae2 100644 --- a/v7.1.3/.doctrees/output/botcore.exts.doctree +++ b/v7.1.3/.doctrees/output/botcore.exts.doctree diff --git a/v7.1.3/.doctrees/output/botcore.site_api.doctree b/v7.1.3/.doctrees/output/botcore.site_api.doctree Binary files differindex b1bc03c1..e802d859 100644 --- a/v7.1.3/.doctrees/output/botcore.site_api.doctree +++ b/v7.1.3/.doctrees/output/botcore.site_api.doctree diff --git a/v7.1.3/.doctrees/output/botcore.utils.caching.doctree b/v7.1.3/.doctrees/output/botcore.utils.caching.doctree Binary files differindex 8cd3f5e3..b60b2eda 100644 --- a/v7.1.3/.doctrees/output/botcore.utils.caching.doctree +++ b/v7.1.3/.doctrees/output/botcore.utils.caching.doctree diff --git a/v7.1.3/.doctrees/output/botcore.utils.channel.doctree b/v7.1.3/.doctrees/output/botcore.utils.channel.doctree Binary files differindex 4113ea61..ec3045c2 100644 --- a/v7.1.3/.doctrees/output/botcore.utils.channel.doctree +++ b/v7.1.3/.doctrees/output/botcore.utils.channel.doctree diff --git a/v7.1.3/.doctrees/output/botcore.utils.doctree b/v7.1.3/.doctrees/output/botcore.utils.doctree Binary files differindex cfef981c..ba3dab11 100644 --- a/v7.1.3/.doctrees/output/botcore.utils.doctree +++ b/v7.1.3/.doctrees/output/botcore.utils.doctree diff --git a/v7.1.3/.doctrees/output/botcore.utils.logging.doctree b/v7.1.3/.doctrees/output/botcore.utils.logging.doctree Binary files differindex 3c961af4..6caae82b 100644 --- a/v7.1.3/.doctrees/output/botcore.utils.logging.doctree +++ b/v7.1.3/.doctrees/output/botcore.utils.logging.doctree diff --git a/v7.1.3/.doctrees/output/botcore.utils.members.doctree b/v7.1.3/.doctrees/output/botcore.utils.members.doctree Binary files differindex 7bf77c47..9c9ac445 100644 --- a/v7.1.3/.doctrees/output/botcore.utils.members.doctree +++ b/v7.1.3/.doctrees/output/botcore.utils.members.doctree diff --git a/v7.1.3/.doctrees/output/botcore.utils.regex.doctree b/v7.1.3/.doctrees/output/botcore.utils.regex.doctree Binary files differindex e50e884f..953cb0d6 100644 --- a/v7.1.3/.doctrees/output/botcore.utils.regex.doctree +++ b/v7.1.3/.doctrees/output/botcore.utils.regex.doctree diff --git a/v7.1.3/.doctrees/output/botcore.utils.scheduling.doctree b/v7.1.3/.doctrees/output/botcore.utils.scheduling.doctree Binary files differindex 756ff516..532c979c 100644 --- a/v7.1.3/.doctrees/output/botcore.utils.scheduling.doctree +++ b/v7.1.3/.doctrees/output/botcore.utils.scheduling.doctree diff --git a/v7.1.3/_static/_sphinx_javascript_frameworks_compat.js b/v7.1.3/_static/_sphinx_javascript_frameworks_compat.js new file mode 100644 index 00000000..8549469d --- /dev/null +++ b/v7.1.3/_static/_sphinx_javascript_frameworks_compat.js @@ -0,0 +1,134 @@ +/* + * _sphinx_javascript_frameworks_compat.js + * ~~~~~~~~~~ + * + * Compatability shim for jQuery and underscores.js. + * + * WILL BE REMOVED IN Sphinx 6.0 + * xref RemovedInSphinx60Warning + * + */ + +/** + * select a different prefix for underscore + */ +$u = _.noConflict(); + + +/** + * small helper function to urldecode strings + * + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL + */ +jQuery.urldecode = function(x) { +    if (!x) { +        return x +    } +    return decodeURIComponent(x.replace(/\+/g, ' ')); +}; + +/** + * small helper function to urlencode strings + */ +jQuery.urlencode = encodeURIComponent; + +/** + * This function returns the parsed url parameters of the + * current request. Multiple values per key are supported, + * it will always return arrays of strings for the value parts. + */ +jQuery.getQueryParameters = function(s) { +    if (typeof s === 'undefined') +        s = document.location.search; +    var parts = s.substr(s.indexOf('?') + 1).split('&'); +    var result = {}; +    for (var i = 0; i < parts.length; i++) { +        var tmp = parts[i].split('=', 2); +        var key = jQuery.urldecode(tmp[0]); +        var value = jQuery.urldecode(tmp[1]); +        if (key in result) +            result[key].push(value); +        else +            result[key] = [value]; +    } +    return result; +}; + +/** + * highlight a given string on a jquery object by wrapping it in + * span elements with the given class name. + */ +jQuery.fn.highlightText = function(text, className) { +    function highlight(node, addItems) { +        if (node.nodeType === 3) { +            var val = node.nodeValue; +            var pos = val.toLowerCase().indexOf(text); +            if (pos >= 0 && +                !jQuery(node.parentNode).hasClass(className) && +                !jQuery(node.parentNode).hasClass("nohighlight")) { +                var span; +                var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg"); +                if (isInSVG) { +                    span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); +                } else { +                    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); +                if (isInSVG) { +                    var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"); +                    var bbox = node.parentElement.getBBox(); +                    rect.x.baseVal.value = bbox.x; +                    rect.y.baseVal.value = bbox.y; +                    rect.width.baseVal.value = bbox.width; +                    rect.height.baseVal.value = bbox.height; +                    rect.setAttribute('class', className); +                    addItems.push({ +                        "parent": node.parentNode, +                        "target": rect}); +                } +            } +        } +        else if (!jQuery(node).is("button, select, textarea")) { +            jQuery.each(node.childNodes, function() { +                highlight(this, addItems); +            }); +        } +    } +    var addItems = []; +    var result = this.each(function() { +        highlight(this, addItems); +    }); +    for (var i = 0; i < addItems.length; ++i) { +        jQuery(addItems[i].parent).before(addItems[i].target); +    } +    return result; +}; + +/* + * 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; +} diff --git a/v7.1.3/_static/basic.css b/v7.1.3/_static/basic.css index bf18350b..7d5974c3 100644 --- a/v7.1.3/_static/basic.css +++ b/v7.1.3/_static/basic.css @@ -222,7 +222,7 @@ table.modindextable td {  /* -- general body styles --------------------------------------------------- */  div.body { -    min-width: 450px; +    min-width: 360px;      max-width: 800px;  } @@ -236,7 +236,6 @@ div.body p, div.body dd, div.body li, div.body blockquote {  a.headerlink {      visibility: hidden;  } -  a.brackets:before,  span.brackets > a:before{      content: "["; @@ -247,6 +246,7 @@ span.brackets > a:after {      content: "]";  } +  h1:hover > a.headerlink,  h2:hover > a.headerlink,  h3:hover > a.headerlink, @@ -334,13 +334,11 @@ aside.sidebar {  p.sidebar-title {      font-weight: bold;  } -  div.admonition, div.topic, blockquote {      clear: left;  }  /* -- topics ---------------------------------------------------------------- */ -  div.topic {      border: 1px solid #ccc;      padding: 7px; @@ -428,10 +426,6 @@ table.docutils td, table.docutils th {      border-bottom: 1px solid #aaa;  } -table.footnote td, table.footnote th { -    border: 0 !important; -} -  th {      text-align: left;      padding-right: 5px; @@ -615,6 +609,7 @@ ul.simple p {      margin-bottom: 0;  } +/* Docutils 0.17 and older (footnotes & citations) */  dl.footnote > dt,  dl.citation > dt {      float: left; @@ -632,6 +627,33 @@ dl.citation > dd:after {      clear: both;  } +/* Docutils 0.18+ (footnotes & citations) */ +aside.footnote > span, +div.citation > span { +    float: left; +} +aside.footnote > span:last-of-type, +div.citation > span:last-of-type { +  padding-right: 0.5em; +} +aside.footnote > p { +  margin-left: 2em; +} +div.citation > p { +  margin-left: 4em; +} +aside.footnote > p:last-of-type, +div.citation > p:last-of-type { +    margin-bottom: 0em; +} +aside.footnote > p:last-of-type:after, +div.citation > p:last-of-type:after { +    content: ""; +    clear: both; +} + +/* Footnotes & citations ends */ +  dl.field-list {      display: grid;      grid-template-columns: fit-content(30%) auto; diff --git a/v7.1.3/_static/doctools.js b/v7.1.3/_static/doctools.js index e1bfd708..c3db08d1 100644 --- a/v7.1.3/_static/doctools.js +++ b/v7.1.3/_static/doctools.js @@ -2,357 +2,263 @@   * doctools.js   * ~~~~~~~~~~~   * - * Sphinx JavaScript utilities for all documentation. + * Base JavaScript utilities for all Sphinx HTML documentation.   *   * :copyright: Copyright 2007-2022 by the Sphinx team, see AUTHORS.   * :license: BSD, see LICENSE for details.   *   */ +"use strict"; -/** - * select a different prefix for underscore - */ -$u = _.noConflict(); - -/** - * make the code below compatible with browsers without - * an installed firebug like debugger -if (!window.console || !console.firebug) { -  var names = ["log", "debug", "info", "warn", "error", "assert", "dir", -    "dirxml", "group", "groupEnd", "time", "timeEnd", "count", "trace", -    "profile", "profileEnd"]; -  window.console = {}; -  for (var i = 0; i < names.length; ++i) -    window.console[names[i]] = function() {}; -} - */ - -/** - * small helper function to urldecode strings - * - * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent#Decoding_query_parameters_from_a_URL - */ -jQuery.urldecode = function(x) { -  if (!x) { -    return x +const _ready = (callback) => { +  if (document.readyState !== "loading") { +    callback(); +  } else { +    document.addEventListener("DOMContentLoaded", callback);    } -  return decodeURIComponent(x.replace(/\+/g, ' '));  };  /** - * small helper function to urlencode strings + * highlight a given string on a node by wrapping it in + * span elements with the given class name.   */ -jQuery.urlencode = encodeURIComponent; +const _highlight = (node, addItems, text, className) => { +  if (node.nodeType === Node.TEXT_NODE) { +    const val = node.nodeValue; +    const parent = node.parentNode; +    const pos = val.toLowerCase().indexOf(text); +    if ( +      pos >= 0 && +      !parent.classList.contains(className) && +      !parent.classList.contains("nohighlight") +    ) { +      let span; -/** - * This function returns the parsed url parameters of the - * current request. Multiple values per key are supported, - * it will always return arrays of strings for the value parts. - */ -jQuery.getQueryParameters = function(s) { -  if (typeof s === 'undefined') -    s = document.location.search; -  var parts = s.substr(s.indexOf('?') + 1).split('&'); -  var result = {}; -  for (var i = 0; i < parts.length; i++) { -    var tmp = parts[i].split('=', 2); -    var key = jQuery.urldecode(tmp[0]); -    var value = jQuery.urldecode(tmp[1]); -    if (key in result) -      result[key].push(value); -    else -      result[key] = [value]; -  } -  return result; -}; +      const closestNode = parent.closest("body, svg, foreignObject"); +      const isInSVG = closestNode && closestNode.matches("svg"); +      if (isInSVG) { +        span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); +      } else { +        span = document.createElement("span"); +        span.classList.add(className); +      } -/** - * highlight a given string on a jquery object by wrapping it in - * span elements with the given class name. - */ -jQuery.fn.highlightText = function(text, className) { -  function highlight(node, addItems) { -    if (node.nodeType === 3) { -      var val = node.nodeValue; -      var pos = val.toLowerCase().indexOf(text); -      if (pos >= 0 && -          !jQuery(node.parentNode).hasClass(className) && -          !jQuery(node.parentNode).hasClass("nohighlight")) { -        var span; -        var isInSVG = jQuery(node).closest("body, svg, foreignObject").is("svg"); -        if (isInSVG) { -          span = document.createElementNS("http://www.w3.org/2000/svg", "tspan"); -        } else { -          span = document.createElement("span"); -          span.className = className; -        } -        span.appendChild(document.createTextNode(val.substr(pos, text.length))); -        node.parentNode.insertBefore(span, node.parentNode.insertBefore( +      span.appendChild(document.createTextNode(val.substr(pos, text.length))); +      parent.insertBefore( +        span, +        parent.insertBefore(            document.createTextNode(val.substr(pos + text.length)), -          node.nextSibling)); -        node.nodeValue = val.substr(0, pos); -        if (isInSVG) { -          var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect"); -          var bbox = node.parentElement.getBBox(); -          rect.x.baseVal.value = bbox.x; -          rect.y.baseVal.value = bbox.y; -          rect.width.baseVal.value = bbox.width; -          rect.height.baseVal.value = bbox.height; -          rect.setAttribute('class', className); -          addItems.push({ -              "parent": node.parentNode, -              "target": rect}); -        } +          node.nextSibling +        ) +      ); +      node.nodeValue = val.substr(0, pos); + +      if (isInSVG) { +        const rect = document.createElementNS( +          "http://www.w3.org/2000/svg", +          "rect" +        ); +        const bbox = parent.getBBox(); +        rect.x.baseVal.value = bbox.x; +        rect.y.baseVal.value = bbox.y; +        rect.width.baseVal.value = bbox.width; +        rect.height.baseVal.value = bbox.height; +        rect.setAttribute("class", className); +        addItems.push({ parent: parent, target: rect });        }      } -    else if (!jQuery(node).is("button, select, textarea")) { -      jQuery.each(node.childNodes, function() { -        highlight(this, addItems); -      }); -    } +  } else if (node.matches && !node.matches("button, select, textarea")) { +    node.childNodes.forEach((el) => _highlight(el, addItems, text, className));    } -  var addItems = []; -  var result = this.each(function() { -    highlight(this, addItems); -  }); -  for (var i = 0; i < addItems.length; ++i) { -    jQuery(addItems[i].parent).before(addItems[i].target); -  } -  return result;  }; - -/* - * 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; -} +const _highlightText = (thisNode, text, className) => { +  let addItems = []; +  _highlight(thisNode, addItems, text, className); +  addItems.forEach((obj) => +    obj.parent.insertAdjacentElement("beforebegin", obj.target) +  ); +};  /**   * Small JavaScript module for the documentation.   */ -var Documentation = { - -  init : function() { -    this.fixFirefoxAnchorBug(); -    this.highlightSearchWords(); -    this.initIndexTable(); -    this.initOnKeyListeners(); +const Documentation = { +  init: () => { +    Documentation.highlightSearchWords(); +    Documentation.initDomainIndexTable(); +    Documentation.initOnKeyListeners();    },    /**     * i18n support     */ -  TRANSLATIONS : {}, -  PLURAL_EXPR : function(n) { return n === 1 ? 0 : 1; }, -  LOCALE : 'unknown', +  TRANSLATIONS: {}, +  PLURAL_EXPR: (n) => (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; +  gettext: (string) => { +    const translated = Documentation.TRANSLATIONS[string]; +    switch (typeof translated) { +      case "undefined": +        return string; // no translation +      case "string": +        return translated; // translation exists +      default: +        return translated[0]; // (singular, plural) translation tuple exists +    }    }, -  /** -   * add context elements like header anchor links -   */ -  addContextElements : function() { -    $('div[id] > :header:first').each(function() { -      $('<a class="headerlink">\u00B6</a>'). -      attr('href', '#' + this.id). -      attr('title', _('Permalink to this headline')). -      appendTo(this); -    }); -    $('dt[id]').each(function() { -      $('<a class="headerlink">\u00B6</a>'). -      attr('href', '#' + this.id). -      attr('title', _('Permalink to this definition')). -      appendTo(this); -    }); +  ngettext: (singular, plural, n) => { +    const translated = Documentation.TRANSLATIONS[singular]; +    if (typeof translated !== "undefined") +      return translated[Documentation.PLURAL_EXPR(n)]; +    return n === 1 ? singular : plural;    }, -  /** -   * workaround a firefox stupidity -   * see: https://bugzilla.mozilla.org/show_bug.cgi?id=645075 -   */ -  fixFirefoxAnchorBug : function() { -    if (document.location.hash && $.browser.mozilla) -      window.setTimeout(function() { -        document.location.href += ''; -      }, 10); +  addTranslations: (catalog) => { +    Object.assign(Documentation.TRANSLATIONS, catalog.messages); +    Documentation.PLURAL_EXPR = new Function( +      "n", +      `return (${catalog.plural_expr})` +    ); +    Documentation.LOCALE = catalog.locale;    },    /**     * 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); -      $('<p class="highlight-link"><a href="javascript:Documentation.' + -        'hideSearchWords()">' + _('Hide Search Matches') + '</a></p>') -          .appendTo($('#searchbox')); -    } -  }, +  highlightSearchWords: () => { +    const highlight = +      new URLSearchParams(window.location.search).get("highlight") || ""; +    const terms = highlight.toLowerCase().split(/\s+/).filter(x => x); +    if (terms.length === 0) return; // nothing to do -  /** -   * 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(); -    } +    // There should never be more than one element matching "div.body" +    const divBody = document.querySelectorAll("div.body"); +    const body = divBody.length ? divBody[0] : document.querySelector("body"); +    window.setTimeout(() => { +      terms.forEach((term) => _highlightText(body, term, "highlighted")); +    }, 10); + +    const searchBox = document.getElementById("searchbox"); +    if (searchBox === null) return; +    searchBox.appendChild( +      document +        .createRange() +        .createContextualFragment( +          '<p class="highlight-link">' + +            '<a href="javascript:Documentation.hideSearchWords()">' + +            Documentation.gettext("Hide Search Matches") + +            "</a></p>" +        ) +    );    },    /**     * helper function to hide the search marks again     */ -  hideSearchWords : function() { -    $('#searchbox .highlight-link').fadeOut(300); -    $('span.highlighted').removeClass('highlighted'); -    var url = new URL(window.location); -    url.searchParams.delete('highlight'); -    window.history.replaceState({}, '', url); +  hideSearchWords: () => { +    document +      .querySelectorAll("#searchbox .highlight-link") +      .forEach((el) => el.remove()); +    document +      .querySelectorAll("span.highlighted") +      .forEach((el) => el.classList.remove("highlighted")); +    const url = new URL(window.location); +    url.searchParams.delete("highlight"); +    window.history.replaceState({}, "", url);    }, -   /** +  /**     * helper function to focus on search bar     */ -  focusSearchBar : function() { -    $('input[name=q]').first().focus(); +  focusSearchBar: () => { +    document.querySelectorAll("input[name=q]")[0]?.focus();    },    /** -   * make the url absolute +   * Initialise the domain index toggle buttons     */ -  makeURL : function(relativeURL) { -    return DOCUMENTATION_OPTIONS.URL_ROOT + '/' + relativeURL; -  }, +  initDomainIndexTable: () => { +    const toggler = (el) => { +      const idNumber = el.id.substr(7); +      const toggledRows = document.querySelectorAll(`tr.cg-${idNumber}`); +      if (el.src.substr(-9) === "minus.png") { +        el.src = `${el.src.substr(0, el.src.length - 9)}plus.png`; +        toggledRows.forEach((el) => (el.style.display = "none")); +      } else { +        el.src = `${el.src.substr(0, el.src.length - 8)}minus.png`; +        toggledRows.forEach((el) => (el.style.display = "")); +      } +    }; -  /** -   * 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); +    const togglerElements = document.querySelectorAll("img.toggler"); +    togglerElements.forEach((el) => +      el.addEventListener("click", (event) => toggler(event.currentTarget)) +    ); +    togglerElements.forEach((el) => (el.style.display = "")); +    if (DOCUMENTATION_OPTIONS.COLLAPSE_INDEX) togglerElements.forEach(toggler);    }, -  initOnKeyListeners: function() { +  initOnKeyListeners: () => {      // only install a listener if it is really needed -    if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && -        !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -        return; +    if ( +      !DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS && +      !DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS +    ) +      return; -    $(document).keydown(function(event) { -      var activeElementType = document.activeElement.tagName; -      // don't navigate when in search box, textarea, dropdown or button -      if (activeElementType !== 'TEXTAREA' && activeElementType !== 'INPUT' && activeElementType !== 'SELECT' -          && activeElementType !== 'BUTTON') { -        if (event.altKey || event.ctrlKey || event.metaKey) -          return; +    const blacklistedElements = new Set([ +      "TEXTAREA", +      "INPUT", +      "SELECT", +      "BUTTON", +    ]); +    document.addEventListener("keydown", (event) => { +      if (blacklistedElements.has(document.activeElement.tagName)) return; // bail for input elements +      if (event.altKey || event.ctrlKey || event.metaKey) return; // bail with special keys -          if (!event.shiftKey) { -            switch (event.key) { -              case 'ArrowLeft': -                if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) -                  break; -                var prevHref = $('link[rel="prev"]').prop('href'); -                if (prevHref) { -                  window.location.href = prevHref; -                  return false; -                } -                break; -              case 'ArrowRight': -                if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) -                  break; -                var nextHref = $('link[rel="next"]').prop('href'); -                if (nextHref) { -                  window.location.href = nextHref; -                  return false; -                } -                break; -              case 'Escape': -                if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -                  break; -                Documentation.hideSearchWords(); -                return false; -          } -        } - -        // some keyboard layouts may need Shift to get / +      if (!event.shiftKey) {          switch (event.key) { -          case '/': -            if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) -              break; -            Documentation.focusSearchBar(); -            return false; +          case "ArrowLeft": +            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + +            const prevLink = document.querySelector('link[rel="prev"]'); +            if (prevLink && prevLink.href) { +              window.location.href = prevLink.href; +              event.preventDefault(); +            } +            break; +          case "ArrowRight": +            if (!DOCUMENTATION_OPTIONS.NAVIGATION_WITH_KEYS) break; + +            const nextLink = document.querySelector('link[rel="next"]'); +            if (nextLink && nextLink.href) { +              window.location.href = nextLink.href; +              event.preventDefault(); +            } +            break; +          case "Escape": +            if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; +            Documentation.hideSearchWords(); +            event.preventDefault();          }        } + +      // some keyboard layouts may need Shift to get / +      switch (event.key) { +        case "/": +          if (!DOCUMENTATION_OPTIONS.ENABLE_SEARCH_SHORTCUTS) break; +          Documentation.focusSearchBar(); +          event.preventDefault(); +      }      }); -  } +  },  };  // quick alias for translations -_ = Documentation.gettext; +const _ = Documentation.gettext; -$(document).ready(function() { -  Documentation.init(); -}); +_ready(Documentation.init); diff --git a/v7.1.3/_static/documentation_options.js b/v7.1.3/_static/documentation_options.js index bc162b8f..e18dc2b7 100644 --- a/v7.1.3/_static/documentation_options.js +++ b/v7.1.3/_static/documentation_options.js @@ -1,7 +1,7 @@  var DOCUMENTATION_OPTIONS = {      URL_ROOT: document.getElementById("documentation_options").getAttribute('data-url_root'),      VERSION: '7.1.3', -    LANGUAGE: 'None', +    LANGUAGE: 'en',      COLLAPSE_INDEX: false,      BUILDER: 'html',      FILE_SUFFIX: '.html', @@ -10,5 +10,5 @@ var DOCUMENTATION_OPTIONS = {      SOURCELINK_SUFFIX: '.txt',      NAVIGATION_WITH_KEYS: false,      SHOW_SEARCH_SUMMARY: true, -    ENABLE_SEARCH_SHORTCUTS: true, +    ENABLE_SEARCH_SHORTCUTS: false,  };
\ No newline at end of file diff --git a/v7.1.3/_static/jquery-3.5.1.js b/v7.1.3/_static/jquery-3.5.1.js deleted file mode 100644 index 50937333..00000000 --- a/v7.1.3/_static/jquery-3.5.1.js +++ /dev/null @@ -1,10872 +0,0 @@ -/*! - * jQuery JavaScript Library v3.5.1 - * https://jquery.com/ - * - * Includes Sizzle.js - * https://sizzlejs.com/ - * - * Copyright JS Foundation and other contributors - * Released under the MIT license - * https://jquery.org/license - * - * Date: 2020-05-04T22:49Z - */ -( function( global, factory ) { - -	"use strict"; - -	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 have a `window` with a `document` -		// (such as Node.js), expose a 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 ) { - -// Edge <= 12 - 13+, Firefox <=18 - 45+, IE 10 - 11, Safari 5.1 - 9+, iOS 6 - 9.1 -// throw exceptions when non-strict code (e.g., ASP.NET 4.5) accesses strict mode -// arguments.callee.caller (trac-13335). But as of jQuery 3.0 (2016), strict mode should be common -// enough that all such attempts are guarded in a try block. -"use strict"; - -var arr = []; - -var getProto = Object.getPrototypeOf; - -var slice = arr.slice; - -var flat = arr.flat ? function( array ) { -	return arr.flat.call( array ); -} : function( array ) { -	return arr.concat.apply( [], array ); -}; - - -var push = arr.push; - -var indexOf = arr.indexOf; - -var class2type = {}; - -var toString = class2type.toString; - -var hasOwn = class2type.hasOwnProperty; - -var fnToString = hasOwn.toString; - -var ObjectFunctionString = fnToString.call( Object ); - -var support = {}; - -var isFunction = function isFunction( obj ) { - -      // Support: Chrome <=57, Firefox <=52 -      // In some browsers, typeof returns "function" for HTML <object> elements -      // (i.e., `typeof document.createElement( "object" ) === "function"`). -      // We don't want to classify *any* DOM node as a function. -      return typeof obj === "function" && typeof obj.nodeType !== "number"; -  }; - - -var isWindow = function isWindow( obj ) { -		return obj != null && obj === obj.window; -	}; - - -var document = window.document; - - - -	var preservedScriptAttributes = { -		type: true, -		src: true, -		nonce: true, -		noModule: true -	}; - -	function DOMEval( code, node, doc ) { -		doc = doc || document; - -		var i, val, -			script = doc.createElement( "script" ); - -		script.text = code; -		if ( node ) { -			for ( i in preservedScriptAttributes ) { - -				// Support: Firefox 64+, Edge 18+ -				// Some browsers don't support the "nonce" property on scripts. -				// On the other hand, just using `getAttribute` is not enough as -				// the `nonce` attribute is reset to an empty string whenever it -				// becomes browsing-context connected. -				// See https://github.com/whatwg/html/issues/2369 -				// See https://html.spec.whatwg.org/#nonce-attributes -				// The `node.getAttribute` check was added for the sake of -				// `jQuery.globalEval` so that it can fake a nonce-containing node -				// via an object. -				val = node[ i ] || node.getAttribute && node.getAttribute( i ); -				if ( val ) { -					script.setAttribute( i, val ); -				} -			} -		} -		doc.head.appendChild( script ).parentNode.removeChild( script ); -	} - - -function toType( obj ) { -	if ( obj == null ) { -		return obj + ""; -	} - -	// Support: Android <=2.3 only (functionish RegExp) -	return typeof obj === "object" || typeof obj === "function" ? -		class2type[ toString.call( obj ) ] || "object" : -		typeof obj; -} -/* global Symbol */ -// Defining this global in .eslintrc.json would create a danger of using the global -// unguarded in another place, it seems safer to define global only for this module - - - -var -	version = "3.5.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 ); -	}; - -jQuery.fn = jQuery.prototype = { - -	// The current version of jQuery being used -	jquery: version, - -	constructor: jQuery, - -	// 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 all the elements in a clean array -		if ( num == null ) { -			return slice.call( this ); -		} - -		// Return just the one element from the set -		return num < 0 ? this[ num + this.length ] : this[ num ]; -	}, - -	// 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; - -		// Return the newly-formed element set -		return ret; -	}, - -	// Execute a callback for every element in the matched set. -	each: function( callback ) { -		return jQuery.each( this, callback ); -	}, - -	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 ); -	}, - -	even: function() { -		return this.pushStack( jQuery.grep( this, function( _elem, i ) { -			return ( i + 1 ) % 2; -		} ) ); -	}, - -	odd: function() { -		return this.pushStack( jQuery.grep( this, function( _elem, i ) { -			return i % 2; -		} ) ); -	}, - -	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(); -	}, - -	// For internal use only. -	// Behaves like an Array's method, not like a jQuery method. -	push: push, -	sort: arr.sort, -	splice: arr.splice -}; - -jQuery.extend = jQuery.fn.extend = function() { -	var options, name, src, copy, copyIsArray, 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" && !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 ) { -				copy = options[ name ]; - -				// Prevent Object.prototype pollution -				// Prevent never-ending loop -				if ( name === "__proto__" || target === copy ) { -					continue; -				} - -				// Recurse if we're merging plain objects or arrays -				if ( deep && copy && ( jQuery.isPlainObject( copy ) || -					( copyIsArray = Array.isArray( copy ) ) ) ) { -					src = target[ name ]; - -					// Ensure proper type for the source value -					if ( copyIsArray && !Array.isArray( src ) ) { -						clone = []; -					} else if ( !copyIsArray && !jQuery.isPlainObject( src ) ) { -						clone = {}; -					} else { -						clone = src; -					} -					copyIsArray = false; - -					// 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() {}, - -	isPlainObject: function( obj ) { -		var proto, Ctor; - -		// Detect obvious negatives -		// Use toString instead of jQuery.type to catch host objects -		if ( !obj || toString.call( obj ) !== "[object Object]" ) { -			return false; -		} - -		proto = getProto( obj ); - -		// Objects with no prototype (e.g., `Object.create( null )`) are plain -		if ( !proto ) { -			return true; -		} - -		// Objects with prototype are plain iff they were constructed by a global Object function -		Ctor = hasOwn.call( proto, "constructor" ) && proto.constructor; -		return typeof Ctor === "function" && fnToString.call( Ctor ) === ObjectFunctionString; -	}, - -	isEmptyObject: function( obj ) { -		var name; - -		for ( name in obj ) { -			return false; -		} -		return true; -	}, - -	// Evaluates a script in a provided context; falls back to the global one -	// if not specified. -	globalEval: function( code, options, doc ) { -		DOMEval( code, { nonce: options && options.nonce }, doc ); -	}, - -	each: function( obj, callback ) { -		var length, i = 0; - -		if ( isArrayLike( obj ) ) { -			length = obj.length; -			for ( ; i < length; i++ ) { -				if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) { -					break; -				} -			} -		} else { -			for ( i in obj ) { -				if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) { -					break; -				} -			} -		} - -		return obj; -	}, - -	// 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 ) { -		return arr == null ? -1 : indexOf.call( arr, elem, i ); -	}, - -	// Support: Android <=4.0 only, PhantomJS 1 only -	// push.apply(_, arraylike) throws on ancient WebKit -	merge: function( first, second ) { -		var len = +second.length, -			j = 0, -			i = first.length; - -		for ( ; j < len; j++ ) { -			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 length, value, -			i = 0, -			ret = []; - -		// Go through the array, translating each of the items to their new values -		if ( isArrayLike( elems ) ) { -			length = elems.length; -			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 flat( ret ); -	}, - -	// A global GUID counter for objects -	guid: 1, - -	// jQuery.support is not used in Core but other projects attach their -	// properties to it so it needs to exist. -	support: support -} ); - -if ( typeof Symbol === "function" ) { -	jQuery.fn[ Symbol.iterator ] = arr[ Symbol.iterator ]; -} - -// Populate the class2type map -jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ), -function( _i, name ) { -	class2type[ "[object " + name + "]" ] = name.toLowerCase(); -} ); - -function isArrayLike( obj ) { - -	// Support: real iOS 8.2 only (not reproducible in simulator) -	// `in` check used to prevent JIT error (gh-2145) -	// hasOwn isn't used here due to false negatives -	// regarding Nodelist length in IE -	var length = !!obj && "length" in obj && obj.length, -		type = toType( obj ); - -	if ( isFunction( obj ) || isWindow( obj ) ) { -		return false; -	} - -	return type === "array" || length === 0 || -		typeof length === "number" && length > 0 && ( length - 1 ) in obj; -} -var Sizzle = -/*! - * Sizzle CSS Selector Engine v2.3.5 - * https://sizzlejs.com/ - * - * Copyright JS Foundation and other contributors - * Released under the MIT license - * https://js.foundation/ - * - * Date: 2020-03-14 - */ -( 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" + 1 * new Date(), -	preferredDoc = window.document, -	dirruns = 0, -	done = 0, -	classCache = createCache(), -	tokenCache = createCache(), -	compilerCache = createCache(), -	nonnativeSelectorCache = createCache(), -	sortOrder = function( a, b ) { -		if ( a === b ) { -			hasDuplicate = true; -		} -		return 0; -	}, - -	// Instance methods -	hasOwn = ( {} ).hasOwnProperty, -	arr = [], -	pop = arr.pop, -	pushNative = arr.push, -	push = arr.push, -	slice = arr.slice, - -	// Use a stripped-down indexOf as it's faster than native -	// https://jsperf.com/thor-indexof-vs-for/5 -	indexOf = function( list, elem ) { -		var i = 0, -			len = list.length; -		for ( ; i < len; i++ ) { -			if ( list[ 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 - -	// http://www.w3.org/TR/css3-selectors/#whitespace -	whitespace = "[\\x20\\t\\r\\n\\f]", - -	// https://www.w3.org/TR/css-syntax-3/#ident-token-diagram -	identifier = "(?:\\\\[\\da-fA-F]{1,6}" + whitespace + -		"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+", - -	// Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors -	attributes = "\\[" + whitespace + "*(" + identifier + ")(?:" + whitespace + - -		// Operator (capture 2) -		"*([*^$|!~]?=)" + whitespace + - -		// "Attribute values must be CSS identifiers [capture 5] -		// or strings [capture 3 or capture 4]" -		"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + identifier + "))|)" + -		whitespace + "*\\]", - -	pseudos = ":(" + identifier + ")(?:\\((" + - -		// 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 -	rwhitespace = new RegExp( whitespace + "+", "g" ), -	rtrim = new RegExp( "^" + whitespace + "+|((?:^|[^\\\\])(?:\\\\.)*)" + -		whitespace + "+$", "g" ), - -	rcomma = new RegExp( "^" + whitespace + "*," + whitespace + "*" ), -	rcombinators = new RegExp( "^" + whitespace + "*([>+~]|" + whitespace + ")" + whitespace + -		"*" ), -	rdescend = new RegExp( whitespace + "|>" ), - -	rpseudo = new RegExp( pseudos ), -	ridentifier = new RegExp( "^" + identifier + "$" ), - -	matchExpr = { -		"ID": new RegExp( "^#(" + identifier + ")" ), -		"CLASS": new RegExp( "^\\.(" + identifier + ")" ), -		"TAG": new RegExp( "^(" + identifier + "|[*])" ), -		"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" ) -	}, - -	rhtml = /HTML$/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 = /[+~]/, - -	// CSS escapes -	// http://www.w3.org/TR/CSS21/syndata.html#escaped-characters -	runescape = new RegExp( "\\\\[\\da-fA-F]{1,6}" + whitespace + "?|\\\\([^\\r\\n\\f])", "g" ), -	funescape = function( escape, nonHex ) { -		var high = "0x" + escape.slice( 1 ) - 0x10000; - -		return nonHex ? - -			// Strip the backslash prefix from a non-hex escape sequence -			nonHex : - -			// Replace a hexadecimal escape sequence with the encoded Unicode code point -			// Support: IE <=11+ -			// For values outside the Basic Multilingual Plane (BMP), manually construct a -			// surrogate pair -			high < 0 ? -				String.fromCharCode( high + 0x10000 ) : -				String.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 ); -	}, - -	// CSS string/identifier serialization -	// https://drafts.csswg.org/cssom/#common-serializing-idioms -	rcssescape = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g, -	fcssescape = function( ch, asCodePoint ) { -		if ( asCodePoint ) { - -			// U+0000 NULL becomes U+FFFD REPLACEMENT CHARACTER -			if ( ch === "\0" ) { -				return "\uFFFD"; -			} - -			// Control characters and (dependent upon position) numbers get escaped as code points -			return ch.slice( 0, -1 ) + "\\" + -				ch.charCodeAt( ch.length - 1 ).toString( 16 ) + " "; -		} - -		// Other potentially-special ASCII characters get backslash-escaped -		return "\\" + ch; -	}, - -	// Used for iframes -	// See setDocument() -	// Removing the function wrapper causes a "Permission Denied" -	// error in IE -	unloadHandler = function() { -		setDocument(); -	}, - -	inDisabledFieldset = addCombinator( -		function( elem ) { -			return elem.disabled === true && elem.nodeName.toLowerCase() === "fieldset"; -		}, -		{ dir: "parentNode", next: "legend" } -	); - -// Optimize for push.apply( _, NodeList ) -try { -	push.apply( -		( arr = slice.call( preferredDoc.childNodes ) ), -		preferredDoc.childNodes -	); - -	// Support: Android<4.0 -	// Detect silently failing push.apply -	// eslint-disable-next-line no-unused-expressions -	arr[ preferredDoc.childNodes.length ].nodeType; -} catch ( e ) { -	push = { apply: arr.length ? - -		// Leverage slice if possible -		function( target, els ) { -			pushNative.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 m, i, elem, nid, match, groups, newSelector, -		newContext = context && context.ownerDocument, - -		// nodeType defaults to 9, since context defaults to document -		nodeType = context ? context.nodeType : 9; - -	results = results || []; - -	// Return early from calls with invalid selector or context -	if ( typeof selector !== "string" || !selector || -		nodeType !== 1 && nodeType !== 9 && nodeType !== 11 ) { - -		return results; -	} - -	// Try to shortcut find operations (as opposed to filters) in HTML documents -	if ( !seed ) { -		setDocument( context ); -		context = context || document; - -		if ( documentIsHTML ) { - -			// If the selector is sufficiently simple, try using a "get*By*" DOM method -			// (excepting DocumentFragment context, where the methods don't exist) -			if ( nodeType !== 11 && ( match = rquickExpr.exec( selector ) ) ) { - -				// ID selector -				if ( ( m = match[ 1 ] ) ) { - -					// Document context -					if ( nodeType === 9 ) { -						if ( ( elem = context.getElementById( m ) ) ) { - -							// Support: IE, Opera, Webkit -							// TODO: identify versions -							// getElementById can match elements by name instead of ID -							if ( elem.id === m ) { -								results.push( elem ); -								return results; -							} -						} else { -							return results; -						} - -					// Element context -					} else { - -						// Support: IE, Opera, Webkit -						// TODO: identify versions -						// getElementById can match elements by name instead of ID -						if ( newContext && ( elem = newContext.getElementById( m ) ) && -							contains( context, elem ) && -							elem.id === m ) { - -							results.push( elem ); -							return results; -						} -					} - -				// Type selector -				} else if ( match[ 2 ] ) { -					push.apply( results, context.getElementsByTagName( selector ) ); -					return results; - -				// Class selector -				} else if ( ( m = match[ 3 ] ) && support.getElementsByClassName && -					context.getElementsByClassName ) { - -					push.apply( results, context.getElementsByClassName( m ) ); -					return results; -				} -			} - -			// Take advantage of querySelectorAll -			if ( support.qsa && -				!nonnativeSelectorCache[ selector + " " ] && -				( !rbuggyQSA || !rbuggyQSA.test( selector ) ) && - -				// Support: IE 8 only -				// Exclude object elements -				( nodeType !== 1 || context.nodeName.toLowerCase() !== "object" ) ) { - -				newSelector = selector; -				newContext = context; - -				// qSA considers elements outside a scoping root when evaluating child or -				// descendant combinators, which is not what we want. -				// In such cases, we work around the behavior by prefixing every selector in the -				// list with an ID selector referencing the scope context. -				// The technique has to be used as well when a leading combinator is used -				// as such selectors are not recognized by querySelectorAll. -				// Thanks to Andrew Dupont for this technique. -				if ( nodeType === 1 && -					( rdescend.test( selector ) || rcombinators.test( selector ) ) ) { - -					// Expand context for sibling selectors -					newContext = rsibling.test( selector ) && testContext( context.parentNode ) || -						context; - -					// We can use :scope instead of the ID hack if the browser -					// supports it & if we're not changing the context. -					if ( newContext !== context || !support.scope ) { - -						// Capture the context ID, setting it first if necessary -						if ( ( nid = context.getAttribute( "id" ) ) ) { -							nid = nid.replace( rcssescape, fcssescape ); -						} else { -							context.setAttribute( "id", ( nid = expando ) ); -						} -					} - -					// Prefix every selector in the list -					groups = tokenize( selector ); -					i = groups.length; -					while ( i-- ) { -						groups[ i ] = ( nid ? "#" + nid : ":scope" ) + " " + -							toSelector( groups[ i ] ); -					} -					newSelector = groups.join( "," ); -				} - -				try { -					push.apply( results, -						newContext.querySelectorAll( newSelector ) -					); -					return results; -				} catch ( qsaError ) { -					nonnativeSelectorCache( selector, true ); -				} finally { -					if ( nid === expando ) { -						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 element and returns a boolean result - */ -function assert( fn ) { -	var el = document.createElement( "fieldset" ); - -	try { -		return !!fn( el ); -	} catch ( e ) { -		return false; -	} finally { - -		// Remove from its parent by default -		if ( el.parentNode ) { -			el.parentNode.removeChild( el ); -		} - -		// release memory in IE -		el = 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 = arr.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 && -			a.sourceIndex - b.sourceIndex; - -	// 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 :enabled/:disabled - * @param {Boolean} disabled true for :disabled; false for :enabled - */ -function createDisabledPseudo( disabled ) { - -	// Known :disabled false positives: fieldset[disabled] > legend:nth-of-type(n+2) :can-disable -	return function( elem ) { - -		// Only certain elements can match :enabled or :disabled -		// https://html.spec.whatwg.org/multipage/scripting.html#selector-enabled -		// https://html.spec.whatwg.org/multipage/scripting.html#selector-disabled -		if ( "form" in elem ) { - -			// Check for inherited disabledness on relevant non-disabled elements: -			// * listed form-associated elements in a disabled fieldset -			//   https://html.spec.whatwg.org/multipage/forms.html#category-listed -			//   https://html.spec.whatwg.org/multipage/forms.html#concept-fe-disabled -			// * option elements in a disabled optgroup -			//   https://html.spec.whatwg.org/multipage/forms.html#concept-option-disabled -			// All such elements have a "form" property. -			if ( elem.parentNode && elem.disabled === false ) { - -				// Option elements defer to a parent optgroup if present -				if ( "label" in elem ) { -					if ( "label" in elem.parentNode ) { -						return elem.parentNode.disabled === disabled; -					} else { -						return elem.disabled === disabled; -					} -				} - -				// Support: IE 6 - 11 -				// Use the isDisabled shortcut property to check for disabled fieldset ancestors -				return elem.isDisabled === disabled || - -					// Where there is no isDisabled, check manually -					/* jshint -W018 */ -					elem.isDisabled !== !disabled && -					inDisabledFieldset( elem ) === disabled; -			} - -			return elem.disabled === disabled; - -		// Try to winnow out elements that can't be disabled before trusting the disabled property. -		// Some victims get caught in our net (label, legend, menu, track), but it shouldn't -		// even exist on them, let alone have a boolean value. -		} else if ( "label" in elem ) { -			return elem.disabled === disabled; -		} - -		// Remaining elements are neither :enabled nor :disabled -		return false; -	}; -} - -/** - * 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 !== "undefined" && 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 ) { -	var namespace = elem.namespaceURI, -		docElem = ( elem.ownerDocument || elem ).documentElement; - -	// Support: IE <=8 -	// Assume HTML when documentElement doesn't yet exist, such as inside loading iframes -	// https://bugs.jquery.com/ticket/4833 -	return !rhtml.test( namespace || docElem && docElem.nodeName || "HTML" ); -}; - -/** - * 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, subWindow, -		doc = node ? node.ownerDocument || node : preferredDoc; - -	// Return early if doc is invalid or already selected -	// Support: IE 11+, Edge 17 - 18+ -	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing -	// two documents; shallow comparisons work. -	// eslint-disable-next-line eqeqeq -	if ( doc == document || doc.nodeType !== 9 || !doc.documentElement ) { -		return document; -	} - -	// Update global variables -	document = doc; -	docElem = document.documentElement; -	documentIsHTML = !isXML( document ); - -	// Support: IE 9 - 11+, Edge 12 - 18+ -	// Accessing iframe documents after unload throws "permission denied" errors (jQuery #13936) -	// Support: IE 11+, Edge 17 - 18+ -	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing -	// two documents; shallow comparisons work. -	// eslint-disable-next-line eqeqeq -	if ( preferredDoc != document && -		( subWindow = document.defaultView ) && subWindow.top !== subWindow ) { - -		// Support: IE 11, Edge -		if ( subWindow.addEventListener ) { -			subWindow.addEventListener( "unload", unloadHandler, false ); - -		// Support: IE 9 - 10 only -		} else if ( subWindow.attachEvent ) { -			subWindow.attachEvent( "onunload", unloadHandler ); -		} -	} - -	// Support: IE 8 - 11+, Edge 12 - 18+, Chrome <=16 - 25 only, Firefox <=3.6 - 31 only, -	// Safari 4 - 5 only, Opera <=11.6 - 12.x only -	// IE/Edge & older browsers don't support the :scope pseudo-class. -	// Support: Safari 6.0 only -	// Safari 6.0 supports :scope but it's an alias of :root there. -	support.scope = assert( function( el ) { -		docElem.appendChild( el ).appendChild( document.createElement( "div" ) ); -		return typeof el.querySelectorAll !== "undefined" && -			!el.querySelectorAll( ":scope fieldset div" ).length; -	} ); - -	/* Attributes -	---------------------------------------------------------------------- */ - -	// Support: IE<8 -	// Verify that getAttribute really returns attributes and not properties -	// (excepting IE8 booleans) -	support.attributes = assert( function( el ) { -		el.className = "i"; -		return !el.getAttribute( "className" ); -	} ); - -	/* getElement(s)By* -	---------------------------------------------------------------------- */ - -	// Check if getElementsByTagName("*") returns only elements -	support.getElementsByTagName = assert( function( el ) { -		el.appendChild( document.createComment( "" ) ); -		return !el.getElementsByTagName( "*" ).length; -	} ); - -	// Support: IE<9 -	support.getElementsByClassName = rnative.test( document.getElementsByClassName ); - -	// Support: IE<10 -	// Check if getElementById returns elements by name -	// The broken getElementById methods don't pick up programmatically-set names, -	// so use a roundabout getElementsByName test -	support.getById = assert( function( el ) { -		docElem.appendChild( el ).id = expando; -		return !document.getElementsByName || !document.getElementsByName( expando ).length; -	} ); - -	// ID filter and find -	if ( support.getById ) { -		Expr.filter[ "ID" ] = function( id ) { -			var attrId = id.replace( runescape, funescape ); -			return function( elem ) { -				return elem.getAttribute( "id" ) === attrId; -			}; -		}; -		Expr.find[ "ID" ] = function( id, context ) { -			if ( typeof context.getElementById !== "undefined" && documentIsHTML ) { -				var elem = context.getElementById( id ); -				return elem ? [ elem ] : []; -			} -		}; -	} else { -		Expr.filter[ "ID" ] =  function( id ) { -			var attrId = id.replace( runescape, funescape ); -			return function( elem ) { -				var node = typeof elem.getAttributeNode !== "undefined" && -					elem.getAttributeNode( "id" ); -				return node && node.value === attrId; -			}; -		}; - -		// Support: IE 6 - 7 only -		// getElementById is not reliable as a find shortcut -		Expr.find[ "ID" ] = function( id, context ) { -			if ( typeof context.getElementById !== "undefined" && documentIsHTML ) { -				var node, i, elems, -					elem = context.getElementById( id ); - -				if ( elem ) { - -					// Verify the id attribute -					node = elem.getAttributeNode( "id" ); -					if ( node && node.value === id ) { -						return [ elem ]; -					} - -					// Fall back on getElementsByName -					elems = context.getElementsByName( id ); -					i = 0; -					while ( ( elem = elems[ i++ ] ) ) { -						node = elem.getAttributeNode( "id" ); -						if ( node && node.value === id ) { -							return [ elem ]; -						} -					} -				} - -				return []; -			} -		}; -	} - -	// Tag -	Expr.find[ "TAG" ] = support.getElementsByTagName ? -		function( tag, context ) { -			if ( typeof context.getElementsByTagName !== "undefined" ) { -				return context.getElementsByTagName( tag ); - -			// DocumentFragment nodes don't have gEBTN -			} else if ( support.qsa ) { -				return context.querySelectorAll( tag ); -			} -		} : - -		function( tag, context ) { -			var elem, -				tmp = [], -				i = 0, - -				// By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too -				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 !== "undefined" && 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 https://bugs.jquery.com/ticket/13378 -	rbuggyQSA = []; - -	if ( ( support.qsa = rnative.test( document.querySelectorAll ) ) ) { - -		// Build QSA regex -		// Regex strategy adopted from Diego Perini -		assert( function( el ) { - -			var input; - -			// 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 -			// https://bugs.jquery.com/ticket/12359 -			docElem.appendChild( el ).innerHTML = "<a id='" + expando + "'></a>" + -				"<select id='" + expando + "-\r\\' msallowcapture=''>" + -				"<option selected=''></option></select>"; - -			// 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 -			// https://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section -			if ( el.querySelectorAll( "[msallowcapture^='']" ).length ) { -				rbuggyQSA.push( "[*^$]=" + whitespace + "*(?:''|\"\")" ); -			} - -			// Support: IE8 -			// Boolean attributes and "value" are not treated correctly -			if ( !el.querySelectorAll( "[selected]" ).length ) { -				rbuggyQSA.push( "\\[" + whitespace + "*(?:value|" + booleans + ")" ); -			} - -			// Support: Chrome<29, Android<4.4, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.8+ -			if ( !el.querySelectorAll( "[id~=" + expando + "-]" ).length ) { -				rbuggyQSA.push( "~=" ); -			} - -			// Support: IE 11+, Edge 15 - 18+ -			// IE 11/Edge don't find elements on a `[name='']` query in some cases. -			// Adding a temporary attribute to the document before the selection works -			// around the issue. -			// Interestingly, IE 10 & older don't seem to have the issue. -			input = document.createElement( "input" ); -			input.setAttribute( "name", "" ); -			el.appendChild( input ); -			if ( !el.querySelectorAll( "[name='']" ).length ) { -				rbuggyQSA.push( "\\[" + whitespace + "*name" + whitespace + "*=" + -					whitespace + "*(?:''|\"\")" ); -			} - -			// 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 ( !el.querySelectorAll( ":checked" ).length ) { -				rbuggyQSA.push( ":checked" ); -			} - -			// Support: Safari 8+, iOS 8+ -			// https://bugs.webkit.org/show_bug.cgi?id=136851 -			// In-page `selector#id sibling-combinator selector` fails -			if ( !el.querySelectorAll( "a#" + expando + "+*" ).length ) { -				rbuggyQSA.push( ".#.+[+~]" ); -			} - -			// Support: Firefox <=3.6 - 5 only -			// Old Firefox doesn't throw on a badly-escaped identifier. -			el.querySelectorAll( "\\\f" ); -			rbuggyQSA.push( "[\\r\\n\\f]" ); -		} ); - -		assert( function( el ) { -			el.innerHTML = "<a href='' disabled='disabled'></a>" + -				"<select disabled='disabled'><option/></select>"; - -			// Support: Windows 8 Native Apps -			// The type and name attributes are restricted during .innerHTML assignment -			var input = document.createElement( "input" ); -			input.setAttribute( "type", "hidden" ); -			el.appendChild( input ).setAttribute( "name", "D" ); - -			// Support: IE8 -			// Enforce case-sensitivity of name attribute -			if ( el.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 ( el.querySelectorAll( ":enabled" ).length !== 2 ) { -				rbuggyQSA.push( ":enabled", ":disabled" ); -			} - -			// Support: IE9-11+ -			// IE's :disabled selector does not pick up the children of disabled fieldsets -			docElem.appendChild( el ).disabled = true; -			if ( el.querySelectorAll( ":disabled" ).length !== 2 ) { -				rbuggyQSA.push( ":enabled", ":disabled" ); -			} - -			// Support: Opera 10 - 11 only -			// Opera 10-11 does not throw on post-comma invalid pseudos -			el.querySelectorAll( "*,:x" ); -			rbuggyQSA.push( ",.*:" ); -		} ); -	} - -	if ( ( support.matchesSelector = rnative.test( ( matches = docElem.matches || -		docElem.webkitMatchesSelector || -		docElem.mozMatchesSelector || -		docElem.oMatchesSelector || -		docElem.msMatchesSelector ) ) ) ) { - -		assert( function( el ) { - -			// Check to see if it's possible to do matchesSelector -			// on a disconnected node (IE 9) -			support.disconnectedMatch = matches.call( el, "*" ); - -			// This should fail with an exception -			// Gecko does not error, returns false instead -			matches.call( el, "[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 self-exclusive -	// 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 -		// Support: IE 11+, Edge 17 - 18+ -		// IE/Edge sometimes throw a "Permission denied" error when strict-comparing -		// two documents; shallow comparisons work. -		// eslint-disable-next-line eqeqeq -		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 -			// Support: IE 11+, Edge 17 - 18+ -			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing -			// two documents; shallow comparisons work. -			// eslint-disable-next-line eqeqeq -			if ( a == document || a.ownerDocument == preferredDoc && -				contains( preferredDoc, a ) ) { -				return -1; -			} - -			// Support: IE 11+, Edge 17 - 18+ -			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing -			// two documents; shallow comparisons work. -			// eslint-disable-next-line eqeqeq -			if ( b == document || b.ownerDocument == preferredDoc && -				contains( preferredDoc, b ) ) { -				return 1; -			} - -			// Maintain original order -			return sortInput ? -				( indexOf( sortInput, a ) - indexOf( 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 ) { - -			// Support: IE 11+, Edge 17 - 18+ -			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing -			// two documents; shallow comparisons work. -			/* eslint-disable eqeqeq */ -			return a == document ? -1 : -				b == document ? 1 : -				/* eslint-enable eqeqeq */ -				aup ? -1 : -				bup ? 1 : -				sortInput ? -				( indexOf( sortInput, a ) - indexOf( 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 -			// Support: IE 11+, Edge 17 - 18+ -			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing -			// two documents; shallow comparisons work. -			/* eslint-disable eqeqeq */ -			ap[ i ] == preferredDoc ? -1 : -			bp[ i ] == preferredDoc ? 1 : -			/* eslint-enable eqeqeq */ -			0; -	}; - -	return document; -}; - -Sizzle.matches = function( expr, elements ) { -	return Sizzle( expr, null, null, elements ); -}; - -Sizzle.matchesSelector = function( elem, expr ) { -	setDocument( elem ); - -	if ( support.matchesSelector && documentIsHTML && -		!nonnativeSelectorCache[ expr + " " ] && -		( !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 ) { -			nonnativeSelectorCache( expr, true ); -		} -	} - -	return Sizzle( expr, document, null, [ elem ] ).length > 0; -}; - -Sizzle.contains = function( context, elem ) { - -	// Set document vars if needed -	// Support: IE 11+, Edge 17 - 18+ -	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing -	// two documents; shallow comparisons work. -	// eslint-disable-next-line eqeqeq -	if ( ( context.ownerDocument || context ) != document ) { -		setDocument( context ); -	} -	return contains( context, elem ); -}; - -Sizzle.attr = function( elem, name ) { - -	// Set document vars if needed -	// Support: IE 11+, Edge 17 - 18+ -	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing -	// two documents; shallow comparisons work. -	// eslint-disable-next-line eqeqeq -	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.escape = function( sel ) { -	return ( sel + "" ).replace( rcssescape, fcssescape ); -}; - -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 !== "undefined" && -									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 += ""; - -				/* eslint-disable max-len */ - -				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.replace( rwhitespace, " " ) + " " ).indexOf( check ) > -1 : -					operator === "|=" ? result === check || result.slice( 0, check.length + 1 ) === check + "-" : -					false; -				/* eslint-enable max-len */ - -			}; -		}, - -		"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, uniqueCache, outerCache, node, nodeIndex, start, -						dir = simple !== forward ? "nextSibling" : "previousSibling", -						parent = elem.parentNode, -						name = ofType && elem.nodeName.toLowerCase(), -						useCache = !xml && !ofType, -						diff = false; - -					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 - -							// ...in a gzip-friendly way -							node = parent; -							outerCache = node[ expando ] || ( node[ expando ] = {} ); - -							// Support: IE <9 only -							// Defend against cloned attroperties (jQuery gh-1709) -							uniqueCache = outerCache[ node.uniqueID ] || -								( outerCache[ node.uniqueID ] = {} ); - -							cache = uniqueCache[ type ] || []; -							nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ]; -							diff = nodeIndex && 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 ) { -									uniqueCache[ type ] = [ dirruns, nodeIndex, diff ]; -									break; -								} -							} - -						} else { - -							// Use previously-cached element index if available -							if ( useCache ) { - -								// ...in a gzip-friendly way -								node = elem; -								outerCache = node[ expando ] || ( node[ expando ] = {} ); - -								// Support: IE <9 only -								// Defend against cloned attroperties (jQuery gh-1709) -								uniqueCache = outerCache[ node.uniqueID ] || -									( outerCache[ node.uniqueID ] = {} ); - -								cache = uniqueCache[ type ] || []; -								nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ]; -								diff = nodeIndex; -							} - -							// xml :nth-child(...) -							// or :nth-last-child(...) or :nth(-last)?-of-type(...) -							if ( diff === false ) { - -								// 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 ) { -											outerCache = node[ expando ] || -												( node[ expando ] = {} ); - -											// Support: IE <9 only -											// Defend against cloned attroperties (jQuery gh-1709) -											uniqueCache = outerCache[ node.uniqueID ] || -												( outerCache[ node.uniqueID ] = {} ); - -											uniqueCache[ 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( 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 ); - -					// Don't keep the element (issue #299) -					input[ 0 ] = null; -					return !results.pop(); -				}; -		} ), - -		"has": markFunction( function( selector ) { -			return function( elem ) { -				return Sizzle( selector, elem ).length > 0; -			}; -		} ), - -		"contains": markFunction( function( text ) { -			text = text.replace( runescape, funescape ); -			return function( elem ) { -				return ( elem.textContent || 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": createDisabledPseudo( false ), -		"disabled": createDisabledPseudo( 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 ) { -				// eslint-disable-next-line no-unused-expressions -				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 > length ? -					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, -		skip = combinator.next, -		key = skip || dir, -		checkNonElements = base && key === "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 ); -				} -			} -			return false; -		} : - -		// Check against all ancestor/preceding elements -		function( elem, context, xml ) { -			var oldCache, uniqueCache, outerCache, -				newCache = [ dirruns, doneName ]; - -			// We can't set arbitrary data on XML nodes, so they don't benefit from combinator 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 ] = {} ); - -						// Support: IE <9 only -						// Defend against cloned attroperties (jQuery gh-1709) -						uniqueCache = outerCache[ elem.uniqueID ] || -							( outerCache[ elem.uniqueID ] = {} ); - -						if ( skip && skip === elem.nodeName.toLowerCase() ) { -							elem = elem[ dir ] || elem; -						} else if ( ( oldCache = uniqueCache[ key ] ) && -							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 -							uniqueCache[ key ] = newCache; - -							// A match means we're done; a fail means we have to keep checking -							if ( ( newCache[ 2 ] = matcher( elem, context, xml ) ) ) { -								return true; -							} -						} -					} -				} -			} -			return false; -		}; -} - -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( 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( checkContext, elem ) > -1; -		}, implicitRelative, true ), -		matchers = [ function( elem, context, xml ) { -			var ret = ( !leadingRelative && ( xml || context !== outermostContext ) ) || ( -				( checkContext = context ).nodeType ? -					matchContext( elem, context, xml ) : -					matchAnyContext( elem, context, xml ) ); - -			// Avoid hanging onto element (issue #299) -			checkContext = null; -			return ret; -		} ]; - -	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 ) { - -				// Support: IE 11+, Edge 17 - 18+ -				// IE/Edge sometimes throw a "Permission denied" error when strict-comparing -				// two documents; shallow comparisons work. -				// eslint-disable-next-line eqeqeq -				outermostContext = context == document || context || outermost; -			} - -			// Add elements passing elementMatchers directly to results -			// Support: IE<9, Safari -			// Tolerate NodeList properties (IE: "length"; Safari: <number>) matching elements by id -			for ( ; i !== len && ( elem = elems[ i ] ) != null; i++ ) { -				if ( byElement && elem ) { -					j = 0; - -					// Support: IE 11+, Edge 17 - 18+ -					// IE/Edge sometimes throw a "Permission denied" error when strict-comparing -					// two documents; shallow comparisons work. -					// eslint-disable-next-line eqeqeq -					if ( !context && elem.ownerDocument != document ) { -						setDocument( elem ); -						xml = !documentIsHTML; -					} -					while ( ( matcher = elementMatchers[ j++ ] ) ) { -						if ( matcher( elem, context || document, 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 ); -					} -				} -			} - -			// `i` is now the count of elements visited above, and adding it to `matchedCount` -			// makes the latter nonnegative. -			matchedCount += i; - -			// Apply set filters to unmatched elements -			// NOTE: This can be skipped if there are no unmatched elements (i.e., `matchedCount` -			// equals `i`), unless we didn't visit _any_ elements in the above loop because we have -			// no element matchers and no seed. -			// Incrementing an initially-string "0" `i` allows `i` to remain a string only in that -			// case, which will result in a "00" `matchedCount` that differs from `i` but is also -			// numerically zero. -			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 only one selector in the list and no seed -	// (the latter of which guarantees us context) -	if ( match.length === 1 ) { - -		// Reduce context if the leading compound selector is an ID -		tokens = match[ 0 ] = match[ 0 ].slice( 0 ); -		if ( tokens.length > 2 && ( token = tokens[ 0 ] ).type === "ID" && -			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, -		!context || 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-35+ -// 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( el ) { - -	// Should return 1, but returns 4 (following) -	return el.compareDocumentPosition( document.createElement( "fieldset" ) ) & 1; -} ); - -// Support: IE<8 -// Prevent attribute/property "interpolation" -// https://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx -if ( !assert( function( el ) { -	el.innerHTML = "<a href='#'></a>"; -	return el.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( el ) { -	el.innerHTML = "<input/>"; -	el.firstChild.setAttribute( "value", "" ); -	return el.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( el ) { -	return el.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; - -// Deprecated -jQuery.expr[ ":" ] = jQuery.expr.pseudos; -jQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort; -jQuery.text = Sizzle.getText; -jQuery.isXMLDoc = Sizzle.isXML; -jQuery.contains = Sizzle.contains; -jQuery.escapeSelector = Sizzle.escape; - - - - -var dir = function( elem, dir, until ) { -	var matched = [], -		truncate = until !== undefined; - -	while ( ( elem = elem[ dir ] ) && elem.nodeType !== 9 ) { -		if ( elem.nodeType === 1 ) { -			if ( truncate && jQuery( elem ).is( until ) ) { -				break; -			} -			matched.push( elem ); -		} -	} -	return matched; -}; - - -var siblings = function( n, elem ) { -	var matched = []; - -	for ( ; n; n = n.nextSibling ) { -		if ( n.nodeType === 1 && n !== elem ) { -			matched.push( n ); -		} -	} - -	return matched; -}; - - -var rneedsContext = jQuery.expr.match.needsContext; - - - -function nodeName( elem, name ) { - -  return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); - -}; -var rsingleTag = ( /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i ); - - - -// Implement the identical functionality for filter and not -function winnow( elements, qualifier, not ) { -	if ( isFunction( qualifier ) ) { -		return jQuery.grep( elements, function( elem, i ) { -			return !!qualifier.call( elem, i, elem ) !== not; -		} ); -	} - -	// Single element -	if ( qualifier.nodeType ) { -		return jQuery.grep( elements, function( elem ) { -			return ( elem === qualifier ) !== not; -		} ); -	} - -	// Arraylike of elements (jQuery, arguments, Array) -	if ( typeof qualifier !== "string" ) { -		return jQuery.grep( elements, function( elem ) { -			return ( indexOf.call( qualifier, elem ) > -1 ) !== not; -		} ); -	} - -	// Filtered directly for both simple and complex selectors -	return jQuery.filter( qualifier, elements, not ); -} - -jQuery.filter = function( expr, elems, not ) { -	var elem = elems[ 0 ]; - -	if ( not ) { -		expr = ":not(" + expr + ")"; -	} - -	if ( elems.length === 1 && elem.nodeType === 1 ) { -		return jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : []; -	} - -	return jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) { -		return elem.nodeType === 1; -	} ) ); -}; - -jQuery.fn.extend( { -	find: function( selector ) { -		var i, ret, -			len = this.length, -			self = this; - -		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; -					} -				} -			} ) ); -		} - -		ret = this.pushStack( [] ); - -		for ( i = 0; i < len; i++ ) { -			jQuery.find( selector, self[ i ], ret ); -		} - -		return len > 1 ? jQuery.uniqueSort( ret ) : 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, - -	// A simple way to check for HTML strings -	// Prioritize #id over <tag> to avoid XSS via location.hash (#9521) -	// Strict HTML recognition (#11290: must start with <) -	// Shortcut simple #id case for speed -	rquickExpr = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/, - -	init = jQuery.fn.init = function( selector, context, root ) { -		var match, elem; - -		// HANDLE: $(""), $(null), $(undefined), $(false) -		if ( !selector ) { -			return this; -		} - -		// Method init() accepts an alternate rootjQuery -		// so migrate can support jQuery.sub (gh-2101) -		root = root || rootjQuery; - -		// Handle HTML strings -		if ( typeof selector === "string" ) { -			if ( selector[ 0 ] === "<" && -				selector[ 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; - -					// Option to run 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 ( 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 ] ); - -					if ( elem ) { - -						// Inject the element directly into the jQuery object -						this[ 0 ] = elem; -						this.length = 1; -					} -					return this; -				} - -			// HANDLE: $(expr, $(...)) -			} else if ( !context || context.jquery ) { -				return ( context || root ).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[ 0 ] = selector; -			this.length = 1; -			return this; - -		// HANDLE: $(function) -		// Shortcut for document ready -		} else if ( isFunction( selector ) ) { -			return root.ready !== undefined ? -				root.ready( selector ) : - -				// Execute immediately if ready is not present -				selector( jQuery ); -		} - -		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.fn.extend( { -	has: function( target ) { -		var targets = jQuery( target, this ), -			l = targets.length; - -		return this.filter( function() { -			var i = 0; -			for ( ; i < l; i++ ) { -				if ( jQuery.contains( this, targets[ i ] ) ) { -					return true; -				} -			} -		} ); -	}, - -	closest: function( selectors, context ) { -		var cur, -			i = 0, -			l = this.length, -			matched = [], -			targets = typeof selectors !== "string" && jQuery( selectors ); - -		// Positional selectors never match, since there's no _selection_ context -		if ( !rneedsContext.test( selectors ) ) { -			for ( ; i < l; i++ ) { -				for ( cur = this[ i ]; cur && cur !== context; cur = cur.parentNode ) { - -					// Always skip document fragments -					if ( cur.nodeType < 11 && ( targets ? -						targets.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.uniqueSort( matched ) : matched ); -	}, - -	// Determine the position of an element within the set -	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 indexOf.call( jQuery( elem ), this[ 0 ] ); -		} - -		// Locate the position of the desired element -		return indexOf.call( this, - -			// If it receives a jQuery object, the first element is used -			elem.jquery ? elem[ 0 ] : elem -		); -	}, - -	add: function( selector, context ) { -		return this.pushStack( -			jQuery.uniqueSort( -				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 ) { -	while ( ( cur = cur[ dir ] ) && 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 dir( elem, "parentNode" ); -	}, -	parentsUntil: function( elem, _i, until ) { -		return dir( elem, "parentNode", until ); -	}, -	next: function( elem ) { -		return sibling( elem, "nextSibling" ); -	}, -	prev: function( elem ) { -		return sibling( elem, "previousSibling" ); -	}, -	nextAll: function( elem ) { -		return dir( elem, "nextSibling" ); -	}, -	prevAll: function( elem ) { -		return dir( elem, "previousSibling" ); -	}, -	nextUntil: function( elem, _i, until ) { -		return dir( elem, "nextSibling", until ); -	}, -	prevUntil: function( elem, _i, until ) { -		return dir( elem, "previousSibling", until ); -	}, -	siblings: function( elem ) { -		return siblings( ( elem.parentNode || {} ).firstChild, elem ); -	}, -	children: function( elem ) { -		return siblings( elem.firstChild ); -	}, -	contents: function( elem ) { -		if ( elem.contentDocument != null && - -			// Support: IE 11+ -			// <object> elements with no `data` attribute has an object -			// `contentDocument` with a `null` prototype. -			getProto( elem.contentDocument ) ) { - -			return elem.contentDocument; -		} - -		// Support: IE 9 - 11 only, iOS 7 only, Android Browser <=4.3 only -		// Treat the template element as a regular one in browsers that -		// don't support it. -		if ( nodeName( elem, "template" ) ) { -			elem = elem.content || elem; -		} - -		return jQuery.merge( [], elem.childNodes ); -	} -}, function( name, fn ) { -	jQuery.fn[ name ] = function( until, selector ) { -		var matched = jQuery.map( this, fn, until ); - -		if ( name.slice( -5 ) !== "Until" ) { -			selector = until; -		} - -		if ( selector && typeof selector === "string" ) { -			matched = jQuery.filter( selector, matched ); -		} - -		if ( this.length > 1 ) { - -			// Remove duplicates -			if ( !guaranteedUnique[ name ] ) { -				jQuery.uniqueSort( matched ); -			} - -			// Reverse order for parents* and prev-derivatives -			if ( rparentsprev.test( name ) ) { -				matched.reverse(); -			} -		} - -		return this.pushStack( matched ); -	}; -} ); -var rnothtmlwhite = ( /[^\x20\t\r\n\f]+/g ); - - - -// Convert String-formatted options into Object-formatted ones -function createOptions( options ) { -	var object = {}; -	jQuery.each( options.match( rnothtmlwhite ) || [], 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" ? -		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, - -		// Flag to prevent firing -		locked, - -		// Actual callback list -		list = [], - -		// Queue of execution data for repeatable lists -		queue = [], - -		// Index of currently firing callback (modified by add/remove as needed) -		firingIndex = -1, - -		// Fire callbacks -		fire = function() { - -			// Enforce single-firing -			locked = locked || options.once; - -			// Execute callbacks for all pending executions, -			// respecting firingIndex overrides and runtime changes -			fired = firing = true; -			for ( ; queue.length; firingIndex = -1 ) { -				memory = queue.shift(); -				while ( ++firingIndex < list.length ) { - -					// Run callback and check for early termination -					if ( list[ firingIndex ].apply( memory[ 0 ], memory[ 1 ] ) === false && -						options.stopOnFalse ) { - -						// Jump to end and forget the data so .add doesn't re-fire -						firingIndex = list.length; -						memory = false; -					} -				} -			} - -			// Forget the data if we're done with it -			if ( !options.memory ) { -				memory = false; -			} - -			firing = false; - -			// Clean up if we're done firing for good -			if ( locked ) { - -				// Keep an empty list if we have data for future add calls -				if ( memory ) { -					list = []; - -				// Otherwise, this object is spent -				} else { -					list = ""; -				} -			} -		}, - -		// Actual Callbacks object -		self = { - -			// Add a callback or a collection of callbacks to the list -			add: function() { -				if ( list ) { - -					// If we have memory from a past run, we should fire after adding -					if ( memory && !firing ) { -						firingIndex = list.length - 1; -						queue.push( memory ); -					} - -					( function add( args ) { -						jQuery.each( args, function( _, arg ) { -							if ( isFunction( arg ) ) { -								if ( !options.unique || !self.has( arg ) ) { -									list.push( arg ); -								} -							} else if ( arg && arg.length && toType( arg ) !== "string" ) { - -								// Inspect recursively -								add( arg ); -							} -						} ); -					} )( arguments ); - -					if ( memory && !firing ) { -						fire(); -					} -				} -				return this; -			}, - -			// Remove a callback from the list -			remove: function() { -				jQuery.each( arguments, function( _, arg ) { -					var index; -					while ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) { -						list.splice( index, 1 ); - -						// Handle firing indexes -						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.length > 0; -			}, - -			// Remove all callbacks from the list -			empty: function() { -				if ( list ) { -					list = []; -				} -				return this; -			}, - -			// Disable .fire and .add -			// Abort any current/pending executions -			// Clear all callbacks and values -			disable: function() { -				locked = queue = []; -				list = memory = ""; -				return this; -			}, -			disabled: function() { -				return !list; -			}, - -			// Disable .fire -			// Also disable .add unless we have memory (since it would have no effect) -			// Abort any pending executions -			lock: function() { -				locked = queue = []; -				if ( !memory && !firing ) { -					list = memory = ""; -				} -				return this; -			}, -			locked: function() { -				return !!locked; -			}, - -			// Call all callbacks with the given context and arguments -			fireWith: function( context, args ) { -				if ( !locked ) { -					args = args || []; -					args = [ context, args.slice ? args.slice() : args ]; -					queue.push( args ); -					if ( !firing ) { -						fire(); -					} -				} -				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; -}; - - -function Identity( v ) { -	return v; -} -function Thrower( ex ) { -	throw ex; -} - -function adoptValue( value, resolve, reject, noValue ) { -	var method; - -	try { - -		// Check for promise aspect first to privilege synchronous behavior -		if ( value && isFunction( ( method = value.promise ) ) ) { -			method.call( value ).done( resolve ).fail( reject ); - -		// Other thenables -		} else if ( value && isFunction( ( method = value.then ) ) ) { -			method.call( value, resolve, reject ); - -		// Other non-thenables -		} else { - -			// Control `resolve` arguments by letting Array#slice cast boolean `noValue` to integer: -			// * false: [ value ].slice( 0 ) => resolve( value ) -			// * true: [ value ].slice( 1 ) => resolve() -			resolve.apply( undefined, [ value ].slice( noValue ) ); -		} - -	// For Promises/A+, convert exceptions into rejections -	// Since jQuery.when doesn't unwrap thenables, we can skip the extra checks appearing in -	// Deferred#then to conditionally suppress rejection. -	} catch ( value ) { - -		// Support: Android 4.0 only -		// Strict mode functions invoked without .call/.apply get global-object context -		reject.apply( undefined, [ value ] ); -	} -} - -jQuery.extend( { - -	Deferred: function( func ) { -		var tuples = [ - -				// action, add listener, callbacks, -				// ... .then handlers, argument index, [final state] -				[ "notify", "progress", jQuery.Callbacks( "memory" ), -					jQuery.Callbacks( "memory" ), 2 ], -				[ "resolve", "done", jQuery.Callbacks( "once memory" ), -					jQuery.Callbacks( "once memory" ), 0, "resolved" ], -				[ "reject", "fail", jQuery.Callbacks( "once memory" ), -					jQuery.Callbacks( "once memory" ), 1, "rejected" ] -			], -			state = "pending", -			promise = { -				state: function() { -					return state; -				}, -				always: function() { -					deferred.done( arguments ).fail( arguments ); -					return this; -				}, -				"catch": function( fn ) { -					return promise.then( null, fn ); -				}, - -				// Keep pipe for back-compat -				pipe: function( /* fnDone, fnFail, fnProgress */ ) { -					var fns = arguments; - -					return jQuery.Deferred( function( newDefer ) { -						jQuery.each( tuples, function( _i, tuple ) { - -							// Map tuples (progress, done, fail) to arguments (done, fail, progress) -							var fn = isFunction( fns[ tuple[ 4 ] ] ) && fns[ tuple[ 4 ] ]; - -							// deferred.progress(function() { bind to newDefer or newDefer.notify }) -							// deferred.done(function() { bind to newDefer or newDefer.resolve }) -							// deferred.fail(function() { bind to newDefer or newDefer.reject }) -							deferred[ tuple[ 1 ] ]( function() { -								var returned = fn && fn.apply( this, arguments ); -								if ( returned && isFunction( returned.promise ) ) { -									returned.promise() -										.progress( newDefer.notify ) -										.done( newDefer.resolve ) -										.fail( newDefer.reject ); -								} else { -									newDefer[ tuple[ 0 ] + "With" ]( -										this, -										fn ? [ returned ] : arguments -									); -								} -							} ); -						} ); -						fns = null; -					} ).promise(); -				}, -				then: function( onFulfilled, onRejected, onProgress ) { -					var maxDepth = 0; -					function resolve( depth, deferred, handler, special ) { -						return function() { -							var that = this, -								args = arguments, -								mightThrow = function() { -									var returned, then; - -									// Support: Promises/A+ section 2.3.3.3.3 -									// https://promisesaplus.com/#point-59 -									// Ignore double-resolution attempts -									if ( depth < maxDepth ) { -										return; -									} - -									returned = handler.apply( that, args ); - -									// Support: Promises/A+ section 2.3.1 -									// https://promisesaplus.com/#point-48 -									if ( returned === deferred.promise() ) { -										throw new TypeError( "Thenable self-resolution" ); -									} - -									// Support: Promises/A+ sections 2.3.3.1, 3.5 -									// https://promisesaplus.com/#point-54 -									// https://promisesaplus.com/#point-75 -									// Retrieve `then` only once -									then = returned && - -										// Support: Promises/A+ section 2.3.4 -										// https://promisesaplus.com/#point-64 -										// Only check objects and functions for thenability -										( typeof returned === "object" || -											typeof returned === "function" ) && -										returned.then; - -									// Handle a returned thenable -									if ( isFunction( then ) ) { - -										// Special processors (notify) just wait for resolution -										if ( special ) { -											then.call( -												returned, -												resolve( maxDepth, deferred, Identity, special ), -												resolve( maxDepth, deferred, Thrower, special ) -											); - -										// Normal processors (resolve) also hook into progress -										} else { - -											// ...and disregard older resolution values -											maxDepth++; - -											then.call( -												returned, -												resolve( maxDepth, deferred, Identity, special ), -												resolve( maxDepth, deferred, Thrower, special ), -												resolve( maxDepth, deferred, Identity, -													deferred.notifyWith ) -											); -										} - -									// Handle all other returned values -									} else { - -										// Only substitute handlers pass on context -										// and multiple values (non-spec behavior) -										if ( handler !== Identity ) { -											that = undefined; -											args = [ returned ]; -										} - -										// Process the value(s) -										// Default process is resolve -										( special || deferred.resolveWith )( that, args ); -									} -								}, - -								// Only normal processors (resolve) catch and reject exceptions -								process = special ? -									mightThrow : -									function() { -										try { -											mightThrow(); -										} catch ( e ) { - -											if ( jQuery.Deferred.exceptionHook ) { -												jQuery.Deferred.exceptionHook( e, -													process.stackTrace ); -											} - -											// Support: Promises/A+ section 2.3.3.3.4.1 -											// https://promisesaplus.com/#point-61 -											// Ignore post-resolution exceptions -											if ( depth + 1 >= maxDepth ) { - -												// Only substitute handlers pass on context -												// and multiple values (non-spec behavior) -												if ( handler !== Thrower ) { -													that = undefined; -													args = [ e ]; -												} - -												deferred.rejectWith( that, args ); -											} -										} -									}; - -							// Support: Promises/A+ section 2.3.3.3.1 -							// https://promisesaplus.com/#point-57 -							// Re-resolve promises immediately to dodge false rejection from -							// subsequent errors -							if ( depth ) { -								process(); -							} else { - -								// Call an optional hook to record the stack, in case of exception -								// since it's otherwise lost when execution goes async -								if ( jQuery.Deferred.getStackHook ) { -									process.stackTrace = jQuery.Deferred.getStackHook(); -								} -								window.setTimeout( process ); -							} -						}; -					} - -					return jQuery.Deferred( function( newDefer ) { - -						// progress_handlers.add( ... ) -						tuples[ 0 ][ 3 ].add( -							resolve( -								0, -								newDefer, -								isFunction( onProgress ) ? -									onProgress : -									Identity, -								newDefer.notifyWith -							) -						); - -						// fulfilled_handlers.add( ... ) -						tuples[ 1 ][ 3 ].add( -							resolve( -								0, -								newDefer, -								isFunction( onFulfilled ) ? -									onFulfilled : -									Identity -							) -						); - -						// rejected_handlers.add( ... ) -						tuples[ 2 ][ 3 ].add( -							resolve( -								0, -								newDefer, -								isFunction( onRejected ) ? -									onRejected : -									Thrower -							) -						); -					} ).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 = {}; - -		// Add list-specific methods -		jQuery.each( tuples, function( i, tuple ) { -			var list = tuple[ 2 ], -				stateString = tuple[ 5 ]; - -			// promise.progress = list.add -			// promise.done = list.add -			// promise.fail = list.add -			promise[ tuple[ 1 ] ] = list.add; - -			// Handle state -			if ( stateString ) { -				list.add( -					function() { - -						// state = "resolved" (i.e., fulfilled) -						// state = "rejected" -						state = stateString; -					}, - -					// rejected_callbacks.disable -					// fulfilled_callbacks.disable -					tuples[ 3 - i ][ 2 ].disable, - -					// rejected_handlers.disable -					// fulfilled_handlers.disable -					tuples[ 3 - i ][ 3 ].disable, - -					// progress_callbacks.lock -					tuples[ 0 ][ 2 ].lock, - -					// progress_handlers.lock -					tuples[ 0 ][ 3 ].lock -				); -			} - -			// progress_handlers.fire -			// fulfilled_handlers.fire -			// rejected_handlers.fire -			list.add( tuple[ 3 ].fire ); - -			// deferred.notify = function() { deferred.notifyWith(...) } -			// deferred.resolve = function() { deferred.resolveWith(...) } -			// deferred.reject = function() { deferred.rejectWith(...) } -			deferred[ tuple[ 0 ] ] = function() { -				deferred[ tuple[ 0 ] + "With" ]( this === deferred ? undefined : this, arguments ); -				return this; -			}; - -			// deferred.notifyWith = list.fireWith -			// deferred.resolveWith = list.fireWith -			// deferred.rejectWith = list.fireWith -			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( singleValue ) { -		var - -			// count of uncompleted subordinates -			remaining = arguments.length, - -			// count of unprocessed arguments -			i = remaining, - -			// subordinate fulfillment data -			resolveContexts = Array( i ), -			resolveValues = slice.call( arguments ), - -			// the master Deferred -			master = jQuery.Deferred(), - -			// subordinate callback factory -			updateFunc = function( i ) { -				return function( value ) { -					resolveContexts[ i ] = this; -					resolveValues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value; -					if ( !( --remaining ) ) { -						master.resolveWith( resolveContexts, resolveValues ); -					} -				}; -			}; - -		// Single- and empty arguments are adopted like Promise.resolve -		if ( remaining <= 1 ) { -			adoptValue( singleValue, master.done( updateFunc( i ) ).resolve, master.reject, -				!remaining ); - -			// Use .then() to unwrap secondary thenables (cf. gh-3000) -			if ( master.state() === "pending" || -				isFunction( resolveValues[ i ] && resolveValues[ i ].then ) ) { - -				return master.then(); -			} -		} - -		// Multiple arguments are aggregated like Promise.all array elements -		while ( i-- ) { -			adoptValue( resolveValues[ i ], updateFunc( i ), master.reject ); -		} - -		return master.promise(); -	} -} ); - - -// These usually indicate a programmer mistake during development, -// warn about them ASAP rather than swallowing them by default. -var rerrorNames = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/; - -jQuery.Deferred.exceptionHook = function( error, stack ) { - -	// Support: IE 8 - 9 only -	// Console exists when dev tools are open, which can happen at any time -	if ( window.console && window.console.warn && error && rerrorNames.test( error.name ) ) { -		window.console.warn( "jQuery.Deferred exception: " + error.message, error.stack, stack ); -	} -}; - - - - -jQuery.readyException = function( error ) { -	window.setTimeout( function() { -		throw error; -	} ); -}; - - - - -// The deferred used on DOM ready -var readyList = jQuery.Deferred(); - -jQuery.fn.ready = function( fn ) { - -	readyList -		.then( fn ) - -		// Wrap jQuery.readyException in a function so that the lookup -		// happens at the time of error handling instead of callback -		// registration. -		.catch( function( error ) { -			jQuery.readyException( error ); -		} ); - -	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, - -	// 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; -		} - -		// 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 ] ); -	} -} ); - -jQuery.ready.then = readyList.then; - -// The ready event handler and self cleanup method -function completed() { -	document.removeEventListener( "DOMContentLoaded", completed ); -	window.removeEventListener( "load", completed ); -	jQuery.ready(); -} - -// Catch cases where $(document).ready() is called -// after the browser event has already occurred. -// Support: IE <=9 - 10 only -// Older IE sometimes signals "interactive" too soon -if ( document.readyState === "complete" || -	( document.readyState !== "loading" && !document.documentElement.doScroll ) ) { - -	// Handle it asynchronously to allow scripts the opportunity to delay ready -	window.setTimeout( jQuery.ready ); - -} else { - -	// Use the handy event callback -	document.addEventListener( "DOMContentLoaded", completed ); - -	// A fallback to window.onload, that will always work -	window.addEventListener( "load", completed ); -} - - - - -// Multifunctional method to get and set values of a collection -// The value/s can optionally be executed if it's a function -var access = function( elems, fn, key, value, chainable, emptyGet, raw ) { -	var i = 0, -		len = elems.length, -		bulk = key == null; - -	// Sets many values -	if ( toType( key ) === "object" ) { -		chainable = true; -		for ( i in key ) { -			access( elems, fn, i, key[ i ], true, emptyGet, raw ); -		} - -	// Sets one value -	} else if ( value !== undefined ) { -		chainable = true; - -		if ( !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 < len; i++ ) { -				fn( -					elems[ i ], key, raw ? -					value : -					value.call( elems[ i ], i, fn( elems[ i ], key ) ) -				); -			} -		} -	} - -	if ( chainable ) { -		return elems; -	} - -	// Gets -	if ( bulk ) { -		return fn.call( elems ); -	} - -	return len ? fn( elems[ 0 ], key ) : emptyGet; -}; - - -// Matches dashed string for camelizing -var rmsPrefix = /^-ms-/, -	rdashAlpha = /-([a-z])/g; - -// Used by camelCase as callback to replace() -function fcamelCase( _all, letter ) { -	return letter.toUpperCase(); -} - -// Convert dashed to camelCase; used by the css and data modules -// Support: IE <=9 - 11, Edge 12 - 15 -// Microsoft forgot to hump their vendor prefix (#9572) -function camelCase( string ) { -	return string.replace( rmsPrefix, "ms-" ).replace( rdashAlpha, fcamelCase ); -} -var acceptData = function( owner ) { - -	// Accepts only: -	//  - Node -	//    - Node.ELEMENT_NODE -	//    - Node.DOCUMENT_NODE -	//  - Object -	//    - Any -	return owner.nodeType === 1 || owner.nodeType === 9 || !( +owner.nodeType ); -}; - - - - -function Data() { -	this.expando = jQuery.expando + Data.uid++; -} - -Data.uid = 1; - -Data.prototype = { - -	cache: function( owner ) { - -		// Check if the owner object already has a cache -		var value = owner[ this.expando ]; - -		// If not, create one -		if ( !value ) { -			value = {}; - -			// We can accept data for non-element nodes in modern browsers, -			// but we should not, see #8335. -			// Always return an empty object. -			if ( acceptData( owner ) ) { - -				// If it is a node unlikely to be stringify-ed or looped over -				// use plain assignment -				if ( owner.nodeType ) { -					owner[ this.expando ] = value; - -				// Otherwise secure it in a non-enumerable property -				// configurable must be true to allow the property to be -				// deleted when data is removed -				} else { -					Object.defineProperty( owner, this.expando, { -						value: value, -						configurable: true -					} ); -				} -			} -		} - -		return value; -	}, -	set: function( owner, data, value ) { -		var prop, -			cache = this.cache( owner ); - -		// Handle: [ owner, key, value ] args -		// Always use camelCase key (gh-2257) -		if ( typeof data === "string" ) { -			cache[ camelCase( data ) ] = value; - -		// Handle: [ owner, { properties } ] args -		} else { - -			// Copy the properties one-by-one to the cache object -			for ( prop in data ) { -				cache[ camelCase( prop ) ] = data[ prop ]; -			} -		} -		return cache; -	}, -	get: function( owner, key ) { -		return key === undefined ? -			this.cache( owner ) : - -			// Always use camelCase key (gh-2257) -			owner[ this.expando ] && owner[ this.expando ][ camelCase( key ) ]; -	}, -	access: function( owner, key, value ) { - -		// In cases where either: -		// -		//   1. No key was specified -		//   2. A string key was specified, but no value provided -		// -		// Take the "read" path and allow the get method to determine -		// which value to return, respectively either: -		// -		//   1. The entire cache object -		//   2. The data stored at the key -		// -		if ( key === undefined || -				( ( key && typeof key === "string" ) && value === undefined ) ) { - -			return this.get( owner, key ); -		} - -		// When the key is not a string, or both a key and value -		// are specified, set or extend (existing objects) with either: -		// -		//   1. An object of properties -		//   2. A key and value -		// -		this.set( owner, key, value ); - -		// Since the "set" path can have two possible entry points -		// return the expected data based on which path was taken[*] -		return value !== undefined ? value : key; -	}, -	remove: function( owner, key ) { -		var i, -			cache = owner[ this.expando ]; - -		if ( cache === undefined ) { -			return; -		} - -		if ( key !== undefined ) { - -			// Support array or space separated string of keys -			if ( Array.isArray( key ) ) { - -				// If key is an array of keys... -				// We always set camelCase keys, so remove that. -				key = key.map( camelCase ); -			} else { -				key = camelCase( key ); - -				// If a key with the spaces exists, use it. -				// Otherwise, create an array by matching non-whitespace -				key = key in cache ? -					[ key ] : -					( key.match( rnothtmlwhite ) || [] ); -			} - -			i = key.length; - -			while ( i-- ) { -				delete cache[ key[ i ] ]; -			} -		} - -		// Remove the expando if there's no more data -		if ( key === undefined || jQuery.isEmptyObject( cache ) ) { - -			// Support: Chrome <=35 - 45 -			// Webkit & Blink performance suffers when deleting properties -			// from DOM nodes, so set to undefined instead -			// https://bugs.chromium.org/p/chromium/issues/detail?id=378607 (bug restricted) -			if ( owner.nodeType ) { -				owner[ this.expando ] = undefined; -			} else { -				delete owner[ this.expando ]; -			} -		} -	}, -	hasData: function( owner ) { -		var cache = owner[ this.expando ]; -		return cache !== undefined && !jQuery.isEmptyObject( cache ); -	} -}; -var dataPriv = new Data(); - -var dataUser = new Data(); - - - -//	Implementation Summary -// -//	1. Enforce API surface and semantic compatibility with 1.9.x branch -//	2. Improve the module's maintainability by reducing the storage -//		paths to a single mechanism. -//	3. Use the same single mechanism to support "private" and "user" data. -//	4. _Never_ expose "private" data to user code (TODO: Drop _data, _removeData) -//	5. Avoid exposing implementation details on user objects (eg. expando properties) -//	6. Provide a clear path for implementation upgrade to WeakMap in 2014 - -var rbrace = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/, -	rmultiDash = /[A-Z]/g; - -function getData( data ) { -	if ( data === "true" ) { -		return true; -	} - -	if ( data === "false" ) { -		return false; -	} - -	if ( data === "null" ) { -		return null; -	} - -	// Only convert to a number if it doesn't change the string -	if ( data === +data + "" ) { -		return +data; -	} - -	if ( rbrace.test( data ) ) { -		return JSON.parse( data ); -	} - -	return data; -} - -function dataAttr( elem, key, data ) { -	var name; - -	// If nothing was found internally, try to fetch any -	// data from the HTML5 data-* attribute -	if ( data === undefined && elem.nodeType === 1 ) { -		name = "data-" + key.replace( rmultiDash, "-$&" ).toLowerCase(); -		data = elem.getAttribute( name ); - -		if ( typeof data === "string" ) { -			try { -				data = getData( data ); -			} catch ( e ) {} - -			// Make sure we set the data so it isn't changed later -			dataUser.set( elem, key, data ); -		} else { -			data = undefined; -		} -	} -	return data; -} - -jQuery.extend( { -	hasData: function( elem ) { -		return dataUser.hasData( elem ) || dataPriv.hasData( elem ); -	}, - -	data: function( elem, name, data ) { -		return dataUser.access( elem, name, data ); -	}, - -	removeData: function( elem, name ) { -		dataUser.remove( elem, name ); -	}, - -	// TODO: Now that all calls to _data and _removeData have been replaced -	// with direct calls to dataPriv methods, these can be deprecated. -	_data: function( elem, name, data ) { -		return dataPriv.access( elem, name, data ); -	}, - -	_removeData: function( elem, name ) { -		dataPriv.remove( elem, name ); -	} -} ); - -jQuery.fn.extend( { -	data: function( key, value ) { -		var i, name, data, -			elem = this[ 0 ], -			attrs = elem && elem.attributes; - -		// Gets all values -		if ( key === undefined ) { -			if ( this.length ) { -				data = dataUser.get( elem ); - -				if ( elem.nodeType === 1 && !dataPriv.get( elem, "hasDataAttrs" ) ) { -					i = attrs.length; -					while ( i-- ) { - -						// Support: IE 11 only -						// The attrs elements can be null (#14894) -						if ( attrs[ i ] ) { -							name = attrs[ i ].name; -							if ( name.indexOf( "data-" ) === 0 ) { -								name = camelCase( name.slice( 5 ) ); -								dataAttr( elem, name, data[ name ] ); -							} -						} -					} -					dataPriv.set( elem, "hasDataAttrs", true ); -				} -			} - -			return data; -		} - -		// Sets multiple values -		if ( typeof key === "object" ) { -			return this.each( function() { -				dataUser.set( this, key ); -			} ); -		} - -		return access( this, function( value ) { -			var data; - -			// The calling jQuery object (element matches) is not empty -			// (and therefore has an element appears at this[ 0 ]) and the -			// `value` parameter was not undefined. An empty jQuery object -			// will result in `undefined` for elem = this[ 0 ] which will -			// throw an exception if an attempt to read a data cache is made. -			if ( elem && value === undefined ) { - -				// Attempt to get data from the cache -				// The key will always be camelCased in Data -				data = dataUser.get( elem, key ); -				if ( data !== undefined ) { -					return data; -				} - -				// Attempt to "discover" the data in -				// HTML5 custom data-* attrs -				data = dataAttr( elem, key ); -				if ( data !== undefined ) { -					return data; -				} - -				// We tried really hard, but the data doesn't exist. -				return; -			} - -			// Set the data... -			this.each( function() { - -				// We always store the camelCased key -				dataUser.set( this, key, value ); -			} ); -		}, null, value, arguments.length > 1, null, true ); -	}, - -	removeData: function( key ) { -		return this.each( function() { -			dataUser.remove( this, key ); -		} ); -	} -} ); - - -jQuery.extend( { -	queue: function( elem, type, data ) { -		var queue; - -		if ( elem ) { -			type = ( type || "fx" ) + "queue"; -			queue = dataPriv.get( elem, type ); - -			// Speed up dequeue by getting out quickly if this is just a lookup -			if ( data ) { -				if ( !queue || Array.isArray( data ) ) { -					queue = dataPriv.access( 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 public - generate a queueHooks object, or return the current one -	_queueHooks: function( elem, type ) { -		var key = type + "queueHooks"; -		return dataPriv.get( elem, key ) || dataPriv.access( elem, key, { -			empty: jQuery.Callbacks( "once memory" ).add( function() { -				dataPriv.remove( elem, [ type + "queue", 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 = dataPriv.get( 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 rcssNum = new RegExp( "^(?:([+-])=|)(" + pnum + ")([a-z%]*)$", "i" ); - - -var cssExpand = [ "Top", "Right", "Bottom", "Left" ]; - -var documentElement = document.documentElement; - - - -	var isAttached = function( elem ) { -			return jQuery.contains( elem.ownerDocument, elem ); -		}, -		composed = { composed: true }; - -	// Support: IE 9 - 11+, Edge 12 - 18+, iOS 10.0 - 10.2 only -	// Check attachment across shadow DOM boundaries when possible (gh-3504) -	// Support: iOS 10.0-10.2 only -	// Early iOS 10 versions support `attachShadow` but not `getRootNode`, -	// leading to errors. We need to check for `getRootNode`. -	if ( documentElement.getRootNode ) { -		isAttached = function( elem ) { -			return jQuery.contains( elem.ownerDocument, elem ) || -				elem.getRootNode( composed ) === elem.ownerDocument; -		}; -	} -var isHiddenWithinTree = function( elem, el ) { - -		// isHiddenWithinTree might be called from jQuery#filter function; -		// in that case, element will be second argument -		elem = el || elem; - -		// Inline style trumps all -		return elem.style.display === "none" || -			elem.style.display === "" && - -			// Otherwise, check computed style -			// Support: Firefox <=43 - 45 -			// Disconnected elements can have computed display: none, so first confirm that elem is -			// in the document. -			isAttached( elem ) && - -			jQuery.css( elem, "display" ) === "none"; -	}; - - - -function adjustCSS( elem, prop, valueParts, tween ) { -	var adjusted, scale, -		maxIterations = 20, -		currentValue = tween ? -			function() { -				return tween.cur(); -			} : -			function() { -				return jQuery.css( elem, prop, "" ); -			}, -		initial = currentValue(), -		unit = valueParts && valueParts[ 3 ] || ( jQuery.cssNumber[ prop ] ? "" : "px" ), - -		// Starting value computation is required for potential unit mismatches -		initialInUnit = elem.nodeType && -			( jQuery.cssNumber[ prop ] || unit !== "px" && +initial ) && -			rcssNum.exec( jQuery.css( elem, prop ) ); - -	if ( initialInUnit && initialInUnit[ 3 ] !== unit ) { - -		// Support: Firefox <=54 -		// Halve the iteration target value to prevent interference from CSS upper bounds (gh-2144) -		initial = initial / 2; - -		// Trust units reported by jQuery.css -		unit = unit || initialInUnit[ 3 ]; - -		// Iteratively approximate from a nonzero starting point -		initialInUnit = +initial || 1; - -		while ( maxIterations-- ) { - -			// Evaluate and update our best guess (doubling guesses that zero out). -			// Finish if the scale equals or crosses 1 (making the old*new product non-positive). -			jQuery.style( elem, prop, initialInUnit + unit ); -			if ( ( 1 - scale ) * ( 1 - ( scale = currentValue() / initial || 0.5 ) ) <= 0 ) { -				maxIterations = 0; -			} -			initialInUnit = initialInUnit / scale; - -		} - -		initialInUnit = initialInUnit * 2; -		jQuery.style( elem, prop, initialInUnit + unit ); - -		// Make sure we update the tween properties later on -		valueParts = valueParts || []; -	} - -	if ( valueParts ) { -		initialInUnit = +initialInUnit || +initial || 0; - -		// Apply relative offset (+=/-=) if specified -		adjusted = valueParts[ 1 ] ? -			initialInUnit + ( valueParts[ 1 ] + 1 ) * valueParts[ 2 ] : -			+valueParts[ 2 ]; -		if ( tween ) { -			tween.unit = unit; -			tween.start = initialInUnit; -			tween.end = adjusted; -		} -	} -	return adjusted; -} - - -var defaultDisplayMap = {}; - -function getDefaultDisplay( elem ) { -	var temp, -		doc = elem.ownerDocument, -		nodeName = elem.nodeName, -		display = defaultDisplayMap[ nodeName ]; - -	if ( display ) { -		return display; -	} - -	temp = doc.body.appendChild( doc.createElement( nodeName ) ); -	display = jQuery.css( temp, "display" ); - -	temp.parentNode.removeChild( temp ); - -	if ( display === "none" ) { -		display = "block"; -	} -	defaultDisplayMap[ nodeName ] = display; - -	return display; -} - -function showHide( elements, show ) { -	var display, elem, -		values = [], -		index = 0, -		length = elements.length; - -	// Determine new display value for elements that need to change -	for ( ; index < length; index++ ) { -		elem = elements[ index ]; -		if ( !elem.style ) { -			continue; -		} - -		display = elem.style.display; -		if ( show ) { - -			// Since we force visibility upon cascade-hidden elements, an immediate (and slow) -			// check is required in this first loop unless we have a nonempty display value (either -			// inline or about-to-be-restored) -			if ( display === "none" ) { -				values[ index ] = dataPriv.get( elem, "display" ) || null; -				if ( !values[ index ] ) { -					elem.style.display = ""; -				} -			} -			if ( elem.style.display === "" && isHiddenWithinTree( elem ) ) { -				values[ index ] = getDefaultDisplay( elem ); -			} -		} else { -			if ( display !== "none" ) { -				values[ index ] = "none"; - -				// Remember what we're overwriting -				dataPriv.set( elem, "display", display ); -			} -		} -	} - -	// Set the display of the elements in a second loop to avoid constant reflow -	for ( index = 0; index < length; index++ ) { -		if ( values[ index ] != null ) { -			elements[ index ].style.display = values[ index ]; -		} -	} - -	return elements; -} - -jQuery.fn.extend( { -	show: function() { -		return showHide( this, true ); -	}, -	hide: function() { -		return showHide( this ); -	}, -	toggle: function( state ) { -		if ( typeof state === "boolean" ) { -			return state ? this.show() : this.hide(); -		} - -		return this.each( function() { -			if ( isHiddenWithinTree( this ) ) { -				jQuery( this ).show(); -			} else { -				jQuery( this ).hide(); -			} -		} ); -	} -} ); -var rcheckableType = ( /^(?:checkbox|radio)$/i ); - -var rtagName = ( /<([a-z][^\/\0>\x20\t\r\n\f]*)/i ); - -var rscriptType = ( /^$|^module$|\/(?:java|ecma)script/i ); - - - -( function() { -	var fragment = document.createDocumentFragment(), -		div = fragment.appendChild( document.createElement( "div" ) ), -		input = document.createElement( "input" ); - -	// Support: Android 4.0 - 4.3 only -	// Check state lost if the name is set (#11217) -	// Support: Windows Web Apps (WWA) -	// `name` and `type` must use .setAttribute for WWA (#14901) -	input.setAttribute( "type", "radio" ); -	input.setAttribute( "checked", "checked" ); -	input.setAttribute( "name", "t" ); - -	div.appendChild( input ); - -	// Support: Android <=4.1 only -	// Older WebKit doesn't clone checked state correctly in fragments -	support.checkClone = div.cloneNode( true ).cloneNode( true ).lastChild.checked; - -	// Support: IE <=11 only -	// Make sure textarea (and checkbox) defaultValue is properly cloned -	div.innerHTML = "<textarea>x</textarea>"; -	support.noCloneChecked = !!div.cloneNode( true ).lastChild.defaultValue; - -	// Support: IE <=9 only -	// IE <=9 replaces <option> tags with their contents when inserted outside of -	// the select element. -	div.innerHTML = "<option></option>"; -	support.option = !!div.lastChild; -} )(); - - -// We have to close these tags to support XHTML (#13200) -var wrapMap = { - -	// XHTML parsers do not magically insert elements in the -	// same way that tag soup parsers do. So we cannot shorten -	// this by omitting <tbody> or other required elements. -	thead: [ 1, "<table>", "</table>" ], -	col: [ 2, "<table><colgroup>", "</colgroup></table>" ], -	tr: [ 2, "<table><tbody>", "</tbody></table>" ], -	td: [ 3, "<table><tbody><tr>", "</tr></tbody></table>" ], - -	_default: [ 0, "", "" ] -}; - -wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; -wrapMap.th = wrapMap.td; - -// Support: IE <=9 only -if ( !support.option ) { -	wrapMap.optgroup = wrapMap.option = [ 1, "<select multiple='multiple'>", "</select>" ]; -} - - -function getAll( context, tag ) { - -	// Support: IE <=9 - 11 only -	// Use typeof to avoid zero-argument method invocation on host objects (#15151) -	var ret; - -	if ( typeof context.getElementsByTagName !== "undefined" ) { -		ret = context.getElementsByTagName( tag || "*" ); - -	} else if ( typeof context.querySelectorAll !== "undefined" ) { -		ret = context.querySelectorAll( tag || "*" ); - -	} else { -		ret = []; -	} - -	if ( tag === undefined || tag && nodeName( context, tag ) ) { -		return jQuery.merge( [ context ], ret ); -	} - -	return ret; -} - - -// Mark scripts as having already been evaluated -function setGlobalEval( elems, refElements ) { -	var i = 0, -		l = elems.length; - -	for ( ; i < l; i++ ) { -		dataPriv.set( -			elems[ i ], -			"globalEval", -			!refElements || dataPriv.get( refElements[ i ], "globalEval" ) -		); -	} -} - - -var rhtml = /<|&#?\w+;/; - -function buildFragment( elems, context, scripts, selection, ignored ) { -	var elem, tmp, tag, wrap, attached, j, -		fragment = context.createDocumentFragment(), -		nodes = [], -		i = 0, -		l = elems.length; - -	for ( ; i < l; i++ ) { -		elem = elems[ i ]; - -		if ( elem || elem === 0 ) { - -			// Add nodes directly -			if ( toType( elem ) === "object" ) { - -				// Support: Android <=4.0 only, PhantomJS 1 only -				// push.apply(_, arraylike) throws on ancient WebKit -				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 || fragment.appendChild( context.createElement( "div" ) ); - -				// Deserialize a standard representation -				tag = ( rtagName.exec( elem ) || [ "", "" ] )[ 1 ].toLowerCase(); -				wrap = wrapMap[ tag ] || wrapMap._default; -				tmp.innerHTML = wrap[ 1 ] + jQuery.htmlPrefilter( elem ) + wrap[ 2 ]; - -				// Descend through wrappers to the right content -				j = wrap[ 0 ]; -				while ( j-- ) { -					tmp = tmp.lastChild; -				} - -				// Support: Android <=4.0 only, PhantomJS 1 only -				// push.apply(_, arraylike) throws on ancient WebKit -				jQuery.merge( nodes, tmp.childNodes ); - -				// Remember the top-level container -				tmp = fragment.firstChild; - -				// Ensure the created nodes are orphaned (#12392) -				tmp.textContent = ""; -			} -		} -	} - -	// Remove wrapper from fragment -	fragment.textContent = ""; - -	i = 0; -	while ( ( elem = nodes[ i++ ] ) ) { - -		// Skip elements already in the context collection (trac-4087) -		if ( selection && jQuery.inArray( elem, selection ) > -1 ) { -			if ( ignored ) { -				ignored.push( elem ); -			} -			continue; -		} - -		attached = isAttached( elem ); - -		// Append to fragment -		tmp = getAll( fragment.appendChild( elem ), "script" ); - -		// Preserve script evaluation history -		if ( attached ) { -			setGlobalEval( tmp ); -		} - -		// Capture executables -		if ( scripts ) { -			j = 0; -			while ( ( elem = tmp[ j++ ] ) ) { -				if ( rscriptType.test( elem.type || "" ) ) { -					scripts.push( elem ); -				} -			} -		} -	} - -	return fragment; -} - - -var -	rkeyEvent = /^key/, -	rmouseEvent = /^(?:mouse|pointer|contextmenu|drag|drop)|click/, -	rtypenamespace = /^([^.]*)(?:\.(.+)|)/; - -function returnTrue() { -	return true; -} - -function returnFalse() { -	return false; -} - -// Support: IE <=9 - 11+ -// focus() and blur() are asynchronous, except when they are no-op. -// So expect focus to be synchronous when the element is already active, -// and blur to be synchronous when the element is not already active. -// (focus and blur are always synchronous in other supported browsers, -// this just defines when we can count on it). -function expectSync( elem, type ) { -	return ( elem === safeActiveElement() ) === ( type === "focus" ); -} - -// Support: IE <=9 only -// Accessing document.activeElement can throw unexpectedly -// https://bugs.jquery.com/ticket/13393 -function safeActiveElement() { -	try { -		return document.activeElement; -	} catch ( err ) { } -} - -function on( elem, types, selector, data, fn, one ) { -	var origFn, type; - -	// 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 ) { -			on( elem, type, selector, data, types[ type ], one ); -		} -		return elem; -	} - -	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 elem; -	} - -	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 elem.each( function() { -		jQuery.event.add( this, types, fn, data, selector ); -	} ); -} - -/* - * 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 handleObjIn, eventHandle, tmp, -			events, t, handleObj, -			special, handlers, type, namespaces, origType, -			elemData = dataPriv.get( elem ); - -		// Only attach events to objects that accept data -		if ( !acceptData( elem ) ) { -			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; -		} - -		// Ensure that invalid selectors throw exceptions at attach time -		// Evaluate against documentElement in case elem is a non-element node (e.g., document) -		if ( selector ) { -			jQuery.find.matchesSelector( documentElement, 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 = Object.create( null ); -		} -		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 !== "undefined" && jQuery.event.triggered !== e.type ? -					jQuery.event.dispatch.apply( elem, arguments ) : undefined; -			}; -		} - -		// Handle multiple events separated by a space -		types = ( types || "" ).match( rnothtmlwhite ) || [ "" ]; -		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 if the special events handler returns false -				if ( !special.setup || -					special.setup.call( elem, data, namespaces, eventHandle ) === false ) { - -					if ( elem.addEventListener ) { -						elem.addEventListener( 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; -		} - -	}, - -	// Detach an event or set of events from an element -	remove: function( elem, types, handler, selector, mappedTypes ) { - -		var j, origCount, tmp, -			events, t, handleObj, -			special, handlers, type, namespaces, origType, -			elemData = dataPriv.hasData( elem ) && dataPriv.get( elem ); - -		if ( !elemData || !( events = elemData.events ) ) { -			return; -		} - -		// Once for each type.namespace in types; type may be omitted -		types = ( types || "" ).match( rnothtmlwhite ) || [ "" ]; -		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 data and the expando if it's no longer used -		if ( jQuery.isEmptyObject( events ) ) { -			dataPriv.remove( elem, "handle events" ); -		} -	}, - -	dispatch: function( nativeEvent ) { - -		var i, j, ret, matched, handleObj, handlerQueue, -			args = new Array( arguments.length ), - -			// Make a writable jQuery.Event from the native event object -			event = jQuery.event.fix( nativeEvent ), - -			handlers = ( -					dataPriv.get( this, "events" ) || Object.create( null ) -				)[ event.type ] || [], -			special = jQuery.event.special[ event.type ] || {}; - -		// Use the fix-ed jQuery.Event rather than the (read-only) native event -		args[ 0 ] = event; - -		for ( i = 1; i < arguments.length; i++ ) { -			args[ i ] = arguments[ i ]; -		} - -		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() ) { - -				// If the event is namespaced, then each handler is only invoked if it is -				// specially universal or its namespaces are a superset of the event's. -				if ( !event.rnamespace || handleObj.namespace === false || -					event.rnamespace.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 i, handleObj, sel, matchedHandlers, matchedSelectors, -			handlerQueue = [], -			delegateCount = handlers.delegateCount, -			cur = event.target; - -		// Find delegate handlers -		if ( delegateCount && - -			// Support: IE <=9 -			// Black-hole SVG <use> instance trees (trac-13180) -			cur.nodeType && - -			// Support: Firefox <=42 -			// Suppress spec-violating clicks indicating a non-primary pointer button (trac-3861) -			// https://www.w3.org/TR/DOM-Level-3-Events/#event-type-click -			// Support: IE 11 only -			// ...but not arrow key "clicks" of radio inputs, which can have `button` -1 (gh-2343) -			!( event.type === "click" && event.button >= 1 ) ) { - -			for ( ; cur !== this; cur = cur.parentNode || this ) { - -				// Don't check non-elements (#13208) -				// Don't process clicks on disabled elements (#6911, #8165, #11382, #11764) -				if ( cur.nodeType === 1 && !( event.type === "click" && cur.disabled === true ) ) { -					matchedHandlers = []; -					matchedSelectors = {}; -					for ( i = 0; i < delegateCount; i++ ) { -						handleObj = handlers[ i ]; - -						// Don't conflict with Object.prototype properties (#13203) -						sel = handleObj.selector + " "; - -						if ( matchedSelectors[ sel ] === undefined ) { -							matchedSelectors[ sel ] = handleObj.needsContext ? -								jQuery( sel, this ).index( cur ) > -1 : -								jQuery.find( sel, this, null, [ cur ] ).length; -						} -						if ( matchedSelectors[ sel ] ) { -							matchedHandlers.push( handleObj ); -						} -					} -					if ( matchedHandlers.length ) { -						handlerQueue.push( { elem: cur, handlers: matchedHandlers } ); -					} -				} -			} -		} - -		// Add the remaining (directly-bound) handlers -		cur = this; -		if ( delegateCount < handlers.length ) { -			handlerQueue.push( { elem: cur, handlers: handlers.slice( delegateCount ) } ); -		} - -		return handlerQueue; -	}, - -	addProp: function( name, hook ) { -		Object.defineProperty( jQuery.Event.prototype, name, { -			enumerable: true, -			configurable: true, - -			get: isFunction( hook ) ? -				function() { -					if ( this.originalEvent ) { -							return hook( this.originalEvent ); -					} -				} : -				function() { -					if ( this.originalEvent ) { -							return this.originalEvent[ name ]; -					} -				}, - -			set: function( value ) { -				Object.defineProperty( this, name, { -					enumerable: true, -					configurable: true, -					writable: true, -					value: value -				} ); -			} -		} ); -	}, - -	fix: function( originalEvent ) { -		return originalEvent[ jQuery.expando ] ? -			originalEvent : -			new jQuery.Event( originalEvent ); -	}, - -	special: { -		load: { - -			// Prevent triggered image.load events from bubbling to window.load -			noBubble: true -		}, -		click: { - -			// Utilize native event to ensure correct state for checkable inputs -			setup: function( data ) { - -				// For mutual compressibility with _default, replace `this` access with a local var. -				// `|| data` is dead code meant only to preserve the variable through minification. -				var el = this || data; - -				// Claim the first handler -				if ( rcheckableType.test( el.type ) && -					el.click && nodeName( el, "input" ) ) { - -					// dataPriv.set( el, "click", ... ) -					leverageNative( el, "click", returnTrue ); -				} - -				// Return false to allow normal processing in the caller -				return false; -			}, -			trigger: function( data ) { - -				// For mutual compressibility with _default, replace `this` access with a local var. -				// `|| data` is dead code meant only to preserve the variable through minification. -				var el = this || data; - -				// Force setup before triggering a click -				if ( rcheckableType.test( el.type ) && -					el.click && nodeName( el, "input" ) ) { - -					leverageNative( el, "click" ); -				} - -				// Return non-false to allow normal event-path propagation -				return true; -			}, - -			// For cross-browser consistency, suppress native .click() on links -			// Also prevent it if we're currently inside a leveraged native-event stack -			_default: function( event ) { -				var target = event.target; -				return rcheckableType.test( target.type ) && -					target.click && nodeName( target, "input" ) && -					dataPriv.get( target, "click" ) || -					nodeName( 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; -				} -			} -		} -	} -}; - -// Ensure the presence of an event listener that handles manually-triggered -// synthetic events by interrupting progress until reinvoked in response to -// *native* events that it fires directly, ensuring that state changes have -// already occurred before other listeners are invoked. -function leverageNative( el, type, expectSync ) { - -	// Missing expectSync indicates a trigger call, which must force setup through jQuery.event.add -	if ( !expectSync ) { -		if ( dataPriv.get( el, type ) === undefined ) { -			jQuery.event.add( el, type, returnTrue ); -		} -		return; -	} - -	// Register the controller as a special universal handler for all event namespaces -	dataPriv.set( el, type, false ); -	jQuery.event.add( el, type, { -		namespace: false, -		handler: function( event ) { -			var notAsync, result, -				saved = dataPriv.get( this, type ); - -			if ( ( event.isTrigger & 1 ) && this[ type ] ) { - -				// Interrupt processing of the outer synthetic .trigger()ed event -				// Saved data should be false in such cases, but might be a leftover capture object -				// from an async native handler (gh-4350) -				if ( !saved.length ) { - -					// Store arguments for use when handling the inner native event -					// There will always be at least one argument (an event object), so this array -					// will not be confused with a leftover capture object. -					saved = slice.call( arguments ); -					dataPriv.set( this, type, saved ); - -					// Trigger the native event and capture its result -					// Support: IE <=9 - 11+ -					// focus() and blur() are asynchronous -					notAsync = expectSync( this, type ); -					this[ type ](); -					result = dataPriv.get( this, type ); -					if ( saved !== result || notAsync ) { -						dataPriv.set( this, type, false ); -					} else { -						result = {}; -					} -					if ( saved !== result ) { - -						// Cancel the outer synthetic event -						event.stopImmediatePropagation(); -						event.preventDefault(); -						return result.value; -					} - -				// If this is an inner synthetic event for an event with a bubbling surrogate -				// (focus or blur), assume that the surrogate already propagated from triggering the -				// native event and prevent that from happening again here. -				// This technically gets the ordering wrong w.r.t. to `.trigger()` (in which the -				// bubbling surrogate propagates *after* the non-bubbling base), but that seems -				// less bad than duplication. -				} else if ( ( jQuery.event.special[ type ] || {} ).delegateType ) { -					event.stopPropagation(); -				} - -			// If this is a native event triggered above, everything is now in order -			// Fire an inner synthetic event with the original arguments -			} else if ( saved.length ) { - -				// ...and capture the result -				dataPriv.set( this, type, { -					value: jQuery.event.trigger( - -						// Support: IE <=9 - 11+ -						// Extend with the prototype to reset the above stopImmediatePropagation() -						jQuery.extend( saved[ 0 ], jQuery.Event.prototype ), -						saved.slice( 1 ), -						this -					) -				} ); - -				// Abort handling of the native event -				event.stopImmediatePropagation(); -			} -		} -	} ); -} - -jQuery.removeEvent = function( elem, type, handle ) { - -	// This "if" is needed for plain objects -	if ( elem.removeEventListener ) { -		elem.removeEventListener( type, 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: Android <=2.3 only -				src.returnValue === false ? -			returnTrue : -			returnFalse; - -		// Create target properties -		// Support: Safari <=6 - 7 only -		// Target should not be a text node (#504, #13143) -		this.target = ( src.target && src.target.nodeType === 3 ) ? -			src.target.parentNode : -			src.target; - -		this.currentTarget = src.currentTarget; -		this.relatedTarget = src.relatedTarget; - -	// 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 || Date.now(); - -	// Mark it as fixed -	this[ jQuery.expando ] = true; -}; - -// jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding -// https://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html -jQuery.Event.prototype = { -	constructor: jQuery.Event, -	isDefaultPrevented: returnFalse, -	isPropagationStopped: returnFalse, -	isImmediatePropagationStopped: returnFalse, -	isSimulated: false, - -	preventDefault: function() { -		var e = this.originalEvent; - -		this.isDefaultPrevented = returnTrue; - -		if ( e && !this.isSimulated ) { -			e.preventDefault(); -		} -	}, -	stopPropagation: function() { -		var e = this.originalEvent; - -		this.isPropagationStopped = returnTrue; - -		if ( e && !this.isSimulated ) { -			e.stopPropagation(); -		} -	}, -	stopImmediatePropagation: function() { -		var e = this.originalEvent; - -		this.isImmediatePropagationStopped = returnTrue; - -		if ( e && !this.isSimulated ) { -			e.stopImmediatePropagation(); -		} - -		this.stopPropagation(); -	} -}; - -// Includes all common event props including KeyEvent and MouseEvent specific props -jQuery.each( { -	altKey: true, -	bubbles: true, -	cancelable: true, -	changedTouches: true, -	ctrlKey: true, -	detail: true, -	eventPhase: true, -	metaKey: true, -	pageX: true, -	pageY: true, -	shiftKey: true, -	view: true, -	"char": true, -	code: true, -	charCode: true, -	key: true, -	keyCode: true, -	button: true, -	buttons: true, -	clientX: true, -	clientY: true, -	offsetX: true, -	offsetY: true, -	pointerId: true, -	pointerType: true, -	screenX: true, -	screenY: true, -	targetTouches: true, -	toElement: true, -	touches: true, - -	which: function( event ) { -		var button = event.button; - -		// Add which for key events -		if ( event.which == null && rkeyEvent.test( event.type ) ) { -			return event.charCode != null ? event.charCode : event.keyCode; -		} - -		// Add which for click: 1 === left; 2 === middle; 3 === right -		if ( !event.which && button !== undefined && rmouseEvent.test( event.type ) ) { -			if ( button & 1 ) { -				return 1; -			} - -			if ( button & 2 ) { -				return 3; -			} - -			if ( button & 4 ) { -				return 2; -			} - -			return 0; -		} - -		return event.which; -	} -}, jQuery.event.addProp ); - -jQuery.each( { focus: "focusin", blur: "focusout" }, function( type, delegateType ) { -	jQuery.event.special[ type ] = { - -		// Utilize native event if possible so blur/focus sequence is correct -		setup: function() { - -			// Claim the first handler -			// dataPriv.set( this, "focus", ... ) -			// dataPriv.set( this, "blur", ... ) -			leverageNative( this, type, expectSync ); - -			// Return false to allow normal processing in the caller -			return false; -		}, -		trigger: function() { - -			// Force setup before trigger -			leverageNative( this, type ); - -			// Return non-false to allow normal event-path propagation -			return true; -		}, - -		delegateType: delegateType -	}; -} ); - -// Create mouseenter/leave events using mouseover/out and event-time checks -// so that event delegation works in jQuery. -// Do the same for pointerenter/pointerleave and pointerover/pointerout -// -// Support: Safari 7 only -// Safari sends mouseenter too often; see: -// https://bugs.chromium.org/p/chromium/issues/detail?id=470258 -// for the description of the bug (it existed in older Chrome versions as well). -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 mouseenter/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; -		} -	}; -} ); - -jQuery.fn.extend( { - -	on: function( types, selector, data, fn ) { -		return on( this, types, selector, data, fn ); -	}, -	one: function( types, selector, data, fn ) { -		return on( this, 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 ); -		} ); -	} -} ); - - -var - -	// Support: IE <=10 - 11, Edge 12 - 13 only -	// In IE/Edge using regex groups here causes severe slowdowns. -	// See https://connect.microsoft.com/IE/feedback/details/1736512/ -	rnoInnerhtml = /<script|<style|<link/i, - -	// checked="checked" or checked -	rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i, -	rcleanScript = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g; - -// Prefer a tbody over its parent table for containing new rows -function manipulationTarget( elem, content ) { -	if ( nodeName( elem, "table" ) && -		nodeName( content.nodeType !== 11 ? content : content.firstChild, "tr" ) ) { - -		return jQuery( elem ).children( "tbody" )[ 0 ] || elem; -	} - -	return elem; -} - -// Replace/restore the type attribute of script elements for safe DOM manipulation -function disableScript( elem ) { -	elem.type = ( elem.getAttribute( "type" ) !== null ) + "/" + elem.type; -	return elem; -} -function restoreScript( elem ) { -	if ( ( elem.type || "" ).slice( 0, 5 ) === "true/" ) { -		elem.type = elem.type.slice( 5 ); -	} else { -		elem.removeAttribute( "type" ); -	} - -	return elem; -} - -function cloneCopyEvent( src, dest ) { -	var i, l, type, pdataOld, udataOld, udataCur, events; - -	if ( dest.nodeType !== 1 ) { -		return; -	} - -	// 1. Copy private data: events, handlers, etc. -	if ( dataPriv.hasData( src ) ) { -		pdataOld = dataPriv.get( src ); -		events = pdataOld.events; - -		if ( events ) { -			dataPriv.remove( dest, "handle events" ); - -			for ( type in events ) { -				for ( i = 0, l = events[ type ].length; i < l; i++ ) { -					jQuery.event.add( dest, type, events[ type ][ i ] ); -				} -			} -		} -	} - -	// 2. Copy user data -	if ( dataUser.hasData( src ) ) { -		udataOld = dataUser.access( src ); -		udataCur = jQuery.extend( {}, udataOld ); - -		dataUser.set( dest, udataCur ); -	} -} - -// Fix IE bugs, see support tests -function fixInput( src, dest ) { -	var nodeName = dest.nodeName.toLowerCase(); - -	// Fails to persist the checked state of a cloned checkbox or radio button. -	if ( nodeName === "input" && rcheckableType.test( src.type ) ) { -		dest.checked = src.checked; - -	// Fails to return the selected option to the default selected state when cloning options -	} else if ( nodeName === "input" || nodeName === "textarea" ) { -		dest.defaultValue = src.defaultValue; -	} -} - -function domManip( collection, args, callback, ignored ) { - -	// Flatten any nested arrays -	args = flat( args ); - -	var fragment, first, scripts, hasScripts, node, doc, -		i = 0, -		l = collection.length, -		iNoClone = l - 1, -		value = args[ 0 ], -		valueIsFunction = isFunction( value ); - -	// We can't cloneNode fragments that contain checked, in WebKit -	if ( valueIsFunction || -			( l > 1 && typeof value === "string" && -				!support.checkClone && rchecked.test( value ) ) ) { -		return collection.each( function( index ) { -			var self = collection.eq( index ); -			if ( valueIsFunction ) { -				args[ 0 ] = value.call( this, index, self.html() ); -			} -			domManip( self, args, callback, ignored ); -		} ); -	} - -	if ( l ) { -		fragment = buildFragment( args, collection[ 0 ].ownerDocument, false, collection, ignored ); -		first = fragment.firstChild; - -		if ( fragment.childNodes.length === 1 ) { -			fragment = first; -		} - -		// Require either new content or an interest in ignored elements to invoke the callback -		if ( first || ignored ) { -			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 ) { - -						// Support: Android <=4.0 only, PhantomJS 1 only -						// push.apply(_, arraylike) throws on ancient WebKit -						jQuery.merge( scripts, getAll( node, "script" ) ); -					} -				} - -				callback.call( collection[ 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 || "" ) && -						!dataPriv.access( node, "globalEval" ) && -						jQuery.contains( doc, node ) ) { - -						if ( node.src && ( node.type || "" ).toLowerCase()  !== "module" ) { - -							// Optional AJAX dependency, but won't run scripts if not present -							if ( jQuery._evalUrl && !node.noModule ) { -								jQuery._evalUrl( node.src, { -									nonce: node.nonce || node.getAttribute( "nonce" ) -								}, doc ); -							} -						} else { -							DOMEval( node.textContent.replace( rcleanScript, "" ), node, doc ); -						} -					} -				} -			} -		} -	} - -	return collection; -} - -function remove( elem, selector, keepData ) { -	var node, -		nodes = selector ? jQuery.filter( selector, elem ) : elem, -		i = 0; - -	for ( ; ( node = nodes[ i ] ) != null; i++ ) { -		if ( !keepData && node.nodeType === 1 ) { -			jQuery.cleanData( getAll( node ) ); -		} - -		if ( node.parentNode ) { -			if ( keepData && isAttached( node ) ) { -				setGlobalEval( getAll( node, "script" ) ); -			} -			node.parentNode.removeChild( node ); -		} -	} - -	return elem; -} - -jQuery.extend( { -	htmlPrefilter: function( html ) { -		return html; -	}, - -	clone: function( elem, dataAndEvents, deepDataAndEvents ) { -		var i, l, srcElements, destElements, -			clone = elem.cloneNode( true ), -			inPage = isAttached( elem ); - -		// Fix IE cloning issues -		if ( !support.noCloneChecked && ( elem.nodeType === 1 || elem.nodeType === 11 ) && -				!jQuery.isXMLDoc( elem ) ) { - -			// We eschew Sizzle here for performance reasons: https://jsperf.com/getall-vs-sizzle/2 -			destElements = getAll( clone ); -			srcElements = getAll( elem ); - -			for ( i = 0, l = srcElements.length; i < l; i++ ) { -				fixInput( srcElements[ i ], 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, l = srcElements.length; i < l; i++ ) { -					cloneCopyEvent( srcElements[ i ], destElements[ i ] ); -				} -			} else { -				cloneCopyEvent( elem, clone ); -			} -		} - -		// Preserve script evaluation history -		destElements = getAll( clone, "script" ); -		if ( destElements.length > 0 ) { -			setGlobalEval( destElements, !inPage && getAll( elem, "script" ) ); -		} - -		// Return the cloned set -		return clone; -	}, - -	cleanData: function( elems ) { -		var data, elem, type, -			special = jQuery.event.special, -			i = 0; - -		for ( ; ( elem = elems[ i ] ) !== undefined; i++ ) { -			if ( acceptData( elem ) ) { -				if ( ( data = elem[ dataPriv.expando ] ) ) { -					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 ); -							} -						} -					} - -					// Support: Chrome <=35 - 45+ -					// Assign undefined instead of using delete, see Data#remove -					elem[ dataPriv.expando ] = undefined; -				} -				if ( elem[ dataUser.expando ] ) { - -					// Support: Chrome <=35 - 45+ -					// Assign undefined instead of using delete, see Data#remove -					elem[ dataUser.expando ] = undefined; -				} -			} -		} -	} -} ); - -jQuery.fn.extend( { -	detach: function( selector ) { -		return remove( this, selector, true ); -	}, - -	remove: function( selector ) { -		return remove( this, selector ); -	}, - -	text: function( value ) { -		return access( this, function( value ) { -			return value === undefined ? -				jQuery.text( this ) : -				this.empty().each( function() { -					if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { -						this.textContent = value; -					} -				} ); -		}, null, value, arguments.length ); -	}, - -	append: function() { -		return domManip( this, arguments, function( elem ) { -			if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { -				var target = manipulationTarget( this, elem ); -				target.appendChild( elem ); -			} -		} ); -	}, - -	prepend: function() { -		return domManip( this, 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 domManip( this, arguments, function( elem ) { -			if ( this.parentNode ) { -				this.parentNode.insertBefore( elem, this ); -			} -		} ); -	}, - -	after: function() { -		return domManip( this, arguments, function( elem ) { -			if ( this.parentNode ) { -				this.parentNode.insertBefore( elem, this.nextSibling ); -			} -		} ); -	}, - -	empty: function() { -		var elem, -			i = 0; - -		for ( ; ( elem = this[ i ] ) != null; i++ ) { -			if ( elem.nodeType === 1 ) { - -				// Prevent memory leaks -				jQuery.cleanData( getAll( elem, false ) ); - -				// Remove any remaining nodes -				elem.textContent = ""; -			} -		} - -		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 && elem.nodeType === 1 ) { -				return elem.innerHTML; -			} - -			// See if we can take a shortcut and just use innerHTML -			if ( typeof value === "string" && !rnoInnerhtml.test( value ) && -				!wrapMap[ ( rtagName.exec( value ) || [ "", "" ] )[ 1 ].toLowerCase() ] ) { - -				value = jQuery.htmlPrefilter( value ); - -				try { -					for ( ; i < l; i++ ) { -						elem = this[ i ] || {}; - -						// Remove element nodes and prevent memory leaks -						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 ignored = []; - -		// Make the changes, replacing each non-ignored context element with the new content -		return domManip( this, arguments, function( elem ) { -			var parent = this.parentNode; - -			if ( jQuery.inArray( this, ignored ) < 0 ) { -				jQuery.cleanData( getAll( this ) ); -				if ( parent ) { -					parent.replaceChild( elem, this ); -				} -			} - -		// Force callback invocation -		}, ignored ); -	} -} ); - -jQuery.each( { -	appendTo: "append", -	prependTo: "prepend", -	insertBefore: "before", -	insertAfter: "after", -	replaceAll: "replaceWith" -}, function( name, original ) { -	jQuery.fn[ name ] = function( selector ) { -		var elems, -			ret = [], -			insert = jQuery( selector ), -			last = insert.length - 1, -			i = 0; - -		for ( ; i <= last; i++ ) { -			elems = i === last ? this : this.clone( true ); -			jQuery( insert[ i ] )[ original ]( elems ); - -			// Support: Android <=4.0 only, PhantomJS 1 only -			// .get() because push.apply(_, arraylike) throws on ancient WebKit -			push.apply( ret, elems.get() ); -		} - -		return this.pushStack( ret ); -	}; -} ); -var rnumnonpx = new RegExp( "^(" + pnum + ")(?!px)[a-z%]+$", "i" ); - -var getStyles = function( elem ) { - -		// Support: IE <=11 only, Firefox <=30 (#15098, #14150) -		// IE throws on elements created in popups -		// FF meanwhile throws on frame elements through "defaultView.getComputedStyle" -		var view = elem.ownerDocument.defaultView; - -		if ( !view || !view.opener ) { -			view = window; -		} - -		return view.getComputedStyle( elem ); -	}; - -var swap = function( elem, options, callback ) { -	var ret, name, -		old = {}; - -	// Remember the old values, and insert the new ones -	for ( name in options ) { -		old[ name ] = elem.style[ name ]; -		elem.style[ name ] = options[ name ]; -	} - -	ret = callback.call( elem ); - -	// Revert the old values -	for ( name in options ) { -		elem.style[ name ] = old[ name ]; -	} - -	return ret; -}; - - -var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" ); - - - -( function() { - -	// Executing both pixelPosition & boxSizingReliable tests require only one layout -	// so they're executed at the same time to save the second computation. -	function computeStyleTests() { - -		// This is a singleton, we need to execute it only once -		if ( !div ) { -			return; -		} - -		container.style.cssText = "position:absolute;left:-11111px;width:60px;" + -			"margin-top:1px;padding:0;border:0"; -		div.style.cssText = -			"position:relative;display:block;box-sizing:border-box;overflow:scroll;" + -			"margin:auto;border:1px;padding:1px;" + -			"width:60%;top:1%"; -		documentElement.appendChild( container ).appendChild( div ); - -		var divStyle = window.getComputedStyle( div ); -		pixelPositionVal = divStyle.top !== "1%"; - -		// Support: Android 4.0 - 4.3 only, Firefox <=3 - 44 -		reliableMarginLeftVal = roundPixelMeasures( divStyle.marginLeft ) === 12; - -		// Support: Android 4.0 - 4.3 only, Safari <=9.1 - 10.1, iOS <=7.0 - 9.3 -		// Some styles come back with percentage values, even though they shouldn't -		div.style.right = "60%"; -		pixelBoxStylesVal = roundPixelMeasures( divStyle.right ) === 36; - -		// Support: IE 9 - 11 only -		// Detect misreporting of content dimensions for box-sizing:border-box elements -		boxSizingReliableVal = roundPixelMeasures( divStyle.width ) === 36; - -		// Support: IE 9 only -		// Detect overflow:scroll screwiness (gh-3699) -		// Support: Chrome <=64 -		// Don't get tricked when zoom affects offsetWidth (gh-4029) -		div.style.position = "absolute"; -		scrollboxSizeVal = roundPixelMeasures( div.offsetWidth / 3 ) === 12; - -		documentElement.removeChild( container ); - -		// Nullify the div so it wouldn't be stored in the memory and -		// it will also be a sign that checks already performed -		div = null; -	} - -	function roundPixelMeasures( measure ) { -		return Math.round( parseFloat( measure ) ); -	} - -	var pixelPositionVal, boxSizingReliableVal, scrollboxSizeVal, pixelBoxStylesVal, -		reliableTrDimensionsVal, reliableMarginLeftVal, -		container = document.createElement( "div" ), -		div = document.createElement( "div" ); - -	// Finish early in limited (non-browser) environments -	if ( !div.style ) { -		return; -	} - -	// Support: IE <=9 - 11 only -	// Style of cloned element affects source element cloned (#8908) -	div.style.backgroundClip = "content-box"; -	div.cloneNode( true ).style.backgroundClip = ""; -	support.clearCloneStyle = div.style.backgroundClip === "content-box"; - -	jQuery.extend( support, { -		boxSizingReliable: function() { -			computeStyleTests(); -			return boxSizingReliableVal; -		}, -		pixelBoxStyles: function() { -			computeStyleTests(); -			return pixelBoxStylesVal; -		}, -		pixelPosition: function() { -			computeStyleTests(); -			return pixelPositionVal; -		}, -		reliableMarginLeft: function() { -			computeStyleTests(); -			return reliableMarginLeftVal; -		}, -		scrollboxSize: function() { -			computeStyleTests(); -			return scrollboxSizeVal; -		}, - -		// Support: IE 9 - 11+, Edge 15 - 18+ -		// IE/Edge misreport `getComputedStyle` of table rows with width/height -		// set in CSS while `offset*` properties report correct values. -		// Behavior in IE 9 is more subtle than in newer versions & it passes -		// some versions of this test; make sure not to make it pass there! -		reliableTrDimensions: function() { -			var table, tr, trChild, trStyle; -			if ( reliableTrDimensionsVal == null ) { -				table = document.createElement( "table" ); -				tr = document.createElement( "tr" ); -				trChild = document.createElement( "div" ); - -				table.style.cssText = "position:absolute;left:-11111px"; -				tr.style.height = "1px"; -				trChild.style.height = "9px"; - -				documentElement -					.appendChild( table ) -					.appendChild( tr ) -					.appendChild( trChild ); - -				trStyle = window.getComputedStyle( tr ); -				reliableTrDimensionsVal = parseInt( trStyle.height ) > 3; - -				documentElement.removeChild( table ); -			} -			return reliableTrDimensionsVal; -		} -	} ); -} )(); - - -function curCSS( elem, name, computed ) { -	var width, minWidth, maxWidth, ret, - -		// Support: Firefox 51+ -		// Retrieving style before computed somehow -		// fixes an issue with getting wrong values -		// on detached elements -		style = elem.style; - -	computed = computed || getStyles( elem ); - -	// getPropertyValue is needed for: -	//   .css('filter') (IE 9 only, #12537) -	//   .css('--customProperty) (#3144) -	if ( computed ) { -		ret = computed.getPropertyValue( name ) || computed[ name ]; - -		if ( ret === "" && !isAttached( elem ) ) { -			ret = jQuery.style( elem, name ); -		} - -		// A tribute to the "awesome hack by Dean Edwards" -		// Android Browser returns percentage for some values, -		// but width seems to be reliably pixels. -		// This is against the CSSOM draft spec: -		// https://drafts.csswg.org/cssom/#resolved-values -		if ( !support.pixelBoxStyles() && rnumnonpx.test( ret ) && rboxStyle.test( name ) ) { - -			// Remember the original values -			width = style.width; -			minWidth = style.minWidth; -			maxWidth = style.maxWidth; - -			// Put in the new values to get a computed value out -			style.minWidth = style.maxWidth = style.width = ret; -			ret = computed.width; - -			// Revert the changed values -			style.width = width; -			style.minWidth = minWidth; -			style.maxWidth = maxWidth; -		} -	} - -	return ret !== undefined ? - -		// Support: IE <=9 - 11 only -		// IE returns zIndex value as an integer. -		ret + "" : -		ret; -} - - -function addGetHookIf( conditionFn, hookFn ) { - -	// Define the hook, we'll check on the first run if it's really needed. -	return { -		get: function() { -			if ( conditionFn() ) { - -				// Hook not needed (or it's not possible to use it due -				// to missing dependency), remove it. -				delete this.get; -				return; -			} - -			// Hook needed; redefine it so that the support test is not executed again. -			return ( this.get = hookFn ).apply( this, arguments ); -		} -	}; -} - - -var cssPrefixes = [ "Webkit", "Moz", "ms" ], -	emptyStyle = document.createElement( "div" ).style, -	vendorProps = {}; - -// Return a vendor-prefixed property or undefined -function vendorPropName( name ) { - -	// Check for vendor prefixed names -	var capName = name[ 0 ].toUpperCase() + name.slice( 1 ), -		i = cssPrefixes.length; - -	while ( i-- ) { -		name = cssPrefixes[ i ] + capName; -		if ( name in emptyStyle ) { -			return name; -		} -	} -} - -// Return a potentially-mapped jQuery.cssProps or vendor prefixed property -function finalPropName( name ) { -	var final = jQuery.cssProps[ name ] || vendorProps[ name ]; - -	if ( final ) { -		return final; -	} -	if ( name in emptyStyle ) { -		return name; -	} -	return vendorProps[ name ] = vendorPropName( name ) || name; -} - - -var - -	// Swappable if display is none or starts with table -	// except "table", "table-cell", or "table-caption" -	// See here for display values: https://developer.mozilla.org/en-US/docs/CSS/display -	rdisplayswap = /^(none|table(?!-c[ea]).+)/, -	rcustomProp = /^--/, -	cssShow = { position: "absolute", visibility: "hidden", display: "block" }, -	cssNormalTransform = { -		letterSpacing: "0", -		fontWeight: "400" -	}; - -function setPositiveNumber( _elem, value, subtract ) { - -	// Any relative (+/-) values have already been -	// normalized at this point -	var matches = rcssNum.exec( value ); -	return matches ? - -		// Guard against undefined "subtract", e.g., when used as in cssHooks -		Math.max( 0, matches[ 2 ] - ( subtract || 0 ) ) + ( matches[ 3 ] || "px" ) : -		value; -} - -function boxModelAdjustment( elem, dimension, box, isBorderBox, styles, computedVal ) { -	var i = dimension === "width" ? 1 : 0, -		extra = 0, -		delta = 0; - -	// Adjustment may not be necessary -	if ( box === ( isBorderBox ? "border" : "content" ) ) { -		return 0; -	} - -	for ( ; i < 4; i += 2 ) { - -		// Both box models exclude margin -		if ( box === "margin" ) { -			delta += jQuery.css( elem, box + cssExpand[ i ], true, styles ); -		} - -		// If we get here with a content-box, we're seeking "padding" or "border" or "margin" -		if ( !isBorderBox ) { - -			// Add padding -			delta += jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); - -			// For "border" or "margin", add border -			if ( box !== "padding" ) { -				delta += jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); - -			// But still keep track of it otherwise -			} else { -				extra += jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); -			} - -		// If we get here with a border-box (content + padding + border), we're seeking "content" or -		// "padding" or "margin" -		} else { - -			// For "content", subtract padding -			if ( box === "content" ) { -				delta -= jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); -			} - -			// For "content" or "padding", subtract border -			if ( box !== "margin" ) { -				delta -= jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); -			} -		} -	} - -	// Account for positive content-box scroll gutter when requested by providing computedVal -	if ( !isBorderBox && computedVal >= 0 ) { - -		// offsetWidth/offsetHeight is a rounded sum of content, padding, scroll gutter, and border -		// Assuming integer scroll gutter, subtract the rest and round down -		delta += Math.max( 0, Math.ceil( -			elem[ "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ] - -			computedVal - -			delta - -			extra - -			0.5 - -		// If offsetWidth/offsetHeight is unknown, then we can't determine content-box scroll gutter -		// Use an explicit zero to avoid NaN (gh-3964) -		) ) || 0; -	} - -	return delta; -} - -function getWidthOrHeight( elem, dimension, extra ) { - -	// Start with computed style -	var styles = getStyles( elem ), - -		// To avoid forcing a reflow, only fetch boxSizing if we need it (gh-4322). -		// Fake content-box until we know it's needed to know the true value. -		boxSizingNeeded = !support.boxSizingReliable() || extra, -		isBorderBox = boxSizingNeeded && -			jQuery.css( elem, "boxSizing", false, styles ) === "border-box", -		valueIsBorderBox = isBorderBox, - -		val = curCSS( elem, dimension, styles ), -		offsetProp = "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ); - -	// Support: Firefox <=54 -	// Return a confounding non-pixel value or feign ignorance, as appropriate. -	if ( rnumnonpx.test( val ) ) { -		if ( !extra ) { -			return val; -		} -		val = "auto"; -	} - - -	// Support: IE 9 - 11 only -	// Use offsetWidth/offsetHeight for when box sizing is unreliable. -	// In those cases, the computed value can be trusted to be border-box. -	if ( ( !support.boxSizingReliable() && isBorderBox || - -		// Support: IE 10 - 11+, Edge 15 - 18+ -		// IE/Edge misreport `getComputedStyle` of table rows with width/height -		// set in CSS while `offset*` properties report correct values. -		// Interestingly, in some cases IE 9 doesn't suffer from this issue. -		!support.reliableTrDimensions() && nodeName( elem, "tr" ) || - -		// Fall back to offsetWidth/offsetHeight when value is "auto" -		// This happens for inline elements with no explicit setting (gh-3571) -		val === "auto" || - -		// Support: Android <=4.1 - 4.3 only -		// Also use offsetWidth/offsetHeight for misreported inline dimensions (gh-3602) -		!parseFloat( val ) && jQuery.css( elem, "display", false, styles ) === "inline" ) && - -		// Make sure the element is visible & connected -		elem.getClientRects().length ) { - -		isBorderBox = jQuery.css( elem, "boxSizing", false, styles ) === "border-box"; - -		// Where available, offsetWidth/offsetHeight approximate border box dimensions. -		// Where not available (e.g., SVG), assume unreliable box-sizing and interpret the -		// retrieved value as a content box dimension. -		valueIsBorderBox = offsetProp in elem; -		if ( valueIsBorderBox ) { -			val = elem[ offsetProp ]; -		} -	} - -	// Normalize "" and auto -	val = parseFloat( val ) || 0; - -	// Adjust for the element's box model -	return ( val + -		boxModelAdjustment( -			elem, -			dimension, -			extra || ( isBorderBox ? "border" : "content" ), -			valueIsBorderBox, -			styles, - -			// Provide the current computed size to request scroll gutter calculation (gh-3589) -			val -		) -	) + "px"; -} - -jQuery.extend( { - -	// Add in style property hooks for overriding the default -	// behavior of getting and setting a style property -	cssHooks: { -		opacity: { -			get: function( elem, computed ) { -				if ( computed ) { - -					// We should always get a number back from opacity -					var ret = curCSS( elem, "opacity" ); -					return ret === "" ? "1" : ret; -				} -			} -		} -	}, - -	// Don't automatically add "px" to these possibly-unitless properties -	cssNumber: { -		"animationIterationCount": true, -		"columnCount": true, -		"fillOpacity": true, -		"flexGrow": true, -		"flexShrink": true, -		"fontWeight": true, -		"gridArea": true, -		"gridColumn": true, -		"gridColumnEnd": true, -		"gridColumnStart": true, -		"gridRow": true, -		"gridRowEnd": true, -		"gridRowStart": true, -		"lineHeight": true, -		"opacity": true, -		"order": true, -		"orphans": true, -		"widows": true, -		"zIndex": true, -		"zoom": true -	}, - -	// Add in properties whose names you wish to fix before -	// setting or getting the value -	cssProps: {}, - -	// Get and set the style property on a DOM Node -	style: function( elem, name, value, extra ) { - -		// Don't set styles on text and comment nodes -		if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) { -			return; -		} - -		// Make sure that we're working with the right name -		var ret, type, hooks, -			origName = camelCase( name ), -			isCustomProp = rcustomProp.test( name ), -			style = elem.style; - -		// Make sure that we're working with the right name. We don't -		// want to query the value if it is a CSS custom property -		// since they are user-defined. -		if ( !isCustomProp ) { -			name = finalPropName( origName ); -		} - -		// Gets hook for the prefixed version, then unprefixed version -		hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ]; - -		// Check if we're setting a value -		if ( value !== undefined ) { -			type = typeof value; - -			// Convert "+=" or "-=" to relative numbers (#7345) -			if ( type === "string" && ( ret = rcssNum.exec( value ) ) && ret[ 1 ] ) { -				value = adjustCSS( elem, name, ret ); - -				// Fixes bug #9237 -				type = "number"; -			} - -			// Make sure that null and NaN values aren't set (#7116) -			if ( value == null || value !== value ) { -				return; -			} - -			// If a number was passed in, add the unit (except for certain CSS properties) -			// The isCustomProp check can be removed in jQuery 4.0 when we only auto-append -			// "px" to a few hardcoded values. -			if ( type === "number" && !isCustomProp ) { -				value += ret && ret[ 3 ] || ( jQuery.cssNumber[ origName ] ? "" : "px" ); -			} - -			// background-* props affect original clone's values -			if ( !support.clearCloneStyle && value === "" && name.indexOf( "background" ) === 0 ) { -				style[ name ] = "inherit"; -			} - -			// If a hook was provided, use that value, otherwise just set the specified value -			if ( !hooks || !( "set" in hooks ) || -				( value = hooks.set( elem, value, extra ) ) !== undefined ) { - -				if ( isCustomProp ) { -					style.setProperty( name, value ); -				} else { -					style[ name ] = value; -				} -			} - -		} else { - -			// If a hook was provided get the non-computed value from there -			if ( hooks && "get" in hooks && -				( ret = hooks.get( elem, false, extra ) ) !== undefined ) { - -				return ret; -			} - -			// Otherwise just get the value from the style object -			return style[ name ]; -		} -	}, - -	css: function( elem, name, extra, styles ) { -		var val, num, hooks, -			origName = camelCase( name ), -			isCustomProp = rcustomProp.test( name ); - -		// Make sure that we're working with the right name. We don't -		// want to modify the value if it is a CSS custom property -		// since they are user-defined. -		if ( !isCustomProp ) { -			name = finalPropName( origName ); -		} - -		// Try prefixed name followed by the unprefixed name -		hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ]; - -		// If a hook was provided get the computed value from there -		if ( hooks && "get" in hooks ) { -			val = hooks.get( elem, true, extra ); -		} - -		// Otherwise, if a way to get the computed value exists, use that -		if ( val === undefined ) { -			val = curCSS( elem, name, styles ); -		} - -		// Convert "normal" to computed value -		if ( val === "normal" && name in cssNormalTransform ) { -			val = cssNormalTransform[ name ]; -		} - -		// Make numeric if forced or a qualifier was provided and val looks numeric -		if ( extra === "" || extra ) { -			num = parseFloat( val ); -			return extra === true || isFinite( num ) ? num || 0 : val; -		} - -		return val; -	} -} ); - -jQuery.each( [ "height", "width" ], function( _i, dimension ) { -	jQuery.cssHooks[ dimension ] = { -		get: function( elem, computed, extra ) { -			if ( computed ) { - -				// Certain elements can have dimension info if we invisibly show them -				// but it must have a current display style that would benefit -				return rdisplayswap.test( jQuery.css( elem, "display" ) ) && - -					// Support: Safari 8+ -					// Table columns in Safari have non-zero offsetWidth & zero -					// getBoundingClientRect().width unless display is changed. -					// Support: IE <=11 only -					// Running getBoundingClientRect on a disconnected node -					// in IE throws an error. -					( !elem.getClientRects().length || !elem.getBoundingClientRect().width ) ? -						swap( elem, cssShow, function() { -							return getWidthOrHeight( elem, dimension, extra ); -						} ) : -						getWidthOrHeight( elem, dimension, extra ); -			} -		}, - -		set: function( elem, value, extra ) { -			var matches, -				styles = getStyles( elem ), - -				// Only read styles.position if the test has a chance to fail -				// to avoid forcing a reflow. -				scrollboxSizeBuggy = !support.scrollboxSize() && -					styles.position === "absolute", - -				// To avoid forcing a reflow, only fetch boxSizing if we need it (gh-3991) -				boxSizingNeeded = scrollboxSizeBuggy || extra, -				isBorderBox = boxSizingNeeded && -					jQuery.css( elem, "boxSizing", false, styles ) === "border-box", -				subtract = extra ? -					boxModelAdjustment( -						elem, -						dimension, -						extra, -						isBorderBox, -						styles -					) : -					0; - -			// Account for unreliable border-box dimensions by comparing offset* to computed and -			// faking a content-box to get border and padding (gh-3699) -			if ( isBorderBox && scrollboxSizeBuggy ) { -				subtract -= Math.ceil( -					elem[ "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ] - -					parseFloat( styles[ dimension ] ) - -					boxModelAdjustment( elem, dimension, "border", false, styles ) - -					0.5 -				); -			} - -			// Convert to pixels if value adjustment is needed -			if ( subtract && ( matches = rcssNum.exec( value ) ) && -				( matches[ 3 ] || "px" ) !== "px" ) { - -				elem.style[ dimension ] = value; -				value = jQuery.css( elem, dimension ); -			} - -			return setPositiveNumber( elem, value, subtract ); -		} -	}; -} ); - -jQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft, -	function( elem, computed ) { -		if ( computed ) { -			return ( parseFloat( curCSS( elem, "marginLeft" ) ) || -				elem.getBoundingClientRect().left - -					swap( elem, { marginLeft: 0 }, function() { -						return elem.getBoundingClientRect().left; -					} ) -				) + "px"; -		} -	} -); - -// These hooks are used by animate to expand properties -jQuery.each( { -	margin: "", -	padding: "", -	border: "Width" -}, function( prefix, suffix ) { -	jQuery.cssHooks[ prefix + suffix ] = { -		expand: function( value ) { -			var i = 0, -				expanded = {}, - -				// Assumes a single number if not a string -				parts = typeof value === "string" ? value.split( " " ) : [ value ]; - -			for ( ; i < 4; i++ ) { -				expanded[ prefix + cssExpand[ i ] + suffix ] = -					parts[ i ] || parts[ i - 2 ] || parts[ 0 ]; -			} - -			return expanded; -		} -	}; - -	if ( prefix !== "margin" ) { -		jQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber; -	} -} ); - -jQuery.fn.extend( { -	css: function( name, value ) { -		return access( this, function( elem, name, value ) { -			var styles, len, -				map = {}, -				i = 0; - -			if ( Array.isArray( name ) ) { -				styles = getStyles( elem ); -				len = name.length; - -				for ( ; i < len; i++ ) { -					map[ name[ i ] ] = jQuery.css( elem, name[ i ], false, styles ); -				} - -				return map; -			} - -			return value !== undefined ? -				jQuery.style( elem, name, value ) : -				jQuery.css( elem, name ); -		}, name, value, arguments.length > 1 ); -	} -} ); - - -function Tween( elem, options, prop, end, easing ) { -	return new Tween.prototype.init( elem, options, prop, end, easing ); -} -jQuery.Tween = Tween; - -Tween.prototype = { -	constructor: Tween, -	init: function( elem, options, prop, end, easing, unit ) { -		this.elem = elem; -		this.prop = prop; -		this.easing = easing || jQuery.easing._default; -		this.options = options; -		this.start = this.now = this.cur(); -		this.end = end; -		this.unit = unit || ( jQuery.cssNumber[ prop ] ? "" : "px" ); -	}, -	cur: function() { -		var hooks = Tween.propHooks[ this.prop ]; - -		return hooks && hooks.get ? -			hooks.get( this ) : -			Tween.propHooks._default.get( this ); -	}, -	run: function( percent ) { -		var eased, -			hooks = Tween.propHooks[ this.prop ]; - -		if ( this.options.duration ) { -			this.pos = eased = jQuery.easing[ this.easing ]( -				percent, this.options.duration * percent, 0, 1, this.options.duration -			); -		} else { -			this.pos = eased = percent; -		} -		this.now = ( this.end - this.start ) * eased + this.start; - -		if ( this.options.step ) { -			this.options.step.call( this.elem, this.now, this ); -		} - -		if ( hooks && hooks.set ) { -			hooks.set( this ); -		} else { -			Tween.propHooks._default.set( this ); -		} -		return this; -	} -}; - -Tween.prototype.init.prototype = Tween.prototype; - -Tween.propHooks = { -	_default: { -		get: function( tween ) { -			var result; - -			// Use a property on the element directly when it is not a DOM element, -			// or when there is no matching style property that exists. -			if ( tween.elem.nodeType !== 1 || -				tween.elem[ tween.prop ] != null && tween.elem.style[ tween.prop ] == null ) { -				return tween.elem[ tween.prop ]; -			} - -			// Passing an empty string as a 3rd parameter to .css will automatically -			// attempt a parseFloat and fallback to a string if the parse fails. -			// Simple values such as "10px" are parsed to Float; -			// complex values such as "rotate(1rad)" are returned as-is. -			result = jQuery.css( tween.elem, tween.prop, "" ); - -			// Empty strings, null, undefined and "auto" are converted to 0. -			return !result || result === "auto" ? 0 : result; -		}, -		set: function( tween ) { - -			// Use step hook for back compat. -			// Use cssHook if its there. -			// Use .style if available and use plain properties where available. -			if ( jQuery.fx.step[ tween.prop ] ) { -				jQuery.fx.step[ tween.prop ]( tween ); -			} else if ( tween.elem.nodeType === 1 && ( -					jQuery.cssHooks[ tween.prop ] || -					tween.elem.style[ finalPropName( tween.prop ) ] != null ) ) { -				jQuery.style( tween.elem, tween.prop, tween.now + tween.unit ); -			} else { -				tween.elem[ tween.prop ] = tween.now; -			} -		} -	} -}; - -// Support: IE <=9 only -// Panic based approach to setting things on disconnected nodes -Tween.propHooks.scrollTop = Tween.propHooks.scrollLeft = { -	set: function( tween ) { -		if ( tween.elem.nodeType && tween.elem.parentNode ) { -			tween.elem[ tween.prop ] = tween.now; -		} -	} -}; - -jQuery.easing = { -	linear: function( p ) { -		return p; -	}, -	swing: function( p ) { -		return 0.5 - Math.cos( p * Math.PI ) / 2; -	}, -	_default: "swing" -}; - -jQuery.fx = Tween.prototype.init; - -// Back compat <1.8 extension point -jQuery.fx.step = {}; - - - - -var -	fxNow, inProgress, -	rfxtypes = /^(?:toggle|show|hide)$/, -	rrun = /queueHooks$/; - -function schedule() { -	if ( inProgress ) { -		if ( document.hidden === false && window.requestAnimationFrame ) { -			window.requestAnimationFrame( schedule ); -		} else { -			window.setTimeout( schedule, jQuery.fx.interval ); -		} - -		jQuery.fx.tick(); -	} -} - -// Animations created synchronously will run synchronously -function createFxNow() { -	window.setTimeout( function() { -		fxNow = undefined; -	} ); -	return ( fxNow = Date.now() ); -} - -// Generate parameters to create a standard animation -function genFx( type, includeWidth ) { -	var which, -		i = 0, -		attrs = { height: type }; - -	// If we include width, step value is 1 to do all cssExpand values, -	// otherwise step value is 2 to skip over Left and Right -	includeWidth = includeWidth ? 1 : 0; -	for ( ; i < 4; i += 2 - includeWidth ) { -		which = cssExpand[ i ]; -		attrs[ "margin" + which ] = attrs[ "padding" + which ] = type; -	} - -	if ( includeWidth ) { -		attrs.opacity = attrs.width = type; -	} - -	return attrs; -} - -function createTween( value, prop, animation ) { -	var tween, -		collection = ( Animation.tweeners[ prop ] || [] ).concat( Animation.tweeners[ "*" ] ), -		index = 0, -		length = collection.length; -	for ( ; index < length; index++ ) { -		if ( ( tween = collection[ index ].call( animation, prop, value ) ) ) { - -			// We're done with this property -			return tween; -		} -	} -} - -function defaultPrefilter( elem, props, opts ) { -	var prop, value, toggle, hooks, oldfire, propTween, restoreDisplay, display, -		isBox = "width" in props || "height" in props, -		anim = this, -		orig = {}, -		style = elem.style, -		hidden = elem.nodeType && isHiddenWithinTree( elem ), -		dataShow = dataPriv.get( elem, "fxshow" ); - -	// Queue-skipping animations hijack the fx hooks -	if ( !opts.queue ) { -		hooks = jQuery._queueHooks( elem, "fx" ); -		if ( hooks.unqueued == null ) { -			hooks.unqueued = 0; -			oldfire = hooks.empty.fire; -			hooks.empty.fire = function() { -				if ( !hooks.unqueued ) { -					oldfire(); -				} -			}; -		} -		hooks.unqueued++; - -		anim.always( function() { - -			// Ensure the complete handler is called before this completes -			anim.always( function() { -				hooks.unqueued--; -				if ( !jQuery.queue( elem, "fx" ).length ) { -					hooks.empty.fire(); -				} -			} ); -		} ); -	} - -	// Detect show/hide animations -	for ( prop in props ) { -		value = props[ prop ]; -		if ( rfxtypes.test( value ) ) { -			delete props[ prop ]; -			toggle = toggle || value === "toggle"; -			if ( value === ( hidden ? "hide" : "show" ) ) { - -				// Pretend to be hidden if this is a "show" and -				// there is still data from a stopped show/hide -				if ( value === "show" && dataShow && dataShow[ prop ] !== undefined ) { -					hidden = true; - -				// Ignore all other no-op show/hide data -				} else { -					continue; -				} -			} -			orig[ prop ] = dataShow && dataShow[ prop ] || jQuery.style( elem, prop ); -		} -	} - -	// Bail out if this is a no-op like .hide().hide() -	propTween = !jQuery.isEmptyObject( props ); -	if ( !propTween && jQuery.isEmptyObject( orig ) ) { -		return; -	} - -	// Restrict "overflow" and "display" styles during box animations -	if ( isBox && elem.nodeType === 1 ) { - -		// Support: IE <=9 - 11, Edge 12 - 15 -		// Record all 3 overflow attributes because IE does not infer the shorthand -		// from identically-valued overflowX and overflowY and Edge just mirrors -		// the overflowX value there. -		opts.overflow = [ style.overflow, style.overflowX, style.overflowY ]; - -		// Identify a display type, preferring old show/hide data over the CSS cascade -		restoreDisplay = dataShow && dataShow.display; -		if ( restoreDisplay == null ) { -			restoreDisplay = dataPriv.get( elem, "display" ); -		} -		display = jQuery.css( elem, "display" ); -		if ( display === "none" ) { -			if ( restoreDisplay ) { -				display = restoreDisplay; -			} else { - -				// Get nonempty value(s) by temporarily forcing visibility -				showHide( [ elem ], true ); -				restoreDisplay = elem.style.display || restoreDisplay; -				display = jQuery.css( elem, "display" ); -				showHide( [ elem ] ); -			} -		} - -		// Animate inline elements as inline-block -		if ( display === "inline" || display === "inline-block" && restoreDisplay != null ) { -			if ( jQuery.css( elem, "float" ) === "none" ) { - -				// Restore the original display value at the end of pure show/hide animations -				if ( !propTween ) { -					anim.done( function() { -						style.display = restoreDisplay; -					} ); -					if ( restoreDisplay == null ) { -						display = style.display; -						restoreDisplay = display === "none" ? "" : display; -					} -				} -				style.display = "inline-block"; -			} -		} -	} - -	if ( opts.overflow ) { -		style.overflow = "hidden"; -		anim.always( function() { -			style.overflow = opts.overflow[ 0 ]; -			style.overflowX = opts.overflow[ 1 ]; -			style.overflowY = opts.overflow[ 2 ]; -		} ); -	} - -	// Implement show/hide animations -	propTween = false; -	for ( prop in orig ) { - -		// General show/hide setup for this element animation -		if ( !propTween ) { -			if ( dataShow ) { -				if ( "hidden" in dataShow ) { -					hidden = dataShow.hidden; -				} -			} else { -				dataShow = dataPriv.access( elem, "fxshow", { display: restoreDisplay } ); -			} - -			// Store hidden/visible for toggle so `.stop().toggle()` "reverses" -			if ( toggle ) { -				dataShow.hidden = !hidden; -			} - -			// Show elements before animating them -			if ( hidden ) { -				showHide( [ elem ], true ); -			} - -			/* eslint-disable no-loop-func */ - -			anim.done( function() { - -			/* eslint-enable no-loop-func */ - -				// The final step of a "hide" animation is actually hiding the element -				if ( !hidden ) { -					showHide( [ elem ] ); -				} -				dataPriv.remove( elem, "fxshow" ); -				for ( prop in orig ) { -					jQuery.style( elem, prop, orig[ prop ] ); -				} -			} ); -		} - -		// Per-property setup -		propTween = createTween( hidden ? dataShow[ prop ] : 0, prop, anim ); -		if ( !( prop in dataShow ) ) { -			dataShow[ prop ] = propTween.start; -			if ( hidden ) { -				propTween.end = propTween.start; -				propTween.start = 0; -			} -		} -	} -} - -function propFilter( props, specialEasing ) { -	var index, name, easing, value, hooks; - -	// camelCase, specialEasing and expand cssHook pass -	for ( index in props ) { -		name = camelCase( index ); -		easing = specialEasing[ name ]; -		value = props[ index ]; -		if ( Array.isArray( value ) ) { -			easing = value[ 1 ]; -			value = props[ index ] = value[ 0 ]; -		} - -		if ( index !== name ) { -			props[ name ] = value; -			delete props[ index ]; -		} - -		hooks = jQuery.cssHooks[ name ]; -		if ( hooks && "expand" in hooks ) { -			value = hooks.expand( value ); -			delete props[ name ]; - -			// Not quite $.extend, this won't overwrite existing keys. -			// Reusing 'index' because we have the correct "name" -			for ( index in value ) { -				if ( !( index in props ) ) { -					props[ index ] = value[ index ]; -					specialEasing[ index ] = easing; -				} -			} -		} else { -			specialEasing[ name ] = easing; -		} -	} -} - -function Animation( elem, properties, options ) { -	var result, -		stopped, -		index = 0, -		length = Animation.prefilters.length, -		deferred = jQuery.Deferred().always( function() { - -			// Don't match elem in the :animated selector -			delete tick.elem; -		} ), -		tick = function() { -			if ( stopped ) { -				return false; -			} -			var currentTime = fxNow || createFxNow(), -				remaining = Math.max( 0, animation.startTime + animation.duration - currentTime ), - -				// Support: Android 2.3 only -				// Archaic crash bug won't allow us to use `1 - ( 0.5 || 0 )` (#12497) -				temp = remaining / animation.duration || 0, -				percent = 1 - temp, -				index = 0, -				length = animation.tweens.length; - -			for ( ; index < length; index++ ) { -				animation.tweens[ index ].run( percent ); -			} - -			deferred.notifyWith( elem, [ animation, percent, remaining ] ); - -			// If there's more to do, yield -			if ( percent < 1 && length ) { -				return remaining; -			} - -			// If this was an empty animation, synthesize a final progress notification -			if ( !length ) { -				deferred.notifyWith( elem, [ animation, 1, 0 ] ); -			} - -			// Resolve the animation and report its conclusion -			deferred.resolveWith( elem, [ animation ] ); -			return false; -		}, -		animation = deferred.promise( { -			elem: elem, -			props: jQuery.extend( {}, properties ), -			opts: jQuery.extend( true, { -				specialEasing: {}, -				easing: jQuery.easing._default -			}, options ), -			originalProperties: properties, -			originalOptions: options, -			startTime: fxNow || createFxNow(), -			duration: options.duration, -			tweens: [], -			createTween: function( prop, end ) { -				var tween = jQuery.Tween( elem, animation.opts, prop, end, -						animation.opts.specialEasing[ prop ] || animation.opts.easing ); -				animation.tweens.push( tween ); -				return tween; -			}, -			stop: function( gotoEnd ) { -				var index = 0, - -					// If we are going to the end, we want to run all the tweens -					// otherwise we skip this part -					length = gotoEnd ? animation.tweens.length : 0; -				if ( stopped ) { -					return this; -				} -				stopped = true; -				for ( ; index < length; index++ ) { -					animation.tweens[ index ].run( 1 ); -				} - -				// Resolve when we played the last frame; otherwise, reject -				if ( gotoEnd ) { -					deferred.notifyWith( elem, [ animation, 1, 0 ] ); -					deferred.resolveWith( elem, [ animation, gotoEnd ] ); -				} else { -					deferred.rejectWith( elem, [ animation, gotoEnd ] ); -				} -				return this; -			} -		} ), -		props = animation.props; - -	propFilter( props, animation.opts.specialEasing ); - -	for ( ; index < length; index++ ) { -		result = Animation.prefilters[ index ].call( animation, elem, props, animation.opts ); -		if ( result ) { -			if ( isFunction( result.stop ) ) { -				jQuery._queueHooks( animation.elem, animation.opts.queue ).stop = -					result.stop.bind( result ); -			} -			return result; -		} -	} - -	jQuery.map( props, createTween, animation ); - -	if ( isFunction( animation.opts.start ) ) { -		animation.opts.start.call( elem, animation ); -	} - -	// Attach callbacks from options -	animation -		.progress( animation.opts.progress ) -		.done( animation.opts.done, animation.opts.complete ) -		.fail( animation.opts.fail ) -		.always( animation.opts.always ); - -	jQuery.fx.timer( -		jQuery.extend( tick, { -			elem: elem, -			anim: animation, -			queue: animation.opts.queue -		} ) -	); - -	return animation; -} - -jQuery.Animation = jQuery.extend( Animation, { - -	tweeners: { -		"*": [ function( prop, value ) { -			var tween = this.createTween( prop, value ); -			adjustCSS( tween.elem, prop, rcssNum.exec( value ), tween ); -			return tween; -		} ] -	}, - -	tweener: function( props, callback ) { -		if ( isFunction( props ) ) { -			callback = props; -			props = [ "*" ]; -		} else { -			props = props.match( rnothtmlwhite ); -		} - -		var prop, -			index = 0, -			length = props.length; - -		for ( ; index < length; index++ ) { -			prop = props[ index ]; -			Animation.tweeners[ prop ] = Animation.tweeners[ prop ] || []; -			Animation.tweeners[ prop ].unshift( callback ); -		} -	}, - -	prefilters: [ defaultPrefilter ], - -	prefilter: function( callback, prepend ) { -		if ( prepend ) { -			Animation.prefilters.unshift( callback ); -		} else { -			Animation.prefilters.push( callback ); -		} -	} -} ); - -jQuery.speed = function( speed, easing, fn ) { -	var opt = speed && typeof speed === "object" ? jQuery.extend( {}, speed ) : { -		complete: fn || !fn && easing || -			isFunction( speed ) && speed, -		duration: speed, -		easing: fn && easing || easing && !isFunction( easing ) && easing -	}; - -	// Go to the end state if fx are off -	if ( jQuery.fx.off ) { -		opt.duration = 0; - -	} else { -		if ( typeof opt.duration !== "number" ) { -			if ( opt.duration in jQuery.fx.speeds ) { -				opt.duration = jQuery.fx.speeds[ opt.duration ]; - -			} else { -				opt.duration = jQuery.fx.speeds._default; -			} -		} -	} - -	// Normalize opt.queue - true/undefined/null -> "fx" -	if ( opt.queue == null || opt.queue === true ) { -		opt.queue = "fx"; -	} - -	// Queueing -	opt.old = opt.complete; - -	opt.complete = function() { -		if ( isFunction( opt.old ) ) { -			opt.old.call( this ); -		} - -		if ( opt.queue ) { -			jQuery.dequeue( this, opt.queue ); -		} -	}; - -	return opt; -}; - -jQuery.fn.extend( { -	fadeTo: function( speed, to, easing, callback ) { - -		// Show any hidden elements after setting opacity to 0 -		return this.filter( isHiddenWithinTree ).css( "opacity", 0 ).show() - -			// Animate to the value specified -			.end().animate( { opacity: to }, speed, easing, callback ); -	}, -	animate: function( prop, speed, easing, callback ) { -		var empty = jQuery.isEmptyObject( prop ), -			optall = jQuery.speed( speed, easing, callback ), -			doAnimation = function() { - -				// Operate on a copy of prop so per-property easing won't be lost -				var anim = Animation( this, jQuery.extend( {}, prop ), optall ); - -				// Empty animations, or finishing resolves immediately -				if ( empty || dataPriv.get( this, "finish" ) ) { -					anim.stop( true ); -				} -			}; -			doAnimation.finish = doAnimation; - -		return empty || optall.queue === false ? -			this.each( doAnimation ) : -			this.queue( optall.queue, doAnimation ); -	}, -	stop: function( type, clearQueue, gotoEnd ) { -		var stopQueue = function( hooks ) { -			var stop = hooks.stop; -			delete hooks.stop; -			stop( gotoEnd ); -		}; - -		if ( typeof type !== "string" ) { -			gotoEnd = clearQueue; -			clearQueue = type; -			type = undefined; -		} -		if ( clearQueue ) { -			this.queue( type || "fx", [] ); -		} - -		return this.each( function() { -			var dequeue = true, -				index = type != null && type + "queueHooks", -				timers = jQuery.timers, -				data = dataPriv.get( this ); - -			if ( index ) { -				if ( data[ index ] && data[ index ].stop ) { -					stopQueue( data[ index ] ); -				} -			} else { -				for ( index in data ) { -					if ( data[ index ] && data[ index ].stop && rrun.test( index ) ) { -						stopQueue( data[ index ] ); -					} -				} -			} - -			for ( index = timers.length; index--; ) { -				if ( timers[ index ].elem === this && -					( type == null || timers[ index ].queue === type ) ) { - -					timers[ index ].anim.stop( gotoEnd ); -					dequeue = false; -					timers.splice( index, 1 ); -				} -			} - -			// Start the next in the queue if the last step wasn't forced. -			// Timers currently will call their complete callbacks, which -			// will dequeue but only if they were gotoEnd. -			if ( dequeue || !gotoEnd ) { -				jQuery.dequeue( this, type ); -			} -		} ); -	}, -	finish: function( type ) { -		if ( type !== false ) { -			type = type || "fx"; -		} -		return this.each( function() { -			var index, -				data = dataPriv.get( this ), -				queue = data[ type + "queue" ], -				hooks = data[ type + "queueHooks" ], -				timers = jQuery.timers, -				length = queue ? queue.length : 0; - -			// Enable finishing flag on private data -			data.finish = true; - -			// Empty the queue first -			jQuery.queue( this, type, [] ); - -			if ( hooks && hooks.stop ) { -				hooks.stop.call( this, true ); -			} - -			// Look for any active animations, and finish them -			for ( index = timers.length; index--; ) { -				if ( timers[ index ].elem === this && timers[ index ].queue === type ) { -					timers[ index ].anim.stop( true ); -					timers.splice( index, 1 ); -				} -			} - -			// Look for any animations in the old queue and finish them -			for ( index = 0; index < length; index++ ) { -				if ( queue[ index ] && queue[ index ].finish ) { -					queue[ index ].finish.call( this ); -				} -			} - -			// Turn off finishing flag -			delete data.finish; -		} ); -	} -} ); - -jQuery.each( [ "toggle", "show", "hide" ], function( _i, name ) { -	var cssFn = jQuery.fn[ name ]; -	jQuery.fn[ name ] = function( speed, easing, callback ) { -		return speed == null || typeof speed === "boolean" ? -			cssFn.apply( this, arguments ) : -			this.animate( genFx( name, true ), speed, easing, callback ); -	}; -} ); - -// Generate shortcuts for custom animations -jQuery.each( { -	slideDown: genFx( "show" ), -	slideUp: genFx( "hide" ), -	slideToggle: genFx( "toggle" ), -	fadeIn: { opacity: "show" }, -	fadeOut: { opacity: "hide" }, -	fadeToggle: { opacity: "toggle" } -}, function( name, props ) { -	jQuery.fn[ name ] = function( speed, easing, callback ) { -		return this.animate( props, speed, easing, callback ); -	}; -} ); - -jQuery.timers = []; -jQuery.fx.tick = function() { -	var timer, -		i = 0, -		timers = jQuery.timers; - -	fxNow = Date.now(); - -	for ( ; i < timers.length; i++ ) { -		timer = timers[ i ]; - -		// Run the timer and safely remove it when done (allowing for external removal) -		if ( !timer() && timers[ i ] === timer ) { -			timers.splice( i--, 1 ); -		} -	} - -	if ( !timers.length ) { -		jQuery.fx.stop(); -	} -	fxNow = undefined; -}; - -jQuery.fx.timer = function( timer ) { -	jQuery.timers.push( timer ); -	jQuery.fx.start(); -}; - -jQuery.fx.interval = 13; -jQuery.fx.start = function() { -	if ( inProgress ) { -		return; -	} - -	inProgress = true; -	schedule(); -}; - -jQuery.fx.stop = function() { -	inProgress = null; -}; - -jQuery.fx.speeds = { -	slow: 600, -	fast: 200, - -	// Default speed -	_default: 400 -}; - - -// Based off of the plugin by Clint Helfers, with permission. -// https://web.archive.org/web/20100324014747/http://blindsignals.com/index.php/2009/07/jquery-delay/ -jQuery.fn.delay = function( time, type ) { -	time = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time; -	type = type || "fx"; - -	return this.queue( type, function( next, hooks ) { -		var timeout = window.setTimeout( next, time ); -		hooks.stop = function() { -			window.clearTimeout( timeout ); -		}; -	} ); -}; - - -( function() { -	var input = document.createElement( "input" ), -		select = document.createElement( "select" ), -		opt = select.appendChild( document.createElement( "option" ) ); - -	input.type = "checkbox"; - -	// Support: Android <=4.3 only -	// Default value for a checkbox should be "on" -	support.checkOn = input.value !== ""; - -	// Support: IE <=11 only -	// Must access selectedIndex to make default options select -	support.optSelected = opt.selected; - -	// Support: IE <=11 only -	// An input loses its value after becoming a radio -	input = document.createElement( "input" ); -	input.value = "t"; -	input.type = "radio"; -	support.radioValue = input.value === "t"; -} )(); - - -var boolHook, -	attrHandle = jQuery.expr.attrHandle; - -jQuery.fn.extend( { -	attr: function( name, value ) { -		return access( this, jQuery.attr, name, value, arguments.length > 1 ); -	}, - -	removeAttr: function( name ) { -		return this.each( function() { -			jQuery.removeAttr( this, name ); -		} ); -	} -} ); - -jQuery.extend( { -	attr: function( elem, name, value ) { -		var ret, hooks, -			nType = elem.nodeType; - -		// Don't get/set attributes on text, comment and attribute nodes -		if ( nType === 3 || nType === 8 || nType === 2 ) { -			return; -		} - -		// Fallback to prop when attributes are not supported -		if ( typeof elem.getAttribute === "undefined" ) { -			return jQuery.prop( elem, name, value ); -		} - -		// Attribute hooks are determined by the lowercase version -		// Grab necessary hook if one is defined -		if ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) { -			hooks = jQuery.attrHooks[ name.toLowerCase() ] || -				( jQuery.expr.match.bool.test( name ) ? boolHook : undefined ); -		} - -		if ( value !== undefined ) { -			if ( value === null ) { -				jQuery.removeAttr( elem, name ); -				return; -			} - -			if ( hooks && "set" in hooks && -				( ret = hooks.set( elem, value, name ) ) !== undefined ) { -				return ret; -			} - -			elem.setAttribute( name, value + "" ); -			return value; -		} - -		if ( hooks && "get" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) { -			return ret; -		} - -		ret = jQuery.find.attr( elem, name ); - -		// Non-existent attributes return null, we normalize to undefined -		return ret == null ? undefined : ret; -	}, - -	attrHooks: { -		type: { -			set: function( elem, value ) { -				if ( !support.radioValue && value === "radio" && -					nodeName( elem, "input" ) ) { -					var val = elem.value; -					elem.setAttribute( "type", value ); -					if ( val ) { -						elem.value = val; -					} -					return value; -				} -			} -		} -	}, - -	removeAttr: function( elem, value ) { -		var name, -			i = 0, - -			// Attribute names can contain non-HTML whitespace characters -			// https://html.spec.whatwg.org/multipage/syntax.html#attributes-2 -			attrNames = value && value.match( rnothtmlwhite ); - -		if ( attrNames && elem.nodeType === 1 ) { -			while ( ( name = attrNames[ i++ ] ) ) { -				elem.removeAttribute( name ); -			} -		} -	} -} ); - -// Hooks for boolean attributes -boolHook = { -	set: function( elem, value, name ) { -		if ( value === false ) { - -			// Remove boolean attributes when set to false -			jQuery.removeAttr( elem, name ); -		} else { -			elem.setAttribute( name, name ); -		} -		return name; -	} -}; - -jQuery.each( jQuery.expr.match.bool.source.match( /\w+/g ), function( _i, name ) { -	var getter = attrHandle[ name ] || jQuery.find.attr; - -	attrHandle[ name ] = function( elem, name, isXML ) { -		var ret, handle, -			lowercaseName = name.toLowerCase(); - -		if ( !isXML ) { - -			// Avoid an infinite loop by temporarily removing this function from the getter -			handle = attrHandle[ lowercaseName ]; -			attrHandle[ lowercaseName ] = ret; -			ret = getter( elem, name, isXML ) != null ? -				lowercaseName : -				null; -			attrHandle[ lowercaseName ] = handle; -		} -		return ret; -	}; -} ); - - - - -var rfocusable = /^(?:input|select|textarea|button)$/i, -	rclickable = /^(?:a|area)$/i; - -jQuery.fn.extend( { -	prop: function( name, value ) { -		return access( this, jQuery.prop, name, value, arguments.length > 1 ); -	}, - -	removeProp: function( name ) { -		return this.each( function() { -			delete this[ jQuery.propFix[ name ] || name ]; -		} ); -	} -} ); - -jQuery.extend( { -	prop: function( elem, name, value ) { -		var ret, hooks, -			nType = elem.nodeType; - -		// Don't get/set properties on text, comment and attribute nodes -		if ( nType === 3 || nType === 8 || nType === 2 ) { -			return; -		} - -		if ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) { - -			// Fix name and attach hooks -			name = jQuery.propFix[ name ] || name; -			hooks = jQuery.propHooks[ name ]; -		} - -		if ( value !== undefined ) { -			if ( hooks && "set" in hooks && -				( ret = hooks.set( elem, value, name ) ) !== undefined ) { -				return ret; -			} - -			return ( elem[ name ] = value ); -		} - -		if ( hooks && "get" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) { -			return ret; -		} - -		return elem[ name ]; -	}, - -	propHooks: { -		tabIndex: { -			get: function( elem ) { - -				// Support: IE <=9 - 11 only -				// elem.tabIndex doesn't always return the -				// correct value when it hasn't been explicitly set -				// https://web.archive.org/web/20141116233347/http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/ -				// Use proper attribute retrieval(#12072) -				var tabindex = jQuery.find.attr( elem, "tabindex" ); - -				if ( tabindex ) { -					return parseInt( tabindex, 10 ); -				} - -				if ( -					rfocusable.test( elem.nodeName ) || -					rclickable.test( elem.nodeName ) && -					elem.href -				) { -					return 0; -				} - -				return -1; -			} -		} -	}, - -	propFix: { -		"for": "htmlFor", -		"class": "className" -	} -} ); - -// Support: IE <=11 only -// Accessing the selectedIndex property -// forces the browser to respect setting selected -// on the option -// The getter ensures a default option is selected -// when in an optgroup -// eslint rule "no-unused-expressions" is disabled for this code -// since it considers such accessions noop -if ( !support.optSelected ) { -	jQuery.propHooks.selected = { -		get: function( elem ) { - -			/* eslint no-unused-expressions: "off" */ - -			var parent = elem.parentNode; -			if ( parent && parent.parentNode ) { -				parent.parentNode.selectedIndex; -			} -			return null; -		}, -		set: function( elem ) { - -			/* eslint no-unused-expressions: "off" */ - -			var parent = elem.parentNode; -			if ( parent ) { -				parent.selectedIndex; - -				if ( parent.parentNode ) { -					parent.parentNode.selectedIndex; -				} -			} -		} -	}; -} - -jQuery.each( [ -	"tabIndex", -	"readOnly", -	"maxLength", -	"cellSpacing", -	"cellPadding", -	"rowSpan", -	"colSpan", -	"useMap", -	"frameBorder", -	"contentEditable" -], function() { -	jQuery.propFix[ this.toLowerCase() ] = this; -} ); - - - - -	// Strip and collapse whitespace according to HTML spec -	// https://infra.spec.whatwg.org/#strip-and-collapse-ascii-whitespace -	function stripAndCollapse( value ) { -		var tokens = value.match( rnothtmlwhite ) || []; -		return tokens.join( " " ); -	} - - -function getClass( elem ) { -	return elem.getAttribute && elem.getAttribute( "class" ) || ""; -} - -function classesToArray( value ) { -	if ( Array.isArray( value ) ) { -		return value; -	} -	if ( typeof value === "string" ) { -		return value.match( rnothtmlwhite ) || []; -	} -	return []; -} - -jQuery.fn.extend( { -	addClass: function( value ) { -		var classes, elem, cur, curValue, clazz, j, finalValue, -			i = 0; - -		if ( isFunction( value ) ) { -			return this.each( function( j ) { -				jQuery( this ).addClass( value.call( this, j, getClass( this ) ) ); -			} ); -		} - -		classes = classesToArray( value ); - -		if ( classes.length ) { -			while ( ( elem = this[ i++ ] ) ) { -				curValue = getClass( elem ); -				cur = elem.nodeType === 1 && ( " " + stripAndCollapse( curValue ) + " " ); - -				if ( cur ) { -					j = 0; -					while ( ( clazz = classes[ j++ ] ) ) { -						if ( cur.indexOf( " " + clazz + " " ) < 0 ) { -							cur += clazz + " "; -						} -					} - -					// Only assign if different to avoid unneeded rendering. -					finalValue = stripAndCollapse( cur ); -					if ( curValue !== finalValue ) { -						elem.setAttribute( "class", finalValue ); -					} -				} -			} -		} - -		return this; -	}, - -	removeClass: function( value ) { -		var classes, elem, cur, curValue, clazz, j, finalValue, -			i = 0; - -		if ( isFunction( value ) ) { -			return this.each( function( j ) { -				jQuery( this ).removeClass( value.call( this, j, getClass( this ) ) ); -			} ); -		} - -		if ( !arguments.length ) { -			return this.attr( "class", "" ); -		} - -		classes = classesToArray( value ); - -		if ( classes.length ) { -			while ( ( elem = this[ i++ ] ) ) { -				curValue = getClass( elem ); - -				// This expression is here for better compressibility (see addClass) -				cur = elem.nodeType === 1 && ( " " + stripAndCollapse( curValue ) + " " ); - -				if ( cur ) { -					j = 0; -					while ( ( clazz = classes[ j++ ] ) ) { - -						// Remove *all* instances -						while ( cur.indexOf( " " + clazz + " " ) > -1 ) { -							cur = cur.replace( " " + clazz + " ", " " ); -						} -					} - -					// Only assign if different to avoid unneeded rendering. -					finalValue = stripAndCollapse( cur ); -					if ( curValue !== finalValue ) { -						elem.setAttribute( "class", finalValue ); -					} -				} -			} -		} - -		return this; -	}, - -	toggleClass: function( value, stateVal ) { -		var type = typeof value, -			isValidValue = type === "string" || Array.isArray( value ); - -		if ( typeof stateVal === "boolean" && isValidValue ) { -			return stateVal ? this.addClass( value ) : this.removeClass( value ); -		} - -		if ( isFunction( value ) ) { -			return this.each( function( i ) { -				jQuery( this ).toggleClass( -					value.call( this, i, getClass( this ), stateVal ), -					stateVal -				); -			} ); -		} - -		return this.each( function() { -			var className, i, self, classNames; - -			if ( isValidValue ) { - -				// Toggle individual class names -				i = 0; -				self = jQuery( this ); -				classNames = classesToArray( value ); - -				while ( ( className = classNames[ i++ ] ) ) { - -					// Check each className given, space separated list -					if ( self.hasClass( className ) ) { -						self.removeClass( className ); -					} else { -						self.addClass( className ); -					} -				} - -			// Toggle whole class name -			} else if ( value === undefined || type === "boolean" ) { -				className = getClass( this ); -				if ( className ) { - -					// Store className if set -					dataPriv.set( this, "__className__", className ); -				} - -				// If the element has a class name or if we're passed `false`, -				// then remove the whole classname (if there was one, the above saved it). -				// Otherwise bring back whatever was previously saved (if anything), -				// falling back to the empty string if nothing was stored. -				if ( this.setAttribute ) { -					this.setAttribute( "class", -						className || value === false ? -						"" : -						dataPriv.get( this, "__className__" ) || "" -					); -				} -			} -		} ); -	}, - -	hasClass: function( selector ) { -		var className, elem, -			i = 0; - -		className = " " + selector + " "; -		while ( ( elem = this[ i++ ] ) ) { -			if ( elem.nodeType === 1 && -				( " " + stripAndCollapse( getClass( elem ) ) + " " ).indexOf( className ) > -1 ) { -					return true; -			} -		} - -		return false; -	} -} ); - - - - -var rreturn = /\r/g; - -jQuery.fn.extend( { -	val: function( value ) { -		var hooks, ret, valueIsFunction, -			elem = this[ 0 ]; - -		if ( !arguments.length ) { -			if ( elem ) { -				hooks = jQuery.valHooks[ elem.type ] || -					jQuery.valHooks[ elem.nodeName.toLowerCase() ]; - -				if ( hooks && -					"get" in hooks && -					( ret = hooks.get( elem, "value" ) ) !== undefined -				) { -					return ret; -				} - -				ret = elem.value; - -				// Handle most common string cases -				if ( typeof ret === "string" ) { -					return ret.replace( rreturn, "" ); -				} - -				// Handle cases where value is null/undef or number -				return ret == null ? "" : ret; -			} - -			return; -		} - -		valueIsFunction = isFunction( value ); - -		return this.each( function( i ) { -			var val; - -			if ( this.nodeType !== 1 ) { -				return; -			} - -			if ( valueIsFunction ) { -				val = value.call( this, i, jQuery( this ).val() ); -			} else { -				val = value; -			} - -			// Treat null/undefined as ""; convert numbers to string -			if ( val == null ) { -				val = ""; - -			} else if ( typeof val === "number" ) { -				val += ""; - -			} else if ( Array.isArray( val ) ) { -				val = jQuery.map( val, function( value ) { -					return value == null ? "" : value + ""; -				} ); -			} - -			hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ]; - -			// If set returns undefined, fall back to normal setting -			if ( !hooks || !( "set" in hooks ) || hooks.set( this, val, "value" ) === undefined ) { -				this.value = val; -			} -		} ); -	} -} ); - -jQuery.extend( { -	valHooks: { -		option: { -			get: function( elem ) { - -				var val = jQuery.find.attr( elem, "value" ); -				return val != null ? -					val : - -					// Support: IE <=10 - 11 only -					// option.text throws exceptions (#14686, #14858) -					// Strip and collapse whitespace -					// https://html.spec.whatwg.org/#strip-and-collapse-whitespace -					stripAndCollapse( jQuery.text( elem ) ); -			} -		}, -		select: { -			get: function( elem ) { -				var value, option, i, -					options = elem.options, -					index = elem.selectedIndex, -					one = elem.type === "select-one", -					values = one ? null : [], -					max = one ? index + 1 : options.length; - -				if ( index < 0 ) { -					i = max; - -				} else { -					i = one ? index : 0; -				} - -				// Loop through all the selected options -				for ( ; i < max; i++ ) { -					option = options[ i ]; - -					// Support: IE <=9 only -					// IE8-9 doesn't update selected after form reset (#2551) -					if ( ( option.selected || i === index ) && - -							// Don't return options that are disabled or in a disabled optgroup -							!option.disabled && -							( !option.parentNode.disabled || -								!nodeName( option.parentNode, "optgroup" ) ) ) { - -						// Get the specific value for the option -						value = jQuery( option ).val(); - -						// We don't need an array for one selects -						if ( one ) { -							return value; -						} - -						// Multi-Selects return an array -						values.push( value ); -					} -				} - -				return values; -			}, - -			set: function( elem, value ) { -				var optionSet, option, -					options = elem.options, -					values = jQuery.makeArray( value ), -					i = options.length; - -				while ( i-- ) { -					option = options[ i ]; - -					/* eslint-disable no-cond-assign */ - -					if ( option.selected = -						jQuery.inArray( jQuery.valHooks.option.get( option ), values ) > -1 -					) { -						optionSet = true; -					} - -					/* eslint-enable no-cond-assign */ -				} - -				// Force browsers to behave consistently when non-matching value is set -				if ( !optionSet ) { -					elem.selectedIndex = -1; -				} -				return values; -			} -		} -	} -} ); - -// Radios and checkboxes getter/setter -jQuery.each( [ "radio", "checkbox" ], function() { -	jQuery.valHooks[ this ] = { -		set: function( elem, value ) { -			if ( Array.isArray( value ) ) { -				return ( elem.checked = jQuery.inArray( jQuery( elem ).val(), value ) > -1 ); -			} -		} -	}; -	if ( !support.checkOn ) { -		jQuery.valHooks[ this ].get = function( elem ) { -			return elem.getAttribute( "value" ) === null ? "on" : elem.value; -		}; -	} -} ); - - - - -// Return jQuery for attributes-only inclusion - - -support.focusin = "onfocusin" in window; - - -var rfocusMorph = /^(?:focusinfocus|focusoutblur)$/, -	stopPropagationCallback = function( e ) { -		e.stopPropagation(); -	}; - -jQuery.extend( jQuery.event, { - -	trigger: function( event, data, elem, onlyHandlers ) { - -		var i, cur, tmp, bubbleType, ontype, handle, special, lastElement, -			eventPath = [ elem || document ], -			type = hasOwn.call( event, "type" ) ? event.type : event, -			namespaces = hasOwn.call( event, "namespace" ) ? event.namespace.split( "." ) : []; - -		cur = lastElement = 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( "." ) > -1 ) { - -			// 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.rnamespace = 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 && !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() ) { -			lastElement = cur; -			event.type = i > 1 ? -				bubbleType : -				special.bindType || type; - -			// jQuery handler -			handle = ( -					dataPriv.get( cur, "events" ) || Object.create( null ) -				)[ event.type ] && -				dataPriv.get( cur, "handle" ); -			if ( handle ) { -				handle.apply( cur, data ); -			} - -			// Native handler -			handle = ontype && cur[ ontype ]; -			if ( handle && handle.apply && 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 ) && -				acceptData( elem ) ) { - -				// Call a native DOM method on the target with the same name as the event. -				// Don't do default actions on window, that's where global variables be (#6170) -				if ( ontype && isFunction( elem[ type ] ) && !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; - -					if ( event.isPropagationStopped() ) { -						lastElement.addEventListener( type, stopPropagationCallback ); -					} - -					elem[ type ](); - -					if ( event.isPropagationStopped() ) { -						lastElement.removeEventListener( type, stopPropagationCallback ); -					} - -					jQuery.event.triggered = undefined; - -					if ( tmp ) { -						elem[ ontype ] = tmp; -					} -				} -			} -		} - -		return event.result; -	}, - -	// Piggyback on a donor event to simulate a different one -	// Used only for `focus(in | out)` events -	simulate: function( type, elem, event ) { -		var e = jQuery.extend( -			new jQuery.Event(), -			event, -			{ -				type: type, -				isSimulated: true -			} -		); - -		jQuery.event.trigger( e, null, elem ); -	} - -} ); - -jQuery.fn.extend( { - -	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 ); -		} -	} -} ); - - -// Support: Firefox <=44 -// Firefox doesn't have focus(in | out) events -// Related ticket - https://bugzilla.mozilla.org/show_bug.cgi?id=687787 -// -// Support: Chrome <=48 - 49, Safari <=9.0 - 9.1 -// focus(in | out) events fire after focus & blur events, -// which is spec violation - http://www.w3.org/TR/DOM-Level-3-Events/#events-focusevent-event-order -// Related ticket - https://bugs.chromium.org/p/chromium/issues/detail?id=449857 -if ( !support.focusin ) { -	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 ) ); -		}; - -		jQuery.event.special[ fix ] = { -			setup: function() { - -				// Handle: regular nodes (via `this.ownerDocument`), window -				// (via `this.document`) & document (via `this`). -				var doc = this.ownerDocument || this.document || this, -					attaches = dataPriv.access( doc, fix ); - -				if ( !attaches ) { -					doc.addEventListener( orig, handler, true ); -				} -				dataPriv.access( doc, fix, ( attaches || 0 ) + 1 ); -			}, -			teardown: function() { -				var doc = this.ownerDocument || this.document || this, -					attaches = dataPriv.access( doc, fix ) - 1; - -				if ( !attaches ) { -					doc.removeEventListener( orig, handler, true ); -					dataPriv.remove( doc, fix ); - -				} else { -					dataPriv.access( doc, fix, attaches ); -				} -			} -		}; -	} ); -} -var location = window.location; - -var nonce = { guid: Date.now() }; - -var rquery = ( /\?/ ); - - - -// Cross-browser xml parsing -jQuery.parseXML = function( data ) { -	var xml; -	if ( !data || typeof data !== "string" ) { -		return null; -	} - -	// Support: IE 9 - 11 only -	// IE throws on parseFromString with invalid input. -	try { -		xml = ( new window.DOMParser() ).parseFromString( data, "text/xml" ); -	} catch ( e ) { -		xml = undefined; -	} - -	if ( !xml || xml.getElementsByTagName( "parsererror" ).length ) { -		jQuery.error( "Invalid XML: " + data ); -	} -	return xml; -}; - - -var -	rbracket = /\[\]$/, -	rCRLF = /\r?\n/g, -	rsubmitterTypes = /^(?:submit|button|image|reset|file)$/i, -	rsubmittable = /^(?:input|select|textarea|keygen)/i; - -function buildParams( prefix, obj, traditional, add ) { -	var name; - -	if ( Array.isArray( obj ) ) { - -		// Serialize array item. -		jQuery.each( obj, function( i, v ) { -			if ( traditional || rbracket.test( prefix ) ) { - -				// Treat each array item as a scalar. -				add( prefix, v ); - -			} else { - -				// Item is non-scalar (array or object), encode its numeric index. -				buildParams( -					prefix + "[" + ( typeof v === "object" && v != null ? i : "" ) + "]", -					v, -					traditional, -					add -				); -			} -		} ); - -	} else if ( !traditional && toType( obj ) === "object" ) { - -		// Serialize object item. -		for ( name in obj ) { -			buildParams( prefix + "[" + name + "]", obj[ name ], traditional, add ); -		} - -	} else { - -		// Serialize scalar item. -		add( prefix, obj ); -	} -} - -// Serialize an array of form elements or a set of -// key/values into a query string -jQuery.param = function( a, traditional ) { -	var prefix, -		s = [], -		add = function( key, valueOrFunction ) { - -			// If value is a function, invoke it and use its return value -			var value = isFunction( valueOrFunction ) ? -				valueOrFunction() : -				valueOrFunction; - -			s[ s.length ] = encodeURIComponent( key ) + "=" + -				encodeURIComponent( value == null ? "" : value ); -		}; - -	if ( a == null ) { -		return ""; -	} - -	// If an array was passed in, assume that it is an array of form elements. -	if ( Array.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) { - -		// Serialize the form elements -		jQuery.each( a, function() { -			add( this.name, this.value ); -		} ); - -	} else { - -		// If traditional, encode the "old" way (the way 1.3.2 or older -		// did it), otherwise encode params recursively. -		for ( prefix in a ) { -			buildParams( prefix, a[ prefix ], traditional, add ); -		} -	} - -	// Return the resulting serialization -	return s.join( "&" ); -}; - -jQuery.fn.extend( { -	serialize: function() { -		return jQuery.param( this.serializeArray() ); -	}, -	serializeArray: function() { -		return this.map( function() { - -			// Can add propHook for "elements" to filter or add form elements -			var elements = jQuery.prop( this, "elements" ); -			return elements ? jQuery.makeArray( elements ) : this; -		} ) -		.filter( function() { -			var type = this.type; - -			// Use .is( ":disabled" ) so that fieldset[disabled] works -			return this.name && !jQuery( this ).is( ":disabled" ) && -				rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) && -				( this.checked || !rcheckableType.test( type ) ); -		} ) -		.map( function( _i, elem ) { -			var val = jQuery( this ).val(); - -			if ( val == null ) { -				return null; -			} - -			if ( Array.isArray( val ) ) { -				return jQuery.map( val, function( val ) { -					return { name: elem.name, value: val.replace( rCRLF, "\r\n" ) }; -				} ); -			} - -			return { name: elem.name, value: val.replace( rCRLF, "\r\n" ) }; -		} ).get(); -	} -} ); - - -var -	r20 = /%20/g, -	rhash = /#.*$/, -	rantiCache = /([?&])_=[^&]*/, -	rheaders = /^(.*?):[ \t]*([^\r\n]*)$/mg, - -	// #7653, #8125, #8152: local protocol detection -	rlocalProtocol = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/, -	rnoContent = /^(?:GET|HEAD)$/, -	rprotocol = /^\/\//, - -	/* Prefilters -	 * 1) They are useful to introduce custom dataTypes (see ajax/jsonp.js for an example) -	 * 2) These are called: -	 *    - BEFORE asking for a transport -	 *    - AFTER param serialization (s.data is a string if s.processData is true) -	 * 3) key is the dataType -	 * 4) the catchall symbol "*" can be used -	 * 5) execution will start with transport dataType and THEN continue down to "*" if needed -	 */ -	prefilters = {}, - -	/* Transports bindings -	 * 1) key is the dataType -	 * 2) the catchall symbol "*" can be used -	 * 3) selection will start with transport dataType and THEN go to "*" if needed -	 */ -	transports = {}, - -	// Avoid comment-prolog char sequence (#10098); must appease lint and evade compression -	allTypes = "*/".concat( "*" ), - -	// Anchor tag for parsing the document origin -	originAnchor = document.createElement( "a" ); -	originAnchor.href = location.href; - -// Base "constructor" for jQuery.ajaxPrefilter and jQuery.ajaxTransport -function addToPrefiltersOrTransports( structure ) { - -	// dataTypeExpression is optional and defaults to "*" -	return function( dataTypeExpression, func ) { - -		if ( typeof dataTypeExpression !== "string" ) { -			func = dataTypeExpression; -			dataTypeExpression = "*"; -		} - -		var dataType, -			i = 0, -			dataTypes = dataTypeExpression.toLowerCase().match( rnothtmlwhite ) || []; - -		if ( isFunction( func ) ) { - -			// For each dataType in the dataTypeExpression -			while ( ( dataType = dataTypes[ i++ ] ) ) { - -				// Prepend if requested -				if ( dataType[ 0 ] === "+" ) { -					dataType = dataType.slice( 1 ) || "*"; -					( structure[ dataType ] = structure[ dataType ] || [] ).unshift( func ); - -				// Otherwise append -				} else { -					( structure[ dataType ] = structure[ dataType ] || [] ).push( func ); -				} -			} -		} -	}; -} - -// Base inspection function for prefilters and transports -function inspectPrefiltersOrTransports( structure, options, originalOptions, jqXHR ) { - -	var inspected = {}, -		seekingTransport = ( structure === transports ); - -	function inspect( dataType ) { -		var selected; -		inspected[ dataType ] = true; -		jQuery.each( structure[ dataType ] || [], function( _, prefilterOrFactory ) { -			var dataTypeOrTransport = prefilterOrFactory( options, originalOptions, jqXHR ); -			if ( typeof dataTypeOrTransport === "string" && -				!seekingTransport && !inspected[ dataTypeOrTransport ] ) { - -				options.dataTypes.unshift( dataTypeOrTransport ); -				inspect( dataTypeOrTransport ); -				return false; -			} else if ( seekingTransport ) { -				return !( selected = dataTypeOrTransport ); -			} -		} ); -		return selected; -	} - -	return inspect( options.dataTypes[ 0 ] ) || !inspected[ "*" ] && inspect( "*" ); -} - -// A special extend for ajax options -// that takes "flat" options (not to be deep extended) -// Fixes #9887 -function ajaxExtend( target, src ) { -	var key, deep, -		flatOptions = jQuery.ajaxSettings.flatOptions || {}; - -	for ( key in src ) { -		if ( src[ key ] !== undefined ) { -			( flatOptions[ key ] ? target : ( deep || ( deep = {} ) ) )[ key ] = src[ key ]; -		} -	} -	if ( deep ) { -		jQuery.extend( true, target, deep ); -	} - -	return target; -} - -/* Handles responses to an ajax request: - * - finds the right dataType (mediates between content-type and expected dataType) - * - returns the corresponding response - */ -function ajaxHandleResponses( s, jqXHR, responses ) { - -	var ct, type, finalDataType, firstDataType, -		contents = s.contents, -		dataTypes = s.dataTypes; - -	// Remove auto dataType and get content-type in the process -	while ( dataTypes[ 0 ] === "*" ) { -		dataTypes.shift(); -		if ( ct === undefined ) { -			ct = s.mimeType || jqXHR.getResponseHeader( "Content-Type" ); -		} -	} - -	// Check if we're dealing with a known content-type -	if ( ct ) { -		for ( type in contents ) { -			if ( contents[ type ] && contents[ type ].test( ct ) ) { -				dataTypes.unshift( type ); -				break; -			} -		} -	} - -	// Check to see if we have a response for the expected dataType -	if ( dataTypes[ 0 ] in responses ) { -		finalDataType = dataTypes[ 0 ]; -	} else { - -		// Try convertible dataTypes -		for ( type in responses ) { -			if ( !dataTypes[ 0 ] || s.converters[ type + " " + dataTypes[ 0 ] ] ) { -				finalDataType = type; -				break; -			} -			if ( !firstDataType ) { -				firstDataType = type; -			} -		} - -		// Or just use first one -		finalDataType = finalDataType || firstDataType; -	} - -	// If we found a dataType -	// We add the dataType to the list if needed -	// and return the corresponding response -	if ( finalDataType ) { -		if ( finalDataType !== dataTypes[ 0 ] ) { -			dataTypes.unshift( finalDataType ); -		} -		return responses[ finalDataType ]; -	} -} - -/* Chain conversions given the request and the original response - * Also sets the responseXXX fields on the jqXHR instance - */ -function ajaxConvert( s, response, jqXHR, isSuccess ) { -	var conv2, current, conv, tmp, prev, -		converters = {}, - -		// Work with a copy of dataTypes in case we need to modify it for conversion -		dataTypes = s.dataTypes.slice(); - -	// Create converters map with lowercased keys -	if ( dataTypes[ 1 ] ) { -		for ( conv in s.converters ) { -			converters[ conv.toLowerCase() ] = s.converters[ conv ]; -		} -	} - -	current = dataTypes.shift(); - -	// Convert to each sequential dataType -	while ( current ) { - -		if ( s.responseFields[ current ] ) { -			jqXHR[ s.responseFields[ current ] ] = response; -		} - -		// Apply the dataFilter if provided -		if ( !prev && isSuccess && s.dataFilter ) { -			response = s.dataFilter( response, s.dataType ); -		} - -		prev = current; -		current = dataTypes.shift(); - -		if ( current ) { - -			// There's only work to do if current dataType is non-auto -			if ( current === "*" ) { - -				current = prev; - -			// Convert response if prev dataType is non-auto and differs from current -			} else if ( prev !== "*" && prev !== current ) { - -				// Seek a direct converter -				conv = converters[ prev + " " + current ] || converters[ "* " + current ]; - -				// If none found, seek a pair -				if ( !conv ) { -					for ( conv2 in converters ) { - -						// If conv2 outputs current -						tmp = conv2.split( " " ); -						if ( tmp[ 1 ] === current ) { - -							// If prev can be converted to accepted input -							conv = converters[ prev + " " + tmp[ 0 ] ] || -								converters[ "* " + tmp[ 0 ] ]; -							if ( conv ) { - -								// Condense equivalence converters -								if ( conv === true ) { -									conv = converters[ conv2 ]; - -								// Otherwise, insert the intermediate dataType -								} else if ( converters[ conv2 ] !== true ) { -									current = tmp[ 0 ]; -									dataTypes.unshift( tmp[ 1 ] ); -								} -								break; -							} -						} -					} -				} - -				// Apply converter (if not an equivalence) -				if ( conv !== true ) { - -					// Unless errors are allowed to bubble, catch and return them -					if ( conv && s.throws ) { -						response = conv( response ); -					} else { -						try { -							response = conv( response ); -						} catch ( e ) { -							return { -								state: "parsererror", -								error: conv ? e : "No conversion from " + prev + " to " + current -							}; -						} -					} -				} -			} -		} -	} - -	return { state: "success", data: response }; -} - -jQuery.extend( { - -	// Counter for holding the number of active queries -	active: 0, - -	// Last-Modified header cache for next request -	lastModified: {}, -	etag: {}, - -	ajaxSettings: { -		url: location.href, -		type: "GET", -		isLocal: rlocalProtocol.test( location.protocol ), -		global: true, -		processData: true, -		async: true, -		contentType: "application/x-www-form-urlencoded; charset=UTF-8", - -		/* -		timeout: 0, -		data: null, -		dataType: null, -		username: null, -		password: null, -		cache: null, -		throws: false, -		traditional: false, -		headers: {}, -		*/ - -		accepts: { -			"*": allTypes, -			text: "text/plain", -			html: "text/html", -			xml: "application/xml, text/xml", -			json: "application/json, text/javascript" -		}, - -		contents: { -			xml: /\bxml\b/, -			html: /\bhtml/, -			json: /\bjson\b/ -		}, - -		responseFields: { -			xml: "responseXML", -			text: "responseText", -			json: "responseJSON" -		}, - -		// Data converters -		// Keys separate source (or catchall "*") and destination types with a single space -		converters: { - -			// Convert anything to text -			"* text": String, - -			// Text to html (true = no transformation) -			"text html": true, - -			// Evaluate text as a json expression -			"text json": JSON.parse, - -			// Parse text as xml -			"text xml": jQuery.parseXML -		}, - -		// For options that shouldn't be deep extended: -		// you can add your own custom options here if -		// and when you create one that shouldn't be -		// deep extended (see ajaxExtend) -		flatOptions: { -			url: true, -			context: true -		} -	}, - -	// Creates a full fledged settings object into target -	// with both ajaxSettings and settings fields. -	// If target is omitted, writes into ajaxSettings. -	ajaxSetup: function( target, settings ) { -		return settings ? - -			// Building a settings object -			ajaxExtend( ajaxExtend( target, jQuery.ajaxSettings ), settings ) : - -			// Extending ajaxSettings -			ajaxExtend( jQuery.ajaxSettings, target ); -	}, - -	ajaxPrefilter: addToPrefiltersOrTransports( prefilters ), -	ajaxTransport: addToPrefiltersOrTransports( transports ), - -	// Main method -	ajax: function( url, options ) { - -		// If url is an object, simulate pre-1.5 signature -		if ( typeof url === "object" ) { -			options = url; -			url = undefined; -		} - -		// Force options to be an object -		options = options || {}; - -		var transport, - -			// URL without anti-cache param -			cacheURL, - -			// Response headers -			responseHeadersString, -			responseHeaders, - -			// timeout handle -			timeoutTimer, - -			// Url cleanup var -			urlAnchor, - -			// Request state (becomes false upon send and true upon completion) -			completed, - -			// To know if global events are to be dispatched -			fireGlobals, - -			// Loop variable -			i, - -			// uncached part of the url -			uncached, - -			// Create the final options object -			s = jQuery.ajaxSetup( {}, options ), - -			// Callbacks context -			callbackContext = s.context || s, - -			// Context for global events is callbackContext if it is a DOM node or jQuery collection -			globalEventContext = s.context && -				( callbackContext.nodeType || callbackContext.jquery ) ? -					jQuery( callbackContext ) : -					jQuery.event, - -			// Deferreds -			deferred = jQuery.Deferred(), -			completeDeferred = jQuery.Callbacks( "once memory" ), - -			// Status-dependent callbacks -			statusCode = s.statusCode || {}, - -			// Headers (they are sent all at once) -			requestHeaders = {}, -			requestHeadersNames = {}, - -			// Default abort message -			strAbort = "canceled", - -			// Fake xhr -			jqXHR = { -				readyState: 0, - -				// Builds headers hashtable if needed -				getResponseHeader: function( key ) { -					var match; -					if ( completed ) { -						if ( !responseHeaders ) { -							responseHeaders = {}; -							while ( ( match = rheaders.exec( responseHeadersString ) ) ) { -								responseHeaders[ match[ 1 ].toLowerCase() + " " ] = -									( responseHeaders[ match[ 1 ].toLowerCase() + " " ] || [] ) -										.concat( match[ 2 ] ); -							} -						} -						match = responseHeaders[ key.toLowerCase() + " " ]; -					} -					return match == null ? null : match.join( ", " ); -				}, - -				// Raw string -				getAllResponseHeaders: function() { -					return completed ? responseHeadersString : null; -				}, - -				// Caches the header -				setRequestHeader: function( name, value ) { -					if ( completed == null ) { -						name = requestHeadersNames[ name.toLowerCase() ] = -							requestHeadersNames[ name.toLowerCase() ] || name; -						requestHeaders[ name ] = value; -					} -					return this; -				}, - -				// Overrides response content-type header -				overrideMimeType: function( type ) { -					if ( completed == null ) { -						s.mimeType = type; -					} -					return this; -				}, - -				// Status-dependent callbacks -				statusCode: function( map ) { -					var code; -					if ( map ) { -						if ( completed ) { - -							// Execute the appropriate callbacks -							jqXHR.always( map[ jqXHR.status ] ); -						} else { - -							// Lazy-add the new callbacks in a way that preserves old ones -							for ( code in map ) { -								statusCode[ code ] = [ statusCode[ code ], map[ code ] ]; -							} -						} -					} -					return this; -				}, - -				// Cancel the request -				abort: function( statusText ) { -					var finalText = statusText || strAbort; -					if ( transport ) { -						transport.abort( finalText ); -					} -					done( 0, finalText ); -					return this; -				} -			}; - -		// Attach deferreds -		deferred.promise( jqXHR ); - -		// Add protocol if not provided (prefilters might expect it) -		// Handle falsy url in the settings object (#10093: consistency with old signature) -		// We also use the url parameter if available -		s.url = ( ( url || s.url || location.href ) + "" ) -			.replace( rprotocol, location.protocol + "//" ); - -		// Alias method option to type as per ticket #12004 -		s.type = options.method || options.type || s.method || s.type; - -		// Extract dataTypes list -		s.dataTypes = ( s.dataType || "*" ).toLowerCase().match( rnothtmlwhite ) || [ "" ]; - -		// A cross-domain request is in order when the origin doesn't match the current origin. -		if ( s.crossDomain == null ) { -			urlAnchor = document.createElement( "a" ); - -			// Support: IE <=8 - 11, Edge 12 - 15 -			// IE throws exception on accessing the href property if url is malformed, -			// e.g. http://example.com:80x/ -			try { -				urlAnchor.href = s.url; - -				// Support: IE <=8 - 11 only -				// Anchor's host property isn't correctly set when s.url is relative -				urlAnchor.href = urlAnchor.href; -				s.crossDomain = originAnchor.protocol + "//" + originAnchor.host !== -					urlAnchor.protocol + "//" + urlAnchor.host; -			} catch ( e ) { - -				// If there is an error parsing the URL, assume it is crossDomain, -				// it can be rejected by the transport if it is invalid -				s.crossDomain = true; -			} -		} - -		// Convert data if not already a string -		if ( s.data && s.processData && typeof s.data !== "string" ) { -			s.data = jQuery.param( s.data, s.traditional ); -		} - -		// Apply prefilters -		inspectPrefiltersOrTransports( prefilters, s, options, jqXHR ); - -		// If request was aborted inside a prefilter, stop there -		if ( completed ) { -			return jqXHR; -		} - -		// We can fire global events as of now if asked to -		// Don't fire events if jQuery.event is undefined in an AMD-usage scenario (#15118) -		fireGlobals = jQuery.event && s.global; - -		// Watch for a new set of requests -		if ( fireGlobals && jQuery.active++ === 0 ) { -			jQuery.event.trigger( "ajaxStart" ); -		} - -		// Uppercase the type -		s.type = s.type.toUpperCase(); - -		// Determine if request has content -		s.hasContent = !rnoContent.test( s.type ); - -		// Save the URL in case we're toying with the If-Modified-Since -		// and/or If-None-Match header later on -		// Remove hash to simplify url manipulation -		cacheURL = s.url.replace( rhash, "" ); - -		// More options handling for requests with no content -		if ( !s.hasContent ) { - -			// Remember the hash so we can put it back -			uncached = s.url.slice( cacheURL.length ); - -			// If data is available and should be processed, append data to url -			if ( s.data && ( s.processData || typeof s.data === "string" ) ) { -				cacheURL += ( rquery.test( cacheURL ) ? "&" : "?" ) + s.data; - -				// #9682: remove data so that it's not used in an eventual retry -				delete s.data; -			} - -			// Add or update anti-cache param if needed -			if ( s.cache === false ) { -				cacheURL = cacheURL.replace( rantiCache, "$1" ); -				uncached = ( rquery.test( cacheURL ) ? "&" : "?" ) + "_=" + ( nonce.guid++ ) + -					uncached; -			} - -			// Put hash and anti-cache on the URL that will be requested (gh-1732) -			s.url = cacheURL + uncached; - -		// Change '%20' to '+' if this is encoded form body content (gh-2658) -		} else if ( s.data && s.processData && -			( s.contentType || "" ).indexOf( "application/x-www-form-urlencoded" ) === 0 ) { -			s.data = s.data.replace( r20, "+" ); -		} - -		// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode. -		if ( s.ifModified ) { -			if ( jQuery.lastModified[ cacheURL ] ) { -				jqXHR.setRequestHeader( "If-Modified-Since", jQuery.lastModified[ cacheURL ] ); -			} -			if ( jQuery.etag[ cacheURL ] ) { -				jqXHR.setRequestHeader( "If-None-Match", jQuery.etag[ cacheURL ] ); -			} -		} - -		// Set the correct header, if data is being sent -		if ( s.data && s.hasContent && s.contentType !== false || options.contentType ) { -			jqXHR.setRequestHeader( "Content-Type", s.contentType ); -		} - -		// Set the Accepts header for the server, depending on the dataType -		jqXHR.setRequestHeader( -			"Accept", -			s.dataTypes[ 0 ] && s.accepts[ s.dataTypes[ 0 ] ] ? -				s.accepts[ s.dataTypes[ 0 ] ] + -					( s.dataTypes[ 0 ] !== "*" ? ", " + allTypes + "; q=0.01" : "" ) : -				s.accepts[ "*" ] -		); - -		// Check for headers option -		for ( i in s.headers ) { -			jqXHR.setRequestHeader( i, s.headers[ i ] ); -		} - -		// Allow custom headers/mimetypes and early abort -		if ( s.beforeSend && -			( s.beforeSend.call( callbackContext, jqXHR, s ) === false || completed ) ) { - -			// Abort if not done already and return -			return jqXHR.abort(); -		} - -		// Aborting is no longer a cancellation -		strAbort = "abort"; - -		// Install callbacks on deferreds -		completeDeferred.add( s.complete ); -		jqXHR.done( s.success ); -		jqXHR.fail( s.error ); - -		// Get transport -		transport = inspectPrefiltersOrTransports( transports, s, options, jqXHR ); - -		// If no transport, we auto-abort -		if ( !transport ) { -			done( -1, "No Transport" ); -		} else { -			jqXHR.readyState = 1; - -			// Send global event -			if ( fireGlobals ) { -				globalEventContext.trigger( "ajaxSend", [ jqXHR, s ] ); -			} - -			// If request was aborted inside ajaxSend, stop there -			if ( completed ) { -				return jqXHR; -			} - -			// Timeout -			if ( s.async && s.timeout > 0 ) { -				timeoutTimer = window.setTimeout( function() { -					jqXHR.abort( "timeout" ); -				}, s.timeout ); -			} - -			try { -				completed = false; -				transport.send( requestHeaders, done ); -			} catch ( e ) { - -				// Rethrow post-completion exceptions -				if ( completed ) { -					throw e; -				} - -				// Propagate others as results -				done( -1, e ); -			} -		} - -		// Callback for when everything is done -		function done( status, nativeStatusText, responses, headers ) { -			var isSuccess, success, error, response, modified, -				statusText = nativeStatusText; - -			// Ignore repeat invocations -			if ( completed ) { -				return; -			} - -			completed = true; - -			// Clear timeout if it exists -			if ( timeoutTimer ) { -				window.clearTimeout( timeoutTimer ); -			} - -			// Dereference transport for early garbage collection -			// (no matter how long the jqXHR object will be used) -			transport = undefined; - -			// Cache response headers -			responseHeadersString = headers || ""; - -			// Set readyState -			jqXHR.readyState = status > 0 ? 4 : 0; - -			// Determine if successful -			isSuccess = status >= 200 && status < 300 || status === 304; - -			// Get response data -			if ( responses ) { -				response = ajaxHandleResponses( s, jqXHR, responses ); -			} - -			// Use a noop converter for missing script -			if ( !isSuccess && jQuery.inArray( "script", s.dataTypes ) > -1 ) { -				s.converters[ "text script" ] = function() {}; -			} - -			// Convert no matter what (that way responseXXX fields are always set) -			response = ajaxConvert( s, response, jqXHR, isSuccess ); - -			// If successful, handle type chaining -			if ( isSuccess ) { - -				// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode. -				if ( s.ifModified ) { -					modified = jqXHR.getResponseHeader( "Last-Modified" ); -					if ( modified ) { -						jQuery.lastModified[ cacheURL ] = modified; -					} -					modified = jqXHR.getResponseHeader( "etag" ); -					if ( modified ) { -						jQuery.etag[ cacheURL ] = modified; -					} -				} - -				// if no content -				if ( status === 204 || s.type === "HEAD" ) { -					statusText = "nocontent"; - -				// if not modified -				} else if ( status === 304 ) { -					statusText = "notmodified"; - -				// If we have data, let's convert it -				} else { -					statusText = response.state; -					success = response.data; -					error = response.error; -					isSuccess = !error; -				} -			} else { - -				// Extract error from statusText and normalize for non-aborts -				error = statusText; -				if ( status || !statusText ) { -					statusText = "error"; -					if ( status < 0 ) { -						status = 0; -					} -				} -			} - -			// Set data for the fake xhr object -			jqXHR.status = status; -			jqXHR.statusText = ( nativeStatusText || statusText ) + ""; - -			// Success/Error -			if ( isSuccess ) { -				deferred.resolveWith( callbackContext, [ success, statusText, jqXHR ] ); -			} else { -				deferred.rejectWith( callbackContext, [ jqXHR, statusText, error ] ); -			} - -			// Status-dependent callbacks -			jqXHR.statusCode( statusCode ); -			statusCode = undefined; - -			if ( fireGlobals ) { -				globalEventContext.trigger( isSuccess ? "ajaxSuccess" : "ajaxError", -					[ jqXHR, s, isSuccess ? success : error ] ); -			} - -			// Complete -			completeDeferred.fireWith( callbackContext, [ jqXHR, statusText ] ); - -			if ( fireGlobals ) { -				globalEventContext.trigger( "ajaxComplete", [ jqXHR, s ] ); - -				// Handle the global AJAX counter -				if ( !( --jQuery.active ) ) { -					jQuery.event.trigger( "ajaxStop" ); -				} -			} -		} - -		return jqXHR; -	}, - -	getJSON: function( url, data, callback ) { -		return jQuery.get( url, data, callback, "json" ); -	}, - -	getScript: function( url, callback ) { -		return jQuery.get( url, undefined, callback, "script" ); -	} -} ); - -jQuery.each( [ "get", "post" ], function( _i, method ) { -	jQuery[ method ] = function( url, data, callback, type ) { - -		// Shift arguments if data argument was omitted -		if ( isFunction( data ) ) { -			type = type || callback; -			callback = data; -			data = undefined; -		} - -		// The url can be an options object (which then must have .url) -		return jQuery.ajax( jQuery.extend( { -			url: url, -			type: method, -			dataType: type, -			data: data, -			success: callback -		}, jQuery.isPlainObject( url ) && url ) ); -	}; -} ); - -jQuery.ajaxPrefilter( function( s ) { -	var i; -	for ( i in s.headers ) { -		if ( i.toLowerCase() === "content-type" ) { -			s.contentType = s.headers[ i ] || ""; -		} -	} -} ); - - -jQuery._evalUrl = function( url, options, doc ) { -	return jQuery.ajax( { -		url: url, - -		// Make this explicit, since user can override this through ajaxSetup (#11264) -		type: "GET", -		dataType: "script", -		cache: true, -		async: false, -		global: false, - -		// Only evaluate the response if it is successful (gh-4126) -		// dataFilter is not invoked for failure responses, so using it instead -		// of the default converter is kludgy but it works. -		converters: { -			"text script": function() {} -		}, -		dataFilter: function( response ) { -			jQuery.globalEval( response, options, doc ); -		} -	} ); -}; - - -jQuery.fn.extend( { -	wrapAll: function( html ) { -		var wrap; - -		if ( this[ 0 ] ) { -			if ( isFunction( html ) ) { -				html = html.call( this[ 0 ] ); -			} - -			// The elements to wrap the target around -			wrap = jQuery( html, this[ 0 ].ownerDocument ).eq( 0 ).clone( true ); - -			if ( this[ 0 ].parentNode ) { -				wrap.insertBefore( this[ 0 ] ); -			} - -			wrap.map( function() { -				var elem = this; - -				while ( elem.firstElementChild ) { -					elem = elem.firstElementChild; -				} - -				return elem; -			} ).append( this ); -		} - -		return this; -	}, - -	wrapInner: function( html ) { -		if ( isFunction( html ) ) { -			return this.each( function( i ) { -				jQuery( this ).wrapInner( html.call( this, i ) ); -			} ); -		} - -		return this.each( function() { -			var self = jQuery( this ), -				contents = self.contents(); - -			if ( contents.length ) { -				contents.wrapAll( html ); - -			} else { -				self.append( html ); -			} -		} ); -	}, - -	wrap: function( html ) { -		var htmlIsFunction = isFunction( html ); - -		return this.each( function( i ) { -			jQuery( this ).wrapAll( htmlIsFunction ? html.call( this, i ) : html ); -		} ); -	}, - -	unwrap: function( selector ) { -		this.parent( selector ).not( "body" ).each( function() { -			jQuery( this ).replaceWith( this.childNodes ); -		} ); -		return this; -	} -} ); - - -jQuery.expr.pseudos.hidden = function( elem ) { -	return !jQuery.expr.pseudos.visible( elem ); -}; -jQuery.expr.pseudos.visible = function( elem ) { -	return !!( elem.offsetWidth || elem.offsetHeight || elem.getClientRects().length ); -}; - - - - -jQuery.ajaxSettings.xhr = function() { -	try { -		return new window.XMLHttpRequest(); -	} catch ( e ) {} -}; - -var xhrSuccessStatus = { - -		// File protocol always yields status code 0, assume 200 -		0: 200, - -		// Support: IE <=9 only -		// #1450: sometimes IE returns 1223 when it should be 204 -		1223: 204 -	}, -	xhrSupported = jQuery.ajaxSettings.xhr(); - -support.cors = !!xhrSupported && ( "withCredentials" in xhrSupported ); -support.ajax = xhrSupported = !!xhrSupported; - -jQuery.ajaxTransport( function( options ) { -	var callback, errorCallback; - -	// Cross domain only allowed if supported through XMLHttpRequest -	if ( support.cors || xhrSupported && !options.crossDomain ) { -		return { -			send: function( headers, complete ) { -				var i, -					xhr = options.xhr(); - -				xhr.open( -					options.type, -					options.url, -					options.async, -					options.username, -					options.password -				); - -				// Apply custom fields if provided -				if ( options.xhrFields ) { -					for ( i in options.xhrFields ) { -						xhr[ i ] = options.xhrFields[ i ]; -					} -				} - -				// Override mime type if needed -				if ( options.mimeType && xhr.overrideMimeType ) { -					xhr.overrideMimeType( options.mimeType ); -				} - -				// X-Requested-With header -				// For cross-domain requests, seeing as conditions for a preflight are -				// akin to a jigsaw puzzle, we simply never set it to be sure. -				// (it can always be set on a per-request basis or even using ajaxSetup) -				// For same-domain requests, won't change header if already provided. -				if ( !options.crossDomain && !headers[ "X-Requested-With" ] ) { -					headers[ "X-Requested-With" ] = "XMLHttpRequest"; -				} - -				// Set headers -				for ( i in headers ) { -					xhr.setRequestHeader( i, headers[ i ] ); -				} - -				// Callback -				callback = function( type ) { -					return function() { -						if ( callback ) { -							callback = errorCallback = xhr.onload = -								xhr.onerror = xhr.onabort = xhr.ontimeout = -									xhr.onreadystatechange = null; - -							if ( type === "abort" ) { -								xhr.abort(); -							} else if ( type === "error" ) { - -								// Support: IE <=9 only -								// On a manual native abort, IE9 throws -								// errors on any property access that is not readyState -								if ( typeof xhr.status !== "number" ) { -									complete( 0, "error" ); -								} else { -									complete( - -										// File: protocol always yields status 0; see #8605, #14207 -										xhr.status, -										xhr.statusText -									); -								} -							} else { -								complete( -									xhrSuccessStatus[ xhr.status ] || xhr.status, -									xhr.statusText, - -									// Support: IE <=9 only -									// IE9 has no XHR2 but throws on binary (trac-11426) -									// For XHR2 non-text, let the caller handle it (gh-2498) -									( xhr.responseType || "text" ) !== "text"  || -									typeof xhr.responseText !== "string" ? -										{ binary: xhr.response } : -										{ text: xhr.responseText }, -									xhr.getAllResponseHeaders() -								); -							} -						} -					}; -				}; - -				// Listen to events -				xhr.onload = callback(); -				errorCallback = xhr.onerror = xhr.ontimeout = callback( "error" ); - -				// Support: IE 9 only -				// Use onreadystatechange to replace onabort -				// to handle uncaught aborts -				if ( xhr.onabort !== undefined ) { -					xhr.onabort = errorCallback; -				} else { -					xhr.onreadystatechange = function() { - -						// Check readyState before timeout as it changes -						if ( xhr.readyState === 4 ) { - -							// Allow onerror to be called first, -							// but that will not handle a native abort -							// Also, save errorCallback to a variable -							// as xhr.onerror cannot be accessed -							window.setTimeout( function() { -								if ( callback ) { -									errorCallback(); -								} -							} ); -						} -					}; -				} - -				// Create the abort callback -				callback = callback( "abort" ); - -				try { - -					// Do send the request (this may raise an exception) -					xhr.send( options.hasContent && options.data || null ); -				} catch ( e ) { - -					// #14683: Only rethrow if this hasn't been notified as an error yet -					if ( callback ) { -						throw e; -					} -				} -			}, - -			abort: function() { -				if ( callback ) { -					callback(); -				} -			} -		}; -	} -} ); - - - - -// Prevent auto-execution of scripts when no explicit dataType was provided (See gh-2432) -jQuery.ajaxPrefilter( function( s ) { -	if ( s.crossDomain ) { -		s.contents.script = false; -	} -} ); - -// Install script dataType -jQuery.ajaxSetup( { -	accepts: { -		script: "text/javascript, application/javascript, " + -			"application/ecmascript, application/x-ecmascript" -	}, -	contents: { -		script: /\b(?:java|ecma)script\b/ -	}, -	converters: { -		"text script": function( text ) { -			jQuery.globalEval( text ); -			return text; -		} -	} -} ); - -// Handle cache's special case and crossDomain -jQuery.ajaxPrefilter( "script", function( s ) { -	if ( s.cache === undefined ) { -		s.cache = false; -	} -	if ( s.crossDomain ) { -		s.type = "GET"; -	} -} ); - -// Bind script tag hack transport -jQuery.ajaxTransport( "script", function( s ) { - -	// This transport only deals with cross domain or forced-by-attrs requests -	if ( s.crossDomain || s.scriptAttrs ) { -		var script, callback; -		return { -			send: function( _, complete ) { -				script = jQuery( "<script>" ) -					.attr( s.scriptAttrs || {} ) -					.prop( { charset: s.scriptCharset, src: s.url } ) -					.on( "load error", callback = function( evt ) { -						script.remove(); -						callback = null; -						if ( evt ) { -							complete( evt.type === "error" ? 404 : 200, evt.type ); -						} -					} ); - -				// Use native DOM manipulation to avoid our domManip AJAX trickery -				document.head.appendChild( script[ 0 ] ); -			}, -			abort: function() { -				if ( callback ) { -					callback(); -				} -			} -		}; -	} -} ); - - - - -var oldCallbacks = [], -	rjsonp = /(=)\?(?=&|$)|\?\?/; - -// Default jsonp settings -jQuery.ajaxSetup( { -	jsonp: "callback", -	jsonpCallback: function() { -		var callback = oldCallbacks.pop() || ( jQuery.expando + "_" + ( nonce.guid++ ) ); -		this[ callback ] = true; -		return callback; -	} -} ); - -// Detect, normalize options and install callbacks for jsonp requests -jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { - -	var callbackName, overwritten, responseContainer, -		jsonProp = s.jsonp !== false && ( rjsonp.test( s.url ) ? -			"url" : -			typeof s.data === "string" && -				( s.contentType || "" ) -					.indexOf( "application/x-www-form-urlencoded" ) === 0 && -				rjsonp.test( s.data ) && "data" -		); - -	// Handle iff the expected data type is "jsonp" or we have a parameter to set -	if ( jsonProp || s.dataTypes[ 0 ] === "jsonp" ) { - -		// Get callback name, remembering preexisting value associated with it -		callbackName = s.jsonpCallback = isFunction( s.jsonpCallback ) ? -			s.jsonpCallback() : -			s.jsonpCallback; - -		// Insert callback into url or form data -		if ( jsonProp ) { -			s[ jsonProp ] = s[ jsonProp ].replace( rjsonp, "$1" + callbackName ); -		} else if ( s.jsonp !== false ) { -			s.url += ( rquery.test( s.url ) ? "&" : "?" ) + s.jsonp + "=" + callbackName; -		} - -		// Use data converter to retrieve json after script execution -		s.converters[ "script json" ] = function() { -			if ( !responseContainer ) { -				jQuery.error( callbackName + " was not called" ); -			} -			return responseContainer[ 0 ]; -		}; - -		// Force json dataType -		s.dataTypes[ 0 ] = "json"; - -		// Install callback -		overwritten = window[ callbackName ]; -		window[ callbackName ] = function() { -			responseContainer = arguments; -		}; - -		// Clean-up function (fires after converters) -		jqXHR.always( function() { - -			// If previous value didn't exist - remove it -			if ( overwritten === undefined ) { -				jQuery( window ).removeProp( callbackName ); - -			// Otherwise restore preexisting value -			} else { -				window[ callbackName ] = overwritten; -			} - -			// Save back as free -			if ( s[ callbackName ] ) { - -				// Make sure that re-using the options doesn't screw things around -				s.jsonpCallback = originalSettings.jsonpCallback; - -				// Save the callback name for future use -				oldCallbacks.push( callbackName ); -			} - -			// Call if it was a function and we have a response -			if ( responseContainer && isFunction( overwritten ) ) { -				overwritten( responseContainer[ 0 ] ); -			} - -			responseContainer = overwritten = undefined; -		} ); - -		// Delegate to script -		return "script"; -	} -} ); - - - - -// Support: Safari 8 only -// In Safari 8 documents created via document.implementation.createHTMLDocument -// collapse sibling forms: the second one becomes a child of the first one. -// Because of that, this security measure has to be disabled in Safari 8. -// https://bugs.webkit.org/show_bug.cgi?id=137337 -support.createHTMLDocument = ( function() { -	var body = document.implementation.createHTMLDocument( "" ).body; -	body.innerHTML = "<form></form><form></form>"; -	return body.childNodes.length === 2; -} )(); - - -// Argument "data" should be string of html -// context (optional): If specified, the fragment will be created in this context, -// defaults to document -// keepScripts (optional): If true, will include scripts passed in the html string -jQuery.parseHTML = function( data, context, keepScripts ) { -	if ( typeof data !== "string" ) { -		return []; -	} -	if ( typeof context === "boolean" ) { -		keepScripts = context; -		context = false; -	} - -	var base, parsed, scripts; - -	if ( !context ) { - -		// Stop scripts or inline event handlers from being executed immediately -		// by using document.implementation -		if ( support.createHTMLDocument ) { -			context = document.implementation.createHTMLDocument( "" ); - -			// Set the base href for the created document -			// so any parsed elements with URLs -			// are based on the document's URL (gh-2965) -			base = context.createElement( "base" ); -			base.href = document.location.href; -			context.head.appendChild( base ); -		} else { -			context = document; -		} -	} - -	parsed = rsingleTag.exec( data ); -	scripts = !keepScripts && []; - -	// Single tag -	if ( parsed ) { -		return [ context.createElement( parsed[ 1 ] ) ]; -	} - -	parsed = buildFragment( [ data ], context, scripts ); - -	if ( scripts && scripts.length ) { -		jQuery( scripts ).remove(); -	} - -	return jQuery.merge( [], parsed.childNodes ); -}; - - -/** - * Load a url into a page - */ -jQuery.fn.load = function( url, params, callback ) { -	var selector, type, response, -		self = this, -		off = url.indexOf( " " ); - -	if ( off > -1 ) { -		selector = stripAndCollapse( url.slice( off ) ); -		url = url.slice( 0, off ); -	} - -	// If it's a function -	if ( isFunction( params ) ) { - -		// We assume that it's the callback -		callback = params; -		params = undefined; - -	// Otherwise, build a param string -	} else if ( params && typeof params === "object" ) { -		type = "POST"; -	} - -	// If we have elements to modify, make the request -	if ( self.length > 0 ) { -		jQuery.ajax( { -			url: url, - -			// If "type" variable is undefined, then "GET" method will be used. -			// Make value of this field explicit since -			// user can override it through ajaxSetup method -			type: type || "GET", -			dataType: "html", -			data: params -		} ).done( function( responseText ) { - -			// Save response for use in complete callback -			response = arguments; - -			self.html( selector ? - -				// If a selector was specified, locate the right elements in a dummy div -				// Exclude scripts to avoid IE 'Permission Denied' errors -				jQuery( "<div>" ).append( jQuery.parseHTML( responseText ) ).find( selector ) : - -				// Otherwise use the full result -				responseText ); - -		// If the request succeeds, this function gets "data", "status", "jqXHR" -		// but they are ignored because response was set above. -		// If it fails, this function gets "jqXHR", "status", "error" -		} ).always( callback && function( jqXHR, status ) { -			self.each( function() { -				callback.apply( this, response || [ jqXHR.responseText, status, jqXHR ] ); -			} ); -		} ); -	} - -	return this; -}; - - - - -jQuery.expr.pseudos.animated = function( elem ) { -	return jQuery.grep( jQuery.timers, function( fn ) { -		return elem === fn.elem; -	} ).length; -}; - - - - -jQuery.offset = { -	setOffset: function( elem, options, i ) { -		var curPosition, curLeft, curCSSTop, curTop, curOffset, curCSSLeft, calculatePosition, -			position = jQuery.css( elem, "position" ), -			curElem = jQuery( elem ), -			props = {}; - -		// Set position first, in-case top/left are set even on static elem -		if ( position === "static" ) { -			elem.style.position = "relative"; -		} - -		curOffset = curElem.offset(); -		curCSSTop = jQuery.css( elem, "top" ); -		curCSSLeft = jQuery.css( elem, "left" ); -		calculatePosition = ( position === "absolute" || position === "fixed" ) && -			( curCSSTop + curCSSLeft ).indexOf( "auto" ) > -1; - -		// Need to be able to calculate position if either -		// top or left is auto and position is either absolute or fixed -		if ( calculatePosition ) { -			curPosition = curElem.position(); -			curTop = curPosition.top; -			curLeft = curPosition.left; - -		} else { -			curTop = parseFloat( curCSSTop ) || 0; -			curLeft = parseFloat( curCSSLeft ) || 0; -		} - -		if ( isFunction( options ) ) { - -			// Use jQuery.extend here to allow modification of coordinates argument (gh-1848) -			options = options.call( elem, i, jQuery.extend( {}, curOffset ) ); -		} - -		if ( options.top != null ) { -			props.top = ( options.top - curOffset.top ) + curTop; -		} -		if ( options.left != null ) { -			props.left = ( options.left - curOffset.left ) + curLeft; -		} - -		if ( "using" in options ) { -			options.using.call( elem, props ); - -		} else { -			if ( typeof props.top === "number" ) { -				props.top += "px"; -			} -			if ( typeof props.left === "number" ) { -				props.left += "px"; -			} -			curElem.css( props ); -		} -	} -}; - -jQuery.fn.extend( { - -	// offset() relates an element's border box to the document origin -	offset: function( options ) { - -		// Preserve chaining for setter -		if ( arguments.length ) { -			return options === undefined ? -				this : -				this.each( function( i ) { -					jQuery.offset.setOffset( this, options, i ); -				} ); -		} - -		var rect, win, -			elem = this[ 0 ]; - -		if ( !elem ) { -			return; -		} - -		// Return zeros for disconnected and hidden (display: none) elements (gh-2310) -		// Support: IE <=11 only -		// Running getBoundingClientRect on a -		// disconnected node in IE throws an error -		if ( !elem.getClientRects().length ) { -			return { top: 0, left: 0 }; -		} - -		// Get document-relative position by adding viewport scroll to viewport-relative gBCR -		rect = elem.getBoundingClientRect(); -		win = elem.ownerDocument.defaultView; -		return { -			top: rect.top + win.pageYOffset, -			left: rect.left + win.pageXOffset -		}; -	}, - -	// position() relates an element's margin box to its offset parent's padding box -	// This corresponds to the behavior of CSS absolute positioning -	position: function() { -		if ( !this[ 0 ] ) { -			return; -		} - -		var offsetParent, offset, doc, -			elem = this[ 0 ], -			parentOffset = { top: 0, left: 0 }; - -		// position:fixed elements are offset from the viewport, which itself always has zero offset -		if ( jQuery.css( elem, "position" ) === "fixed" ) { - -			// Assume position:fixed implies availability of getBoundingClientRect -			offset = elem.getBoundingClientRect(); - -		} else { -			offset = this.offset(); - -			// Account for the *real* offset parent, which can be the document or its root element -			// when a statically positioned element is identified -			doc = elem.ownerDocument; -			offsetParent = elem.offsetParent || doc.documentElement; -			while ( offsetParent && -				( offsetParent === doc.body || offsetParent === doc.documentElement ) && -				jQuery.css( offsetParent, "position" ) === "static" ) { - -				offsetParent = offsetParent.parentNode; -			} -			if ( offsetParent && offsetParent !== elem && offsetParent.nodeType === 1 ) { - -				// Incorporate borders into its offset, since they are outside its content origin -				parentOffset = jQuery( offsetParent ).offset(); -				parentOffset.top += jQuery.css( offsetParent, "borderTopWidth", true ); -				parentOffset.left += jQuery.css( offsetParent, "borderLeftWidth", true ); -			} -		} - -		// Subtract parent offsets and element margins -		return { -			top: offset.top - parentOffset.top - jQuery.css( elem, "marginTop", true ), -			left: offset.left - parentOffset.left - jQuery.css( elem, "marginLeft", true ) -		}; -	}, - -	// This method will return documentElement in the following cases: -	// 1) For the element inside the iframe without offsetParent, this method will return -	//    documentElement of the parent window -	// 2) For the hidden or detached element -	// 3) For body or html element, i.e. in case of the html node - it will return itself -	// -	// but those exceptions were never presented as a real life use-cases -	// and might be considered as more preferable results. -	// -	// This logic, however, is not guaranteed and can change at any point in the future -	offsetParent: function() { -		return this.map( function() { -			var offsetParent = this.offsetParent; - -			while ( offsetParent && jQuery.css( offsetParent, "position" ) === "static" ) { -				offsetParent = offsetParent.offsetParent; -			} - -			return offsetParent || documentElement; -		} ); -	} -} ); - -// Create scrollLeft and scrollTop methods -jQuery.each( { scrollLeft: "pageXOffset", scrollTop: "pageYOffset" }, function( method, prop ) { -	var top = "pageYOffset" === prop; - -	jQuery.fn[ method ] = function( val ) { -		return access( this, function( elem, method, val ) { - -			// Coalesce documents and windows -			var win; -			if ( isWindow( elem ) ) { -				win = elem; -			} else if ( elem.nodeType === 9 ) { -				win = elem.defaultView; -			} - -			if ( val === undefined ) { -				return win ? win[ prop ] : elem[ method ]; -			} - -			if ( win ) { -				win.scrollTo( -					!top ? val : win.pageXOffset, -					top ? val : win.pageYOffset -				); - -			} else { -				elem[ method ] = val; -			} -		}, method, val, arguments.length ); -	}; -} ); - -// Support: Safari <=7 - 9.1, Chrome <=37 - 49 -// Add the top/left cssHooks using jQuery.fn.position -// Webkit bug: https://bugs.webkit.org/show_bug.cgi?id=29084 -// Blink bug: https://bugs.chromium.org/p/chromium/issues/detail?id=589347 -// getComputedStyle returns percent when specified for top/left/bottom/right; -// rather than make the css module depend on the offset module, just check for it here -jQuery.each( [ "top", "left" ], function( _i, prop ) { -	jQuery.cssHooks[ prop ] = addGetHookIf( support.pixelPosition, -		function( elem, computed ) { -			if ( computed ) { -				computed = curCSS( elem, prop ); - -				// If curCSS returns percentage, fallback to offset -				return rnumnonpx.test( computed ) ? -					jQuery( elem ).position()[ prop ] + "px" : -					computed; -			} -		} -	); -} ); - - -// Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods -jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { -	jQuery.each( { padding: "inner" + name, content: type, "": "outer" + name }, -		function( defaultExtra, funcName ) { - -		// Margin is only for outerHeight, outerWidth -		jQuery.fn[ funcName ] = function( margin, value ) { -			var chainable = arguments.length && ( defaultExtra || typeof margin !== "boolean" ), -				extra = defaultExtra || ( margin === true || value === true ? "margin" : "border" ); - -			return access( this, function( elem, type, value ) { -				var doc; - -				if ( isWindow( elem ) ) { - -					// $( window ).outerWidth/Height return w/h including scrollbars (gh-1729) -					return funcName.indexOf( "outer" ) === 0 ? -						elem[ "inner" + name ] : -						elem.document.documentElement[ "client" + name ]; -				} - -				// Get document width or height -				if ( elem.nodeType === 9 ) { -					doc = elem.documentElement; - -					// Either scroll[Width/Height] or offset[Width/Height] or client[Width/Height], -					// whichever is greatest -					return Math.max( -						elem.body[ "scroll" + name ], doc[ "scroll" + name ], -						elem.body[ "offset" + name ], doc[ "offset" + name ], -						doc[ "client" + name ] -					); -				} - -				return value === undefined ? - -					// Get width or height on the element, requesting but not forcing parseFloat -					jQuery.css( elem, type, extra ) : - -					// Set width or height on the element -					jQuery.style( elem, type, value, extra ); -			}, type, chainable ? margin : undefined, chainable ); -		}; -	} ); -} ); - - -jQuery.each( [ -	"ajaxStart", -	"ajaxStop", -	"ajaxComplete", -	"ajaxError", -	"ajaxSuccess", -	"ajaxSend" -], function( _i, type ) { -	jQuery.fn[ type ] = function( fn ) { -		return this.on( type, fn ); -	}; -} ); - - - - -jQuery.fn.extend( { - -	bind: function( types, data, fn ) { -		return this.on( types, null, data, fn ); -	}, -	unbind: function( types, fn ) { -		return this.off( types, null, fn ); -	}, - -	delegate: function( selector, types, data, fn ) { -		return this.on( types, selector, data, fn ); -	}, -	undelegate: function( selector, types, fn ) { - -		// ( namespace ) or ( selector, types [, fn] ) -		return arguments.length === 1 ? -			this.off( selector, "**" ) : -			this.off( types, selector || "**", fn ); -	}, - -	hover: function( fnOver, fnOut ) { -		return this.mouseenter( fnOver ).mouseleave( fnOut || fnOver ); -	} -} ); - -jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " + -	"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " + -	"change select submit keydown keypress keyup contextmenu" ).split( " " ), -	function( _i, name ) { - -		// Handle event binding -		jQuery.fn[ name ] = function( data, fn ) { -			return arguments.length > 0 ? -				this.on( name, null, data, fn ) : -				this.trigger( name ); -		}; -	} ); - - - - -// Support: Android <=4.0 only -// Make sure we trim BOM and NBSP -var rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g; - -// Bind a function to a context, optionally partially applying any -// arguments. -// jQuery.proxy is deprecated to promote standards (specifically Function#bind) -// However, it is not slated for removal any time soon -jQuery.proxy = function( fn, context ) { -	var tmp, args, proxy; - -	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 ( !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; -}; - -jQuery.holdReady = function( hold ) { -	if ( hold ) { -		jQuery.readyWait++; -	} else { -		jQuery.ready( true ); -	} -}; -jQuery.isArray = Array.isArray; -jQuery.parseJSON = JSON.parse; -jQuery.nodeName = nodeName; -jQuery.isFunction = isFunction; -jQuery.isWindow = isWindow; -jQuery.camelCase = camelCase; -jQuery.type = toType; - -jQuery.now = Date.now; - -jQuery.isNumeric = function( obj ) { - -	// As of jQuery 3.0, isNumeric is limited to -	// strings and numbers (primitives or objects) -	// that can be coerced to finite numbers (gh-2662) -	var type = jQuery.type( obj ); -	return ( type === "number" || type === "string" ) && - -		// parseFloat NaNs numeric-cast false positives ("") -		// ...but misinterprets leading-number strings, particularly hex literals ("0x...") -		// subtraction forces infinities to NaN -		!isNaN( obj - parseFloat( obj ) ); -}; - -jQuery.trim = function( text ) { -	return text == null ? -		"" : -		( text + "" ).replace( rtrim, "" ); -}; - - - -// Register as a named AMD module, since jQuery can be concatenated with other -// files that may use define, but not via a proper concatenation script that -// understands anonymous AMD modules. A named AMD is safest and most robust -// way to register. Lowercase jquery is used because AMD module names are -// derived from file names, and jQuery is normally delivered in a lowercase -// file name. Do this after creating the global so that if an AMD module wants -// to call noConflict to hide this version of jQuery, it will work. - -// Note that for maximum portability, libraries that are not jQuery should -// declare themselves as anonymous modules, and avoid setting a global if an -// AMD loader is present. jQuery is a special case. For more information, see -// https://github.com/jrburke/requirejs/wiki/Updating-existing-libraries#wiki-anon - -if ( typeof define === "function" && define.amd ) { -	define( "jquery", [], function() { -		return jQuery; -	} ); -} - - - - -var - -	// Map over jQuery in case of overwrite -	_jQuery = window.jQuery, - -	// Map over the $ in case of overwrite -	_$ = window.$; - -jQuery.noConflict = function( deep ) { -	if ( window.$ === jQuery ) { -		window.$ = _$; -	} - -	if ( deep && window.jQuery === jQuery ) { -		window.jQuery = _jQuery; -	} - -	return jQuery; -}; - -// Expose jQuery and $ identifiers, even in AMD -// (#7102#comment:10, https://github.com/jquery/jquery/pull/557) -// and CommonJS for browser emulators (#13566) -if ( typeof noGlobal === "undefined" ) { -	window.jQuery = window.$ = jQuery; -} - - - - -return jQuery; -} ); diff --git a/v7.1.3/_static/jquery-3.6.0.js b/v7.1.3/_static/jquery-3.6.0.js new file mode 100644 index 00000000..fc6c299b --- /dev/null +++ b/v7.1.3/_static/jquery-3.6.0.js @@ -0,0 +1,10881 @@ +/*! + * jQuery JavaScript Library v3.6.0 + * https://jquery.com/ + * + * Includes Sizzle.js + * https://sizzlejs.com/ + * + * Copyright OpenJS Foundation and other contributors + * Released under the MIT license + * https://jquery.org/license + * + * Date: 2021-03-02T17:08Z + */ +( function( global, factory ) { + +	"use strict"; + +	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 have a `window` with a `document` +		// (such as Node.js), expose a 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 ) { + +// Edge <= 12 - 13+, Firefox <=18 - 45+, IE 10 - 11, Safari 5.1 - 9+, iOS 6 - 9.1 +// throw exceptions when non-strict code (e.g., ASP.NET 4.5) accesses strict mode +// arguments.callee.caller (trac-13335). But as of jQuery 3.0 (2016), strict mode should be common +// enough that all such attempts are guarded in a try block. +"use strict"; + +var arr = []; + +var getProto = Object.getPrototypeOf; + +var slice = arr.slice; + +var flat = arr.flat ? function( array ) { +	return arr.flat.call( array ); +} : function( array ) { +	return arr.concat.apply( [], array ); +}; + + +var push = arr.push; + +var indexOf = arr.indexOf; + +var class2type = {}; + +var toString = class2type.toString; + +var hasOwn = class2type.hasOwnProperty; + +var fnToString = hasOwn.toString; + +var ObjectFunctionString = fnToString.call( Object ); + +var support = {}; + +var isFunction = function isFunction( obj ) { + +		// Support: Chrome <=57, Firefox <=52 +		// In some browsers, typeof returns "function" for HTML <object> elements +		// (i.e., `typeof document.createElement( "object" ) === "function"`). +		// We don't want to classify *any* DOM node as a function. +		// Support: QtWeb <=3.8.5, WebKit <=534.34, wkhtmltopdf tool <=0.12.5 +		// Plus for old WebKit, typeof returns "function" for HTML collections +		// (e.g., `typeof document.getElementsByTagName("div") === "function"`). (gh-4756) +		return typeof obj === "function" && typeof obj.nodeType !== "number" && +			typeof obj.item !== "function"; +	}; + + +var isWindow = function isWindow( obj ) { +		return obj != null && obj === obj.window; +	}; + + +var document = window.document; + + + +	var preservedScriptAttributes = { +		type: true, +		src: true, +		nonce: true, +		noModule: true +	}; + +	function DOMEval( code, node, doc ) { +		doc = doc || document; + +		var i, val, +			script = doc.createElement( "script" ); + +		script.text = code; +		if ( node ) { +			for ( i in preservedScriptAttributes ) { + +				// Support: Firefox 64+, Edge 18+ +				// Some browsers don't support the "nonce" property on scripts. +				// On the other hand, just using `getAttribute` is not enough as +				// the `nonce` attribute is reset to an empty string whenever it +				// becomes browsing-context connected. +				// See https://github.com/whatwg/html/issues/2369 +				// See https://html.spec.whatwg.org/#nonce-attributes +				// The `node.getAttribute` check was added for the sake of +				// `jQuery.globalEval` so that it can fake a nonce-containing node +				// via an object. +				val = node[ i ] || node.getAttribute && node.getAttribute( i ); +				if ( val ) { +					script.setAttribute( i, val ); +				} +			} +		} +		doc.head.appendChild( script ).parentNode.removeChild( script ); +	} + + +function toType( obj ) { +	if ( obj == null ) { +		return obj + ""; +	} + +	// Support: Android <=2.3 only (functionish RegExp) +	return typeof obj === "object" || typeof obj === "function" ? +		class2type[ toString.call( obj ) ] || "object" : +		typeof obj; +} +/* global Symbol */ +// Defining this global in .eslintrc.json would create a danger of using the global +// unguarded in another place, it seems safer to define global only for this module + + + +var +	version = "3.6.0", + +	// 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 ); +	}; + +jQuery.fn = jQuery.prototype = { + +	// The current version of jQuery being used +	jquery: version, + +	constructor: jQuery, + +	// 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 all the elements in a clean array +		if ( num == null ) { +			return slice.call( this ); +		} + +		// Return just the one element from the set +		return num < 0 ? this[ num + this.length ] : this[ num ]; +	}, + +	// 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; + +		// Return the newly-formed element set +		return ret; +	}, + +	// Execute a callback for every element in the matched set. +	each: function( callback ) { +		return jQuery.each( this, callback ); +	}, + +	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 ); +	}, + +	even: function() { +		return this.pushStack( jQuery.grep( this, function( _elem, i ) { +			return ( i + 1 ) % 2; +		} ) ); +	}, + +	odd: function() { +		return this.pushStack( jQuery.grep( this, function( _elem, i ) { +			return i % 2; +		} ) ); +	}, + +	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(); +	}, + +	// For internal use only. +	// Behaves like an Array's method, not like a jQuery method. +	push: push, +	sort: arr.sort, +	splice: arr.splice +}; + +jQuery.extend = jQuery.fn.extend = function() { +	var options, name, src, copy, copyIsArray, 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" && !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 ) { +				copy = options[ name ]; + +				// Prevent Object.prototype pollution +				// Prevent never-ending loop +				if ( name === "__proto__" || target === copy ) { +					continue; +				} + +				// Recurse if we're merging plain objects or arrays +				if ( deep && copy && ( jQuery.isPlainObject( copy ) || +					( copyIsArray = Array.isArray( copy ) ) ) ) { +					src = target[ name ]; + +					// Ensure proper type for the source value +					if ( copyIsArray && !Array.isArray( src ) ) { +						clone = []; +					} else if ( !copyIsArray && !jQuery.isPlainObject( src ) ) { +						clone = {}; +					} else { +						clone = src; +					} +					copyIsArray = false; + +					// 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() {}, + +	isPlainObject: function( obj ) { +		var proto, Ctor; + +		// Detect obvious negatives +		// Use toString instead of jQuery.type to catch host objects +		if ( !obj || toString.call( obj ) !== "[object Object]" ) { +			return false; +		} + +		proto = getProto( obj ); + +		// Objects with no prototype (e.g., `Object.create( null )`) are plain +		if ( !proto ) { +			return true; +		} + +		// Objects with prototype are plain iff they were constructed by a global Object function +		Ctor = hasOwn.call( proto, "constructor" ) && proto.constructor; +		return typeof Ctor === "function" && fnToString.call( Ctor ) === ObjectFunctionString; +	}, + +	isEmptyObject: function( obj ) { +		var name; + +		for ( name in obj ) { +			return false; +		} +		return true; +	}, + +	// Evaluates a script in a provided context; falls back to the global one +	// if not specified. +	globalEval: function( code, options, doc ) { +		DOMEval( code, { nonce: options && options.nonce }, doc ); +	}, + +	each: function( obj, callback ) { +		var length, i = 0; + +		if ( isArrayLike( obj ) ) { +			length = obj.length; +			for ( ; i < length; i++ ) { +				if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) { +					break; +				} +			} +		} else { +			for ( i in obj ) { +				if ( callback.call( obj[ i ], i, obj[ i ] ) === false ) { +					break; +				} +			} +		} + +		return obj; +	}, + +	// 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 ) { +		return arr == null ? -1 : indexOf.call( arr, elem, i ); +	}, + +	// Support: Android <=4.0 only, PhantomJS 1 only +	// push.apply(_, arraylike) throws on ancient WebKit +	merge: function( first, second ) { +		var len = +second.length, +			j = 0, +			i = first.length; + +		for ( ; j < len; j++ ) { +			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 length, value, +			i = 0, +			ret = []; + +		// Go through the array, translating each of the items to their new values +		if ( isArrayLike( elems ) ) { +			length = elems.length; +			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 flat( ret ); +	}, + +	// A global GUID counter for objects +	guid: 1, + +	// jQuery.support is not used in Core but other projects attach their +	// properties to it so it needs to exist. +	support: support +} ); + +if ( typeof Symbol === "function" ) { +	jQuery.fn[ Symbol.iterator ] = arr[ Symbol.iterator ]; +} + +// Populate the class2type map +jQuery.each( "Boolean Number String Function Array Date RegExp Object Error Symbol".split( " " ), +	function( _i, name ) { +		class2type[ "[object " + name + "]" ] = name.toLowerCase(); +	} ); + +function isArrayLike( obj ) { + +	// Support: real iOS 8.2 only (not reproducible in simulator) +	// `in` check used to prevent JIT error (gh-2145) +	// hasOwn isn't used here due to false negatives +	// regarding Nodelist length in IE +	var length = !!obj && "length" in obj && obj.length, +		type = toType( obj ); + +	if ( isFunction( obj ) || isWindow( obj ) ) { +		return false; +	} + +	return type === "array" || length === 0 || +		typeof length === "number" && length > 0 && ( length - 1 ) in obj; +} +var Sizzle = +/*! + * Sizzle CSS Selector Engine v2.3.6 + * https://sizzlejs.com/ + * + * Copyright JS Foundation and other contributors + * Released under the MIT license + * https://js.foundation/ + * + * Date: 2021-02-16 + */ +( 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" + 1 * new Date(), +	preferredDoc = window.document, +	dirruns = 0, +	done = 0, +	classCache = createCache(), +	tokenCache = createCache(), +	compilerCache = createCache(), +	nonnativeSelectorCache = createCache(), +	sortOrder = function( a, b ) { +		if ( a === b ) { +			hasDuplicate = true; +		} +		return 0; +	}, + +	// Instance methods +	hasOwn = ( {} ).hasOwnProperty, +	arr = [], +	pop = arr.pop, +	pushNative = arr.push, +	push = arr.push, +	slice = arr.slice, + +	// Use a stripped-down indexOf as it's faster than native +	// https://jsperf.com/thor-indexof-vs-for/5 +	indexOf = function( list, elem ) { +		var i = 0, +			len = list.length; +		for ( ; i < len; i++ ) { +			if ( list[ 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 + +	// http://www.w3.org/TR/css3-selectors/#whitespace +	whitespace = "[\\x20\\t\\r\\n\\f]", + +	// https://www.w3.org/TR/css-syntax-3/#ident-token-diagram +	identifier = "(?:\\\\[\\da-fA-F]{1,6}" + whitespace + +		"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+", + +	// Attribute selectors: http://www.w3.org/TR/selectors/#attribute-selectors +	attributes = "\\[" + whitespace + "*(" + identifier + ")(?:" + whitespace + + +		// Operator (capture 2) +		"*([*^$|!~]?=)" + whitespace + + +		// "Attribute values must be CSS identifiers [capture 5] +		// or strings [capture 3 or capture 4]" +		"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + identifier + "))|)" + +		whitespace + "*\\]", + +	pseudos = ":(" + identifier + ")(?:\\((" + + +		// 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 +	rwhitespace = new RegExp( whitespace + "+", "g" ), +	rtrim = new RegExp( "^" + whitespace + "+|((?:^|[^\\\\])(?:\\\\.)*)" + +		whitespace + "+$", "g" ), + +	rcomma = new RegExp( "^" + whitespace + "*," + whitespace + "*" ), +	rcombinators = new RegExp( "^" + whitespace + "*([>+~]|" + whitespace + ")" + whitespace + +		"*" ), +	rdescend = new RegExp( whitespace + "|>" ), + +	rpseudo = new RegExp( pseudos ), +	ridentifier = new RegExp( "^" + identifier + "$" ), + +	matchExpr = { +		"ID": new RegExp( "^#(" + identifier + ")" ), +		"CLASS": new RegExp( "^\\.(" + identifier + ")" ), +		"TAG": new RegExp( "^(" + identifier + "|[*])" ), +		"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" ) +	}, + +	rhtml = /HTML$/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 = /[+~]/, + +	// CSS escapes +	// http://www.w3.org/TR/CSS21/syndata.html#escaped-characters +	runescape = new RegExp( "\\\\[\\da-fA-F]{1,6}" + whitespace + "?|\\\\([^\\r\\n\\f])", "g" ), +	funescape = function( escape, nonHex ) { +		var high = "0x" + escape.slice( 1 ) - 0x10000; + +		return nonHex ? + +			// Strip the backslash prefix from a non-hex escape sequence +			nonHex : + +			// Replace a hexadecimal escape sequence with the encoded Unicode code point +			// Support: IE <=11+ +			// For values outside the Basic Multilingual Plane (BMP), manually construct a +			// surrogate pair +			high < 0 ? +				String.fromCharCode( high + 0x10000 ) : +				String.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 ); +	}, + +	// CSS string/identifier serialization +	// https://drafts.csswg.org/cssom/#common-serializing-idioms +	rcssescape = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g, +	fcssescape = function( ch, asCodePoint ) { +		if ( asCodePoint ) { + +			// U+0000 NULL becomes U+FFFD REPLACEMENT CHARACTER +			if ( ch === "\0" ) { +				return "\uFFFD"; +			} + +			// Control characters and (dependent upon position) numbers get escaped as code points +			return ch.slice( 0, -1 ) + "\\" + +				ch.charCodeAt( ch.length - 1 ).toString( 16 ) + " "; +		} + +		// Other potentially-special ASCII characters get backslash-escaped +		return "\\" + ch; +	}, + +	// Used for iframes +	// See setDocument() +	// Removing the function wrapper causes a "Permission Denied" +	// error in IE +	unloadHandler = function() { +		setDocument(); +	}, + +	inDisabledFieldset = addCombinator( +		function( elem ) { +			return elem.disabled === true && elem.nodeName.toLowerCase() === "fieldset"; +		}, +		{ dir: "parentNode", next: "legend" } +	); + +// Optimize for push.apply( _, NodeList ) +try { +	push.apply( +		( arr = slice.call( preferredDoc.childNodes ) ), +		preferredDoc.childNodes +	); + +	// Support: Android<4.0 +	// Detect silently failing push.apply +	// eslint-disable-next-line no-unused-expressions +	arr[ preferredDoc.childNodes.length ].nodeType; +} catch ( e ) { +	push = { apply: arr.length ? + +		// Leverage slice if possible +		function( target, els ) { +			pushNative.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 m, i, elem, nid, match, groups, newSelector, +		newContext = context && context.ownerDocument, + +		// nodeType defaults to 9, since context defaults to document +		nodeType = context ? context.nodeType : 9; + +	results = results || []; + +	// Return early from calls with invalid selector or context +	if ( typeof selector !== "string" || !selector || +		nodeType !== 1 && nodeType !== 9 && nodeType !== 11 ) { + +		return results; +	} + +	// Try to shortcut find operations (as opposed to filters) in HTML documents +	if ( !seed ) { +		setDocument( context ); +		context = context || document; + +		if ( documentIsHTML ) { + +			// If the selector is sufficiently simple, try using a "get*By*" DOM method +			// (excepting DocumentFragment context, where the methods don't exist) +			if ( nodeType !== 11 && ( match = rquickExpr.exec( selector ) ) ) { + +				// ID selector +				if ( ( m = match[ 1 ] ) ) { + +					// Document context +					if ( nodeType === 9 ) { +						if ( ( elem = context.getElementById( m ) ) ) { + +							// Support: IE, Opera, Webkit +							// TODO: identify versions +							// getElementById can match elements by name instead of ID +							if ( elem.id === m ) { +								results.push( elem ); +								return results; +							} +						} else { +							return results; +						} + +					// Element context +					} else { + +						// Support: IE, Opera, Webkit +						// TODO: identify versions +						// getElementById can match elements by name instead of ID +						if ( newContext && ( elem = newContext.getElementById( m ) ) && +							contains( context, elem ) && +							elem.id === m ) { + +							results.push( elem ); +							return results; +						} +					} + +				// Type selector +				} else if ( match[ 2 ] ) { +					push.apply( results, context.getElementsByTagName( selector ) ); +					return results; + +				// Class selector +				} else if ( ( m = match[ 3 ] ) && support.getElementsByClassName && +					context.getElementsByClassName ) { + +					push.apply( results, context.getElementsByClassName( m ) ); +					return results; +				} +			} + +			// Take advantage of querySelectorAll +			if ( support.qsa && +				!nonnativeSelectorCache[ selector + " " ] && +				( !rbuggyQSA || !rbuggyQSA.test( selector ) ) && + +				// Support: IE 8 only +				// Exclude object elements +				( nodeType !== 1 || context.nodeName.toLowerCase() !== "object" ) ) { + +				newSelector = selector; +				newContext = context; + +				// qSA considers elements outside a scoping root when evaluating child or +				// descendant combinators, which is not what we want. +				// In such cases, we work around the behavior by prefixing every selector in the +				// list with an ID selector referencing the scope context. +				// The technique has to be used as well when a leading combinator is used +				// as such selectors are not recognized by querySelectorAll. +				// Thanks to Andrew Dupont for this technique. +				if ( nodeType === 1 && +					( rdescend.test( selector ) || rcombinators.test( selector ) ) ) { + +					// Expand context for sibling selectors +					newContext = rsibling.test( selector ) && testContext( context.parentNode ) || +						context; + +					// We can use :scope instead of the ID hack if the browser +					// supports it & if we're not changing the context. +					if ( newContext !== context || !support.scope ) { + +						// Capture the context ID, setting it first if necessary +						if ( ( nid = context.getAttribute( "id" ) ) ) { +							nid = nid.replace( rcssescape, fcssescape ); +						} else { +							context.setAttribute( "id", ( nid = expando ) ); +						} +					} + +					// Prefix every selector in the list +					groups = tokenize( selector ); +					i = groups.length; +					while ( i-- ) { +						groups[ i ] = ( nid ? "#" + nid : ":scope" ) + " " + +							toSelector( groups[ i ] ); +					} +					newSelector = groups.join( "," ); +				} + +				try { +					push.apply( results, +						newContext.querySelectorAll( newSelector ) +					); +					return results; +				} catch ( qsaError ) { +					nonnativeSelectorCache( selector, true ); +				} finally { +					if ( nid === expando ) { +						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 element and returns a boolean result + */ +function assert( fn ) { +	var el = document.createElement( "fieldset" ); + +	try { +		return !!fn( el ); +	} catch ( e ) { +		return false; +	} finally { + +		// Remove from its parent by default +		if ( el.parentNode ) { +			el.parentNode.removeChild( el ); +		} + +		// release memory in IE +		el = 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 = arr.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 && +			a.sourceIndex - b.sourceIndex; + +	// 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 :enabled/:disabled + * @param {Boolean} disabled true for :disabled; false for :enabled + */ +function createDisabledPseudo( disabled ) { + +	// Known :disabled false positives: fieldset[disabled] > legend:nth-of-type(n+2) :can-disable +	return function( elem ) { + +		// Only certain elements can match :enabled or :disabled +		// https://html.spec.whatwg.org/multipage/scripting.html#selector-enabled +		// https://html.spec.whatwg.org/multipage/scripting.html#selector-disabled +		if ( "form" in elem ) { + +			// Check for inherited disabledness on relevant non-disabled elements: +			// * listed form-associated elements in a disabled fieldset +			//   https://html.spec.whatwg.org/multipage/forms.html#category-listed +			//   https://html.spec.whatwg.org/multipage/forms.html#concept-fe-disabled +			// * option elements in a disabled optgroup +			//   https://html.spec.whatwg.org/multipage/forms.html#concept-option-disabled +			// All such elements have a "form" property. +			if ( elem.parentNode && elem.disabled === false ) { + +				// Option elements defer to a parent optgroup if present +				if ( "label" in elem ) { +					if ( "label" in elem.parentNode ) { +						return elem.parentNode.disabled === disabled; +					} else { +						return elem.disabled === disabled; +					} +				} + +				// Support: IE 6 - 11 +				// Use the isDisabled shortcut property to check for disabled fieldset ancestors +				return elem.isDisabled === disabled || + +					// Where there is no isDisabled, check manually +					/* jshint -W018 */ +					elem.isDisabled !== !disabled && +					inDisabledFieldset( elem ) === disabled; +			} + +			return elem.disabled === disabled; + +		// Try to winnow out elements that can't be disabled before trusting the disabled property. +		// Some victims get caught in our net (label, legend, menu, track), but it shouldn't +		// even exist on them, let alone have a boolean value. +		} else if ( "label" in elem ) { +			return elem.disabled === disabled; +		} + +		// Remaining elements are neither :enabled nor :disabled +		return false; +	}; +} + +/** + * 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 !== "undefined" && 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 ) { +	var namespace = elem && elem.namespaceURI, +		docElem = elem && ( elem.ownerDocument || elem ).documentElement; + +	// Support: IE <=8 +	// Assume HTML when documentElement doesn't yet exist, such as inside loading iframes +	// https://bugs.jquery.com/ticket/4833 +	return !rhtml.test( namespace || docElem && docElem.nodeName || "HTML" ); +}; + +/** + * 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, subWindow, +		doc = node ? node.ownerDocument || node : preferredDoc; + +	// Return early if doc is invalid or already selected +	// Support: IE 11+, Edge 17 - 18+ +	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing +	// two documents; shallow comparisons work. +	// eslint-disable-next-line eqeqeq +	if ( doc == document || doc.nodeType !== 9 || !doc.documentElement ) { +		return document; +	} + +	// Update global variables +	document = doc; +	docElem = document.documentElement; +	documentIsHTML = !isXML( document ); + +	// Support: IE 9 - 11+, Edge 12 - 18+ +	// Accessing iframe documents after unload throws "permission denied" errors (jQuery #13936) +	// Support: IE 11+, Edge 17 - 18+ +	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing +	// two documents; shallow comparisons work. +	// eslint-disable-next-line eqeqeq +	if ( preferredDoc != document && +		( subWindow = document.defaultView ) && subWindow.top !== subWindow ) { + +		// Support: IE 11, Edge +		if ( subWindow.addEventListener ) { +			subWindow.addEventListener( "unload", unloadHandler, false ); + +		// Support: IE 9 - 10 only +		} else if ( subWindow.attachEvent ) { +			subWindow.attachEvent( "onunload", unloadHandler ); +		} +	} + +	// Support: IE 8 - 11+, Edge 12 - 18+, Chrome <=16 - 25 only, Firefox <=3.6 - 31 only, +	// Safari 4 - 5 only, Opera <=11.6 - 12.x only +	// IE/Edge & older browsers don't support the :scope pseudo-class. +	// Support: Safari 6.0 only +	// Safari 6.0 supports :scope but it's an alias of :root there. +	support.scope = assert( function( el ) { +		docElem.appendChild( el ).appendChild( document.createElement( "div" ) ); +		return typeof el.querySelectorAll !== "undefined" && +			!el.querySelectorAll( ":scope fieldset div" ).length; +	} ); + +	/* Attributes +	---------------------------------------------------------------------- */ + +	// Support: IE<8 +	// Verify that getAttribute really returns attributes and not properties +	// (excepting IE8 booleans) +	support.attributes = assert( function( el ) { +		el.className = "i"; +		return !el.getAttribute( "className" ); +	} ); + +	/* getElement(s)By* +	---------------------------------------------------------------------- */ + +	// Check if getElementsByTagName("*") returns only elements +	support.getElementsByTagName = assert( function( el ) { +		el.appendChild( document.createComment( "" ) ); +		return !el.getElementsByTagName( "*" ).length; +	} ); + +	// Support: IE<9 +	support.getElementsByClassName = rnative.test( document.getElementsByClassName ); + +	// Support: IE<10 +	// Check if getElementById returns elements by name +	// The broken getElementById methods don't pick up programmatically-set names, +	// so use a roundabout getElementsByName test +	support.getById = assert( function( el ) { +		docElem.appendChild( el ).id = expando; +		return !document.getElementsByName || !document.getElementsByName( expando ).length; +	} ); + +	// ID filter and find +	if ( support.getById ) { +		Expr.filter[ "ID" ] = function( id ) { +			var attrId = id.replace( runescape, funescape ); +			return function( elem ) { +				return elem.getAttribute( "id" ) === attrId; +			}; +		}; +		Expr.find[ "ID" ] = function( id, context ) { +			if ( typeof context.getElementById !== "undefined" && documentIsHTML ) { +				var elem = context.getElementById( id ); +				return elem ? [ elem ] : []; +			} +		}; +	} else { +		Expr.filter[ "ID" ] =  function( id ) { +			var attrId = id.replace( runescape, funescape ); +			return function( elem ) { +				var node = typeof elem.getAttributeNode !== "undefined" && +					elem.getAttributeNode( "id" ); +				return node && node.value === attrId; +			}; +		}; + +		// Support: IE 6 - 7 only +		// getElementById is not reliable as a find shortcut +		Expr.find[ "ID" ] = function( id, context ) { +			if ( typeof context.getElementById !== "undefined" && documentIsHTML ) { +				var node, i, elems, +					elem = context.getElementById( id ); + +				if ( elem ) { + +					// Verify the id attribute +					node = elem.getAttributeNode( "id" ); +					if ( node && node.value === id ) { +						return [ elem ]; +					} + +					// Fall back on getElementsByName +					elems = context.getElementsByName( id ); +					i = 0; +					while ( ( elem = elems[ i++ ] ) ) { +						node = elem.getAttributeNode( "id" ); +						if ( node && node.value === id ) { +							return [ elem ]; +						} +					} +				} + +				return []; +			} +		}; +	} + +	// Tag +	Expr.find[ "TAG" ] = support.getElementsByTagName ? +		function( tag, context ) { +			if ( typeof context.getElementsByTagName !== "undefined" ) { +				return context.getElementsByTagName( tag ); + +			// DocumentFragment nodes don't have gEBTN +			} else if ( support.qsa ) { +				return context.querySelectorAll( tag ); +			} +		} : + +		function( tag, context ) { +			var elem, +				tmp = [], +				i = 0, + +				// By happy coincidence, a (broken) gEBTN appears on DocumentFragment nodes too +				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 !== "undefined" && 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 https://bugs.jquery.com/ticket/13378 +	rbuggyQSA = []; + +	if ( ( support.qsa = rnative.test( document.querySelectorAll ) ) ) { + +		// Build QSA regex +		// Regex strategy adopted from Diego Perini +		assert( function( el ) { + +			var input; + +			// 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 +			// https://bugs.jquery.com/ticket/12359 +			docElem.appendChild( el ).innerHTML = "<a id='" + expando + "'></a>" + +				"<select id='" + expando + "-\r\\' msallowcapture=''>" + +				"<option selected=''></option></select>"; + +			// 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 +			// https://msdn.microsoft.com/en-us/library/ie/hh465388.aspx#attribute_section +			if ( el.querySelectorAll( "[msallowcapture^='']" ).length ) { +				rbuggyQSA.push( "[*^$]=" + whitespace + "*(?:''|\"\")" ); +			} + +			// Support: IE8 +			// Boolean attributes and "value" are not treated correctly +			if ( !el.querySelectorAll( "[selected]" ).length ) { +				rbuggyQSA.push( "\\[" + whitespace + "*(?:value|" + booleans + ")" ); +			} + +			// Support: Chrome<29, Android<4.4, Safari<7.0+, iOS<7.0+, PhantomJS<1.9.8+ +			if ( !el.querySelectorAll( "[id~=" + expando + "-]" ).length ) { +				rbuggyQSA.push( "~=" ); +			} + +			// Support: IE 11+, Edge 15 - 18+ +			// IE 11/Edge don't find elements on a `[name='']` query in some cases. +			// Adding a temporary attribute to the document before the selection works +			// around the issue. +			// Interestingly, IE 10 & older don't seem to have the issue. +			input = document.createElement( "input" ); +			input.setAttribute( "name", "" ); +			el.appendChild( input ); +			if ( !el.querySelectorAll( "[name='']" ).length ) { +				rbuggyQSA.push( "\\[" + whitespace + "*name" + whitespace + "*=" + +					whitespace + "*(?:''|\"\")" ); +			} + +			// 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 ( !el.querySelectorAll( ":checked" ).length ) { +				rbuggyQSA.push( ":checked" ); +			} + +			// Support: Safari 8+, iOS 8+ +			// https://bugs.webkit.org/show_bug.cgi?id=136851 +			// In-page `selector#id sibling-combinator selector` fails +			if ( !el.querySelectorAll( "a#" + expando + "+*" ).length ) { +				rbuggyQSA.push( ".#.+[+~]" ); +			} + +			// Support: Firefox <=3.6 - 5 only +			// Old Firefox doesn't throw on a badly-escaped identifier. +			el.querySelectorAll( "\\\f" ); +			rbuggyQSA.push( "[\\r\\n\\f]" ); +		} ); + +		assert( function( el ) { +			el.innerHTML = "<a href='' disabled='disabled'></a>" + +				"<select disabled='disabled'><option/></select>"; + +			// Support: Windows 8 Native Apps +			// The type and name attributes are restricted during .innerHTML assignment +			var input = document.createElement( "input" ); +			input.setAttribute( "type", "hidden" ); +			el.appendChild( input ).setAttribute( "name", "D" ); + +			// Support: IE8 +			// Enforce case-sensitivity of name attribute +			if ( el.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 ( el.querySelectorAll( ":enabled" ).length !== 2 ) { +				rbuggyQSA.push( ":enabled", ":disabled" ); +			} + +			// Support: IE9-11+ +			// IE's :disabled selector does not pick up the children of disabled fieldsets +			docElem.appendChild( el ).disabled = true; +			if ( el.querySelectorAll( ":disabled" ).length !== 2 ) { +				rbuggyQSA.push( ":enabled", ":disabled" ); +			} + +			// Support: Opera 10 - 11 only +			// Opera 10-11 does not throw on post-comma invalid pseudos +			el.querySelectorAll( "*,:x" ); +			rbuggyQSA.push( ",.*:" ); +		} ); +	} + +	if ( ( support.matchesSelector = rnative.test( ( matches = docElem.matches || +		docElem.webkitMatchesSelector || +		docElem.mozMatchesSelector || +		docElem.oMatchesSelector || +		docElem.msMatchesSelector ) ) ) ) { + +		assert( function( el ) { + +			// Check to see if it's possible to do matchesSelector +			// on a disconnected node (IE 9) +			support.disconnectedMatch = matches.call( el, "*" ); + +			// This should fail with an exception +			// Gecko does not error, returns false instead +			matches.call( el, "[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 self-exclusive +	// 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 +		// Support: IE 11+, Edge 17 - 18+ +		// IE/Edge sometimes throw a "Permission denied" error when strict-comparing +		// two documents; shallow comparisons work. +		// eslint-disable-next-line eqeqeq +		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 +			// Support: IE 11+, Edge 17 - 18+ +			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing +			// two documents; shallow comparisons work. +			// eslint-disable-next-line eqeqeq +			if ( a == document || a.ownerDocument == preferredDoc && +				contains( preferredDoc, a ) ) { +				return -1; +			} + +			// Support: IE 11+, Edge 17 - 18+ +			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing +			// two documents; shallow comparisons work. +			// eslint-disable-next-line eqeqeq +			if ( b == document || b.ownerDocument == preferredDoc && +				contains( preferredDoc, b ) ) { +				return 1; +			} + +			// Maintain original order +			return sortInput ? +				( indexOf( sortInput, a ) - indexOf( 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 ) { + +			// Support: IE 11+, Edge 17 - 18+ +			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing +			// two documents; shallow comparisons work. +			/* eslint-disable eqeqeq */ +			return a == document ? -1 : +				b == document ? 1 : +				/* eslint-enable eqeqeq */ +				aup ? -1 : +				bup ? 1 : +				sortInput ? +				( indexOf( sortInput, a ) - indexOf( 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 +			// Support: IE 11+, Edge 17 - 18+ +			// IE/Edge sometimes throw a "Permission denied" error when strict-comparing +			// two documents; shallow comparisons work. +			/* eslint-disable eqeqeq */ +			ap[ i ] == preferredDoc ? -1 : +			bp[ i ] == preferredDoc ? 1 : +			/* eslint-enable eqeqeq */ +			0; +	}; + +	return document; +}; + +Sizzle.matches = function( expr, elements ) { +	return Sizzle( expr, null, null, elements ); +}; + +Sizzle.matchesSelector = function( elem, expr ) { +	setDocument( elem ); + +	if ( support.matchesSelector && documentIsHTML && +		!nonnativeSelectorCache[ expr + " " ] && +		( !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 ) { +			nonnativeSelectorCache( expr, true ); +		} +	} + +	return Sizzle( expr, document, null, [ elem ] ).length > 0; +}; + +Sizzle.contains = function( context, elem ) { + +	// Set document vars if needed +	// Support: IE 11+, Edge 17 - 18+ +	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing +	// two documents; shallow comparisons work. +	// eslint-disable-next-line eqeqeq +	if ( ( context.ownerDocument || context ) != document ) { +		setDocument( context ); +	} +	return contains( context, elem ); +}; + +Sizzle.attr = function( elem, name ) { + +	// Set document vars if needed +	// Support: IE 11+, Edge 17 - 18+ +	// IE/Edge sometimes throw a "Permission denied" error when strict-comparing +	// two documents; shallow comparisons work. +	// eslint-disable-next-line eqeqeq +	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.escape = function( sel ) { +	return ( sel + "" ).replace( rcssescape, fcssescape ); +}; + +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 !== "undefined" && +									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 += ""; + +				/* eslint-disable max-len */ + +				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.replace( rwhitespace, " " ) + " " ).indexOf( check ) > -1 : +					operator === "|=" ? result === check || result.slice( 0, check.length + 1 ) === check + "-" : +					false; +				/* eslint-enable max-len */ + +			}; +		}, + +		"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, uniqueCache, outerCache, node, nodeIndex, start, +						dir = simple !== forward ? "nextSibling" : "previousSibling", +						parent = elem.parentNode, +						name = ofType && elem.nodeName.toLowerCase(), +						useCache = !xml && !ofType, +						diff = false; + +					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 + +							// ...in a gzip-friendly way +							node = parent; +							outerCache = node[ expando ] || ( node[ expando ] = {} ); + +							// Support: IE <9 only +							// Defend against cloned attroperties (jQuery gh-1709) +							uniqueCache = outerCache[ node.uniqueID ] || +								( outerCache[ node.uniqueID ] = {} ); + +							cache = uniqueCache[ type ] || []; +							nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ]; +							diff = nodeIndex && 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 ) { +									uniqueCache[ type ] = [ dirruns, nodeIndex, diff ]; +									break; +								} +							} + +						} else { + +							// Use previously-cached element index if available +							if ( useCache ) { + +								// ...in a gzip-friendly way +								node = elem; +								outerCache = node[ expando ] || ( node[ expando ] = {} ); + +								// Support: IE <9 only +								// Defend against cloned attroperties (jQuery gh-1709) +								uniqueCache = outerCache[ node.uniqueID ] || +									( outerCache[ node.uniqueID ] = {} ); + +								cache = uniqueCache[ type ] || []; +								nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ]; +								diff = nodeIndex; +							} + +							// xml :nth-child(...) +							// or :nth-last-child(...) or :nth(-last)?-of-type(...) +							if ( diff === false ) { + +								// 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 ) { +											outerCache = node[ expando ] || +												( node[ expando ] = {} ); + +											// Support: IE <9 only +											// Defend against cloned attroperties (jQuery gh-1709) +											uniqueCache = outerCache[ node.uniqueID ] || +												( outerCache[ node.uniqueID ] = {} ); + +											uniqueCache[ 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( 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 ); + +					// Don't keep the element (issue #299) +					input[ 0 ] = null; +					return !results.pop(); +				}; +		} ), + +		"has": markFunction( function( selector ) { +			return function( elem ) { +				return Sizzle( selector, elem ).length > 0; +			}; +		} ), + +		"contains": markFunction( function( text ) { +			text = text.replace( runescape, funescape ); +			return function( elem ) { +				return ( elem.textContent || 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": createDisabledPseudo( false ), +		"disabled": createDisabledPseudo( 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 ) { +				// eslint-disable-next-line no-unused-expressions +				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 > length ? +					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, +		skip = combinator.next, +		key = skip || dir, +		checkNonElements = base && key === "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 ); +				} +			} +			return false; +		} : + +		// Check against all ancestor/preceding elements +		function( elem, context, xml ) { +			var oldCache, uniqueCache, outerCache, +				newCache = [ dirruns, doneName ]; + +			// We can't set arbitrary data on XML nodes, so they don't benefit from combinator 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 ] = {} ); + +						// Support: IE <9 only +						// Defend against cloned attroperties (jQuery gh-1709) +						uniqueCache = outerCache[ elem.uniqueID ] || +							( outerCache[ elem.uniqueID ] = {} ); + +						if ( skip && skip === elem.nodeName.toLowerCase() ) { +							elem = elem[ dir ] || elem; +						} else if ( ( oldCache = uniqueCache[ key ] ) && +							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 +							uniqueCache[ key ] = newCache; + +							// A match means we're done; a fail means we have to keep checking +							if ( ( newCache[ 2 ] = matcher( elem, context, xml ) ) ) { +								return true; +							} +						} +					} +				} +			} +			return false; +		}; +} + +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( 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( checkContext, elem ) > -1; +		}, implicitRelative, true ), +		matchers = [ function( elem, context, xml ) { +			var ret = ( !leadingRelative && ( xml || context !== outermostContext ) ) || ( +				( checkContext = context ).nodeType ? +					matchContext( elem, context, xml ) : +					matchAnyContext( elem, context, xml ) ); + +			// Avoid hanging onto element (issue #299) +			checkContext = null; +			return ret; +		} ]; + +	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 ) { + +				// Support: IE 11+, Edge 17 - 18+ +				// IE/Edge sometimes throw a "Permission denied" error when strict-comparing +				// two documents; shallow comparisons work. +				// eslint-disable-next-line eqeqeq +				outermostContext = context == document || context || outermost; +			} + +			// Add elements passing elementMatchers directly to results +			// Support: IE<9, Safari +			// Tolerate NodeList properties (IE: "length"; Safari: <number>) matching elements by id +			for ( ; i !== len && ( elem = elems[ i ] ) != null; i++ ) { +				if ( byElement && elem ) { +					j = 0; + +					// Support: IE 11+, Edge 17 - 18+ +					// IE/Edge sometimes throw a "Permission denied" error when strict-comparing +					// two documents; shallow comparisons work. +					// eslint-disable-next-line eqeqeq +					if ( !context && elem.ownerDocument != document ) { +						setDocument( elem ); +						xml = !documentIsHTML; +					} +					while ( ( matcher = elementMatchers[ j++ ] ) ) { +						if ( matcher( elem, context || document, 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 ); +					} +				} +			} + +			// `i` is now the count of elements visited above, and adding it to `matchedCount` +			// makes the latter nonnegative. +			matchedCount += i; + +			// Apply set filters to unmatched elements +			// NOTE: This can be skipped if there are no unmatched elements (i.e., `matchedCount` +			// equals `i`), unless we didn't visit _any_ elements in the above loop because we have +			// no element matchers and no seed. +			// Incrementing an initially-string "0" `i` allows `i` to remain a string only in that +			// case, which will result in a "00" `matchedCount` that differs from `i` but is also +			// numerically zero. +			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 only one selector in the list and no seed +	// (the latter of which guarantees us context) +	if ( match.length === 1 ) { + +		// Reduce context if the leading compound selector is an ID +		tokens = match[ 0 ] = match[ 0 ].slice( 0 ); +		if ( tokens.length > 2 && ( token = tokens[ 0 ] ).type === "ID" && +			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, +		!context || 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-35+ +// 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( el ) { + +	// Should return 1, but returns 4 (following) +	return el.compareDocumentPosition( document.createElement( "fieldset" ) ) & 1; +} ); + +// Support: IE<8 +// Prevent attribute/property "interpolation" +// https://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx +if ( !assert( function( el ) { +	el.innerHTML = "<a href='#'></a>"; +	return el.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( el ) { +	el.innerHTML = "<input/>"; +	el.firstChild.setAttribute( "value", "" ); +	return el.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( el ) { +	return el.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; + +// Deprecated +jQuery.expr[ ":" ] = jQuery.expr.pseudos; +jQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort; +jQuery.text = Sizzle.getText; +jQuery.isXMLDoc = Sizzle.isXML; +jQuery.contains = Sizzle.contains; +jQuery.escapeSelector = Sizzle.escape; + + + + +var dir = function( elem, dir, until ) { +	var matched = [], +		truncate = until !== undefined; + +	while ( ( elem = elem[ dir ] ) && elem.nodeType !== 9 ) { +		if ( elem.nodeType === 1 ) { +			if ( truncate && jQuery( elem ).is( until ) ) { +				break; +			} +			matched.push( elem ); +		} +	} +	return matched; +}; + + +var siblings = function( n, elem ) { +	var matched = []; + +	for ( ; n; n = n.nextSibling ) { +		if ( n.nodeType === 1 && n !== elem ) { +			matched.push( n ); +		} +	} + +	return matched; +}; + + +var rneedsContext = jQuery.expr.match.needsContext; + + + +function nodeName( elem, name ) { + +	return elem.nodeName && elem.nodeName.toLowerCase() === name.toLowerCase(); + +} +var rsingleTag = ( /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i ); + + + +// Implement the identical functionality for filter and not +function winnow( elements, qualifier, not ) { +	if ( isFunction( qualifier ) ) { +		return jQuery.grep( elements, function( elem, i ) { +			return !!qualifier.call( elem, i, elem ) !== not; +		} ); +	} + +	// Single element +	if ( qualifier.nodeType ) { +		return jQuery.grep( elements, function( elem ) { +			return ( elem === qualifier ) !== not; +		} ); +	} + +	// Arraylike of elements (jQuery, arguments, Array) +	if ( typeof qualifier !== "string" ) { +		return jQuery.grep( elements, function( elem ) { +			return ( indexOf.call( qualifier, elem ) > -1 ) !== not; +		} ); +	} + +	// Filtered directly for both simple and complex selectors +	return jQuery.filter( qualifier, elements, not ); +} + +jQuery.filter = function( expr, elems, not ) { +	var elem = elems[ 0 ]; + +	if ( not ) { +		expr = ":not(" + expr + ")"; +	} + +	if ( elems.length === 1 && elem.nodeType === 1 ) { +		return jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : []; +	} + +	return jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) { +		return elem.nodeType === 1; +	} ) ); +}; + +jQuery.fn.extend( { +	find: function( selector ) { +		var i, ret, +			len = this.length, +			self = this; + +		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; +					} +				} +			} ) ); +		} + +		ret = this.pushStack( [] ); + +		for ( i = 0; i < len; i++ ) { +			jQuery.find( selector, self[ i ], ret ); +		} + +		return len > 1 ? jQuery.uniqueSort( ret ) : 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, + +	// A simple way to check for HTML strings +	// Prioritize #id over <tag> to avoid XSS via location.hash (#9521) +	// Strict HTML recognition (#11290: must start with <) +	// Shortcut simple #id case for speed +	rquickExpr = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/, + +	init = jQuery.fn.init = function( selector, context, root ) { +		var match, elem; + +		// HANDLE: $(""), $(null), $(undefined), $(false) +		if ( !selector ) { +			return this; +		} + +		// Method init() accepts an alternate rootjQuery +		// so migrate can support jQuery.sub (gh-2101) +		root = root || rootjQuery; + +		// Handle HTML strings +		if ( typeof selector === "string" ) { +			if ( selector[ 0 ] === "<" && +				selector[ 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; + +					// Option to run 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 ( 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 ] ); + +					if ( elem ) { + +						// Inject the element directly into the jQuery object +						this[ 0 ] = elem; +						this.length = 1; +					} +					return this; +				} + +			// HANDLE: $(expr, $(...)) +			} else if ( !context || context.jquery ) { +				return ( context || root ).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[ 0 ] = selector; +			this.length = 1; +			return this; + +		// HANDLE: $(function) +		// Shortcut for document ready +		} else if ( isFunction( selector ) ) { +			return root.ready !== undefined ? +				root.ready( selector ) : + +				// Execute immediately if ready is not present +				selector( jQuery ); +		} + +		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.fn.extend( { +	has: function( target ) { +		var targets = jQuery( target, this ), +			l = targets.length; + +		return this.filter( function() { +			var i = 0; +			for ( ; i < l; i++ ) { +				if ( jQuery.contains( this, targets[ i ] ) ) { +					return true; +				} +			} +		} ); +	}, + +	closest: function( selectors, context ) { +		var cur, +			i = 0, +			l = this.length, +			matched = [], +			targets = typeof selectors !== "string" && jQuery( selectors ); + +		// Positional selectors never match, since there's no _selection_ context +		if ( !rneedsContext.test( selectors ) ) { +			for ( ; i < l; i++ ) { +				for ( cur = this[ i ]; cur && cur !== context; cur = cur.parentNode ) { + +					// Always skip document fragments +					if ( cur.nodeType < 11 && ( targets ? +						targets.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.uniqueSort( matched ) : matched ); +	}, + +	// Determine the position of an element within the set +	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 indexOf.call( jQuery( elem ), this[ 0 ] ); +		} + +		// Locate the position of the desired element +		return indexOf.call( this, + +			// If it receives a jQuery object, the first element is used +			elem.jquery ? elem[ 0 ] : elem +		); +	}, + +	add: function( selector, context ) { +		return this.pushStack( +			jQuery.uniqueSort( +				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 ) { +	while ( ( cur = cur[ dir ] ) && 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 dir( elem, "parentNode" ); +	}, +	parentsUntil: function( elem, _i, until ) { +		return dir( elem, "parentNode", until ); +	}, +	next: function( elem ) { +		return sibling( elem, "nextSibling" ); +	}, +	prev: function( elem ) { +		return sibling( elem, "previousSibling" ); +	}, +	nextAll: function( elem ) { +		return dir( elem, "nextSibling" ); +	}, +	prevAll: function( elem ) { +		return dir( elem, "previousSibling" ); +	}, +	nextUntil: function( elem, _i, until ) { +		return dir( elem, "nextSibling", until ); +	}, +	prevUntil: function( elem, _i, until ) { +		return dir( elem, "previousSibling", until ); +	}, +	siblings: function( elem ) { +		return siblings( ( elem.parentNode || {} ).firstChild, elem ); +	}, +	children: function( elem ) { +		return siblings( elem.firstChild ); +	}, +	contents: function( elem ) { +		if ( elem.contentDocument != null && + +			// Support: IE 11+ +			// <object> elements with no `data` attribute has an object +			// `contentDocument` with a `null` prototype. +			getProto( elem.contentDocument ) ) { + +			return elem.contentDocument; +		} + +		// Support: IE 9 - 11 only, iOS 7 only, Android Browser <=4.3 only +		// Treat the template element as a regular one in browsers that +		// don't support it. +		if ( nodeName( elem, "template" ) ) { +			elem = elem.content || elem; +		} + +		return jQuery.merge( [], elem.childNodes ); +	} +}, function( name, fn ) { +	jQuery.fn[ name ] = function( until, selector ) { +		var matched = jQuery.map( this, fn, until ); + +		if ( name.slice( -5 ) !== "Until" ) { +			selector = until; +		} + +		if ( selector && typeof selector === "string" ) { +			matched = jQuery.filter( selector, matched ); +		} + +		if ( this.length > 1 ) { + +			// Remove duplicates +			if ( !guaranteedUnique[ name ] ) { +				jQuery.uniqueSort( matched ); +			} + +			// Reverse order for parents* and prev-derivatives +			if ( rparentsprev.test( name ) ) { +				matched.reverse(); +			} +		} + +		return this.pushStack( matched ); +	}; +} ); +var rnothtmlwhite = ( /[^\x20\t\r\n\f]+/g ); + + + +// Convert String-formatted options into Object-formatted ones +function createOptions( options ) { +	var object = {}; +	jQuery.each( options.match( rnothtmlwhite ) || [], 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" ? +		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, + +		// Flag to prevent firing +		locked, + +		// Actual callback list +		list = [], + +		// Queue of execution data for repeatable lists +		queue = [], + +		// Index of currently firing callback (modified by add/remove as needed) +		firingIndex = -1, + +		// Fire callbacks +		fire = function() { + +			// Enforce single-firing +			locked = locked || options.once; + +			// Execute callbacks for all pending executions, +			// respecting firingIndex overrides and runtime changes +			fired = firing = true; +			for ( ; queue.length; firingIndex = -1 ) { +				memory = queue.shift(); +				while ( ++firingIndex < list.length ) { + +					// Run callback and check for early termination +					if ( list[ firingIndex ].apply( memory[ 0 ], memory[ 1 ] ) === false && +						options.stopOnFalse ) { + +						// Jump to end and forget the data so .add doesn't re-fire +						firingIndex = list.length; +						memory = false; +					} +				} +			} + +			// Forget the data if we're done with it +			if ( !options.memory ) { +				memory = false; +			} + +			firing = false; + +			// Clean up if we're done firing for good +			if ( locked ) { + +				// Keep an empty list if we have data for future add calls +				if ( memory ) { +					list = []; + +				// Otherwise, this object is spent +				} else { +					list = ""; +				} +			} +		}, + +		// Actual Callbacks object +		self = { + +			// Add a callback or a collection of callbacks to the list +			add: function() { +				if ( list ) { + +					// If we have memory from a past run, we should fire after adding +					if ( memory && !firing ) { +						firingIndex = list.length - 1; +						queue.push( memory ); +					} + +					( function add( args ) { +						jQuery.each( args, function( _, arg ) { +							if ( isFunction( arg ) ) { +								if ( !options.unique || !self.has( arg ) ) { +									list.push( arg ); +								} +							} else if ( arg && arg.length && toType( arg ) !== "string" ) { + +								// Inspect recursively +								add( arg ); +							} +						} ); +					} )( arguments ); + +					if ( memory && !firing ) { +						fire(); +					} +				} +				return this; +			}, + +			// Remove a callback from the list +			remove: function() { +				jQuery.each( arguments, function( _, arg ) { +					var index; +					while ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) { +						list.splice( index, 1 ); + +						// Handle firing indexes +						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.length > 0; +			}, + +			// Remove all callbacks from the list +			empty: function() { +				if ( list ) { +					list = []; +				} +				return this; +			}, + +			// Disable .fire and .add +			// Abort any current/pending executions +			// Clear all callbacks and values +			disable: function() { +				locked = queue = []; +				list = memory = ""; +				return this; +			}, +			disabled: function() { +				return !list; +			}, + +			// Disable .fire +			// Also disable .add unless we have memory (since it would have no effect) +			// Abort any pending executions +			lock: function() { +				locked = queue = []; +				if ( !memory && !firing ) { +					list = memory = ""; +				} +				return this; +			}, +			locked: function() { +				return !!locked; +			}, + +			// Call all callbacks with the given context and arguments +			fireWith: function( context, args ) { +				if ( !locked ) { +					args = args || []; +					args = [ context, args.slice ? args.slice() : args ]; +					queue.push( args ); +					if ( !firing ) { +						fire(); +					} +				} +				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; +}; + + +function Identity( v ) { +	return v; +} +function Thrower( ex ) { +	throw ex; +} + +function adoptValue( value, resolve, reject, noValue ) { +	var method; + +	try { + +		// Check for promise aspect first to privilege synchronous behavior +		if ( value && isFunction( ( method = value.promise ) ) ) { +			method.call( value ).done( resolve ).fail( reject ); + +		// Other thenables +		} else if ( value && isFunction( ( method = value.then ) ) ) { +			method.call( value, resolve, reject ); + +		// Other non-thenables +		} else { + +			// Control `resolve` arguments by letting Array#slice cast boolean `noValue` to integer: +			// * false: [ value ].slice( 0 ) => resolve( value ) +			// * true: [ value ].slice( 1 ) => resolve() +			resolve.apply( undefined, [ value ].slice( noValue ) ); +		} + +	// For Promises/A+, convert exceptions into rejections +	// Since jQuery.when doesn't unwrap thenables, we can skip the extra checks appearing in +	// Deferred#then to conditionally suppress rejection. +	} catch ( value ) { + +		// Support: Android 4.0 only +		// Strict mode functions invoked without .call/.apply get global-object context +		reject.apply( undefined, [ value ] ); +	} +} + +jQuery.extend( { + +	Deferred: function( func ) { +		var tuples = [ + +				// action, add listener, callbacks, +				// ... .then handlers, argument index, [final state] +				[ "notify", "progress", jQuery.Callbacks( "memory" ), +					jQuery.Callbacks( "memory" ), 2 ], +				[ "resolve", "done", jQuery.Callbacks( "once memory" ), +					jQuery.Callbacks( "once memory" ), 0, "resolved" ], +				[ "reject", "fail", jQuery.Callbacks( "once memory" ), +					jQuery.Callbacks( "once memory" ), 1, "rejected" ] +			], +			state = "pending", +			promise = { +				state: function() { +					return state; +				}, +				always: function() { +					deferred.done( arguments ).fail( arguments ); +					return this; +				}, +				"catch": function( fn ) { +					return promise.then( null, fn ); +				}, + +				// Keep pipe for back-compat +				pipe: function( /* fnDone, fnFail, fnProgress */ ) { +					var fns = arguments; + +					return jQuery.Deferred( function( newDefer ) { +						jQuery.each( tuples, function( _i, tuple ) { + +							// Map tuples (progress, done, fail) to arguments (done, fail, progress) +							var fn = isFunction( fns[ tuple[ 4 ] ] ) && fns[ tuple[ 4 ] ]; + +							// deferred.progress(function() { bind to newDefer or newDefer.notify }) +							// deferred.done(function() { bind to newDefer or newDefer.resolve }) +							// deferred.fail(function() { bind to newDefer or newDefer.reject }) +							deferred[ tuple[ 1 ] ]( function() { +								var returned = fn && fn.apply( this, arguments ); +								if ( returned && isFunction( returned.promise ) ) { +									returned.promise() +										.progress( newDefer.notify ) +										.done( newDefer.resolve ) +										.fail( newDefer.reject ); +								} else { +									newDefer[ tuple[ 0 ] + "With" ]( +										this, +										fn ? [ returned ] : arguments +									); +								} +							} ); +						} ); +						fns = null; +					} ).promise(); +				}, +				then: function( onFulfilled, onRejected, onProgress ) { +					var maxDepth = 0; +					function resolve( depth, deferred, handler, special ) { +						return function() { +							var that = this, +								args = arguments, +								mightThrow = function() { +									var returned, then; + +									// Support: Promises/A+ section 2.3.3.3.3 +									// https://promisesaplus.com/#point-59 +									// Ignore double-resolution attempts +									if ( depth < maxDepth ) { +										return; +									} + +									returned = handler.apply( that, args ); + +									// Support: Promises/A+ section 2.3.1 +									// https://promisesaplus.com/#point-48 +									if ( returned === deferred.promise() ) { +										throw new TypeError( "Thenable self-resolution" ); +									} + +									// Support: Promises/A+ sections 2.3.3.1, 3.5 +									// https://promisesaplus.com/#point-54 +									// https://promisesaplus.com/#point-75 +									// Retrieve `then` only once +									then = returned && + +										// Support: Promises/A+ section 2.3.4 +										// https://promisesaplus.com/#point-64 +										// Only check objects and functions for thenability +										( typeof returned === "object" || +											typeof returned === "function" ) && +										returned.then; + +									// Handle a returned thenable +									if ( isFunction( then ) ) { + +										// Special processors (notify) just wait for resolution +										if ( special ) { +											then.call( +												returned, +												resolve( maxDepth, deferred, Identity, special ), +												resolve( maxDepth, deferred, Thrower, special ) +											); + +										// Normal processors (resolve) also hook into progress +										} else { + +											// ...and disregard older resolution values +											maxDepth++; + +											then.call( +												returned, +												resolve( maxDepth, deferred, Identity, special ), +												resolve( maxDepth, deferred, Thrower, special ), +												resolve( maxDepth, deferred, Identity, +													deferred.notifyWith ) +											); +										} + +									// Handle all other returned values +									} else { + +										// Only substitute handlers pass on context +										// and multiple values (non-spec behavior) +										if ( handler !== Identity ) { +											that = undefined; +											args = [ returned ]; +										} + +										// Process the value(s) +										// Default process is resolve +										( special || deferred.resolveWith )( that, args ); +									} +								}, + +								// Only normal processors (resolve) catch and reject exceptions +								process = special ? +									mightThrow : +									function() { +										try { +											mightThrow(); +										} catch ( e ) { + +											if ( jQuery.Deferred.exceptionHook ) { +												jQuery.Deferred.exceptionHook( e, +													process.stackTrace ); +											} + +											// Support: Promises/A+ section 2.3.3.3.4.1 +											// https://promisesaplus.com/#point-61 +											// Ignore post-resolution exceptions +											if ( depth + 1 >= maxDepth ) { + +												// Only substitute handlers pass on context +												// and multiple values (non-spec behavior) +												if ( handler !== Thrower ) { +													that = undefined; +													args = [ e ]; +												} + +												deferred.rejectWith( that, args ); +											} +										} +									}; + +							// Support: Promises/A+ section 2.3.3.3.1 +							// https://promisesaplus.com/#point-57 +							// Re-resolve promises immediately to dodge false rejection from +							// subsequent errors +							if ( depth ) { +								process(); +							} else { + +								// Call an optional hook to record the stack, in case of exception +								// since it's otherwise lost when execution goes async +								if ( jQuery.Deferred.getStackHook ) { +									process.stackTrace = jQuery.Deferred.getStackHook(); +								} +								window.setTimeout( process ); +							} +						}; +					} + +					return jQuery.Deferred( function( newDefer ) { + +						// progress_handlers.add( ... ) +						tuples[ 0 ][ 3 ].add( +							resolve( +								0, +								newDefer, +								isFunction( onProgress ) ? +									onProgress : +									Identity, +								newDefer.notifyWith +							) +						); + +						// fulfilled_handlers.add( ... ) +						tuples[ 1 ][ 3 ].add( +							resolve( +								0, +								newDefer, +								isFunction( onFulfilled ) ? +									onFulfilled : +									Identity +							) +						); + +						// rejected_handlers.add( ... ) +						tuples[ 2 ][ 3 ].add( +							resolve( +								0, +								newDefer, +								isFunction( onRejected ) ? +									onRejected : +									Thrower +							) +						); +					} ).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 = {}; + +		// Add list-specific methods +		jQuery.each( tuples, function( i, tuple ) { +			var list = tuple[ 2 ], +				stateString = tuple[ 5 ]; + +			// promise.progress = list.add +			// promise.done = list.add +			// promise.fail = list.add +			promise[ tuple[ 1 ] ] = list.add; + +			// Handle state +			if ( stateString ) { +				list.add( +					function() { + +						// state = "resolved" (i.e., fulfilled) +						// state = "rejected" +						state = stateString; +					}, + +					// rejected_callbacks.disable +					// fulfilled_callbacks.disable +					tuples[ 3 - i ][ 2 ].disable, + +					// rejected_handlers.disable +					// fulfilled_handlers.disable +					tuples[ 3 - i ][ 3 ].disable, + +					// progress_callbacks.lock +					tuples[ 0 ][ 2 ].lock, + +					// progress_handlers.lock +					tuples[ 0 ][ 3 ].lock +				); +			} + +			// progress_handlers.fire +			// fulfilled_handlers.fire +			// rejected_handlers.fire +			list.add( tuple[ 3 ].fire ); + +			// deferred.notify = function() { deferred.notifyWith(...) } +			// deferred.resolve = function() { deferred.resolveWith(...) } +			// deferred.reject = function() { deferred.rejectWith(...) } +			deferred[ tuple[ 0 ] ] = function() { +				deferred[ tuple[ 0 ] + "With" ]( this === deferred ? undefined : this, arguments ); +				return this; +			}; + +			// deferred.notifyWith = list.fireWith +			// deferred.resolveWith = list.fireWith +			// deferred.rejectWith = list.fireWith +			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( singleValue ) { +		var + +			// count of uncompleted subordinates +			remaining = arguments.length, + +			// count of unprocessed arguments +			i = remaining, + +			// subordinate fulfillment data +			resolveContexts = Array( i ), +			resolveValues = slice.call( arguments ), + +			// the primary Deferred +			primary = jQuery.Deferred(), + +			// subordinate callback factory +			updateFunc = function( i ) { +				return function( value ) { +					resolveContexts[ i ] = this; +					resolveValues[ i ] = arguments.length > 1 ? slice.call( arguments ) : value; +					if ( !( --remaining ) ) { +						primary.resolveWith( resolveContexts, resolveValues ); +					} +				}; +			}; + +		// Single- and empty arguments are adopted like Promise.resolve +		if ( remaining <= 1 ) { +			adoptValue( singleValue, primary.done( updateFunc( i ) ).resolve, primary.reject, +				!remaining ); + +			// Use .then() to unwrap secondary thenables (cf. gh-3000) +			if ( primary.state() === "pending" || +				isFunction( resolveValues[ i ] && resolveValues[ i ].then ) ) { + +				return primary.then(); +			} +		} + +		// Multiple arguments are aggregated like Promise.all array elements +		while ( i-- ) { +			adoptValue( resolveValues[ i ], updateFunc( i ), primary.reject ); +		} + +		return primary.promise(); +	} +} ); + + +// These usually indicate a programmer mistake during development, +// warn about them ASAP rather than swallowing them by default. +var rerrorNames = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/; + +jQuery.Deferred.exceptionHook = function( error, stack ) { + +	// Support: IE 8 - 9 only +	// Console exists when dev tools are open, which can happen at any time +	if ( window.console && window.console.warn && error && rerrorNames.test( error.name ) ) { +		window.console.warn( "jQuery.Deferred exception: " + error.message, error.stack, stack ); +	} +}; + + + + +jQuery.readyException = function( error ) { +	window.setTimeout( function() { +		throw error; +	} ); +}; + + + + +// The deferred used on DOM ready +var readyList = jQuery.Deferred(); + +jQuery.fn.ready = function( fn ) { + +	readyList +		.then( fn ) + +		// Wrap jQuery.readyException in a function so that the lookup +		// happens at the time of error handling instead of callback +		// registration. +		.catch( function( error ) { +			jQuery.readyException( error ); +		} ); + +	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, + +	// 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; +		} + +		// 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 ] ); +	} +} ); + +jQuery.ready.then = readyList.then; + +// The ready event handler and self cleanup method +function completed() { +	document.removeEventListener( "DOMContentLoaded", completed ); +	window.removeEventListener( "load", completed ); +	jQuery.ready(); +} + +// Catch cases where $(document).ready() is called +// after the browser event has already occurred. +// Support: IE <=9 - 10 only +// Older IE sometimes signals "interactive" too soon +if ( document.readyState === "complete" || +	( document.readyState !== "loading" && !document.documentElement.doScroll ) ) { + +	// Handle it asynchronously to allow scripts the opportunity to delay ready +	window.setTimeout( jQuery.ready ); + +} else { + +	// Use the handy event callback +	document.addEventListener( "DOMContentLoaded", completed ); + +	// A fallback to window.onload, that will always work +	window.addEventListener( "load", completed ); +} + + + + +// Multifunctional method to get and set values of a collection +// The value/s can optionally be executed if it's a function +var access = function( elems, fn, key, value, chainable, emptyGet, raw ) { +	var i = 0, +		len = elems.length, +		bulk = key == null; + +	// Sets many values +	if ( toType( key ) === "object" ) { +		chainable = true; +		for ( i in key ) { +			access( elems, fn, i, key[ i ], true, emptyGet, raw ); +		} + +	// Sets one value +	} else if ( value !== undefined ) { +		chainable = true; + +		if ( !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 < len; i++ ) { +				fn( +					elems[ i ], key, raw ? +						value : +						value.call( elems[ i ], i, fn( elems[ i ], key ) ) +				); +			} +		} +	} + +	if ( chainable ) { +		return elems; +	} + +	// Gets +	if ( bulk ) { +		return fn.call( elems ); +	} + +	return len ? fn( elems[ 0 ], key ) : emptyGet; +}; + + +// Matches dashed string for camelizing +var rmsPrefix = /^-ms-/, +	rdashAlpha = /-([a-z])/g; + +// Used by camelCase as callback to replace() +function fcamelCase( _all, letter ) { +	return letter.toUpperCase(); +} + +// Convert dashed to camelCase; used by the css and data modules +// Support: IE <=9 - 11, Edge 12 - 15 +// Microsoft forgot to hump their vendor prefix (#9572) +function camelCase( string ) { +	return string.replace( rmsPrefix, "ms-" ).replace( rdashAlpha, fcamelCase ); +} +var acceptData = function( owner ) { + +	// Accepts only: +	//  - Node +	//    - Node.ELEMENT_NODE +	//    - Node.DOCUMENT_NODE +	//  - Object +	//    - Any +	return owner.nodeType === 1 || owner.nodeType === 9 || !( +owner.nodeType ); +}; + + + + +function Data() { +	this.expando = jQuery.expando + Data.uid++; +} + +Data.uid = 1; + +Data.prototype = { + +	cache: function( owner ) { + +		// Check if the owner object already has a cache +		var value = owner[ this.expando ]; + +		// If not, create one +		if ( !value ) { +			value = {}; + +			// We can accept data for non-element nodes in modern browsers, +			// but we should not, see #8335. +			// Always return an empty object. +			if ( acceptData( owner ) ) { + +				// If it is a node unlikely to be stringify-ed or looped over +				// use plain assignment +				if ( owner.nodeType ) { +					owner[ this.expando ] = value; + +				// Otherwise secure it in a non-enumerable property +				// configurable must be true to allow the property to be +				// deleted when data is removed +				} else { +					Object.defineProperty( owner, this.expando, { +						value: value, +						configurable: true +					} ); +				} +			} +		} + +		return value; +	}, +	set: function( owner, data, value ) { +		var prop, +			cache = this.cache( owner ); + +		// Handle: [ owner, key, value ] args +		// Always use camelCase key (gh-2257) +		if ( typeof data === "string" ) { +			cache[ camelCase( data ) ] = value; + +		// Handle: [ owner, { properties } ] args +		} else { + +			// Copy the properties one-by-one to the cache object +			for ( prop in data ) { +				cache[ camelCase( prop ) ] = data[ prop ]; +			} +		} +		return cache; +	}, +	get: function( owner, key ) { +		return key === undefined ? +			this.cache( owner ) : + +			// Always use camelCase key (gh-2257) +			owner[ this.expando ] && owner[ this.expando ][ camelCase( key ) ]; +	}, +	access: function( owner, key, value ) { + +		// In cases where either: +		// +		//   1. No key was specified +		//   2. A string key was specified, but no value provided +		// +		// Take the "read" path and allow the get method to determine +		// which value to return, respectively either: +		// +		//   1. The entire cache object +		//   2. The data stored at the key +		// +		if ( key === undefined || +				( ( key && typeof key === "string" ) && value === undefined ) ) { + +			return this.get( owner, key ); +		} + +		// When the key is not a string, or both a key and value +		// are specified, set or extend (existing objects) with either: +		// +		//   1. An object of properties +		//   2. A key and value +		// +		this.set( owner, key, value ); + +		// Since the "set" path can have two possible entry points +		// return the expected data based on which path was taken[*] +		return value !== undefined ? value : key; +	}, +	remove: function( owner, key ) { +		var i, +			cache = owner[ this.expando ]; + +		if ( cache === undefined ) { +			return; +		} + +		if ( key !== undefined ) { + +			// Support array or space separated string of keys +			if ( Array.isArray( key ) ) { + +				// If key is an array of keys... +				// We always set camelCase keys, so remove that. +				key = key.map( camelCase ); +			} else { +				key = camelCase( key ); + +				// If a key with the spaces exists, use it. +				// Otherwise, create an array by matching non-whitespace +				key = key in cache ? +					[ key ] : +					( key.match( rnothtmlwhite ) || [] ); +			} + +			i = key.length; + +			while ( i-- ) { +				delete cache[ key[ i ] ]; +			} +		} + +		// Remove the expando if there's no more data +		if ( key === undefined || jQuery.isEmptyObject( cache ) ) { + +			// Support: Chrome <=35 - 45 +			// Webkit & Blink performance suffers when deleting properties +			// from DOM nodes, so set to undefined instead +			// https://bugs.chromium.org/p/chromium/issues/detail?id=378607 (bug restricted) +			if ( owner.nodeType ) { +				owner[ this.expando ] = undefined; +			} else { +				delete owner[ this.expando ]; +			} +		} +	}, +	hasData: function( owner ) { +		var cache = owner[ this.expando ]; +		return cache !== undefined && !jQuery.isEmptyObject( cache ); +	} +}; +var dataPriv = new Data(); + +var dataUser = new Data(); + + + +//	Implementation Summary +// +//	1. Enforce API surface and semantic compatibility with 1.9.x branch +//	2. Improve the module's maintainability by reducing the storage +//		paths to a single mechanism. +//	3. Use the same single mechanism to support "private" and "user" data. +//	4. _Never_ expose "private" data to user code (TODO: Drop _data, _removeData) +//	5. Avoid exposing implementation details on user objects (eg. expando properties) +//	6. Provide a clear path for implementation upgrade to WeakMap in 2014 + +var rbrace = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/, +	rmultiDash = /[A-Z]/g; + +function getData( data ) { +	if ( data === "true" ) { +		return true; +	} + +	if ( data === "false" ) { +		return false; +	} + +	if ( data === "null" ) { +		return null; +	} + +	// Only convert to a number if it doesn't change the string +	if ( data === +data + "" ) { +		return +data; +	} + +	if ( rbrace.test( data ) ) { +		return JSON.parse( data ); +	} + +	return data; +} + +function dataAttr( elem, key, data ) { +	var name; + +	// If nothing was found internally, try to fetch any +	// data from the HTML5 data-* attribute +	if ( data === undefined && elem.nodeType === 1 ) { +		name = "data-" + key.replace( rmultiDash, "-$&" ).toLowerCase(); +		data = elem.getAttribute( name ); + +		if ( typeof data === "string" ) { +			try { +				data = getData( data ); +			} catch ( e ) {} + +			// Make sure we set the data so it isn't changed later +			dataUser.set( elem, key, data ); +		} else { +			data = undefined; +		} +	} +	return data; +} + +jQuery.extend( { +	hasData: function( elem ) { +		return dataUser.hasData( elem ) || dataPriv.hasData( elem ); +	}, + +	data: function( elem, name, data ) { +		return dataUser.access( elem, name, data ); +	}, + +	removeData: function( elem, name ) { +		dataUser.remove( elem, name ); +	}, + +	// TODO: Now that all calls to _data and _removeData have been replaced +	// with direct calls to dataPriv methods, these can be deprecated. +	_data: function( elem, name, data ) { +		return dataPriv.access( elem, name, data ); +	}, + +	_removeData: function( elem, name ) { +		dataPriv.remove( elem, name ); +	} +} ); + +jQuery.fn.extend( { +	data: function( key, value ) { +		var i, name, data, +			elem = this[ 0 ], +			attrs = elem && elem.attributes; + +		// Gets all values +		if ( key === undefined ) { +			if ( this.length ) { +				data = dataUser.get( elem ); + +				if ( elem.nodeType === 1 && !dataPriv.get( elem, "hasDataAttrs" ) ) { +					i = attrs.length; +					while ( i-- ) { + +						// Support: IE 11 only +						// The attrs elements can be null (#14894) +						if ( attrs[ i ] ) { +							name = attrs[ i ].name; +							if ( name.indexOf( "data-" ) === 0 ) { +								name = camelCase( name.slice( 5 ) ); +								dataAttr( elem, name, data[ name ] ); +							} +						} +					} +					dataPriv.set( elem, "hasDataAttrs", true ); +				} +			} + +			return data; +		} + +		// Sets multiple values +		if ( typeof key === "object" ) { +			return this.each( function() { +				dataUser.set( this, key ); +			} ); +		} + +		return access( this, function( value ) { +			var data; + +			// The calling jQuery object (element matches) is not empty +			// (and therefore has an element appears at this[ 0 ]) and the +			// `value` parameter was not undefined. An empty jQuery object +			// will result in `undefined` for elem = this[ 0 ] which will +			// throw an exception if an attempt to read a data cache is made. +			if ( elem && value === undefined ) { + +				// Attempt to get data from the cache +				// The key will always be camelCased in Data +				data = dataUser.get( elem, key ); +				if ( data !== undefined ) { +					return data; +				} + +				// Attempt to "discover" the data in +				// HTML5 custom data-* attrs +				data = dataAttr( elem, key ); +				if ( data !== undefined ) { +					return data; +				} + +				// We tried really hard, but the data doesn't exist. +				return; +			} + +			// Set the data... +			this.each( function() { + +				// We always store the camelCased key +				dataUser.set( this, key, value ); +			} ); +		}, null, value, arguments.length > 1, null, true ); +	}, + +	removeData: function( key ) { +		return this.each( function() { +			dataUser.remove( this, key ); +		} ); +	} +} ); + + +jQuery.extend( { +	queue: function( elem, type, data ) { +		var queue; + +		if ( elem ) { +			type = ( type || "fx" ) + "queue"; +			queue = dataPriv.get( elem, type ); + +			// Speed up dequeue by getting out quickly if this is just a lookup +			if ( data ) { +				if ( !queue || Array.isArray( data ) ) { +					queue = dataPriv.access( 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 public - generate a queueHooks object, or return the current one +	_queueHooks: function( elem, type ) { +		var key = type + "queueHooks"; +		return dataPriv.get( elem, key ) || dataPriv.access( elem, key, { +			empty: jQuery.Callbacks( "once memory" ).add( function() { +				dataPriv.remove( elem, [ type + "queue", 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 = dataPriv.get( 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 rcssNum = new RegExp( "^(?:([+-])=|)(" + pnum + ")([a-z%]*)$", "i" ); + + +var cssExpand = [ "Top", "Right", "Bottom", "Left" ]; + +var documentElement = document.documentElement; + + + +	var isAttached = function( elem ) { +			return jQuery.contains( elem.ownerDocument, elem ); +		}, +		composed = { composed: true }; + +	// Support: IE 9 - 11+, Edge 12 - 18+, iOS 10.0 - 10.2 only +	// Check attachment across shadow DOM boundaries when possible (gh-3504) +	// Support: iOS 10.0-10.2 only +	// Early iOS 10 versions support `attachShadow` but not `getRootNode`, +	// leading to errors. We need to check for `getRootNode`. +	if ( documentElement.getRootNode ) { +		isAttached = function( elem ) { +			return jQuery.contains( elem.ownerDocument, elem ) || +				elem.getRootNode( composed ) === elem.ownerDocument; +		}; +	} +var isHiddenWithinTree = function( elem, el ) { + +		// isHiddenWithinTree might be called from jQuery#filter function; +		// in that case, element will be second argument +		elem = el || elem; + +		// Inline style trumps all +		return elem.style.display === "none" || +			elem.style.display === "" && + +			// Otherwise, check computed style +			// Support: Firefox <=43 - 45 +			// Disconnected elements can have computed display: none, so first confirm that elem is +			// in the document. +			isAttached( elem ) && + +			jQuery.css( elem, "display" ) === "none"; +	}; + + + +function adjustCSS( elem, prop, valueParts, tween ) { +	var adjusted, scale, +		maxIterations = 20, +		currentValue = tween ? +			function() { +				return tween.cur(); +			} : +			function() { +				return jQuery.css( elem, prop, "" ); +			}, +		initial = currentValue(), +		unit = valueParts && valueParts[ 3 ] || ( jQuery.cssNumber[ prop ] ? "" : "px" ), + +		// Starting value computation is required for potential unit mismatches +		initialInUnit = elem.nodeType && +			( jQuery.cssNumber[ prop ] || unit !== "px" && +initial ) && +			rcssNum.exec( jQuery.css( elem, prop ) ); + +	if ( initialInUnit && initialInUnit[ 3 ] !== unit ) { + +		// Support: Firefox <=54 +		// Halve the iteration target value to prevent interference from CSS upper bounds (gh-2144) +		initial = initial / 2; + +		// Trust units reported by jQuery.css +		unit = unit || initialInUnit[ 3 ]; + +		// Iteratively approximate from a nonzero starting point +		initialInUnit = +initial || 1; + +		while ( maxIterations-- ) { + +			// Evaluate and update our best guess (doubling guesses that zero out). +			// Finish if the scale equals or crosses 1 (making the old*new product non-positive). +			jQuery.style( elem, prop, initialInUnit + unit ); +			if ( ( 1 - scale ) * ( 1 - ( scale = currentValue() / initial || 0.5 ) ) <= 0 ) { +				maxIterations = 0; +			} +			initialInUnit = initialInUnit / scale; + +		} + +		initialInUnit = initialInUnit * 2; +		jQuery.style( elem, prop, initialInUnit + unit ); + +		// Make sure we update the tween properties later on +		valueParts = valueParts || []; +	} + +	if ( valueParts ) { +		initialInUnit = +initialInUnit || +initial || 0; + +		// Apply relative offset (+=/-=) if specified +		adjusted = valueParts[ 1 ] ? +			initialInUnit + ( valueParts[ 1 ] + 1 ) * valueParts[ 2 ] : +			+valueParts[ 2 ]; +		if ( tween ) { +			tween.unit = unit; +			tween.start = initialInUnit; +			tween.end = adjusted; +		} +	} +	return adjusted; +} + + +var defaultDisplayMap = {}; + +function getDefaultDisplay( elem ) { +	var temp, +		doc = elem.ownerDocument, +		nodeName = elem.nodeName, +		display = defaultDisplayMap[ nodeName ]; + +	if ( display ) { +		return display; +	} + +	temp = doc.body.appendChild( doc.createElement( nodeName ) ); +	display = jQuery.css( temp, "display" ); + +	temp.parentNode.removeChild( temp ); + +	if ( display === "none" ) { +		display = "block"; +	} +	defaultDisplayMap[ nodeName ] = display; + +	return display; +} + +function showHide( elements, show ) { +	var display, elem, +		values = [], +		index = 0, +		length = elements.length; + +	// Determine new display value for elements that need to change +	for ( ; index < length; index++ ) { +		elem = elements[ index ]; +		if ( !elem.style ) { +			continue; +		} + +		display = elem.style.display; +		if ( show ) { + +			// Since we force visibility upon cascade-hidden elements, an immediate (and slow) +			// check is required in this first loop unless we have a nonempty display value (either +			// inline or about-to-be-restored) +			if ( display === "none" ) { +				values[ index ] = dataPriv.get( elem, "display" ) || null; +				if ( !values[ index ] ) { +					elem.style.display = ""; +				} +			} +			if ( elem.style.display === "" && isHiddenWithinTree( elem ) ) { +				values[ index ] = getDefaultDisplay( elem ); +			} +		} else { +			if ( display !== "none" ) { +				values[ index ] = "none"; + +				// Remember what we're overwriting +				dataPriv.set( elem, "display", display ); +			} +		} +	} + +	// Set the display of the elements in a second loop to avoid constant reflow +	for ( index = 0; index < length; index++ ) { +		if ( values[ index ] != null ) { +			elements[ index ].style.display = values[ index ]; +		} +	} + +	return elements; +} + +jQuery.fn.extend( { +	show: function() { +		return showHide( this, true ); +	}, +	hide: function() { +		return showHide( this ); +	}, +	toggle: function( state ) { +		if ( typeof state === "boolean" ) { +			return state ? this.show() : this.hide(); +		} + +		return this.each( function() { +			if ( isHiddenWithinTree( this ) ) { +				jQuery( this ).show(); +			} else { +				jQuery( this ).hide(); +			} +		} ); +	} +} ); +var rcheckableType = ( /^(?:checkbox|radio)$/i ); + +var rtagName = ( /<([a-z][^\/\0>\x20\t\r\n\f]*)/i ); + +var rscriptType = ( /^$|^module$|\/(?:java|ecma)script/i ); + + + +( function() { +	var fragment = document.createDocumentFragment(), +		div = fragment.appendChild( document.createElement( "div" ) ), +		input = document.createElement( "input" ); + +	// Support: Android 4.0 - 4.3 only +	// Check state lost if the name is set (#11217) +	// Support: Windows Web Apps (WWA) +	// `name` and `type` must use .setAttribute for WWA (#14901) +	input.setAttribute( "type", "radio" ); +	input.setAttribute( "checked", "checked" ); +	input.setAttribute( "name", "t" ); + +	div.appendChild( input ); + +	// Support: Android <=4.1 only +	// Older WebKit doesn't clone checked state correctly in fragments +	support.checkClone = div.cloneNode( true ).cloneNode( true ).lastChild.checked; + +	// Support: IE <=11 only +	// Make sure textarea (and checkbox) defaultValue is properly cloned +	div.innerHTML = "<textarea>x</textarea>"; +	support.noCloneChecked = !!div.cloneNode( true ).lastChild.defaultValue; + +	// Support: IE <=9 only +	// IE <=9 replaces <option> tags with their contents when inserted outside of +	// the select element. +	div.innerHTML = "<option></option>"; +	support.option = !!div.lastChild; +} )(); + + +// We have to close these tags to support XHTML (#13200) +var wrapMap = { + +	// XHTML parsers do not magically insert elements in the +	// same way that tag soup parsers do. So we cannot shorten +	// this by omitting <tbody> or other required elements. +	thead: [ 1, "<table>", "</table>" ], +	col: [ 2, "<table><colgroup>", "</colgroup></table>" ], +	tr: [ 2, "<table><tbody>", "</tbody></table>" ], +	td: [ 3, "<table><tbody><tr>", "</tr></tbody></table>" ], + +	_default: [ 0, "", "" ] +}; + +wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; +wrapMap.th = wrapMap.td; + +// Support: IE <=9 only +if ( !support.option ) { +	wrapMap.optgroup = wrapMap.option = [ 1, "<select multiple='multiple'>", "</select>" ]; +} + + +function getAll( context, tag ) { + +	// Support: IE <=9 - 11 only +	// Use typeof to avoid zero-argument method invocation on host objects (#15151) +	var ret; + +	if ( typeof context.getElementsByTagName !== "undefined" ) { +		ret = context.getElementsByTagName( tag || "*" ); + +	} else if ( typeof context.querySelectorAll !== "undefined" ) { +		ret = context.querySelectorAll( tag || "*" ); + +	} else { +		ret = []; +	} + +	if ( tag === undefined || tag && nodeName( context, tag ) ) { +		return jQuery.merge( [ context ], ret ); +	} + +	return ret; +} + + +// Mark scripts as having already been evaluated +function setGlobalEval( elems, refElements ) { +	var i = 0, +		l = elems.length; + +	for ( ; i < l; i++ ) { +		dataPriv.set( +			elems[ i ], +			"globalEval", +			!refElements || dataPriv.get( refElements[ i ], "globalEval" ) +		); +	} +} + + +var rhtml = /<|&#?\w+;/; + +function buildFragment( elems, context, scripts, selection, ignored ) { +	var elem, tmp, tag, wrap, attached, j, +		fragment = context.createDocumentFragment(), +		nodes = [], +		i = 0, +		l = elems.length; + +	for ( ; i < l; i++ ) { +		elem = elems[ i ]; + +		if ( elem || elem === 0 ) { + +			// Add nodes directly +			if ( toType( elem ) === "object" ) { + +				// Support: Android <=4.0 only, PhantomJS 1 only +				// push.apply(_, arraylike) throws on ancient WebKit +				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 || fragment.appendChild( context.createElement( "div" ) ); + +				// Deserialize a standard representation +				tag = ( rtagName.exec( elem ) || [ "", "" ] )[ 1 ].toLowerCase(); +				wrap = wrapMap[ tag ] || wrapMap._default; +				tmp.innerHTML = wrap[ 1 ] + jQuery.htmlPrefilter( elem ) + wrap[ 2 ]; + +				// Descend through wrappers to the right content +				j = wrap[ 0 ]; +				while ( j-- ) { +					tmp = tmp.lastChild; +				} + +				// Support: Android <=4.0 only, PhantomJS 1 only +				// push.apply(_, arraylike) throws on ancient WebKit +				jQuery.merge( nodes, tmp.childNodes ); + +				// Remember the top-level container +				tmp = fragment.firstChild; + +				// Ensure the created nodes are orphaned (#12392) +				tmp.textContent = ""; +			} +		} +	} + +	// Remove wrapper from fragment +	fragment.textContent = ""; + +	i = 0; +	while ( ( elem = nodes[ i++ ] ) ) { + +		// Skip elements already in the context collection (trac-4087) +		if ( selection && jQuery.inArray( elem, selection ) > -1 ) { +			if ( ignored ) { +				ignored.push( elem ); +			} +			continue; +		} + +		attached = isAttached( elem ); + +		// Append to fragment +		tmp = getAll( fragment.appendChild( elem ), "script" ); + +		// Preserve script evaluation history +		if ( attached ) { +			setGlobalEval( tmp ); +		} + +		// Capture executables +		if ( scripts ) { +			j = 0; +			while ( ( elem = tmp[ j++ ] ) ) { +				if ( rscriptType.test( elem.type || "" ) ) { +					scripts.push( elem ); +				} +			} +		} +	} + +	return fragment; +} + + +var rtypenamespace = /^([^.]*)(?:\.(.+)|)/; + +function returnTrue() { +	return true; +} + +function returnFalse() { +	return false; +} + +// Support: IE <=9 - 11+ +// focus() and blur() are asynchronous, except when they are no-op. +// So expect focus to be synchronous when the element is already active, +// and blur to be synchronous when the element is not already active. +// (focus and blur are always synchronous in other supported browsers, +// this just defines when we can count on it). +function expectSync( elem, type ) { +	return ( elem === safeActiveElement() ) === ( type === "focus" ); +} + +// Support: IE <=9 only +// Accessing document.activeElement can throw unexpectedly +// https://bugs.jquery.com/ticket/13393 +function safeActiveElement() { +	try { +		return document.activeElement; +	} catch ( err ) { } +} + +function on( elem, types, selector, data, fn, one ) { +	var origFn, type; + +	// 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 ) { +			on( elem, type, selector, data, types[ type ], one ); +		} +		return elem; +	} + +	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 elem; +	} + +	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 elem.each( function() { +		jQuery.event.add( this, types, fn, data, selector ); +	} ); +} + +/* + * 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 handleObjIn, eventHandle, tmp, +			events, t, handleObj, +			special, handlers, type, namespaces, origType, +			elemData = dataPriv.get( elem ); + +		// Only attach events to objects that accept data +		if ( !acceptData( elem ) ) { +			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; +		} + +		// Ensure that invalid selectors throw exceptions at attach time +		// Evaluate against documentElement in case elem is a non-element node (e.g., document) +		if ( selector ) { +			jQuery.find.matchesSelector( documentElement, 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 = Object.create( null ); +		} +		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 !== "undefined" && jQuery.event.triggered !== e.type ? +					jQuery.event.dispatch.apply( elem, arguments ) : undefined; +			}; +		} + +		// Handle multiple events separated by a space +		types = ( types || "" ).match( rnothtmlwhite ) || [ "" ]; +		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 if the special events handler returns false +				if ( !special.setup || +					special.setup.call( elem, data, namespaces, eventHandle ) === false ) { + +					if ( elem.addEventListener ) { +						elem.addEventListener( 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; +		} + +	}, + +	// Detach an event or set of events from an element +	remove: function( elem, types, handler, selector, mappedTypes ) { + +		var j, origCount, tmp, +			events, t, handleObj, +			special, handlers, type, namespaces, origType, +			elemData = dataPriv.hasData( elem ) && dataPriv.get( elem ); + +		if ( !elemData || !( events = elemData.events ) ) { +			return; +		} + +		// Once for each type.namespace in types; type may be omitted +		types = ( types || "" ).match( rnothtmlwhite ) || [ "" ]; +		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 data and the expando if it's no longer used +		if ( jQuery.isEmptyObject( events ) ) { +			dataPriv.remove( elem, "handle events" ); +		} +	}, + +	dispatch: function( nativeEvent ) { + +		var i, j, ret, matched, handleObj, handlerQueue, +			args = new Array( arguments.length ), + +			// Make a writable jQuery.Event from the native event object +			event = jQuery.event.fix( nativeEvent ), + +			handlers = ( +				dataPriv.get( this, "events" ) || Object.create( null ) +			)[ event.type ] || [], +			special = jQuery.event.special[ event.type ] || {}; + +		// Use the fix-ed jQuery.Event rather than the (read-only) native event +		args[ 0 ] = event; + +		for ( i = 1; i < arguments.length; i++ ) { +			args[ i ] = arguments[ i ]; +		} + +		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() ) { + +				// If the event is namespaced, then each handler is only invoked if it is +				// specially universal or its namespaces are a superset of the event's. +				if ( !event.rnamespace || handleObj.namespace === false || +					event.rnamespace.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 i, handleObj, sel, matchedHandlers, matchedSelectors, +			handlerQueue = [], +			delegateCount = handlers.delegateCount, +			cur = event.target; + +		// Find delegate handlers +		if ( delegateCount && + +			// Support: IE <=9 +			// Black-hole SVG <use> instance trees (trac-13180) +			cur.nodeType && + +			// Support: Firefox <=42 +			// Suppress spec-violating clicks indicating a non-primary pointer button (trac-3861) +			// https://www.w3.org/TR/DOM-Level-3-Events/#event-type-click +			// Support: IE 11 only +			// ...but not arrow key "clicks" of radio inputs, which can have `button` -1 (gh-2343) +			!( event.type === "click" && event.button >= 1 ) ) { + +			for ( ; cur !== this; cur = cur.parentNode || this ) { + +				// Don't check non-elements (#13208) +				// Don't process clicks on disabled elements (#6911, #8165, #11382, #11764) +				if ( cur.nodeType === 1 && !( event.type === "click" && cur.disabled === true ) ) { +					matchedHandlers = []; +					matchedSelectors = {}; +					for ( i = 0; i < delegateCount; i++ ) { +						handleObj = handlers[ i ]; + +						// Don't conflict with Object.prototype properties (#13203) +						sel = handleObj.selector + " "; + +						if ( matchedSelectors[ sel ] === undefined ) { +							matchedSelectors[ sel ] = handleObj.needsContext ? +								jQuery( sel, this ).index( cur ) > -1 : +								jQuery.find( sel, this, null, [ cur ] ).length; +						} +						if ( matchedSelectors[ sel ] ) { +							matchedHandlers.push( handleObj ); +						} +					} +					if ( matchedHandlers.length ) { +						handlerQueue.push( { elem: cur, handlers: matchedHandlers } ); +					} +				} +			} +		} + +		// Add the remaining (directly-bound) handlers +		cur = this; +		if ( delegateCount < handlers.length ) { +			handlerQueue.push( { elem: cur, handlers: handlers.slice( delegateCount ) } ); +		} + +		return handlerQueue; +	}, + +	addProp: function( name, hook ) { +		Object.defineProperty( jQuery.Event.prototype, name, { +			enumerable: true, +			configurable: true, + +			get: isFunction( hook ) ? +				function() { +					if ( this.originalEvent ) { +						return hook( this.originalEvent ); +					} +				} : +				function() { +					if ( this.originalEvent ) { +						return this.originalEvent[ name ]; +					} +				}, + +			set: function( value ) { +				Object.defineProperty( this, name, { +					enumerable: true, +					configurable: true, +					writable: true, +					value: value +				} ); +			} +		} ); +	}, + +	fix: function( originalEvent ) { +		return originalEvent[ jQuery.expando ] ? +			originalEvent : +			new jQuery.Event( originalEvent ); +	}, + +	special: { +		load: { + +			// Prevent triggered image.load events from bubbling to window.load +			noBubble: true +		}, +		click: { + +			// Utilize native event to ensure correct state for checkable inputs +			setup: function( data ) { + +				// For mutual compressibility with _default, replace `this` access with a local var. +				// `|| data` is dead code meant only to preserve the variable through minification. +				var el = this || data; + +				// Claim the first handler +				if ( rcheckableType.test( el.type ) && +					el.click && nodeName( el, "input" ) ) { + +					// dataPriv.set( el, "click", ... ) +					leverageNative( el, "click", returnTrue ); +				} + +				// Return false to allow normal processing in the caller +				return false; +			}, +			trigger: function( data ) { + +				// For mutual compressibility with _default, replace `this` access with a local var. +				// `|| data` is dead code meant only to preserve the variable through minification. +				var el = this || data; + +				// Force setup before triggering a click +				if ( rcheckableType.test( el.type ) && +					el.click && nodeName( el, "input" ) ) { + +					leverageNative( el, "click" ); +				} + +				// Return non-false to allow normal event-path propagation +				return true; +			}, + +			// For cross-browser consistency, suppress native .click() on links +			// Also prevent it if we're currently inside a leveraged native-event stack +			_default: function( event ) { +				var target = event.target; +				return rcheckableType.test( target.type ) && +					target.click && nodeName( target, "input" ) && +					dataPriv.get( target, "click" ) || +					nodeName( 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; +				} +			} +		} +	} +}; + +// Ensure the presence of an event listener that handles manually-triggered +// synthetic events by interrupting progress until reinvoked in response to +// *native* events that it fires directly, ensuring that state changes have +// already occurred before other listeners are invoked. +function leverageNative( el, type, expectSync ) { + +	// Missing expectSync indicates a trigger call, which must force setup through jQuery.event.add +	if ( !expectSync ) { +		if ( dataPriv.get( el, type ) === undefined ) { +			jQuery.event.add( el, type, returnTrue ); +		} +		return; +	} + +	// Register the controller as a special universal handler for all event namespaces +	dataPriv.set( el, type, false ); +	jQuery.event.add( el, type, { +		namespace: false, +		handler: function( event ) { +			var notAsync, result, +				saved = dataPriv.get( this, type ); + +			if ( ( event.isTrigger & 1 ) && this[ type ] ) { + +				// Interrupt processing of the outer synthetic .trigger()ed event +				// Saved data should be false in such cases, but might be a leftover capture object +				// from an async native handler (gh-4350) +				if ( !saved.length ) { + +					// Store arguments for use when handling the inner native event +					// There will always be at least one argument (an event object), so this array +					// will not be confused with a leftover capture object. +					saved = slice.call( arguments ); +					dataPriv.set( this, type, saved ); + +					// Trigger the native event and capture its result +					// Support: IE <=9 - 11+ +					// focus() and blur() are asynchronous +					notAsync = expectSync( this, type ); +					this[ type ](); +					result = dataPriv.get( this, type ); +					if ( saved !== result || notAsync ) { +						dataPriv.set( this, type, false ); +					} else { +						result = {}; +					} +					if ( saved !== result ) { + +						// Cancel the outer synthetic event +						event.stopImmediatePropagation(); +						event.preventDefault(); + +						// Support: Chrome 86+ +						// In Chrome, if an element having a focusout handler is blurred by +						// clicking outside of it, it invokes the handler synchronously. If +						// that handler calls `.remove()` on the element, the data is cleared, +						// leaving `result` undefined. We need to guard against this. +						return result && result.value; +					} + +				// If this is an inner synthetic event for an event with a bubbling surrogate +				// (focus or blur), assume that the surrogate already propagated from triggering the +				// native event and prevent that from happening again here. +				// This technically gets the ordering wrong w.r.t. to `.trigger()` (in which the +				// bubbling surrogate propagates *after* the non-bubbling base), but that seems +				// less bad than duplication. +				} else if ( ( jQuery.event.special[ type ] || {} ).delegateType ) { +					event.stopPropagation(); +				} + +			// If this is a native event triggered above, everything is now in order +			// Fire an inner synthetic event with the original arguments +			} else if ( saved.length ) { + +				// ...and capture the result +				dataPriv.set( this, type, { +					value: jQuery.event.trigger( + +						// Support: IE <=9 - 11+ +						// Extend with the prototype to reset the above stopImmediatePropagation() +						jQuery.extend( saved[ 0 ], jQuery.Event.prototype ), +						saved.slice( 1 ), +						this +					) +				} ); + +				// Abort handling of the native event +				event.stopImmediatePropagation(); +			} +		} +	} ); +} + +jQuery.removeEvent = function( elem, type, handle ) { + +	// This "if" is needed for plain objects +	if ( elem.removeEventListener ) { +		elem.removeEventListener( type, 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: Android <=2.3 only +				src.returnValue === false ? +			returnTrue : +			returnFalse; + +		// Create target properties +		// Support: Safari <=6 - 7 only +		// Target should not be a text node (#504, #13143) +		this.target = ( src.target && src.target.nodeType === 3 ) ? +			src.target.parentNode : +			src.target; + +		this.currentTarget = src.currentTarget; +		this.relatedTarget = src.relatedTarget; + +	// 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 || Date.now(); + +	// Mark it as fixed +	this[ jQuery.expando ] = true; +}; + +// jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding +// https://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html +jQuery.Event.prototype = { +	constructor: jQuery.Event, +	isDefaultPrevented: returnFalse, +	isPropagationStopped: returnFalse, +	isImmediatePropagationStopped: returnFalse, +	isSimulated: false, + +	preventDefault: function() { +		var e = this.originalEvent; + +		this.isDefaultPrevented = returnTrue; + +		if ( e && !this.isSimulated ) { +			e.preventDefault(); +		} +	}, +	stopPropagation: function() { +		var e = this.originalEvent; + +		this.isPropagationStopped = returnTrue; + +		if ( e && !this.isSimulated ) { +			e.stopPropagation(); +		} +	}, +	stopImmediatePropagation: function() { +		var e = this.originalEvent; + +		this.isImmediatePropagationStopped = returnTrue; + +		if ( e && !this.isSimulated ) { +			e.stopImmediatePropagation(); +		} + +		this.stopPropagation(); +	} +}; + +// Includes all common event props including KeyEvent and MouseEvent specific props +jQuery.each( { +	altKey: true, +	bubbles: true, +	cancelable: true, +	changedTouches: true, +	ctrlKey: true, +	detail: true, +	eventPhase: true, +	metaKey: true, +	pageX: true, +	pageY: true, +	shiftKey: true, +	view: true, +	"char": true, +	code: true, +	charCode: true, +	key: true, +	keyCode: true, +	button: true, +	buttons: true, +	clientX: true, +	clientY: true, +	offsetX: true, +	offsetY: true, +	pointerId: true, +	pointerType: true, +	screenX: true, +	screenY: true, +	targetTouches: true, +	toElement: true, +	touches: true, +	which: true +}, jQuery.event.addProp ); + +jQuery.each( { focus: "focusin", blur: "focusout" }, function( type, delegateType ) { +	jQuery.event.special[ type ] = { + +		// Utilize native event if possible so blur/focus sequence is correct +		setup: function() { + +			// Claim the first handler +			// dataPriv.set( this, "focus", ... ) +			// dataPriv.set( this, "blur", ... ) +			leverageNative( this, type, expectSync ); + +			// Return false to allow normal processing in the caller +			return false; +		}, +		trigger: function() { + +			// Force setup before trigger +			leverageNative( this, type ); + +			// Return non-false to allow normal event-path propagation +			return true; +		}, + +		// Suppress native focus or blur as it's already being fired +		// in leverageNative. +		_default: function() { +			return true; +		}, + +		delegateType: delegateType +	}; +} ); + +// Create mouseenter/leave events using mouseover/out and event-time checks +// so that event delegation works in jQuery. +// Do the same for pointerenter/pointerleave and pointerover/pointerout +// +// Support: Safari 7 only +// Safari sends mouseenter too often; see: +// https://bugs.chromium.org/p/chromium/issues/detail?id=470258 +// for the description of the bug (it existed in older Chrome versions as well). +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 mouseenter/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; +		} +	}; +} ); + +jQuery.fn.extend( { + +	on: function( types, selector, data, fn ) { +		return on( this, types, selector, data, fn ); +	}, +	one: function( types, selector, data, fn ) { +		return on( this, 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 ); +		} ); +	} +} ); + + +var + +	// Support: IE <=10 - 11, Edge 12 - 13 only +	// In IE/Edge using regex groups here causes severe slowdowns. +	// See https://connect.microsoft.com/IE/feedback/details/1736512/ +	rnoInnerhtml = /<script|<style|<link/i, + +	// checked="checked" or checked +	rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i, +	rcleanScript = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g; + +// Prefer a tbody over its parent table for containing new rows +function manipulationTarget( elem, content ) { +	if ( nodeName( elem, "table" ) && +		nodeName( content.nodeType !== 11 ? content : content.firstChild, "tr" ) ) { + +		return jQuery( elem ).children( "tbody" )[ 0 ] || elem; +	} + +	return elem; +} + +// Replace/restore the type attribute of script elements for safe DOM manipulation +function disableScript( elem ) { +	elem.type = ( elem.getAttribute( "type" ) !== null ) + "/" + elem.type; +	return elem; +} +function restoreScript( elem ) { +	if ( ( elem.type || "" ).slice( 0, 5 ) === "true/" ) { +		elem.type = elem.type.slice( 5 ); +	} else { +		elem.removeAttribute( "type" ); +	} + +	return elem; +} + +function cloneCopyEvent( src, dest ) { +	var i, l, type, pdataOld, udataOld, udataCur, events; + +	if ( dest.nodeType !== 1 ) { +		return; +	} + +	// 1. Copy private data: events, handlers, etc. +	if ( dataPriv.hasData( src ) ) { +		pdataOld = dataPriv.get( src ); +		events = pdataOld.events; + +		if ( events ) { +			dataPriv.remove( dest, "handle events" ); + +			for ( type in events ) { +				for ( i = 0, l = events[ type ].length; i < l; i++ ) { +					jQuery.event.add( dest, type, events[ type ][ i ] ); +				} +			} +		} +	} + +	// 2. Copy user data +	if ( dataUser.hasData( src ) ) { +		udataOld = dataUser.access( src ); +		udataCur = jQuery.extend( {}, udataOld ); + +		dataUser.set( dest, udataCur ); +	} +} + +// Fix IE bugs, see support tests +function fixInput( src, dest ) { +	var nodeName = dest.nodeName.toLowerCase(); + +	// Fails to persist the checked state of a cloned checkbox or radio button. +	if ( nodeName === "input" && rcheckableType.test( src.type ) ) { +		dest.checked = src.checked; + +	// Fails to return the selected option to the default selected state when cloning options +	} else if ( nodeName === "input" || nodeName === "textarea" ) { +		dest.defaultValue = src.defaultValue; +	} +} + +function domManip( collection, args, callback, ignored ) { + +	// Flatten any nested arrays +	args = flat( args ); + +	var fragment, first, scripts, hasScripts, node, doc, +		i = 0, +		l = collection.length, +		iNoClone = l - 1, +		value = args[ 0 ], +		valueIsFunction = isFunction( value ); + +	// We can't cloneNode fragments that contain checked, in WebKit +	if ( valueIsFunction || +			( l > 1 && typeof value === "string" && +				!support.checkClone && rchecked.test( value ) ) ) { +		return collection.each( function( index ) { +			var self = collection.eq( index ); +			if ( valueIsFunction ) { +				args[ 0 ] = value.call( this, index, self.html() ); +			} +			domManip( self, args, callback, ignored ); +		} ); +	} + +	if ( l ) { +		fragment = buildFragment( args, collection[ 0 ].ownerDocument, false, collection, ignored ); +		first = fragment.firstChild; + +		if ( fragment.childNodes.length === 1 ) { +			fragment = first; +		} + +		// Require either new content or an interest in ignored elements to invoke the callback +		if ( first || ignored ) { +			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 ) { + +						// Support: Android <=4.0 only, PhantomJS 1 only +						// push.apply(_, arraylike) throws on ancient WebKit +						jQuery.merge( scripts, getAll( node, "script" ) ); +					} +				} + +				callback.call( collection[ 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 || "" ) && +						!dataPriv.access( node, "globalEval" ) && +						jQuery.contains( doc, node ) ) { + +						if ( node.src && ( node.type || "" ).toLowerCase()  !== "module" ) { + +							// Optional AJAX dependency, but won't run scripts if not present +							if ( jQuery._evalUrl && !node.noModule ) { +								jQuery._evalUrl( node.src, { +									nonce: node.nonce || node.getAttribute( "nonce" ) +								}, doc ); +							} +						} else { +							DOMEval( node.textContent.replace( rcleanScript, "" ), node, doc ); +						} +					} +				} +			} +		} +	} + +	return collection; +} + +function remove( elem, selector, keepData ) { +	var node, +		nodes = selector ? jQuery.filter( selector, elem ) : elem, +		i = 0; + +	for ( ; ( node = nodes[ i ] ) != null; i++ ) { +		if ( !keepData && node.nodeType === 1 ) { +			jQuery.cleanData( getAll( node ) ); +		} + +		if ( node.parentNode ) { +			if ( keepData && isAttached( node ) ) { +				setGlobalEval( getAll( node, "script" ) ); +			} +			node.parentNode.removeChild( node ); +		} +	} + +	return elem; +} + +jQuery.extend( { +	htmlPrefilter: function( html ) { +		return html; +	}, + +	clone: function( elem, dataAndEvents, deepDataAndEvents ) { +		var i, l, srcElements, destElements, +			clone = elem.cloneNode( true ), +			inPage = isAttached( elem ); + +		// Fix IE cloning issues +		if ( !support.noCloneChecked && ( elem.nodeType === 1 || elem.nodeType === 11 ) && +				!jQuery.isXMLDoc( elem ) ) { + +			// We eschew Sizzle here for performance reasons: https://jsperf.com/getall-vs-sizzle/2 +			destElements = getAll( clone ); +			srcElements = getAll( elem ); + +			for ( i = 0, l = srcElements.length; i < l; i++ ) { +				fixInput( srcElements[ i ], 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, l = srcElements.length; i < l; i++ ) { +					cloneCopyEvent( srcElements[ i ], destElements[ i ] ); +				} +			} else { +				cloneCopyEvent( elem, clone ); +			} +		} + +		// Preserve script evaluation history +		destElements = getAll( clone, "script" ); +		if ( destElements.length > 0 ) { +			setGlobalEval( destElements, !inPage && getAll( elem, "script" ) ); +		} + +		// Return the cloned set +		return clone; +	}, + +	cleanData: function( elems ) { +		var data, elem, type, +			special = jQuery.event.special, +			i = 0; + +		for ( ; ( elem = elems[ i ] ) !== undefined; i++ ) { +			if ( acceptData( elem ) ) { +				if ( ( data = elem[ dataPriv.expando ] ) ) { +					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 ); +							} +						} +					} + +					// Support: Chrome <=35 - 45+ +					// Assign undefined instead of using delete, see Data#remove +					elem[ dataPriv.expando ] = undefined; +				} +				if ( elem[ dataUser.expando ] ) { + +					// Support: Chrome <=35 - 45+ +					// Assign undefined instead of using delete, see Data#remove +					elem[ dataUser.expando ] = undefined; +				} +			} +		} +	} +} ); + +jQuery.fn.extend( { +	detach: function( selector ) { +		return remove( this, selector, true ); +	}, + +	remove: function( selector ) { +		return remove( this, selector ); +	}, + +	text: function( value ) { +		return access( this, function( value ) { +			return value === undefined ? +				jQuery.text( this ) : +				this.empty().each( function() { +					if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { +						this.textContent = value; +					} +				} ); +		}, null, value, arguments.length ); +	}, + +	append: function() { +		return domManip( this, arguments, function( elem ) { +			if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { +				var target = manipulationTarget( this, elem ); +				target.appendChild( elem ); +			} +		} ); +	}, + +	prepend: function() { +		return domManip( this, 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 domManip( this, arguments, function( elem ) { +			if ( this.parentNode ) { +				this.parentNode.insertBefore( elem, this ); +			} +		} ); +	}, + +	after: function() { +		return domManip( this, arguments, function( elem ) { +			if ( this.parentNode ) { +				this.parentNode.insertBefore( elem, this.nextSibling ); +			} +		} ); +	}, + +	empty: function() { +		var elem, +			i = 0; + +		for ( ; ( elem = this[ i ] ) != null; i++ ) { +			if ( elem.nodeType === 1 ) { + +				// Prevent memory leaks +				jQuery.cleanData( getAll( elem, false ) ); + +				// Remove any remaining nodes +				elem.textContent = ""; +			} +		} + +		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 && elem.nodeType === 1 ) { +				return elem.innerHTML; +			} + +			// See if we can take a shortcut and just use innerHTML +			if ( typeof value === "string" && !rnoInnerhtml.test( value ) && +				!wrapMap[ ( rtagName.exec( value ) || [ "", "" ] )[ 1 ].toLowerCase() ] ) { + +				value = jQuery.htmlPrefilter( value ); + +				try { +					for ( ; i < l; i++ ) { +						elem = this[ i ] || {}; + +						// Remove element nodes and prevent memory leaks +						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 ignored = []; + +		// Make the changes, replacing each non-ignored context element with the new content +		return domManip( this, arguments, function( elem ) { +			var parent = this.parentNode; + +			if ( jQuery.inArray( this, ignored ) < 0 ) { +				jQuery.cleanData( getAll( this ) ); +				if ( parent ) { +					parent.replaceChild( elem, this ); +				} +			} + +		// Force callback invocation +		}, ignored ); +	} +} ); + +jQuery.each( { +	appendTo: "append", +	prependTo: "prepend", +	insertBefore: "before", +	insertAfter: "after", +	replaceAll: "replaceWith" +}, function( name, original ) { +	jQuery.fn[ name ] = function( selector ) { +		var elems, +			ret = [], +			insert = jQuery( selector ), +			last = insert.length - 1, +			i = 0; + +		for ( ; i <= last; i++ ) { +			elems = i === last ? this : this.clone( true ); +			jQuery( insert[ i ] )[ original ]( elems ); + +			// Support: Android <=4.0 only, PhantomJS 1 only +			// .get() because push.apply(_, arraylike) throws on ancient WebKit +			push.apply( ret, elems.get() ); +		} + +		return this.pushStack( ret ); +	}; +} ); +var rnumnonpx = new RegExp( "^(" + pnum + ")(?!px)[a-z%]+$", "i" ); + +var getStyles = function( elem ) { + +		// Support: IE <=11 only, Firefox <=30 (#15098, #14150) +		// IE throws on elements created in popups +		// FF meanwhile throws on frame elements through "defaultView.getComputedStyle" +		var view = elem.ownerDocument.defaultView; + +		if ( !view || !view.opener ) { +			view = window; +		} + +		return view.getComputedStyle( elem ); +	}; + +var swap = function( elem, options, callback ) { +	var ret, name, +		old = {}; + +	// Remember the old values, and insert the new ones +	for ( name in options ) { +		old[ name ] = elem.style[ name ]; +		elem.style[ name ] = options[ name ]; +	} + +	ret = callback.call( elem ); + +	// Revert the old values +	for ( name in options ) { +		elem.style[ name ] = old[ name ]; +	} + +	return ret; +}; + + +var rboxStyle = new RegExp( cssExpand.join( "|" ), "i" ); + + + +( function() { + +	// Executing both pixelPosition & boxSizingReliable tests require only one layout +	// so they're executed at the same time to save the second computation. +	function computeStyleTests() { + +		// This is a singleton, we need to execute it only once +		if ( !div ) { +			return; +		} + +		container.style.cssText = "position:absolute;left:-11111px;width:60px;" + +			"margin-top:1px;padding:0;border:0"; +		div.style.cssText = +			"position:relative;display:block;box-sizing:border-box;overflow:scroll;" + +			"margin:auto;border:1px;padding:1px;" + +			"width:60%;top:1%"; +		documentElement.appendChild( container ).appendChild( div ); + +		var divStyle = window.getComputedStyle( div ); +		pixelPositionVal = divStyle.top !== "1%"; + +		// Support: Android 4.0 - 4.3 only, Firefox <=3 - 44 +		reliableMarginLeftVal = roundPixelMeasures( divStyle.marginLeft ) === 12; + +		// Support: Android 4.0 - 4.3 only, Safari <=9.1 - 10.1, iOS <=7.0 - 9.3 +		// Some styles come back with percentage values, even though they shouldn't +		div.style.right = "60%"; +		pixelBoxStylesVal = roundPixelMeasures( divStyle.right ) === 36; + +		// Support: IE 9 - 11 only +		// Detect misreporting of content dimensions for box-sizing:border-box elements +		boxSizingReliableVal = roundPixelMeasures( divStyle.width ) === 36; + +		// Support: IE 9 only +		// Detect overflow:scroll screwiness (gh-3699) +		// Support: Chrome <=64 +		// Don't get tricked when zoom affects offsetWidth (gh-4029) +		div.style.position = "absolute"; +		scrollboxSizeVal = roundPixelMeasures( div.offsetWidth / 3 ) === 12; + +		documentElement.removeChild( container ); + +		// Nullify the div so it wouldn't be stored in the memory and +		// it will also be a sign that checks already performed +		div = null; +	} + +	function roundPixelMeasures( measure ) { +		return Math.round( parseFloat( measure ) ); +	} + +	var pixelPositionVal, boxSizingReliableVal, scrollboxSizeVal, pixelBoxStylesVal, +		reliableTrDimensionsVal, reliableMarginLeftVal, +		container = document.createElement( "div" ), +		div = document.createElement( "div" ); + +	// Finish early in limited (non-browser) environments +	if ( !div.style ) { +		return; +	} + +	// Support: IE <=9 - 11 only +	// Style of cloned element affects source element cloned (#8908) +	div.style.backgroundClip = "content-box"; +	div.cloneNode( true ).style.backgroundClip = ""; +	support.clearCloneStyle = div.style.backgroundClip === "content-box"; + +	jQuery.extend( support, { +		boxSizingReliable: function() { +			computeStyleTests(); +			return boxSizingReliableVal; +		}, +		pixelBoxStyles: function() { +			computeStyleTests(); +			return pixelBoxStylesVal; +		}, +		pixelPosition: function() { +			computeStyleTests(); +			return pixelPositionVal; +		}, +		reliableMarginLeft: function() { +			computeStyleTests(); +			return reliableMarginLeftVal; +		}, +		scrollboxSize: function() { +			computeStyleTests(); +			return scrollboxSizeVal; +		}, + +		// Support: IE 9 - 11+, Edge 15 - 18+ +		// IE/Edge misreport `getComputedStyle` of table rows with width/height +		// set in CSS while `offset*` properties report correct values. +		// Behavior in IE 9 is more subtle than in newer versions & it passes +		// some versions of this test; make sure not to make it pass there! +		// +		// Support: Firefox 70+ +		// Only Firefox includes border widths +		// in computed dimensions. (gh-4529) +		reliableTrDimensions: function() { +			var table, tr, trChild, trStyle; +			if ( reliableTrDimensionsVal == null ) { +				table = document.createElement( "table" ); +				tr = document.createElement( "tr" ); +				trChild = document.createElement( "div" ); + +				table.style.cssText = "position:absolute;left:-11111px;border-collapse:separate"; +				tr.style.cssText = "border:1px solid"; + +				// Support: Chrome 86+ +				// Height set through cssText does not get applied. +				// Computed height then comes back as 0. +				tr.style.height = "1px"; +				trChild.style.height = "9px"; + +				// Support: Android 8 Chrome 86+ +				// In our bodyBackground.html iframe, +				// display for all div elements is set to "inline", +				// which causes a problem only in Android 8 Chrome 86. +				// Ensuring the div is display: block +				// gets around this issue. +				trChild.style.display = "block"; + +				documentElement +					.appendChild( table ) +					.appendChild( tr ) +					.appendChild( trChild ); + +				trStyle = window.getComputedStyle( tr ); +				reliableTrDimensionsVal = ( parseInt( trStyle.height, 10 ) + +					parseInt( trStyle.borderTopWidth, 10 ) + +					parseInt( trStyle.borderBottomWidth, 10 ) ) === tr.offsetHeight; + +				documentElement.removeChild( table ); +			} +			return reliableTrDimensionsVal; +		} +	} ); +} )(); + + +function curCSS( elem, name, computed ) { +	var width, minWidth, maxWidth, ret, + +		// Support: Firefox 51+ +		// Retrieving style before computed somehow +		// fixes an issue with getting wrong values +		// on detached elements +		style = elem.style; + +	computed = computed || getStyles( elem ); + +	// getPropertyValue is needed for: +	//   .css('filter') (IE 9 only, #12537) +	//   .css('--customProperty) (#3144) +	if ( computed ) { +		ret = computed.getPropertyValue( name ) || computed[ name ]; + +		if ( ret === "" && !isAttached( elem ) ) { +			ret = jQuery.style( elem, name ); +		} + +		// A tribute to the "awesome hack by Dean Edwards" +		// Android Browser returns percentage for some values, +		// but width seems to be reliably pixels. +		// This is against the CSSOM draft spec: +		// https://drafts.csswg.org/cssom/#resolved-values +		if ( !support.pixelBoxStyles() && rnumnonpx.test( ret ) && rboxStyle.test( name ) ) { + +			// Remember the original values +			width = style.width; +			minWidth = style.minWidth; +			maxWidth = style.maxWidth; + +			// Put in the new values to get a computed value out +			style.minWidth = style.maxWidth = style.width = ret; +			ret = computed.width; + +			// Revert the changed values +			style.width = width; +			style.minWidth = minWidth; +			style.maxWidth = maxWidth; +		} +	} + +	return ret !== undefined ? + +		// Support: IE <=9 - 11 only +		// IE returns zIndex value as an integer. +		ret + "" : +		ret; +} + + +function addGetHookIf( conditionFn, hookFn ) { + +	// Define the hook, we'll check on the first run if it's really needed. +	return { +		get: function() { +			if ( conditionFn() ) { + +				// Hook not needed (or it's not possible to use it due +				// to missing dependency), remove it. +				delete this.get; +				return; +			} + +			// Hook needed; redefine it so that the support test is not executed again. +			return ( this.get = hookFn ).apply( this, arguments ); +		} +	}; +} + + +var cssPrefixes = [ "Webkit", "Moz", "ms" ], +	emptyStyle = document.createElement( "div" ).style, +	vendorProps = {}; + +// Return a vendor-prefixed property or undefined +function vendorPropName( name ) { + +	// Check for vendor prefixed names +	var capName = name[ 0 ].toUpperCase() + name.slice( 1 ), +		i = cssPrefixes.length; + +	while ( i-- ) { +		name = cssPrefixes[ i ] + capName; +		if ( name in emptyStyle ) { +			return name; +		} +	} +} + +// Return a potentially-mapped jQuery.cssProps or vendor prefixed property +function finalPropName( name ) { +	var final = jQuery.cssProps[ name ] || vendorProps[ name ]; + +	if ( final ) { +		return final; +	} +	if ( name in emptyStyle ) { +		return name; +	} +	return vendorProps[ name ] = vendorPropName( name ) || name; +} + + +var + +	// Swappable if display is none or starts with table +	// except "table", "table-cell", or "table-caption" +	// See here for display values: https://developer.mozilla.org/en-US/docs/CSS/display +	rdisplayswap = /^(none|table(?!-c[ea]).+)/, +	rcustomProp = /^--/, +	cssShow = { position: "absolute", visibility: "hidden", display: "block" }, +	cssNormalTransform = { +		letterSpacing: "0", +		fontWeight: "400" +	}; + +function setPositiveNumber( _elem, value, subtract ) { + +	// Any relative (+/-) values have already been +	// normalized at this point +	var matches = rcssNum.exec( value ); +	return matches ? + +		// Guard against undefined "subtract", e.g., when used as in cssHooks +		Math.max( 0, matches[ 2 ] - ( subtract || 0 ) ) + ( matches[ 3 ] || "px" ) : +		value; +} + +function boxModelAdjustment( elem, dimension, box, isBorderBox, styles, computedVal ) { +	var i = dimension === "width" ? 1 : 0, +		extra = 0, +		delta = 0; + +	// Adjustment may not be necessary +	if ( box === ( isBorderBox ? "border" : "content" ) ) { +		return 0; +	} + +	for ( ; i < 4; i += 2 ) { + +		// Both box models exclude margin +		if ( box === "margin" ) { +			delta += jQuery.css( elem, box + cssExpand[ i ], true, styles ); +		} + +		// If we get here with a content-box, we're seeking "padding" or "border" or "margin" +		if ( !isBorderBox ) { + +			// Add padding +			delta += jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); + +			// For "border" or "margin", add border +			if ( box !== "padding" ) { +				delta += jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); + +			// But still keep track of it otherwise +			} else { +				extra += jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); +			} + +		// If we get here with a border-box (content + padding + border), we're seeking "content" or +		// "padding" or "margin" +		} else { + +			// For "content", subtract padding +			if ( box === "content" ) { +				delta -= jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); +			} + +			// For "content" or "padding", subtract border +			if ( box !== "margin" ) { +				delta -= jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); +			} +		} +	} + +	// Account for positive content-box scroll gutter when requested by providing computedVal +	if ( !isBorderBox && computedVal >= 0 ) { + +		// offsetWidth/offsetHeight is a rounded sum of content, padding, scroll gutter, and border +		// Assuming integer scroll gutter, subtract the rest and round down +		delta += Math.max( 0, Math.ceil( +			elem[ "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ] - +			computedVal - +			delta - +			extra - +			0.5 + +		// If offsetWidth/offsetHeight is unknown, then we can't determine content-box scroll gutter +		// Use an explicit zero to avoid NaN (gh-3964) +		) ) || 0; +	} + +	return delta; +} + +function getWidthOrHeight( elem, dimension, extra ) { + +	// Start with computed style +	var styles = getStyles( elem ), + +		// To avoid forcing a reflow, only fetch boxSizing if we need it (gh-4322). +		// Fake content-box until we know it's needed to know the true value. +		boxSizingNeeded = !support.boxSizingReliable() || extra, +		isBorderBox = boxSizingNeeded && +			jQuery.css( elem, "boxSizing", false, styles ) === "border-box", +		valueIsBorderBox = isBorderBox, + +		val = curCSS( elem, dimension, styles ), +		offsetProp = "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ); + +	// Support: Firefox <=54 +	// Return a confounding non-pixel value or feign ignorance, as appropriate. +	if ( rnumnonpx.test( val ) ) { +		if ( !extra ) { +			return val; +		} +		val = "auto"; +	} + + +	// Support: IE 9 - 11 only +	// Use offsetWidth/offsetHeight for when box sizing is unreliable. +	// In those cases, the computed value can be trusted to be border-box. +	if ( ( !support.boxSizingReliable() && isBorderBox || + +		// Support: IE 10 - 11+, Edge 15 - 18+ +		// IE/Edge misreport `getComputedStyle` of table rows with width/height +		// set in CSS while `offset*` properties report correct values. +		// Interestingly, in some cases IE 9 doesn't suffer from this issue. +		!support.reliableTrDimensions() && nodeName( elem, "tr" ) || + +		// Fall back to offsetWidth/offsetHeight when value is "auto" +		// This happens for inline elements with no explicit setting (gh-3571) +		val === "auto" || + +		// Support: Android <=4.1 - 4.3 only +		// Also use offsetWidth/offsetHeight for misreported inline dimensions (gh-3602) +		!parseFloat( val ) && jQuery.css( elem, "display", false, styles ) === "inline" ) && + +		// Make sure the element is visible & connected +		elem.getClientRects().length ) { + +		isBorderBox = jQuery.css( elem, "boxSizing", false, styles ) === "border-box"; + +		// Where available, offsetWidth/offsetHeight approximate border box dimensions. +		// Where not available (e.g., SVG), assume unreliable box-sizing and interpret the +		// retrieved value as a content box dimension. +		valueIsBorderBox = offsetProp in elem; +		if ( valueIsBorderBox ) { +			val = elem[ offsetProp ]; +		} +	} + +	// Normalize "" and auto +	val = parseFloat( val ) || 0; + +	// Adjust for the element's box model +	return ( val + +		boxModelAdjustment( +			elem, +			dimension, +			extra || ( isBorderBox ? "border" : "content" ), +			valueIsBorderBox, +			styles, + +			// Provide the current computed size to request scroll gutter calculation (gh-3589) +			val +		) +	) + "px"; +} + +jQuery.extend( { + +	// Add in style property hooks for overriding the default +	// behavior of getting and setting a style property +	cssHooks: { +		opacity: { +			get: function( elem, computed ) { +				if ( computed ) { + +					// We should always get a number back from opacity +					var ret = curCSS( elem, "opacity" ); +					return ret === "" ? "1" : ret; +				} +			} +		} +	}, + +	// Don't automatically add "px" to these possibly-unitless properties +	cssNumber: { +		"animationIterationCount": true, +		"columnCount": true, +		"fillOpacity": true, +		"flexGrow": true, +		"flexShrink": true, +		"fontWeight": true, +		"gridArea": true, +		"gridColumn": true, +		"gridColumnEnd": true, +		"gridColumnStart": true, +		"gridRow": true, +		"gridRowEnd": true, +		"gridRowStart": true, +		"lineHeight": true, +		"opacity": true, +		"order": true, +		"orphans": true, +		"widows": true, +		"zIndex": true, +		"zoom": true +	}, + +	// Add in properties whose names you wish to fix before +	// setting or getting the value +	cssProps: {}, + +	// Get and set the style property on a DOM Node +	style: function( elem, name, value, extra ) { + +		// Don't set styles on text and comment nodes +		if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) { +			return; +		} + +		// Make sure that we're working with the right name +		var ret, type, hooks, +			origName = camelCase( name ), +			isCustomProp = rcustomProp.test( name ), +			style = elem.style; + +		// Make sure that we're working with the right name. We don't +		// want to query the value if it is a CSS custom property +		// since they are user-defined. +		if ( !isCustomProp ) { +			name = finalPropName( origName ); +		} + +		// Gets hook for the prefixed version, then unprefixed version +		hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ]; + +		// Check if we're setting a value +		if ( value !== undefined ) { +			type = typeof value; + +			// Convert "+=" or "-=" to relative numbers (#7345) +			if ( type === "string" && ( ret = rcssNum.exec( value ) ) && ret[ 1 ] ) { +				value = adjustCSS( elem, name, ret ); + +				// Fixes bug #9237 +				type = "number"; +			} + +			// Make sure that null and NaN values aren't set (#7116) +			if ( value == null || value !== value ) { +				return; +			} + +			// If a number was passed in, add the unit (except for certain CSS properties) +			// The isCustomProp check can be removed in jQuery 4.0 when we only auto-append +			// "px" to a few hardcoded values. +			if ( type === "number" && !isCustomProp ) { +				value += ret && ret[ 3 ] || ( jQuery.cssNumber[ origName ] ? "" : "px" ); +			} + +			// background-* props affect original clone's values +			if ( !support.clearCloneStyle && value === "" && name.indexOf( "background" ) === 0 ) { +				style[ name ] = "inherit"; +			} + +			// If a hook was provided, use that value, otherwise just set the specified value +			if ( !hooks || !( "set" in hooks ) || +				( value = hooks.set( elem, value, extra ) ) !== undefined ) { + +				if ( isCustomProp ) { +					style.setProperty( name, value ); +				} else { +					style[ name ] = value; +				} +			} + +		} else { + +			// If a hook was provided get the non-computed value from there +			if ( hooks && "get" in hooks && +				( ret = hooks.get( elem, false, extra ) ) !== undefined ) { + +				return ret; +			} + +			// Otherwise just get the value from the style object +			return style[ name ]; +		} +	}, + +	css: function( elem, name, extra, styles ) { +		var val, num, hooks, +			origName = camelCase( name ), +			isCustomProp = rcustomProp.test( name ); + +		// Make sure that we're working with the right name. We don't +		// want to modify the value if it is a CSS custom property +		// since they are user-defined. +		if ( !isCustomProp ) { +			name = finalPropName( origName ); +		} + +		// Try prefixed name followed by the unprefixed name +		hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ]; + +		// If a hook was provided get the computed value from there +		if ( hooks && "get" in hooks ) { +			val = hooks.get( elem, true, extra ); +		} + +		// Otherwise, if a way to get the computed value exists, use that +		if ( val === undefined ) { +			val = curCSS( elem, name, styles ); +		} + +		// Convert "normal" to computed value +		if ( val === "normal" && name in cssNormalTransform ) { +			val = cssNormalTransform[ name ]; +		} + +		// Make numeric if forced or a qualifier was provided and val looks numeric +		if ( extra === "" || extra ) { +			num = parseFloat( val ); +			return extra === true || isFinite( num ) ? num || 0 : val; +		} + +		return val; +	} +} ); + +jQuery.each( [ "height", "width" ], function( _i, dimension ) { +	jQuery.cssHooks[ dimension ] = { +		get: function( elem, computed, extra ) { +			if ( computed ) { + +				// Certain elements can have dimension info if we invisibly show them +				// but it must have a current display style that would benefit +				return rdisplayswap.test( jQuery.css( elem, "display" ) ) && + +					// Support: Safari 8+ +					// Table columns in Safari have non-zero offsetWidth & zero +					// getBoundingClientRect().width unless display is changed. +					// Support: IE <=11 only +					// Running getBoundingClientRect on a disconnected node +					// in IE throws an error. +					( !elem.getClientRects().length || !elem.getBoundingClientRect().width ) ? +					swap( elem, cssShow, function() { +						return getWidthOrHeight( elem, dimension, extra ); +					} ) : +					getWidthOrHeight( elem, dimension, extra ); +			} +		}, + +		set: function( elem, value, extra ) { +			var matches, +				styles = getStyles( elem ), + +				// Only read styles.position if the test has a chance to fail +				// to avoid forcing a reflow. +				scrollboxSizeBuggy = !support.scrollboxSize() && +					styles.position === "absolute", + +				// To avoid forcing a reflow, only fetch boxSizing if we need it (gh-3991) +				boxSizingNeeded = scrollboxSizeBuggy || extra, +				isBorderBox = boxSizingNeeded && +					jQuery.css( elem, "boxSizing", false, styles ) === "border-box", +				subtract = extra ? +					boxModelAdjustment( +						elem, +						dimension, +						extra, +						isBorderBox, +						styles +					) : +					0; + +			// Account for unreliable border-box dimensions by comparing offset* to computed and +			// faking a content-box to get border and padding (gh-3699) +			if ( isBorderBox && scrollboxSizeBuggy ) { +				subtract -= Math.ceil( +					elem[ "offset" + dimension[ 0 ].toUpperCase() + dimension.slice( 1 ) ] - +					parseFloat( styles[ dimension ] ) - +					boxModelAdjustment( elem, dimension, "border", false, styles ) - +					0.5 +				); +			} + +			// Convert to pixels if value adjustment is needed +			if ( subtract && ( matches = rcssNum.exec( value ) ) && +				( matches[ 3 ] || "px" ) !== "px" ) { + +				elem.style[ dimension ] = value; +				value = jQuery.css( elem, dimension ); +			} + +			return setPositiveNumber( elem, value, subtract ); +		} +	}; +} ); + +jQuery.cssHooks.marginLeft = addGetHookIf( support.reliableMarginLeft, +	function( elem, computed ) { +		if ( computed ) { +			return ( parseFloat( curCSS( elem, "marginLeft" ) ) || +				elem.getBoundingClientRect().left - +					swap( elem, { marginLeft: 0 }, function() { +						return elem.getBoundingClientRect().left; +					} ) +			) + "px"; +		} +	} +); + +// These hooks are used by animate to expand properties +jQuery.each( { +	margin: "", +	padding: "", +	border: "Width" +}, function( prefix, suffix ) { +	jQuery.cssHooks[ prefix + suffix ] = { +		expand: function( value ) { +			var i = 0, +				expanded = {}, + +				// Assumes a single number if not a string +				parts = typeof value === "string" ? value.split( " " ) : [ value ]; + +			for ( ; i < 4; i++ ) { +				expanded[ prefix + cssExpand[ i ] + suffix ] = +					parts[ i ] || parts[ i - 2 ] || parts[ 0 ]; +			} + +			return expanded; +		} +	}; + +	if ( prefix !== "margin" ) { +		jQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber; +	} +} ); + +jQuery.fn.extend( { +	css: function( name, value ) { +		return access( this, function( elem, name, value ) { +			var styles, len, +				map = {}, +				i = 0; + +			if ( Array.isArray( name ) ) { +				styles = getStyles( elem ); +				len = name.length; + +				for ( ; i < len; i++ ) { +					map[ name[ i ] ] = jQuery.css( elem, name[ i ], false, styles ); +				} + +				return map; +			} + +			return value !== undefined ? +				jQuery.style( elem, name, value ) : +				jQuery.css( elem, name ); +		}, name, value, arguments.length > 1 ); +	} +} ); + + +function Tween( elem, options, prop, end, easing ) { +	return new Tween.prototype.init( elem, options, prop, end, easing ); +} +jQuery.Tween = Tween; + +Tween.prototype = { +	constructor: Tween, +	init: function( elem, options, prop, end, easing, unit ) { +		this.elem = elem; +		this.prop = prop; +		this.easing = easing || jQuery.easing._default; +		this.options = options; +		this.start = this.now = this.cur(); +		this.end = end; +		this.unit = unit || ( jQuery.cssNumber[ prop ] ? "" : "px" ); +	}, +	cur: function() { +		var hooks = Tween.propHooks[ this.prop ]; + +		return hooks && hooks.get ? +			hooks.get( this ) : +			Tween.propHooks._default.get( this ); +	}, +	run: function( percent ) { +		var eased, +			hooks = Tween.propHooks[ this.prop ]; + +		if ( this.options.duration ) { +			this.pos = eased = jQuery.easing[ this.easing ]( +				percent, this.options.duration * percent, 0, 1, this.options.duration +			); +		} else { +			this.pos = eased = percent; +		} +		this.now = ( this.end - this.start ) * eased + this.start; + +		if ( this.options.step ) { +			this.options.step.call( this.elem, this.now, this ); +		} + +		if ( hooks && hooks.set ) { +			hooks.set( this ); +		} else { +			Tween.propHooks._default.set( this ); +		} +		return this; +	} +}; + +Tween.prototype.init.prototype = Tween.prototype; + +Tween.propHooks = { +	_default: { +		get: function( tween ) { +			var result; + +			// Use a property on the element directly when it is not a DOM element, +			// or when there is no matching style property that exists. +			if ( tween.elem.nodeType !== 1 || +				tween.elem[ tween.prop ] != null && tween.elem.style[ tween.prop ] == null ) { +				return tween.elem[ tween.prop ]; +			} + +			// Passing an empty string as a 3rd parameter to .css will automatically +			// attempt a parseFloat and fallback to a string if the parse fails. +			// Simple values such as "10px" are parsed to Float; +			// complex values such as "rotate(1rad)" are returned as-is. +			result = jQuery.css( tween.elem, tween.prop, "" ); + +			// Empty strings, null, undefined and "auto" are converted to 0. +			return !result || result === "auto" ? 0 : result; +		}, +		set: function( tween ) { + +			// Use step hook for back compat. +			// Use cssHook if its there. +			// Use .style if available and use plain properties where available. +			if ( jQuery.fx.step[ tween.prop ] ) { +				jQuery.fx.step[ tween.prop ]( tween ); +			} else if ( tween.elem.nodeType === 1 && ( +				jQuery.cssHooks[ tween.prop ] || +					tween.elem.style[ finalPropName( tween.prop ) ] != null ) ) { +				jQuery.style( tween.elem, tween.prop, tween.now + tween.unit ); +			} else { +				tween.elem[ tween.prop ] = tween.now; +			} +		} +	} +}; + +// Support: IE <=9 only +// Panic based approach to setting things on disconnected nodes +Tween.propHooks.scrollTop = Tween.propHooks.scrollLeft = { +	set: function( tween ) { +		if ( tween.elem.nodeType && tween.elem.parentNode ) { +			tween.elem[ tween.prop ] = tween.now; +		} +	} +}; + +jQuery.easing = { +	linear: function( p ) { +		return p; +	}, +	swing: function( p ) { +		return 0.5 - Math.cos( p * Math.PI ) / 2; +	}, +	_default: "swing" +}; + +jQuery.fx = Tween.prototype.init; + +// Back compat <1.8 extension point +jQuery.fx.step = {}; + + + + +var +	fxNow, inProgress, +	rfxtypes = /^(?:toggle|show|hide)$/, +	rrun = /queueHooks$/; + +function schedule() { +	if ( inProgress ) { +		if ( document.hidden === false && window.requestAnimationFrame ) { +			window.requestAnimationFrame( schedule ); +		} else { +			window.setTimeout( schedule, jQuery.fx.interval ); +		} + +		jQuery.fx.tick(); +	} +} + +// Animations created synchronously will run synchronously +function createFxNow() { +	window.setTimeout( function() { +		fxNow = undefined; +	} ); +	return ( fxNow = Date.now() ); +} + +// Generate parameters to create a standard animation +function genFx( type, includeWidth ) { +	var which, +		i = 0, +		attrs = { height: type }; + +	// If we include width, step value is 1 to do all cssExpand values, +	// otherwise step value is 2 to skip over Left and Right +	includeWidth = includeWidth ? 1 : 0; +	for ( ; i < 4; i += 2 - includeWidth ) { +		which = cssExpand[ i ]; +		attrs[ "margin" + which ] = attrs[ "padding" + which ] = type; +	} + +	if ( includeWidth ) { +		attrs.opacity = attrs.width = type; +	} + +	return attrs; +} + +function createTween( value, prop, animation ) { +	var tween, +		collection = ( Animation.tweeners[ prop ] || [] ).concat( Animation.tweeners[ "*" ] ), +		index = 0, +		length = collection.length; +	for ( ; index < length; index++ ) { +		if ( ( tween = collection[ index ].call( animation, prop, value ) ) ) { + +			// We're done with this property +			return tween; +		} +	} +} + +function defaultPrefilter( elem, props, opts ) { +	var prop, value, toggle, hooks, oldfire, propTween, restoreDisplay, display, +		isBox = "width" in props || "height" in props, +		anim = this, +		orig = {}, +		style = elem.style, +		hidden = elem.nodeType && isHiddenWithinTree( elem ), +		dataShow = dataPriv.get( elem, "fxshow" ); + +	// Queue-skipping animations hijack the fx hooks +	if ( !opts.queue ) { +		hooks = jQuery._queueHooks( elem, "fx" ); +		if ( hooks.unqueued == null ) { +			hooks.unqueued = 0; +			oldfire = hooks.empty.fire; +			hooks.empty.fire = function() { +				if ( !hooks.unqueued ) { +					oldfire(); +				} +			}; +		} +		hooks.unqueued++; + +		anim.always( function() { + +			// Ensure the complete handler is called before this completes +			anim.always( function() { +				hooks.unqueued--; +				if ( !jQuery.queue( elem, "fx" ).length ) { +					hooks.empty.fire(); +				} +			} ); +		} ); +	} + +	// Detect show/hide animations +	for ( prop in props ) { +		value = props[ prop ]; +		if ( rfxtypes.test( value ) ) { +			delete props[ prop ]; +			toggle = toggle || value === "toggle"; +			if ( value === ( hidden ? "hide" : "show" ) ) { + +				// Pretend to be hidden if this is a "show" and +				// there is still data from a stopped show/hide +				if ( value === "show" && dataShow && dataShow[ prop ] !== undefined ) { +					hidden = true; + +				// Ignore all other no-op show/hide data +				} else { +					continue; +				} +			} +			orig[ prop ] = dataShow && dataShow[ prop ] || jQuery.style( elem, prop ); +		} +	} + +	// Bail out if this is a no-op like .hide().hide() +	propTween = !jQuery.isEmptyObject( props ); +	if ( !propTween && jQuery.isEmptyObject( orig ) ) { +		return; +	} + +	// Restrict "overflow" and "display" styles during box animations +	if ( isBox && elem.nodeType === 1 ) { + +		// Support: IE <=9 - 11, Edge 12 - 15 +		// Record all 3 overflow attributes because IE does not infer the shorthand +		// from identically-valued overflowX and overflowY and Edge just mirrors +		// the overflowX value there. +		opts.overflow = [ style.overflow, style.overflowX, style.overflowY ]; + +		// Identify a display type, preferring old show/hide data over the CSS cascade +		restoreDisplay = dataShow && dataShow.display; +		if ( restoreDisplay == null ) { +			restoreDisplay = dataPriv.get( elem, "display" ); +		} +		display = jQuery.css( elem, "display" ); +		if ( display === "none" ) { +			if ( restoreDisplay ) { +				display = restoreDisplay; +			} else { + +				// Get nonempty value(s) by temporarily forcing visibility +				showHide( [ elem ], true ); +				restoreDisplay = elem.style.display || restoreDisplay; +				display = jQuery.css( elem, "display" ); +				showHide( [ elem ] ); +			} +		} + +		// Animate inline elements as inline-block +		if ( display === "inline" || display === "inline-block" && restoreDisplay != null ) { +			if ( jQuery.css( elem, "float" ) === "none" ) { + +				// Restore the original display value at the end of pure show/hide animations +				if ( !propTween ) { +					anim.done( function() { +						style.display = restoreDisplay; +					} ); +					if ( restoreDisplay == null ) { +						display = style.display; +						restoreDisplay = display === "none" ? "" : display; +					} +				} +				style.display = "inline-block"; +			} +		} +	} + +	if ( opts.overflow ) { +		style.overflow = "hidden"; +		anim.always( function() { +			style.overflow = opts.overflow[ 0 ]; +			style.overflowX = opts.overflow[ 1 ]; +			style.overflowY = opts.overflow[ 2 ]; +		} ); +	} + +	// Implement show/hide animations +	propTween = false; +	for ( prop in orig ) { + +		// General show/hide setup for this element animation +		if ( !propTween ) { +			if ( dataShow ) { +				if ( "hidden" in dataShow ) { +					hidden = dataShow.hidden; +				} +			} else { +				dataShow = dataPriv.access( elem, "fxshow", { display: restoreDisplay } ); +			} + +			// Store hidden/visible for toggle so `.stop().toggle()` "reverses" +			if ( toggle ) { +				dataShow.hidden = !hidden; +			} + +			// Show elements before animating them +			if ( hidden ) { +				showHide( [ elem ], true ); +			} + +			/* eslint-disable no-loop-func */ + +			anim.done( function() { + +				/* eslint-enable no-loop-func */ + +				// The final step of a "hide" animation is actually hiding the element +				if ( !hidden ) { +					showHide( [ elem ] ); +				} +				dataPriv.remove( elem, "fxshow" ); +				for ( prop in orig ) { +					jQuery.style( elem, prop, orig[ prop ] ); +				} +			} ); +		} + +		// Per-property setup +		propTween = createTween( hidden ? dataShow[ prop ] : 0, prop, anim ); +		if ( !( prop in dataShow ) ) { +			dataShow[ prop ] = propTween.start; +			if ( hidden ) { +				propTween.end = propTween.start; +				propTween.start = 0; +			} +		} +	} +} + +function propFilter( props, specialEasing ) { +	var index, name, easing, value, hooks; + +	// camelCase, specialEasing and expand cssHook pass +	for ( index in props ) { +		name = camelCase( index ); +		easing = specialEasing[ name ]; +		value = props[ index ]; +		if ( Array.isArray( value ) ) { +			easing = value[ 1 ]; +			value = props[ index ] = value[ 0 ]; +		} + +		if ( index !== name ) { +			props[ name ] = value; +			delete props[ index ]; +		} + +		hooks = jQuery.cssHooks[ name ]; +		if ( hooks && "expand" in hooks ) { +			value = hooks.expand( value ); +			delete props[ name ]; + +			// Not quite $.extend, this won't overwrite existing keys. +			// Reusing 'index' because we have the correct "name" +			for ( index in value ) { +				if ( !( index in props ) ) { +					props[ index ] = value[ index ]; +					specialEasing[ index ] = easing; +				} +			} +		} else { +			specialEasing[ name ] = easing; +		} +	} +} + +function Animation( elem, properties, options ) { +	var result, +		stopped, +		index = 0, +		length = Animation.prefilters.length, +		deferred = jQuery.Deferred().always( function() { + +			// Don't match elem in the :animated selector +			delete tick.elem; +		} ), +		tick = function() { +			if ( stopped ) { +				return false; +			} +			var currentTime = fxNow || createFxNow(), +				remaining = Math.max( 0, animation.startTime + animation.duration - currentTime ), + +				// Support: Android 2.3 only +				// Archaic crash bug won't allow us to use `1 - ( 0.5 || 0 )` (#12497) +				temp = remaining / animation.duration || 0, +				percent = 1 - temp, +				index = 0, +				length = animation.tweens.length; + +			for ( ; index < length; index++ ) { +				animation.tweens[ index ].run( percent ); +			} + +			deferred.notifyWith( elem, [ animation, percent, remaining ] ); + +			// If there's more to do, yield +			if ( percent < 1 && length ) { +				return remaining; +			} + +			// If this was an empty animation, synthesize a final progress notification +			if ( !length ) { +				deferred.notifyWith( elem, [ animation, 1, 0 ] ); +			} + +			// Resolve the animation and report its conclusion +			deferred.resolveWith( elem, [ animation ] ); +			return false; +		}, +		animation = deferred.promise( { +			elem: elem, +			props: jQuery.extend( {}, properties ), +			opts: jQuery.extend( true, { +				specialEasing: {}, +				easing: jQuery.easing._default +			}, options ), +			originalProperties: properties, +			originalOptions: options, +			startTime: fxNow || createFxNow(), +			duration: options.duration, +			tweens: [], +			createTween: function( prop, end ) { +				var tween = jQuery.Tween( elem, animation.opts, prop, end, +					animation.opts.specialEasing[ prop ] || animation.opts.easing ); +				animation.tweens.push( tween ); +				return tween; +			}, +			stop: function( gotoEnd ) { +				var index = 0, + +					// If we are going to the end, we want to run all the tweens +					// otherwise we skip this part +					length = gotoEnd ? animation.tweens.length : 0; +				if ( stopped ) { +					return this; +				} +				stopped = true; +				for ( ; index < length; index++ ) { +					animation.tweens[ index ].run( 1 ); +				} + +				// Resolve when we played the last frame; otherwise, reject +				if ( gotoEnd ) { +					deferred.notifyWith( elem, [ animation, 1, 0 ] ); +					deferred.resolveWith( elem, [ animation, gotoEnd ] ); +				} else { +					deferred.rejectWith( elem, [ animation, gotoEnd ] ); +				} +				return this; +			} +		} ), +		props = animation.props; + +	propFilter( props, animation.opts.specialEasing ); + +	for ( ; index < length; index++ ) { +		result = Animation.prefilters[ index ].call( animation, elem, props, animation.opts ); +		if ( result ) { +			if ( isFunction( result.stop ) ) { +				jQuery._queueHooks( animation.elem, animation.opts.queue ).stop = +					result.stop.bind( result ); +			} +			return result; +		} +	} + +	jQuery.map( props, createTween, animation ); + +	if ( isFunction( animation.opts.start ) ) { +		animation.opts.start.call( elem, animation ); +	} + +	// Attach callbacks from options +	animation +		.progress( animation.opts.progress ) +		.done( animation.opts.done, animation.opts.complete ) +		.fail( animation.opts.fail ) +		.always( animation.opts.always ); + +	jQuery.fx.timer( +		jQuery.extend( tick, { +			elem: elem, +			anim: animation, +			queue: animation.opts.queue +		} ) +	); + +	return animation; +} + +jQuery.Animation = jQuery.extend( Animation, { + +	tweeners: { +		"*": [ function( prop, value ) { +			var tween = this.createTween( prop, value ); +			adjustCSS( tween.elem, prop, rcssNum.exec( value ), tween ); +			return tween; +		} ] +	}, + +	tweener: function( props, callback ) { +		if ( isFunction( props ) ) { +			callback = props; +			props = [ "*" ]; +		} else { +			props = props.match( rnothtmlwhite ); +		} + +		var prop, +			index = 0, +			length = props.length; + +		for ( ; index < length; index++ ) { +			prop = props[ index ]; +			Animation.tweeners[ prop ] = Animation.tweeners[ prop ] || []; +			Animation.tweeners[ prop ].unshift( callback ); +		} +	}, + +	prefilters: [ defaultPrefilter ], + +	prefilter: function( callback, prepend ) { +		if ( prepend ) { +			Animation.prefilters.unshift( callback ); +		} else { +			Animation.prefilters.push( callback ); +		} +	} +} ); + +jQuery.speed = function( speed, easing, fn ) { +	var opt = speed && typeof speed === "object" ? jQuery.extend( {}, speed ) : { +		complete: fn || !fn && easing || +			isFunction( speed ) && speed, +		duration: speed, +		easing: fn && easing || easing && !isFunction( easing ) && easing +	}; + +	// Go to the end state if fx are off +	if ( jQuery.fx.off ) { +		opt.duration = 0; + +	} else { +		if ( typeof opt.duration !== "number" ) { +			if ( opt.duration in jQuery.fx.speeds ) { +				opt.duration = jQuery.fx.speeds[ opt.duration ]; + +			} else { +				opt.duration = jQuery.fx.speeds._default; +			} +		} +	} + +	// Normalize opt.queue - true/undefined/null -> "fx" +	if ( opt.queue == null || opt.queue === true ) { +		opt.queue = "fx"; +	} + +	// Queueing +	opt.old = opt.complete; + +	opt.complete = function() { +		if ( isFunction( opt.old ) ) { +			opt.old.call( this ); +		} + +		if ( opt.queue ) { +			jQuery.dequeue( this, opt.queue ); +		} +	}; + +	return opt; +}; + +jQuery.fn.extend( { +	fadeTo: function( speed, to, easing, callback ) { + +		// Show any hidden elements after setting opacity to 0 +		return this.filter( isHiddenWithinTree ).css( "opacity", 0 ).show() + +			// Animate to the value specified +			.end().animate( { opacity: to }, speed, easing, callback ); +	}, +	animate: function( prop, speed, easing, callback ) { +		var empty = jQuery.isEmptyObject( prop ), +			optall = jQuery.speed( speed, easing, callback ), +			doAnimation = function() { + +				// Operate on a copy of prop so per-property easing won't be lost +				var anim = Animation( this, jQuery.extend( {}, prop ), optall ); + +				// Empty animations, or finishing resolves immediately +				if ( empty || dataPriv.get( this, "finish" ) ) { +					anim.stop( true ); +				} +			}; + +		doAnimation.finish = doAnimation; + +		return empty || optall.queue === false ? +			this.each( doAnimation ) : +			this.queue( optall.queue, doAnimation ); +	}, +	stop: function( type, clearQueue, gotoEnd ) { +		var stopQueue = function( hooks ) { +			var stop = hooks.stop; +			delete hooks.stop; +			stop( gotoEnd ); +		}; + +		if ( typeof type !== "string" ) { +			gotoEnd = clearQueue; +			clearQueue = type; +			type = undefined; +		} +		if ( clearQueue ) { +			this.queue( type || "fx", [] ); +		} + +		return this.each( function() { +			var dequeue = true, +				index = type != null && type + "queueHooks", +				timers = jQuery.timers, +				data = dataPriv.get( this ); + +			if ( index ) { +				if ( data[ index ] && data[ index ].stop ) { +					stopQueue( data[ index ] ); +				} +			} else { +				for ( index in data ) { +					if ( data[ index ] && data[ index ].stop && rrun.test( index ) ) { +						stopQueue( data[ index ] ); +					} +				} +			} + +			for ( index = timers.length; index--; ) { +				if ( timers[ index ].elem === this && +					( type == null || timers[ index ].queue === type ) ) { + +					timers[ index ].anim.stop( gotoEnd ); +					dequeue = false; +					timers.splice( index, 1 ); +				} +			} + +			// Start the next in the queue if the last step wasn't forced. +			// Timers currently will call their complete callbacks, which +			// will dequeue but only if they were gotoEnd. +			if ( dequeue || !gotoEnd ) { +				jQuery.dequeue( this, type ); +			} +		} ); +	}, +	finish: function( type ) { +		if ( type !== false ) { +			type = type || "fx"; +		} +		return this.each( function() { +			var index, +				data = dataPriv.get( this ), +				queue = data[ type + "queue" ], +				hooks = data[ type + "queueHooks" ], +				timers = jQuery.timers, +				length = queue ? queue.length : 0; + +			// Enable finishing flag on private data +			data.finish = true; + +			// Empty the queue first +			jQuery.queue( this, type, [] ); + +			if ( hooks && hooks.stop ) { +				hooks.stop.call( this, true ); +			} + +			// Look for any active animations, and finish them +			for ( index = timers.length; index--; ) { +				if ( timers[ index ].elem === this && timers[ index ].queue === type ) { +					timers[ index ].anim.stop( true ); +					timers.splice( index, 1 ); +				} +			} + +			// Look for any animations in the old queue and finish them +			for ( index = 0; index < length; index++ ) { +				if ( queue[ index ] && queue[ index ].finish ) { +					queue[ index ].finish.call( this ); +				} +			} + +			// Turn off finishing flag +			delete data.finish; +		} ); +	} +} ); + +jQuery.each( [ "toggle", "show", "hide" ], function( _i, name ) { +	var cssFn = jQuery.fn[ name ]; +	jQuery.fn[ name ] = function( speed, easing, callback ) { +		return speed == null || typeof speed === "boolean" ? +			cssFn.apply( this, arguments ) : +			this.animate( genFx( name, true ), speed, easing, callback ); +	}; +} ); + +// Generate shortcuts for custom animations +jQuery.each( { +	slideDown: genFx( "show" ), +	slideUp: genFx( "hide" ), +	slideToggle: genFx( "toggle" ), +	fadeIn: { opacity: "show" }, +	fadeOut: { opacity: "hide" }, +	fadeToggle: { opacity: "toggle" } +}, function( name, props ) { +	jQuery.fn[ name ] = function( speed, easing, callback ) { +		return this.animate( props, speed, easing, callback ); +	}; +} ); + +jQuery.timers = []; +jQuery.fx.tick = function() { +	var timer, +		i = 0, +		timers = jQuery.timers; + +	fxNow = Date.now(); + +	for ( ; i < timers.length; i++ ) { +		timer = timers[ i ]; + +		// Run the timer and safely remove it when done (allowing for external removal) +		if ( !timer() && timers[ i ] === timer ) { +			timers.splice( i--, 1 ); +		} +	} + +	if ( !timers.length ) { +		jQuery.fx.stop(); +	} +	fxNow = undefined; +}; + +jQuery.fx.timer = function( timer ) { +	jQuery.timers.push( timer ); +	jQuery.fx.start(); +}; + +jQuery.fx.interval = 13; +jQuery.fx.start = function() { +	if ( inProgress ) { +		return; +	} + +	inProgress = true; +	schedule(); +}; + +jQuery.fx.stop = function() { +	inProgress = null; +}; + +jQuery.fx.speeds = { +	slow: 600, +	fast: 200, + +	// Default speed +	_default: 400 +}; + + +// Based off of the plugin by Clint Helfers, with permission. +// https://web.archive.org/web/20100324014747/http://blindsignals.com/index.php/2009/07/jquery-delay/ +jQuery.fn.delay = function( time, type ) { +	time = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time; +	type = type || "fx"; + +	return this.queue( type, function( next, hooks ) { +		var timeout = window.setTimeout( next, time ); +		hooks.stop = function() { +			window.clearTimeout( timeout ); +		}; +	} ); +}; + + +( function() { +	var input = document.createElement( "input" ), +		select = document.createElement( "select" ), +		opt = select.appendChild( document.createElement( "option" ) ); + +	input.type = "checkbox"; + +	// Support: Android <=4.3 only +	// Default value for a checkbox should be "on" +	support.checkOn = input.value !== ""; + +	// Support: IE <=11 only +	// Must access selectedIndex to make default options select +	support.optSelected = opt.selected; + +	// Support: IE <=11 only +	// An input loses its value after becoming a radio +	input = document.createElement( "input" ); +	input.value = "t"; +	input.type = "radio"; +	support.radioValue = input.value === "t"; +} )(); + + +var boolHook, +	attrHandle = jQuery.expr.attrHandle; + +jQuery.fn.extend( { +	attr: function( name, value ) { +		return access( this, jQuery.attr, name, value, arguments.length > 1 ); +	}, + +	removeAttr: function( name ) { +		return this.each( function() { +			jQuery.removeAttr( this, name ); +		} ); +	} +} ); + +jQuery.extend( { +	attr: function( elem, name, value ) { +		var ret, hooks, +			nType = elem.nodeType; + +		// Don't get/set attributes on text, comment and attribute nodes +		if ( nType === 3 || nType === 8 || nType === 2 ) { +			return; +		} + +		// Fallback to prop when attributes are not supported +		if ( typeof elem.getAttribute === "undefined" ) { +			return jQuery.prop( elem, name, value ); +		} + +		// Attribute hooks are determined by the lowercase version +		// Grab necessary hook if one is defined +		if ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) { +			hooks = jQuery.attrHooks[ name.toLowerCase() ] || +				( jQuery.expr.match.bool.test( name ) ? boolHook : undefined ); +		} + +		if ( value !== undefined ) { +			if ( value === null ) { +				jQuery.removeAttr( elem, name ); +				return; +			} + +			if ( hooks && "set" in hooks && +				( ret = hooks.set( elem, value, name ) ) !== undefined ) { +				return ret; +			} + +			elem.setAttribute( name, value + "" ); +			return value; +		} + +		if ( hooks && "get" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) { +			return ret; +		} + +		ret = jQuery.find.attr( elem, name ); + +		// Non-existent attributes return null, we normalize to undefined +		return ret == null ? undefined : ret; +	}, + +	attrHooks: { +		type: { +			set: function( elem, value ) { +				if ( !support.radioValue && value === "radio" && +					nodeName( elem, "input" ) ) { +					var val = elem.value; +					elem.setAttribute( "type", value ); +					if ( val ) { +						elem.value = val; +					} +					return value; +				} +			} +		} +	}, + +	removeAttr: function( elem, value ) { +		var name, +			i = 0, + +			// Attribute names can contain non-HTML whitespace characters +			// https://html.spec.whatwg.org/multipage/syntax.html#attributes-2 +			attrNames = value && value.match( rnothtmlwhite ); + +		if ( attrNames && elem.nodeType === 1 ) { +			while ( ( name = attrNames[ i++ ] ) ) { +				elem.removeAttribute( name ); +			} +		} +	} +} ); + +// Hooks for boolean attributes +boolHook = { +	set: function( elem, value, name ) { +		if ( value === false ) { + +			// Remove boolean attributes when set to false +			jQuery.removeAttr( elem, name ); +		} else { +			elem.setAttribute( name, name ); +		} +		return name; +	} +}; + +jQuery.each( jQuery.expr.match.bool.source.match( /\w+/g ), function( _i, name ) { +	var getter = attrHandle[ name ] || jQuery.find.attr; + +	attrHandle[ name ] = function( elem, name, isXML ) { +		var ret, handle, +			lowercaseName = name.toLowerCase(); + +		if ( !isXML ) { + +			// Avoid an infinite loop by temporarily removing this function from the getter +			handle = attrHandle[ lowercaseName ]; +			attrHandle[ lowercaseName ] = ret; +			ret = getter( elem, name, isXML ) != null ? +				lowercaseName : +				null; +			attrHandle[ lowercaseName ] = handle; +		} +		return ret; +	}; +} ); + + + + +var rfocusable = /^(?:input|select|textarea|button)$/i, +	rclickable = /^(?:a|area)$/i; + +jQuery.fn.extend( { +	prop: function( name, value ) { +		return access( this, jQuery.prop, name, value, arguments.length > 1 ); +	}, + +	removeProp: function( name ) { +		return this.each( function() { +			delete this[ jQuery.propFix[ name ] || name ]; +		} ); +	} +} ); + +jQuery.extend( { +	prop: function( elem, name, value ) { +		var ret, hooks, +			nType = elem.nodeType; + +		// Don't get/set properties on text, comment and attribute nodes +		if ( nType === 3 || nType === 8 || nType === 2 ) { +			return; +		} + +		if ( nType !== 1 || !jQuery.isXMLDoc( elem ) ) { + +			// Fix name and attach hooks +			name = jQuery.propFix[ name ] || name; +			hooks = jQuery.propHooks[ name ]; +		} + +		if ( value !== undefined ) { +			if ( hooks && "set" in hooks && +				( ret = hooks.set( elem, value, name ) ) !== undefined ) { +				return ret; +			} + +			return ( elem[ name ] = value ); +		} + +		if ( hooks && "get" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) { +			return ret; +		} + +		return elem[ name ]; +	}, + +	propHooks: { +		tabIndex: { +			get: function( elem ) { + +				// Support: IE <=9 - 11 only +				// elem.tabIndex doesn't always return the +				// correct value when it hasn't been explicitly set +				// https://web.archive.org/web/20141116233347/http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/ +				// Use proper attribute retrieval(#12072) +				var tabindex = jQuery.find.attr( elem, "tabindex" ); + +				if ( tabindex ) { +					return parseInt( tabindex, 10 ); +				} + +				if ( +					rfocusable.test( elem.nodeName ) || +					rclickable.test( elem.nodeName ) && +					elem.href +				) { +					return 0; +				} + +				return -1; +			} +		} +	}, + +	propFix: { +		"for": "htmlFor", +		"class": "className" +	} +} ); + +// Support: IE <=11 only +// Accessing the selectedIndex property +// forces the browser to respect setting selected +// on the option +// The getter ensures a default option is selected +// when in an optgroup +// eslint rule "no-unused-expressions" is disabled for this code +// since it considers such accessions noop +if ( !support.optSelected ) { +	jQuery.propHooks.selected = { +		get: function( elem ) { + +			/* eslint no-unused-expressions: "off" */ + +			var parent = elem.parentNode; +			if ( parent && parent.parentNode ) { +				parent.parentNode.selectedIndex; +			} +			return null; +		}, +		set: function( elem ) { + +			/* eslint no-unused-expressions: "off" */ + +			var parent = elem.parentNode; +			if ( parent ) { +				parent.selectedIndex; + +				if ( parent.parentNode ) { +					parent.parentNode.selectedIndex; +				} +			} +		} +	}; +} + +jQuery.each( [ +	"tabIndex", +	"readOnly", +	"maxLength", +	"cellSpacing", +	"cellPadding", +	"rowSpan", +	"colSpan", +	"useMap", +	"frameBorder", +	"contentEditable" +], function() { +	jQuery.propFix[ this.toLowerCase() ] = this; +} ); + + + + +	// Strip and collapse whitespace according to HTML spec +	// https://infra.spec.whatwg.org/#strip-and-collapse-ascii-whitespace +	function stripAndCollapse( value ) { +		var tokens = value.match( rnothtmlwhite ) || []; +		return tokens.join( " " ); +	} + + +function getClass( elem ) { +	return elem.getAttribute && elem.getAttribute( "class" ) || ""; +} + +function classesToArray( value ) { +	if ( Array.isArray( value ) ) { +		return value; +	} +	if ( typeof value === "string" ) { +		return value.match( rnothtmlwhite ) || []; +	} +	return []; +} + +jQuery.fn.extend( { +	addClass: function( value ) { +		var classes, elem, cur, curValue, clazz, j, finalValue, +			i = 0; + +		if ( isFunction( value ) ) { +			return this.each( function( j ) { +				jQuery( this ).addClass( value.call( this, j, getClass( this ) ) ); +			} ); +		} + +		classes = classesToArray( value ); + +		if ( classes.length ) { +			while ( ( elem = this[ i++ ] ) ) { +				curValue = getClass( elem ); +				cur = elem.nodeType === 1 && ( " " + stripAndCollapse( curValue ) + " " ); + +				if ( cur ) { +					j = 0; +					while ( ( clazz = classes[ j++ ] ) ) { +						if ( cur.indexOf( " " + clazz + " " ) < 0 ) { +							cur += clazz + " "; +						} +					} + +					// Only assign if different to avoid unneeded rendering. +					finalValue = stripAndCollapse( cur ); +					if ( curValue !== finalValue ) { +						elem.setAttribute( "class", finalValue ); +					} +				} +			} +		} + +		return this; +	}, + +	removeClass: function( value ) { +		var classes, elem, cur, curValue, clazz, j, finalValue, +			i = 0; + +		if ( isFunction( value ) ) { +			return this.each( function( j ) { +				jQuery( this ).removeClass( value.call( this, j, getClass( this ) ) ); +			} ); +		} + +		if ( !arguments.length ) { +			return this.attr( "class", "" ); +		} + +		classes = classesToArray( value ); + +		if ( classes.length ) { +			while ( ( elem = this[ i++ ] ) ) { +				curValue = getClass( elem ); + +				// This expression is here for better compressibility (see addClass) +				cur = elem.nodeType === 1 && ( " " + stripAndCollapse( curValue ) + " " ); + +				if ( cur ) { +					j = 0; +					while ( ( clazz = classes[ j++ ] ) ) { + +						// Remove *all* instances +						while ( cur.indexOf( " " + clazz + " " ) > -1 ) { +							cur = cur.replace( " " + clazz + " ", " " ); +						} +					} + +					// Only assign if different to avoid unneeded rendering. +					finalValue = stripAndCollapse( cur ); +					if ( curValue !== finalValue ) { +						elem.setAttribute( "class", finalValue ); +					} +				} +			} +		} + +		return this; +	}, + +	toggleClass: function( value, stateVal ) { +		var type = typeof value, +			isValidValue = type === "string" || Array.isArray( value ); + +		if ( typeof stateVal === "boolean" && isValidValue ) { +			return stateVal ? this.addClass( value ) : this.removeClass( value ); +		} + +		if ( isFunction( value ) ) { +			return this.each( function( i ) { +				jQuery( this ).toggleClass( +					value.call( this, i, getClass( this ), stateVal ), +					stateVal +				); +			} ); +		} + +		return this.each( function() { +			var className, i, self, classNames; + +			if ( isValidValue ) { + +				// Toggle individual class names +				i = 0; +				self = jQuery( this ); +				classNames = classesToArray( value ); + +				while ( ( className = classNames[ i++ ] ) ) { + +					// Check each className given, space separated list +					if ( self.hasClass( className ) ) { +						self.removeClass( className ); +					} else { +						self.addClass( className ); +					} +				} + +			// Toggle whole class name +			} else if ( value === undefined || type === "boolean" ) { +				className = getClass( this ); +				if ( className ) { + +					// Store className if set +					dataPriv.set( this, "__className__", className ); +				} + +				// If the element has a class name or if we're passed `false`, +				// then remove the whole classname (if there was one, the above saved it). +				// Otherwise bring back whatever was previously saved (if anything), +				// falling back to the empty string if nothing was stored. +				if ( this.setAttribute ) { +					this.setAttribute( "class", +						className || value === false ? +							"" : +							dataPriv.get( this, "__className__" ) || "" +					); +				} +			} +		} ); +	}, + +	hasClass: function( selector ) { +		var className, elem, +			i = 0; + +		className = " " + selector + " "; +		while ( ( elem = this[ i++ ] ) ) { +			if ( elem.nodeType === 1 && +				( " " + stripAndCollapse( getClass( elem ) ) + " " ).indexOf( className ) > -1 ) { +				return true; +			} +		} + +		return false; +	} +} ); + + + + +var rreturn = /\r/g; + +jQuery.fn.extend( { +	val: function( value ) { +		var hooks, ret, valueIsFunction, +			elem = this[ 0 ]; + +		if ( !arguments.length ) { +			if ( elem ) { +				hooks = jQuery.valHooks[ elem.type ] || +					jQuery.valHooks[ elem.nodeName.toLowerCase() ]; + +				if ( hooks && +					"get" in hooks && +					( ret = hooks.get( elem, "value" ) ) !== undefined +				) { +					return ret; +				} + +				ret = elem.value; + +				// Handle most common string cases +				if ( typeof ret === "string" ) { +					return ret.replace( rreturn, "" ); +				} + +				// Handle cases where value is null/undef or number +				return ret == null ? "" : ret; +			} + +			return; +		} + +		valueIsFunction = isFunction( value ); + +		return this.each( function( i ) { +			var val; + +			if ( this.nodeType !== 1 ) { +				return; +			} + +			if ( valueIsFunction ) { +				val = value.call( this, i, jQuery( this ).val() ); +			} else { +				val = value; +			} + +			// Treat null/undefined as ""; convert numbers to string +			if ( val == null ) { +				val = ""; + +			} else if ( typeof val === "number" ) { +				val += ""; + +			} else if ( Array.isArray( val ) ) { +				val = jQuery.map( val, function( value ) { +					return value == null ? "" : value + ""; +				} ); +			} + +			hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ]; + +			// If set returns undefined, fall back to normal setting +			if ( !hooks || !( "set" in hooks ) || hooks.set( this, val, "value" ) === undefined ) { +				this.value = val; +			} +		} ); +	} +} ); + +jQuery.extend( { +	valHooks: { +		option: { +			get: function( elem ) { + +				var val = jQuery.find.attr( elem, "value" ); +				return val != null ? +					val : + +					// Support: IE <=10 - 11 only +					// option.text throws exceptions (#14686, #14858) +					// Strip and collapse whitespace +					// https://html.spec.whatwg.org/#strip-and-collapse-whitespace +					stripAndCollapse( jQuery.text( elem ) ); +			} +		}, +		select: { +			get: function( elem ) { +				var value, option, i, +					options = elem.options, +					index = elem.selectedIndex, +					one = elem.type === "select-one", +					values = one ? null : [], +					max = one ? index + 1 : options.length; + +				if ( index < 0 ) { +					i = max; + +				} else { +					i = one ? index : 0; +				} + +				// Loop through all the selected options +				for ( ; i < max; i++ ) { +					option = options[ i ]; + +					// Support: IE <=9 only +					// IE8-9 doesn't update selected after form reset (#2551) +					if ( ( option.selected || i === index ) && + +							// Don't return options that are disabled or in a disabled optgroup +							!option.disabled && +							( !option.parentNode.disabled || +								!nodeName( option.parentNode, "optgroup" ) ) ) { + +						// Get the specific value for the option +						value = jQuery( option ).val(); + +						// We don't need an array for one selects +						if ( one ) { +							return value; +						} + +						// Multi-Selects return an array +						values.push( value ); +					} +				} + +				return values; +			}, + +			set: function( elem, value ) { +				var optionSet, option, +					options = elem.options, +					values = jQuery.makeArray( value ), +					i = options.length; + +				while ( i-- ) { +					option = options[ i ]; + +					/* eslint-disable no-cond-assign */ + +					if ( option.selected = +						jQuery.inArray( jQuery.valHooks.option.get( option ), values ) > -1 +					) { +						optionSet = true; +					} + +					/* eslint-enable no-cond-assign */ +				} + +				// Force browsers to behave consistently when non-matching value is set +				if ( !optionSet ) { +					elem.selectedIndex = -1; +				} +				return values; +			} +		} +	} +} ); + +// Radios and checkboxes getter/setter +jQuery.each( [ "radio", "checkbox" ], function() { +	jQuery.valHooks[ this ] = { +		set: function( elem, value ) { +			if ( Array.isArray( value ) ) { +				return ( elem.checked = jQuery.inArray( jQuery( elem ).val(), value ) > -1 ); +			} +		} +	}; +	if ( !support.checkOn ) { +		jQuery.valHooks[ this ].get = function( elem ) { +			return elem.getAttribute( "value" ) === null ? "on" : elem.value; +		}; +	} +} ); + + + + +// Return jQuery for attributes-only inclusion + + +support.focusin = "onfocusin" in window; + + +var rfocusMorph = /^(?:focusinfocus|focusoutblur)$/, +	stopPropagationCallback = function( e ) { +		e.stopPropagation(); +	}; + +jQuery.extend( jQuery.event, { + +	trigger: function( event, data, elem, onlyHandlers ) { + +		var i, cur, tmp, bubbleType, ontype, handle, special, lastElement, +			eventPath = [ elem || document ], +			type = hasOwn.call( event, "type" ) ? event.type : event, +			namespaces = hasOwn.call( event, "namespace" ) ? event.namespace.split( "." ) : []; + +		cur = lastElement = 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( "." ) > -1 ) { + +			// 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.rnamespace = 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 && !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() ) { +			lastElement = cur; +			event.type = i > 1 ? +				bubbleType : +				special.bindType || type; + +			// jQuery handler +			handle = ( dataPriv.get( cur, "events" ) || Object.create( null ) )[ event.type ] && +				dataPriv.get( cur, "handle" ); +			if ( handle ) { +				handle.apply( cur, data ); +			} + +			// Native handler +			handle = ontype && cur[ ontype ]; +			if ( handle && handle.apply && 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 ) && +				acceptData( elem ) ) { + +				// Call a native DOM method on the target with the same name as the event. +				// Don't do default actions on window, that's where global variables be (#6170) +				if ( ontype && isFunction( elem[ type ] ) && !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; + +					if ( event.isPropagationStopped() ) { +						lastElement.addEventListener( type, stopPropagationCallback ); +					} + +					elem[ type ](); + +					if ( event.isPropagationStopped() ) { +						lastElement.removeEventListener( type, stopPropagationCallback ); +					} + +					jQuery.event.triggered = undefined; + +					if ( tmp ) { +						elem[ ontype ] = tmp; +					} +				} +			} +		} + +		return event.result; +	}, + +	// Piggyback on a donor event to simulate a different one +	// Used only for `focus(in | out)` events +	simulate: function( type, elem, event ) { +		var e = jQuery.extend( +			new jQuery.Event(), +			event, +			{ +				type: type, +				isSimulated: true +			} +		); + +		jQuery.event.trigger( e, null, elem ); +	} + +} ); + +jQuery.fn.extend( { + +	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 ); +		} +	} +} ); + + +// Support: Firefox <=44 +// Firefox doesn't have focus(in | out) events +// Related ticket - https://bugzilla.mozilla.org/show_bug.cgi?id=687787 +// +// Support: Chrome <=48 - 49, Safari <=9.0 - 9.1 +// focus(in | out) events fire after focus & blur events, +// which is spec violation - http://www.w3.org/TR/DOM-Level-3-Events/#events-focusevent-event-order +// Related ticket - https://bugs.chromium.org/p/chromium/issues/detail?id=449857 +if ( !support.focusin ) { +	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 ) ); +		}; + +		jQuery.event.special[ fix ] = { +			setup: function() { + +				// Handle: regular nodes (via `this.ownerDocument`), window +				// (via `this.document`) & document (via `this`). +				var doc = this.ownerDocument || this.document || this, +					attaches = dataPriv.access( doc, fix ); + +				if ( !attaches ) { +					doc.addEventListener( orig, handler, true ); +				} +				dataPriv.access( doc, fix, ( attaches || 0 ) + 1 ); +			}, +			teardown: function() { +				var doc = this.ownerDocument || this.document || this, +					attaches = dataPriv.access( doc, fix ) - 1; + +				if ( !attaches ) { +					doc.removeEventListener( orig, handler, true ); +					dataPriv.remove( doc, fix ); + +				} else { +					dataPriv.access( doc, fix, attaches ); +				} +			} +		}; +	} ); +} +var location = window.location; + +var nonce = { guid: Date.now() }; + +var rquery = ( /\?/ ); + + + +// Cross-browser xml parsing +jQuery.parseXML = function( data ) { +	var xml, parserErrorElem; +	if ( !data || typeof data !== "string" ) { +		return null; +	} + +	// Support: IE 9 - 11 only +	// IE throws on parseFromString with invalid input. +	try { +		xml = ( new window.DOMParser() ).parseFromString( data, "text/xml" ); +	} catch ( e ) {} + +	parserErrorElem = xml && xml.getElementsByTagName( "parsererror" )[ 0 ]; +	if ( !xml || parserErrorElem ) { +		jQuery.error( "Invalid XML: " + ( +			parserErrorElem ? +				jQuery.map( parserErrorElem.childNodes, function( el ) { +					return el.textContent; +				} ).join( "\n" ) : +				data +		) ); +	} +	return xml; +}; + + +var +	rbracket = /\[\]$/, +	rCRLF = /\r?\n/g, +	rsubmitterTypes = /^(?:submit|button|image|reset|file)$/i, +	rsubmittable = /^(?:input|select|textarea|keygen)/i; + +function buildParams( prefix, obj, traditional, add ) { +	var name; + +	if ( Array.isArray( obj ) ) { + +		// Serialize array item. +		jQuery.each( obj, function( i, v ) { +			if ( traditional || rbracket.test( prefix ) ) { + +				// Treat each array item as a scalar. +				add( prefix, v ); + +			} else { + +				// Item is non-scalar (array or object), encode its numeric index. +				buildParams( +					prefix + "[" + ( typeof v === "object" && v != null ? i : "" ) + "]", +					v, +					traditional, +					add +				); +			} +		} ); + +	} else if ( !traditional && toType( obj ) === "object" ) { + +		// Serialize object item. +		for ( name in obj ) { +			buildParams( prefix + "[" + name + "]", obj[ name ], traditional, add ); +		} + +	} else { + +		// Serialize scalar item. +		add( prefix, obj ); +	} +} + +// Serialize an array of form elements or a set of +// key/values into a query string +jQuery.param = function( a, traditional ) { +	var prefix, +		s = [], +		add = function( key, valueOrFunction ) { + +			// If value is a function, invoke it and use its return value +			var value = isFunction( valueOrFunction ) ? +				valueOrFunction() : +				valueOrFunction; + +			s[ s.length ] = encodeURIComponent( key ) + "=" + +				encodeURIComponent( value == null ? "" : value ); +		}; + +	if ( a == null ) { +		return ""; +	} + +	// If an array was passed in, assume that it is an array of form elements. +	if ( Array.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) { + +		// Serialize the form elements +		jQuery.each( a, function() { +			add( this.name, this.value ); +		} ); + +	} else { + +		// If traditional, encode the "old" way (the way 1.3.2 or older +		// did it), otherwise encode params recursively. +		for ( prefix in a ) { +			buildParams( prefix, a[ prefix ], traditional, add ); +		} +	} + +	// Return the resulting serialization +	return s.join( "&" ); +}; + +jQuery.fn.extend( { +	serialize: function() { +		return jQuery.param( this.serializeArray() ); +	}, +	serializeArray: function() { +		return this.map( function() { + +			// Can add propHook for "elements" to filter or add form elements +			var elements = jQuery.prop( this, "elements" ); +			return elements ? jQuery.makeArray( elements ) : this; +		} ).filter( function() { +			var type = this.type; + +			// Use .is( ":disabled" ) so that fieldset[disabled] works +			return this.name && !jQuery( this ).is( ":disabled" ) && +				rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) && +				( this.checked || !rcheckableType.test( type ) ); +		} ).map( function( _i, elem ) { +			var val = jQuery( this ).val(); + +			if ( val == null ) { +				return null; +			} + +			if ( Array.isArray( val ) ) { +				return jQuery.map( val, function( val ) { +					return { name: elem.name, value: val.replace( rCRLF, "\r\n" ) }; +				} ); +			} + +			return { name: elem.name, value: val.replace( rCRLF, "\r\n" ) }; +		} ).get(); +	} +} ); + + +var +	r20 = /%20/g, +	rhash = /#.*$/, +	rantiCache = /([?&])_=[^&]*/, +	rheaders = /^(.*?):[ \t]*([^\r\n]*)$/mg, + +	// #7653, #8125, #8152: local protocol detection +	rlocalProtocol = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/, +	rnoContent = /^(?:GET|HEAD)$/, +	rprotocol = /^\/\//, + +	/* Prefilters +	 * 1) They are useful to introduce custom dataTypes (see ajax/jsonp.js for an example) +	 * 2) These are called: +	 *    - BEFORE asking for a transport +	 *    - AFTER param serialization (s.data is a string if s.processData is true) +	 * 3) key is the dataType +	 * 4) the catchall symbol "*" can be used +	 * 5) execution will start with transport dataType and THEN continue down to "*" if needed +	 */ +	prefilters = {}, + +	/* Transports bindings +	 * 1) key is the dataType +	 * 2) the catchall symbol "*" can be used +	 * 3) selection will start with transport dataType and THEN go to "*" if needed +	 */ +	transports = {}, + +	// Avoid comment-prolog char sequence (#10098); must appease lint and evade compression +	allTypes = "*/".concat( "*" ), + +	// Anchor tag for parsing the document origin +	originAnchor = document.createElement( "a" ); + +originAnchor.href = location.href; + +// Base "constructor" for jQuery.ajaxPrefilter and jQuery.ajaxTransport +function addToPrefiltersOrTransports( structure ) { + +	// dataTypeExpression is optional and defaults to "*" +	return function( dataTypeExpression, func ) { + +		if ( typeof dataTypeExpression !== "string" ) { +			func = dataTypeExpression; +			dataTypeExpression = "*"; +		} + +		var dataType, +			i = 0, +			dataTypes = dataTypeExpression.toLowerCase().match( rnothtmlwhite ) || []; + +		if ( isFunction( func ) ) { + +			// For each dataType in the dataTypeExpression +			while ( ( dataType = dataTypes[ i++ ] ) ) { + +				// Prepend if requested +				if ( dataType[ 0 ] === "+" ) { +					dataType = dataType.slice( 1 ) || "*"; +					( structure[ dataType ] = structure[ dataType ] || [] ).unshift( func ); + +				// Otherwise append +				} else { +					( structure[ dataType ] = structure[ dataType ] || [] ).push( func ); +				} +			} +		} +	}; +} + +// Base inspection function for prefilters and transports +function inspectPrefiltersOrTransports( structure, options, originalOptions, jqXHR ) { + +	var inspected = {}, +		seekingTransport = ( structure === transports ); + +	function inspect( dataType ) { +		var selected; +		inspected[ dataType ] = true; +		jQuery.each( structure[ dataType ] || [], function( _, prefilterOrFactory ) { +			var dataTypeOrTransport = prefilterOrFactory( options, originalOptions, jqXHR ); +			if ( typeof dataTypeOrTransport === "string" && +				!seekingTransport && !inspected[ dataTypeOrTransport ] ) { + +				options.dataTypes.unshift( dataTypeOrTransport ); +				inspect( dataTypeOrTransport ); +				return false; +			} else if ( seekingTransport ) { +				return !( selected = dataTypeOrTransport ); +			} +		} ); +		return selected; +	} + +	return inspect( options.dataTypes[ 0 ] ) || !inspected[ "*" ] && inspect( "*" ); +} + +// A special extend for ajax options +// that takes "flat" options (not to be deep extended) +// Fixes #9887 +function ajaxExtend( target, src ) { +	var key, deep, +		flatOptions = jQuery.ajaxSettings.flatOptions || {}; + +	for ( key in src ) { +		if ( src[ key ] !== undefined ) { +			( flatOptions[ key ] ? target : ( deep || ( deep = {} ) ) )[ key ] = src[ key ]; +		} +	} +	if ( deep ) { +		jQuery.extend( true, target, deep ); +	} + +	return target; +} + +/* Handles responses to an ajax request: + * - finds the right dataType (mediates between content-type and expected dataType) + * - returns the corresponding response + */ +function ajaxHandleResponses( s, jqXHR, responses ) { + +	var ct, type, finalDataType, firstDataType, +		contents = s.contents, +		dataTypes = s.dataTypes; + +	// Remove auto dataType and get content-type in the process +	while ( dataTypes[ 0 ] === "*" ) { +		dataTypes.shift(); +		if ( ct === undefined ) { +			ct = s.mimeType || jqXHR.getResponseHeader( "Content-Type" ); +		} +	} + +	// Check if we're dealing with a known content-type +	if ( ct ) { +		for ( type in contents ) { +			if ( contents[ type ] && contents[ type ].test( ct ) ) { +				dataTypes.unshift( type ); +				break; +			} +		} +	} + +	// Check to see if we have a response for the expected dataType +	if ( dataTypes[ 0 ] in responses ) { +		finalDataType = dataTypes[ 0 ]; +	} else { + +		// Try convertible dataTypes +		for ( type in responses ) { +			if ( !dataTypes[ 0 ] || s.converters[ type + " " + dataTypes[ 0 ] ] ) { +				finalDataType = type; +				break; +			} +			if ( !firstDataType ) { +				firstDataType = type; +			} +		} + +		// Or just use first one +		finalDataType = finalDataType || firstDataType; +	} + +	// If we found a dataType +	// We add the dataType to the list if needed +	// and return the corresponding response +	if ( finalDataType ) { +		if ( finalDataType !== dataTypes[ 0 ] ) { +			dataTypes.unshift( finalDataType ); +		} +		return responses[ finalDataType ]; +	} +} + +/* Chain conversions given the request and the original response + * Also sets the responseXXX fields on the jqXHR instance + */ +function ajaxConvert( s, response, jqXHR, isSuccess ) { +	var conv2, current, conv, tmp, prev, +		converters = {}, + +		// Work with a copy of dataTypes in case we need to modify it for conversion +		dataTypes = s.dataTypes.slice(); + +	// Create converters map with lowercased keys +	if ( dataTypes[ 1 ] ) { +		for ( conv in s.converters ) { +			converters[ conv.toLowerCase() ] = s.converters[ conv ]; +		} +	} + +	current = dataTypes.shift(); + +	// Convert to each sequential dataType +	while ( current ) { + +		if ( s.responseFields[ current ] ) { +			jqXHR[ s.responseFields[ current ] ] = response; +		} + +		// Apply the dataFilter if provided +		if ( !prev && isSuccess && s.dataFilter ) { +			response = s.dataFilter( response, s.dataType ); +		} + +		prev = current; +		current = dataTypes.shift(); + +		if ( current ) { + +			// There's only work to do if current dataType is non-auto +			if ( current === "*" ) { + +				current = prev; + +			// Convert response if prev dataType is non-auto and differs from current +			} else if ( prev !== "*" && prev !== current ) { + +				// Seek a direct converter +				conv = converters[ prev + " " + current ] || converters[ "* " + current ]; + +				// If none found, seek a pair +				if ( !conv ) { +					for ( conv2 in converters ) { + +						// If conv2 outputs current +						tmp = conv2.split( " " ); +						if ( tmp[ 1 ] === current ) { + +							// If prev can be converted to accepted input +							conv = converters[ prev + " " + tmp[ 0 ] ] || +								converters[ "* " + tmp[ 0 ] ]; +							if ( conv ) { + +								// Condense equivalence converters +								if ( conv === true ) { +									conv = converters[ conv2 ]; + +								// Otherwise, insert the intermediate dataType +								} else if ( converters[ conv2 ] !== true ) { +									current = tmp[ 0 ]; +									dataTypes.unshift( tmp[ 1 ] ); +								} +								break; +							} +						} +					} +				} + +				// Apply converter (if not an equivalence) +				if ( conv !== true ) { + +					// Unless errors are allowed to bubble, catch and return them +					if ( conv && s.throws ) { +						response = conv( response ); +					} else { +						try { +							response = conv( response ); +						} catch ( e ) { +							return { +								state: "parsererror", +								error: conv ? e : "No conversion from " + prev + " to " + current +							}; +						} +					} +				} +			} +		} +	} + +	return { state: "success", data: response }; +} + +jQuery.extend( { + +	// Counter for holding the number of active queries +	active: 0, + +	// Last-Modified header cache for next request +	lastModified: {}, +	etag: {}, + +	ajaxSettings: { +		url: location.href, +		type: "GET", +		isLocal: rlocalProtocol.test( location.protocol ), +		global: true, +		processData: true, +		async: true, +		contentType: "application/x-www-form-urlencoded; charset=UTF-8", + +		/* +		timeout: 0, +		data: null, +		dataType: null, +		username: null, +		password: null, +		cache: null, +		throws: false, +		traditional: false, +		headers: {}, +		*/ + +		accepts: { +			"*": allTypes, +			text: "text/plain", +			html: "text/html", +			xml: "application/xml, text/xml", +			json: "application/json, text/javascript" +		}, + +		contents: { +			xml: /\bxml\b/, +			html: /\bhtml/, +			json: /\bjson\b/ +		}, + +		responseFields: { +			xml: "responseXML", +			text: "responseText", +			json: "responseJSON" +		}, + +		// Data converters +		// Keys separate source (or catchall "*") and destination types with a single space +		converters: { + +			// Convert anything to text +			"* text": String, + +			// Text to html (true = no transformation) +			"text html": true, + +			// Evaluate text as a json expression +			"text json": JSON.parse, + +			// Parse text as xml +			"text xml": jQuery.parseXML +		}, + +		// For options that shouldn't be deep extended: +		// you can add your own custom options here if +		// and when you create one that shouldn't be +		// deep extended (see ajaxExtend) +		flatOptions: { +			url: true, +			context: true +		} +	}, + +	// Creates a full fledged settings object into target +	// with both ajaxSettings and settings fields. +	// If target is omitted, writes into ajaxSettings. +	ajaxSetup: function( target, settings ) { +		return settings ? + +			// Building a settings object +			ajaxExtend( ajaxExtend( target, jQuery.ajaxSettings ), settings ) : + +			// Extending ajaxSettings +			ajaxExtend( jQuery.ajaxSettings, target ); +	}, + +	ajaxPrefilter: addToPrefiltersOrTransports( prefilters ), +	ajaxTransport: addToPrefiltersOrTransports( transports ), + +	// Main method +	ajax: function( url, options ) { + +		// If url is an object, simulate pre-1.5 signature +		if ( typeof url === "object" ) { +			options = url; +			url = undefined; +		} + +		// Force options to be an object +		options = options || {}; + +		var transport, + +			// URL without anti-cache param +			cacheURL, + +			// Response headers +			responseHeadersString, +			responseHeaders, + +			// timeout handle +			timeoutTimer, + +			// Url cleanup var +			urlAnchor, + +			// Request state (becomes false upon send and true upon completion) +			completed, + +			// To know if global events are to be dispatched +			fireGlobals, + +			// Loop variable +			i, + +			// uncached part of the url +			uncached, + +			// Create the final options object +			s = jQuery.ajaxSetup( {}, options ), + +			// Callbacks context +			callbackContext = s.context || s, + +			// Context for global events is callbackContext if it is a DOM node or jQuery collection +			globalEventContext = s.context && +				( callbackContext.nodeType || callbackContext.jquery ) ? +				jQuery( callbackContext ) : +				jQuery.event, + +			// Deferreds +			deferred = jQuery.Deferred(), +			completeDeferred = jQuery.Callbacks( "once memory" ), + +			// Status-dependent callbacks +			statusCode = s.statusCode || {}, + +			// Headers (they are sent all at once) +			requestHeaders = {}, +			requestHeadersNames = {}, + +			// Default abort message +			strAbort = "canceled", + +			// Fake xhr +			jqXHR = { +				readyState: 0, + +				// Builds headers hashtable if needed +				getResponseHeader: function( key ) { +					var match; +					if ( completed ) { +						if ( !responseHeaders ) { +							responseHeaders = {}; +							while ( ( match = rheaders.exec( responseHeadersString ) ) ) { +								responseHeaders[ match[ 1 ].toLowerCase() + " " ] = +									( responseHeaders[ match[ 1 ].toLowerCase() + " " ] || [] ) +										.concat( match[ 2 ] ); +							} +						} +						match = responseHeaders[ key.toLowerCase() + " " ]; +					} +					return match == null ? null : match.join( ", " ); +				}, + +				// Raw string +				getAllResponseHeaders: function() { +					return completed ? responseHeadersString : null; +				}, + +				// Caches the header +				setRequestHeader: function( name, value ) { +					if ( completed == null ) { +						name = requestHeadersNames[ name.toLowerCase() ] = +							requestHeadersNames[ name.toLowerCase() ] || name; +						requestHeaders[ name ] = value; +					} +					return this; +				}, + +				// Overrides response content-type header +				overrideMimeType: function( type ) { +					if ( completed == null ) { +						s.mimeType = type; +					} +					return this; +				}, + +				// Status-dependent callbacks +				statusCode: function( map ) { +					var code; +					if ( map ) { +						if ( completed ) { + +							// Execute the appropriate callbacks +							jqXHR.always( map[ jqXHR.status ] ); +						} else { + +							// Lazy-add the new callbacks in a way that preserves old ones +							for ( code in map ) { +								statusCode[ code ] = [ statusCode[ code ], map[ code ] ]; +							} +						} +					} +					return this; +				}, + +				// Cancel the request +				abort: function( statusText ) { +					var finalText = statusText || strAbort; +					if ( transport ) { +						transport.abort( finalText ); +					} +					done( 0, finalText ); +					return this; +				} +			}; + +		// Attach deferreds +		deferred.promise( jqXHR ); + +		// Add protocol if not provided (prefilters might expect it) +		// Handle falsy url in the settings object (#10093: consistency with old signature) +		// We also use the url parameter if available +		s.url = ( ( url || s.url || location.href ) + "" ) +			.replace( rprotocol, location.protocol + "//" ); + +		// Alias method option to type as per ticket #12004 +		s.type = options.method || options.type || s.method || s.type; + +		// Extract dataTypes list +		s.dataTypes = ( s.dataType || "*" ).toLowerCase().match( rnothtmlwhite ) || [ "" ]; + +		// A cross-domain request is in order when the origin doesn't match the current origin. +		if ( s.crossDomain == null ) { +			urlAnchor = document.createElement( "a" ); + +			// Support: IE <=8 - 11, Edge 12 - 15 +			// IE throws exception on accessing the href property if url is malformed, +			// e.g. http://example.com:80x/ +			try { +				urlAnchor.href = s.url; + +				// Support: IE <=8 - 11 only +				// Anchor's host property isn't correctly set when s.url is relative +				urlAnchor.href = urlAnchor.href; +				s.crossDomain = originAnchor.protocol + "//" + originAnchor.host !== +					urlAnchor.protocol + "//" + urlAnchor.host; +			} catch ( e ) { + +				// If there is an error parsing the URL, assume it is crossDomain, +				// it can be rejected by the transport if it is invalid +				s.crossDomain = true; +			} +		} + +		// Convert data if not already a string +		if ( s.data && s.processData && typeof s.data !== "string" ) { +			s.data = jQuery.param( s.data, s.traditional ); +		} + +		// Apply prefilters +		inspectPrefiltersOrTransports( prefilters, s, options, jqXHR ); + +		// If request was aborted inside a prefilter, stop there +		if ( completed ) { +			return jqXHR; +		} + +		// We can fire global events as of now if asked to +		// Don't fire events if jQuery.event is undefined in an AMD-usage scenario (#15118) +		fireGlobals = jQuery.event && s.global; + +		// Watch for a new set of requests +		if ( fireGlobals && jQuery.active++ === 0 ) { +			jQuery.event.trigger( "ajaxStart" ); +		} + +		// Uppercase the type +		s.type = s.type.toUpperCase(); + +		// Determine if request has content +		s.hasContent = !rnoContent.test( s.type ); + +		// Save the URL in case we're toying with the If-Modified-Since +		// and/or If-None-Match header later on +		// Remove hash to simplify url manipulation +		cacheURL = s.url.replace( rhash, "" ); + +		// More options handling for requests with no content +		if ( !s.hasContent ) { + +			// Remember the hash so we can put it back +			uncached = s.url.slice( cacheURL.length ); + +			// If data is available and should be processed, append data to url +			if ( s.data && ( s.processData || typeof s.data === "string" ) ) { +				cacheURL += ( rquery.test( cacheURL ) ? "&" : "?" ) + s.data; + +				// #9682: remove data so that it's not used in an eventual retry +				delete s.data; +			} + +			// Add or update anti-cache param if needed +			if ( s.cache === false ) { +				cacheURL = cacheURL.replace( rantiCache, "$1" ); +				uncached = ( rquery.test( cacheURL ) ? "&" : "?" ) + "_=" + ( nonce.guid++ ) + +					uncached; +			} + +			// Put hash and anti-cache on the URL that will be requested (gh-1732) +			s.url = cacheURL + uncached; + +		// Change '%20' to '+' if this is encoded form body content (gh-2658) +		} else if ( s.data && s.processData && +			( s.contentType || "" ).indexOf( "application/x-www-form-urlencoded" ) === 0 ) { +			s.data = s.data.replace( r20, "+" ); +		} + +		// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode. +		if ( s.ifModified ) { +			if ( jQuery.lastModified[ cacheURL ] ) { +				jqXHR.setRequestHeader( "If-Modified-Since", jQuery.lastModified[ cacheURL ] ); +			} +			if ( jQuery.etag[ cacheURL ] ) { +				jqXHR.setRequestHeader( "If-None-Match", jQuery.etag[ cacheURL ] ); +			} +		} + +		// Set the correct header, if data is being sent +		if ( s.data && s.hasContent && s.contentType !== false || options.contentType ) { +			jqXHR.setRequestHeader( "Content-Type", s.contentType ); +		} + +		// Set the Accepts header for the server, depending on the dataType +		jqXHR.setRequestHeader( +			"Accept", +			s.dataTypes[ 0 ] && s.accepts[ s.dataTypes[ 0 ] ] ? +				s.accepts[ s.dataTypes[ 0 ] ] + +					( s.dataTypes[ 0 ] !== "*" ? ", " + allTypes + "; q=0.01" : "" ) : +				s.accepts[ "*" ] +		); + +		// Check for headers option +		for ( i in s.headers ) { +			jqXHR.setRequestHeader( i, s.headers[ i ] ); +		} + +		// Allow custom headers/mimetypes and early abort +		if ( s.beforeSend && +			( s.beforeSend.call( callbackContext, jqXHR, s ) === false || completed ) ) { + +			// Abort if not done already and return +			return jqXHR.abort(); +		} + +		// Aborting is no longer a cancellation +		strAbort = "abort"; + +		// Install callbacks on deferreds +		completeDeferred.add( s.complete ); +		jqXHR.done( s.success ); +		jqXHR.fail( s.error ); + +		// Get transport +		transport = inspectPrefiltersOrTransports( transports, s, options, jqXHR ); + +		// If no transport, we auto-abort +		if ( !transport ) { +			done( -1, "No Transport" ); +		} else { +			jqXHR.readyState = 1; + +			// Send global event +			if ( fireGlobals ) { +				globalEventContext.trigger( "ajaxSend", [ jqXHR, s ] ); +			} + +			// If request was aborted inside ajaxSend, stop there +			if ( completed ) { +				return jqXHR; +			} + +			// Timeout +			if ( s.async && s.timeout > 0 ) { +				timeoutTimer = window.setTimeout( function() { +					jqXHR.abort( "timeout" ); +				}, s.timeout ); +			} + +			try { +				completed = false; +				transport.send( requestHeaders, done ); +			} catch ( e ) { + +				// Rethrow post-completion exceptions +				if ( completed ) { +					throw e; +				} + +				// Propagate others as results +				done( -1, e ); +			} +		} + +		// Callback for when everything is done +		function done( status, nativeStatusText, responses, headers ) { +			var isSuccess, success, error, response, modified, +				statusText = nativeStatusText; + +			// Ignore repeat invocations +			if ( completed ) { +				return; +			} + +			completed = true; + +			// Clear timeout if it exists +			if ( timeoutTimer ) { +				window.clearTimeout( timeoutTimer ); +			} + +			// Dereference transport for early garbage collection +			// (no matter how long the jqXHR object will be used) +			transport = undefined; + +			// Cache response headers +			responseHeadersString = headers || ""; + +			// Set readyState +			jqXHR.readyState = status > 0 ? 4 : 0; + +			// Determine if successful +			isSuccess = status >= 200 && status < 300 || status === 304; + +			// Get response data +			if ( responses ) { +				response = ajaxHandleResponses( s, jqXHR, responses ); +			} + +			// Use a noop converter for missing script but not if jsonp +			if ( !isSuccess && +				jQuery.inArray( "script", s.dataTypes ) > -1 && +				jQuery.inArray( "json", s.dataTypes ) < 0 ) { +				s.converters[ "text script" ] = function() {}; +			} + +			// Convert no matter what (that way responseXXX fields are always set) +			response = ajaxConvert( s, response, jqXHR, isSuccess ); + +			// If successful, handle type chaining +			if ( isSuccess ) { + +				// Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode. +				if ( s.ifModified ) { +					modified = jqXHR.getResponseHeader( "Last-Modified" ); +					if ( modified ) { +						jQuery.lastModified[ cacheURL ] = modified; +					} +					modified = jqXHR.getResponseHeader( "etag" ); +					if ( modified ) { +						jQuery.etag[ cacheURL ] = modified; +					} +				} + +				// if no content +				if ( status === 204 || s.type === "HEAD" ) { +					statusText = "nocontent"; + +				// if not modified +				} else if ( status === 304 ) { +					statusText = "notmodified"; + +				// If we have data, let's convert it +				} else { +					statusText = response.state; +					success = response.data; +					error = response.error; +					isSuccess = !error; +				} +			} else { + +				// Extract error from statusText and normalize for non-aborts +				error = statusText; +				if ( status || !statusText ) { +					statusText = "error"; +					if ( status < 0 ) { +						status = 0; +					} +				} +			} + +			// Set data for the fake xhr object +			jqXHR.status = status; +			jqXHR.statusText = ( nativeStatusText || statusText ) + ""; + +			// Success/Error +			if ( isSuccess ) { +				deferred.resolveWith( callbackContext, [ success, statusText, jqXHR ] ); +			} else { +				deferred.rejectWith( callbackContext, [ jqXHR, statusText, error ] ); +			} + +			// Status-dependent callbacks +			jqXHR.statusCode( statusCode ); +			statusCode = undefined; + +			if ( fireGlobals ) { +				globalEventContext.trigger( isSuccess ? "ajaxSuccess" : "ajaxError", +					[ jqXHR, s, isSuccess ? success : error ] ); +			} + +			// Complete +			completeDeferred.fireWith( callbackContext, [ jqXHR, statusText ] ); + +			if ( fireGlobals ) { +				globalEventContext.trigger( "ajaxComplete", [ jqXHR, s ] ); + +				// Handle the global AJAX counter +				if ( !( --jQuery.active ) ) { +					jQuery.event.trigger( "ajaxStop" ); +				} +			} +		} + +		return jqXHR; +	}, + +	getJSON: function( url, data, callback ) { +		return jQuery.get( url, data, callback, "json" ); +	}, + +	getScript: function( url, callback ) { +		return jQuery.get( url, undefined, callback, "script" ); +	} +} ); + +jQuery.each( [ "get", "post" ], function( _i, method ) { +	jQuery[ method ] = function( url, data, callback, type ) { + +		// Shift arguments if data argument was omitted +		if ( isFunction( data ) ) { +			type = type || callback; +			callback = data; +			data = undefined; +		} + +		// The url can be an options object (which then must have .url) +		return jQuery.ajax( jQuery.extend( { +			url: url, +			type: method, +			dataType: type, +			data: data, +			success: callback +		}, jQuery.isPlainObject( url ) && url ) ); +	}; +} ); + +jQuery.ajaxPrefilter( function( s ) { +	var i; +	for ( i in s.headers ) { +		if ( i.toLowerCase() === "content-type" ) { +			s.contentType = s.headers[ i ] || ""; +		} +	} +} ); + + +jQuery._evalUrl = function( url, options, doc ) { +	return jQuery.ajax( { +		url: url, + +		// Make this explicit, since user can override this through ajaxSetup (#11264) +		type: "GET", +		dataType: "script", +		cache: true, +		async: false, +		global: false, + +		// Only evaluate the response if it is successful (gh-4126) +		// dataFilter is not invoked for failure responses, so using it instead +		// of the default converter is kludgy but it works. +		converters: { +			"text script": function() {} +		}, +		dataFilter: function( response ) { +			jQuery.globalEval( response, options, doc ); +		} +	} ); +}; + + +jQuery.fn.extend( { +	wrapAll: function( html ) { +		var wrap; + +		if ( this[ 0 ] ) { +			if ( isFunction( html ) ) { +				html = html.call( this[ 0 ] ); +			} + +			// The elements to wrap the target around +			wrap = jQuery( html, this[ 0 ].ownerDocument ).eq( 0 ).clone( true ); + +			if ( this[ 0 ].parentNode ) { +				wrap.insertBefore( this[ 0 ] ); +			} + +			wrap.map( function() { +				var elem = this; + +				while ( elem.firstElementChild ) { +					elem = elem.firstElementChild; +				} + +				return elem; +			} ).append( this ); +		} + +		return this; +	}, + +	wrapInner: function( html ) { +		if ( isFunction( html ) ) { +			return this.each( function( i ) { +				jQuery( this ).wrapInner( html.call( this, i ) ); +			} ); +		} + +		return this.each( function() { +			var self = jQuery( this ), +				contents = self.contents(); + +			if ( contents.length ) { +				contents.wrapAll( html ); + +			} else { +				self.append( html ); +			} +		} ); +	}, + +	wrap: function( html ) { +		var htmlIsFunction = isFunction( html ); + +		return this.each( function( i ) { +			jQuery( this ).wrapAll( htmlIsFunction ? html.call( this, i ) : html ); +		} ); +	}, + +	unwrap: function( selector ) { +		this.parent( selector ).not( "body" ).each( function() { +			jQuery( this ).replaceWith( this.childNodes ); +		} ); +		return this; +	} +} ); + + +jQuery.expr.pseudos.hidden = function( elem ) { +	return !jQuery.expr.pseudos.visible( elem ); +}; +jQuery.expr.pseudos.visible = function( elem ) { +	return !!( elem.offsetWidth || elem.offsetHeight || elem.getClientRects().length ); +}; + + + + +jQuery.ajaxSettings.xhr = function() { +	try { +		return new window.XMLHttpRequest(); +	} catch ( e ) {} +}; + +var xhrSuccessStatus = { + +		// File protocol always yields status code 0, assume 200 +		0: 200, + +		// Support: IE <=9 only +		// #1450: sometimes IE returns 1223 when it should be 204 +		1223: 204 +	}, +	xhrSupported = jQuery.ajaxSettings.xhr(); + +support.cors = !!xhrSupported && ( "withCredentials" in xhrSupported ); +support.ajax = xhrSupported = !!xhrSupported; + +jQuery.ajaxTransport( function( options ) { +	var callback, errorCallback; + +	// Cross domain only allowed if supported through XMLHttpRequest +	if ( support.cors || xhrSupported && !options.crossDomain ) { +		return { +			send: function( headers, complete ) { +				var i, +					xhr = options.xhr(); + +				xhr.open( +					options.type, +					options.url, +					options.async, +					options.username, +					options.password +				); + +				// Apply custom fields if provided +				if ( options.xhrFields ) { +					for ( i in options.xhrFields ) { +						xhr[ i ] = options.xhrFields[ i ]; +					} +				} + +				// Override mime type if needed +				if ( options.mimeType && xhr.overrideMimeType ) { +					xhr.overrideMimeType( options.mimeType ); +				} + +				// X-Requested-With header +				// For cross-domain requests, seeing as conditions for a preflight are +				// akin to a jigsaw puzzle, we simply never set it to be sure. +				// (it can always be set on a per-request basis or even using ajaxSetup) +				// For same-domain requests, won't change header if already provided. +				if ( !options.crossDomain && !headers[ "X-Requested-With" ] ) { +					headers[ "X-Requested-With" ] = "XMLHttpRequest"; +				} + +				// Set headers +				for ( i in headers ) { +					xhr.setRequestHeader( i, headers[ i ] ); +				} + +				// Callback +				callback = function( type ) { +					return function() { +						if ( callback ) { +							callback = errorCallback = xhr.onload = +								xhr.onerror = xhr.onabort = xhr.ontimeout = +									xhr.onreadystatechange = null; + +							if ( type === "abort" ) { +								xhr.abort(); +							} else if ( type === "error" ) { + +								// Support: IE <=9 only +								// On a manual native abort, IE9 throws +								// errors on any property access that is not readyState +								if ( typeof xhr.status !== "number" ) { +									complete( 0, "error" ); +								} else { +									complete( + +										// File: protocol always yields status 0; see #8605, #14207 +										xhr.status, +										xhr.statusText +									); +								} +							} else { +								complete( +									xhrSuccessStatus[ xhr.status ] || xhr.status, +									xhr.statusText, + +									// Support: IE <=9 only +									// IE9 has no XHR2 but throws on binary (trac-11426) +									// For XHR2 non-text, let the caller handle it (gh-2498) +									( xhr.responseType || "text" ) !== "text"  || +									typeof xhr.responseText !== "string" ? +										{ binary: xhr.response } : +										{ text: xhr.responseText }, +									xhr.getAllResponseHeaders() +								); +							} +						} +					}; +				}; + +				// Listen to events +				xhr.onload = callback(); +				errorCallback = xhr.onerror = xhr.ontimeout = callback( "error" ); + +				// Support: IE 9 only +				// Use onreadystatechange to replace onabort +				// to handle uncaught aborts +				if ( xhr.onabort !== undefined ) { +					xhr.onabort = errorCallback; +				} else { +					xhr.onreadystatechange = function() { + +						// Check readyState before timeout as it changes +						if ( xhr.readyState === 4 ) { + +							// Allow onerror to be called first, +							// but that will not handle a native abort +							// Also, save errorCallback to a variable +							// as xhr.onerror cannot be accessed +							window.setTimeout( function() { +								if ( callback ) { +									errorCallback(); +								} +							} ); +						} +					}; +				} + +				// Create the abort callback +				callback = callback( "abort" ); + +				try { + +					// Do send the request (this may raise an exception) +					xhr.send( options.hasContent && options.data || null ); +				} catch ( e ) { + +					// #14683: Only rethrow if this hasn't been notified as an error yet +					if ( callback ) { +						throw e; +					} +				} +			}, + +			abort: function() { +				if ( callback ) { +					callback(); +				} +			} +		}; +	} +} ); + + + + +// Prevent auto-execution of scripts when no explicit dataType was provided (See gh-2432) +jQuery.ajaxPrefilter( function( s ) { +	if ( s.crossDomain ) { +		s.contents.script = false; +	} +} ); + +// Install script dataType +jQuery.ajaxSetup( { +	accepts: { +		script: "text/javascript, application/javascript, " + +			"application/ecmascript, application/x-ecmascript" +	}, +	contents: { +		script: /\b(?:java|ecma)script\b/ +	}, +	converters: { +		"text script": function( text ) { +			jQuery.globalEval( text ); +			return text; +		} +	} +} ); + +// Handle cache's special case and crossDomain +jQuery.ajaxPrefilter( "script", function( s ) { +	if ( s.cache === undefined ) { +		s.cache = false; +	} +	if ( s.crossDomain ) { +		s.type = "GET"; +	} +} ); + +// Bind script tag hack transport +jQuery.ajaxTransport( "script", function( s ) { + +	// This transport only deals with cross domain or forced-by-attrs requests +	if ( s.crossDomain || s.scriptAttrs ) { +		var script, callback; +		return { +			send: function( _, complete ) { +				script = jQuery( "<script>" ) +					.attr( s.scriptAttrs || {} ) +					.prop( { charset: s.scriptCharset, src: s.url } ) +					.on( "load error", callback = function( evt ) { +						script.remove(); +						callback = null; +						if ( evt ) { +							complete( evt.type === "error" ? 404 : 200, evt.type ); +						} +					} ); + +				// Use native DOM manipulation to avoid our domManip AJAX trickery +				document.head.appendChild( script[ 0 ] ); +			}, +			abort: function() { +				if ( callback ) { +					callback(); +				} +			} +		}; +	} +} ); + + + + +var oldCallbacks = [], +	rjsonp = /(=)\?(?=&|$)|\?\?/; + +// Default jsonp settings +jQuery.ajaxSetup( { +	jsonp: "callback", +	jsonpCallback: function() { +		var callback = oldCallbacks.pop() || ( jQuery.expando + "_" + ( nonce.guid++ ) ); +		this[ callback ] = true; +		return callback; +	} +} ); + +// Detect, normalize options and install callbacks for jsonp requests +jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { + +	var callbackName, overwritten, responseContainer, +		jsonProp = s.jsonp !== false && ( rjsonp.test( s.url ) ? +			"url" : +			typeof s.data === "string" && +				( s.contentType || "" ) +					.indexOf( "application/x-www-form-urlencoded" ) === 0 && +				rjsonp.test( s.data ) && "data" +		); + +	// Handle iff the expected data type is "jsonp" or we have a parameter to set +	if ( jsonProp || s.dataTypes[ 0 ] === "jsonp" ) { + +		// Get callback name, remembering preexisting value associated with it +		callbackName = s.jsonpCallback = isFunction( s.jsonpCallback ) ? +			s.jsonpCallback() : +			s.jsonpCallback; + +		// Insert callback into url or form data +		if ( jsonProp ) { +			s[ jsonProp ] = s[ jsonProp ].replace( rjsonp, "$1" + callbackName ); +		} else if ( s.jsonp !== false ) { +			s.url += ( rquery.test( s.url ) ? "&" : "?" ) + s.jsonp + "=" + callbackName; +		} + +		// Use data converter to retrieve json after script execution +		s.converters[ "script json" ] = function() { +			if ( !responseContainer ) { +				jQuery.error( callbackName + " was not called" ); +			} +			return responseContainer[ 0 ]; +		}; + +		// Force json dataType +		s.dataTypes[ 0 ] = "json"; + +		// Install callback +		overwritten = window[ callbackName ]; +		window[ callbackName ] = function() { +			responseContainer = arguments; +		}; + +		// Clean-up function (fires after converters) +		jqXHR.always( function() { + +			// If previous value didn't exist - remove it +			if ( overwritten === undefined ) { +				jQuery( window ).removeProp( callbackName ); + +			// Otherwise restore preexisting value +			} else { +				window[ callbackName ] = overwritten; +			} + +			// Save back as free +			if ( s[ callbackName ] ) { + +				// Make sure that re-using the options doesn't screw things around +				s.jsonpCallback = originalSettings.jsonpCallback; + +				// Save the callback name for future use +				oldCallbacks.push( callbackName ); +			} + +			// Call if it was a function and we have a response +			if ( responseContainer && isFunction( overwritten ) ) { +				overwritten( responseContainer[ 0 ] ); +			} + +			responseContainer = overwritten = undefined; +		} ); + +		// Delegate to script +		return "script"; +	} +} ); + + + + +// Support: Safari 8 only +// In Safari 8 documents created via document.implementation.createHTMLDocument +// collapse sibling forms: the second one becomes a child of the first one. +// Because of that, this security measure has to be disabled in Safari 8. +// https://bugs.webkit.org/show_bug.cgi?id=137337 +support.createHTMLDocument = ( function() { +	var body = document.implementation.createHTMLDocument( "" ).body; +	body.innerHTML = "<form></form><form></form>"; +	return body.childNodes.length === 2; +} )(); + + +// Argument "data" should be string of html +// context (optional): If specified, the fragment will be created in this context, +// defaults to document +// keepScripts (optional): If true, will include scripts passed in the html string +jQuery.parseHTML = function( data, context, keepScripts ) { +	if ( typeof data !== "string" ) { +		return []; +	} +	if ( typeof context === "boolean" ) { +		keepScripts = context; +		context = false; +	} + +	var base, parsed, scripts; + +	if ( !context ) { + +		// Stop scripts or inline event handlers from being executed immediately +		// by using document.implementation +		if ( support.createHTMLDocument ) { +			context = document.implementation.createHTMLDocument( "" ); + +			// Set the base href for the created document +			// so any parsed elements with URLs +			// are based on the document's URL (gh-2965) +			base = context.createElement( "base" ); +			base.href = document.location.href; +			context.head.appendChild( base ); +		} else { +			context = document; +		} +	} + +	parsed = rsingleTag.exec( data ); +	scripts = !keepScripts && []; + +	// Single tag +	if ( parsed ) { +		return [ context.createElement( parsed[ 1 ] ) ]; +	} + +	parsed = buildFragment( [ data ], context, scripts ); + +	if ( scripts && scripts.length ) { +		jQuery( scripts ).remove(); +	} + +	return jQuery.merge( [], parsed.childNodes ); +}; + + +/** + * Load a url into a page + */ +jQuery.fn.load = function( url, params, callback ) { +	var selector, type, response, +		self = this, +		off = url.indexOf( " " ); + +	if ( off > -1 ) { +		selector = stripAndCollapse( url.slice( off ) ); +		url = url.slice( 0, off ); +	} + +	// If it's a function +	if ( isFunction( params ) ) { + +		// We assume that it's the callback +		callback = params; +		params = undefined; + +	// Otherwise, build a param string +	} else if ( params && typeof params === "object" ) { +		type = "POST"; +	} + +	// If we have elements to modify, make the request +	if ( self.length > 0 ) { +		jQuery.ajax( { +			url: url, + +			// If "type" variable is undefined, then "GET" method will be used. +			// Make value of this field explicit since +			// user can override it through ajaxSetup method +			type: type || "GET", +			dataType: "html", +			data: params +		} ).done( function( responseText ) { + +			// Save response for use in complete callback +			response = arguments; + +			self.html( selector ? + +				// If a selector was specified, locate the right elements in a dummy div +				// Exclude scripts to avoid IE 'Permission Denied' errors +				jQuery( "<div>" ).append( jQuery.parseHTML( responseText ) ).find( selector ) : + +				// Otherwise use the full result +				responseText ); + +		// If the request succeeds, this function gets "data", "status", "jqXHR" +		// but they are ignored because response was set above. +		// If it fails, this function gets "jqXHR", "status", "error" +		} ).always( callback && function( jqXHR, status ) { +			self.each( function() { +				callback.apply( this, response || [ jqXHR.responseText, status, jqXHR ] ); +			} ); +		} ); +	} + +	return this; +}; + + + + +jQuery.expr.pseudos.animated = function( elem ) { +	return jQuery.grep( jQuery.timers, function( fn ) { +		return elem === fn.elem; +	} ).length; +}; + + + + +jQuery.offset = { +	setOffset: function( elem, options, i ) { +		var curPosition, curLeft, curCSSTop, curTop, curOffset, curCSSLeft, calculatePosition, +			position = jQuery.css( elem, "position" ), +			curElem = jQuery( elem ), +			props = {}; + +		// Set position first, in-case top/left are set even on static elem +		if ( position === "static" ) { +			elem.style.position = "relative"; +		} + +		curOffset = curElem.offset(); +		curCSSTop = jQuery.css( elem, "top" ); +		curCSSLeft = jQuery.css( elem, "left" ); +		calculatePosition = ( position === "absolute" || position === "fixed" ) && +			( curCSSTop + curCSSLeft ).indexOf( "auto" ) > -1; + +		// Need to be able to calculate position if either +		// top or left is auto and position is either absolute or fixed +		if ( calculatePosition ) { +			curPosition = curElem.position(); +			curTop = curPosition.top; +			curLeft = curPosition.left; + +		} else { +			curTop = parseFloat( curCSSTop ) || 0; +			curLeft = parseFloat( curCSSLeft ) || 0; +		} + +		if ( isFunction( options ) ) { + +			// Use jQuery.extend here to allow modification of coordinates argument (gh-1848) +			options = options.call( elem, i, jQuery.extend( {}, curOffset ) ); +		} + +		if ( options.top != null ) { +			props.top = ( options.top - curOffset.top ) + curTop; +		} +		if ( options.left != null ) { +			props.left = ( options.left - curOffset.left ) + curLeft; +		} + +		if ( "using" in options ) { +			options.using.call( elem, props ); + +		} else { +			curElem.css( props ); +		} +	} +}; + +jQuery.fn.extend( { + +	// offset() relates an element's border box to the document origin +	offset: function( options ) { + +		// Preserve chaining for setter +		if ( arguments.length ) { +			return options === undefined ? +				this : +				this.each( function( i ) { +					jQuery.offset.setOffset( this, options, i ); +				} ); +		} + +		var rect, win, +			elem = this[ 0 ]; + +		if ( !elem ) { +			return; +		} + +		// Return zeros for disconnected and hidden (display: none) elements (gh-2310) +		// Support: IE <=11 only +		// Running getBoundingClientRect on a +		// disconnected node in IE throws an error +		if ( !elem.getClientRects().length ) { +			return { top: 0, left: 0 }; +		} + +		// Get document-relative position by adding viewport scroll to viewport-relative gBCR +		rect = elem.getBoundingClientRect(); +		win = elem.ownerDocument.defaultView; +		return { +			top: rect.top + win.pageYOffset, +			left: rect.left + win.pageXOffset +		}; +	}, + +	// position() relates an element's margin box to its offset parent's padding box +	// This corresponds to the behavior of CSS absolute positioning +	position: function() { +		if ( !this[ 0 ] ) { +			return; +		} + +		var offsetParent, offset, doc, +			elem = this[ 0 ], +			parentOffset = { top: 0, left: 0 }; + +		// position:fixed elements are offset from the viewport, which itself always has zero offset +		if ( jQuery.css( elem, "position" ) === "fixed" ) { + +			// Assume position:fixed implies availability of getBoundingClientRect +			offset = elem.getBoundingClientRect(); + +		} else { +			offset = this.offset(); + +			// Account for the *real* offset parent, which can be the document or its root element +			// when a statically positioned element is identified +			doc = elem.ownerDocument; +			offsetParent = elem.offsetParent || doc.documentElement; +			while ( offsetParent && +				( offsetParent === doc.body || offsetParent === doc.documentElement ) && +				jQuery.css( offsetParent, "position" ) === "static" ) { + +				offsetParent = offsetParent.parentNode; +			} +			if ( offsetParent && offsetParent !== elem && offsetParent.nodeType === 1 ) { + +				// Incorporate borders into its offset, since they are outside its content origin +				parentOffset = jQuery( offsetParent ).offset(); +				parentOffset.top += jQuery.css( offsetParent, "borderTopWidth", true ); +				parentOffset.left += jQuery.css( offsetParent, "borderLeftWidth", true ); +			} +		} + +		// Subtract parent offsets and element margins +		return { +			top: offset.top - parentOffset.top - jQuery.css( elem, "marginTop", true ), +			left: offset.left - parentOffset.left - jQuery.css( elem, "marginLeft", true ) +		}; +	}, + +	// This method will return documentElement in the following cases: +	// 1) For the element inside the iframe without offsetParent, this method will return +	//    documentElement of the parent window +	// 2) For the hidden or detached element +	// 3) For body or html element, i.e. in case of the html node - it will return itself +	// +	// but those exceptions were never presented as a real life use-cases +	// and might be considered as more preferable results. +	// +	// This logic, however, is not guaranteed and can change at any point in the future +	offsetParent: function() { +		return this.map( function() { +			var offsetParent = this.offsetParent; + +			while ( offsetParent && jQuery.css( offsetParent, "position" ) === "static" ) { +				offsetParent = offsetParent.offsetParent; +			} + +			return offsetParent || documentElement; +		} ); +	} +} ); + +// Create scrollLeft and scrollTop methods +jQuery.each( { scrollLeft: "pageXOffset", scrollTop: "pageYOffset" }, function( method, prop ) { +	var top = "pageYOffset" === prop; + +	jQuery.fn[ method ] = function( val ) { +		return access( this, function( elem, method, val ) { + +			// Coalesce documents and windows +			var win; +			if ( isWindow( elem ) ) { +				win = elem; +			} else if ( elem.nodeType === 9 ) { +				win = elem.defaultView; +			} + +			if ( val === undefined ) { +				return win ? win[ prop ] : elem[ method ]; +			} + +			if ( win ) { +				win.scrollTo( +					!top ? val : win.pageXOffset, +					top ? val : win.pageYOffset +				); + +			} else { +				elem[ method ] = val; +			} +		}, method, val, arguments.length ); +	}; +} ); + +// Support: Safari <=7 - 9.1, Chrome <=37 - 49 +// Add the top/left cssHooks using jQuery.fn.position +// Webkit bug: https://bugs.webkit.org/show_bug.cgi?id=29084 +// Blink bug: https://bugs.chromium.org/p/chromium/issues/detail?id=589347 +// getComputedStyle returns percent when specified for top/left/bottom/right; +// rather than make the css module depend on the offset module, just check for it here +jQuery.each( [ "top", "left" ], function( _i, prop ) { +	jQuery.cssHooks[ prop ] = addGetHookIf( support.pixelPosition, +		function( elem, computed ) { +			if ( computed ) { +				computed = curCSS( elem, prop ); + +				// If curCSS returns percentage, fallback to offset +				return rnumnonpx.test( computed ) ? +					jQuery( elem ).position()[ prop ] + "px" : +					computed; +			} +		} +	); +} ); + + +// Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods +jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { +	jQuery.each( { +		padding: "inner" + name, +		content: type, +		"": "outer" + name +	}, function( defaultExtra, funcName ) { + +		// Margin is only for outerHeight, outerWidth +		jQuery.fn[ funcName ] = function( margin, value ) { +			var chainable = arguments.length && ( defaultExtra || typeof margin !== "boolean" ), +				extra = defaultExtra || ( margin === true || value === true ? "margin" : "border" ); + +			return access( this, function( elem, type, value ) { +				var doc; + +				if ( isWindow( elem ) ) { + +					// $( window ).outerWidth/Height return w/h including scrollbars (gh-1729) +					return funcName.indexOf( "outer" ) === 0 ? +						elem[ "inner" + name ] : +						elem.document.documentElement[ "client" + name ]; +				} + +				// Get document width or height +				if ( elem.nodeType === 9 ) { +					doc = elem.documentElement; + +					// Either scroll[Width/Height] or offset[Width/Height] or client[Width/Height], +					// whichever is greatest +					return Math.max( +						elem.body[ "scroll" + name ], doc[ "scroll" + name ], +						elem.body[ "offset" + name ], doc[ "offset" + name ], +						doc[ "client" + name ] +					); +				} + +				return value === undefined ? + +					// Get width or height on the element, requesting but not forcing parseFloat +					jQuery.css( elem, type, extra ) : + +					// Set width or height on the element +					jQuery.style( elem, type, value, extra ); +			}, type, chainable ? margin : undefined, chainable ); +		}; +	} ); +} ); + + +jQuery.each( [ +	"ajaxStart", +	"ajaxStop", +	"ajaxComplete", +	"ajaxError", +	"ajaxSuccess", +	"ajaxSend" +], function( _i, type ) { +	jQuery.fn[ type ] = function( fn ) { +		return this.on( type, fn ); +	}; +} ); + + + + +jQuery.fn.extend( { + +	bind: function( types, data, fn ) { +		return this.on( types, null, data, fn ); +	}, +	unbind: function( types, fn ) { +		return this.off( types, null, fn ); +	}, + +	delegate: function( selector, types, data, fn ) { +		return this.on( types, selector, data, fn ); +	}, +	undelegate: function( selector, types, fn ) { + +		// ( namespace ) or ( selector, types [, fn] ) +		return arguments.length === 1 ? +			this.off( selector, "**" ) : +			this.off( types, selector || "**", fn ); +	}, + +	hover: function( fnOver, fnOut ) { +		return this.mouseenter( fnOver ).mouseleave( fnOut || fnOver ); +	} +} ); + +jQuery.each( +	( "blur focus focusin focusout resize scroll click dblclick " + +	"mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " + +	"change select submit keydown keypress keyup contextmenu" ).split( " " ), +	function( _i, name ) { + +		// Handle event binding +		jQuery.fn[ name ] = function( data, fn ) { +			return arguments.length > 0 ? +				this.on( name, null, data, fn ) : +				this.trigger( name ); +		}; +	} +); + + + + +// Support: Android <=4.0 only +// Make sure we trim BOM and NBSP +var rtrim = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g; + +// Bind a function to a context, optionally partially applying any +// arguments. +// jQuery.proxy is deprecated to promote standards (specifically Function#bind) +// However, it is not slated for removal any time soon +jQuery.proxy = function( fn, context ) { +	var tmp, args, proxy; + +	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 ( !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; +}; + +jQuery.holdReady = function( hold ) { +	if ( hold ) { +		jQuery.readyWait++; +	} else { +		jQuery.ready( true ); +	} +}; +jQuery.isArray = Array.isArray; +jQuery.parseJSON = JSON.parse; +jQuery.nodeName = nodeName; +jQuery.isFunction = isFunction; +jQuery.isWindow = isWindow; +jQuery.camelCase = camelCase; +jQuery.type = toType; + +jQuery.now = Date.now; + +jQuery.isNumeric = function( obj ) { + +	// As of jQuery 3.0, isNumeric is limited to +	// strings and numbers (primitives or objects) +	// that can be coerced to finite numbers (gh-2662) +	var type = jQuery.type( obj ); +	return ( type === "number" || type === "string" ) && + +		// parseFloat NaNs numeric-cast false positives ("") +		// ...but misinterprets leading-number strings, particularly hex literals ("0x...") +		// subtraction forces infinities to NaN +		!isNaN( obj - parseFloat( obj ) ); +}; + +jQuery.trim = function( text ) { +	return text == null ? +		"" : +		( text + "" ).replace( rtrim, "" ); +}; + + + +// Register as a named AMD module, since jQuery can be concatenated with other +// files that may use define, but not via a proper concatenation script that +// understands anonymous AMD modules. A named AMD is safest and most robust +// way to register. Lowercase jquery is used because AMD module names are +// derived from file names, and jQuery is normally delivered in a lowercase +// file name. Do this after creating the global so that if an AMD module wants +// to call noConflict to hide this version of jQuery, it will work. + +// Note that for maximum portability, libraries that are not jQuery should +// declare themselves as anonymous modules, and avoid setting a global if an +// AMD loader is present. jQuery is a special case. For more information, see +// https://github.com/jrburke/requirejs/wiki/Updating-existing-libraries#wiki-anon + +if ( typeof define === "function" && define.amd ) { +	define( "jquery", [], function() { +		return jQuery; +	} ); +} + + + + +var + +	// Map over jQuery in case of overwrite +	_jQuery = window.jQuery, + +	// Map over the $ in case of overwrite +	_$ = window.$; + +jQuery.noConflict = function( deep ) { +	if ( window.$ === jQuery ) { +		window.$ = _$; +	} + +	if ( deep && window.jQuery === jQuery ) { +		window.jQuery = _jQuery; +	} + +	return jQuery; +}; + +// Expose jQuery and $ identifiers, even in AMD +// (#7102#comment:10, https://github.com/jquery/jquery/pull/557) +// and CommonJS for browser emulators (#13566) +if ( typeof noGlobal === "undefined" ) { +	window.jQuery = window.$ = jQuery; +} + + + + +return jQuery; +} ); diff --git a/v7.1.3/_static/jquery.js b/v7.1.3/_static/jquery.js index b0614034..c4c6022f 100644 --- a/v7.1.3/_static/jquery.js +++ b/v7.1.3/_static/jquery.js @@ -1,2 +1,2 @@ -/*! jQuery v3.5.1 | (c) JS Foundation and other contributors | jquery.org/license */ -!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.5.1",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),D=function(e,t){return e===t&&(l=!0),0},j={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e.namespaceURI,n=(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},D=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&j.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(D),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(D).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function D(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(D(this,e||[],!1))},not:function(e){return this.pushStack(D(this,e||[],!0))},is:function(e){return!!D(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var j,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||j,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,j=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^key/,we=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,Te=/^([^.]*)(?:\.(.+)|)/;function Ce(){return!0}function Ee(){return!1}function Se(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function ke(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)ke(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Ee;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Ae(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,Ce)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=Te.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=Te.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Ae(t,"click",Ce),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Ae(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?Ce:Ee,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Ee,isPropagationStopped:Ee,isImmediatePropagationStopped:Ee,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=Ce,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=Ce,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=Ce,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:function(e){var t=e.button;return null==e.which&&be.test(e.type)?null!=e.charCode?e.charCode:e.keyCode:!e.which&&void 0!==t&&we.test(e.type)?1&t?1:2&t?3:4&t?2:0:e.which}},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Ae(this,e,Se),!1},trigger:function(){return Ae(this,e),!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return ke(this,e,t,n,r)},one:function(e,t,n,r){return ke(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Ee),this.each(function(){S.event.remove(this,e,n,t)})}});var Ne=/<script|<style|<link/i,De=/checked\s*(?:[^=]|=\s*.checked.)/i,je=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function qe(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function Le(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function He(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Oe(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function Pe(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&De.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),Pe(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),Le)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,He),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(je,""),u,l))}return n}function Re(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Oe(o[r],a[r]);else Oe(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Re(this,e,!0)},remove:function(e){return Re(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return Pe(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||qe(this,e).appendChild(e)})},prepend:function(){return Pe(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=qe(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return Pe(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return Pe(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!Ne.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return Pe(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Me=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Ie=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},We=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Fe=new RegExp(ne.join("|"),"i");function Be(e,t,n){var r,i,o,a,s=e.style;return(n=n||Ie(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Me.test(a)&&Fe.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function $e(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px",t.style.height="1px",n.style.height="9px",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=3<parseInt(r.height),re.removeChild(e)),a}}))}();var _e=["Webkit","Moz","ms"],ze=E.createElement("div").style,Ue={};function Xe(e){var t=S.cssProps[e]||Ue[e];return t||(e in ze?e:Ue[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=_e.length;while(n--)if((e=_e[n]+t)in ze)return e}(e)||e)}var Ve=/^(none|table(?!-c[ea]).+)/,Ge=/^--/,Ye={position:"absolute",visibility:"hidden",display:"block"},Qe={letterSpacing:"0",fontWeight:"400"};function Je(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Ke(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Ze(e,t,n){var r=Ie(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=Be(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Me.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Ke(e,t,n||(i?"border":"content"),o,r,a)+"px"}function et(e,t,n,r,i){return new et.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=Be(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Ge.test(t),l=e.style;if(u||(t=Xe(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Ge.test(t)||(t=Xe(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=Be(e,t,r)),"normal"===i&&t in Qe&&(i=Qe[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ve.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Ze(e,u,n):We(e,Ye,function(){return Ze(e,u,n)})},set:function(e,t,n){var r,i=Ie(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Ke(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Ke(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Je(0,t,s)}}}),S.cssHooks.marginLeft=$e(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(Be(e,"marginLeft"))||e.getBoundingClientRect().left-We(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Je)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Ie(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=et).prototype={constructor:et,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=et.propHooks[this.prop];return e&&e.get?e.get(this):et.propHooks._default.get(this)},run:function(e){var t,n=et.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):et.propHooks._default.set(this),this}}).init.prototype=et.prototype,(et.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[Xe(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=et.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=et.prototype.init,S.fx.step={};var tt,nt,rt,it,ot=/^(?:toggle|show|hide)$/,at=/queueHooks$/;function st(){nt&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(st):C.setTimeout(st,S.fx.interval),S.fx.tick())}function ut(){return C.setTimeout(function(){tt=void 0}),tt=Date.now()}function lt(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ct(e,t,n){for(var r,i=(ft.tweeners[t]||[]).concat(ft.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function ft(o,e,t){var n,a,r=0,i=ft.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=tt||ut(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:tt||ut(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=ft.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ct,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(ft,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],ft.tweeners[n]=ft.tweeners[n]||[],ft.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],ot.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ct(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?ft.prefilters.unshift(e):ft.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=ft(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&at.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(lt(r,!0),e,t,n)}}),S.each({slideDown:lt("show"),slideUp:lt("hide"),slideToggle:lt("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(tt=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),tt=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){nt||(nt=!0,st())},S.fx.stop=function(){nt=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},rt=E.createElement("input"),it=E.createElement("select").appendChild(E.createElement("option")),rt.type="checkbox",y.checkOn=""!==rt.value,y.optSelected=it.selected,(rt=E.createElement("input")).value="t",rt.type="radio",y.radioValue="t"===rt.value;var pt,dt=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?pt:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),pt={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=dt[t]||S.find.attr;dt[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=dt[o],dt[o]=r,r=null!=a(e,t,n)?o:null,dt[o]=i),r}});var ht=/^(?:input|select|textarea|button)$/i,gt=/^(?:a|area)$/i;function vt(e){return(e.match(P)||[]).join(" ")}function yt(e){return e.getAttribute&&e.getAttribute("class")||""}function mt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):ht.test(e.nodeName)||gt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,yt(this)))});if((e=mt(t)).length)while(n=this[u++])if(i=yt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,yt(this)))});if(!arguments.length)return this.attr("class","");if((e=mt(t)).length)while(n=this[u++])if(i=yt(n),r=1===n.nodeType&&" "+vt(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=vt(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,yt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=mt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=yt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+vt(yt(n))+" ").indexOf(t))return!0;return!1}});var xt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(xt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:vt(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var bt=/^(?:focusinfocus|focusoutblur)$/,wt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!bt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,bt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,wt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,wt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var Tt=C.location,Ct={guid:Date.now()},Et=/\?/;S.parseXML=function(e){var t;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){t=void 0}return t&&!t.getElementsByTagName("parsererror").length||S.error("Invalid XML: "+e),t};var St=/\[\]$/,kt=/\r?\n/g,At=/^(?:submit|button|image|reset|file)$/i,Nt=/^(?:input|select|textarea|keygen)/i;function Dt(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||St.test(n)?i(n,t):Dt(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)Dt(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)Dt(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&Nt.test(this.nodeName)&&!At.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(kt,"\r\n")}}):{name:t.name,value:n.replace(kt,"\r\n")}}).get()}});var jt=/%20/g,qt=/#.*$/,Lt=/([?&])_=[^&]*/,Ht=/^(.*?):[ \t]*([^\r\n]*)$/gm,Ot=/^(?:GET|HEAD)$/,Pt=/^\/\//,Rt={},Mt={},It="*/".concat("*"),Wt=E.createElement("a");function Ft(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Bt(t,i,o,a){var s={},u=t===Mt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function $t(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Wt.href=Tt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:Tt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(Tt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":It,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?$t($t(e,S.ajaxSettings),t):$t(S.ajaxSettings,e)},ajaxPrefilter:Ft(Rt),ajaxTransport:Ft(Mt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=Ht.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||Tt.href)+"").replace(Pt,Tt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Wt.protocol+"//"+Wt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Bt(Rt,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Ot.test(v.type),f=v.url.replace(qt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(jt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Et.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Lt,"$1"),o=(Et.test(f)?"&":"?")+"_="+Ct.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+It+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Bt(Mt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var _t={0:200,1223:204},zt=S.ajaxSettings.xhr();y.cors=!!zt&&"withCredentials"in zt,y.ajax=zt=!!zt,S.ajaxTransport(function(i){var o,a;if(y.cors||zt&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(_t[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var Ut,Xt=[],Vt=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=Xt.pop()||S.expando+"_"+Ct.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Vt.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Vt.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Vt,"$1"+r):!1!==e.jsonp&&(e.url+=(Et.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,Xt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((Ut=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===Ut.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=vt(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):("number"==typeof f.top&&(f.top+="px"),"number"==typeof f.left&&(f.left+="px"),c.css(f))}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=$e(y.pixelPosition,function(e,t){if(t)return t=Be(e,n),Me.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Gt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Gt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Yt=C.jQuery,Qt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Qt),e&&C.jQuery===S&&(C.jQuery=Yt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S}); +/*! jQuery v3.6.0 | (c) OpenJS Foundation and other contributors | jquery.org/license */ +!function(e,t){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=e.document?t(e,!0):function(e){if(!e.document)throw new Error("jQuery requires a window with a document");return t(e)}:t(e)}("undefined"!=typeof window?window:this,function(C,e){"use strict";var t=[],r=Object.getPrototypeOf,s=t.slice,g=t.flat?function(e){return t.flat.call(e)}:function(e){return t.concat.apply([],e)},u=t.push,i=t.indexOf,n={},o=n.toString,v=n.hasOwnProperty,a=v.toString,l=a.call(Object),y={},m=function(e){return"function"==typeof e&&"number"!=typeof e.nodeType&&"function"!=typeof e.item},x=function(e){return null!=e&&e===e.window},E=C.document,c={type:!0,src:!0,nonce:!0,noModule:!0};function b(e,t,n){var r,i,o=(n=n||E).createElement("script");if(o.text=e,t)for(r in c)(i=t[r]||t.getAttribute&&t.getAttribute(r))&&o.setAttribute(r,i);n.head.appendChild(o).parentNode.removeChild(o)}function w(e){return null==e?e+"":"object"==typeof e||"function"==typeof e?n[o.call(e)]||"object":typeof e}var f="3.6.0",S=function(e,t){return new S.fn.init(e,t)};function p(e){var t=!!e&&"length"in e&&e.length,n=w(e);return!m(e)&&!x(e)&&("array"===n||0===t||"number"==typeof t&&0<t&&t-1 in e)}S.fn=S.prototype={jquery:f,constructor:S,length:0,toArray:function(){return s.call(this)},get:function(e){return null==e?s.call(this):e<0?this[e+this.length]:this[e]},pushStack:function(e){var t=S.merge(this.constructor(),e);return t.prevObject=this,t},each:function(e){return S.each(this,e)},map:function(n){return this.pushStack(S.map(this,function(e,t){return n.call(e,t,e)}))},slice:function(){return this.pushStack(s.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},even:function(){return this.pushStack(S.grep(this,function(e,t){return(t+1)%2}))},odd:function(){return this.pushStack(S.grep(this,function(e,t){return t%2}))},eq:function(e){var t=this.length,n=+e+(e<0?t:0);return this.pushStack(0<=n&&n<t?[this[n]]:[])},end:function(){return this.prevObject||this.constructor()},push:u,sort:t.sort,splice:t.splice},S.extend=S.fn.extend=function(){var e,t,n,r,i,o,a=arguments[0]||{},s=1,u=arguments.length,l=!1;for("boolean"==typeof a&&(l=a,a=arguments[s]||{},s++),"object"==typeof a||m(a)||(a={}),s===u&&(a=this,s--);s<u;s++)if(null!=(e=arguments[s]))for(t in e)r=e[t],"__proto__"!==t&&a!==r&&(l&&r&&(S.isPlainObject(r)||(i=Array.isArray(r)))?(n=a[t],o=i&&!Array.isArray(n)?[]:i||S.isPlainObject(n)?n:{},i=!1,a[t]=S.extend(l,o,r)):void 0!==r&&(a[t]=r));return a},S.extend({expando:"jQuery"+(f+Math.random()).replace(/\D/g,""),isReady:!0,error:function(e){throw new Error(e)},noop:function(){},isPlainObject:function(e){var t,n;return!(!e||"[object Object]"!==o.call(e))&&(!(t=r(e))||"function"==typeof(n=v.call(t,"constructor")&&t.constructor)&&a.call(n)===l)},isEmptyObject:function(e){var t;for(t in e)return!1;return!0},globalEval:function(e,t,n){b(e,{nonce:t&&t.nonce},n)},each:function(e,t){var n,r=0;if(p(e)){for(n=e.length;r<n;r++)if(!1===t.call(e[r],r,e[r]))break}else for(r in e)if(!1===t.call(e[r],r,e[r]))break;return e},makeArray:function(e,t){var n=t||[];return null!=e&&(p(Object(e))?S.merge(n,"string"==typeof e?[e]:e):u.call(n,e)),n},inArray:function(e,t,n){return null==t?-1:i.call(t,e,n)},merge:function(e,t){for(var n=+t.length,r=0,i=e.length;r<n;r++)e[i++]=t[r];return e.length=i,e},grep:function(e,t,n){for(var r=[],i=0,o=e.length,a=!n;i<o;i++)!t(e[i],i)!==a&&r.push(e[i]);return r},map:function(e,t,n){var r,i,o=0,a=[];if(p(e))for(r=e.length;o<r;o++)null!=(i=t(e[o],o,n))&&a.push(i);else for(o in e)null!=(i=t(e[o],o,n))&&a.push(i);return g(a)},guid:1,support:y}),"function"==typeof Symbol&&(S.fn[Symbol.iterator]=t[Symbol.iterator]),S.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "),function(e,t){n["[object "+t+"]"]=t.toLowerCase()});var d=function(n){var e,d,b,o,i,h,f,g,w,u,l,T,C,a,E,v,s,c,y,S="sizzle"+1*new Date,p=n.document,k=0,r=0,m=ue(),x=ue(),A=ue(),N=ue(),j=function(e,t){return e===t&&(l=!0),0},D={}.hasOwnProperty,t=[],q=t.pop,L=t.push,H=t.push,O=t.slice,P=function(e,t){for(var n=0,r=e.length;n<r;n++)if(e[n]===t)return n;return-1},R="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",I="(?:\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\[^\\r\\n\\f]|[\\w-]|[^\0-\\x7f])+",W="\\["+M+"*("+I+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+I+"))|)"+M+"*\\]",F=":("+I+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+W+")*)|.*)\\)|)",B=new RegExp(M+"+","g"),$=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),_=new RegExp("^"+M+"*,"+M+"*"),z=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp(M+"|>"),X=new RegExp(F),V=new RegExp("^"+I+"$"),G={ID:new RegExp("^#("+I+")"),CLASS:new RegExp("^\\.("+I+")"),TAG:new RegExp("^("+I+"|[*])"),ATTR:new RegExp("^"+W),PSEUDO:new RegExp("^"+F),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+R+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/HTML$/i,Q=/^(?:input|select|textarea|button)$/i,J=/^h\d$/i,K=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ee=/[+~]/,te=new RegExp("\\\\[\\da-fA-F]{1,6}"+M+"?|\\\\([^\\r\\n\\f])","g"),ne=function(e,t){var n="0x"+e.slice(1)-65536;return t||(n<0?String.fromCharCode(n+65536):String.fromCharCode(n>>10|55296,1023&n|56320))},re=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ie=function(e,t){return t?"\0"===e?"\ufffd":e.slice(0,-1)+"\\"+e.charCodeAt(e.length-1).toString(16)+" ":"\\"+e},oe=function(){T()},ae=be(function(e){return!0===e.disabled&&"fieldset"===e.nodeName.toLowerCase()},{dir:"parentNode",next:"legend"});try{H.apply(t=O.call(p.childNodes),p.childNodes),t[p.childNodes.length].nodeType}catch(e){H={apply:t.length?function(e,t){L.apply(e,O.call(t))}:function(e,t){var n=e.length,r=0;while(e[n++]=t[r++]);e.length=n-1}}}function se(t,e,n,r){var i,o,a,s,u,l,c,f=e&&e.ownerDocument,p=e?e.nodeType:9;if(n=n||[],"string"!=typeof t||!t||1!==p&&9!==p&&11!==p)return n;if(!r&&(T(e),e=e||C,E)){if(11!==p&&(u=Z.exec(t)))if(i=u[1]){if(9===p){if(!(a=e.getElementById(i)))return n;if(a.id===i)return n.push(a),n}else if(f&&(a=f.getElementById(i))&&y(e,a)&&a.id===i)return n.push(a),n}else{if(u[2])return H.apply(n,e.getElementsByTagName(t)),n;if((i=u[3])&&d.getElementsByClassName&&e.getElementsByClassName)return H.apply(n,e.getElementsByClassName(i)),n}if(d.qsa&&!N[t+" "]&&(!v||!v.test(t))&&(1!==p||"object"!==e.nodeName.toLowerCase())){if(c=t,f=e,1===p&&(U.test(t)||z.test(t))){(f=ee.test(t)&&ye(e.parentNode)||e)===e&&d.scope||((s=e.getAttribute("id"))?s=s.replace(re,ie):e.setAttribute("id",s=S)),o=(l=h(t)).length;while(o--)l[o]=(s?"#"+s:":scope")+" "+xe(l[o]);c=l.join(",")}try{return H.apply(n,f.querySelectorAll(c)),n}catch(e){N(t,!0)}finally{s===S&&e.removeAttribute("id")}}}return g(t.replace($,"$1"),e,n,r)}function ue(){var r=[];return function e(t,n){return r.push(t+" ")>b.cacheLength&&delete e[r.shift()],e[t+" "]=n}}function le(e){return e[S]=!0,e}function ce(e){var t=C.createElement("fieldset");try{return!!e(t)}catch(e){return!1}finally{t.parentNode&&t.parentNode.removeChild(t),t=null}}function fe(e,t){var n=e.split("|"),r=n.length;while(r--)b.attrHandle[n[r]]=t}function pe(e,t){var n=t&&e,r=n&&1===e.nodeType&&1===t.nodeType&&e.sourceIndex-t.sourceIndex;if(r)return r;if(n)while(n=n.nextSibling)if(n===t)return-1;return e?1:-1}function de(t){return function(e){return"input"===e.nodeName.toLowerCase()&&e.type===t}}function he(n){return function(e){var t=e.nodeName.toLowerCase();return("input"===t||"button"===t)&&e.type===n}}function ge(t){return function(e){return"form"in e?e.parentNode&&!1===e.disabled?"label"in e?"label"in e.parentNode?e.parentNode.disabled===t:e.disabled===t:e.isDisabled===t||e.isDisabled!==!t&&ae(e)===t:e.disabled===t:"label"in e&&e.disabled===t}}function ve(a){return le(function(o){return o=+o,le(function(e,t){var n,r=a([],e.length,o),i=r.length;while(i--)e[n=r[i]]&&(e[n]=!(t[n]=e[n]))})})}function ye(e){return e&&"undefined"!=typeof e.getElementsByTagName&&e}for(e in d=se.support={},i=se.isXML=function(e){var t=e&&e.namespaceURI,n=e&&(e.ownerDocument||e).documentElement;return!Y.test(t||n&&n.nodeName||"HTML")},T=se.setDocument=function(e){var t,n,r=e?e.ownerDocument||e:p;return r!=C&&9===r.nodeType&&r.documentElement&&(a=(C=r).documentElement,E=!i(C),p!=C&&(n=C.defaultView)&&n.top!==n&&(n.addEventListener?n.addEventListener("unload",oe,!1):n.attachEvent&&n.attachEvent("onunload",oe)),d.scope=ce(function(e){return a.appendChild(e).appendChild(C.createElement("div")),"undefined"!=typeof e.querySelectorAll&&!e.querySelectorAll(":scope fieldset div").length}),d.attributes=ce(function(e){return e.className="i",!e.getAttribute("className")}),d.getElementsByTagName=ce(function(e){return e.appendChild(C.createComment("")),!e.getElementsByTagName("*").length}),d.getElementsByClassName=K.test(C.getElementsByClassName),d.getById=ce(function(e){return a.appendChild(e).id=S,!C.getElementsByName||!C.getElementsByName(S).length}),d.getById?(b.filter.ID=function(e){var t=e.replace(te,ne);return function(e){return e.getAttribute("id")===t}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n=t.getElementById(e);return n?[n]:[]}}):(b.filter.ID=function(e){var n=e.replace(te,ne);return function(e){var t="undefined"!=typeof e.getAttributeNode&&e.getAttributeNode("id");return t&&t.value===n}},b.find.ID=function(e,t){if("undefined"!=typeof t.getElementById&&E){var n,r,i,o=t.getElementById(e);if(o){if((n=o.getAttributeNode("id"))&&n.value===e)return[o];i=t.getElementsByName(e),r=0;while(o=i[r++])if((n=o.getAttributeNode("id"))&&n.value===e)return[o]}return[]}}),b.find.TAG=d.getElementsByTagName?function(e,t){return"undefined"!=typeof t.getElementsByTagName?t.getElementsByTagName(e):d.qsa?t.querySelectorAll(e):void 0}:function(e,t){var n,r=[],i=0,o=t.getElementsByTagName(e);if("*"===e){while(n=o[i++])1===n.nodeType&&r.push(n);return r}return o},b.find.CLASS=d.getElementsByClassName&&function(e,t){if("undefined"!=typeof t.getElementsByClassName&&E)return t.getElementsByClassName(e)},s=[],v=[],(d.qsa=K.test(C.querySelectorAll))&&(ce(function(e){var t;a.appendChild(e).innerHTML="<a id='"+S+"'></a><select id='"+S+"-\r\\' msallowcapture=''><option selected=''></option></select>",e.querySelectorAll("[msallowcapture^='']").length&&v.push("[*^$]="+M+"*(?:''|\"\")"),e.querySelectorAll("[selected]").length||v.push("\\["+M+"*(?:value|"+R+")"),e.querySelectorAll("[id~="+S+"-]").length||v.push("~="),(t=C.createElement("input")).setAttribute("name",""),e.appendChild(t),e.querySelectorAll("[name='']").length||v.push("\\["+M+"*name"+M+"*="+M+"*(?:''|\"\")"),e.querySelectorAll(":checked").length||v.push(":checked"),e.querySelectorAll("a#"+S+"+*").length||v.push(".#.+[+~]"),e.querySelectorAll("\\\f"),v.push("[\\r\\n\\f]")}),ce(function(e){e.innerHTML="<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";var t=C.createElement("input");t.setAttribute("type","hidden"),e.appendChild(t).setAttribute("name","D"),e.querySelectorAll("[name=d]").length&&v.push("name"+M+"*[*^$|!~]?="),2!==e.querySelectorAll(":enabled").length&&v.push(":enabled",":disabled"),a.appendChild(e).disabled=!0,2!==e.querySelectorAll(":disabled").length&&v.push(":enabled",":disabled"),e.querySelectorAll("*,:x"),v.push(",.*:")})),(d.matchesSelector=K.test(c=a.matches||a.webkitMatchesSelector||a.mozMatchesSelector||a.oMatchesSelector||a.msMatchesSelector))&&ce(function(e){d.disconnectedMatch=c.call(e,"*"),c.call(e,"[s!='']:x"),s.push("!=",F)}),v=v.length&&new RegExp(v.join("|")),s=s.length&&new RegExp(s.join("|")),t=K.test(a.compareDocumentPosition),y=t||K.test(a.contains)?function(e,t){var n=9===e.nodeType?e.documentElement:e,r=t&&t.parentNode;return e===r||!(!r||1!==r.nodeType||!(n.contains?n.contains(r):e.compareDocumentPosition&&16&e.compareDocumentPosition(r)))}:function(e,t){if(t)while(t=t.parentNode)if(t===e)return!0;return!1},j=t?function(e,t){if(e===t)return l=!0,0;var n=!e.compareDocumentPosition-!t.compareDocumentPosition;return n||(1&(n=(e.ownerDocument||e)==(t.ownerDocument||t)?e.compareDocumentPosition(t):1)||!d.sortDetached&&t.compareDocumentPosition(e)===n?e==C||e.ownerDocument==p&&y(p,e)?-1:t==C||t.ownerDocument==p&&y(p,t)?1:u?P(u,e)-P(u,t):0:4&n?-1:1)}:function(e,t){if(e===t)return l=!0,0;var n,r=0,i=e.parentNode,o=t.parentNode,a=[e],s=[t];if(!i||!o)return e==C?-1:t==C?1:i?-1:o?1:u?P(u,e)-P(u,t):0;if(i===o)return pe(e,t);n=e;while(n=n.parentNode)a.unshift(n);n=t;while(n=n.parentNode)s.unshift(n);while(a[r]===s[r])r++;return r?pe(a[r],s[r]):a[r]==p?-1:s[r]==p?1:0}),C},se.matches=function(e,t){return se(e,null,null,t)},se.matchesSelector=function(e,t){if(T(e),d.matchesSelector&&E&&!N[t+" "]&&(!s||!s.test(t))&&(!v||!v.test(t)))try{var n=c.call(e,t);if(n||d.disconnectedMatch||e.document&&11!==e.document.nodeType)return n}catch(e){N(t,!0)}return 0<se(t,C,null,[e]).length},se.contains=function(e,t){return(e.ownerDocument||e)!=C&&T(e),y(e,t)},se.attr=function(e,t){(e.ownerDocument||e)!=C&&T(e);var n=b.attrHandle[t.toLowerCase()],r=n&&D.call(b.attrHandle,t.toLowerCase())?n(e,t,!E):void 0;return void 0!==r?r:d.attributes||!E?e.getAttribute(t):(r=e.getAttributeNode(t))&&r.specified?r.value:null},se.escape=function(e){return(e+"").replace(re,ie)},se.error=function(e){throw new Error("Syntax error, unrecognized expression: "+e)},se.uniqueSort=function(e){var t,n=[],r=0,i=0;if(l=!d.detectDuplicates,u=!d.sortStable&&e.slice(0),e.sort(j),l){while(t=e[i++])t===e[i]&&(r=n.push(i));while(r--)e.splice(n[r],1)}return u=null,e},o=se.getText=function(e){var t,n="",r=0,i=e.nodeType;if(i){if(1===i||9===i||11===i){if("string"==typeof e.textContent)return e.textContent;for(e=e.firstChild;e;e=e.nextSibling)n+=o(e)}else if(3===i||4===i)return e.nodeValue}else while(t=e[r++])n+=o(t);return n},(b=se.selectors={cacheLength:50,createPseudo:le,match:G,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(e){return e[1]=e[1].replace(te,ne),e[3]=(e[3]||e[4]||e[5]||"").replace(te,ne),"~="===e[2]&&(e[3]=" "+e[3]+" "),e.slice(0,4)},CHILD:function(e){return e[1]=e[1].toLowerCase(),"nth"===e[1].slice(0,3)?(e[3]||se.error(e[0]),e[4]=+(e[4]?e[5]+(e[6]||1):2*("even"===e[3]||"odd"===e[3])),e[5]=+(e[7]+e[8]||"odd"===e[3])):e[3]&&se.error(e[0]),e},PSEUDO:function(e){var t,n=!e[6]&&e[2];return G.CHILD.test(e[0])?null:(e[3]?e[2]=e[4]||e[5]||"":n&&X.test(n)&&(t=h(n,!0))&&(t=n.indexOf(")",n.length-t)-n.length)&&(e[0]=e[0].slice(0,t),e[2]=n.slice(0,t)),e.slice(0,3))}},filter:{TAG:function(e){var t=e.replace(te,ne).toLowerCase();return"*"===e?function(){return!0}:function(e){return e.nodeName&&e.nodeName.toLowerCase()===t}},CLASS:function(e){var t=m[e+" "];return t||(t=new RegExp("(^|"+M+")"+e+"("+M+"|$)"))&&m(e,function(e){return t.test("string"==typeof e.className&&e.className||"undefined"!=typeof e.getAttribute&&e.getAttribute("class")||"")})},ATTR:function(n,r,i){return function(e){var t=se.attr(e,n);return null==t?"!="===r:!r||(t+="","="===r?t===i:"!="===r?t!==i:"^="===r?i&&0===t.indexOf(i):"*="===r?i&&-1<t.indexOf(i):"$="===r?i&&t.slice(-i.length)===i:"~="===r?-1<(" "+t.replace(B," ")+" ").indexOf(i):"|="===r&&(t===i||t.slice(0,i.length+1)===i+"-"))}},CHILD:function(h,e,t,g,v){var y="nth"!==h.slice(0,3),m="last"!==h.slice(-4),x="of-type"===e;return 1===g&&0===v?function(e){return!!e.parentNode}:function(e,t,n){var r,i,o,a,s,u,l=y!==m?"nextSibling":"previousSibling",c=e.parentNode,f=x&&e.nodeName.toLowerCase(),p=!n&&!x,d=!1;if(c){if(y){while(l){a=e;while(a=a[l])if(x?a.nodeName.toLowerCase()===f:1===a.nodeType)return!1;u=l="only"===h&&!u&&"nextSibling"}return!0}if(u=[m?c.firstChild:c.lastChild],m&&p){d=(s=(r=(i=(o=(a=c)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1])&&r[2],a=s&&c.childNodes[s];while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if(1===a.nodeType&&++d&&a===e){i[h]=[k,s,d];break}}else if(p&&(d=s=(r=(i=(o=(a=e)[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]||[])[0]===k&&r[1]),!1===d)while(a=++s&&a&&a[l]||(d=s=0)||u.pop())if((x?a.nodeName.toLowerCase()===f:1===a.nodeType)&&++d&&(p&&((i=(o=a[S]||(a[S]={}))[a.uniqueID]||(o[a.uniqueID]={}))[h]=[k,d]),a===e))break;return(d-=v)===g||d%g==0&&0<=d/g}}},PSEUDO:function(e,o){var t,a=b.pseudos[e]||b.setFilters[e.toLowerCase()]||se.error("unsupported pseudo: "+e);return a[S]?a(o):1<a.length?(t=[e,e,"",o],b.setFilters.hasOwnProperty(e.toLowerCase())?le(function(e,t){var n,r=a(e,o),i=r.length;while(i--)e[n=P(e,r[i])]=!(t[n]=r[i])}):function(e){return a(e,0,t)}):a}},pseudos:{not:le(function(e){var r=[],i=[],s=f(e.replace($,"$1"));return s[S]?le(function(e,t,n,r){var i,o=s(e,null,r,[]),a=e.length;while(a--)(i=o[a])&&(e[a]=!(t[a]=i))}):function(e,t,n){return r[0]=e,s(r,null,n,i),r[0]=null,!i.pop()}}),has:le(function(t){return function(e){return 0<se(t,e).length}}),contains:le(function(t){return t=t.replace(te,ne),function(e){return-1<(e.textContent||o(e)).indexOf(t)}}),lang:le(function(n){return V.test(n||"")||se.error("unsupported lang: "+n),n=n.replace(te,ne).toLowerCase(),function(e){var t;do{if(t=E?e.lang:e.getAttribute("xml:lang")||e.getAttribute("lang"))return(t=t.toLowerCase())===n||0===t.indexOf(n+"-")}while((e=e.parentNode)&&1===e.nodeType);return!1}}),target:function(e){var t=n.location&&n.location.hash;return t&&t.slice(1)===e.id},root:function(e){return e===a},focus:function(e){return e===C.activeElement&&(!C.hasFocus||C.hasFocus())&&!!(e.type||e.href||~e.tabIndex)},enabled:ge(!1),disabled:ge(!0),checked:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&!!e.checked||"option"===t&&!!e.selected},selected:function(e){return e.parentNode&&e.parentNode.selectedIndex,!0===e.selected},empty:function(e){for(e=e.firstChild;e;e=e.nextSibling)if(e.nodeType<6)return!1;return!0},parent:function(e){return!b.pseudos.empty(e)},header:function(e){return J.test(e.nodeName)},input:function(e){return Q.test(e.nodeName)},button:function(e){var t=e.nodeName.toLowerCase();return"input"===t&&"button"===e.type||"button"===t},text:function(e){var t;return"input"===e.nodeName.toLowerCase()&&"text"===e.type&&(null==(t=e.getAttribute("type"))||"text"===t.toLowerCase())},first:ve(function(){return[0]}),last:ve(function(e,t){return[t-1]}),eq:ve(function(e,t,n){return[n<0?n+t:n]}),even:ve(function(e,t){for(var n=0;n<t;n+=2)e.push(n);return e}),odd:ve(function(e,t){for(var n=1;n<t;n+=2)e.push(n);return e}),lt:ve(function(e,t,n){for(var r=n<0?n+t:t<n?t:n;0<=--r;)e.push(r);return e}),gt:ve(function(e,t,n){for(var r=n<0?n+t:n;++r<t;)e.push(r);return e})}}).pseudos.nth=b.pseudos.eq,{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})b.pseudos[e]=de(e);for(e in{submit:!0,reset:!0})b.pseudos[e]=he(e);function me(){}function xe(e){for(var t=0,n=e.length,r="";t<n;t++)r+=e[t].value;return r}function be(s,e,t){var u=e.dir,l=e.next,c=l||u,f=t&&"parentNode"===c,p=r++;return e.first?function(e,t,n){while(e=e[u])if(1===e.nodeType||f)return s(e,t,n);return!1}:function(e,t,n){var r,i,o,a=[k,p];if(n){while(e=e[u])if((1===e.nodeType||f)&&s(e,t,n))return!0}else while(e=e[u])if(1===e.nodeType||f)if(i=(o=e[S]||(e[S]={}))[e.uniqueID]||(o[e.uniqueID]={}),l&&l===e.nodeName.toLowerCase())e=e[u]||e;else{if((r=i[c])&&r[0]===k&&r[1]===p)return a[2]=r[2];if((i[c]=a)[2]=s(e,t,n))return!0}return!1}}function we(i){return 1<i.length?function(e,t,n){var r=i.length;while(r--)if(!i[r](e,t,n))return!1;return!0}:i[0]}function Te(e,t,n,r,i){for(var o,a=[],s=0,u=e.length,l=null!=t;s<u;s++)(o=e[s])&&(n&&!n(o,r,i)||(a.push(o),l&&t.push(s)));return a}function Ce(d,h,g,v,y,e){return v&&!v[S]&&(v=Ce(v)),y&&!y[S]&&(y=Ce(y,e)),le(function(e,t,n,r){var i,o,a,s=[],u=[],l=t.length,c=e||function(e,t,n){for(var r=0,i=t.length;r<i;r++)se(e,t[r],n);return n}(h||"*",n.nodeType?[n]:n,[]),f=!d||!e&&h?c:Te(c,s,d,n,r),p=g?y||(e?d:l||v)?[]:t:f;if(g&&g(f,p,n,r),v){i=Te(p,u),v(i,[],n,r),o=i.length;while(o--)(a=i[o])&&(p[u[o]]=!(f[u[o]]=a))}if(e){if(y||d){if(y){i=[],o=p.length;while(o--)(a=p[o])&&i.push(f[o]=a);y(null,p=[],i,r)}o=p.length;while(o--)(a=p[o])&&-1<(i=y?P(e,a):s[o])&&(e[i]=!(t[i]=a))}}else p=Te(p===t?p.splice(l,p.length):p),y?y(null,t,p,r):H.apply(t,p)})}function Ee(e){for(var i,t,n,r=e.length,o=b.relative[e[0].type],a=o||b.relative[" "],s=o?1:0,u=be(function(e){return e===i},a,!0),l=be(function(e){return-1<P(i,e)},a,!0),c=[function(e,t,n){var r=!o&&(n||t!==w)||((i=t).nodeType?u(e,t,n):l(e,t,n));return i=null,r}];s<r;s++)if(t=b.relative[e[s].type])c=[be(we(c),t)];else{if((t=b.filter[e[s].type].apply(null,e[s].matches))[S]){for(n=++s;n<r;n++)if(b.relative[e[n].type])break;return Ce(1<s&&we(c),1<s&&xe(e.slice(0,s-1).concat({value:" "===e[s-2].type?"*":""})).replace($,"$1"),t,s<n&&Ee(e.slice(s,n)),n<r&&Ee(e=e.slice(n)),n<r&&xe(e))}c.push(t)}return we(c)}return me.prototype=b.filters=b.pseudos,b.setFilters=new me,h=se.tokenize=function(e,t){var n,r,i,o,a,s,u,l=x[e+" "];if(l)return t?0:l.slice(0);a=e,s=[],u=b.preFilter;while(a){for(o in n&&!(r=_.exec(a))||(r&&(a=a.slice(r[0].length)||a),s.push(i=[])),n=!1,(r=z.exec(a))&&(n=r.shift(),i.push({value:n,type:r[0].replace($," ")}),a=a.slice(n.length)),b.filter)!(r=G[o].exec(a))||u[o]&&!(r=u[o](r))||(n=r.shift(),i.push({value:n,type:o,matches:r}),a=a.slice(n.length));if(!n)break}return t?a.length:a?se.error(e):x(e,s).slice(0)},f=se.compile=function(e,t){var n,v,y,m,x,r,i=[],o=[],a=A[e+" "];if(!a){t||(t=h(e)),n=t.length;while(n--)(a=Ee(t[n]))[S]?i.push(a):o.push(a);(a=A(e,(v=o,m=0<(y=i).length,x=0<v.length,r=function(e,t,n,r,i){var o,a,s,u=0,l="0",c=e&&[],f=[],p=w,d=e||x&&b.find.TAG("*",i),h=k+=null==p?1:Math.random()||.1,g=d.length;for(i&&(w=t==C||t||i);l!==g&&null!=(o=d[l]);l++){if(x&&o){a=0,t||o.ownerDocument==C||(T(o),n=!E);while(s=v[a++])if(s(o,t||C,n)){r.push(o);break}i&&(k=h)}m&&((o=!s&&o)&&u--,e&&c.push(o))}if(u+=l,m&&l!==u){a=0;while(s=y[a++])s(c,f,t,n);if(e){if(0<u)while(l--)c[l]||f[l]||(f[l]=q.call(r));f=Te(f)}H.apply(r,f),i&&!e&&0<f.length&&1<u+y.length&&se.uniqueSort(r)}return i&&(k=h,w=p),c},m?le(r):r))).selector=e}return a},g=se.select=function(e,t,n,r){var i,o,a,s,u,l="function"==typeof e&&e,c=!r&&h(e=l.selector||e);if(n=n||[],1===c.length){if(2<(o=c[0]=c[0].slice(0)).length&&"ID"===(a=o[0]).type&&9===t.nodeType&&E&&b.relative[o[1].type]){if(!(t=(b.find.ID(a.matches[0].replace(te,ne),t)||[])[0]))return n;l&&(t=t.parentNode),e=e.slice(o.shift().value.length)}i=G.needsContext.test(e)?0:o.length;while(i--){if(a=o[i],b.relative[s=a.type])break;if((u=b.find[s])&&(r=u(a.matches[0].replace(te,ne),ee.test(o[0].type)&&ye(t.parentNode)||t))){if(o.splice(i,1),!(e=r.length&&xe(o)))return H.apply(n,r),n;break}}}return(l||f(e,c))(r,t,!E,n,!t||ee.test(e)&&ye(t.parentNode)||t),n},d.sortStable=S.split("").sort(j).join("")===S,d.detectDuplicates=!!l,T(),d.sortDetached=ce(function(e){return 1&e.compareDocumentPosition(C.createElement("fieldset"))}),ce(function(e){return e.innerHTML="<a href='#'></a>","#"===e.firstChild.getAttribute("href")})||fe("type|href|height|width",function(e,t,n){if(!n)return e.getAttribute(t,"type"===t.toLowerCase()?1:2)}),d.attributes&&ce(function(e){return e.innerHTML="<input/>",e.firstChild.setAttribute("value",""),""===e.firstChild.getAttribute("value")})||fe("value",function(e,t,n){if(!n&&"input"===e.nodeName.toLowerCase())return e.defaultValue}),ce(function(e){return null==e.getAttribute("disabled")})||fe(R,function(e,t,n){var r;if(!n)return!0===e[t]?t.toLowerCase():(r=e.getAttributeNode(t))&&r.specified?r.value:null}),se}(C);S.find=d,S.expr=d.selectors,S.expr[":"]=S.expr.pseudos,S.uniqueSort=S.unique=d.uniqueSort,S.text=d.getText,S.isXMLDoc=d.isXML,S.contains=d.contains,S.escapeSelector=d.escape;var h=function(e,t,n){var r=[],i=void 0!==n;while((e=e[t])&&9!==e.nodeType)if(1===e.nodeType){if(i&&S(e).is(n))break;r.push(e)}return r},T=function(e,t){for(var n=[];e;e=e.nextSibling)1===e.nodeType&&e!==t&&n.push(e);return n},k=S.expr.match.needsContext;function A(e,t){return e.nodeName&&e.nodeName.toLowerCase()===t.toLowerCase()}var N=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i;function j(e,n,r){return m(n)?S.grep(e,function(e,t){return!!n.call(e,t,e)!==r}):n.nodeType?S.grep(e,function(e){return e===n!==r}):"string"!=typeof n?S.grep(e,function(e){return-1<i.call(n,e)!==r}):S.filter(n,e,r)}S.filter=function(e,t,n){var r=t[0];return n&&(e=":not("+e+")"),1===t.length&&1===r.nodeType?S.find.matchesSelector(r,e)?[r]:[]:S.find.matches(e,S.grep(t,function(e){return 1===e.nodeType}))},S.fn.extend({find:function(e){var t,n,r=this.length,i=this;if("string"!=typeof e)return this.pushStack(S(e).filter(function(){for(t=0;t<r;t++)if(S.contains(i[t],this))return!0}));for(n=this.pushStack([]),t=0;t<r;t++)S.find(e,i[t],n);return 1<r?S.uniqueSort(n):n},filter:function(e){return this.pushStack(j(this,e||[],!1))},not:function(e){return this.pushStack(j(this,e||[],!0))},is:function(e){return!!j(this,"string"==typeof e&&k.test(e)?S(e):e||[],!1).length}});var D,q=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/;(S.fn.init=function(e,t,n){var r,i;if(!e)return this;if(n=n||D,"string"==typeof e){if(!(r="<"===e[0]&&">"===e[e.length-1]&&3<=e.length?[null,e,null]:q.exec(e))||!r[1]&&t)return!t||t.jquery?(t||n).find(e):this.constructor(t).find(e);if(r[1]){if(t=t instanceof S?t[0]:t,S.merge(this,S.parseHTML(r[1],t&&t.nodeType?t.ownerDocument||t:E,!0)),N.test(r[1])&&S.isPlainObject(t))for(r in t)m(this[r])?this[r](t[r]):this.attr(r,t[r]);return this}return(i=E.getElementById(r[2]))&&(this[0]=i,this.length=1),this}return e.nodeType?(this[0]=e,this.length=1,this):m(e)?void 0!==n.ready?n.ready(e):e(S):S.makeArray(e,this)}).prototype=S.fn,D=S(E);var L=/^(?:parents|prev(?:Until|All))/,H={children:!0,contents:!0,next:!0,prev:!0};function O(e,t){while((e=e[t])&&1!==e.nodeType);return e}S.fn.extend({has:function(e){var t=S(e,this),n=t.length;return this.filter(function(){for(var e=0;e<n;e++)if(S.contains(this,t[e]))return!0})},closest:function(e,t){var n,r=0,i=this.length,o=[],a="string"!=typeof e&&S(e);if(!k.test(e))for(;r<i;r++)for(n=this[r];n&&n!==t;n=n.parentNode)if(n.nodeType<11&&(a?-1<a.index(n):1===n.nodeType&&S.find.matchesSelector(n,e))){o.push(n);break}return this.pushStack(1<o.length?S.uniqueSort(o):o)},index:function(e){return e?"string"==typeof e?i.call(S(e),this[0]):i.call(this,e.jquery?e[0]:e):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(e,t){return this.pushStack(S.uniqueSort(S.merge(this.get(),S(e,t))))},addBack:function(e){return this.add(null==e?this.prevObject:this.prevObject.filter(e))}}),S.each({parent:function(e){var t=e.parentNode;return t&&11!==t.nodeType?t:null},parents:function(e){return h(e,"parentNode")},parentsUntil:function(e,t,n){return h(e,"parentNode",n)},next:function(e){return O(e,"nextSibling")},prev:function(e){return O(e,"previousSibling")},nextAll:function(e){return h(e,"nextSibling")},prevAll:function(e){return h(e,"previousSibling")},nextUntil:function(e,t,n){return h(e,"nextSibling",n)},prevUntil:function(e,t,n){return h(e,"previousSibling",n)},siblings:function(e){return T((e.parentNode||{}).firstChild,e)},children:function(e){return T(e.firstChild)},contents:function(e){return null!=e.contentDocument&&r(e.contentDocument)?e.contentDocument:(A(e,"template")&&(e=e.content||e),S.merge([],e.childNodes))}},function(r,i){S.fn[r]=function(e,t){var n=S.map(this,i,e);return"Until"!==r.slice(-5)&&(t=e),t&&"string"==typeof t&&(n=S.filter(t,n)),1<this.length&&(H[r]||S.uniqueSort(n),L.test(r)&&n.reverse()),this.pushStack(n)}});var P=/[^\x20\t\r\n\f]+/g;function R(e){return e}function M(e){throw e}function I(e,t,n,r){var i;try{e&&m(i=e.promise)?i.call(e).done(t).fail(n):e&&m(i=e.then)?i.call(e,t,n):t.apply(void 0,[e].slice(r))}catch(e){n.apply(void 0,[e])}}S.Callbacks=function(r){var e,n;r="string"==typeof r?(e=r,n={},S.each(e.match(P)||[],function(e,t){n[t]=!0}),n):S.extend({},r);var i,t,o,a,s=[],u=[],l=-1,c=function(){for(a=a||r.once,o=i=!0;u.length;l=-1){t=u.shift();while(++l<s.length)!1===s[l].apply(t[0],t[1])&&r.stopOnFalse&&(l=s.length,t=!1)}r.memory||(t=!1),i=!1,a&&(s=t?[]:"")},f={add:function(){return s&&(t&&!i&&(l=s.length-1,u.push(t)),function n(e){S.each(e,function(e,t){m(t)?r.unique&&f.has(t)||s.push(t):t&&t.length&&"string"!==w(t)&&n(t)})}(arguments),t&&!i&&c()),this},remove:function(){return S.each(arguments,function(e,t){var n;while(-1<(n=S.inArray(t,s,n)))s.splice(n,1),n<=l&&l--}),this},has:function(e){return e?-1<S.inArray(e,s):0<s.length},empty:function(){return s&&(s=[]),this},disable:function(){return a=u=[],s=t="",this},disabled:function(){return!s},lock:function(){return a=u=[],t||i||(s=t=""),this},locked:function(){return!!a},fireWith:function(e,t){return a||(t=[e,(t=t||[]).slice?t.slice():t],u.push(t),i||c()),this},fire:function(){return f.fireWith(this,arguments),this},fired:function(){return!!o}};return f},S.extend({Deferred:function(e){var o=[["notify","progress",S.Callbacks("memory"),S.Callbacks("memory"),2],["resolve","done",S.Callbacks("once memory"),S.Callbacks("once memory"),0,"resolved"],["reject","fail",S.Callbacks("once memory"),S.Callbacks("once memory"),1,"rejected"]],i="pending",a={state:function(){return i},always:function(){return s.done(arguments).fail(arguments),this},"catch":function(e){return a.then(null,e)},pipe:function(){var i=arguments;return S.Deferred(function(r){S.each(o,function(e,t){var n=m(i[t[4]])&&i[t[4]];s[t[1]](function(){var e=n&&n.apply(this,arguments);e&&m(e.promise)?e.promise().progress(r.notify).done(r.resolve).fail(r.reject):r[t[0]+"With"](this,n?[e]:arguments)})}),i=null}).promise()},then:function(t,n,r){var u=0;function l(i,o,a,s){return function(){var n=this,r=arguments,e=function(){var e,t;if(!(i<u)){if((e=a.apply(n,r))===o.promise())throw new TypeError("Thenable self-resolution");t=e&&("object"==typeof e||"function"==typeof e)&&e.then,m(t)?s?t.call(e,l(u,o,R,s),l(u,o,M,s)):(u++,t.call(e,l(u,o,R,s),l(u,o,M,s),l(u,o,R,o.notifyWith))):(a!==R&&(n=void 0,r=[e]),(s||o.resolveWith)(n,r))}},t=s?e:function(){try{e()}catch(e){S.Deferred.exceptionHook&&S.Deferred.exceptionHook(e,t.stackTrace),u<=i+1&&(a!==M&&(n=void 0,r=[e]),o.rejectWith(n,r))}};i?t():(S.Deferred.getStackHook&&(t.stackTrace=S.Deferred.getStackHook()),C.setTimeout(t))}}return S.Deferred(function(e){o[0][3].add(l(0,e,m(r)?r:R,e.notifyWith)),o[1][3].add(l(0,e,m(t)?t:R)),o[2][3].add(l(0,e,m(n)?n:M))}).promise()},promise:function(e){return null!=e?S.extend(e,a):a}},s={};return S.each(o,function(e,t){var n=t[2],r=t[5];a[t[1]]=n.add,r&&n.add(function(){i=r},o[3-e][2].disable,o[3-e][3].disable,o[0][2].lock,o[0][3].lock),n.add(t[3].fire),s[t[0]]=function(){return s[t[0]+"With"](this===s?void 0:this,arguments),this},s[t[0]+"With"]=n.fireWith}),a.promise(s),e&&e.call(s,s),s},when:function(e){var n=arguments.length,t=n,r=Array(t),i=s.call(arguments),o=S.Deferred(),a=function(t){return function(e){r[t]=this,i[t]=1<arguments.length?s.call(arguments):e,--n||o.resolveWith(r,i)}};if(n<=1&&(I(e,o.done(a(t)).resolve,o.reject,!n),"pending"===o.state()||m(i[t]&&i[t].then)))return o.then();while(t--)I(i[t],a(t),o.reject);return o.promise()}});var W=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;S.Deferred.exceptionHook=function(e,t){C.console&&C.console.warn&&e&&W.test(e.name)&&C.console.warn("jQuery.Deferred exception: "+e.message,e.stack,t)},S.readyException=function(e){C.setTimeout(function(){throw e})};var F=S.Deferred();function B(){E.removeEventListener("DOMContentLoaded",B),C.removeEventListener("load",B),S.ready()}S.fn.ready=function(e){return F.then(e)["catch"](function(e){S.readyException(e)}),this},S.extend({isReady:!1,readyWait:1,ready:function(e){(!0===e?--S.readyWait:S.isReady)||(S.isReady=!0)!==e&&0<--S.readyWait||F.resolveWith(E,[S])}}),S.ready.then=F.then,"complete"===E.readyState||"loading"!==E.readyState&&!E.documentElement.doScroll?C.setTimeout(S.ready):(E.addEventListener("DOMContentLoaded",B),C.addEventListener("load",B));var $=function(e,t,n,r,i,o,a){var s=0,u=e.length,l=null==n;if("object"===w(n))for(s in i=!0,n)$(e,t,s,n[s],!0,o,a);else if(void 0!==r&&(i=!0,m(r)||(a=!0),l&&(a?(t.call(e,r),t=null):(l=t,t=function(e,t,n){return l.call(S(e),n)})),t))for(;s<u;s++)t(e[s],n,a?r:r.call(e[s],s,t(e[s],n)));return i?e:l?t.call(e):u?t(e[0],n):o},_=/^-ms-/,z=/-([a-z])/g;function U(e,t){return t.toUpperCase()}function X(e){return e.replace(_,"ms-").replace(z,U)}var V=function(e){return 1===e.nodeType||9===e.nodeType||!+e.nodeType};function G(){this.expando=S.expando+G.uid++}G.uid=1,G.prototype={cache:function(e){var t=e[this.expando];return t||(t={},V(e)&&(e.nodeType?e[this.expando]=t:Object.defineProperty(e,this.expando,{value:t,configurable:!0}))),t},set:function(e,t,n){var r,i=this.cache(e);if("string"==typeof t)i[X(t)]=n;else for(r in t)i[X(r)]=t[r];return i},get:function(e,t){return void 0===t?this.cache(e):e[this.expando]&&e[this.expando][X(t)]},access:function(e,t,n){return void 0===t||t&&"string"==typeof t&&void 0===n?this.get(e,t):(this.set(e,t,n),void 0!==n?n:t)},remove:function(e,t){var n,r=e[this.expando];if(void 0!==r){if(void 0!==t){n=(t=Array.isArray(t)?t.map(X):(t=X(t))in r?[t]:t.match(P)||[]).length;while(n--)delete r[t[n]]}(void 0===t||S.isEmptyObject(r))&&(e.nodeType?e[this.expando]=void 0:delete e[this.expando])}},hasData:function(e){var t=e[this.expando];return void 0!==t&&!S.isEmptyObject(t)}};var Y=new G,Q=new G,J=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,K=/[A-Z]/g;function Z(e,t,n){var r,i;if(void 0===n&&1===e.nodeType)if(r="data-"+t.replace(K,"-$&").toLowerCase(),"string"==typeof(n=e.getAttribute(r))){try{n="true"===(i=n)||"false"!==i&&("null"===i?null:i===+i+""?+i:J.test(i)?JSON.parse(i):i)}catch(e){}Q.set(e,t,n)}else n=void 0;return n}S.extend({hasData:function(e){return Q.hasData(e)||Y.hasData(e)},data:function(e,t,n){return Q.access(e,t,n)},removeData:function(e,t){Q.remove(e,t)},_data:function(e,t,n){return Y.access(e,t,n)},_removeData:function(e,t){Y.remove(e,t)}}),S.fn.extend({data:function(n,e){var t,r,i,o=this[0],a=o&&o.attributes;if(void 0===n){if(this.length&&(i=Q.get(o),1===o.nodeType&&!Y.get(o,"hasDataAttrs"))){t=a.length;while(t--)a[t]&&0===(r=a[t].name).indexOf("data-")&&(r=X(r.slice(5)),Z(o,r,i[r]));Y.set(o,"hasDataAttrs",!0)}return i}return"object"==typeof n?this.each(function(){Q.set(this,n)}):$(this,function(e){var t;if(o&&void 0===e)return void 0!==(t=Q.get(o,n))?t:void 0!==(t=Z(o,n))?t:void 0;this.each(function(){Q.set(this,n,e)})},null,e,1<arguments.length,null,!0)},removeData:function(e){return this.each(function(){Q.remove(this,e)})}}),S.extend({queue:function(e,t,n){var r;if(e)return t=(t||"fx")+"queue",r=Y.get(e,t),n&&(!r||Array.isArray(n)?r=Y.access(e,t,S.makeArray(n)):r.push(n)),r||[]},dequeue:function(e,t){t=t||"fx";var n=S.queue(e,t),r=n.length,i=n.shift(),o=S._queueHooks(e,t);"inprogress"===i&&(i=n.shift(),r--),i&&("fx"===t&&n.unshift("inprogress"),delete o.stop,i.call(e,function(){S.dequeue(e,t)},o)),!r&&o&&o.empty.fire()},_queueHooks:function(e,t){var n=t+"queueHooks";return Y.get(e,n)||Y.access(e,n,{empty:S.Callbacks("once memory").add(function(){Y.remove(e,[t+"queue",n])})})}}),S.fn.extend({queue:function(t,n){var e=2;return"string"!=typeof t&&(n=t,t="fx",e--),arguments.length<e?S.queue(this[0],t):void 0===n?this:this.each(function(){var e=S.queue(this,t,n);S._queueHooks(this,t),"fx"===t&&"inprogress"!==e[0]&&S.dequeue(this,t)})},dequeue:function(e){return this.each(function(){S.dequeue(this,e)})},clearQueue:function(e){return this.queue(e||"fx",[])},promise:function(e,t){var n,r=1,i=S.Deferred(),o=this,a=this.length,s=function(){--r||i.resolveWith(o,[o])};"string"!=typeof e&&(t=e,e=void 0),e=e||"fx";while(a--)(n=Y.get(o[a],e+"queueHooks"))&&n.empty&&(r++,n.empty.add(s));return s(),i.promise(t)}});var ee=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,te=new RegExp("^(?:([+-])=|)("+ee+")([a-z%]*)$","i"),ne=["Top","Right","Bottom","Left"],re=E.documentElement,ie=function(e){return S.contains(e.ownerDocument,e)},oe={composed:!0};re.getRootNode&&(ie=function(e){return S.contains(e.ownerDocument,e)||e.getRootNode(oe)===e.ownerDocument});var ae=function(e,t){return"none"===(e=t||e).style.display||""===e.style.display&&ie(e)&&"none"===S.css(e,"display")};function se(e,t,n,r){var i,o,a=20,s=r?function(){return r.cur()}:function(){return S.css(e,t,"")},u=s(),l=n&&n[3]||(S.cssNumber[t]?"":"px"),c=e.nodeType&&(S.cssNumber[t]||"px"!==l&&+u)&&te.exec(S.css(e,t));if(c&&c[3]!==l){u/=2,l=l||c[3],c=+u||1;while(a--)S.style(e,t,c+l),(1-o)*(1-(o=s()/u||.5))<=0&&(a=0),c/=o;c*=2,S.style(e,t,c+l),n=n||[]}return n&&(c=+c||+u||0,i=n[1]?c+(n[1]+1)*n[2]:+n[2],r&&(r.unit=l,r.start=c,r.end=i)),i}var ue={};function le(e,t){for(var n,r,i,o,a,s,u,l=[],c=0,f=e.length;c<f;c++)(r=e[c]).style&&(n=r.style.display,t?("none"===n&&(l[c]=Y.get(r,"display")||null,l[c]||(r.style.display="")),""===r.style.display&&ae(r)&&(l[c]=(u=a=o=void 0,a=(i=r).ownerDocument,s=i.nodeName,(u=ue[s])||(o=a.body.appendChild(a.createElement(s)),u=S.css(o,"display"),o.parentNode.removeChild(o),"none"===u&&(u="block"),ue[s]=u)))):"none"!==n&&(l[c]="none",Y.set(r,"display",n)));for(c=0;c<f;c++)null!=l[c]&&(e[c].style.display=l[c]);return e}S.fn.extend({show:function(){return le(this,!0)},hide:function(){return le(this)},toggle:function(e){return"boolean"==typeof e?e?this.show():this.hide():this.each(function(){ae(this)?S(this).show():S(this).hide()})}});var ce,fe,pe=/^(?:checkbox|radio)$/i,de=/<([a-z][^\/\0>\x20\t\r\n\f]*)/i,he=/^$|^module$|\/(?:java|ecma)script/i;ce=E.createDocumentFragment().appendChild(E.createElement("div")),(fe=E.createElement("input")).setAttribute("type","radio"),fe.setAttribute("checked","checked"),fe.setAttribute("name","t"),ce.appendChild(fe),y.checkClone=ce.cloneNode(!0).cloneNode(!0).lastChild.checked,ce.innerHTML="<textarea>x</textarea>",y.noCloneChecked=!!ce.cloneNode(!0).lastChild.defaultValue,ce.innerHTML="<option></option>",y.option=!!ce.lastChild;var ge={thead:[1,"<table>","</table>"],col:[2,"<table><colgroup>","</colgroup></table>"],tr:[2,"<table><tbody>","</tbody></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:[0,"",""]};function ve(e,t){var n;return n="undefined"!=typeof e.getElementsByTagName?e.getElementsByTagName(t||"*"):"undefined"!=typeof e.querySelectorAll?e.querySelectorAll(t||"*"):[],void 0===t||t&&A(e,t)?S.merge([e],n):n}function ye(e,t){for(var n=0,r=e.length;n<r;n++)Y.set(e[n],"globalEval",!t||Y.get(t[n],"globalEval"))}ge.tbody=ge.tfoot=ge.colgroup=ge.caption=ge.thead,ge.th=ge.td,y.option||(ge.optgroup=ge.option=[1,"<select multiple='multiple'>","</select>"]);var me=/<|&#?\w+;/;function xe(e,t,n,r,i){for(var o,a,s,u,l,c,f=t.createDocumentFragment(),p=[],d=0,h=e.length;d<h;d++)if((o=e[d])||0===o)if("object"===w(o))S.merge(p,o.nodeType?[o]:o);else if(me.test(o)){a=a||f.appendChild(t.createElement("div")),s=(de.exec(o)||["",""])[1].toLowerCase(),u=ge[s]||ge._default,a.innerHTML=u[1]+S.htmlPrefilter(o)+u[2],c=u[0];while(c--)a=a.lastChild;S.merge(p,a.childNodes),(a=f.firstChild).textContent=""}else p.push(t.createTextNode(o));f.textContent="",d=0;while(o=p[d++])if(r&&-1<S.inArray(o,r))i&&i.push(o);else if(l=ie(o),a=ve(f.appendChild(o),"script"),l&&ye(a),n){c=0;while(o=a[c++])he.test(o.type||"")&&n.push(o)}return f}var be=/^([^.]*)(?:\.(.+)|)/;function we(){return!0}function Te(){return!1}function Ce(e,t){return e===function(){try{return E.activeElement}catch(e){}}()==("focus"===t)}function Ee(e,t,n,r,i,o){var a,s;if("object"==typeof t){for(s in"string"!=typeof n&&(r=r||n,n=void 0),t)Ee(e,s,n,r,t[s],o);return e}if(null==r&&null==i?(i=n,r=n=void 0):null==i&&("string"==typeof n?(i=r,r=void 0):(i=r,r=n,n=void 0)),!1===i)i=Te;else if(!i)return e;return 1===o&&(a=i,(i=function(e){return S().off(e),a.apply(this,arguments)}).guid=a.guid||(a.guid=S.guid++)),e.each(function(){S.event.add(this,t,i,r,n)})}function Se(e,i,o){o?(Y.set(e,i,!1),S.event.add(e,i,{namespace:!1,handler:function(e){var t,n,r=Y.get(this,i);if(1&e.isTrigger&&this[i]){if(r.length)(S.event.special[i]||{}).delegateType&&e.stopPropagation();else if(r=s.call(arguments),Y.set(this,i,r),t=o(this,i),this[i](),r!==(n=Y.get(this,i))||t?Y.set(this,i,!1):n={},r!==n)return e.stopImmediatePropagation(),e.preventDefault(),n&&n.value}else r.length&&(Y.set(this,i,{value:S.event.trigger(S.extend(r[0],S.Event.prototype),r.slice(1),this)}),e.stopImmediatePropagation())}})):void 0===Y.get(e,i)&&S.event.add(e,i,we)}S.event={global:{},add:function(t,e,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.get(t);if(V(t)){n.handler&&(n=(o=n).handler,i=o.selector),i&&S.find.matchesSelector(re,i),n.guid||(n.guid=S.guid++),(u=v.events)||(u=v.events=Object.create(null)),(a=v.handle)||(a=v.handle=function(e){return"undefined"!=typeof S&&S.event.triggered!==e.type?S.event.dispatch.apply(t,arguments):void 0}),l=(e=(e||"").match(P)||[""]).length;while(l--)d=g=(s=be.exec(e[l])||[])[1],h=(s[2]||"").split(".").sort(),d&&(f=S.event.special[d]||{},d=(i?f.delegateType:f.bindType)||d,f=S.event.special[d]||{},c=S.extend({type:d,origType:g,data:r,handler:n,guid:n.guid,selector:i,needsContext:i&&S.expr.match.needsContext.test(i),namespace:h.join(".")},o),(p=u[d])||((p=u[d]=[]).delegateCount=0,f.setup&&!1!==f.setup.call(t,r,h,a)||t.addEventListener&&t.addEventListener(d,a)),f.add&&(f.add.call(t,c),c.handler.guid||(c.handler.guid=n.guid)),i?p.splice(p.delegateCount++,0,c):p.push(c),S.event.global[d]=!0)}},remove:function(e,t,n,r,i){var o,a,s,u,l,c,f,p,d,h,g,v=Y.hasData(e)&&Y.get(e);if(v&&(u=v.events)){l=(t=(t||"").match(P)||[""]).length;while(l--)if(d=g=(s=be.exec(t[l])||[])[1],h=(s[2]||"").split(".").sort(),d){f=S.event.special[d]||{},p=u[d=(r?f.delegateType:f.bindType)||d]||[],s=s[2]&&new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"),a=o=p.length;while(o--)c=p[o],!i&&g!==c.origType||n&&n.guid!==c.guid||s&&!s.test(c.namespace)||r&&r!==c.selector&&("**"!==r||!c.selector)||(p.splice(o,1),c.selector&&p.delegateCount--,f.remove&&f.remove.call(e,c));a&&!p.length&&(f.teardown&&!1!==f.teardown.call(e,h,v.handle)||S.removeEvent(e,d,v.handle),delete u[d])}else for(d in u)S.event.remove(e,d+t[l],n,r,!0);S.isEmptyObject(u)&&Y.remove(e,"handle events")}},dispatch:function(e){var t,n,r,i,o,a,s=new Array(arguments.length),u=S.event.fix(e),l=(Y.get(this,"events")||Object.create(null))[u.type]||[],c=S.event.special[u.type]||{};for(s[0]=u,t=1;t<arguments.length;t++)s[t]=arguments[t];if(u.delegateTarget=this,!c.preDispatch||!1!==c.preDispatch.call(this,u)){a=S.event.handlers.call(this,u,l),t=0;while((i=a[t++])&&!u.isPropagationStopped()){u.currentTarget=i.elem,n=0;while((o=i.handlers[n++])&&!u.isImmediatePropagationStopped())u.rnamespace&&!1!==o.namespace&&!u.rnamespace.test(o.namespace)||(u.handleObj=o,u.data=o.data,void 0!==(r=((S.event.special[o.origType]||{}).handle||o.handler).apply(i.elem,s))&&!1===(u.result=r)&&(u.preventDefault(),u.stopPropagation()))}return c.postDispatch&&c.postDispatch.call(this,u),u.result}},handlers:function(e,t){var n,r,i,o,a,s=[],u=t.delegateCount,l=e.target;if(u&&l.nodeType&&!("click"===e.type&&1<=e.button))for(;l!==this;l=l.parentNode||this)if(1===l.nodeType&&("click"!==e.type||!0!==l.disabled)){for(o=[],a={},n=0;n<u;n++)void 0===a[i=(r=t[n]).selector+" "]&&(a[i]=r.needsContext?-1<S(i,this).index(l):S.find(i,this,null,[l]).length),a[i]&&o.push(r);o.length&&s.push({elem:l,handlers:o})}return l=this,u<t.length&&s.push({elem:l,handlers:t.slice(u)}),s},addProp:function(t,e){Object.defineProperty(S.Event.prototype,t,{enumerable:!0,configurable:!0,get:m(e)?function(){if(this.originalEvent)return e(this.originalEvent)}:function(){if(this.originalEvent)return this.originalEvent[t]},set:function(e){Object.defineProperty(this,t,{enumerable:!0,configurable:!0,writable:!0,value:e})}})},fix:function(e){return e[S.expando]?e:new S.Event(e)},special:{load:{noBubble:!0},click:{setup:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click",we),!1},trigger:function(e){var t=this||e;return pe.test(t.type)&&t.click&&A(t,"input")&&Se(t,"click"),!0},_default:function(e){var t=e.target;return pe.test(t.type)&&t.click&&A(t,"input")&&Y.get(t,"click")||A(t,"a")}},beforeunload:{postDispatch:function(e){void 0!==e.result&&e.originalEvent&&(e.originalEvent.returnValue=e.result)}}}},S.removeEvent=function(e,t,n){e.removeEventListener&&e.removeEventListener(t,n)},S.Event=function(e,t){if(!(this instanceof S.Event))return new S.Event(e,t);e&&e.type?(this.originalEvent=e,this.type=e.type,this.isDefaultPrevented=e.defaultPrevented||void 0===e.defaultPrevented&&!1===e.returnValue?we:Te,this.target=e.target&&3===e.target.nodeType?e.target.parentNode:e.target,this.currentTarget=e.currentTarget,this.relatedTarget=e.relatedTarget):this.type=e,t&&S.extend(this,t),this.timeStamp=e&&e.timeStamp||Date.now(),this[S.expando]=!0},S.Event.prototype={constructor:S.Event,isDefaultPrevented:Te,isPropagationStopped:Te,isImmediatePropagationStopped:Te,isSimulated:!1,preventDefault:function(){var e=this.originalEvent;this.isDefaultPrevented=we,e&&!this.isSimulated&&e.preventDefault()},stopPropagation:function(){var e=this.originalEvent;this.isPropagationStopped=we,e&&!this.isSimulated&&e.stopPropagation()},stopImmediatePropagation:function(){var e=this.originalEvent;this.isImmediatePropagationStopped=we,e&&!this.isSimulated&&e.stopImmediatePropagation(),this.stopPropagation()}},S.each({altKey:!0,bubbles:!0,cancelable:!0,changedTouches:!0,ctrlKey:!0,detail:!0,eventPhase:!0,metaKey:!0,pageX:!0,pageY:!0,shiftKey:!0,view:!0,"char":!0,code:!0,charCode:!0,key:!0,keyCode:!0,button:!0,buttons:!0,clientX:!0,clientY:!0,offsetX:!0,offsetY:!0,pointerId:!0,pointerType:!0,screenX:!0,screenY:!0,targetTouches:!0,toElement:!0,touches:!0,which:!0},S.event.addProp),S.each({focus:"focusin",blur:"focusout"},function(e,t){S.event.special[e]={setup:function(){return Se(this,e,Ce),!1},trigger:function(){return Se(this,e),!0},_default:function(){return!0},delegateType:t}}),S.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(e,i){S.event.special[e]={delegateType:i,bindType:i,handle:function(e){var t,n=e.relatedTarget,r=e.handleObj;return n&&(n===this||S.contains(this,n))||(e.type=r.origType,t=r.handler.apply(this,arguments),e.type=i),t}}}),S.fn.extend({on:function(e,t,n,r){return Ee(this,e,t,n,r)},one:function(e,t,n,r){return Ee(this,e,t,n,r,1)},off:function(e,t,n){var r,i;if(e&&e.preventDefault&&e.handleObj)return r=e.handleObj,S(e.delegateTarget).off(r.namespace?r.origType+"."+r.namespace:r.origType,r.selector,r.handler),this;if("object"==typeof e){for(i in e)this.off(i,t,e[i]);return this}return!1!==t&&"function"!=typeof t||(n=t,t=void 0),!1===n&&(n=Te),this.each(function(){S.event.remove(this,e,n,t)})}});var ke=/<script|<style|<link/i,Ae=/checked\s*(?:[^=]|=\s*.checked.)/i,Ne=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;function je(e,t){return A(e,"table")&&A(11!==t.nodeType?t:t.firstChild,"tr")&&S(e).children("tbody")[0]||e}function De(e){return e.type=(null!==e.getAttribute("type"))+"/"+e.type,e}function qe(e){return"true/"===(e.type||"").slice(0,5)?e.type=e.type.slice(5):e.removeAttribute("type"),e}function Le(e,t){var n,r,i,o,a,s;if(1===t.nodeType){if(Y.hasData(e)&&(s=Y.get(e).events))for(i in Y.remove(t,"handle events"),s)for(n=0,r=s[i].length;n<r;n++)S.event.add(t,i,s[i][n]);Q.hasData(e)&&(o=Q.access(e),a=S.extend({},o),Q.set(t,a))}}function He(n,r,i,o){r=g(r);var e,t,a,s,u,l,c=0,f=n.length,p=f-1,d=r[0],h=m(d);if(h||1<f&&"string"==typeof d&&!y.checkClone&&Ae.test(d))return n.each(function(e){var t=n.eq(e);h&&(r[0]=d.call(this,e,t.html())),He(t,r,i,o)});if(f&&(t=(e=xe(r,n[0].ownerDocument,!1,n,o)).firstChild,1===e.childNodes.length&&(e=t),t||o)){for(s=(a=S.map(ve(e,"script"),De)).length;c<f;c++)u=e,c!==p&&(u=S.clone(u,!0,!0),s&&S.merge(a,ve(u,"script"))),i.call(n[c],u,c);if(s)for(l=a[a.length-1].ownerDocument,S.map(a,qe),c=0;c<s;c++)u=a[c],he.test(u.type||"")&&!Y.access(u,"globalEval")&&S.contains(l,u)&&(u.src&&"module"!==(u.type||"").toLowerCase()?S._evalUrl&&!u.noModule&&S._evalUrl(u.src,{nonce:u.nonce||u.getAttribute("nonce")},l):b(u.textContent.replace(Ne,""),u,l))}return n}function Oe(e,t,n){for(var r,i=t?S.filter(t,e):e,o=0;null!=(r=i[o]);o++)n||1!==r.nodeType||S.cleanData(ve(r)),r.parentNode&&(n&&ie(r)&&ye(ve(r,"script")),r.parentNode.removeChild(r));return e}S.extend({htmlPrefilter:function(e){return e},clone:function(e,t,n){var r,i,o,a,s,u,l,c=e.cloneNode(!0),f=ie(e);if(!(y.noCloneChecked||1!==e.nodeType&&11!==e.nodeType||S.isXMLDoc(e)))for(a=ve(c),r=0,i=(o=ve(e)).length;r<i;r++)s=o[r],u=a[r],void 0,"input"===(l=u.nodeName.toLowerCase())&&pe.test(s.type)?u.checked=s.checked:"input"!==l&&"textarea"!==l||(u.defaultValue=s.defaultValue);if(t)if(n)for(o=o||ve(e),a=a||ve(c),r=0,i=o.length;r<i;r++)Le(o[r],a[r]);else Le(e,c);return 0<(a=ve(c,"script")).length&&ye(a,!f&&ve(e,"script")),c},cleanData:function(e){for(var t,n,r,i=S.event.special,o=0;void 0!==(n=e[o]);o++)if(V(n)){if(t=n[Y.expando]){if(t.events)for(r in t.events)i[r]?S.event.remove(n,r):S.removeEvent(n,r,t.handle);n[Y.expando]=void 0}n[Q.expando]&&(n[Q.expando]=void 0)}}}),S.fn.extend({detach:function(e){return Oe(this,e,!0)},remove:function(e){return Oe(this,e)},text:function(e){return $(this,function(e){return void 0===e?S.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=e)})},null,e,arguments.length)},append:function(){return He(this,arguments,function(e){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||je(this,e).appendChild(e)})},prepend:function(){return He(this,arguments,function(e){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var t=je(this,e);t.insertBefore(e,t.firstChild)}})},before:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this)})},after:function(){return He(this,arguments,function(e){this.parentNode&&this.parentNode.insertBefore(e,this.nextSibling)})},empty:function(){for(var e,t=0;null!=(e=this[t]);t++)1===e.nodeType&&(S.cleanData(ve(e,!1)),e.textContent="");return this},clone:function(e,t){return e=null!=e&&e,t=null==t?e:t,this.map(function(){return S.clone(this,e,t)})},html:function(e){return $(this,function(e){var t=this[0]||{},n=0,r=this.length;if(void 0===e&&1===t.nodeType)return t.innerHTML;if("string"==typeof e&&!ke.test(e)&&!ge[(de.exec(e)||["",""])[1].toLowerCase()]){e=S.htmlPrefilter(e);try{for(;n<r;n++)1===(t=this[n]||{}).nodeType&&(S.cleanData(ve(t,!1)),t.innerHTML=e);t=0}catch(e){}}t&&this.empty().append(e)},null,e,arguments.length)},replaceWith:function(){var n=[];return He(this,arguments,function(e){var t=this.parentNode;S.inArray(this,n)<0&&(S.cleanData(ve(this)),t&&t.replaceChild(e,this))},n)}}),S.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(e,a){S.fn[e]=function(e){for(var t,n=[],r=S(e),i=r.length-1,o=0;o<=i;o++)t=o===i?this:this.clone(!0),S(r[o])[a](t),u.apply(n,t.get());return this.pushStack(n)}});var Pe=new RegExp("^("+ee+")(?!px)[a-z%]+$","i"),Re=function(e){var t=e.ownerDocument.defaultView;return t&&t.opener||(t=C),t.getComputedStyle(e)},Me=function(e,t,n){var r,i,o={};for(i in t)o[i]=e.style[i],e.style[i]=t[i];for(i in r=n.call(e),t)e.style[i]=o[i];return r},Ie=new RegExp(ne.join("|"),"i");function We(e,t,n){var r,i,o,a,s=e.style;return(n=n||Re(e))&&(""!==(a=n.getPropertyValue(t)||n[t])||ie(e)||(a=S.style(e,t)),!y.pixelBoxStyles()&&Pe.test(a)&&Ie.test(t)&&(r=s.width,i=s.minWidth,o=s.maxWidth,s.minWidth=s.maxWidth=s.width=a,a=n.width,s.width=r,s.minWidth=i,s.maxWidth=o)),void 0!==a?a+"":a}function Fe(e,t){return{get:function(){if(!e())return(this.get=t).apply(this,arguments);delete this.get}}}!function(){function e(){if(l){u.style.cssText="position:absolute;left:-11111px;width:60px;margin-top:1px;padding:0;border:0",l.style.cssText="position:relative;display:block;box-sizing:border-box;overflow:scroll;margin:auto;border:1px;padding:1px;width:60%;top:1%",re.appendChild(u).appendChild(l);var e=C.getComputedStyle(l);n="1%"!==e.top,s=12===t(e.marginLeft),l.style.right="60%",o=36===t(e.right),r=36===t(e.width),l.style.position="absolute",i=12===t(l.offsetWidth/3),re.removeChild(u),l=null}}function t(e){return Math.round(parseFloat(e))}var n,r,i,o,a,s,u=E.createElement("div"),l=E.createElement("div");l.style&&(l.style.backgroundClip="content-box",l.cloneNode(!0).style.backgroundClip="",y.clearCloneStyle="content-box"===l.style.backgroundClip,S.extend(y,{boxSizingReliable:function(){return e(),r},pixelBoxStyles:function(){return e(),o},pixelPosition:function(){return e(),n},reliableMarginLeft:function(){return e(),s},scrollboxSize:function(){return e(),i},reliableTrDimensions:function(){var e,t,n,r;return null==a&&(e=E.createElement("table"),t=E.createElement("tr"),n=E.createElement("div"),e.style.cssText="position:absolute;left:-11111px;border-collapse:separate",t.style.cssText="border:1px solid",t.style.height="1px",n.style.height="9px",n.style.display="block",re.appendChild(e).appendChild(t).appendChild(n),r=C.getComputedStyle(t),a=parseInt(r.height,10)+parseInt(r.borderTopWidth,10)+parseInt(r.borderBottomWidth,10)===t.offsetHeight,re.removeChild(e)),a}}))}();var Be=["Webkit","Moz","ms"],$e=E.createElement("div").style,_e={};function ze(e){var t=S.cssProps[e]||_e[e];return t||(e in $e?e:_e[e]=function(e){var t=e[0].toUpperCase()+e.slice(1),n=Be.length;while(n--)if((e=Be[n]+t)in $e)return e}(e)||e)}var Ue=/^(none|table(?!-c[ea]).+)/,Xe=/^--/,Ve={position:"absolute",visibility:"hidden",display:"block"},Ge={letterSpacing:"0",fontWeight:"400"};function Ye(e,t,n){var r=te.exec(t);return r?Math.max(0,r[2]-(n||0))+(r[3]||"px"):t}function Qe(e,t,n,r,i,o){var a="width"===t?1:0,s=0,u=0;if(n===(r?"border":"content"))return 0;for(;a<4;a+=2)"margin"===n&&(u+=S.css(e,n+ne[a],!0,i)),r?("content"===n&&(u-=S.css(e,"padding"+ne[a],!0,i)),"margin"!==n&&(u-=S.css(e,"border"+ne[a]+"Width",!0,i))):(u+=S.css(e,"padding"+ne[a],!0,i),"padding"!==n?u+=S.css(e,"border"+ne[a]+"Width",!0,i):s+=S.css(e,"border"+ne[a]+"Width",!0,i));return!r&&0<=o&&(u+=Math.max(0,Math.ceil(e["offset"+t[0].toUpperCase()+t.slice(1)]-o-u-s-.5))||0),u}function Je(e,t,n){var r=Re(e),i=(!y.boxSizingReliable()||n)&&"border-box"===S.css(e,"boxSizing",!1,r),o=i,a=We(e,t,r),s="offset"+t[0].toUpperCase()+t.slice(1);if(Pe.test(a)){if(!n)return a;a="auto"}return(!y.boxSizingReliable()&&i||!y.reliableTrDimensions()&&A(e,"tr")||"auto"===a||!parseFloat(a)&&"inline"===S.css(e,"display",!1,r))&&e.getClientRects().length&&(i="border-box"===S.css(e,"boxSizing",!1,r),(o=s in e)&&(a=e[s])),(a=parseFloat(a)||0)+Qe(e,t,n||(i?"border":"content"),o,r,a)+"px"}function Ke(e,t,n,r,i){return new Ke.prototype.init(e,t,n,r,i)}S.extend({cssHooks:{opacity:{get:function(e,t){if(t){var n=We(e,"opacity");return""===n?"1":n}}}},cssNumber:{animationIterationCount:!0,columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,gridArea:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnStart:!0,gridRow:!0,gridRowEnd:!0,gridRowStart:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{},style:function(e,t,n,r){if(e&&3!==e.nodeType&&8!==e.nodeType&&e.style){var i,o,a,s=X(t),u=Xe.test(t),l=e.style;if(u||(t=ze(s)),a=S.cssHooks[t]||S.cssHooks[s],void 0===n)return a&&"get"in a&&void 0!==(i=a.get(e,!1,r))?i:l[t];"string"===(o=typeof n)&&(i=te.exec(n))&&i[1]&&(n=se(e,t,i),o="number"),null!=n&&n==n&&("number"!==o||u||(n+=i&&i[3]||(S.cssNumber[s]?"":"px")),y.clearCloneStyle||""!==n||0!==t.indexOf("background")||(l[t]="inherit"),a&&"set"in a&&void 0===(n=a.set(e,n,r))||(u?l.setProperty(t,n):l[t]=n))}},css:function(e,t,n,r){var i,o,a,s=X(t);return Xe.test(t)||(t=ze(s)),(a=S.cssHooks[t]||S.cssHooks[s])&&"get"in a&&(i=a.get(e,!0,n)),void 0===i&&(i=We(e,t,r)),"normal"===i&&t in Ge&&(i=Ge[t]),""===n||n?(o=parseFloat(i),!0===n||isFinite(o)?o||0:i):i}}),S.each(["height","width"],function(e,u){S.cssHooks[u]={get:function(e,t,n){if(t)return!Ue.test(S.css(e,"display"))||e.getClientRects().length&&e.getBoundingClientRect().width?Je(e,u,n):Me(e,Ve,function(){return Je(e,u,n)})},set:function(e,t,n){var r,i=Re(e),o=!y.scrollboxSize()&&"absolute"===i.position,a=(o||n)&&"border-box"===S.css(e,"boxSizing",!1,i),s=n?Qe(e,u,n,a,i):0;return a&&o&&(s-=Math.ceil(e["offset"+u[0].toUpperCase()+u.slice(1)]-parseFloat(i[u])-Qe(e,u,"border",!1,i)-.5)),s&&(r=te.exec(t))&&"px"!==(r[3]||"px")&&(e.style[u]=t,t=S.css(e,u)),Ye(0,t,s)}}}),S.cssHooks.marginLeft=Fe(y.reliableMarginLeft,function(e,t){if(t)return(parseFloat(We(e,"marginLeft"))||e.getBoundingClientRect().left-Me(e,{marginLeft:0},function(){return e.getBoundingClientRect().left}))+"px"}),S.each({margin:"",padding:"",border:"Width"},function(i,o){S.cssHooks[i+o]={expand:function(e){for(var t=0,n={},r="string"==typeof e?e.split(" "):[e];t<4;t++)n[i+ne[t]+o]=r[t]||r[t-2]||r[0];return n}},"margin"!==i&&(S.cssHooks[i+o].set=Ye)}),S.fn.extend({css:function(e,t){return $(this,function(e,t,n){var r,i,o={},a=0;if(Array.isArray(t)){for(r=Re(e),i=t.length;a<i;a++)o[t[a]]=S.css(e,t[a],!1,r);return o}return void 0!==n?S.style(e,t,n):S.css(e,t)},e,t,1<arguments.length)}}),((S.Tween=Ke).prototype={constructor:Ke,init:function(e,t,n,r,i,o){this.elem=e,this.prop=n,this.easing=i||S.easing._default,this.options=t,this.start=this.now=this.cur(),this.end=r,this.unit=o||(S.cssNumber[n]?"":"px")},cur:function(){var e=Ke.propHooks[this.prop];return e&&e.get?e.get(this):Ke.propHooks._default.get(this)},run:function(e){var t,n=Ke.propHooks[this.prop];return this.options.duration?this.pos=t=S.easing[this.easing](e,this.options.duration*e,0,1,this.options.duration):this.pos=t=e,this.now=(this.end-this.start)*t+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),n&&n.set?n.set(this):Ke.propHooks._default.set(this),this}}).init.prototype=Ke.prototype,(Ke.propHooks={_default:{get:function(e){var t;return 1!==e.elem.nodeType||null!=e.elem[e.prop]&&null==e.elem.style[e.prop]?e.elem[e.prop]:(t=S.css(e.elem,e.prop,""))&&"auto"!==t?t:0},set:function(e){S.fx.step[e.prop]?S.fx.step[e.prop](e):1!==e.elem.nodeType||!S.cssHooks[e.prop]&&null==e.elem.style[ze(e.prop)]?e.elem[e.prop]=e.now:S.style(e.elem,e.prop,e.now+e.unit)}}}).scrollTop=Ke.propHooks.scrollLeft={set:function(e){e.elem.nodeType&&e.elem.parentNode&&(e.elem[e.prop]=e.now)}},S.easing={linear:function(e){return e},swing:function(e){return.5-Math.cos(e*Math.PI)/2},_default:"swing"},S.fx=Ke.prototype.init,S.fx.step={};var Ze,et,tt,nt,rt=/^(?:toggle|show|hide)$/,it=/queueHooks$/;function ot(){et&&(!1===E.hidden&&C.requestAnimationFrame?C.requestAnimationFrame(ot):C.setTimeout(ot,S.fx.interval),S.fx.tick())}function at(){return C.setTimeout(function(){Ze=void 0}),Ze=Date.now()}function st(e,t){var n,r=0,i={height:e};for(t=t?1:0;r<4;r+=2-t)i["margin"+(n=ne[r])]=i["padding"+n]=e;return t&&(i.opacity=i.width=e),i}function ut(e,t,n){for(var r,i=(lt.tweeners[t]||[]).concat(lt.tweeners["*"]),o=0,a=i.length;o<a;o++)if(r=i[o].call(n,t,e))return r}function lt(o,e,t){var n,a,r=0,i=lt.prefilters.length,s=S.Deferred().always(function(){delete u.elem}),u=function(){if(a)return!1;for(var e=Ze||at(),t=Math.max(0,l.startTime+l.duration-e),n=1-(t/l.duration||0),r=0,i=l.tweens.length;r<i;r++)l.tweens[r].run(n);return s.notifyWith(o,[l,n,t]),n<1&&i?t:(i||s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l]),!1)},l=s.promise({elem:o,props:S.extend({},e),opts:S.extend(!0,{specialEasing:{},easing:S.easing._default},t),originalProperties:e,originalOptions:t,startTime:Ze||at(),duration:t.duration,tweens:[],createTween:function(e,t){var n=S.Tween(o,l.opts,e,t,l.opts.specialEasing[e]||l.opts.easing);return l.tweens.push(n),n},stop:function(e){var t=0,n=e?l.tweens.length:0;if(a)return this;for(a=!0;t<n;t++)l.tweens[t].run(1);return e?(s.notifyWith(o,[l,1,0]),s.resolveWith(o,[l,e])):s.rejectWith(o,[l,e]),this}}),c=l.props;for(!function(e,t){var n,r,i,o,a;for(n in e)if(i=t[r=X(n)],o=e[n],Array.isArray(o)&&(i=o[1],o=e[n]=o[0]),n!==r&&(e[r]=o,delete e[n]),(a=S.cssHooks[r])&&"expand"in a)for(n in o=a.expand(o),delete e[r],o)n in e||(e[n]=o[n],t[n]=i);else t[r]=i}(c,l.opts.specialEasing);r<i;r++)if(n=lt.prefilters[r].call(l,o,c,l.opts))return m(n.stop)&&(S._queueHooks(l.elem,l.opts.queue).stop=n.stop.bind(n)),n;return S.map(c,ut,l),m(l.opts.start)&&l.opts.start.call(o,l),l.progress(l.opts.progress).done(l.opts.done,l.opts.complete).fail(l.opts.fail).always(l.opts.always),S.fx.timer(S.extend(u,{elem:o,anim:l,queue:l.opts.queue})),l}S.Animation=S.extend(lt,{tweeners:{"*":[function(e,t){var n=this.createTween(e,t);return se(n.elem,e,te.exec(t),n),n}]},tweener:function(e,t){m(e)?(t=e,e=["*"]):e=e.match(P);for(var n,r=0,i=e.length;r<i;r++)n=e[r],lt.tweeners[n]=lt.tweeners[n]||[],lt.tweeners[n].unshift(t)},prefilters:[function(e,t,n){var r,i,o,a,s,u,l,c,f="width"in t||"height"in t,p=this,d={},h=e.style,g=e.nodeType&&ae(e),v=Y.get(e,"fxshow");for(r in n.queue||(null==(a=S._queueHooks(e,"fx")).unqueued&&(a.unqueued=0,s=a.empty.fire,a.empty.fire=function(){a.unqueued||s()}),a.unqueued++,p.always(function(){p.always(function(){a.unqueued--,S.queue(e,"fx").length||a.empty.fire()})})),t)if(i=t[r],rt.test(i)){if(delete t[r],o=o||"toggle"===i,i===(g?"hide":"show")){if("show"!==i||!v||void 0===v[r])continue;g=!0}d[r]=v&&v[r]||S.style(e,r)}if((u=!S.isEmptyObject(t))||!S.isEmptyObject(d))for(r in f&&1===e.nodeType&&(n.overflow=[h.overflow,h.overflowX,h.overflowY],null==(l=v&&v.display)&&(l=Y.get(e,"display")),"none"===(c=S.css(e,"display"))&&(l?c=l:(le([e],!0),l=e.style.display||l,c=S.css(e,"display"),le([e]))),("inline"===c||"inline-block"===c&&null!=l)&&"none"===S.css(e,"float")&&(u||(p.done(function(){h.display=l}),null==l&&(c=h.display,l="none"===c?"":c)),h.display="inline-block")),n.overflow&&(h.overflow="hidden",p.always(function(){h.overflow=n.overflow[0],h.overflowX=n.overflow[1],h.overflowY=n.overflow[2]})),u=!1,d)u||(v?"hidden"in v&&(g=v.hidden):v=Y.access(e,"fxshow",{display:l}),o&&(v.hidden=!g),g&&le([e],!0),p.done(function(){for(r in g||le([e]),Y.remove(e,"fxshow"),d)S.style(e,r,d[r])})),u=ut(g?v[r]:0,r,p),r in v||(v[r]=u.start,g&&(u.end=u.start,u.start=0))}],prefilter:function(e,t){t?lt.prefilters.unshift(e):lt.prefilters.push(e)}}),S.speed=function(e,t,n){var r=e&&"object"==typeof e?S.extend({},e):{complete:n||!n&&t||m(e)&&e,duration:e,easing:n&&t||t&&!m(t)&&t};return S.fx.off?r.duration=0:"number"!=typeof r.duration&&(r.duration in S.fx.speeds?r.duration=S.fx.speeds[r.duration]:r.duration=S.fx.speeds._default),null!=r.queue&&!0!==r.queue||(r.queue="fx"),r.old=r.complete,r.complete=function(){m(r.old)&&r.old.call(this),r.queue&&S.dequeue(this,r.queue)},r},S.fn.extend({fadeTo:function(e,t,n,r){return this.filter(ae).css("opacity",0).show().end().animate({opacity:t},e,n,r)},animate:function(t,e,n,r){var i=S.isEmptyObject(t),o=S.speed(e,n,r),a=function(){var e=lt(this,S.extend({},t),o);(i||Y.get(this,"finish"))&&e.stop(!0)};return a.finish=a,i||!1===o.queue?this.each(a):this.queue(o.queue,a)},stop:function(i,e,o){var a=function(e){var t=e.stop;delete e.stop,t(o)};return"string"!=typeof i&&(o=e,e=i,i=void 0),e&&this.queue(i||"fx",[]),this.each(function(){var e=!0,t=null!=i&&i+"queueHooks",n=S.timers,r=Y.get(this);if(t)r[t]&&r[t].stop&&a(r[t]);else for(t in r)r[t]&&r[t].stop&&it.test(t)&&a(r[t]);for(t=n.length;t--;)n[t].elem!==this||null!=i&&n[t].queue!==i||(n[t].anim.stop(o),e=!1,n.splice(t,1));!e&&o||S.dequeue(this,i)})},finish:function(a){return!1!==a&&(a=a||"fx"),this.each(function(){var e,t=Y.get(this),n=t[a+"queue"],r=t[a+"queueHooks"],i=S.timers,o=n?n.length:0;for(t.finish=!0,S.queue(this,a,[]),r&&r.stop&&r.stop.call(this,!0),e=i.length;e--;)i[e].elem===this&&i[e].queue===a&&(i[e].anim.stop(!0),i.splice(e,1));for(e=0;e<o;e++)n[e]&&n[e].finish&&n[e].finish.call(this);delete t.finish})}}),S.each(["toggle","show","hide"],function(e,r){var i=S.fn[r];S.fn[r]=function(e,t,n){return null==e||"boolean"==typeof e?i.apply(this,arguments):this.animate(st(r,!0),e,t,n)}}),S.each({slideDown:st("show"),slideUp:st("hide"),slideToggle:st("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(e,r){S.fn[e]=function(e,t,n){return this.animate(r,e,t,n)}}),S.timers=[],S.fx.tick=function(){var e,t=0,n=S.timers;for(Ze=Date.now();t<n.length;t++)(e=n[t])()||n[t]!==e||n.splice(t--,1);n.length||S.fx.stop(),Ze=void 0},S.fx.timer=function(e){S.timers.push(e),S.fx.start()},S.fx.interval=13,S.fx.start=function(){et||(et=!0,ot())},S.fx.stop=function(){et=null},S.fx.speeds={slow:600,fast:200,_default:400},S.fn.delay=function(r,e){return r=S.fx&&S.fx.speeds[r]||r,e=e||"fx",this.queue(e,function(e,t){var n=C.setTimeout(e,r);t.stop=function(){C.clearTimeout(n)}})},tt=E.createElement("input"),nt=E.createElement("select").appendChild(E.createElement("option")),tt.type="checkbox",y.checkOn=""!==tt.value,y.optSelected=nt.selected,(tt=E.createElement("input")).value="t",tt.type="radio",y.radioValue="t"===tt.value;var ct,ft=S.expr.attrHandle;S.fn.extend({attr:function(e,t){return $(this,S.attr,e,t,1<arguments.length)},removeAttr:function(e){return this.each(function(){S.removeAttr(this,e)})}}),S.extend({attr:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return"undefined"==typeof e.getAttribute?S.prop(e,t,n):(1===o&&S.isXMLDoc(e)||(i=S.attrHooks[t.toLowerCase()]||(S.expr.match.bool.test(t)?ct:void 0)),void 0!==n?null===n?void S.removeAttr(e,t):i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:(e.setAttribute(t,n+""),n):i&&"get"in i&&null!==(r=i.get(e,t))?r:null==(r=S.find.attr(e,t))?void 0:r)},attrHooks:{type:{set:function(e,t){if(!y.radioValue&&"radio"===t&&A(e,"input")){var n=e.value;return e.setAttribute("type",t),n&&(e.value=n),t}}}},removeAttr:function(e,t){var n,r=0,i=t&&t.match(P);if(i&&1===e.nodeType)while(n=i[r++])e.removeAttribute(n)}}),ct={set:function(e,t,n){return!1===t?S.removeAttr(e,n):e.setAttribute(n,n),n}},S.each(S.expr.match.bool.source.match(/\w+/g),function(e,t){var a=ft[t]||S.find.attr;ft[t]=function(e,t,n){var r,i,o=t.toLowerCase();return n||(i=ft[o],ft[o]=r,r=null!=a(e,t,n)?o:null,ft[o]=i),r}});var pt=/^(?:input|select|textarea|button)$/i,dt=/^(?:a|area)$/i;function ht(e){return(e.match(P)||[]).join(" ")}function gt(e){return e.getAttribute&&e.getAttribute("class")||""}function vt(e){return Array.isArray(e)?e:"string"==typeof e&&e.match(P)||[]}S.fn.extend({prop:function(e,t){return $(this,S.prop,e,t,1<arguments.length)},removeProp:function(e){return this.each(function(){delete this[S.propFix[e]||e]})}}),S.extend({prop:function(e,t,n){var r,i,o=e.nodeType;if(3!==o&&8!==o&&2!==o)return 1===o&&S.isXMLDoc(e)||(t=S.propFix[t]||t,i=S.propHooks[t]),void 0!==n?i&&"set"in i&&void 0!==(r=i.set(e,n,t))?r:e[t]=n:i&&"get"in i&&null!==(r=i.get(e,t))?r:e[t]},propHooks:{tabIndex:{get:function(e){var t=S.find.attr(e,"tabindex");return t?parseInt(t,10):pt.test(e.nodeName)||dt.test(e.nodeName)&&e.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),y.optSelected||(S.propHooks.selected={get:function(e){var t=e.parentNode;return t&&t.parentNode&&t.parentNode.selectedIndex,null},set:function(e){var t=e.parentNode;t&&(t.selectedIndex,t.parentNode&&t.parentNode.selectedIndex)}}),S.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){S.propFix[this.toLowerCase()]=this}),S.fn.extend({addClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).addClass(t.call(this,e,gt(this)))});if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])r.indexOf(" "+o+" ")<0&&(r+=o+" ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},removeClass:function(t){var e,n,r,i,o,a,s,u=0;if(m(t))return this.each(function(e){S(this).removeClass(t.call(this,e,gt(this)))});if(!arguments.length)return this.attr("class","");if((e=vt(t)).length)while(n=this[u++])if(i=gt(n),r=1===n.nodeType&&" "+ht(i)+" "){a=0;while(o=e[a++])while(-1<r.indexOf(" "+o+" "))r=r.replace(" "+o+" "," ");i!==(s=ht(r))&&n.setAttribute("class",s)}return this},toggleClass:function(i,t){var o=typeof i,a="string"===o||Array.isArray(i);return"boolean"==typeof t&&a?t?this.addClass(i):this.removeClass(i):m(i)?this.each(function(e){S(this).toggleClass(i.call(this,e,gt(this),t),t)}):this.each(function(){var e,t,n,r;if(a){t=0,n=S(this),r=vt(i);while(e=r[t++])n.hasClass(e)?n.removeClass(e):n.addClass(e)}else void 0!==i&&"boolean"!==o||((e=gt(this))&&Y.set(this,"__className__",e),this.setAttribute&&this.setAttribute("class",e||!1===i?"":Y.get(this,"__className__")||""))})},hasClass:function(e){var t,n,r=0;t=" "+e+" ";while(n=this[r++])if(1===n.nodeType&&-1<(" "+ht(gt(n))+" ").indexOf(t))return!0;return!1}});var yt=/\r/g;S.fn.extend({val:function(n){var r,e,i,t=this[0];return arguments.length?(i=m(n),this.each(function(e){var t;1===this.nodeType&&(null==(t=i?n.call(this,e,S(this).val()):n)?t="":"number"==typeof t?t+="":Array.isArray(t)&&(t=S.map(t,function(e){return null==e?"":e+""})),(r=S.valHooks[this.type]||S.valHooks[this.nodeName.toLowerCase()])&&"set"in r&&void 0!==r.set(this,t,"value")||(this.value=t))})):t?(r=S.valHooks[t.type]||S.valHooks[t.nodeName.toLowerCase()])&&"get"in r&&void 0!==(e=r.get(t,"value"))?e:"string"==typeof(e=t.value)?e.replace(yt,""):null==e?"":e:void 0}}),S.extend({valHooks:{option:{get:function(e){var t=S.find.attr(e,"value");return null!=t?t:ht(S.text(e))}},select:{get:function(e){var t,n,r,i=e.options,o=e.selectedIndex,a="select-one"===e.type,s=a?null:[],u=a?o+1:i.length;for(r=o<0?u:a?o:0;r<u;r++)if(((n=i[r]).selected||r===o)&&!n.disabled&&(!n.parentNode.disabled||!A(n.parentNode,"optgroup"))){if(t=S(n).val(),a)return t;s.push(t)}return s},set:function(e,t){var n,r,i=e.options,o=S.makeArray(t),a=i.length;while(a--)((r=i[a]).selected=-1<S.inArray(S.valHooks.option.get(r),o))&&(n=!0);return n||(e.selectedIndex=-1),o}}}}),S.each(["radio","checkbox"],function(){S.valHooks[this]={set:function(e,t){if(Array.isArray(t))return e.checked=-1<S.inArray(S(e).val(),t)}},y.checkOn||(S.valHooks[this].get=function(e){return null===e.getAttribute("value")?"on":e.value})}),y.focusin="onfocusin"in C;var mt=/^(?:focusinfocus|focusoutblur)$/,xt=function(e){e.stopPropagation()};S.extend(S.event,{trigger:function(e,t,n,r){var i,o,a,s,u,l,c,f,p=[n||E],d=v.call(e,"type")?e.type:e,h=v.call(e,"namespace")?e.namespace.split("."):[];if(o=f=a=n=n||E,3!==n.nodeType&&8!==n.nodeType&&!mt.test(d+S.event.triggered)&&(-1<d.indexOf(".")&&(d=(h=d.split(".")).shift(),h.sort()),u=d.indexOf(":")<0&&"on"+d,(e=e[S.expando]?e:new S.Event(d,"object"==typeof e&&e)).isTrigger=r?2:3,e.namespace=h.join("."),e.rnamespace=e.namespace?new RegExp("(^|\\.)"+h.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,e.result=void 0,e.target||(e.target=n),t=null==t?[e]:S.makeArray(t,[e]),c=S.event.special[d]||{},r||!c.trigger||!1!==c.trigger.apply(n,t))){if(!r&&!c.noBubble&&!x(n)){for(s=c.delegateType||d,mt.test(s+d)||(o=o.parentNode);o;o=o.parentNode)p.push(o),a=o;a===(n.ownerDocument||E)&&p.push(a.defaultView||a.parentWindow||C)}i=0;while((o=p[i++])&&!e.isPropagationStopped())f=o,e.type=1<i?s:c.bindType||d,(l=(Y.get(o,"events")||Object.create(null))[e.type]&&Y.get(o,"handle"))&&l.apply(o,t),(l=u&&o[u])&&l.apply&&V(o)&&(e.result=l.apply(o,t),!1===e.result&&e.preventDefault());return e.type=d,r||e.isDefaultPrevented()||c._default&&!1!==c._default.apply(p.pop(),t)||!V(n)||u&&m(n[d])&&!x(n)&&((a=n[u])&&(n[u]=null),S.event.triggered=d,e.isPropagationStopped()&&f.addEventListener(d,xt),n[d](),e.isPropagationStopped()&&f.removeEventListener(d,xt),S.event.triggered=void 0,a&&(n[u]=a)),e.result}},simulate:function(e,t,n){var r=S.extend(new S.Event,n,{type:e,isSimulated:!0});S.event.trigger(r,null,t)}}),S.fn.extend({trigger:function(e,t){return this.each(function(){S.event.trigger(e,t,this)})},triggerHandler:function(e,t){var n=this[0];if(n)return S.event.trigger(e,t,n,!0)}}),y.focusin||S.each({focus:"focusin",blur:"focusout"},function(n,r){var i=function(e){S.event.simulate(r,e.target,S.event.fix(e))};S.event.special[r]={setup:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r);t||e.addEventListener(n,i,!0),Y.access(e,r,(t||0)+1)},teardown:function(){var e=this.ownerDocument||this.document||this,t=Y.access(e,r)-1;t?Y.access(e,r,t):(e.removeEventListener(n,i,!0),Y.remove(e,r))}}});var bt=C.location,wt={guid:Date.now()},Tt=/\?/;S.parseXML=function(e){var t,n;if(!e||"string"!=typeof e)return null;try{t=(new C.DOMParser).parseFromString(e,"text/xml")}catch(e){}return n=t&&t.getElementsByTagName("parsererror")[0],t&&!n||S.error("Invalid XML: "+(n?S.map(n.childNodes,function(e){return e.textContent}).join("\n"):e)),t};var Ct=/\[\]$/,Et=/\r?\n/g,St=/^(?:submit|button|image|reset|file)$/i,kt=/^(?:input|select|textarea|keygen)/i;function At(n,e,r,i){var t;if(Array.isArray(e))S.each(e,function(e,t){r||Ct.test(n)?i(n,t):At(n+"["+("object"==typeof t&&null!=t?e:"")+"]",t,r,i)});else if(r||"object"!==w(e))i(n,e);else for(t in e)At(n+"["+t+"]",e[t],r,i)}S.param=function(e,t){var n,r=[],i=function(e,t){var n=m(t)?t():t;r[r.length]=encodeURIComponent(e)+"="+encodeURIComponent(null==n?"":n)};if(null==e)return"";if(Array.isArray(e)||e.jquery&&!S.isPlainObject(e))S.each(e,function(){i(this.name,this.value)});else for(n in e)At(n,e[n],t,i);return r.join("&")},S.fn.extend({serialize:function(){return S.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var e=S.prop(this,"elements");return e?S.makeArray(e):this}).filter(function(){var e=this.type;return this.name&&!S(this).is(":disabled")&&kt.test(this.nodeName)&&!St.test(e)&&(this.checked||!pe.test(e))}).map(function(e,t){var n=S(this).val();return null==n?null:Array.isArray(n)?S.map(n,function(e){return{name:t.name,value:e.replace(Et,"\r\n")}}):{name:t.name,value:n.replace(Et,"\r\n")}}).get()}});var Nt=/%20/g,jt=/#.*$/,Dt=/([?&])_=[^&]*/,qt=/^(.*?):[ \t]*([^\r\n]*)$/gm,Lt=/^(?:GET|HEAD)$/,Ht=/^\/\//,Ot={},Pt={},Rt="*/".concat("*"),Mt=E.createElement("a");function It(o){return function(e,t){"string"!=typeof e&&(t=e,e="*");var n,r=0,i=e.toLowerCase().match(P)||[];if(m(t))while(n=i[r++])"+"===n[0]?(n=n.slice(1)||"*",(o[n]=o[n]||[]).unshift(t)):(o[n]=o[n]||[]).push(t)}}function Wt(t,i,o,a){var s={},u=t===Pt;function l(e){var r;return s[e]=!0,S.each(t[e]||[],function(e,t){var n=t(i,o,a);return"string"!=typeof n||u||s[n]?u?!(r=n):void 0:(i.dataTypes.unshift(n),l(n),!1)}),r}return l(i.dataTypes[0])||!s["*"]&&l("*")}function Ft(e,t){var n,r,i=S.ajaxSettings.flatOptions||{};for(n in t)void 0!==t[n]&&((i[n]?e:r||(r={}))[n]=t[n]);return r&&S.extend(!0,e,r),e}Mt.href=bt.href,S.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:bt.href,type:"GET",isLocal:/^(?:about|app|app-storage|.+-extension|file|res|widget):$/.test(bt.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Rt,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":S.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(e,t){return t?Ft(Ft(e,S.ajaxSettings),t):Ft(S.ajaxSettings,e)},ajaxPrefilter:It(Ot),ajaxTransport:It(Pt),ajax:function(e,t){"object"==typeof e&&(t=e,e=void 0),t=t||{};var c,f,p,n,d,r,h,g,i,o,v=S.ajaxSetup({},t),y=v.context||v,m=v.context&&(y.nodeType||y.jquery)?S(y):S.event,x=S.Deferred(),b=S.Callbacks("once memory"),w=v.statusCode||{},a={},s={},u="canceled",T={readyState:0,getResponseHeader:function(e){var t;if(h){if(!n){n={};while(t=qt.exec(p))n[t[1].toLowerCase()+" "]=(n[t[1].toLowerCase()+" "]||[]).concat(t[2])}t=n[e.toLowerCase()+" "]}return null==t?null:t.join(", ")},getAllResponseHeaders:function(){return h?p:null},setRequestHeader:function(e,t){return null==h&&(e=s[e.toLowerCase()]=s[e.toLowerCase()]||e,a[e]=t),this},overrideMimeType:function(e){return null==h&&(v.mimeType=e),this},statusCode:function(e){var t;if(e)if(h)T.always(e[T.status]);else for(t in e)w[t]=[w[t],e[t]];return this},abort:function(e){var t=e||u;return c&&c.abort(t),l(0,t),this}};if(x.promise(T),v.url=((e||v.url||bt.href)+"").replace(Ht,bt.protocol+"//"),v.type=t.method||t.type||v.method||v.type,v.dataTypes=(v.dataType||"*").toLowerCase().match(P)||[""],null==v.crossDomain){r=E.createElement("a");try{r.href=v.url,r.href=r.href,v.crossDomain=Mt.protocol+"//"+Mt.host!=r.protocol+"//"+r.host}catch(e){v.crossDomain=!0}}if(v.data&&v.processData&&"string"!=typeof v.data&&(v.data=S.param(v.data,v.traditional)),Wt(Ot,v,t,T),h)return T;for(i in(g=S.event&&v.global)&&0==S.active++&&S.event.trigger("ajaxStart"),v.type=v.type.toUpperCase(),v.hasContent=!Lt.test(v.type),f=v.url.replace(jt,""),v.hasContent?v.data&&v.processData&&0===(v.contentType||"").indexOf("application/x-www-form-urlencoded")&&(v.data=v.data.replace(Nt,"+")):(o=v.url.slice(f.length),v.data&&(v.processData||"string"==typeof v.data)&&(f+=(Tt.test(f)?"&":"?")+v.data,delete v.data),!1===v.cache&&(f=f.replace(Dt,"$1"),o=(Tt.test(f)?"&":"?")+"_="+wt.guid+++o),v.url=f+o),v.ifModified&&(S.lastModified[f]&&T.setRequestHeader("If-Modified-Since",S.lastModified[f]),S.etag[f]&&T.setRequestHeader("If-None-Match",S.etag[f])),(v.data&&v.hasContent&&!1!==v.contentType||t.contentType)&&T.setRequestHeader("Content-Type",v.contentType),T.setRequestHeader("Accept",v.dataTypes[0]&&v.accepts[v.dataTypes[0]]?v.accepts[v.dataTypes[0]]+("*"!==v.dataTypes[0]?", "+Rt+"; q=0.01":""):v.accepts["*"]),v.headers)T.setRequestHeader(i,v.headers[i]);if(v.beforeSend&&(!1===v.beforeSend.call(y,T,v)||h))return T.abort();if(u="abort",b.add(v.complete),T.done(v.success),T.fail(v.error),c=Wt(Pt,v,t,T)){if(T.readyState=1,g&&m.trigger("ajaxSend",[T,v]),h)return T;v.async&&0<v.timeout&&(d=C.setTimeout(function(){T.abort("timeout")},v.timeout));try{h=!1,c.send(a,l)}catch(e){if(h)throw e;l(-1,e)}}else l(-1,"No Transport");function l(e,t,n,r){var i,o,a,s,u,l=t;h||(h=!0,d&&C.clearTimeout(d),c=void 0,p=r||"",T.readyState=0<e?4:0,i=200<=e&&e<300||304===e,n&&(s=function(e,t,n){var r,i,o,a,s=e.contents,u=e.dataTypes;while("*"===u[0])u.shift(),void 0===r&&(r=e.mimeType||t.getResponseHeader("Content-Type"));if(r)for(i in s)if(s[i]&&s[i].test(r)){u.unshift(i);break}if(u[0]in n)o=u[0];else{for(i in n){if(!u[0]||e.converters[i+" "+u[0]]){o=i;break}a||(a=i)}o=o||a}if(o)return o!==u[0]&&u.unshift(o),n[o]}(v,T,n)),!i&&-1<S.inArray("script",v.dataTypes)&&S.inArray("json",v.dataTypes)<0&&(v.converters["text script"]=function(){}),s=function(e,t,n,r){var i,o,a,s,u,l={},c=e.dataTypes.slice();if(c[1])for(a in e.converters)l[a.toLowerCase()]=e.converters[a];o=c.shift();while(o)if(e.responseFields[o]&&(n[e.responseFields[o]]=t),!u&&r&&e.dataFilter&&(t=e.dataFilter(t,e.dataType)),u=o,o=c.shift())if("*"===o)o=u;else if("*"!==u&&u!==o){if(!(a=l[u+" "+o]||l["* "+o]))for(i in l)if((s=i.split(" "))[1]===o&&(a=l[u+" "+s[0]]||l["* "+s[0]])){!0===a?a=l[i]:!0!==l[i]&&(o=s[0],c.unshift(s[1]));break}if(!0!==a)if(a&&e["throws"])t=a(t);else try{t=a(t)}catch(e){return{state:"parsererror",error:a?e:"No conversion from "+u+" to "+o}}}return{state:"success",data:t}}(v,s,T,i),i?(v.ifModified&&((u=T.getResponseHeader("Last-Modified"))&&(S.lastModified[f]=u),(u=T.getResponseHeader("etag"))&&(S.etag[f]=u)),204===e||"HEAD"===v.type?l="nocontent":304===e?l="notmodified":(l=s.state,o=s.data,i=!(a=s.error))):(a=l,!e&&l||(l="error",e<0&&(e=0))),T.status=e,T.statusText=(t||l)+"",i?x.resolveWith(y,[o,l,T]):x.rejectWith(y,[T,l,a]),T.statusCode(w),w=void 0,g&&m.trigger(i?"ajaxSuccess":"ajaxError",[T,v,i?o:a]),b.fireWith(y,[T,l]),g&&(m.trigger("ajaxComplete",[T,v]),--S.active||S.event.trigger("ajaxStop")))}return T},getJSON:function(e,t,n){return S.get(e,t,n,"json")},getScript:function(e,t){return S.get(e,void 0,t,"script")}}),S.each(["get","post"],function(e,i){S[i]=function(e,t,n,r){return m(t)&&(r=r||n,n=t,t=void 0),S.ajax(S.extend({url:e,type:i,dataType:r,data:t,success:n},S.isPlainObject(e)&&e))}}),S.ajaxPrefilter(function(e){var t;for(t in e.headers)"content-type"===t.toLowerCase()&&(e.contentType=e.headers[t]||"")}),S._evalUrl=function(e,t,n){return S.ajax({url:e,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,converters:{"text script":function(){}},dataFilter:function(e){S.globalEval(e,t,n)}})},S.fn.extend({wrapAll:function(e){var t;return this[0]&&(m(e)&&(e=e.call(this[0])),t=S(e,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&t.insertBefore(this[0]),t.map(function(){var e=this;while(e.firstElementChild)e=e.firstElementChild;return e}).append(this)),this},wrapInner:function(n){return m(n)?this.each(function(e){S(this).wrapInner(n.call(this,e))}):this.each(function(){var e=S(this),t=e.contents();t.length?t.wrapAll(n):e.append(n)})},wrap:function(t){var n=m(t);return this.each(function(e){S(this).wrapAll(n?t.call(this,e):t)})},unwrap:function(e){return this.parent(e).not("body").each(function(){S(this).replaceWith(this.childNodes)}),this}}),S.expr.pseudos.hidden=function(e){return!S.expr.pseudos.visible(e)},S.expr.pseudos.visible=function(e){return!!(e.offsetWidth||e.offsetHeight||e.getClientRects().length)},S.ajaxSettings.xhr=function(){try{return new C.XMLHttpRequest}catch(e){}};var Bt={0:200,1223:204},$t=S.ajaxSettings.xhr();y.cors=!!$t&&"withCredentials"in $t,y.ajax=$t=!!$t,S.ajaxTransport(function(i){var o,a;if(y.cors||$t&&!i.crossDomain)return{send:function(e,t){var n,r=i.xhr();if(r.open(i.type,i.url,i.async,i.username,i.password),i.xhrFields)for(n in i.xhrFields)r[n]=i.xhrFields[n];for(n in i.mimeType&&r.overrideMimeType&&r.overrideMimeType(i.mimeType),i.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest"),e)r.setRequestHeader(n,e[n]);o=function(e){return function(){o&&(o=a=r.onload=r.onerror=r.onabort=r.ontimeout=r.onreadystatechange=null,"abort"===e?r.abort():"error"===e?"number"!=typeof r.status?t(0,"error"):t(r.status,r.statusText):t(Bt[r.status]||r.status,r.statusText,"text"!==(r.responseType||"text")||"string"!=typeof r.responseText?{binary:r.response}:{text:r.responseText},r.getAllResponseHeaders()))}},r.onload=o(),a=r.onerror=r.ontimeout=o("error"),void 0!==r.onabort?r.onabort=a:r.onreadystatechange=function(){4===r.readyState&&C.setTimeout(function(){o&&a()})},o=o("abort");try{r.send(i.hasContent&&i.data||null)}catch(e){if(o)throw e}},abort:function(){o&&o()}}}),S.ajaxPrefilter(function(e){e.crossDomain&&(e.contents.script=!1)}),S.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(e){return S.globalEval(e),e}}}),S.ajaxPrefilter("script",function(e){void 0===e.cache&&(e.cache=!1),e.crossDomain&&(e.type="GET")}),S.ajaxTransport("script",function(n){var r,i;if(n.crossDomain||n.scriptAttrs)return{send:function(e,t){r=S("<script>").attr(n.scriptAttrs||{}).prop({charset:n.scriptCharset,src:n.url}).on("load error",i=function(e){r.remove(),i=null,e&&t("error"===e.type?404:200,e.type)}),E.head.appendChild(r[0])},abort:function(){i&&i()}}});var _t,zt=[],Ut=/(=)\?(?=&|$)|\?\?/;S.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var e=zt.pop()||S.expando+"_"+wt.guid++;return this[e]=!0,e}}),S.ajaxPrefilter("json jsonp",function(e,t,n){var r,i,o,a=!1!==e.jsonp&&(Ut.test(e.url)?"url":"string"==typeof e.data&&0===(e.contentType||"").indexOf("application/x-www-form-urlencoded")&&Ut.test(e.data)&&"data");if(a||"jsonp"===e.dataTypes[0])return r=e.jsonpCallback=m(e.jsonpCallback)?e.jsonpCallback():e.jsonpCallback,a?e[a]=e[a].replace(Ut,"$1"+r):!1!==e.jsonp&&(e.url+=(Tt.test(e.url)?"&":"?")+e.jsonp+"="+r),e.converters["script json"]=function(){return o||S.error(r+" was not called"),o[0]},e.dataTypes[0]="json",i=C[r],C[r]=function(){o=arguments},n.always(function(){void 0===i?S(C).removeProp(r):C[r]=i,e[r]&&(e.jsonpCallback=t.jsonpCallback,zt.push(r)),o&&m(i)&&i(o[0]),o=i=void 0}),"script"}),y.createHTMLDocument=((_t=E.implementation.createHTMLDocument("").body).innerHTML="<form></form><form></form>",2===_t.childNodes.length),S.parseHTML=function(e,t,n){return"string"!=typeof e?[]:("boolean"==typeof t&&(n=t,t=!1),t||(y.createHTMLDocument?((r=(t=E.implementation.createHTMLDocument("")).createElement("base")).href=E.location.href,t.head.appendChild(r)):t=E),o=!n&&[],(i=N.exec(e))?[t.createElement(i[1])]:(i=xe([e],t,o),o&&o.length&&S(o).remove(),S.merge([],i.childNodes)));var r,i,o},S.fn.load=function(e,t,n){var r,i,o,a=this,s=e.indexOf(" ");return-1<s&&(r=ht(e.slice(s)),e=e.slice(0,s)),m(t)?(n=t,t=void 0):t&&"object"==typeof t&&(i="POST"),0<a.length&&S.ajax({url:e,type:i||"GET",dataType:"html",data:t}).done(function(e){o=arguments,a.html(r?S("<div>").append(S.parseHTML(e)).find(r):e)}).always(n&&function(e,t){a.each(function(){n.apply(this,o||[e.responseText,t,e])})}),this},S.expr.pseudos.animated=function(t){return S.grep(S.timers,function(e){return t===e.elem}).length},S.offset={setOffset:function(e,t,n){var r,i,o,a,s,u,l=S.css(e,"position"),c=S(e),f={};"static"===l&&(e.style.position="relative"),s=c.offset(),o=S.css(e,"top"),u=S.css(e,"left"),("absolute"===l||"fixed"===l)&&-1<(o+u).indexOf("auto")?(a=(r=c.position()).top,i=r.left):(a=parseFloat(o)||0,i=parseFloat(u)||0),m(t)&&(t=t.call(e,n,S.extend({},s))),null!=t.top&&(f.top=t.top-s.top+a),null!=t.left&&(f.left=t.left-s.left+i),"using"in t?t.using.call(e,f):c.css(f)}},S.fn.extend({offset:function(t){if(arguments.length)return void 0===t?this:this.each(function(e){S.offset.setOffset(this,t,e)});var e,n,r=this[0];return r?r.getClientRects().length?(e=r.getBoundingClientRect(),n=r.ownerDocument.defaultView,{top:e.top+n.pageYOffset,left:e.left+n.pageXOffset}):{top:0,left:0}:void 0},position:function(){if(this[0]){var e,t,n,r=this[0],i={top:0,left:0};if("fixed"===S.css(r,"position"))t=r.getBoundingClientRect();else{t=this.offset(),n=r.ownerDocument,e=r.offsetParent||n.documentElement;while(e&&(e===n.body||e===n.documentElement)&&"static"===S.css(e,"position"))e=e.parentNode;e&&e!==r&&1===e.nodeType&&((i=S(e).offset()).top+=S.css(e,"borderTopWidth",!0),i.left+=S.css(e,"borderLeftWidth",!0))}return{top:t.top-i.top-S.css(r,"marginTop",!0),left:t.left-i.left-S.css(r,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var e=this.offsetParent;while(e&&"static"===S.css(e,"position"))e=e.offsetParent;return e||re})}}),S.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(t,i){var o="pageYOffset"===i;S.fn[t]=function(e){return $(this,function(e,t,n){var r;if(x(e)?r=e:9===e.nodeType&&(r=e.defaultView),void 0===n)return r?r[i]:e[t];r?r.scrollTo(o?r.pageXOffset:n,o?n:r.pageYOffset):e[t]=n},t,e,arguments.length)}}),S.each(["top","left"],function(e,n){S.cssHooks[n]=Fe(y.pixelPosition,function(e,t){if(t)return t=We(e,n),Pe.test(t)?S(e).position()[n]+"px":t})}),S.each({Height:"height",Width:"width"},function(a,s){S.each({padding:"inner"+a,content:s,"":"outer"+a},function(r,o){S.fn[o]=function(e,t){var n=arguments.length&&(r||"boolean"!=typeof e),i=r||(!0===e||!0===t?"margin":"border");return $(this,function(e,t,n){var r;return x(e)?0===o.indexOf("outer")?e["inner"+a]:e.document.documentElement["client"+a]:9===e.nodeType?(r=e.documentElement,Math.max(e.body["scroll"+a],r["scroll"+a],e.body["offset"+a],r["offset"+a],r["client"+a])):void 0===n?S.css(e,t,i):S.style(e,t,n,i)},s,n?e:void 0,n)}})}),S.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(e,t){S.fn[t]=function(e){return this.on(t,e)}}),S.fn.extend({bind:function(e,t,n){return this.on(e,null,t,n)},unbind:function(e,t){return this.off(e,null,t)},delegate:function(e,t,n,r){return this.on(t,e,n,r)},undelegate:function(e,t,n){return 1===arguments.length?this.off(e,"**"):this.off(t,e||"**",n)},hover:function(e,t){return this.mouseenter(e).mouseleave(t||e)}}),S.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(e,n){S.fn[n]=function(e,t){return 0<arguments.length?this.on(n,null,e,t):this.trigger(n)}});var Xt=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g;S.proxy=function(e,t){var n,r,i;if("string"==typeof t&&(n=e[t],t=e,e=n),m(e))return r=s.call(arguments,2),(i=function(){return e.apply(t||this,r.concat(s.call(arguments)))}).guid=e.guid=e.guid||S.guid++,i},S.holdReady=function(e){e?S.readyWait++:S.ready(!0)},S.isArray=Array.isArray,S.parseJSON=JSON.parse,S.nodeName=A,S.isFunction=m,S.isWindow=x,S.camelCase=X,S.type=w,S.now=Date.now,S.isNumeric=function(e){var t=S.type(e);return("number"===t||"string"===t)&&!isNaN(e-parseFloat(e))},S.trim=function(e){return null==e?"":(e+"").replace(Xt,"")},"function"==typeof define&&define.amd&&define("jquery",[],function(){return S});var Vt=C.jQuery,Gt=C.$;return S.noConflict=function(e){return C.$===S&&(C.$=Gt),e&&C.jQuery===S&&(C.jQuery=Vt),S},"undefined"==typeof e&&(C.jQuery=C.$=S),S}); diff --git a/v7.1.3/_static/language_data.js b/v7.1.3/_static/language_data.js index ebe2f03b..2e22b06a 100644 --- a/v7.1.3/_static/language_data.js +++ b/v7.1.3/_static/language_data.js @@ -10,7 +10,7 @@   *   */ -var stopwords = ["a","and","are","as","at","be","but","by","for","if","in","into","is","it","near","no","not","of","on","or","such","that","the","their","then","there","these","they","this","to","was","will","with"]; +var stopwords = ["a", "and", "are", "as", "at", "be", "but", "by", "for", "if", "in", "into", "is", "it", "near", "no", "not", "of", "on", "or", "such", "that", "the", "their", "then", "there", "these", "they", "this", "to", "was", "will", "with"];  /* Non-minified version is copied as a separate JS file, is available */ @@ -197,101 +197,3 @@ var Stemmer = function() {    }  } - - - -var splitChars = (function() { -    var result = {}; -    var singles = [96, 180, 187, 191, 215, 247, 749, 885, 903, 907, 909, 930, 1014, 1648, -         1748, 1809, 2416, 2473, 2481, 2526, 2601, 2609, 2612, 2615, 2653, 2702, -         2706, 2729, 2737, 2740, 2857, 2865, 2868, 2910, 2928, 2948, 2961, 2971, -         2973, 3085, 3089, 3113, 3124, 3213, 3217, 3241, 3252, 3295, 3341, 3345, -         3369, 3506, 3516, 3633, 3715, 3721, 3736, 3744, 3748, 3750, 3756, 3761, -         3781, 3912, 4239, 4347, 4681, 4695, 4697, 4745, 4785, 4799, 4801, 4823, -         4881, 5760, 5901, 5997, 6313, 7405, 8024, 8026, 8028, 8030, 8117, 8125, -         8133, 8181, 8468, 8485, 8487, 8489, 8494, 8527, 11311, 11359, 11687, 11695, -         11703, 11711, 11719, 11727, 11735, 12448, 12539, 43010, 43014, 43019, 43587, -         43696, 43713, 64286, 64297, 64311, 64317, 64319, 64322, 64325, 65141]; -    var i, j, start, end; -    for (i = 0; i < singles.length; i++) { -        result[singles[i]] = true; -    } -    var ranges = [[0, 47], [58, 64], [91, 94], [123, 169], [171, 177], [182, 184], [706, 709], -         [722, 735], [741, 747], [751, 879], [888, 889], [894, 901], [1154, 1161], -         [1318, 1328], [1367, 1368], [1370, 1376], [1416, 1487], [1515, 1519], [1523, 1568], -         [1611, 1631], [1642, 1645], [1750, 1764], [1767, 1773], [1789, 1790], [1792, 1807], -         [1840, 1868], [1958, 1968], [1970, 1983], [2027, 2035], [2038, 2041], [2043, 2047], -         [2070, 2073], [2075, 2083], [2085, 2087], [2089, 2307], [2362, 2364], [2366, 2383], -         [2385, 2391], [2402, 2405], [2419, 2424], [2432, 2436], [2445, 2446], [2449, 2450], -         [2483, 2485], [2490, 2492], [2494, 2509], [2511, 2523], [2530, 2533], [2546, 2547], -         [2554, 2564], [2571, 2574], [2577, 2578], [2618, 2648], [2655, 2661], [2672, 2673], -         [2677, 2692], [2746, 2748], [2750, 2767], [2769, 2783], [2786, 2789], [2800, 2820], -         [2829, 2830], [2833, 2834], [2874, 2876], [2878, 2907], [2914, 2917], [2930, 2946], -         [2955, 2957], [2966, 2968], [2976, 2978], [2981, 2983], [2987, 2989], [3002, 3023], -         [3025, 3045], [3059, 3076], [3130, 3132], [3134, 3159], [3162, 3167], [3170, 3173], -         [3184, 3191], [3199, 3204], [3258, 3260], [3262, 3293], [3298, 3301], [3312, 3332], -         [3386, 3388], [3390, 3423], [3426, 3429], [3446, 3449], [3456, 3460], [3479, 3481], -         [3518, 3519], [3527, 3584], [3636, 3647], [3655, 3663], [3674, 3712], [3717, 3718], -         [3723, 3724], [3726, 3731], [3752, 3753], [3764, 3772], [3774, 3775], [3783, 3791], -         [3802, 3803], [3806, 3839], [3841, 3871], [3892, 3903], [3949, 3975], [3980, 4095], -         [4139, 4158], [4170, 4175], [4182, 4185], [4190, 4192], [4194, 4196], [4199, 4205], -         [4209, 4212], [4226, 4237], [4250, 4255], [4294, 4303], [4349, 4351], [4686, 4687], -         [4702, 4703], [4750, 4751], [4790, 4791], [4806, 4807], [4886, 4887], [4955, 4968], -         [4989, 4991], [5008, 5023], [5109, 5120], [5741, 5742], [5787, 5791], [5867, 5869], -         [5873, 5887], [5906, 5919], [5938, 5951], [5970, 5983], [6001, 6015], [6068, 6102], -         [6104, 6107], [6109, 6111], [6122, 6127], [6138, 6159], [6170, 6175], [6264, 6271], -         [6315, 6319], [6390, 6399], [6429, 6469], [6510, 6511], [6517, 6527], [6572, 6592], -         [6600, 6607], [6619, 6655], [6679, 6687], [6741, 6783], [6794, 6799], [6810, 6822], -         [6824, 6916], [6964, 6980], [6988, 6991], [7002, 7042], [7073, 7085], [7098, 7167], -         [7204, 7231], [7242, 7244], [7294, 7400], [7410, 7423], [7616, 7679], [7958, 7959], -         [7966, 7967], [8006, 8007], [8014, 8015], [8062, 8063], [8127, 8129], [8141, 8143], -         [8148, 8149], [8156, 8159], [8173, 8177], [8189, 8303], [8306, 8307], [8314, 8318], -         [8330, 8335], [8341, 8449], [8451, 8454], [8456, 8457], [8470, 8472], [8478, 8483], -         [8506, 8507], [8512, 8516], [8522, 8525], [8586, 9311], [9372, 9449], [9472, 10101], -         [10132, 11263], [11493, 11498], [11503, 11516], [11518, 11519], [11558, 11567], -         [11622, 11630], [11632, 11647], [11671, 11679], [11743, 11822], [11824, 12292], -         [12296, 12320], [12330, 12336], [12342, 12343], [12349, 12352], [12439, 12444], -         [12544, 12548], [12590, 12592], [12687, 12689], [12694, 12703], [12728, 12783], -         [12800, 12831], [12842, 12880], [12896, 12927], [12938, 12976], [12992, 13311], -         [19894, 19967], [40908, 40959], [42125, 42191], [42238, 42239], [42509, 42511], -         [42540, 42559], [42592, 42593], [42607, 42622], [42648, 42655], [42736, 42774], -         [42784, 42785], [42889, 42890], [42893, 43002], [43043, 43055], [43062, 43071], -         [43124, 43137], [43188, 43215], [43226, 43249], [43256, 43258], [43260, 43263], -         [43302, 43311], [43335, 43359], [43389, 43395], [43443, 43470], [43482, 43519], -         [43561, 43583], [43596, 43599], [43610, 43615], [43639, 43641], [43643, 43647], -         [43698, 43700], [43703, 43704], [43710, 43711], [43715, 43738], [43742, 43967], -         [44003, 44015], [44026, 44031], [55204, 55215], [55239, 55242], [55292, 55295], -         [57344, 63743], [64046, 64047], [64110, 64111], [64218, 64255], [64263, 64274], -         [64280, 64284], [64434, 64466], [64830, 64847], [64912, 64913], [64968, 65007], -         [65020, 65135], [65277, 65295], [65306, 65312], [65339, 65344], [65371, 65381], -         [65471, 65473], [65480, 65481], [65488, 65489], [65496, 65497]]; -    for (i = 0; i < ranges.length; i++) { -        start = ranges[i][0]; -        end = ranges[i][1]; -        for (j = start; j <= end; j++) { -            result[j] = true; -        } -    } -    return result; -})(); - -function splitQuery(query) { -    var result = []; -    var start = -1; -    for (var i = 0; i < query.length; i++) { -        if (splitChars[query.charCodeAt(i)]) { -            if (start !== -1) { -                result.push(query.slice(start, i)); -                start = -1; -            } -        } else if (start === -1) { -            start = i; -        } -    } -    if (start !== -1) { -        result.push(query.slice(start)); -    } -    return result; -} - - diff --git a/v7.1.3/_static/searchtools.js b/v7.1.3/_static/searchtools.js index 0a44e858..ac4d5861 100644 --- a/v7.1.3/_static/searchtools.js +++ b/v7.1.3/_static/searchtools.js @@ -8,18 +8,20 @@   * :license: BSD, see LICENSE for details.   *   */ +"use strict"; -if (!Scorer) { -  /** -   * Simple result scoring code. -   */ +/** + * Simple result scoring code. + */ +if (typeof Scorer === "undefined") {    var Scorer = {      // Implement the following function to further tweak the score for each result -    // The function takes a result array [filename, title, anchor, descr, score] +    // The function takes a result array [docname, title, anchor, descr, score, filename]      // and returns the new score.      /* -    score: function(result) { -      return result[4]; +    score: result => { +      const [docname, title, anchor, descr, score, filename] = result +      return score      },      */ @@ -28,9 +30,11 @@ if (!Scorer) {      // or matches in the last dotted part of the object name      objPartialMatch: 6,      // Additive scores depending on the priority of the object -    objPrio: {0:  15,   // used to be importantResults -              1:  5,   // used to be objectResults -              2: -5},  // used to be unimportantResults +    objPrio: { +      0: 15, // used to be importantResults +      1: 5, // used to be objectResults +      2: -5, // used to be unimportantResults +    },      //  Used when the priority is not in the mapping.      objPrioDefault: 0, @@ -39,452 +43,455 @@ if (!Scorer) {      partialTitle: 7,      // query found in terms      term: 5, -    partialTerm: 2 +    partialTerm: 2,    };  } -if (!splitQuery) { -  function splitQuery(query) { -    return query.split(/\s+/); +const _removeChildren = (element) => { +  while (element && element.lastChild) element.removeChild(element.lastChild); +}; + +/** + * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#escaping + */ +const _escapeRegExp = (string) => +  string.replace(/[.*+\-?^${}()|[\]\\]/g, "\\$&"); // $& means the whole matched string + +const _displayItem = (item, highlightTerms, searchTerms) => { +  const docBuilder = DOCUMENTATION_OPTIONS.BUILDER; +  const docUrlRoot = DOCUMENTATION_OPTIONS.URL_ROOT; +  const docFileSuffix = DOCUMENTATION_OPTIONS.FILE_SUFFIX; +  const docLinkSuffix = DOCUMENTATION_OPTIONS.LINK_SUFFIX; +  const showSearchSummary = DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY; + +  const [docName, title, anchor, descr] = item; + +  let listItem = document.createElement("li"); +  let requestUrl; +  let linkUrl; +  if (docBuilder === "dirhtml") { +    // dirhtml builder +    let dirname = docName + "/"; +    if (dirname.match(/\/index\/$/)) +      dirname = dirname.substring(0, dirname.length - 6); +    else if (dirname === "index/") dirname = ""; +    requestUrl = docUrlRoot + dirname; +    linkUrl = requestUrl; +  } else { +    // normal html builders +    requestUrl = docUrlRoot + docName + docFileSuffix; +    linkUrl = docName + docLinkSuffix; +  } +  const params = new URLSearchParams(); +  params.set("highlight", [...highlightTerms].join(" ")); +  let linkEl = listItem.appendChild(document.createElement("a")); +  linkEl.href = linkUrl + "?" + params.toString() + anchor; +  linkEl.innerHTML = title; +  if (descr) +    listItem.appendChild(document.createElement("span")).innerText = +      " (" + descr + ")"; +  else if (showSearchSummary) +    fetch(requestUrl) +      .then((responseData) => responseData.text()) +      .then((data) => { +        if (data) +          listItem.appendChild( +            Search.makeSearchSummary(data, searchTerms, highlightTerms) +          ); +      }); +  Search.output.appendChild(listItem); +}; +const _finishSearch = (resultCount) => { +  Search.stopPulse(); +  Search.title.innerText = _("Search Results"); +  if (!resultCount) +    Search.status.innerText = Documentation.gettext( +      "Your search did not match any documents. Please make sure that all words are spelled correctly and that you've selected enough categories." +    ); +  else +    Search.status.innerText = _( +      `Search finished, found ${resultCount} page(s) matching the search query.` +    ); +}; +const _displayNextItem = ( +  results, +  resultCount, +  highlightTerms, +  searchTerms +) => { +  // results left, load the summary and display it +  // this is intended to be dynamic (don't sub resultsCount) +  if (results.length) { +    _displayItem(results.pop(), highlightTerms, searchTerms); +    setTimeout( +      () => _displayNextItem(results, resultCount, highlightTerms, searchTerms), +      5 +    );    } +  // search finished, update title and status message +  else _finishSearch(resultCount); +}; + +/** + * Default splitQuery function. Can be overridden in ``sphinx.search`` with a + * custom function per language. + * + * The regular expression works by splitting the string on consecutive characters + * that are not Unicode letters, numbers, underscores, or emoji characters. + * This is the same as ``\W+`` in Python, preserving the surrogate pair area. + */ +if (typeof splitQuery === "undefined") { +  var splitQuery = (query) => query +      .split(/[^\p{Letter}\p{Number}_\p{Emoji_Presentation}]+/gu) +      .filter(term => term)  // remove remaining empty strings  }  /**   * Search Module   */ -var Search = { - -  _index : null, -  _queued_query : null, -  _pulse_status : -1, - -  htmlToText : function(htmlString) { -      var virtualDocument = document.implementation.createHTMLDocument('virtual'); -      var htmlElement = $(htmlString, virtualDocument); -      htmlElement.find('.headerlink').remove(); -      docContent = htmlElement.find('[role=main]')[0]; -      if(docContent === undefined) { -          console.warn("Content block not found. Sphinx search tries to obtain it " + -                       "via '[role=main]'. Could you check your theme or template."); -          return ""; -      } -      return docContent.textContent || docContent.innerText; +const Search = { +  _index: null, +  _queued_query: null, +  _pulse_status: -1, + +  htmlToText: (htmlString) => { +    const htmlElement = document +      .createRange() +      .createContextualFragment(htmlString); +    _removeChildren(htmlElement.querySelectorAll(".headerlink")); +    const docContent = htmlElement.querySelector('[role="main"]'); +    if (docContent !== undefined) return docContent.textContent; +    console.warn( +      "Content block not found. Sphinx search tries to obtain it via '[role=main]'. Could you check your theme or template." +    ); +    return "";    }, -  init : function() { -      var params = $.getQueryParameters(); -      if (params.q) { -          var query = params.q[0]; -          $('input[name="q"]')[0].value = query; -          this.performSearch(query); -      } +  init: () => { +    const query = new URLSearchParams(window.location.search).get("q"); +    document +      .querySelectorAll('input[name="q"]') +      .forEach((el) => (el.value = query)); +    if (query) Search.performSearch(query);    }, -  loadIndex : function(url) { -    $.ajax({type: "GET", url: url, data: null, -            dataType: "script", cache: true, -            complete: function(jqxhr, textstatus) { -              if (textstatus != "success") { -                document.getElementById("searchindexloader").src = url; -              } -            }}); -  }, +  loadIndex: (url) => +    (document.body.appendChild(document.createElement("script")).src = url), -  setIndex : function(index) { -    var q; -    this._index = index; -    if ((q = this._queued_query) !== null) { -      this._queued_query = null; -      Search.query(q); +  setIndex: (index) => { +    Search._index = index; +    if (Search._queued_query !== null) { +      const query = Search._queued_query; +      Search._queued_query = null; +      Search.query(query);      }    }, -  hasIndex : function() { -      return this._index !== null; -  }, +  hasIndex: () => Search._index !== null, -  deferQuery : function(query) { -      this._queued_query = query; -  }, +  deferQuery: (query) => (Search._queued_query = query), -  stopPulse : function() { -      this._pulse_status = 0; -  }, +  stopPulse: () => (Search._pulse_status = -1), -  startPulse : function() { -    if (this._pulse_status >= 0) -        return; -    function pulse() { -      var i; +  startPulse: () => { +    if (Search._pulse_status >= 0) return; + +    const pulse = () => {        Search._pulse_status = (Search._pulse_status + 1) % 4; -      var dotString = ''; -      for (i = 0; i < Search._pulse_status; i++) -        dotString += '.'; -      Search.dots.text(dotString); -      if (Search._pulse_status > -1) -        window.setTimeout(pulse, 500); -    } +      Search.dots.innerText = ".".repeat(Search._pulse_status); +      if (Search._pulse_status >= 0) window.setTimeout(pulse, 500); +    };      pulse();    },    /**     * perform a search for something (or wait until index is loaded)     */ -  performSearch : function(query) { +  performSearch: (query) => {      // create the required interface elements -    this.out = $('#search-results'); -    this.title = $('<h2>' + _('Searching') + '</h2>').appendTo(this.out); -    this.dots = $('<span></span>').appendTo(this.title); -    this.status = $('<p class="search-summary"> </p>').appendTo(this.out); -    this.output = $('<ul class="search"/>').appendTo(this.out); - -    $('#search-progress').text(_('Preparing search...')); -    this.startPulse(); +    const searchText = document.createElement("h2"); +    searchText.textContent = _("Searching"); +    const searchSummary = document.createElement("p"); +    searchSummary.classList.add("search-summary"); +    searchSummary.innerText = ""; +    const searchList = document.createElement("ul"); +    searchList.classList.add("search"); + +    const out = document.getElementById("search-results"); +    Search.title = out.appendChild(searchText); +    Search.dots = Search.title.appendChild(document.createElement("span")); +    Search.status = out.appendChild(searchSummary); +    Search.output = out.appendChild(searchList); + +    const searchProgress = document.getElementById("search-progress"); +    // Some themes don't use the search progress node +    if (searchProgress) { +      searchProgress.innerText = _("Preparing search..."); +    } +    Search.startPulse();      // index already loaded, the browser was quick! -    if (this.hasIndex()) -      this.query(query); -    else -      this.deferQuery(query); +    if (Search.hasIndex()) Search.query(query); +    else Search.deferQuery(query);    },    /**     * execute search (requires search index to be loaded)     */ -  query : function(query) { -    var i; - -    // stem the searchterms and add them to the correct list -    var stemmer = new Stemmer(); -    var searchterms = []; -    var excluded = []; -    var hlterms = []; -    var tmp = splitQuery(query); -    var objectterms = []; -    for (i = 0; i < tmp.length; i++) { -      if (tmp[i] !== "") { -          objectterms.push(tmp[i].toLowerCase()); -      } +  query: (query) => { +    // stem the search terms and add them to the correct list +    const stemmer = new Stemmer(); +    const searchTerms = new Set(); +    const excludedTerms = new Set(); +    const highlightTerms = new Set(); +    const objectTerms = new Set(splitQuery(query.toLowerCase().trim())); +    splitQuery(query.trim()).forEach((queryTerm) => { +      const queryTermLower = queryTerm.toLowerCase(); + +      // maybe skip this "word" +      // stopwords array is from language_data.js +      if ( +        stopwords.indexOf(queryTermLower) !== -1 || +        queryTerm.match(/^\d+$/) +      ) +        return; -      if ($u.indexOf(stopwords, tmp[i].toLowerCase()) != -1 || tmp[i] === "") { -        // skip this "word" -        continue; -      }        // stem the word -      var word = stemmer.stemWord(tmp[i].toLowerCase()); -      var toAppend; +      let word = stemmer.stemWord(queryTermLower);        // select the correct list -      if (word[0] == '-') { -        toAppend = excluded; -        word = word.substr(1); -      } +      if (word[0] === "-") excludedTerms.add(word.substr(1));        else { -        toAppend = searchterms; -        hlterms.push(tmp[i].toLowerCase()); +        searchTerms.add(word); +        highlightTerms.add(queryTermLower);        } -      // only add if not already in the list -      if (!$u.contains(toAppend, word)) -        toAppend.push(word); -    } -    var highlightstring = '?highlight=' + $.urlencode(hlterms.join(" ")); - -    // console.debug('SEARCH: searching for:'); -    // console.info('required: ', searchterms); -    // console.info('excluded: ', excluded); +    }); -    // prepare search -    var terms = this._index.terms; -    var titleterms = this._index.titleterms; +    // console.debug("SEARCH: searching for:"); +    // console.info("required: ", [...searchTerms]); +    // console.info("excluded: ", [...excludedTerms]); -    // array of [filename, title, anchor, descr, score] -    var results = []; -    $('#search-progress').empty(); +    // array of [docname, title, anchor, descr, score, filename] +    let results = []; +    _removeChildren(document.getElementById("search-progress"));      // lookup as object -    for (i = 0; i < objectterms.length; i++) { -      var others = [].concat(objectterms.slice(0, i), -                             objectterms.slice(i+1, objectterms.length)); -      results = results.concat(this.performObjectSearch(objectterms[i], others)); -    } +    objectTerms.forEach((term) => +      results.push(...Search.performObjectSearch(term, objectTerms)) +    );      // lookup as search terms in fulltext -    results = results.concat(this.performTermsSearch(searchterms, excluded, terms, titleterms)); +    results.push(...Search.performTermsSearch(searchTerms, excludedTerms));      // let the scorer override scores with a custom scoring function -    if (Scorer.score) { -      for (i = 0; i < results.length; i++) -        results[i][4] = Scorer.score(results[i]); -    } +    if (Scorer.score) results.forEach((item) => (item[4] = Scorer.score(item)));      // now sort the results by score (in opposite order of appearance, since the      // display function below uses pop() to retrieve items) and then      // alphabetically -    results.sort(function(a, b) { -      var left = a[4]; -      var right = b[4]; -      if (left > right) { -        return 1; -      } else if (left < right) { -        return -1; -      } else { +    results.sort((a, b) => { +      const leftScore = a[4]; +      const rightScore = b[4]; +      if (leftScore === rightScore) {          // same score: sort alphabetically -        left = a[1].toLowerCase(); -        right = b[1].toLowerCase(); -        return (left > right) ? -1 : ((left < right) ? 1 : 0); +        const leftTitle = a[1].toLowerCase(); +        const rightTitle = b[1].toLowerCase(); +        if (leftTitle === rightTitle) return 0; +        return leftTitle > rightTitle ? -1 : 1; // inverted is intentional        } +      return leftScore > rightScore ? 1 : -1;      }); +    // remove duplicate search results +    // note the reversing of results, so that in the case of duplicates, the highest-scoring entry is kept +    let seen = new Set(); +    results = results.reverse().reduce((acc, result) => { +      let resultStr = result.slice(0, 4).concat([result[5]]).map(v => String(v)).join(','); +      if (!seen.has(resultStr)) { +        acc.push(result); +        seen.add(resultStr); +      } +      return acc; +    }, []); + +    results = results.reverse(); +      // for debugging      //Search.lastresults = results.slice();  // a copy -    //console.info('search results:', Search.lastresults); +    // console.info("search results:", Search.lastresults);      // print the results -    var resultCount = results.length; -    function displayNextItem() { -      // results left, load the summary and display it -      if (results.length) { -        var item = results.pop(); -        var listItem = $('<li></li>'); -        var requestUrl = ""; -        var linkUrl = ""; -        if (DOCUMENTATION_OPTIONS.BUILDER === 'dirhtml') { -          // dirhtml builder -          var dirname = item[0] + '/'; -          if (dirname.match(/\/index\/$/)) { -            dirname = dirname.substring(0, dirname.length-6); -          } else if (dirname == 'index/') { -            dirname = ''; -          } -          requestUrl = DOCUMENTATION_OPTIONS.URL_ROOT + dirname; -          linkUrl = requestUrl; - -        } else { -          // normal html builders -          requestUrl = DOCUMENTATION_OPTIONS.URL_ROOT + item[0] + DOCUMENTATION_OPTIONS.FILE_SUFFIX; -          linkUrl = item[0] + DOCUMENTATION_OPTIONS.LINK_SUFFIX; -        } -        listItem.append($('<a/>').attr('href', -            linkUrl + -            highlightstring + item[2]).html(item[1])); -        if (item[3]) { -          listItem.append($('<span> (' + item[3] + ')</span>')); -          Search.output.append(listItem); -          setTimeout(function() { -            displayNextItem(); -          }, 5); -        } else if (DOCUMENTATION_OPTIONS.SHOW_SEARCH_SUMMARY) { -          $.ajax({url: requestUrl, -                  dataType: "text", -                  complete: function(jqxhr, textstatus) { -                    var data = jqxhr.responseText; -                    if (data !== '' && data !== undefined) { -                      var summary = Search.makeSearchSummary(data, searchterms, hlterms); -                      if (summary) { -                        listItem.append(summary); -                      } -                    } -                    Search.output.append(listItem); -                    setTimeout(function() { -                      displayNextItem(); -                    }, 5); -                  }}); -        } else { -          // just display title -          Search.output.append(listItem); -          setTimeout(function() { -            displayNextItem(); -          }, 5); -        } -      } -      // search finished, update title and status message -      else { -        Search.stopPulse(); -        Search.title.text(_('Search Results')); -        if (!resultCount) -          Search.status.text(_('Your search did not match any documents. Please make sure that all words are spelled correctly and that you\'ve selected enough categories.')); -        else -            Search.status.text(_('Search finished, found %s page(s) matching the search query.').replace('%s', resultCount)); -        Search.status.fadeIn(500); -      } -    } -    displayNextItem(); +    _displayNextItem(results, results.length, highlightTerms, searchTerms);    },    /**     * search for object names     */ -  performObjectSearch : function(object, otherterms) { -    var filenames = this._index.filenames; -    var docnames = this._index.docnames; -    var objects = this._index.objects; -    var objnames = this._index.objnames; -    var titles = this._index.titles; - -    var i; -    var results = []; - -    for (var prefix in objects) { -      for (var iMatch = 0; iMatch != objects[prefix].length; ++iMatch) { -        var match = objects[prefix][iMatch]; -        var name = match[4]; -        var fullname = (prefix ? prefix + '.' : '') + name; -        var fullnameLower = fullname.toLowerCase() -        if (fullnameLower.indexOf(object) > -1) { -          var score = 0; -          var parts = fullnameLower.split('.'); -          // check for different match types: exact matches of full name or -          // "last name" (i.e. last dotted part) -          if (fullnameLower == object || parts[parts.length - 1] == object) { -            score += Scorer.objNameMatch; -          // matches in last name -          } else if (parts[parts.length - 1].indexOf(object) > -1) { -            score += Scorer.objPartialMatch; -          } -          var objname = objnames[match[1]][2]; -          var title = titles[match[0]]; -          // If more than one term searched for, we require other words to be -          // found in the name/title/description -          if (otherterms.length > 0) { -            var haystack = (prefix + ' ' + name + ' ' + -                            objname + ' ' + title).toLowerCase(); -            var allfound = true; -            for (i = 0; i < otherterms.length; i++) { -              if (haystack.indexOf(otherterms[i]) == -1) { -                allfound = false; -                break; -              } -            } -            if (!allfound) { -              continue; -            } -          } -          var descr = objname + _(', in ') + title; - -          var anchor = match[3]; -          if (anchor === '') -            anchor = fullname; -          else if (anchor == '-') -            anchor = objnames[match[1]][1] + '-' + fullname; -          // add custom score for some objects according to scorer -          if (Scorer.objPrio.hasOwnProperty(match[2])) { -            score += Scorer.objPrio[match[2]]; -          } else { -            score += Scorer.objPrioDefault; -          } -          results.push([docnames[match[0]], fullname, '#'+anchor, descr, score, filenames[match[0]]]); -        } +  performObjectSearch: (object, objectTerms) => { +    const filenames = Search._index.filenames; +    const docNames = Search._index.docnames; +    const objects = Search._index.objects; +    const objNames = Search._index.objnames; +    const titles = Search._index.titles; + +    const results = []; + +    const objectSearchCallback = (prefix, match) => { +      const name = match[4] +      const fullname = (prefix ? prefix + "." : "") + name; +      const fullnameLower = fullname.toLowerCase(); +      if (fullnameLower.indexOf(object) < 0) return; + +      let score = 0; +      const parts = fullnameLower.split("."); + +      // check for different match types: exact matches of full name or +      // "last name" (i.e. last dotted part) +      if (fullnameLower === object || parts.slice(-1)[0] === object) +        score += Scorer.objNameMatch; +      else if (parts.slice(-1)[0].indexOf(object) > -1) +        score += Scorer.objPartialMatch; // matches in last name + +      const objName = objNames[match[1]][2]; +      const title = titles[match[0]]; + +      // If more than one term searched for, we require other words to be +      // found in the name/title/description +      const otherTerms = new Set(objectTerms); +      otherTerms.delete(object); +      if (otherTerms.size > 0) { +        const haystack = `${prefix} ${name} ${objName} ${title}`.toLowerCase(); +        if ( +          [...otherTerms].some((otherTerm) => haystack.indexOf(otherTerm) < 0) +        ) +          return;        } -    } +      let anchor = match[3]; +      if (anchor === "") anchor = fullname; +      else if (anchor === "-") anchor = objNames[match[1]][1] + "-" + fullname; + +      const descr = objName + _(", in ") + title; + +      // add custom score for some objects according to scorer +      if (Scorer.objPrio.hasOwnProperty(match[2])) +        score += Scorer.objPrio[match[2]]; +      else score += Scorer.objPrioDefault; + +      results.push([ +        docNames[match[0]], +        fullname, +        "#" + anchor, +        descr, +        score, +        filenames[match[0]], +      ]); +    }; +    Object.keys(objects).forEach((prefix) => +      objects[prefix].forEach((array) => +        objectSearchCallback(prefix, array) +      ) +    );      return results;    },    /** -   * See https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions -   */ -  escapeRegExp : function(string) { -    return string.replace(/[.*+\-?^${}()|[\]\\]/g, '\\$&'); // $& means the whole matched string -  }, - -  /**     * search for full-text terms in the index     */ -  performTermsSearch : function(searchterms, excluded, terms, titleterms) { -    var docnames = this._index.docnames; -    var filenames = this._index.filenames; -    var titles = this._index.titles; +  performTermsSearch: (searchTerms, excludedTerms) => { +    // prepare search +    const terms = Search._index.terms; +    const titleTerms = Search._index.titleterms; +    const docNames = Search._index.docnames; +    const filenames = Search._index.filenames; +    const titles = Search._index.titles; -    var i, j, file; -    var fileMap = {}; -    var scoreMap = {}; -    var results = []; +    const scoreMap = new Map(); +    const fileMap = new Map();      // perform the search on the required terms -    for (i = 0; i < searchterms.length; i++) { -      var word = searchterms[i]; -      var files = []; -      var _o = [ -        {files: terms[word], score: Scorer.term}, -        {files: titleterms[word], score: Scorer.title} +    searchTerms.forEach((word) => { +      const files = []; +      const arr = [ +        { files: terms[word], score: Scorer.term }, +        { files: titleTerms[word], score: Scorer.title },        ];        // add support for partial matches        if (word.length > 2) { -        var word_regex = this.escapeRegExp(word); -        for (var w in terms) { -          if (w.match(word_regex) && !terms[word]) { -            _o.push({files: terms[w], score: Scorer.partialTerm}) -          } -        } -        for (var w in titleterms) { -          if (w.match(word_regex) && !titleterms[word]) { -              _o.push({files: titleterms[w], score: Scorer.partialTitle}) -          } -        } +        const escapedWord = _escapeRegExp(word); +        Object.keys(terms).forEach((term) => { +          if (term.match(escapedWord) && !terms[word]) +            arr.push({ files: terms[term], score: Scorer.partialTerm }); +        }); +        Object.keys(titleTerms).forEach((term) => { +          if (term.match(escapedWord) && !titleTerms[word]) +            arr.push({ files: titleTerms[word], score: Scorer.partialTitle }); +        });        }        // no match but word was a required one -      if ($u.every(_o, function(o){return o.files === undefined;})) { -        break; -      } +      if (arr.every((record) => record.files === undefined)) return; +        // found search word in contents -      $u.each(_o, function(o) { -        var _files = o.files; -        if (_files === undefined) -          return - -        if (_files.length === undefined) -          _files = [_files]; -        files = files.concat(_files); - -        // set score for the word in each file to Scorer.term -        for (j = 0; j < _files.length; j++) { -          file = _files[j]; -          if (!(file in scoreMap)) -            scoreMap[file] = {}; -          scoreMap[file][word] = o.score; -        } +      arr.forEach((record) => { +        if (record.files === undefined) return; + +        let recordFiles = record.files; +        if (recordFiles.length === undefined) recordFiles = [recordFiles]; +        files.push(...recordFiles); + +        // set score for the word in each file +        recordFiles.forEach((file) => { +          if (!scoreMap.has(file)) scoreMap.set(file, {}); +          scoreMap.get(file)[word] = record.score; +        });        });        // create the mapping -      for (j = 0; j < files.length; j++) { -        file = files[j]; -        if (file in fileMap && fileMap[file].indexOf(word) === -1) -          fileMap[file].push(word); -        else -          fileMap[file] = [word]; -      } -    } +      files.forEach((file) => { +        if (fileMap.has(file) && fileMap.get(file).indexOf(word) === -1) +          fileMap.get(file).push(word); +        else fileMap.set(file, [word]); +      }); +    });      // now check if the files don't contain excluded terms -    for (file in fileMap) { -      var valid = true; - +    const results = []; +    for (const [file, wordList] of fileMap) {        // check if all requirements are matched -      var filteredTermCount = // as search terms with length < 3 are discarded: ignore -        searchterms.filter(function(term){return term.length > 2}).length + +      // as search terms with length < 3 are discarded +      const filteredTermCount = [...searchTerms].filter( +        (term) => term.length > 2 +      ).length;        if ( -        fileMap[file].length != searchterms.length && -        fileMap[file].length != filteredTermCount -      ) continue; +        wordList.length !== searchTerms.size && +        wordList.length !== filteredTermCount +      ) +        continue;        // ensure that none of the excluded terms is in the search result -      for (i = 0; i < excluded.length; i++) { -        if (terms[excluded[i]] == file || -            titleterms[excluded[i]] == file || -            $u.contains(terms[excluded[i]] || [], file) || -            $u.contains(titleterms[excluded[i]] || [], file)) { -          valid = false; -          break; -        } -      } +      if ( +        [...excludedTerms].some( +          (term) => +            terms[term] === file || +            titleTerms[term] === file || +            (terms[term] || []).includes(file) || +            (titleTerms[term] || []).includes(file) +        ) +      ) +        break; -      // if we have still a valid result we can add it to the result list -      if (valid) { -        // select one (max) score for the file. -        // for better ranking, we should calculate ranking by using words statistics like basic tf-idf... -        var score = $u.max($u.map(fileMap[file], function(w){return scoreMap[file][w]})); -        results.push([docnames[file], titles[file], '', null, score, filenames[file]]); -      } +      // select one (max) score for the file. +      const score = Math.max(...wordList.map((w) => scoreMap.get(file)[w])); +      // add result to the result list +      results.push([ +        docNames[file], +        titles[file], +        "", +        null, +        score, +        filenames[file], +      ]);      }      return results;    }, @@ -492,34 +499,33 @@ var Search = {    /**     * helper function to return a node containing the     * search summary for a given text. keywords is a list -   * of stemmed words, hlwords is the list of normal, unstemmed +   * of stemmed words, highlightWords is the list of normal, unstemmed     * words. the first one is used to find the occurrence, the     * latter for highlighting it.     */ -  makeSearchSummary : function(htmlText, keywords, hlwords) { -    var text = Search.htmlToText(htmlText); -    if (text == "") { -      return null; -    } -    var textLower = text.toLowerCase(); -    var start = 0; -    $.each(keywords, function() { -      var i = textLower.indexOf(this.toLowerCase()); -      if (i > -1) -        start = i; -    }); -    start = Math.max(start - 120, 0); -    var excerpt = ((start > 0) ? '...' : '') + -      $.trim(text.substr(start, 240)) + -      ((start + 240 - text.length) ? '...' : ''); -    var rv = $('<p class="context"></p>').text(excerpt); -    $.each(hlwords, function() { -      rv = rv.highlightText(this, 'highlighted'); -    }); -    return rv; -  } +  makeSearchSummary: (htmlText, keywords, highlightWords) => { +    const text = Search.htmlToText(htmlText).toLowerCase(); +    if (text === "") return null; + +    const actualStartPosition = [...keywords] +      .map((k) => text.indexOf(k.toLowerCase())) +      .filter((i) => i > -1) +      .slice(-1)[0]; +    const startWithContext = Math.max(actualStartPosition - 120, 0); + +    const top = startWithContext === 0 ? "" : "..."; +    const tail = startWithContext + 240 < text.length ? "..." : ""; + +    let summary = document.createElement("div"); +    summary.classList.add("context"); +    summary.innerText = top + text.substr(startWithContext, 240).trim() + tail; + +    highlightWords.forEach((highlightWord) => +      _highlightText(summary, highlightWord, "highlighted") +    ); + +    return summary; +  },  }; -$(document).ready(function() { -  Search.init(); -}); +_ready(Search.init); diff --git a/v7.1.3/changelog.html b/v7.1.3/changelog.html index 1e337056..60d32e29 100644 --- a/v7.1.3/changelog.html +++ b/v7.1.3/changelog.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /><link rel="prev" title="site_api" href="output/botcore.site_api.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Changelog - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="changelog"> -<h1>Changelog<a class="headerlink" href="#changelog" title="Permalink to this headline">#</a></h1> +<h1>Changelog<a class="headerlink" href="#changelog" title="Permalink to this heading">#</a></h1>  <section id="Next 7.x feature release">  <h2 style="margin-bottom: 0.3em;"><a class="reference external" href="https://github.com/python-discord/bot-core/releases/tag/vmaster">Next 7.x feature release</a></h2><ul class="simple">  <li><p>[<span style="color: #4070A0;">Support</span>]<span> </span><a class="reference external" href="https://github.com/python-discord/bot-core/issues/79">#79</a><span>:</span> Restore on-site changelog.</p></li> @@ -476,6 +476,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.3/genindex.html b/v7.1.3/genindex.html index bc51233e..bf5ae4e6 100644 --- a/v7.1.3/genindex.html +++ b/v7.1.3/genindex.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="#" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Index - Bot Core v7.1.3</title> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Index - Bot Core v7.1.3</title>  <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" /> @@ -700,6 +700,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.3/index.html b/v7.1.3/index.html index 7c0c5046..93e413ac 100644 --- a/v7.1.3/index.html +++ b/v7.1.3/index.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /><link rel="next" title="Botcore" href="output/botcore.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,10 +271,10 @@          </div>          <article role="main">            <section id="bot-core-project-documentation"> -<h1>Bot Core Project Documentation<a class="headerlink" href="#bot-core-project-documentation" title="Permalink to this headline">#</a></h1> +<h1>Bot Core Project Documentation<a class="headerlink" href="#bot-core-project-documentation" title="Permalink to this heading">#</a></h1>  </section>  <section id="reference"> -<h1>Reference<a class="headerlink" href="#reference" title="Permalink to this headline">#</a></h1> +<h1>Reference<a class="headerlink" href="#reference" title="Permalink to this heading">#</a></h1>  <div class="toctree-wrapper compound">  <p class="caption" role="heading"><span class="caption-text">Modules:</span></p>  <ul> @@ -300,7 +300,7 @@  </div>  </section>  <section id="extras"> -<h1>Extras<a class="headerlink" href="#extras" title="Permalink to this headline">#</a></h1> +<h1>Extras<a class="headerlink" href="#extras" title="Permalink to this heading">#</a></h1>  <ul class="simple">  <li><p><a class="reference internal" href="genindex.html"><span class="std std-ref">Index</span></a></p></li>  <li><p><a class="reference internal" href="search.html"><span class="std std-ref">Search Page</span></a></p></li> @@ -353,6 +353,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.3/index_redirect.html b/v7.1.3/index_redirect.html index 3530f19f..ad000222 100644 --- a/v7.1.3/index_redirect.html +++ b/v7.1.3/index_redirect.html @@ -1,5 +1,5 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head>      <script>window.location.replace("./main/index.html")</script> @@ -7,7 +7,7 @@      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" /> @@ -57,6 +57,7 @@  <script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.3/output/botcore.async_stats.html b/v7.1.3/output/botcore.async_stats.html index 7c84e8f6..ba20def2 100644 --- a/v7.1.3/output/botcore.async_stats.html +++ b/v7.1.3/output/botcore.async_stats.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="site_api" href="botcore.site_api.html" /><link rel="prev" title="scheduling" href="botcore.utils.scheduling.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>async_stats - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,12 +271,12 @@          </div>          <article role="main">            <section id="module-botcore.async_stats"> -<span id="async-stats"></span><h1>async_stats<a class="headerlink" href="#module-botcore.async_stats" title="Permalink to this headline">#</a></h1> +<span id="async-stats"></span><h1>async_stats<a class="headerlink" href="#module-botcore.async_stats" title="Permalink to this heading">#</a></h1>  <p>An async transport method for statsd communication.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.async_stats.AsyncStatsClient">  <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">AsyncStatsClient</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">loop</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">host</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">'localhost'</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">port</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">8125</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">prefix</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/c503586db31b26a66c7f63bf05ab0e30a9365fef/botcore/async_stats.py#L12-L55"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.async_stats.AsyncStatsClient" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-class docutils literal notranslate"><span class="pre">statsd.client.base.StatsClientBase</span></code></a></p> +<dd><p>Bases: <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-class docutils literal notranslate"><span class="pre">StatsClientBase</span></code></a></p>  <p>An async implementation of <a class="reference external" href="https://statsd.readthedocs.io/en/v3.3/reference.html#statsd.client.base.StatsClientBase" title="(in Python StatsD - Edited by Python Discord to extend statsd base objects to also allow referencing statsd.client.base.StatsClientBase v3.3)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">statsd.client.base.StatsClientBase</span></code></a> that supports async stat communication.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.async_stats.AsyncStatsClient.__init__"> @@ -364,6 +364,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.3/output/botcore.exts.html b/v7.1.3/output/botcore.exts.html index 4e8b3b82..16288d3a 100644 --- a/v7.1.3/output/botcore.exts.html +++ b/v7.1.3/output/botcore.exts.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Utils" href="botcore.utils.html" /><link rel="prev" title="Botcore" href="botcore.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Exts - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.exts"> -<span id="exts"></span><h1>Exts<a class="headerlink" href="#module-botcore.exts" title="Permalink to this headline">#</a></h1> +<span id="exts"></span><h1>Exts<a class="headerlink" href="#module-botcore.exts" title="Permalink to this heading">#</a></h1>  <p>Reusable Discord cogs.</p>  </section> @@ -329,6 +329,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.3/output/botcore.html b/v7.1.3/output/botcore.html index c0392e5c..0b5b4ba8 100644 --- a/v7.1.3/output/botcore.html +++ b/v7.1.3/output/botcore.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Exts" href="botcore.exts.html" /><link rel="prev" title="Bot Core Project Documentation" href="../index.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Botcore - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,12 +271,12 @@          </div>          <article role="main">            <section id="module-botcore"> -<span id="botcore"></span><h1>Botcore<a class="headerlink" href="#module-botcore" title="Permalink to this headline">#</a></h1> +<span id="botcore"></span><h1>Botcore<a class="headerlink" href="#module-botcore" title="Permalink to this heading">#</a></h1>  <p>Useful utilities and tools for Discord bot development.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.BotBase">  <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">BotBase</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="o"><span class="pre">*</span></span><span class="n"><span class="pre">args</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">guild_id</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">allowed_roles</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">http_session</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">redis_session</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">api_client</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">statsd_url</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">None</span></span></em>, <em class="sig-param"><span class="o"><span class="pre">**</span></span><span class="n"><span class="pre">kwargs</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/c503586db31b26a66c7f63bf05ab0e30a9365fef/botcore/__init__.py#L36-L290"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.BotBase" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Bot" title="(in discord.py v2.0.0a)"><code class="xref py py-class docutils literal notranslate"><span class="pre">discord.ext.commands.bot.Bot</span></code></a></p> +<dd><p>Bases: <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/ext/commands/api.html#discord.ext.commands.Bot" title="(in discord.py v2.0.0a)"><code class="xref py py-class docutils literal notranslate"><span class="pre">Bot</span></code></a></p>  <p>A sub-class that implements many common features that Python Discord bots use.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.BotBase.__init__"> @@ -454,7 +454,7 @@ gateway event before giving up and thus not populating the cache for unavailable  </dd></dl>  <section id="subpackages"> -<h2>Subpackages<a class="headerlink" href="#subpackages" title="Permalink to this headline">#</a></h2> +<h2>Subpackages<a class="headerlink" href="#subpackages" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.exts.html">Exts</a></li> @@ -474,7 +474,7 @@ gateway event before giving up and thus not populating the cache for unavailable  </div>  </section>  <section id="submodules"> -<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this headline">#</a></h2> +<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.async_stats.html">async_stats</a></li> @@ -558,6 +558,7 @@ gateway event before giving up and thus not populating the cache for unavailable  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.3/output/botcore.site_api.html b/v7.1.3/output/botcore.site_api.html index 37302838..9ea1b479 100644 --- a/v7.1.3/output/botcore.site_api.html +++ b/v7.1.3/output/botcore.site_api.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="Changelog" href="../changelog.html" /><link rel="prev" title="async_stats" href="botcore.async_stats.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>site_api - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.site_api"> -<span id="site-api"></span><h1>site_api<a class="headerlink" href="#module-botcore.site_api" title="Permalink to this headline">#</a></h1> +<span id="site-api"></span><h1>site_api<a class="headerlink" href="#module-botcore.site_api" title="Permalink to this heading">#</a></h1>  <p>An API wrapper around the Site API.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.site_api.APIClient"> @@ -500,6 +500,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.3/output/botcore.utils.caching.html b/v7.1.3/output/botcore.utils.caching.html index 3b709a7b..35def672 100644 --- a/v7.1.3/output/botcore.utils.caching.html +++ b/v7.1.3/output/botcore.utils.caching.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="channel" href="botcore.utils.channel.html" /><link rel="prev" title="Utils" href="botcore.utils.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>caching - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.caching"> -<span id="caching"></span><h1>caching<a class="headerlink" href="#module-botcore.utils.caching" title="Permalink to this headline">#</a></h1> +<span id="caching"></span><h1>caching<a class="headerlink" href="#module-botcore.utils.caching" title="Permalink to this heading">#</a></h1>  <p>Utilities related to custom caches.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.caching.AsyncCache"> @@ -377,6 +377,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.3/output/botcore.utils.channel.html b/v7.1.3/output/botcore.utils.channel.html index 6a144769..5dc322ae 100644 --- a/v7.1.3/output/botcore.utils.channel.html +++ b/v7.1.3/output/botcore.utils.channel.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="logging" href="botcore.utils.logging.html" /><link rel="prev" title="caching" href="botcore.utils.caching.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>channel - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.channel"> -<span id="channel"></span><h1>channel<a class="headerlink" href="#module-botcore.utils.channel" title="Permalink to this headline">#</a></h1> +<span id="channel"></span><h1>channel<a class="headerlink" href="#module-botcore.utils.channel" title="Permalink to this heading">#</a></h1>  <p>Useful helper functions for interacting with various discord channel objects.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.channel.get_or_fetch_channel"> @@ -377,6 +377,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.3/output/botcore.utils.html b/v7.1.3/output/botcore.utils.html index 55bd6a80..7933c0a3 100644 --- a/v7.1.3/output/botcore.utils.html +++ b/v7.1.3/output/botcore.utils.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="caching" href="botcore.utils.caching.html" /><link rel="prev" title="Exts" href="botcore.exts.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Utils - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils"> -<span id="utils"></span><h1>Utils<a class="headerlink" href="#module-botcore.utils" title="Permalink to this headline">#</a></h1> +<span id="utils"></span><h1>Utils<a class="headerlink" href="#module-botcore.utils" title="Permalink to this heading">#</a></h1>  <p>Useful utilities and tools for Discord bot development.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.apply_monkey_patches"> @@ -310,7 +310,7 @@ that will act as top-level groups rather than being aliases of the command’s g  </dd></dl>  <section id="submodules"> -<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this headline">#</a></h2> +<h2>Submodules<a class="headerlink" href="#submodules" title="Permalink to this heading">#</a></h2>  <div class="toctree-wrapper compound">  <ul>  <li class="toctree-l1"><a class="reference internal" href="botcore.utils.caching.html">caching</a></li> @@ -397,6 +397,7 @@ that will act as top-level groups rather than being aliases of the command’s g  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.3/output/botcore.utils.logging.html b/v7.1.3/output/botcore.utils.logging.html index 0d386a28..1b03a7a1 100644 --- a/v7.1.3/output/botcore.utils.logging.html +++ b/v7.1.3/output/botcore.utils.logging.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="members" href="botcore.utils.members.html" /><link rel="prev" title="channel" href="botcore.utils.channel.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>logging - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,12 +271,12 @@          </div>          <article role="main">            <section id="module-botcore.utils.logging"> -<span id="logging"></span><h1>logging<a class="headerlink" href="#module-botcore.utils.logging" title="Permalink to this headline">#</a></h1> +<span id="logging"></span><h1>logging<a class="headerlink" href="#module-botcore.utils.logging" title="Permalink to this heading">#</a></h1>  <p>Common logging related functions.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.logging.CustomLogger">  <em class="property"><span class="pre">class</span><span class="w"> </span></em><span class="sig-name descname"><span class="pre">CustomLogger</span></span><span class="sig-paren">(</span><em class="sig-param"><span class="n"><span class="pre">name</span></span></em>, <em class="sig-param"><span class="n"><span class="pre">level</span></span><span class="o"><span class="pre">=</span></span><span class="default_value"><span class="pre">0</span></span></em><span class="sig-paren">)</span><a class="reference external" href="https://github.com/python-discord/bot-core/blob/c503586db31b26a66c7f63bf05ab0e30a9365fef/botcore/utils/logging.py#L14-L33"><span class="viewcode-link"><span class="pre">[source]</span></span></a><a class="headerlink" href="#botcore.utils.logging.CustomLogger" title="Permalink to this definition">#</a></dt> -<dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">logging.Logger</span></code></a></p> +<dd><p>Bases: <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-class docutils literal notranslate"><span class="pre">Logger</span></code></a></p>  <p>Custom implementation of the <a class="reference external" href="https://docs.python.org/3/library/logging.html#logging.Logger" title="(in Python v3.10)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">logging.Logger</span></code></a> class with an added <a class="reference internal" href="#botcore.utils.logging.CustomLogger.trace" title="botcore.utils.logging.CustomLogger.trace"><code class="xref py py-obj docutils literal notranslate"><span class="pre">trace</span></code></a> method.</p>  <dl class="py method">  <dt class="sig sig-object py" id="botcore.utils.logging.CustomLogger.trace"> @@ -375,6 +375,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.3/output/botcore.utils.members.html b/v7.1.3/output/botcore.utils.members.html index f9082a36..b76c3b86 100644 --- a/v7.1.3/output/botcore.utils.members.html +++ b/v7.1.3/output/botcore.utils.members.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="regex" href="botcore.utils.regex.html" /><link rel="prev" title="logging" href="botcore.utils.logging.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>members - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.members"> -<span id="members"></span><h1>members<a class="headerlink" href="#module-botcore.utils.members" title="Permalink to this headline">#</a></h1> +<span id="members"></span><h1>members<a class="headerlink" href="#module-botcore.utils.members" title="Permalink to this heading">#</a></h1>  <p>Useful helper functions for interactin with <a class="reference external" href="https://discordpy.readthedocs.io/en/latest/api.html#discord.Member" title="(in discord.py v2.0.0a)"><code class="xref py py-obj docutils literal notranslate"><span class="pre">discord.Member</span></code></a> objects.</p>  <dl class="py function">  <dt class="sig sig-object py" id="botcore.utils.members.get_or_fetch_member"> @@ -362,6 +362,7 @@  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.3/output/botcore.utils.regex.html b/v7.1.3/output/botcore.utils.regex.html index 0a114f5e..1b46b50d 100644 --- a/v7.1.3/output/botcore.utils.regex.html +++ b/v7.1.3/output/botcore.utils.regex.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="scheduling" href="botcore.utils.scheduling.html" /><link rel="prev" title="members" href="botcore.utils.members.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>regex - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.regex"> -<span id="regex"></span><h1>regex<a class="headerlink" href="#module-botcore.utils.regex" title="Permalink to this headline">#</a></h1> +<span id="regex"></span><h1>regex<a class="headerlink" href="#module-botcore.utils.regex" title="Permalink to this heading">#</a></h1>  <p>Common regular expressions.</p>  <dl class="py data">  <dt class="sig sig-object py" id="botcore.utils.regex.DISCORD_INVITE"> @@ -359,6 +359,7 @@ such as <a class="reference external" href="https://docs.python.org/3/library/ur  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.3/output/botcore.utils.scheduling.html b/v7.1.3/output/botcore.utils.scheduling.html index d27a0ee3..fefe4fce 100644 --- a/v7.1.3/output/botcore.utils.scheduling.html +++ b/v7.1.3/output/botcore.utils.scheduling.html @@ -1,11 +1,11 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><meta name="generator" content="Docutils 0.17.1: http://docutils.sourceforge.net/" />  <link rel="index" title="Index" href="../genindex.html" /><link rel="search" title="Search" href="../search.html" /><link rel="next" title="async_stats" href="botcore.async_stats.html" /><link rel="prev" title="regex" href="botcore.utils.regex.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>scheduling - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="../_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="../_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -271,7 +271,7 @@          </div>          <article role="main">            <section id="module-botcore.utils.scheduling"> -<span id="scheduling"></span><h1>scheduling<a class="headerlink" href="#module-botcore.utils.scheduling" title="Permalink to this headline">#</a></h1> +<span id="scheduling"></span><h1>scheduling<a class="headerlink" href="#module-botcore.utils.scheduling" title="Permalink to this heading">#</a></h1>  <p>Generic python scheduler.</p>  <dl class="py class">  <dt class="sig sig-object py" id="botcore.utils.scheduling.Scheduler"> @@ -484,6 +484,7 @@ otherwise the running loop is used.</p>  </div><script data-url_root="../" id="documentation_options" src="../_static/documentation_options.js"></script>      <script src="../_static/jquery.js"></script>      <script src="../_static/underscore.js"></script> +    <script src="../_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="../_static/doctools.js"></script>      <script src="../_static/scripts/furo.js"></script>      <script src="../_static/changelog.js"></script> diff --git a/v7.1.3/py-modindex.html b/v7.1.3/py-modindex.html index f2dad835..6772bc2b 100644 --- a/v7.1.3/py-modindex.html +++ b/v7.1.3/py-modindex.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Python Module Index - Bot Core v7.1.3</title> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Python Module Index - Bot Core v7.1.3</title>  <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" /> @@ -385,6 +385,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.3/search.html b/v7.1.3/search.html index e97d6a1c..9c2c023e 100644 --- a/v7.1.3/search.html +++ b/v7.1.3/search.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="#" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/><title>Search - Bot Core v7.1.3</title><link rel="stylesheet" type="text/css" href="_static/pygments.css" /> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/><title>Search - Bot Core v7.1.3</title><link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo-extensions.css?digest=30d1aed668e5c3a91c3e3bf6a60b675221979f0e" />      <link rel="stylesheet" type="text/css" href="_static/changelog.css" /> @@ -315,6 +315,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script> diff --git a/v7.1.3/searchindex.js b/v7.1.3/searchindex.js index d5b30ae9..3592dc17 100644 --- a/v7.1.3/searchindex.js +++ b/v7.1.3/searchindex.js @@ -1 +1 @@ -Search.setIndex({docnames:["changelog","index","output/botcore","output/botcore.async_stats","output/botcore.exts","output/botcore.site_api","output/botcore.utils","output/botcore.utils.caching","output/botcore.utils.channel","output/botcore.utils.logging","output/botcore.utils.members","output/botcore.utils.regex","output/botcore.utils.scheduling"],envversion:{"sphinx.domains.c":2,"sphinx.domains.changeset":1,"sphinx.domains.citation":1,"sphinx.domains.cpp":5,"sphinx.domains.index":1,"sphinx.domains.javascript":2,"sphinx.domains.math":2,"sphinx.domains.python":3,"sphinx.domains.rst":2,"sphinx.domains.std":2,"sphinx.ext.intersphinx":1,"sphinx.ext.todo":2,sphinx:56},filenames:["changelog.rst","index.rst","output/botcore.rst","output/botcore.async_stats.rst","output/botcore.exts.rst","output/botcore.site_api.rst","output/botcore.utils.rst","output/botcore.utils.caching.rst","output/botcore.utils.channel.rst","output/botcore.utils.logging.rst","output/botcore.utils.members.rst","output/botcore.utils.regex.rst","output/botcore.utils.scheduling.rst"],objects:{"":[[2,0,0,"-","botcore"]],"botcore.BotBase":[[2,2,1,"","__init__"],[2,2,1,"","add_cog"],[2,2,1,"","add_command"],[2,2,1,"","clear"],[2,2,1,"","close"],[2,2,1,"","load_extensions"],[2,2,1,"","log_to_dev_log"],[2,2,1,"","on_guild_available"],[2,2,1,"","on_guild_unavailable"],[2,2,1,"","ping_services"],[2,2,1,"","remove_command"],[2,2,1,"","setup_hook"],[2,2,1,"","wait_until_guild_available"]],"botcore.StartupError":[[2,2,1,"","__init__"]],"botcore.async_stats":[[3,1,1,"","AsyncStatsClient"]],"botcore.async_stats.AsyncStatsClient":[[3,2,1,"","__init__"],[3,2,1,"","create_socket"]],"botcore.site_api":[[5,1,1,"","APIClient"],[5,3,1,"","ResponseCodeError"]],"botcore.site_api.APIClient":[[5,2,1,"","__init__"],[5,2,1,"","close"],[5,2,1,"","delete"],[5,2,1,"","get"],[5,2,1,"","maybe_raise_for_status"],[5,2,1,"","patch"],[5,2,1,"","post"],[5,2,1,"","put"],[5,2,1,"","request"]],"botcore.site_api.ResponseCodeError":[[5,2,1,"","__init__"],[5,2,1,"","__str__"]],"botcore.utils":[[6,4,1,"","apply_monkey_patches"],[7,0,0,"-","caching"],[8,0,0,"-","channel"],[9,0,0,"-","logging"],[10,0,0,"-","members"],[11,0,0,"-","regex"],[12,0,0,"-","scheduling"],[6,4,1,"","unqualify"]],"botcore.utils.caching":[[7,1,1,"","AsyncCache"]],"botcore.utils.caching.AsyncCache":[[7,2,1,"","__call__"],[7,2,1,"","__init__"],[7,2,1,"","clear"]],"botcore.utils.channel":[[8,4,1,"","get_or_fetch_channel"],[8,4,1,"","is_in_category"]],"botcore.utils.logging":[[9,1,1,"","CustomLogger"],[9,4,1,"","get_logger"]],"botcore.utils.logging.CustomLogger":[[9,2,1,"","trace"]],"botcore.utils.members":[[10,4,1,"","get_or_fetch_member"],[10,4,1,"","handle_role_change"]],"botcore.utils.regex":[[11,5,1,"","DISCORD_INVITE"],[11,5,1,"","FORMATTED_CODE_REGEX"],[11,5,1,"","RAW_CODE_REGEX"]],"botcore.utils.scheduling":[[12,1,1,"","Scheduler"],[12,4,1,"","create_task"]],"botcore.utils.scheduling.Scheduler":[[12,2,1,"","__contains__"],[12,2,1,"","__init__"],[12,2,1,"","cancel"],[12,2,1,"","cancel_all"],[12,2,1,"","schedule"],[12,2,1,"","schedule_at"],[12,2,1,"","schedule_later"]],botcore:[[2,1,1,"","BotBase"],[2,3,1,"","StartupError"],[3,0,0,"-","async_stats"],[4,0,0,"-","exts"],[5,0,0,"-","site_api"],[6,0,0,"-","utils"]]},objnames:{"0":["py","module","Python module"],"1":["py","class","Python class"],"2":["py","method","Python method"],"3":["py","exception","Python exception"],"4":["py","function","Python function"],"5":["py","data","Python data"]},objtypes:{"0":"py:module","1":"py:class","2":"py:method","3":"py:exception","4":"py:function","5":"py:data"},terms:{"0":[0,7,9],"0a0":0,"1":[0,5,9],"10th":0,"12":0,"128":7,"14th":0,"17th":0,"18th":0,"19th":0,"2":[0,2],"2021":0,"2022":0,"204":5,"20th":0,"21st":0,"22nd":0,"24th":0,"25th":0,"26th":0,"29":0,"2nd":0,"3":[0,5],"32":0,"34":0,"35":0,"37":0,"39":0,"3rd":0,"4":0,"403":6,"42":0,"4cbe8f5":0,"5":0,"54":0,"56":0,"5a06fa5":0,"5th":0,"6":0,"61":0,"63":0,"64":0,"65":0,"66":0,"68":0,"69":0,"7":[0,5],"72":0,"75":0,"78":0,"79":0,"8125":3,"987235d":0,"9th":0,"abstract":0,"break":0,"case":0,"class":[0,2,3,5,7,9,12],"do":8,"float":12,"function":[0,2,7,8,9,10,12],"import":0,"int":[2,3,7,8,12],"long":12,"na\u00efv":12,"new":[3,5,7,12],"public":0,"return":[0,2,3,5,6,7,8,9,10,12],"true":[5,9,12],A:[2,5,6,7,8,12],And:5,If:[2,5,12],It:6,No:5,Not:2,The:[2,3,5,6,7,8,9,10,12],To:[2,9],_:0,__call__:7,__contains__:12,__init__:[0,2,3,5,7,12],__str__:5,_guild_avail:0,abstracteventloop:[3,12],act:6,actual:0,ad:[0,6,9],add:[0,2],add_cog:2,add_command:2,add_rol:10,after:12,aiohttp:[0,2,5],alia:[2,6],alias:[2,6],all:[0,2,3,6,12],all_command:2,all_extens:2,allow:[0,2],allowed_rol:2,alpha:0,alreadi:12,also:[0,6],an:[0,2,3,5,6,7,8,9,12],ani:[5,11,12],api:[0,5,10],api_cli:[0,2],apicli:[0,2,5],appear:2,appli:[6,7],apply_monkey_patch:[0,6],april:0,ar:[2,7,11],arg:[2,9],arg_offset:7,argument:[5,6,7,9,10],around:5,async:[0,2,3,5,7,8,10],async_rediscach:2,async_stat:[1,2],asynccach:7,asyncio:[0,3,12],asyncresolv:0,asyncstatscli:[2,3],asyncstatsdcli:0,attempt:[2,8,10],attribut:6,authent:5,autogener:0,avail:[0,2],avoid:[0,2],await:[10,12],awar:12,back:0,base:[0,2,3,5,7,9,12],basic:0,becaus:2,becom:2,befor:[0,2,12],behaviour:0,being:6,between:0,block:[0,11],bool:[5,8,12],bot:[0,2,6,8],botbas:[0,2],botcor:[0,1],broke:0,bug:0,bump:0,cach:[0,2,6,8,10],calcul:12,call:[2,12],callabl:[7,10],can:[0,12],cancel:12,cancel_al:12,cannot:[0,2],captur:[0,11],categori:8,category_id:8,caus:[2,6],chang:0,changelog:1,channel:[0,2,6],channel_id:8,charact:0,check:[5,8,12],chunk:0,ci:0,clear:[2,7],client:[0,2,3],clientrespons:5,clientsess:[2,5],close:[0,2,5,12],cloudflar:6,code:[0,11],cog:[0,2,4],command:[0,2,6,8],commit:0,common:[0,2,6,9,11],commun:3,connect:[0,2,3],connector:2,constructor:5,contain:12,content:5,core:0,coro:[10,12],coroutin:[7,10,12],correct:0,could:10,crash:0,creat:[0,2,3,7,12],create_datagram_endpoint:3,create_socket:[2,3],create_task:12,creation:0,current:12,custom:[0,7,9],customlogg:9,datetim:12,deadlock:2,deal:0,decemb:0,decor:7,delai:12,delet:[5,7],depend:8,deprec:0,detect:0,dev:2,develop:[2,6],dict:5,directli:0,discord:[0,2,4,6,8,10,11],discord_invit:11,disnak:0,distinguish:12,django:5,doc:0,document:0,doesn:12,don:[0,12],done:12,dummi:[0,2],dynam:0,each:0,edit:2,either:2,elsewher:12,emit:2,empti:2,endpoint:5,ensur:[2,11],entir:[0,2],equival:5,error:[2,5,6,10],event:[0,2,3,12],event_loop:12,exc_info:9,exce:7,except:[2,5,9,12],execut:12,exist:12,expect:10,express:11,ext:[0,1,2,6,8],extend:0,extens:[0,2],extra:5,fail:8,failur:10,featur:[0,2],februari:0,fetch:[8,10],fifo:7,fix:0,forbidden:8,format:11,formatted_code_regex:11,forum:0,found:[10,12],from:[0,2,3,5,6,8,10,12],futur:12,gatewai:2,gener:[2,12],get:[0,5,8,10],get_logg:9,get_or_fetch_channel:8,get_or_fetch_memb:10,give:2,given:[2,3,6,8,9,10,12],group:[6,11],guild:[0,2,10],guild_available_but_cache_empti:2,guild_creat:2,guild_id:2,guildchannel:8,ha:6,handl:[0,10,12],handle_role_chang:10,hashabl:12,have:[8,9],heavi:6,help:0,helper:[8,10],hook:0,host:3,houston:9,how:[7,12],http:[5,11],http_session:2,httpexcept:8,id:[2,8,12],identifi:12,ignor:6,immedi:12,implement:[2,3,7,9],inadequ:2,index:1,indic:10,individu:2,inform:[1,9],init:[0,2,3],initi:[5,12],initialis:[2,7],instanc:[0,2,5,7,8,9,12],instanti:[2,12],instead:[2,12],intend:10,interact:8,interactin:10,interest:9,intern:[2,6],intersphinx:0,invalid:8,invaliddata:8,invit:[0,11],is_in_categori:8,item:7,its:2,januari:0,json:5,keep:12,kei:7,keyword:[5,6,9],known:12,kwarg:[2,5,9,12],latest:0,level:[6,9],lint:0,list:2,ll:12,load:[0,2,6],load_extens:2,localhost:3,log:[0,2,6,12],log_to_dev_log:2,logger:[0,9],logic:0,longer:0,look:12,loop:[2,3,12],lot:0,lru:7,made:0,mai:[0,7],main:0,make:[0,9],mani:[0,2,7],manipul:0,manual:2,march:0,match:2,max_siz:7,maximum:7,maybe_raise_for_statu:5,member:[0,2,6],member_id:10,mention:2,messag:[2,9,12],method:[3,5,6,9],migrat:0,modul:[0,2,6,12],monkei:[0,6],move:0,msg:9,multivers:0,must:12,mypi:9,name:[2,6,9,12],namespac:[0,12],next:0,non:5,none:[2,3,5,6,7,9,10,12],normal:2,notabl:0,notfound:8,notic:0,novemb:0,now:[0,12],number:0,object:[5,6,7,8,10,12],offset:7,ok:5,older:0,on_guild_avail:2,on_guild_unavail:2,on_readi:2,onc:7,one:[0,2],onli:2,oper:[2,12],option:[2,3,5,7,9,10],order:[7,12],other:12,otherwis:12,our:[0,6],out:0,output:11,own:0,packag:[0,6],page:1,pagin:0,paramet:[2,3,5,6,7,8,9,10,12],pars:11,pass:[0,5,9,10,12],past:12,patch:[0,5,6],pattern:11,permiss:[0,8],ping:2,ping_servic:2,pleas:11,poetri:0,popul:2,port:[0,3],posit:7,post:5,prefix:3,prematur:12,prevent:12,problem:9,process:0,provid:[7,12],put:5,py:0,pyproject:0,python:[2,12],qualifi:6,quot:11,rais:[5,8,10,12],raise_for_statu:5,ran:2,rather:6,raw:11,raw_code_regex:11,re:[2,12],readi:2,real:0,receiv:[5,8],recognis:9,reconnect:0,redi:0,redis_sess:2,redissess:2,refer:0,regex:[0,2,6],regular:11,relat:[7,9],releas:0,remov:[0,2],remove_command:2,remove_rol:10,repo:0,represent:5,request:[5,11],request_text:5,requir:[2,12],resolut:0,resolv:2,respons:5,response_json:5,response_text:5,responsecodeerror:5,restor:0,result:[0,12],retriev:8,reusabl:4,revert:[0,5],role:[2,10],root:[2,6],root_alias:6,rout:6,run:12,s:[0,6,7,9,11,12],safe:0,same:12,sanitis:11,save:2,schedul:[0,2,6],schedule_at:12,schedule_lat:12,search:1,second:[2,12],self:2,send:5,send_typ:6,sequenc:6,server:[2,11],servic:2,session:[0,2,5],session_kwarg:5,set:2,setup:[0,2],setup_hook:2,sever:9,share:0,should:[0,2,5],should_rais:5,similar:11,singl:0,site:[0,5],site_api:[0,1,2],site_api_token:5,site_api_url:5,size:7,so:[0,6],socket:3,sole:10,someth:11,sourc:[2,3,5,6,7,8,9,10,11,12],specifi:0,sphinx:0,start:[0,2,12],startup:2,startuperror:2,stat:3,statsclientbas:3,statsd:[0,2,3],statsd_url:[0,2],still:2,store:[6,7],str:[2,3,5,6,9,12],string:5,sub:[0,2],submodul:1,subpackag:1,subtract:12,suggest:12,support:[0,3,6,12],suppressed_except:12,t:[0,12],target:7,task:[0,2,12],task_id:12,text:5,textchannel:8,than:6,thei:2,them:[2,12],thi:[0,2,6,8,10,11,12],thrown:6,thu:2,time:[0,12],timeout:0,timezon:12,token:5,toml:0,tool:[2,6],top:6,trace:[0,9],track:12,transport:3,tupl:12,two:6,type:[2,3,5,6,7,8,9,10,12],unavail:2,unawait:12,under:6,union:12,uniqu:12,unknown:8,unqualifi:[0,6],unschedul:12,until:[2,11],up:[0,2],url:[0,2,5],urllib:11,us:[0,2,3,5,6,8,9,10,11,12],utc:12,util:[0,1,2,7,9],valu:9,valueerror:5,variou:8,version:0,wa:[8,12],wait:[2,12],wait_for:2,wait_until_guild_avail:2,warn:12,we:[9,10],when:[0,2,3,5,6,7,12],whether:[5,8],which:[0,6,12],whitespac:[0,11],within:[0,2],work:0,worker:6,wrap:[7,12],wrapper:[0,5,12],x:0,you:[8,11]},titles:["Changelog","Bot Core Project Documentation","Botcore","async_stats","Exts","site_api","Utils","caching","channel","logging","members","regex","scheduling"],titleterms:{async_stat:3,bot:1,botcor:2,cach:7,changelog:0,channel:8,core:1,document:1,ext:4,extra:1,log:9,member:10,modul:1,project:1,refer:1,regex:11,schedul:12,site_api:5,submodul:[2,6],subpackag:2,util:6}})
\ No newline at end of file +Search.setIndex({"docnames": ["changelog", "index", "output/botcore", "output/botcore.async_stats", "output/botcore.exts", "output/botcore.site_api", "output/botcore.utils", "output/botcore.utils.caching", "output/botcore.utils.channel", "output/botcore.utils.logging", "output/botcore.utils.members", "output/botcore.utils.regex", "output/botcore.utils.scheduling"], "filenames": ["changelog.rst", "index.rst", "output/botcore.rst", "output/botcore.async_stats.rst", "output/botcore.exts.rst", "output/botcore.site_api.rst", "output/botcore.utils.rst", "output/botcore.utils.caching.rst", "output/botcore.utils.channel.rst", "output/botcore.utils.logging.rst", "output/botcore.utils.members.rst", "output/botcore.utils.regex.rst", "output/botcore.utils.scheduling.rst"], "titles": ["Changelog", "Bot Core Project Documentation", "Botcore", "async_stats", "Exts", "site_api", "Utils", "caching", "channel", "logging", "members", "regex", "scheduling"], "terms": {"next": 0, "7": [0, 5], "x": 0, "featur": [0, 2], "releas": 0, "support": [0, 3, 6, 12], "79": 0, "restor": 0, "site": [0, 5], "add": [0, 2], "sphinx": 0, "multivers": 0, "make": [0, 9], "avail": [0, 2], "older": 0, "doc": 0, "version": 0, "1": [0, 5, 9], "0": [0, 7, 9], "24th": 0, "mai": [0, 7], "2022": 0, "78": 0, "bump": 0, "discord": [0, 2, 4, 6, 8, 10, 11], "py": 0, "4cbe8f5": 0, "thi": [0, 2, 6, 8, 10, 11, 12], "fix": 0, "bug": 0, "permiss": [0, 8], "resolut": 0, "when": [0, 2, 3, 5, 6, 7, 12], "deal": 0, "time": [0, 12], "out": 0, "member": [0, 2, 6], "10th": 0, "break": 0, "75": 0, "invit": [0, 11], "regex": [0, 2, 6], "longer": 0, "return": [0, 2, 3, 5, 6, 7, 8, 9, 10, 12], "url": [0, 2, 5], "safe": 0, "result": [0, 12], "refer": 0, "document": 0, "handl": [0, 10, 12], "captur": [0, 11], "all": [0, 2, 3, 6, 12], "charact": 0, "up": [0, 2], "whitespac": [0, 11], "6": 0, "4": 0, "26th": 0, "april": 0, "72": 0, "5a06fa5": 0, "notabl": 0, "one": [0, 2], "commit": 0, "dynam": 0, "extend": 0, "timeout": 0, "guild": [0, 2, 10], "chunk": 0, "base": [0, 2, 3, 5, 7, 9, 12], "number": 0, "so": [0, 6], "should": [0, 2, 5], "actual": 0, "work": 0, "our": [0, 6], "now": [0, 12], "3": [0, 5], "2": [0, 2], "25th": 0, "69": 0, "us": [0, 2, 3, 5, 6, 8, 9, 10, 11, 12], "statsd_url": [0, 2], "get": [0, 5, 8, 10], "pass": [0, 5, 9, 10, 12], "botbas": [0, 2], "21st": 0, "68": 0, "correct": 0, "pyproject": 0, "toml": 0, "directli": 0, "main": 0, "don": [0, 12], "t": [0, 12], "load": [0, 2, 6], "modul": [0, 2, 6, 12], "start": [0, 2, 12], "_": 0, "66": 0, "each": 0, "cog": [0, 2, 4], "s": [0, 6, 7, 9, 11, 12], "own": 0, "task": [0, 2, 12], "avoid": [0, 2], "singl": 0, "crash": 0, "entir": [0, 2], "process": 0, "20th": 0, "65": 0, "unqualifi": [0, 6], "botcor": [0, 1], "util": [0, 1, 2, 7, 9], "namespac": [0, 12], "bot": [0, 2, 6, 8], "manipul": 0, "extens": [0, 2], "19th": 0, "64": 0, "987235d": 0, "revert": [0, 5], "chang": 0, "help": 0, "command": [0, 2, 6, 8], "behaviour": 0, "broke": 0, "custom": [0, 7, 9], "pagin": 0, "also": [0, 6], "basic": 0, "forum": 0, "channel": [0, 2, 6], "5": 0, "18th": 0, "63": 0, "allow": [0, 2], "an": [0, 2, 3, 5, 6, 7, 8, 9, 12], "api_cli": [0, 2], "__init__": [0, 2, 3, 5, 7, 12], "specifi": 0, "site_api": [0, 1, 2], "apicli": [0, 2, 5], "instanc": [0, 2, 5, 7, 8, 9, 12], "61": 0, "reconnect": 0, "redi": 0, "session": [0, 2, 5], "setup": [0, 2], "close": [0, 2, 5, 12], "5th": 0, "56": 0, "move": 0, "creation": 0, "asyncio": [0, 3, 12], "event": [0, 2, 3, 12], "_guild_avail": 0, "within": [0, 2], "hook": 0, "deprec": 0, "notic": 0, "creat": [0, 2, 3, 7, 12], "dummi": [0, 2], "asyncstatsdcli": 0, "befor": [0, 2, 12], "connect": [0, 2, 3], "real": 0, "case": 0, "cannot": [0, 2], "made": 0, "init": [0, 2, 3], "2nd": 0, "54": 0, "aiohttp": [0, 2, 5], "asyncresolv": 0, "async": [0, 2, 3, 5, 7, 8, 10], "42": 0, "remov": [0, 2], "public": 0, "statsd": [0, 2, 3], "client": [0, 2, 3], "ext": [0, 1, 2, 6, 8], "sub": [0, 2], "class": [0, 2, 3, 5, 7, 9, 12], "which": [0, 6, 12], "abstract": 0, "lot": 0, "logic": 0, "share": 0, "between": 0, "latest": 0, "alpha": 0, "14th": 0, "march": 0, "39": 0, "migrat": 0, "back": 0, "37": 0, "log": [0, 2, 6, 12], "trace": [0, 9], "import": 0, "can": [0, 12], "function": [0, 2, 7, 8, 9, 10, 12], "3rd": 0, "35": 0, "apply_monkey_patch": [0, 6], "februari": 0, "34": 0, "port": [0, 3], "api": [0, 5, 10], "wrapper": [0, 5, 12], "from": [0, 2, 3, 5, 6, 8, 10, 12], "repo": 0, "22nd": 0, "32": 0, "0a0": 0, "disnak": 0, "29": 0, "mani": [0, 2, 7], "common": [0, 2, 6, 9, 11], "cach": [0, 2, 6, 8, 10], "logger": [0, 9], "schedul": [0, 2, 6], "monkei": [0, 6], "patch": [0, 5, 6], "ad": [0, 6, 9], "intersphinx": 0, "9th": 0, "januari": 0, "12": 0, "code": [0, 11], "block": [0, 11], "detect": 0, "decemb": 0, "2021": 0, "autogener": 0, "17th": 0, "novemb": 0, "core": 0, "packag": [0, 6], "poetri": 0, "lint": 0, "ci": 0, "subpackag": 1, "submodul": 1, "async_stat": [1, 2], "index": 1, "search": 1, "page": 1, "inform": [1, 9], "changelog": 1, "tool": [2, 6], "develop": [2, 6], "arg": [2, 9], "guild_id": 2, "allowed_rol": 2, "http_session": 2, "redis_sess": 2, "none": [2, 3, 5, 6, 7, 9, 10, 12], "kwarg": [2, 5, 9, 12], "sourc": [2, 3, 5, 6, 7, 8, 9, 10, 11, 12], "A": [2, 5, 6, 7, 8, 12], "implement": [2, 3, 7, 9], "python": [2, 12], "initialis": [2, 7], "paramet": [2, 3, 5, 6, 7, 8, 9, 10, 12], "int": [2, 3, 7, 8, 12], "The": [2, 3, 5, 6, 7, 8, 9, 10, 12], "id": [2, 8, 12], "wait_until_guild_avail": 2, "list": 2, "role": [2, 10], "mention": 2, "clientsess": [2, 5], "option": [2, 3, 5, 7, 9, 10], "redissess": 2, "async_rediscach": 2, "str": [2, 3, 5, 6, 9, 12], "server": [2, 11], "If": [2, 5, 12], "given": [2, 3, 6, 8, 9, 10, 12], "add_cog": 2, "oper": [2, 12], "type": [2, 3, 5, 6, 7, 8, 9, 10, 12], "add_command": 2, "normal": 2, "its": 2, "root": [2, 6], "alias": [2, 6], "clear": [2, 7], "Not": 2, "re": [2, 12], "instanti": [2, 12], "instead": [2, 12], "attempt": [2, 8, 10], "connector": 2, "resolv": 2, "load_extens": 2, "save": 2, "them": [2, 12], "self": 2, "all_extens": 2, "ran": 2, "loop": [2, 3, 12], "deadlock": 2, "caus": [2, 6], "wait_for": 2, "call": [2, 12], "log_to_dev_log": 2, "messag": [2, 9, 12], "dev": 2, "on_guild_avail": 2, "set": 2, "intern": [2, 6], "becom": 2, "appear": 2, "still": 2, "empti": 2, "guild_available_but_cache_empti": 2, "emit": 2, "on_guild_unavail": 2, "unavail": 2, "ping_servic": 2, "ping": 2, "requir": [2, 12], "servic": 2, "ensur": [2, 11], "thei": 2, "ar": [2, 7, 11], "remove_command": 2, "name": [2, 6, 9, 12], "alia": [2, 6], "individu": 2, "To": [2, 9], "either": 2, "manual": 2, "edit": 2, "all_command": 2, "setup_hook": 2, "startup": 2, "gener": [2, 12], "asyncstatscli": [2, 3], "create_socket": [2, 3], "wait": [2, 12], "until": [2, 11], "match": 2, "readi": 2, "on_readi": 2, "inadequ": 2, "becaus": 2, "onli": 2, "second": [2, 12], "guild_creat": 2, "gatewai": 2, "give": 2, "thu": 2, "popul": 2, "except": [2, 5, 9, 12], "startuperror": 2, "error": [2, 5, 6, 10], "transport": 3, "method": [3, 5, 6, 9], "commun": 3, "host": 3, "localhost": 3, "8125": 3, "prefix": 3, "statsclientbas": 3, "stat": 3, "new": [3, 5, 7, 12], "abstracteventloop": [3, 12], "create_datagram_endpoint": 3, "socket": 3, "reusabl": 4, "around": 5, "site_api_url": 5, "site_api_token": 5, "session_kwarg": 5, "object": [5, 6, 7, 8, 10, 12], "django": 5, "initi": [5, 12], "token": 5, "authent": 5, "keyword": [5, 6, 9], "argument": [5, 6, 7, 9, 10], "constructor": 5, "delet": [5, 7], "endpoint": 5, "raise_for_statu": 5, "true": [5, 9, 12], "send": 5, "request": [5, 11], "json": 5, "respons": 5, "bool": [5, 8, 12], "whether": [5, 8], "rais": [5, 8, 10, 12], "ok": 5, "ani": [5, 11, 12], "extra": 5, "dict": 5, "204": 5, "No": 5, "content": 5, "equival": 5, "maybe_raise_for_statu": 5, "should_rais": 5, "responsecodeerror": 5, "non": 5, "clientrespons": 5, "check": [5, 8, 12], "post": 5, "put": 5, "http": [5, 11], "response_json": 5, "response_text": 5, "valueerror": 5, "receiv": [5, 8], "And": 5, "request_text": 5, "text": 5, "__str__": 5, "string": 5, "represent": 5, "appli": [6, 7], "group": [6, 11], "root_alias": 6, "two": 6, "sequenc": 6, "act": 6, "top": 6, "level": [6, 9], "rather": 6, "than": 6, "being": 6, "It": 6, "store": [6, 7], "attribut": 6, "send_typ": 6, "ignor": 6, "403": 6, "under": 6, "heavi": 6, "ha": 6, "cloudflar": 6, "worker": 6, "rout": 6, "thrown": 6, "qualifi": 6, "relat": [7, 9], "asynccach": 7, "max_siz": 7, "128": 7, "lru": 7, "coroutin": [7, 10, 12], "onc": 7, "exce": 7, "maximum": 7, "size": 7, "kei": 7, "fifo": 7, "order": [7, 12], "offset": 7, "provid": [7, 12], "__call__": 7, "arg_offset": 7, "decor": 7, "posit": 7, "callabl": [7, 10], "wrap": [7, 12], "target": 7, "how": [7, 12], "item": 7, "helper": [8, 10], "interact": 8, "variou": 8, "get_or_fetch_channel": 8, "channel_id": 8, "fetch": [8, 10], "invaliddata": 8, "unknown": 8, "wa": [8, 12], "httpexcept": 8, "retriev": 8, "fail": 8, "notfound": 8, "invalid": 8, "forbidden": 8, "you": [8, 11], "do": 8, "have": [8, 9], "guildchannel": 8, "is_in_categori": 8, "category_id": 8, "categori": 8, "textchannel": 8, "depend": 8, "customlogg": 9, "msg": 9, "sever": 9, "exc_info": 9, "valu": 9, "houston": 9, "we": [9, 10], "interest": 9, "problem": 9, "get_logg": 9, "mypi": 9, "recognis": 9, "interactin": 10, "get_or_fetch_memb": 10, "member_id": 10, "failur": 10, "indic": 10, "could": 10, "found": [10, 12], "handle_role_chang": 10, "coro": [10, 12], "await": [10, 12], "sole": 10, "expect": 10, "add_rol": 10, "remove_rol": 10, "intend": 10, "regular": 11, "express": 11, "discord_invit": 11, "pattern": 11, "similar": 11, "pleas": 11, "sanitis": 11, "output": 11, "someth": 11, "urllib": 11, "pars": 11, "quot": 11, "formatted_code_regex": 11, "format": 11, "raw_code_regex": 11, "raw": 11, "execut": 12, "keep": 12, "track": 12, "must": 12, "distinguish": 12, "other": 12, "contain": 12, "suggest": 12, "immedi": 12, "futur": 12, "schedule_at": 12, "schedule_lat": 12, "uniqu": 12, "cancel": 12, "prematur": 12, "same": 12, "current": 12, "done": 12, "__contains__": 12, "task_id": 12, "hashabl": 12, "look": 12, "unschedul": 12, "identifi": 12, "warn": 12, "doesn": 12, "exist": 12, "cancel_al": 12, "known": 12, "alreadi": 12, "prevent": 12, "unawait": 12, "ll": 12, "elsewher": 12, "timezon": 12, "awar": 12, "calcul": 12, "subtract": 12, "na\u00efv": 12, "utc": 12, "past": 12, "datetim": 12, "delai": 12, "after": 12, "union": 12, "float": 12, "long": 12, "create_task": 12, "suppressed_except": 12, "event_loop": 12, "otherwis": 12, "run": 12, "tupl": 12}, "objects": {"": [[2, 0, 0, "-", "botcore"]], "botcore": [[2, 1, 1, "", "BotBase"], [2, 3, 1, "", "StartupError"], [3, 0, 0, "-", "async_stats"], [4, 0, 0, "-", "exts"], [5, 0, 0, "-", "site_api"], [6, 0, 0, "-", "utils"]], "botcore.BotBase": [[2, 2, 1, "", "__init__"], [2, 2, 1, "", "add_cog"], [2, 2, 1, "", "add_command"], [2, 2, 1, "", "clear"], [2, 2, 1, "", "close"], [2, 2, 1, "", "load_extensions"], [2, 2, 1, "", "log_to_dev_log"], [2, 2, 1, "", "on_guild_available"], [2, 2, 1, "", "on_guild_unavailable"], [2, 2, 1, "", "ping_services"], [2, 2, 1, "", "remove_command"], [2, 2, 1, "", "setup_hook"], [2, 2, 1, "", "wait_until_guild_available"]], "botcore.StartupError": [[2, 2, 1, "", "__init__"]], "botcore.async_stats": [[3, 1, 1, "", "AsyncStatsClient"]], "botcore.async_stats.AsyncStatsClient": [[3, 2, 1, "", "__init__"], [3, 2, 1, "", "create_socket"]], "botcore.site_api": [[5, 1, 1, "", "APIClient"], [5, 3, 1, "", "ResponseCodeError"]], "botcore.site_api.APIClient": [[5, 2, 1, "", "__init__"], [5, 2, 1, "", "close"], [5, 2, 1, "", "delete"], [5, 2, 1, "", "get"], [5, 2, 1, "", "maybe_raise_for_status"], [5, 2, 1, "", "patch"], [5, 2, 1, "", "post"], [5, 2, 1, "", "put"], [5, 2, 1, "", "request"]], "botcore.site_api.ResponseCodeError": [[5, 2, 1, "", "__init__"], [5, 2, 1, "", "__str__"]], "botcore.utils": [[6, 4, 1, "", "apply_monkey_patches"], [7, 0, 0, "-", "caching"], [8, 0, 0, "-", "channel"], [9, 0, 0, "-", "logging"], [10, 0, 0, "-", "members"], [11, 0, 0, "-", "regex"], [12, 0, 0, "-", "scheduling"], [6, 4, 1, "", "unqualify"]], "botcore.utils.caching": [[7, 1, 1, "", "AsyncCache"]], "botcore.utils.caching.AsyncCache": [[7, 2, 1, "", "__call__"], [7, 2, 1, "", "__init__"], [7, 2, 1, "", "clear"]], "botcore.utils.channel": [[8, 4, 1, "", "get_or_fetch_channel"], [8, 4, 1, "", "is_in_category"]], "botcore.utils.logging": [[9, 1, 1, "", "CustomLogger"], [9, 4, 1, "", "get_logger"]], "botcore.utils.logging.CustomLogger": [[9, 2, 1, "", "trace"]], "botcore.utils.members": [[10, 4, 1, "", "get_or_fetch_member"], [10, 4, 1, "", "handle_role_change"]], "botcore.utils.regex": [[11, 5, 1, "", "DISCORD_INVITE"], [11, 5, 1, "", "FORMATTED_CODE_REGEX"], [11, 5, 1, "", "RAW_CODE_REGEX"]], "botcore.utils.scheduling": [[12, 1, 1, "", "Scheduler"], [12, 4, 1, "", "create_task"]], "botcore.utils.scheduling.Scheduler": [[12, 2, 1, "", "__contains__"], [12, 2, 1, "", "__init__"], [12, 2, 1, "", "cancel"], [12, 2, 1, "", "cancel_all"], [12, 2, 1, "", "schedule"], [12, 2, 1, "", "schedule_at"], [12, 2, 1, "", "schedule_later"]]}, "objtypes": {"0": "py:module", "1": "py:class", "2": "py:method", "3": "py:exception", "4": "py:function", "5": "py:data"}, "objnames": {"0": ["py", "module", "Python module"], "1": ["py", "class", "Python class"], "2": ["py", "method", "Python method"], "3": ["py", "exception", "Python exception"], "4": ["py", "function", "Python function"], "5": ["py", "data", "Python data"]}, "titleterms": {"changelog": 0, "bot": 1, "core": 1, "project": 1, "document": 1, "refer": 1, "modul": 1, "extra": 1, "botcor": 2, "subpackag": 2, "submodul": [2, 6], "async_stat": 3, "ext": 4, "site_api": 5, "util": 6, "cach": 7, "channel": 8, "log": 9, "member": 10, "regex": 11, "schedul": 12}, "envversion": {"sphinx.domains.c": 2, "sphinx.domains.changeset": 1, "sphinx.domains.citation": 1, "sphinx.domains.cpp": 6, "sphinx.domains.index": 1, "sphinx.domains.javascript": 2, "sphinx.domains.math": 2, "sphinx.domains.python": 3, "sphinx.domains.rst": 2, "sphinx.domains.std": 2, "sphinx.ext.intersphinx": 1, "sphinx.ext.todo": 2, "sphinx": 56}})
\ No newline at end of file diff --git a/v7.1.3/versions.html b/v7.1.3/versions.html index 4f91906e..40f9b68b 100644 --- a/v7.1.3/versions.html +++ b/v7.1.3/versions.html @@ -1,10 +1,10 @@  <!doctype html> -<html class="no-js"> +<html class="no-js" lang="en">    <head><meta charset="utf-8"/>      <meta name="viewport" content="width=device-width,initial-scale=1"/>      <meta name="color-scheme" content="light dark"><link rel="index" title="Index" href="genindex.html" /><link rel="search" title="Search" href="search.html" /> -    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-4.5.0, furo 2022.06.21"/> +    <link rel="shortcut icon" href="https://raw.githubusercontent.com/python-discord/branding/main/logos/logo_full/logo_full.min.svg"/><meta name="generator" content="sphinx-5.0.2, furo 2022.06.21"/>          <title>Versions - Bot Core v7.1.3</title>        <link rel="stylesheet" type="text/css" href="_static/pygments.css" />      <link rel="stylesheet" type="text/css" href="_static/styles/furo.css?digest=40978830699223671f4072448e654b5958f38b89" /> @@ -339,6 +339,7 @@  </div><script data-url_root="./" id="documentation_options" src="_static/documentation_options.js"></script>      <script src="_static/jquery.js"></script>      <script src="_static/underscore.js"></script> +    <script src="_static/_sphinx_javascript_frameworks_compat.js"></script>      <script src="_static/doctools.js"></script>      <script src="_static/scripts/furo.js"></script>      <script src="_static/changelog.js"></script>  |