[
  {
    "path": ".babelrc.js",
    "content": "const { NODE_ENV, BABEL_ENV } = process.env\nconst cjs = NODE_ENV === 'test' || BABEL_ENV === 'commonjs'\nconst loose = true\n\nmodule.exports = {\n  presets: [\n    [\n      '@babel/env',\n      {\n        loose,\n        modules: false,\n        exclude: ['@babel/plugin-transform-regenerator'],\n      },\n    ],\n    '@babel/preset-typescript',\n    '@babel/react',\n  ],\n  plugins: [\n    [\n      'const-enum',\n      {\n        transform: 'constObject',\n      },\n    ],\n    'babel-plugin-transform-async-to-promises',\n    cjs && ['@babel/transform-modules-commonjs', { loose }],\n    [\n      '@babel/transform-runtime',\n      {\n        useESModules: !cjs,\n        version: require('./package.json').dependencies[\n          '@babel/runtime'\n        ].replace(/^[^0-9]*/, ''),\n      },\n    ],\n  ].filter(Boolean),\n}\n"
  },
  {
    "path": ".eslintrc",
    "content": "{\n  \"parser\": \"@typescript-eslint/parser\",\n  \"parserOptions\": {\n    \"jsx\": true,\n    \"useJSXTextNode\": true\n  },\n  \"extends\": [\n    // \"plugin:@typescript-eslint/recommended\",\n    \"prettier\"\n  ],\n  \"plugins\": [\"@typescript-eslint\", \"react-hooks\"],\n  \"rules\": {\n    \"@typescript-eslint/explicit-function-return-type\": \"off\",\n    \"@typescript-eslint/explicit-module-boundary-types\": \"off\",\n    \"@typescript-eslint/no-non-null-assertion\": \"off\",\n    \"@typescript-eslint/no-explicit-any\": \"off\",\n    \"react-hooks/rules-of-hooks\": \"error\",\n    \"react-hooks/exhaustive-deps\": \"warn\"\n  }\n}\n"
  },
  {
    "path": ".github/FUNDING.yml",
    "content": "github: tannerlinsley\n"
  },
  {
    "path": ".github/workflows/publish.yml",
    "content": "name: react-charts tests\n\non:\n  push:\n    branches:\n      - 'main'\n      - 'beta'\n  pull_request:\n\njobs:\n  test:\n    name: 'Node ${{ matrix.node }}'\n    runs-on: ubuntu-latest\n    strategy:\n      matrix:\n        node: [12, 14, 16]\n    steps:\n      - uses: actions/checkout@v2\n      - uses: actions/setup-node@v2\n        with:\n          node-version: ${{ matrix.node }}\n      - name: Install dependencies\n        uses: bahmutov/npm-install@v1\n      - run: yarn test:ci\n\n  publish-module:\n    name: 'Publish Module to NPM'\n    # needs: test\n    # publish only when merged in master on original repo, not on PR\n    if: github.repository == 'tanstack/react-charts' && (github.ref == 'refs/heads/main' || github.ref == 'refs/heads/beta')\n    runs-on: ubuntu-latest\n    steps:\n      - uses: actions/checkout@v2\n      - uses: actions/setup-node@v2\n        with:\n          node-version: 14\n          registry-url: https://registry.npmjs.org/\n      - name: Install dependencies\n        uses: bahmutov/npm-install@v1\n      - run: yarn build\n      - run: npx semantic-release@17\n        env:\n          NODE_AUTH_TOKEN: ${{secrets.npm_token}}\n          GH_TOKEN: ${{secrets.GH_TOKEN}}\n"
  },
  {
    "path": ".gitignore",
    "content": "\n# See https://help.github.com/ignore-files/ for more about ignoring files.\n\n# dependencies\nnode_modules\n\n# builds\ntypes\nbuild\ndist\nlib\nes\nartifacts\n.rpt2_cache\ncoverage\n*.tgz\n\n# misc\n.DS_Store\n.env\n.env.local\n.env.development.local\n.env.test.local\n.env.production.local\n.next\n\nnpm-debug.log*\nyarn-debug.log*\nyarn-error.log*\n.history\nsize-plugin.json\nstats-hydration.json\nstats-react.json\nstats.html\n.vscode/settings.json\nstats-react.json\n"
  },
  {
    "path": "LICENSE",
    "content": "MIT License\n\nCopyright (c) 2021 Tanner Linsley\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in all\ncopies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE\nSOFTWARE."
  },
  {
    "path": "README.md",
    "content": "![React Charts Header](https://github.com/TanStack/react-charts/raw/main/media/repo-dark.png)\n\n\n# ⚠️ No Longer Maintained ⚠️\nThis project is no longer actively maintained. No further updates, bug fixes, or support will be provided.\n\n----\n\nSimple, immersive and interactive charts for React\n\n<a href=\"https://twitter.com/intent/tweet?button_hashtag=TanStack\" target=\"\\_parent\">\n  <img alt=\"#TanStack\" src=\"https://img.shields.io/twitter/url?color=%2308a0e9&label=%23TanStack&style=social&url=https%3A%2F%2Ftwitter.com%2Fintent%2Ftweet%3Fbutton_hashtag%3DTanStack\">\n</a>\n<a href=\"https://npmjs.com/package/react-charts\" target=\"\\_parent\">\n  <img alt=\"\" src=\"https://img.shields.io/npm/dm/react-charts.svg\" />\n</a>\n<a href=\"https://bundlephobia.com/result?p=react-charts\" target=\"\\_parent\">\n  <img alt=\"\" src=\"https://badgen.net/bundlephobia/minzip/react-charts\" />\n</a>\n<a href=\"https://discord.com/invite/WrRKjPJ\" target=\"\\_parent\">\n  <img alt=\"\" src=\"https://img.shields.io/badge/Discord-TanStack-%235865F2\" />\n</a>\n<a href=\"https://github.com/react-charts/react-charts\" target=\"\\_parent\">\n  <img alt=\"\" src=\"https://img.shields.io/github/stars/react-charts/react-charts.svg?style=social&label=Star\" />\n</a>\n<a href=\"https://twitter.com/tannerlinsley\" target=\"\\_parent\">\n  <img alt=\"\" src=\"https://img.shields.io/twitter/follow/tannerlinsley.svg?style=social&label=Follow\" />\n</a>\n\n<br />\n<br />\n\nEnjoy this library? Try the entire [TanStack](https://tanstack.com)! [React Table](https://github.com/tannerlinsley/react-table), [React Query](https://github.com/tannerlinsley/react-query), [React Form](https://github.com/tannerlinsley/react-form)\n\n## Visit [react-charts.tanstack.com](https://react-charts.tanstack.com) for docs, guides, API and more!\n\n## Quick Features\n\n- Line Charts\n- Bar Charts\n- Column Charts\n- Bubble Charts\n- Area Charts\n- Axis Stacking\n- Inverted Axes\n- Hyper Responsive\n- Invisibly Powered by D3\n- Declarative\n- Mutliple Axes\n\n### [Become a Sponsor!](https://github.com/sponsors/tannerlinsley/)\n\n# Contributors ✨\n\nThanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):\n\n<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->\n<!-- prettier-ignore-start -->\n<!-- markdownlint-disable -->\n<table>\n  <tr>\n    <td align=\"center\"><a href=\"https://tannerlinsley.com\"><img src=\"https://avatars0.githubusercontent.com/u/5580297?v=4\" width=\"100px;\" alt=\"\"/><br /><sub><b>Tanner Linsley</b></sub></a><br /><a href=\"https://github.com/tannerlinsley/react-charts/commits?author=tannerlinsley\" title=\"Code\">💻</a> <a href=\"#ideas-tannerlinsley\" title=\"Ideas, Planning, & Feedback\">🤔</a> <a href=\"#example-tannerlinsley\" title=\"Examples\">💡</a> <a href=\"#maintenance-tannerlinsley\" title=\"Maintenance\">🚧</a> <a href=\"https://github.com/tannerlinsley/react-charts/pulls?q=is%3Apr+reviewed-by%3Atannerlinsley\" title=\"Reviewed Pull Requests\">👀</a></td>\n  </tr>\n</table>\n\n<!-- markdownlint-enable -->\n<!-- prettier-ignore-end -->\n\n<!-- ALL-CONTRIBUTORS-LIST:END -->\n\nThis project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!\n\n<!-- Force 2 -->\n"
  },
  {
    "path": "docs/.gitignore",
    "content": ".next\n.now\n.env\n.env.*\nnode_modules\n*.log\n.DS_Store\n.vercel"
  },
  {
    "path": "docs/README.md",
    "content": "# React Charts Docs\n\nThis is source code to react-charts.tanstack.com. It is forked from the [Formik](https://formik.org) docs and is built with:\n\n- Next.js\n- MDX\n- Tailwind\n- Algolia\n- Notion\n\n## Running locally\n\n```sh\nyarn install\n```\n\nAt the moment, you need to signup for Notion, and [follow these instructions](https://github.com/ijjk/notion-blog#getting-blog-index-and-token) to get a token and create a blog in order to develop locally. Not ideal, but hopefully will fix soon.\n\nWith tokens and page index in hand, rename `.sample.env` and `.sample.env.build` to just `.env` and `.env.build`. In each one, add respective parameters:\n\n```diff\n-NOTION_TOKEN=XXXX\n+NOTION_TOKEN=<YOUR_TOKEN>\n-BLOG_INDEX_ID=XXXXX\n+BLOG_INDEX_ID=<YOUR_BLOG_INDEX_ID>\n```\n\nNow it will work. Run `yarn dev` to get going.\n\nIf you get stuck or need help, [send a DM to Jared](https://twitter.com/jaredpalmer) on Twitter.\n"
  },
  {
    "path": "docs/jsconfig.json",
    "content": "{\n  \"compilerOptions\": {\n    \"baseUrl\": \"./src\"\n  }\n}\n"
  },
  {
    "path": "docs/next.config.js",
    "content": "const path = require('path')\nconst dotenvLoad = require('dotenv-load')\nconst optimizedImages = require('next-optimized-images')\ndotenvLoad()\n\nconst remarkPlugins = [\n  require('remark-slug'),\n  [\n    require('remark-autolink-headings'),\n    {\n      behavior: 'append',\n      linkProperties: {\n        class: ['anchor'],\n        title: 'Direct link to heading',\n      },\n    },\n  ],\n\n  require('remark-emoji'),\n  require('remark-footnotes'),\n  require('remark-images'),\n  [\n    require('remark-github'),\n    { repository: 'https://github.com/tannerlinsley/react-charts' },\n  ],\n  require('remark-unwrap-images'),\n  [\n    require('remark-toc'),\n    {\n      skip: 'Reference',\n      maxDepth: 6,\n    },\n  ],\n]\n\nmodule.exports = optimizedImages({\n  pageExtensions: ['jsx', 'js', 'mdx', 'md'],\n  env: {\n    GA_TRACKING_ID: process.env.GA_TRACKING_ID || '',\n    SENTRY_RELEASE: process.env.VERCEL_GITHUB_COMMIT_SHA || '',\n  },\n  experimental: {\n    plugins: true,\n    modern: true,\n    rewrites() {\n      return [\n        {\n          source: '/feed.xml',\n          destination: '/_next/static/feed.xml',\n        },\n        {\n          source: '/docs{/}?',\n          destination: '/docs/overview',\n        },\n        {\n          source: '/docs/tag/:tag{/}?',\n          destination: '/docs/tag/:tag/overview',\n        },\n      ]\n    },\n  },\n  webpack: (config, { dev, isServer, ...options }) => {\n    config.module.rules.push({\n      test: /.mdx?$/, // load both .md and .mdx files\n      use: [\n        options.defaultLoaders.babel,\n        {\n          loader: '@mdx-js/loader',\n          options: {\n            remarkPlugins,\n          },\n        },\n        path.join(__dirname, './src/lib/docs/md-loader'),\n      ],\n    })\n\n    // only compile build-rss in production server build\n    if (dev || !isServer) {\n      return config\n    }\n\n    // we're in build mode so enable shared caching for Notion data\n    process.env.USE_CACHE = 'true'\n\n    const originalEntry = config.entry\n    config.entry = async () => {\n      const entries = {\n        ...(await originalEntry()),\n      }\n      // entries['./scripts/build-rss.js'] = './src/lib/build-rss.js'\n      return entries\n    }\n\n    return config\n  },\n  optimizeImages: {\n    /* config for next-optimized-images */\n    mozjpeg: {\n      quality: 70,\n    },\n    optipng: {\n      optimizationLevel: 3,\n    },\n    optimizeImagesInDev: true,\n  },\n})\n"
  },
  {
    "path": "docs/package.json",
    "content": "{\n  \"name\": \"fdocs3\",\n  \"version\": \"1.0.0\",\n  \"main\": \"index.js\",\n  \"author\": \"Jared Palmer <jared@palmer.net>\",\n  \"license\": \"MIT\",\n  \"scripts\": {\n    \"dev\": \"next\",\n    \"build\": \"next build\",\n    \"start\": \"next start\",\n    \"index-docs\": \"node ./.next/serverless/scripts/index-docs.js\"\n  },\n  \"dependencies\": {\n    \"@babel/preset-typescript\": \"^7.10.4\",\n    \"@docsearch/react\": \"1.0.0-alpha.14\",\n    \"@mdx-js/loader\": \"^1.5.1\",\n    \"@mdx-js/mdx\": \"^1.5.1\",\n    \"@mdx-js/react\": \"^1.5.1\",\n    \"@mdx-js/tag\": \"^0.20.3\",\n    \"@next/mdx\": \"^9.4.0\",\n    \"@next/plugin-google-analytics\": \"^9.4.4\",\n    \"@reactions/component\": \"^2.0.2\",\n    \"@visx/responsive\": \"^1.10.1\",\n    \"@zeit/fetch\": \"^6.0.0\",\n    \"@zeit/react-jsx-parser\": \"^2.0.0\",\n    \"async-sema\": \"^3.1.0\",\n    \"body-scroll-lock\": \"^3.0.1\",\n    \"classnames\": \"^2.2.6\",\n    \"copy-to-clipboard\": \"^3.3.1\",\n    \"date-fns\": \"^2.12.0\",\n    \"docsearch.js\": \"^2.6.3\",\n    \"framer-motion\": \"^1.11.1\",\n    \"gray-matter\": \"^4.0.2\",\n    \"imagemin-mozjpeg\": \"^9.0.0\",\n    \"imagemin-optipng\": \"^8.0.0\",\n    \"intersection-observer\": \"^0.10.0\",\n    \"isomorphic-unfetch\": \"^3.0.0\",\n    \"next\": \"^9.4.4\",\n    \"next-images\": \"^1.4.0\",\n    \"next-optimized-images\": \"^2.6.1\",\n    \"node-fetch\": \"^2.6.0\",\n    \"prismjs\": \"^1.20.0\",\n    \"react\": \"^16.13.1\",\n    \"react-dom\": \"^16.13.1\",\n    \"react-icons\": \"^3.9.0\",\n    \"react-live\": \"^2.2.2\",\n    \"rehype-format\": \"^3.0.1\",\n    \"rehype-stringify\": \"^7.0.0\",\n    \"remark\": \"^12.0.0\",\n    \"remark-autolink-headings\": \"^6.0.0\",\n    \"remark-emoji\": \"^2.1.0\",\n    \"remark-footnotes\": \"^1.0.0\",\n    \"remark-github\": \"^9.0.0\",\n    \"remark-images\": \"^2.0.0\",\n    \"remark-slug\": \"^6.0.0\",\n    \"remark-toc\": \"^7.0.0\",\n    \"remark-unwrap-images\": \"^2.0.0\",\n    \"scroll-into-view-if-needed\": \"^2.2.24\",\n    \"semver-regex\": \"^3.1.1\",\n    \"unist-util-visit\": \"^2.0.2\"\n  },\n  \"devDependencies\": {\n    \"@babel/cli\": \"^7.10.4\",\n    \"@babel/core\": \"^7.10.4\",\n    \"@babel/plugin-transform-typescript\": \"^7.10.4\",\n    \"@babel/preset-react\": \"^7.10.4\",\n    \"@tailwindcss/ui\": \"^0.3.0\",\n    \"algoliasearch\": \"3.35.1\",\n    \"babel-preset-react-app\": \"^9.1.2\",\n    \"dotenv-load\": \"^2.0.0\",\n    \"github-slugger\": \"^1.3.0\",\n    \"md5\": \"^2.2.1\",\n    \"mdast-util-to-string\": \"^1.1.0\",\n    \"postcss-preset-env\": \"^6.7.0\",\n    \"remark-parse\": \"^8.0.2\",\n    \"tailwindcss\": \"^1.4.6\",\n    \"unified\": \"^9.0.0\",\n    \"webp-loader\": \"^0.6.0\"\n  },\n  \"engines\": {\n    \"node\": \">=12.x\"\n  }\n}\n"
  },
  {
    "path": "docs/postcss.config.js",
    "content": "module.exports = {\n  plugins: ['tailwindcss', 'postcss-preset-env'],\n};\n"
  },
  {
    "path": "docs/public/robots.txt",
    "content": "User-agent: *\nDisallow:"
  },
  {
    "path": "docs/src/components/ArrowRight.js",
    "content": "import * as React from 'react';\nexport function ArrowRight({\n  fill = '#718096',\n  width = 6,\n  height = 10\n}) {\n  return <svg width={width} height={height} viewBox=\"0 0 6 10\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n      <path d=\"M1.4 8.56L4.67 5M1.4 1.23L4.66 4.7\" stroke={fill} strokeLinecap=\"square\" />\n    </svg>;\n}"
  },
  {
    "path": "docs/src/components/Banner.js",
    "content": "export function Banner() {\n  return null; // return (\n  //   <div className=\"bg-gray-900\">\n  //     <div className=\"container mx-auto py-2 flex items-center justify-between\">\n  //       <img src=\"/logo.png\" alt=\"formium\" width=\"150px\" className=\"-ml-3\" />\n  //       <div className=\"text-white font-bold flex items-center\">\n  //         Hassle-free form storage for static sites →\n  //       </div>\n  //     </div>\n  //   </div>\n  // );\n}"
  },
  {
    "path": "docs/src/components/BytesForm.js",
    "content": "import React from 'react'\nimport useBytesSubmit from './useBytesSubmit'\n\nexport default function BytesForm() {\n  const { state, handleSubmit, error } = useBytesSubmit()\n  if (state === 'submitted') {\n    return (\n      <p>Success! Please, check your email to confirm your subscription.</p>\n    )\n  }\n  return (\n    <form onSubmit={handleSubmit}>\n      <div data-element=\"fields\" className=\"grid relative\">\n        <figure\n          className=\"absolute right-0\"\n          style={{ bottom: '72px', right: '-10px' }}\n        >\n          <img\n            height={40}\n            width={40}\n            src=\"/images/bytes-logo.png\"\n            alt=\"Bytes\"\n          />\n        </figure>\n        <input\n          className=\"border rounded p-2 mb-2 w-full\"\n          name=\"email_address\"\n          placeholder=\"Your email address\"\n          type=\"email\"\n          required=\"\"\n        />\n        <button\n          type=\"submit\"\n          className=\"mb-4 border rounded bg-coral border-none text-white p-2\"\n        >\n          {state !== 'loading' ? (\n            <span>Subscribe</span>\n          ) : (\n            <span>Loading...</span>\n          )}\n        </button>\n      </div>\n      <p className=\"text-gray-400 text-xs\">\n        No spam. Unsubscribe at <em>any</em> time.\n      </p>\n      {error && <p className=\"text-red-600\">{error}</p>}\n    </form>\n  )\n}\n"
  },
  {
    "path": "docs/src/components/CarbonAds.js",
    "content": "import React from 'react'\n\nfunction buildScript(src, attrs = {}) {\n  if (typeof document !== 'undefined') {\n    const script = document.createElement('script')\n    script.async = true\n    script.defer = true\n    Object.keys(attrs).forEach(attr => script.setAttribute(attr, attrs[attr]))\n    script.src = src\n\n    return script\n  }\n}\n\nexport default function CarbonAds() {\n  const ref = React.useRef()\n\n  React.useEffect(() => {\n    const script = buildScript(\n      '//cdn.carbonads.com/carbon.js?serve=CESITK7L&placement=react-chartstanstackcom',\n      {\n        type: 'text/javascript',\n        id: '_carbonads_js',\n      }\n    )\n\n    ref.current.appendChild(script)\n  }, [])\n\n  React.useEffect(() => {\n    const interval = setInterval(() => {\n      ;[...ref.current.children].forEach(child => {\n        if (child.id.startsWith('carbonads_')) {\n          ref.current.removeChild(child)\n        }\n      })\n    }, 100)\n\n    return () => {\n      clearInterval(interval)\n    }\n  })\n\n  return <div ref={ref} />\n}\n"
  },
  {
    "path": "docs/src/components/CodeBlock.js",
    "content": "import React, { useState } from 'react';\nimport { LiveProvider, LiveEditor, LiveError, LivePreview } from 'react-live';\nimport { mdx } from '@mdx-js/react';\nimport { TWButton } from './TWButton';\nimport { useClipboard } from './useClipboard';\nimport Component from '@reactions/component';\nexport const liveEditorStyle = {\n  fontSize: 14,\n  overflowX: 'auto',\n  color: '#f8f8f2',\n  fontFamily: 'SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace',\n  height: '100%',\n  background: '#161e2e'\n};\nexport const liveErrorStyle = {\n  fontFamily: 'SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace',\n  fontSize: 12,\n  padding: '1em',\n  overflowX: 'auto',\n  color: 'white',\n  backgroundColor: 'red'\n};\n\nconst LiveCodePreview = props => <div className=\"font-sans text-gray-900 rounded-md p-4 overflow-x-scroll\">\n    <LivePreview {...props} />\n  </div>;\n\nconst EditableNotice = props => {\n  return <div className=\"absolute right-0 top-0 p-3 text-gray-400 text-xs font-sans uppercase\">\n      Editable Example\n    </div>;\n};\n\nconst CodeBlock = ({\n  className,\n  live = false,\n  noInline = false,\n  collapsed = false,\n  isManual,\n  render,\n  children,\n  ...props\n}) => {\n  const initialCode = React.useRef(children.trim());\n  const [editorCode, setEditorCode] = useState(children.trim());\n  const language = className && className.replace(/language-/, '');\n  const [hasCopied, onCopy] = useClipboard(editorCode);\n  const [isCollapsed, setCollapse] = React.useState(collapsed);\n  const liveProviderProps = {\n    theme: {\n      plain: {},\n      styles: []\n    },\n    language,\n    code: editorCode,\n    transformCode: code => `<>${code}</>`,\n    scope: {\n      mdx,\n      Component\n    },\n    noInline,\n    ...props\n  };\n\n  const handleCodeChange = newCode => setEditorCode(newCode ? newCode.trim() : '');\n\n  if (language === 'jsx' && live === true) {\n    return <LiveProvider {...liveProviderProps}>\n        <div className=\"border relative rounded shadow-sm\">\n          <LiveCodePreview />\n          <EditableNotice />\n          {isCollapsed ? <div className=\"border-t\">\n              <button className=\"text-gray-600 py-2 bg-gray-100 font-semibold w-full text-sm hover:bg-gray-200 transition duration-100 ease-in-out\" onClick={() => setCollapse(false)}>\n                Show Code\n              </button>\n            </div> : <>\n              <div className=\"relative\">\n                <LiveEditor onChange={handleCodeChange} style={liveEditorStyle} className=\"outline-none \" />\n                <div className=\"absolute right-0 top-0 p-2\">\n                  <TWButton size=\"xs\" className=\"font-sans mr-2\" onClick={onCopy}>\n                    {hasCopied ? 'Copied' : 'Copy'}\n                  </TWButton>\n                  <TWButton size=\"xs\" className=\"font-sans\" onClick={() => setEditorCode(initialCode.current)}>\n                    Reset\n                  </TWButton>\n                </div>\n              </div>\n\n              <LiveError style={liveErrorStyle} />\n              <div className=\"border-t\">\n                <button className=\"text-gray-600 py-2 bg-gray-100 font-semibold w-full text-sm hover:bg-gray-200 transition duration-100 ease-in-out\" onClick={() => setCollapse(true)}>\n                  Hide Code\n                </button>\n              </div>\n            </>}\n        </div>\n      </LiveProvider>;\n  }\n\n  if (render) {\n    return <div style={{\n      marginTop: '40px'\n    }}>\n        <LiveProvider {...liveProviderProps}>\n          <LiveCodePreview className=\"font-sans\" />\n        </LiveProvider>\n      </div>;\n  }\n\n  return <LiveProvider disabled {...liveProviderProps}>\n      <div className=\"relative\">\n        <LiveEditor style={liveEditorStyle} className=\"rounded shadow-sm\" />\n        <div className=\"absolute right-0 top-0 p-2\">\n          <TWButton size=\"xs\" className=\"font-sans\" onClick={onCopy}>\n            {hasCopied ? 'Copied' : 'Copy'}\n          </TWButton>\n        </div>\n      </div>\n    </LiveProvider>;\n};\n\nCodeBlock.defaultProps = {\n  mountStylesheet: false\n};\nexport default CodeBlock;"
  },
  {
    "path": "docs/src/components/Container.js",
    "content": "import * as React from 'react';\nimport cn from 'classnames';\nexport const Container = props => {\n  return <div className={cn('container mx-auto')} {...props} />;\n};\nContainer.displayName = 'Container';"
  },
  {
    "path": "docs/src/components/DocsPageFooter.js",
    "content": "import * as React from 'react'\nimport NextLink from 'next/link'\nimport { removeFromLast } from '../lib/docs/utils'\nimport { siteConfig } from 'siteConfig'\nimport { FiThumbsDown, FiThumbsUp } from 'react-icons/fi'\nimport { TWButton } from './TWButton'\n\nfunction areEqual(prevProps, props) {\n  return prevProps.route?.path === props.route?.path\n}\n\nexport const DocsPageFooter = React.memo(({ route, prevRoute, nextRoute }) => {\n  const editUrl = `${siteConfig.editUrl}${route?.editUrl || route?.path}`\n\n  return (\n    <>\n      <div className=\"py-8\">\n        <div className=\"flex space-between items-center\">\n          {prevRoute && prevRoute.path ? (\n            <NextLink href={removeFromLast(prevRoute.path, '.')}>\n              <a className=\"flex-grow  block\">\n                <span className=\"text-sm block text-gray-500 mb-1 font-semibold\">\n                  ← Prev\n                </span>\n                <span className=\"text-xl block text-blue-600 font-semibold\">\n                  {prevRoute.title}\n                </span>\n              </a>\n            </NextLink>\n          ) : (\n            <div />\n          )}\n          {nextRoute && nextRoute.path && (\n            <NextLink href={removeFromLast(nextRoute.path, '.')}>\n              <a className=\"flex-grow text-right block\">\n                <span className=\"text-sm block text-gray-500 mb-1 font-semibold\">\n                  Next →\n                </span>\n                <span className=\"text-xl block text-blue-600 font-semibold\">\n                  {nextRoute.title}\n                </span>\n              </a>\n            </NextLink>\n          )}\n        </div>\n      </div>\n\n      <div className=\"mb-8\">\n        <a\n          href={editUrl}\n          target=\"_blank\"\n          rel=\"noopener noreferrer\"\n          className=\"text-gray-600 underline\"\n        >\n          Edit this page on GitHub\n        </a>\n      </div>\n\n      <div className=\"py-8 md:flex md:items-center md:py-8 border-t border-b\">\n        <div className=\"font-semibold text-xl mr-4 text-center mb-4 md:mb-0  md:text-left\">\n          Was this page helpful?\n        </div>\n        <div className=\"grid grid-cols-2 gap-3 w-auto max-w-xs mx-auto md:mx-2\">\n          <TWButton icon={<FiThumbsUp />}>Yes</TWButton>\n          <TWButton icon={<FiThumbsDown />}>No</TWButton>\n        </div>\n      </div>\n    </>\n  )\n}, areEqual)\nDocsPageFooter.displayName = 'DocsPageFooter'\n"
  },
  {
    "path": "docs/src/components/ExternalLink.js",
    "content": "import * as React from 'react';\nexport function ExternalLink(props) {\n  return <a {...props} rel=\"noopener\" target={props.target || '_blank'} />;\n}"
  },
  {
    "path": "docs/src/components/Footer.js",
    "content": "import * as React from 'react'\nimport Link from 'next/link'\nimport CarbonAds from './CarbonAds'\nimport BytesForm from './BytesForm'\n\nexport const Footer = props => {\n  return (\n    <div className=\"bg-gray-50 border-t border-gray-200\">\n      <div className=\"container mx-auto py-12 px-4 sm:px-6 lg:py-16 lg:px-8\">\n        <div className=\"grid-cols-2 md:grid xl:grid-cols-4 md:gap-8\">\n          <div>\n            <h4 className=\"text-sm leading-5 font-semibold tracking-wider text-gray-400 uppercase\">\n              Resources\n            </h4>\n            <ul className=\"mt-4\">\n              <li>\n                <Link href=\"/docs/overview\">\n                  <a className=\"text-base leading-6 text-gray-500 hover:text-gray-900\">\n                    Docs\n                  </a>\n                </Link>\n              </li>\n              <li className=\"mt-4\">\n                <Link href=\"/examples/simple\">\n                  <a className=\"text-base leading-6 text-gray-500 hover:text-gray-900\">\n                    Examples\n                  </a>\n                </Link>\n              </li>\n              <li className=\"mt-4\">\n                <Link href=\"/docs/api\">\n                  <a className=\"text-base leading-6 text-gray-500 hover:text-gray-900\">\n                    API Reference\n                  </a>\n                </Link>\n              </li>\n            </ul>\n          </div>\n          <div className=\"mt-12 md:mt-0\">\n            <h4 className=\"text-sm leading-5 font-semibold tracking-wider text-gray-400 uppercase\">\n              Community\n            </h4>\n            <ul className=\"mt-4\">\n              <li className=\"mt-4\">\n                <a\n                  href=\"https://github.com/tannerlinsley/react-charts/discussions\"\n                  className=\"text-base leading-6 text-gray-500 hover:text-gray-900\"\n                >\n                  Forum & Support\n                </a>\n              </li>\n              <li className=\"mt-4\">\n                <a\n                  href=\"https://discord.gg/WrRKjPJ\"\n                  className=\"text-base leading-6 text-gray-500 hover:text-gray-900\"\n                >\n                  #TanStack Discord\n                </a>\n              </li>\n              <li className=\"mt-4\">\n                <a\n                  href=\"http://stackoverflow.com/questions/tagged/react-charts\"\n                  className=\"text-base leading-6 text-gray-500 hover:text-gray-900\"\n                >\n                  Stack Overflow\n                </a>\n              </li>\n              <li className=\"mt-4\">\n                <a\n                  href=\"https://github.com/tannerlinsley/react-charts/releases\"\n                  className=\"text-base leading-6 text-gray-500 hover:text-gray-900\"\n                >\n                  Releases\n                </a>\n              </li>\n              <li className=\"mt-4\">\n                <a\n                  className=\"github-button\"\n                  href=\"https://github.com/tannerlinsley/react-charts\"\n                  data-color-scheme=\"no-preference: light; light: light; dark: dark;\"\n                  data-icon=\"octicon-star\"\n                  data-size=\"large\"\n                  data-show-count=\"true\"\n                  aria-label=\"Star tannerlinsley/react-charts on GitHub\"\n                >\n                  Star\n                </a>\n              </li>\n            </ul>\n          </div>\n          <div className=\"mt-12 md:mt-0\">\n            <CarbonAds />\n          </div>\n          <div className=\"mt-8 xl:mt-0\">\n          <h4 className=\"text-sm leading-5 font-semibold tracking-wider text-gray-400 uppercase\">\n              Subscribe to Bytes\n            </h4>\n            <p className=\"mt-4 text-gray-500 text-base leading-6 mb-4\">\n              The best JavaScript newsletter! Delivered every Monday to over\n              76,000 devs.\n            </p>\n            <BytesForm />\n          </div>\n        </div>\n        <div className=\"mt-8 border-t border-gray-200 pt-8 md:flex md:items-center md:justify-between\">\n          <div className=\"flex md:order-2\">\n            <a\n              href=\"https://twitter.com/tannerlinsley\"\n              className=\"ml-6 text-gray-400 hover:text-gray-500\"\n            >\n              <span className=\"sr-only\">Twitter</span>\n              <svg className=\"h-6 w-6\" fill=\"currentColor\" viewBox=\"0 0 24 24\">\n                <path d=\"M8.29 20.251c7.547 0 11.675-6.253 11.675-11.675 0-.178 0-.355-.012-.53A8.348 8.348 0 0022 5.92a8.19 8.19 0 01-2.357.646 4.118 4.118 0 001.804-2.27 8.224 8.224 0 01-2.605.996 4.107 4.107 0 00-6.993 3.743 11.65 11.65 0 01-8.457-4.287 4.106 4.106 0 001.27 5.477A4.072 4.072 0 012.8 9.713v.052a4.105 4.105 0 003.292 4.022 4.095 4.095 0 01-1.853.07 4.108 4.108 0 003.834 2.85A8.233 8.233 0 012 18.407a11.616 11.616 0 006.29 1.84\" />\n              </svg>\n            </a>\n            <a\n              href=\"https://github.com/tannerlinsley\"\n              className=\"ml-6 text-gray-400 hover:text-gray-500\"\n            >\n              <span className=\"sr-only\">GitHub</span>\n              <svg className=\"h-6 w-6\" fill=\"currentColor\" viewBox=\"0 0 24 24\">\n                <path\n                  fillRule=\"evenodd\"\n                  d=\"M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z\"\n                  clipRule=\"evenodd\"\n                />\n              </svg>\n            </a>\n          </div>\n          <p className=\"mt-8 text-base leading-6 text-gray-400 md:mt-0 md:order-1\">\n            &copy; 2020 Tanner Linsley. All rights reserved.\n          </p>\n        </div>\n      </div>\n    </div>\n  )\n}\nFooter.displayName = 'Footer'\n"
  },
  {
    "path": "docs/src/components/Highlight.js",
    "content": "import * as React from 'react';\nimport Highlight, { defaultProps } from 'prism-react-renderer';\nimport { LiveProvider, LiveEditor, LiveError, LivePreview } from 'react-live'; // Original: https://raw.githubusercontent.com/PrismJS/prism-themes/master/themes/prism-ghcolors.css\n\n/*:: import type { PrismTheme } from '../src/types' */\n\nconst theme\n/*: PrismTheme */\n= {\n  plain: {\n    color: '#293742',\n    borderRadius: 12,\n    fontFamily: `SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace`,\n    fontSize: 14,\n    lineHeight: '1.5'\n  },\n  styles: [{\n    types: ['comment', 'prolog', 'doctype', 'cdata'],\n    style: {\n      color: '#A7B6C2',\n      fontStyle: 'italic'\n    }\n  }, {\n    types: ['namespace'],\n    style: {\n      opacity: 0.7\n    }\n  }, {\n    types: ['string', 'attr-value'],\n    style: {\n      color: '#DB2C6F'\n    }\n  }, {\n    types: ['punctuation', 'operator'],\n    style: {\n      color: '#394B59'\n    }\n  }, {\n    types: ['entity', 'url', 'symbol', 'number', 'boolean', 'variable', 'constant', 'property', 'regex', 'inserted'],\n    style: {\n      color: '#36acaa'\n    }\n  }, {\n    types: ['atrule', 'keyword', 'attr-name', 'selector'],\n    style: {\n      color: '#00B3A4'\n    }\n  }, {\n    types: ['function', 'deleted', 'tag'],\n    style: {\n      color: '#DB2C6F'\n    }\n  }, {\n    types: ['function-variable'],\n    style: {\n      color: '#634DBF'\n    }\n  }, {\n    types: ['tag', 'selector', 'keyword'],\n    style: {\n      color: '#1a56db'\n    }\n  }]\n};\n\nconst Code = ({\n  children,\n  codeString,\n  className = 'language-js',\n  ...props\n}) => {\n  const language = className.replace(/language-/, '');\n  const [key, setKey] = React.useState(`${Math.random() * 7}`);\n\n  if (props['live']) {\n    return <div>\n        <LiveProvider key={key} code={children.trim()} theme={theme} noInline>\n          <div className=\"flex items-center justify-between\">\n            <div>Live JSX Editor</div>\n            <div>\n              <button onClick={() => setKey(k => `${k * Math.random()}`)}>\n                Reset\n              </button>\n            </div>\n          </div>\n          <div style={{\n          paddingRight: 10,\n          paddingLeft: 10\n        }}>\n            <LiveEditor />\n          </div>\n          <div>\n            <div>\n              <div>Live Preview</div>\n            </div>\n            <div>\n              <LiveError style={{\n              fontSize: 13,\n              background: '#FED7D7',\n              color: '#9B2C2C',\n              lineHeight: '1.5',\n              margin: -4,\n              padding: 4\n            }} />\n              <LivePreview />\n            </div>\n          </div>\n        </LiveProvider>\n      </div>;\n  } else {\n    return <Highlight {...defaultProps} code={children.trim()} language={language} theme={theme}>\n        {({\n        className,\n        style,\n        tokens,\n        getLineProps,\n        getTokenProps\n      }) => <pre className={className + ' bg-gray-50 pb-4 pt-4 pr-4 overflow-scroll'} style={{ ...style,\n        border: '1px solid #eee',\n        fontSize: 13,\n        lineHeight: '1.5'\n      }}>\n            {tokens.map((line, i) => <div key={i} {...getLineProps({\n          line,\n          key: i\n        })}>\n                {tokens.length > 1 ? <span aria-hidden=\"true\" className=\"select-none text-gray-300 text-right w-5 inline-block mx-2\">\n                    {i + 1}\n                  </span> : <span className=\"mx-2 w-5\" />}{' '}\n                {line.map((token, key) => <span key={key} {...getTokenProps({\n            token,\n            key\n          })} />)}\n              </div>)}\n          </pre>}\n      </Highlight>;\n  }\n};\n\nexport default Code;"
  },
  {
    "path": "docs/src/components/Highlight2.js",
    "content": "import * as React from 'react';\nimport Highlight, { defaultProps } from 'prism-react-renderer';\n// Original: https://raw.githubusercontent.com/PrismJS/prism-themes/master/themes/prism-ghcolors.css\n\n/*:: import type { PrismTheme } from '../src/types' */\nconst theme\n/*: PrismTheme */\n= {\n  plain: {\n    color: '#293742',\n    borderRadius: 12,\n    fontFamily: `SFMono-Regular,Consolas,Liberation Mono,Menlo,Courier,monospace`,\n    fontSize: 14,\n    lineHeight: '1.5'\n  },\n  styles: [{\n    types: ['comment', 'prolog', 'doctype', 'cdata'],\n    style: {\n      color: '#A7B6C2',\n      fontStyle: 'italic'\n    }\n  }, {\n    types: ['namespace'],\n    style: {\n      opacity: 0.7\n    }\n  }, {\n    types: ['string', 'attr-value'],\n    style: {\n      color: '#DB2C6F'\n    }\n  }, {\n    types: ['punctuation', 'operator'],\n    style: {\n      color: '#394B59'\n    }\n  }, {\n    types: ['entity', 'url', 'symbol', 'number', 'boolean', 'variable', 'constant', 'property', 'regex', 'inserted'],\n    style: {\n      color: '#36acaa'\n    }\n  }, {\n    types: ['atrule', 'keyword', 'attr-name', 'selector'],\n    style: {\n      color: '#00B3A4'\n    }\n  }, {\n    types: ['function', 'deleted', 'tag'],\n    style: {\n      color: '#DB2C6F'\n    }\n  }, {\n    types: ['function-variable'],\n    style: {\n      color: '#634DBF'\n    }\n  }, {\n    types: ['tag', 'selector', 'keyword'],\n    style: {\n      color: '#1a56db'\n    }\n  }]\n};\n\nconst Code = ({\n  children,\n  codeString,\n  className = 'language-js',\n  ...props\n}) => {\n  const language = className.replace(/language-/, '');\n  return <Highlight {...defaultProps} code={children.trim()} language={language} theme={theme}>\n      {({\n      className,\n      style,\n      tokens,\n      getLineProps,\n      getTokenProps\n    }) => <pre className={className + ' bg-gray-50 pb-4 pt-4 pr-4 overflow-scroll'} style={{ ...style,\n      border: '1px solid #eee',\n      fontSize: 13,\n      lineHeight: '1.5'\n    }}>\n          {tokens.map((line, i) => <div key={i} {...getLineProps({\n        line,\n        key: i\n      })}>\n              {tokens.length > 1 ? <span aria-hidden=\"true\" className=\"select-none text-gray-300 text-right w-5 inline-block mx-2\">\n                  {i + 1}\n                </span> : <span className=\"mx-2 w-5\" />}{' '}\n              {line.map((token, key) => <span key={key} {...getTokenProps({\n          token,\n          key\n        })} />)}\n            </div>)}\n        </pre>}\n    </Highlight>;\n};\n\nexport default Code;"
  },
  {
    "path": "docs/src/components/LayoutDocs.js",
    "content": "import * as React from 'react'\nimport { MDXProvider } from '@mdx-js/react'\nimport { Nav } from 'components/Nav'\nimport { Sidebar } from 'components/Sidebar'\nimport { SidebarCategory } from 'components/SidebarCategory'\nimport { SidebarHeading } from 'components/SidebarHeading'\nimport { SidebarMobile } from 'components/SidebarMobile'\nimport { SidebarPost } from 'components/SidebarPost'\nimport { Sticky } from 'components/Sticky'\nimport { useIsMobile } from 'components/useIsMobile'\nimport { findRouteByPath } from 'lib/docs/findRouteByPath'\nimport { removeFromLast } from 'lib/docs/utils'\nimport { getRouteContext } from 'lib/get-route-context'\nimport { useRouter } from 'next/router'\nimport { Toc } from './Toc'\nimport s from './markdown.module.css'\nimport { Footer } from './Footer'\nimport { DocsPageFooter } from './DocsPageFooter'\nimport { Seo } from './Seo'\nimport MDXComponents from './MDXComponents'\nimport Head from 'next/head'\nimport { getManifest } from 'manifests/getManifest'\nimport BytesForm from './BytesForm'\n\nconst getSlugAndTag = path => {\n  const parts = path.split('/')\n\n  if (parts[2] === '1.5.8' || parts[2] === '2.1.4') {\n    return {\n      tag: parts[2],\n      slug: `/docs/${parts.slice(2).join('/')}`,\n    }\n  }\n\n  return {\n    slug: path,\n  }\n}\n\nconst addTagToSlug = (slug, tag) => {\n  return tag ? `/docs/${tag}/${slug.replace('/docs/', '')}` : slug\n}\n\nexport const LayoutDocs = props => {\n  const router = useRouter()\n  const { slug, tag } = getSlugAndTag(router.asPath)\n  const { routes } = getManifest(tag)\n\n  const _route = findRouteByPath(removeFromLast(slug, '#'), routes) // @ts-ignore\n\n  const isMobile = useIsMobile()\n  const { route, prevRoute, nextRoute } = getRouteContext(_route, routes)\n  const title = route && `${route.title}`\n\n  return (\n    <>\n      {tag && (\n        <Head>\n          <meta name=\"robots\" content=\"noindex\" />\n        </Head>\n      )}\n      <div>\n        {isMobile ? (\n          <>\n            <Nav />\n            <Sticky shadow>\n              <SidebarMobile>\n                <SidebarRoutes isMobile={true} routes={routes} />\n              </SidebarMobile>\n            </Sticky>\n          </>\n        ) : (\n          <Sticky>\n            <Nav />\n          </Sticky>\n        )}\n        <Seo\n          title={title || props.meta.title}\n          description={props.meta.description}\n        />\n        <div className=\"block\">\n          <>\n\n            <div className=\"container mx-auto pb-12 pt-6 content\">\n              <div className=\"flex relative\">\n                {!isMobile && (\n                  <Sidebar fixed>\n                    <SidebarRoutes routes={routes} />\n                  </Sidebar>\n                )}\n\n                <div className={s['markdown'] + ' w-full docs'}>\n                  <h1>{props.meta.title}</h1>\n                  <MDXProvider components={MDXComponents}>\n                    {props.children}\n                  </MDXProvider>\n                  <DocsPageFooter\n                    href={route?.path || ''}\n                    route={route}\n                    prevRoute={prevRoute}\n                    nextRoute={nextRoute}\n                  />\n                </div>\n                {props.meta.toc === false ? null : (\n                  <div\n                    className=\"hidden xl:block ml-10 flex-shrink-0\"\n                    style={{\n                      width: 200,\n                    }}\n                  >\n                    <div className=\"sticky top-24 \">\n                      <h4 className=\"font-semibold uppercase text-sm mb-2 mt-2 text-gray-500\">\n                        On this page\n                      </h4>\n                      <Toc />\n                      <div className=\"mt-12 relative\">\n                        <h4 className=\"font-semibold uppercase text-sm mb-2 mt-2 text-gray-500\">\n                          Subscribe to Bytes\n                        </h4>\n                        <p className=\"mt-4  text-sm leading-6 mb-4\">\n                          The best JavaScript newsletter! Delivered every\n                          Monday to over 76,000 devs.\n                        </p>\n                        <BytesForm />\n                      </div>\n                    </div>\n                  </div>\n                )}\n              </div>\n            </div>\n          </>\n        </div>\n      </div>\n      <Footer />\n      <style jsx>{`\n        .docs {\n          min-width: calc(100% - 300px - 1rem - 200px);\n          word-wrap: break-word;\n        }\n      `}</style>\n    </>\n  )\n}\n\nfunction getCategoryPath(routes) {\n  const route = routes.find(r => r.path)\n  return route && removeFromLast(route.path, '/')\n}\n\nfunction SidebarRoutes({ isMobile, routes: currentRoutes, level = 1 }) {\n  const { asPath } = useRouter()\n  let { slug, tag } = getSlugAndTag(asPath)\n  return currentRoutes.map(({ path, title, routes, heading, open }) => {\n    if (routes) {\n      const pathname = getCategoryPath(routes)\n      const selected = slug.startsWith(pathname)\n      const opened = selected || isMobile ? false : open\n\n      if (heading) {\n        return (\n          <SidebarHeading key={'parent' + pathname} title={title}>\n            <SidebarRoutes\n              isMobile={isMobile}\n              routes={routes}\n              level={level + 1}\n            />\n          </SidebarHeading>\n        )\n      }\n\n      return (\n        <SidebarCategory\n          key={pathname}\n          isMobile={isMobile}\n          level={level}\n          title={title}\n          selected={selected}\n          opened={opened}\n        >\n          <SidebarRoutes\n            isMobile={isMobile}\n            routes={routes}\n            level={level + 1}\n          />\n        </SidebarCategory>\n      )\n    }\n\n    const pagePath = removeFromLast(path, '.')\n    const pathname = addTagToSlug(pagePath, tag)\n    const selected = slug === pagePath\n    const route = {\n      href: pagePath,\n      path,\n      title,\n      pathname,\n      selected,\n    }\n    return (\n      <SidebarPost\n        key={title}\n        isMobile={isMobile}\n        level={level}\n        route={route}\n      />\n    )\n  })\n}\n\nLayoutDocs.displayName = 'LayoutDocs'\n"
  },
  {
    "path": "docs/src/components/LazyImage.js",
    "content": "import * as React from 'react';\nimport { ProgressiveImage } from './ProgressiveImage';\nimport cn from 'classnames';\nexport class LazyImage extends React.Component {\n  render() {\n    const {\n      height,\n      width,\n      src,\n      alt,\n      className,\n      style\n    } = this.props;\n    return <ProgressiveImage src={src} placeholder={'data:image/gif;base64,R0lGODlhAQABAPABAP///wAAACH5BAEKAAAALAAAAAABAAEAAAICRAEAOw%3D%3D'}>\n        {({\n        image,\n        isLoading\n      }) => <img className={cn('transition duration-100 ease-in', {\n        'opacity-0': isLoading,\n        'opacity-100': !isLoading\n      }, className)} src={image} alt={alt} width={width} style={style} height={height} />}\n      </ProgressiveImage>;\n  }\n\n}"
  },
  {
    "path": "docs/src/components/Logo.js",
    "content": ""
  },
  {
    "path": "docs/src/components/MDXComponents.js",
    "content": "import * as React from 'react';\nimport dynamic from 'next/dynamic';\nexport default {\n  // default tags\n  pre: p => <pre {...p} />,\n  code: dynamic(() => import('./Highlight2')) // Counter: dynamic(() => import('./counter')),\n\n};"
  },
  {
    "path": "docs/src/components/Markdown.js",
    "content": "import * as React from 'react';\nimport markdownStyles from './markdown.module.css';\nexport const Markdown = ({\n  html: content\n}) => {\n  return <div className={markdownStyles['markdown']} dangerouslySetInnerHTML={{\n    __html: content\n  }} />;\n};\nMarkdown.displayName = 'PostBody';"
  },
  {
    "path": "docs/src/components/Nav.js",
    "content": "import * as React from 'react'\nimport Link from 'next/link'\nimport logoSrc from '../images/logo-light.svg'\nimport { siteConfig } from 'siteConfig'\nimport { Search } from './Search'\n\nexport const Nav = () => (\n  <div className=\"bg-white border-b border-gray-200\">\n    <div className=\"container mx-auto\">\n      <div className=\"flex flex-wrap items-center\">\n        <div className=\"w-60 flex items-center h-16 pt-4 md:pt-0\">\n          <Link href=\"/\" as=\"/\">\n            <a>\n              <span className=\"sr-only\">Home</span>\n              <img src={logoSrc} alt=\"React Charts\" />\n            </a>\n          </Link>\n        </div>\n\n        <div className=\"flex-grow hidden lg:block ml-8\">\n          <Search />\n        </div>\n\n        <div className=\"flex flex-grow items-center justify-between w-3/4 md:w-auto md:justify-end space-x-4 md:space-x-8 h-16\">\n          <div className=\"flex space-x-4 md:space-x-8 text-sm md:text-base\">\n            <div>\n              <Link href=\"/docs/overview\">\n                <a className=\"leading-6 font-medium\">Docs</a>\n              </Link>\n            </div>\n            <div>\n              <Link href=\"/examples/simple\">\n                <a className=\"leading-6 font-medium\">Examples</a>\n              </Link>\n            </div>\n            <div>\n              <Link href=\"/docs/api\">\n                <a className=\"leading-6 font-medium\">API</a>\n              </Link>\n            </div>\n            <div>\n              <a href=\"https://tanstack.com\" className=\"leading-6 font-medium\">\n                TanStack\n              </a>\n            </div>\n          </div>\n          <div>\n            <a\n              href={siteConfig.repoUrl}\n              target=\"_blank\"\n              rel=\"noopener noreferrer\"\n            >\n              <span className=\"sr-only\">GitHub</span>\n              <svg className=\"h-6 w-6\" fill=\"currentColor\" viewBox=\"0 0 24 24\">\n                <path\n                  fillRule=\"evenodd\"\n                  d=\"M12 2C6.477 2 2 6.484 2 12.017c0 4.425 2.865 8.18 6.839 9.504.5.092.682-.217.682-.483 0-.237-.008-.868-.013-1.703-2.782.605-3.369-1.343-3.369-1.343-.454-1.158-1.11-1.466-1.11-1.466-.908-.62.069-.608.069-.608 1.003.07 1.531 1.032 1.531 1.032.892 1.53 2.341 1.088 2.91.832.092-.647.35-1.088.636-1.338-2.22-.253-4.555-1.113-4.555-4.951 0-1.093.39-1.988 1.029-2.688-.103-.253-.446-1.272.098-2.65 0 0 .84-.27 2.75 1.026A9.564 9.564 0 0112 6.844c.85.004 1.705.115 2.504.337 1.909-1.296 2.747-1.027 2.747-1.027.546 1.379.202 2.398.1 2.651.64.7 1.028 1.595 1.028 2.688 0 3.848-2.339 4.695-4.566 4.943.359.309.678.92.678 1.855 0 1.338-.012 2.419-.012 2.747 0 .268.18.58.688.482A10.019 10.019 0 0022 12.017C22 6.484 17.522 2 12 2z\"\n                  clipRule=\"evenodd\"\n                />\n              </svg>\n            </a>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n)\n"
  },
  {
    "path": "docs/src/components/ProgressiveImage.js",
    "content": "import * as React from 'react';\nexport class ProgressiveImage extends React.Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      image: props.placeholder,\n      isLoading: true\n    };\n  }\n\n  componentDidMount() {\n    const {\n      src\n    } = this.props;\n\n    if (src) {\n      this.loadImage(src);\n    }\n  }\n\n  componentDidUpdate(prevProps) {\n    const {\n      src,\n      placeholder\n    } = prevProps; // We only invalidate the current image if the src has changed.\n\n    if (src && src !== this.props.src) {\n      this.setState({\n        image: placeholder,\n        isLoading: true\n      }, () => {\n        this.loadImage(src);\n      });\n    }\n  }\n\n  componentWillUnmount() {\n    if (this.image) {\n      this.image.onload = null;\n      this.image.onerror = null;\n    }\n  }\n\n  loadImage = src => {\n    // If there is already an image we nullify the onload\n    // and onerror props so it does not incorrectly set state\n    // when it resolves\n    if (this.image) {\n      this.image.onload = null;\n      this.image.onerror = null;\n    }\n\n    const image = new Image();\n    this.image = image;\n    image.onload = this.onLoad;\n    image.onerror = this.onError;\n    image.src = src;\n  };\n  onLoad = () => {\n    const {\n      naturalWidth,\n      naturalHeight\n    } = this.image; // use this.image.src instead of this.props.src to\n    // avoid the possibility of props being updated and the\n    // new imageisLoading before the new props are available as\n    // this.props.\n\n    this.setState({\n      naturalHeight,\n      naturalWidth,\n      aspectRatio: naturalHeight / naturalWidth,\n      orientation: naturalWidth > naturalHeight ? 'landscape' : 'portrait',\n      image: this.image.src,\n      isLoading: false\n    });\n  };\n  onError = errorEvent => {\n    const {\n      onError\n    } = this.props;\n\n    if (onError) {\n      onError(errorEvent);\n    }\n  };\n\n  render() {\n    const {\n      children\n    } = this.props;\n\n    if (!children || typeof children !== 'function') {\n      throw new Error(`ProgressiveImage requires a function as its only child`);\n    }\n\n    return children(this.state);\n  }\n\n}"
  },
  {
    "path": "docs/src/components/Search.js",
    "content": "import * as React from 'react'\nimport { useSearch } from './useSearch'\n\nexport const Search = () => {\n  const { onOpen } = useSearch()\n\n  return (\n    <div>\n      <button\n        type=\"button\"\n        className=\"group form-input hover:text-gray-600 hover:border-gray-300 transition duration-150 ease-in-out pointer flex items-center bg-gray-50 text-left w-full  text-gray-500 rounded-lg text-sm align-middle\"\n        onClick={onOpen}\n      >\n        <svg\n          width=\"1em\"\n          height=\"1em\"\n          className=\"mr-3 align-middle text-gray-600 flex-shrink-0 group-hover:text-gray-700\"\n          style={{\n            marginBottom: 2,\n          }}\n          viewBox=\"0 0 20 20\"\n        >\n          <path\n            d=\"M14.386 14.386l4.0877 4.0877-4.0877-4.0877c-2.9418 2.9419-7.7115 2.9419-10.6533 0-2.9419-2.9418-2.9419-7.7115 0-10.6533 2.9418-2.9419 7.7115-2.9419 10.6533 0 2.9419 2.9418 2.9419 7.7115 0 10.6533z\"\n            stroke=\"currentColor\"\n            fill=\"none\"\n            strokeWidth=\"2\"\n            fillRule=\"evenodd\"\n            strokeLinecap=\"round\"\n            strokeLinejoin=\"round\"\n          ></path>\n        </svg>\n        Search docs\n        <span className=\"ml-auto invisible lg:visible\">\n          <kbd\n            className=\"border border-gray-300 mr-1 bg-gray-100 align-middle p-0 inline-flex justify-center items-center  text-xs text-center mr-0 rounded group-hover:border-gray-300 transition duration-150 ease-in-out \"\n            style={{\n              minWidth: '1.8em',\n            }}\n          >\n            ⌘\n          </kbd>\n          <kbd\n            className=\"border border-gray-300 bg-gray-100 align-middle p-0 inline-flex justify-center items-center  text-xs text-center ml-auto mr-0 rounded group-hover:border-gray-300 transition duration-150 ease-in-out \"\n            style={{\n              minWidth: '1.8em',\n            }}\n          >\n            K\n          </kbd>\n        </span>\n      </button>\n    </div>\n  )\n}\nSearch.displayName = 'Search'\n"
  },
  {
    "path": "docs/src/components/Seo.js",
    "content": "import React from 'react'\nimport Head from 'next/head'\nimport { withRouter } from 'next/router'\n\nconst ogImage = require('images/og-dark.png?url')\nconst favicon = require('images/favicon.png?url')\n\nexport const Seo = withRouter(\n  ({ title, description, image = ogImage, router, children }) => (\n    <Head>\n      {/* DEFAULT */}\n\n      {title != undefined && (\n        <title key=\"title\">{title} | React Charts | TanStack</title>\n      )}\n      {description != undefined && (\n        <meta name=\"description\" key=\"description\" content={description} />\n      )}\n      <link rel=\"icon\" type=\"image/x-icon\" href={favicon} />\n      <link rel=\"apple-touch-icon\" href={favicon} />\n\n      {/* OPEN GRAPH */}\n      <meta property=\"og:type\" key=\"og:type\" content=\"website\" />\n      <meta\n        property=\"og:url\"\n        key=\"og:url\"\n        content={`https://react-charts.tanstack.com${router.pathname}`}\n      />\n      {title != undefined && (\n        <meta property=\"og:title\" content={title} key=\"og:title\" />\n      )}\n      {description != undefined && (\n        <meta\n          property=\"og:description\"\n          key=\"og:description\"\n          content={description}\n        />\n      )}\n      {image != undefined && (\n        <meta\n          property=\"og:image\"\n          key=\"og:image\"\n          content={`https://react-charts.tanstack.com${image}`}\n        />\n      )}\n\n      {/* TWITTER */}\n      <meta\n        name=\"twitter:card\"\n        key=\"twitter:card\"\n        content=\"summary_large_image\"\n      />\n      <meta name=\"twitter:site\" key=\"twitter:site\" content=\"@tannerlinsley\" />\n      <meta\n        name=\"twitter:creator\"\n        key=\"twitter:creator\"\n        content=\"@tannerlinsley\"\n      />\n      {title != undefined && (\n        <meta name=\"twitter:title\" key=\"twitter:title\" content={title} />\n      )}\n      {description != undefined && (\n        <meta\n          name=\"twitter:description\"\n          key=\"twitter:description\"\n          content={description}\n        />\n      )}\n      {image != undefined && (\n        <meta\n          name=\"twitter:image\"\n          key=\"twitter:image\"\n          content={`https://react-charts.tanstack.com${image}`}\n        />\n      )}\n\n      {children}\n    </Head>\n  )\n)\n"
  },
  {
    "path": "docs/src/components/Sidebar.js",
    "content": "import { useState } from 'react'\nimport cn from 'classnames'\nimport { Search } from './Search'\nimport CarbonAds from './CarbonAds'\nexport const Sidebar = ({ active, children, fixed }) => {\n  const [searching, setSearching] = useState(false)\n  return (\n    <aside\n      className={cn('sidebar bg-white top-24 flex-shrink-0 pr-2', {\n        active,\n        ['pb-0 flex flex-col z-1 sticky']: fixed,\n        fixed,\n        searching,\n      })}\n    >\n      <div className=\"sidebar-search my-2 lg:hidden\">\n        <Search />\n      </div>\n      <div className=\"sidebar-content overflow-y-auto pb-4\">{children}</div>\n      <CarbonAds />\n      <style jsx>{`\n        .sidebar {\n          -webkit-overflow-scrolling: touch;\n        }\n        .sidebar.fixed {\n          width: 300px;\n          padding-right: 2.5rem;\n          /* Full page - content margin - header size - banner */\n          height: calc(100vh - 1.5rem - 64px - 42px);\n        }\n        .sidebar.fixed.searching > .sidebar-content {\n          display: none;\n        }\n        .sidebar-search {\n          position: relative;\n          z-index: 1;\n        }\n        @media screen and (max-width: 1024px) {\n          .sidebar,\n          .sidebar.fixed {\n            display: none;\n          }\n          .sidebar.active {\n            display: block;\n          }\n        }\n      `}</style>\n    </aside>\n  )\n}\n"
  },
  {
    "path": "docs/src/components/SidebarCategory.js",
    "content": "import { useRef, useState, useEffect } from 'react';\nimport cn from 'classnames';\nimport { FiChevronDown } from 'react-icons/fi';\nexport function SidebarCategory({\n  isMobile,\n  level = 1,\n  title,\n  selected,\n  opened,\n  children\n}) {\n  const ref = useRef(null);\n  const [{\n    toggle,\n    shouldScroll = false\n  }, setToggle] = useState({\n    toggle: selected || opened\n  });\n\n  const toggleCategory = () => {\n    setToggle({\n      toggle: !toggle,\n      shouldScroll: true\n    });\n  };\n\n  const levelClass = `level-${level}`; // If a category is selected indirectly, open it. This can happen when using the search input\n\n  useEffect(() => {\n    if (selected) {\n      setToggle({\n        toggle: true\n      });\n    }\n  }, [selected]); // Navigate to the start of the category when manually opened\n\n  useEffect(() => {\n    if (toggle && shouldScroll && ref.current != null) {\n      const content = document.querySelector(isMobile ? '.docs-dropdown' : '.sidebar-content');\n\n      if (content) {\n        // 10 is added for better margin\n        const height = ref.current.offsetTop - (isMobile ? 10 : content.offsetTop);\n        content.scrollTop = height;\n        setToggle({\n          toggle\n        });\n      }\n    }\n  }, [toggle, shouldScroll, isMobile]);\n  return <div ref={ref} className={cn('category', levelClass, {\n    open: toggle,\n    selected\n  })}>\n      <a className=\"label\" onClick={toggleCategory}>\n        {title}\n        <FiChevronDown className=\"text-gray-600\" />\n      </a>\n      <div className=\"posts\">{children}</div>\n      <style jsx>{`\n        .category {\n          margin: 12px 0;\n        }\n        .category:first-child {\n          margin-top: 0;\n        }\n        .category:last-child {\n          margin-bottom: 0;\n        }\n        .label {\n          font-size: 1rem;\n          line-height: 1.5rem;\n          font-weight: 400;\n          cursor: pointer;\n          display: flex;\n          align-items: center;\n          justify-content: space-between;\n          color: #4b5563;\n        }\n        .label > :global(svg) {\n          margin-right: 16px;\n          transform-origin: center;\n          transition: transform 0.15s ease;\n        }\n        .selected > .label {\n          font-weight: 600;\n          color: #161e2e;\n        }\n        .open > .label {\n          color: #161e2e;\n        }\n        .open > .label > :global(svg) {\n          margin-left: 1px;\n          transform-origin: center;\n          transform: rotate(180deg);\n        }\n        .level-2 .label {\n          text-transform: none;\n          letter-spacing: 0;\n        }\n        .label:hover {\n          color: #1a202c;\n        }\n        .separated {\n          margin-bottom: 32px;\n        }\n        .posts {\n          border-left: 1px solid #e5e7eb;\n          margin-top: 0;\n          height: 0;\n          overflow: hidden;\n          padding-left: 19px;\n          margin-left: 3px;\n        }\n        .open > .posts {\n          margin-top: 12px;\n          height: auto;\n        }\n        @media screen and (max-width: 950px) {\n          .category {\n            margin: 24px 0;\n          }\n        }\n      `}</style>\n    </div>;\n}"
  },
  {
    "path": "docs/src/components/SidebarHeading.js",
    "content": "import * as React from 'react';\nexport const SidebarHeading = ({\n  title,\n  children\n}) => {\n  return (// <div>\n    //   <h4 className=\"font-semibold uppercase text-sm my-4\">{title}</h4>\n    //   <div>{children}</div>\n    // </div>\n    <div className=\"heading\">\n      <h4>{title}</h4>\n      <div>{children}</div>\n      <style jsx>{`\n        h4 {\n          margin: 1.25rem 0;\n          font-size: 1.2rem;\n          font-weight: 600;\n        }\n      `}</style>\n    </div>\n  );\n};\nSidebarHeading.displayName = 'SidebarHeading';"
  },
  {
    "path": "docs/src/components/SidebarMobile.js",
    "content": "import * as React from 'react';\nimport { disableBodyScroll, enableBodyScroll, clearAllBodyScrollLocks } from 'body-scroll-lock';\nimport cn from 'classnames';\nimport { Container } from './Container';\nimport { FiChevronRight as ArrowRightSidebar } from 'react-icons/fi';\nimport { Search } from './Search';\nimport { useRouter } from 'next/router';\nexport function SidebarMobile({\n  children\n}) {\n  const [opened, setOpen] = React.useState(false);\n  const menuRef = React.useRef(null);\n  const searchRef = React.useRef(null);\n  const router = useRouter();\n\n  const openMenu = () => {\n    if (menuRef.current != null) {\n      disableBodyScroll(menuRef.current);\n      setOpen(true);\n    }\n  };\n\n  const closeMenu = () => {\n    if (menuRef.current != null) {\n      enableBodyScroll(menuRef.current);\n      setOpen(false);\n    }\n  };\n\n  const toggleOpen = () => {\n    if (opened) {\n      closeMenu();\n    } else {\n      openMenu();\n    }\n  };\n\n  const onRouteChange = () => {\n    closeMenu();\n  };\n\n  React.useEffect(() => {\n    onRouteChange();\n    return () => {\n      clearAllBodyScrollLocks();\n    };\n  }, [router.asPath]);\n  return <div className=\"lg:hidden\">\n      <Container>\n        <div className=\"sidebar-search py-2 z-10\">\n          <Search />\n        </div>\n        <label htmlFor=\"dropdown-input\" className={cn('w-full', {\n        opened\n      })}>\n          <input id=\"dropdown-input\" className=\"hidden\" type=\"checkbox\" checked={opened} onChange={toggleOpen} />\n          <div className=\"docs-select flex w-full items-center\">\n            <ArrowRightSidebar className=\"text-gray-600 -ml-1\" />\n            Menu\n          </div>\n        </label>\n        <div className=\"docs-dropdown shadow-xl\" ref={menuRef}>\n          <Container>\n            <nav>{children}</nav>\n          </Container>\n        </div>\n        <style jsx>{`\n          .docs-select {\n            display: flex;\n            height: 2.5rem;\n            width: 100%;\n            line-height: 3rem;\n            align-items: center;\n            text-align: left;\n            cursor: pointer;\n          }\n          .docs-dropdown {\n            position: absolute;\n            left: 0;\n            right: 0;\n            top: 100%;\n            bottom: 100%;\n            background: white;\n            overflow-y: auto;\n            -webkit-overflow-scrolling: touch;\n          }\n          .docs-dropdown nav {\n            padding: 10px 0;\n          }\n          .opened ~ .docs-dropdown {\n            min-height: 80px;\n            bottom: calc(153px - 90vh);\n            border-top: 1px solid #eaeaea;\n          }\n          .docs-select :global(svg) {\n            margin-left: 1px;\n            margin-right: 14px;\n            transition: transform 0.15s ease;\n          }\n          .opened > .docs-select :global(svg) {\n            transform: rotate(90deg);\n          }\n\n          @media screen and (max-width: 640px) {\n            .opened ~ .docs-dropdown {\n              bottom: calc(203px - 90vh);\n            }\n          }\n        `}</style>\n      </Container>\n    </div>;\n}"
  },
  {
    "path": "docs/src/components/SidebarNavLink.js",
    "content": "import * as React from 'react'\nimport Link from 'next/link'\nimport { useRouter } from 'next/router'\nimport cn from 'classnames'\nexport function SidebarNavLink({\n  route: { href, pathname, title, selected },\n  onClick,\n}) {\n  const router = useRouter()\n  const onlyHashChange = pathname === router.pathname\n\n  return (\n    <div\n      className={cn('nav-link', {\n        selected,\n      })}\n    >\n      {\n        // NOTE: use just anchor element for triggering `hashchange` event\n        onlyHashChange ? (\n          <a className={selected ? 'selected' : ''} href={pathname}>\n            {title}\n          </a>\n        ) : (\n          <Link href={href} as={pathname}>\n            <a>{title}</a>\n          </Link>\n        )\n      }\n      <style jsx>{`\n        div.selected {\n          box-sizing: border-box;\n        }\n        .nav-link {\n          display: flex;\n          width: 100%;\n        }\n        .nav-link :global(a) {\n          text-decoration: none;\n          font-size: 1rem;\n          line-height: 1.5rem;\n          color: #4b5563;\n          width: 100%;\n          box-sizing: border-box;\n        }\n        .selected :global(a) {\n          font-weight: 600;\n          color: #161e2e;\n        }\n        .nav-link:hover :global(a) {\n          color: #161e2e;\n        }\n        span {\n          color: #a0aec0;\n        }\n        @media screen and (max-width: 950px) {\n          div {\n            padding-top: 0;\n            padding-left: 0;\n            padding-bottom: 0;\n          }\n          div.selected {\n            border-left: none;\n            padding-left: 0;\n          }\n          .nav-link :global(a) {\n            display: flex;\n            align-items: center;\n          }\n        }\n      `}</style>\n    </div>\n  )\n}\nSidebarNavLink.displayName = 'SidebarNavLink'\n"
  },
  {
    "path": "docs/src/components/SidebarPost.js",
    "content": "import * as React from 'react';\nimport { SidebarNavLink } from './SidebarNavLink';\nimport cn from 'classnames';\nexport const SidebarPost = ({\n  isMobile,\n  route,\n  level = 1,\n  onClick,\n  ...props\n}) => {\n  const selectedRef = React.useRef(null);\n  const ref = route.selected ? selectedRef : null;\n  React.useEffect(() => {\n    if (ref && ref.current && !isMobile) {\n      const content = document.querySelector('.sidebar-content'); // 32 is the top and bottom margin for `.link`\n\n      const height = ref.current.offsetTop - 32;\n\n      if (content) {\n        content.scrollTop = height - content.offsetHeight / 2;\n      }\n    }\n  }, [ref, isMobile]);\n  return <div ref={ref} className={cn('link', `level-${level}`)}>\n      <SidebarNavLink route={route} scrollSelectedIntoView={props.scrollSelectedIntoView} categorySelected={props.categorySelected} level={level} onClick={onClick} />\n      <style jsx>{`\n        .link {\n          margin: 12px 0;\n          display: flex;\n          align-items: center;\n        }\n\n        .link:first-child {\n          margin-top: 0;\n        }\n        .link:last-child {\n          margin-bottom: 0;\n        }\n        @media screen and (max-width: 950px) {\n          .link {\n            margin: 24px 0;\n          }\n        }\n      `}</style>\n    </div>;\n};"
  },
  {
    "path": "docs/src/components/Sticky.js",
    "content": "import * as React from 'react';\nimport cn from 'classnames';\nexport const Sticky = ({\n  offset,\n  children,\n  shadow\n}) => {\n  return <div style={{\n    top: offset || 0\n  }} className={cn({\n    shadow\n  }, 'z-10')}>\n      {children}\n\n      <style jsx>{`\n        div {\n          background: #fff;\n          position: sticky;\n        }\n        div.shadow {\n          box-shadow: rgba(0, 0, 0, 0.06) 0px 6px 20px;\n        }\n      `}</style>\n    </div>;\n};\nSticky.displayName = 'Sticky';"
  },
  {
    "path": "docs/src/components/TWButton.js",
    "content": "import * as React from 'react';\nimport { forwardRefWithAs } from './forwardRefWithAs';\nimport cx from 'classnames';\nconst mapIntentToColor = {\n  primary: 'blue',\n  success: 'green',\n  danger: 'red',\n  warning: 'yellow'\n};\nexport const TWButton = forwardRefWithAs(({\n  as: is = 'button',\n  children,\n  color,\n  intent = 'none',\n  size = 'md',\n  className,\n  icon,\n  minimal,\n  onClick,\n  iconRight,\n  ...props\n}, ref) => {\n  const tailwindColor = mapIntentToColor[intent] ?? color;\n  const iconIsOnlyChild = !!(icon && !iconRight && !children || iconRight && !icon && !children);\n  let sizeClasses;\n  let iconClasses;\n\n  if (size === 'xs') {\n    sizeClasses = 'text-xs rounded-md leading-4';\n    sizeClasses += iconIsOnlyChild ? ' p-1.5' : ' py-1.5 px-2.5';\n    iconClasses = 'h-3 w-3';\n  }\n\n  if (size === 'sm') {\n    sizeClasses = 'text-sm rounded-md leading-4';\n    sizeClasses += iconIsOnlyChild ? ' p-2' : ' py-2 px-3';\n    iconClasses = 'h-3 w-3';\n  }\n\n  if (size === 'md') {\n    sizeClasses = 'text-sm rounded-md leading-5';\n    sizeClasses += iconIsOnlyChild ? ' p-2' : ' py-2 px-4';\n    iconClasses = 'h-5 w-5';\n  }\n\n  if (size === 'lg') {\n    sizeClasses = 'text-base rounded-md leading-6';\n    sizeClasses += iconIsOnlyChild ? ' p-2' : ' py-2 px-4';\n    iconClasses = 'h-6 w-6';\n  }\n\n  if (size === 'xl') {\n    sizeClasses = 'text-base rounded-md leading-6';\n    sizeClasses += iconIsOnlyChild ? ' p-3' : ' py-3 px-6';\n    iconClasses = 'h-6 w-6';\n  }\n\n  const leftIcon = icon ? React.cloneElement(icon, { ...icon.props,\n    height: '1em',\n    width: '1em',\n    className: cx('block', {\n      'text-white': !!tailwindColor && !minimal,\n      [`text-${tailwindColor}-700`]: !!tailwindColor && !!minimal,\n      'text-gray-600': !tailwindColor,\n      '-ml-1 mr-2': !iconIsOnlyChild\n    }, iconClasses, icon?.props.className)\n  }) : null;\n  const rightIcon = iconRight ? React.cloneElement(iconRight, { ...iconRight.props,\n    height: '1em',\n    width: '1em',\n    className: cx('block ', {\n      'text-white': !!tailwindColor && !minimal,\n      [`text-${tailwindColor}-700`]: !!tailwindColor && !!minimal,\n      'text-gray-600': !tailwindColor,\n      '-mr-1 ml-2': !iconIsOnlyChild\n    }, iconClasses, iconRight?.props.className)\n  }) : null;\n  const propsToPass = { ...props,\n    className: cx('font-medium inline-flex items-center justify-center focus:outline-none transition duration-150 ease-in-out', {\n      [`shadow-xs  border border-transparent text-white bg-${tailwindColor}-600 hover:bg-${tailwindColor}-500 focus:border-${tailwindColor}-700 focus:shadow-outline-${tailwindColor} active:border-${tailwindColor}-700`]: !!tailwindColor && !minimal,\n      [`shadow-xs border border-gray-300 text-gray-700 bg-white hover:text-gray-500  focus:shadow-outline-blue focus:border-blue-300 active:text-gray-800 active:bg-gray-50`]: !tailwindColor && !minimal,\n      [`hover:bg-${tailwindColor}-100 active:bg-${tailwindColor}-200 text-${tailwindColor}-700 focus:shadow-outline-${tailwindColor} border-transparent`]: minimal && tailwindColor,\n      [`hover:bg-gray-200 active:bg-gray-300 text-gray-900 focus:shadow-outline-blue border-transparent`]: minimal && !tailwindColor\n    }, sizeClasses, className),\n    children: <>\n          {leftIcon}\n          {children}\n          {rightIcon}\n        </>\n  };\n  return React.createElement(is, { ...propsToPass,\n    ref,\n    onClick,\n    className: propsToPass.className\n  });\n});\nTWButton.displayName = 'TWButton';"
  },
  {
    "path": "docs/src/components/Toc.js",
    "content": "import * as React from 'react'\nimport cx from 'classnames'\nimport { useTocHighlight } from './useTocHighlight'\nimport styles from './Toc.module.css'\nconst TOP_OFFSET = 100\n\nfunction getHeaderAnchors() {\n  return Array.prototype.filter.call(\n    document.getElementsByClassName('anchor'),\n    function (testElement) {\n      return (\n        testElement.parentNode.nodeName === 'H2' ||\n        testElement.parentNode.nodeName === 'H3'\n      )\n    }\n  )\n}\n\nfunction getHeaderDataFromAnchors(el) {\n  return {\n    url: el.getAttribute('href'),\n    text: el.parentElement?.innerText,\n    depth: Number(el.parentElement?.nodeName.replace('H', '')),\n  }\n}\n\nexport const Toc = () => {\n  const headings = useTocHighlight(\n    styles.contents__link,\n    styles['contents__link--active'],\n    TOP_OFFSET,\n    getHeaderAnchors,\n    getHeaderDataFromAnchors,\n    el => el?.parentElement?.id\n  )\n\n  return (\n    <ul className=\"space-y-3\">\n      {headings &&\n        headings.length > 0 &&\n        headings.map((h, i) =>\n          h.url ? (\n            <li\n              key={`heading-${h.url}-${i}`}\n              className={cx('text-sm ', {\n                'pl-2': h?.depth === 3,\n                hidden: h.depth && h.depth > 3,\n              })}\n            >\n              <a className={styles.contents__link} href={h.url}>\n                {h.text}\n              </a>\n            </li>\n          ) : null\n        )}\n    </ul>\n  )\n}\n"
  },
  {
    "path": "docs/src/components/Toc.module.css",
    "content": "/* purgecss start ignore */\n.contents__link {\n  @apply text-gray-700;\n}\n\n.contents__link:hover {\n  @apply text-blue-600;\n}\n\n.contents__link--active {\n  @apply font-medium text-coral;\n}\n/* purgecss end ignore */\n"
  },
  {
    "path": "docs/src/components/TocNotion.js",
    "content": "import * as React from 'react';\nimport cx from 'classnames';\nimport { useTocHighlight } from './useTocHighlight';\nimport styles from './Toc.module.css';\nimport { NOTION_ANCHOR_CLASSNAME } from './blog/Heading';\nconst TOP_OFFSET = 100;\n\nconst getHeadingDataFromAnchor = el => {\n  return {\n    text: el.getAttribute('data-heading-text'),\n    depth: Number(el.getAttribute('data-heading-depth')),\n    url: el.getAttribute('href')\n  };\n};\n\nexport function getHeaderNotionAnchors() {\n  /**\n   * .filter() does not exist on HTMLCollectionOf<Element>\n   *  (the return type of document.getElementByClassName()),\n   *  so we use this as a workaround.\n   */\n  return Array.prototype.filter.call(document.getElementsByClassName(NOTION_ANCHOR_CLASSNAME), function (testElement) {\n    return testElement.firstElementChild?.nodeName === 'H2' || testElement.firstElementChild?.nodeName === 'H3';\n  });\n}\nexport const TocNotion = () => {\n  const headings = useTocHighlight(styles.contents__link, styles['contents__link--active'], TOP_OFFSET, getHeaderNotionAnchors, getHeadingDataFromAnchor, el => el?.id);\n  return <>\n      <h4 className=\"text-gray-700 font-semibold mb-3\">Table of Contents</h4>\n      <ul className=\"space-y-3\">\n        {headings && headings.length > 0 && headings.map((h, i) => h.url ? <li key={`heading-${h.url}-${i}`} className={cx('text-base ', {\n        ['pl-2']: h?.depth === 3,\n        ['hidden']: h.depth && h.depth > 3\n      })}>\n                <a className={styles.contents__link} href={h.url}>\n                  {h.text}\n                </a>\n              </li> : null)}\n      </ul>\n    </>;\n};"
  },
  {
    "path": "docs/src/components/blog/ExternalLink.js",
    "content": "import * as React from 'react';\nexport default function ExternalLink(props) {\n  return <a {...props} rel=\"noopener\" target={props.target || '_blank'} />;\n}"
  },
  {
    "path": "docs/src/components/blog/Heading.js",
    "content": "import * as React from 'react';\n\nconst collectText = (el, acc = []) => {\n  if (el) {\n    if (typeof el === 'string') acc.push(el);\n    if (Array.isArray(el)) el.map(item => collectText(item, acc));\n    if (typeof el === 'object') collectText(el.props && el.props.children, acc);\n  }\n\n  return acc.join('').trim();\n}; // Structure is in Heading\n\n\nexport const getTocDataFromHeading = el => {\n  return {\n    text: el.parentElement?.getAttribute('[data-text]'),\n    url: el.parentElement?.getAttribute('href')\n  };\n};\nexport const NOTION_ANCHOR_CLASSNAME = 'notion-anchor';\nexport default (({\n  children: component,\n  id\n}) => {\n  const children = component.props.children || '';\n  let text = children;\n\n  if (null == id) {\n    id = collectText(text).toLowerCase().replace(/\\s/g, '-').replace(/[?!:]/g, '');\n  }\n\n  return <a href={`#${id}`} id={id} className={NOTION_ANCHOR_CLASSNAME} style={{\n    color: 'inherit'\n  }} data-heading-text={collectText(text)} data-heading-depth={component.type.replace('h', '')}>\n      {component}\n    </a>;\n});"
  },
  {
    "path": "docs/src/components/blog/Image.js",
    "content": "import React, { Component } from 'react';\nimport IObserver from './intersection-observer';\nimport cn from 'classnames';\n\n// import VideoComponent from '../styleguide/video';\n\n// This component might look a little complex\n// because one could argue that keeping the aspect ratio\n// of an image can be solved with `height: auto`,\n// but it's actually not that easy if you want to prevent\n// element flickering\n\n// Because if you want to do that, you need to set the aspect\n// ratio of the image's container BEFORE the image loads\n\nclass Image extends Component {\n  constructor(props) {\n    super(props);\n  }\n\n  static defaultProps = {\n    lazy: true,\n  };\n\n  state = {\n    src: !this.props.lazy ? this.props.videoSrc || this.props.src : undefined,\n  };\n\n  handleIntersect = (entry) => {\n    if (entry.isIntersecting) {\n      this.setState({ src: this.props.src });\n    }\n  };\n\n  onLoad = () => {\n    this.setState({\n      loaded: true,\n    });\n  };\n\n  render() {\n    const {\n      caption,\n      height: origHeight,\n      lazy,\n      margin = 40,\n      video = false,\n      videoSrc,\n      width: origWidth,\n      captionSpacing = null,\n      oversize = true,\n      borderRadius = false,\n      alt,\n      imageProps,\n      className,\n      children,\n      ...props\n    } = this.props;\n    const height = parseInt(origHeight);\n    const width = parseInt(origWidth);\n\n    const aspectRatio = String((height / width) * 100) + '%';\n\n    // if (video || videoSrc) {\n    //   return <VideoComponent src={videoSrc} {...this.props} />;\n    // }\n\n    let src = this.state.src;\n\n    // if (src && src.indexOf('assets.zeit.co') > -1) {\n    //   if (src.indexOf('/q_auto') === -1) {\n    //     src = src.replace('upload/', 'upload/q_auto/');\n    //   }\n    // }\n\n    return (\n      <IObserver\n        once\n        onIntersect={this.handleIntersect}\n        rootMargin=\"20%\"\n        disabled={!lazy}\n      >\n        <figure\n          className={cn(className, {\n            oversize: width > 650 && oversize,\n            fadeIn: this.state.loaded,\n          })}\n          {...props}\n        >\n          <main style={{ width }}>\n            <div className=\"container\" style={{ paddingBottom: aspectRatio }}>\n              {src ? (\n                <img\n                  decoding=\"async\"\n                  loading=\"lazy\"\n                  src={src || null}\n                  onLoad={this.onLoad}\n                  alt={alt}\n                  {...imageProps}\n                />\n              ) : (\n                children\n              )}\n            </div>\n\n            {caption && (\n              <p style={captionSpacing ? { marginTop: captionSpacing } : {}}>\n                {caption}\n              </p>\n            )}\n          </main>\n\n          <style jsx>{`\n            figure {\n              display: block;\n              text-align: center;\n              margin: ${margin}px 0;\n            }\n\n            figure.fadeIn {\n              animation: fade-in 0.2s cubic-bezier(0.455, 0.03, 0.515, 0.955)\n                forwards;\n            }\n\n            figure.fadeIn img {\n              display: block;\n            }\n\n            @keyframes fade-in {\n              from {\n                /* Don't begin with 0, it gives a feeling of flickering. */\n                opacity: 0.3;\n              }\n              to {\n                opacity: 1;\n              }\n            }\n\n            main {\n              margin: 0 auto;\n              max-width: 100%;\n            }\n\n            div {\n              position: relative;\n            }\n\n            img {\n              display: none;\n              height: 100%;\n              left: 0;\n              position: absolute;\n              top: 0;\n              width: 100%;\n              ${borderRadius ? `border-radius: var(--geist-radius);` : ''};\n            }\n\n            .container {\n              display: flex;\n              justify-content: center;\n            }\n\n            p {\n              color: var(--accents-5);\n              font-size: 14px;\n              margin: 10px 0 0 0;\n              text-align: center;\n            }\n\n            @media (min-width: 992px) {\n              figure.oversize {\n                width: ${width}px;\n                margin: ${margin}px 0 ${margin}px\n                  calc(((${width}px - 768px) / 2) * -1);\n              }\n\n              p {\n                margin: 0;\n              }\n            }\n          `}</style>\n        </figure>\n      </IObserver>\n    );\n  }\n}\n\n// export const Video = (props) => <Image {...props} video />;\n\nexport default Image;\n"
  },
  {
    "path": "docs/src/components/blog/dynamic.js",
    "content": "import dynamic from 'next/dynamic';\nimport ExtLink from './ExternalLink';\nexport default {\n  // default tags\n  ol: 'ol',\n  ul: 'ul',\n  li: 'li',\n  p: 'p',\n  blockquote: 'blockquote',\n  a: ExtLink,\n  Image: dynamic(() => import('./Image')),\n  Code: dynamic(() => import('../Highlight')) // Counter: dynamic(() => import('./counter')),\n\n};"
  },
  {
    "path": "docs/src/components/blog/intersection-observer/index.js",
    "content": "export { default } from './intersection-observer'\n"
  },
  {
    "path": "docs/src/components/blog/intersection-observer/intersection-observer.js",
    "content": "// Packages\nimport { Component, cloneElement, Children } from 'react';\nimport { findDOMNode } from 'react-dom';\nimport PropTypes from 'prop-types';\n\n// Private Observer Manager functions and manager\nimport { getObserver, observeTarget, unobserveTarget } from './manager';\nimport { hasEqualOptions, isDOMNode } from './utils';\n\nexport default class Observer extends Component {\n  static propTypes = {\n    disabled: PropTypes.bool,\n    once: PropTypes.bool,\n    onIntersect: PropTypes.func.isRequired,\n    render: PropTypes.func,\n    root: PropTypes.element,\n    rootMargin: PropTypes.string,\n    threshold: PropTypes.oneOfType([\n      PropTypes.arrayOf(PropTypes.number),\n      PropTypes.number,\n    ]),\n    value: PropTypes.string,\n  };\n\n  static defaultProps = {\n    disabled: false,\n    once: false,\n  };\n\n  shouldReobserve = false;\n\n  componentDidMount() {\n    this.observer = getObserver(getOptions(this.props));\n    this.observe();\n  }\n\n  componentDidUpdate(prevProps) {\n    const nextOptions = getOptions(this.props);\n    if (!hasEqualOptions(this.observer, nextOptions)) {\n      this.unobserve();\n      this.observer = getObserver(nextOptions);\n      this.shouldReobserve = true;\n    }\n\n    if (prevProps.disabled && !this.props.disabled) {\n      this.shouldReobserve = true;\n    }\n\n    if (!prevProps.disabled && this.props.disabled) {\n      this.unobserve();\n    }\n\n    if (this.shouldReobserve) {\n      this.observe();\n      this.shouldReobserve = false;\n    }\n  }\n\n  componentWillUnmount() {\n    this.unobserve();\n  }\n\n  handleTarget = (node) => {\n    // eslint-disable-next-line\n    const element = isDOMNode(node) ? node : findDOMNode(node);\n    if (this.target && this.target !== element) {\n      this.unobserve();\n      this.shouldReobserve = true;\n    }\n    this.target = element;\n  };\n\n  observe() {\n    if (!this.props.disabled && this.target) {\n      observeTarget(this.observer, this.target, this.handleIntersect);\n    }\n  }\n\n  unobserve() {\n    if (this.target) {\n      unobserveTarget(this.observer, this.target);\n    }\n  }\n\n  handleIntersect = (entry) => {\n    this.props.onIntersect(entry, this.props.value);\n    if (this.props.once && entry.isIntersecting) {\n      this.unobserve();\n    }\n  };\n\n  render() {\n    return this.props.render\n      ? this.props.render({ innerRef: this.handleTarget })\n      : cloneElement(Children.only(this.props.children), {\n          ref: this.handleTarget,\n        });\n  }\n}\n\nconst getOptions = (props) => ({\n  root: props.root,\n  rootMargin: props.rootMargin,\n  threshold: props.threshold,\n});\n"
  },
  {
    "path": "docs/src/components/blog/intersection-observer/manager.js",
    "content": "import { hasEqualOptions, parseOptions } from './utils'\n\nif (typeof window !== 'undefined') {\n  require('intersection-observer')\n}\n\nconst manager = (function makeManager() {\n  const observers = new Map()\n\n  function getObserver(options) {\n    return (\n      findObserver(options) ||\n      new IntersectionObserver(intersectionCallback, options)\n    )\n  }\n\n  function findObserver(options = {}) {\n    const parsedOptions = parseOptions(options)\n    for (const observer of observers.keys()) {\n      if (hasEqualOptions(observer, parsedOptions)) {\n        return observer\n      }\n    }\n    return null\n  }\n\n  function getObserverTargets(observer) {\n    return !observers.has(observer)\n      ? observers.set(observer, new Map()).get(observer)\n      : observers.get(observer)\n  }\n\n  function observeTarget(observer, target, handler) {\n    const targets = getObserverTargets(observer)\n    targets.set(target, handler)\n    observer.observe(target)\n  }\n\n  function unobserveTarget(observer, target) {\n    const handlers = getObserverTargets(observer)\n    handlers.delete(target)\n    observer.unobserve(target)\n  }\n\n  function intersectionCallback(entries, observer) {\n    for (let entry of entries) {\n      const handlers = getObserverTargets(observer)\n      const handler = handlers.get(entry.target)\n      if (handler) {\n        handler(entry)\n      }\n    }\n  }\n\n  return {\n    getObserver,\n    observeTarget,\n    unobserveTarget\n  }\n})()\n\nexport default manager\nexport const { getObserver } = manager\nexport const { observeTarget } = manager\nexport const { unobserveTarget } = manager\n"
  },
  {
    "path": "docs/src/components/blog/intersection-observer/utils.js",
    "content": "export function isDOMNode(node) {\n  return (\n    node && Object.prototype.hasOwnProperty.call(node, 'getBoundingClientRect')\n  )\n}\n\nexport function parseOptions(options = {}) {\n  return {\n    root: options.root || null,\n    rootMargin: parseRootMargin(options.rootMargin),\n    threshold: parseThreshold(options.threshold)\n  }\n}\n\nexport function hasEqualOptions(observer, options) {\n  return (\n    equalPair(options.root, observer.root) &&\n    equalPair(options.rootMargin, observer.rootMargin) &&\n    equalPair(options.threshold, observer.thresholds)\n  )\n}\n\nfunction parseRootMargin(rootMargin) {\n  const margins = (rootMargin || '0px').trim().split(/\\s+/)\n  margins.forEach(validateRootMargin)\n  margins[1] = margins[1] || margins[0]\n  margins[2] = margins[2] || margins[0]\n  margins[3] = margins[3] || margins[1]\n  return margins.join(' ')\n}\n\nfunction validateRootMargin(margin) {\n  if (!/^-?\\d*\\.?\\d+(px|%)$/.test(margin)) {\n    throw new Error('rootMargin must be specified as a CSS margin property')\n  }\n}\n\nfunction parseThreshold(threshold) {\n  return !Array.isArray(threshold)\n    ? [typeof threshold !== 'undefined' ? threshold : 0]\n    : threshold\n}\n\nfunction equalPair(optionA, optionB) {\n  if (Array.isArray(optionA) && Array.isArray(optionB)) {\n    if (optionA.length === optionB.length) {\n      return optionA.every((element, idx) =>\n        equalPair(optionA[idx], optionB[idx])\n      )\n    }\n  }\n  return optionA === optionB\n}\n"
  },
  {
    "path": "docs/src/components/blog-markdown.module.css",
    "content": "/* purgecss start ignore */\n.markdown {\n  @apply leading-relaxed text-gray-800 text-base;\n}\n\n/* \n  Add fake margin to offset the nav. This technique is stolen right from the Tailwind docs \n  @see https://tailwindcss.com/docs/customizing-colors/#app\n*/\n.markdown > h1:before,\n.markdown > a > h1:before,\n.markdown > h2:before,\n.markdown > a > h2:before,\n.markdown > h3:before,\n.markdown > a > h3:before,\n.markdown > h4:before,\n.markdown > a > h4:before,\n.markdown > h5:before,\n.markdown > a > h5:before,\n.markdown > h6:before,\n.markdown > a > h6:before {\n  display: block;\n  height: 6rem;\n  margin-top: -6rem;\n  visibility: hidden;\n  content: '';\n}\n\n.markdown > h1,\n.markdown > a > h1 {\n  @apply mb-6 text-3xl lg:text-4xl font-semibold leading-snug tracking-tighter text-gray-900;\n}\n\n.markdown > h2,\n.markdown > a > h2 {\n  @apply mt-12 mb-4 text-2xl font-semibold  text-gray-900;\n}\n\n.markdown > h2 code,\n.markdown > a > h2 code {\n  @apply text-xl;\n}\n\n.markdown > h3,\n.markdown > a > h3 {\n  @apply mt-8 mb-3 text-xl font-semibold  text-gray-900;\n}\n\n.markdown > h3 code,\n.markdown > a > h3 code {\n  @apply text-lg;\n}\n\n.markdown > h4,\n.markdown > a > h4 {\n  @apply pt-8 mb-3 text-lg font-semibold  text-gray-900;\n}\n\n.markdown > h4 code,\n.markdown > a > h4 code {\n  @apply text-base;\n}\n\n.markdown > p > a,\n.markdown > ul > li > a,\n.markdown > ol > li > a,\n.markdown > table > tbody > tr > td > a {\n  @apply text-blue-600 font-semibold transition-colors duration-150 ease-out;\n}\n\n.markdown > p > a:hover,\n.markdown > ul > li > a:hover,\n.markdown > ol > li > a:hover,\n.markdown > table > tbody > tr > td > a:hover {\n  @apply text-blue-800 transition-colors duration-150 ease-out;\n}\n\n.markdown strong {\n  @apply font-bold;\n}\n\n.markdown > p,\n.markdown > ul,\n.markdown > ol,\n.markdown > blockquote,\n.markdown > pre,\n.markdown > div > .code-block {\n  @apply mb-4;\n}\n\n.markdown > ul,\n.markdown > ul > li > ul {\n  @apply ml-8 list-disc;\n}\n\n.markdown > ol {\n  @apply ml-8 list-decimal;\n}\n\n.markdown > pre,\n.markdown > div > .code-block > pre {\n  color: #f8f8f2;\n  overflow: auto;\n}\n\n.markdown > table {\n  @apply mb-6 w-full text-gray-700 text-sm;\n}\n\n.markdown > table > thead > tr {\n  @apply border-b border-t;\n}\n\n.markdown > table > thead > tr > th {\n  @apply px-3 py-2 text-left text-sm font-bold bg-gray-100 text-gray-700;\n}\n\n.markdown > table > tbody > tr {\n  @apply border-b;\n}\n\n.markdown > table > tbody > tr > td {\n  @apply p-3;\n}\n\n.markdown > :not(pre):not(h3) > code,\n.markdown > ul > li > code,\n.markdown > blockquote > code,\n.markdown > blockquote > p > code,\n.markdown > ul > li > ul > li > code,\n.markdown > ol > li > code,\n.markdown > ol > li > ol > li > code,\n.markdown > p a > code,\n.markdown > table > tbody > tr > td:not(:first-child) > code {\n  @apply bg-gray-100 rounded-md px-1  border border-gray-300 text-gray-900;\n  margin-left: 2px;\n  margin-right: 2px;\n  padding-top: 2px;\n  padding-bottom: 2px;\n  word-break: keep-all;\n  font-size: 0.875em;\n}\n\n.markdown > table > tbody > tr > td:not(:first-child) > code {\n  @apply text-xs;\n}\n\n.markdown > table > tbody > tr > td > a > code,\n.markdown > table > tbody > tr > td > code {\n  @apply text-sm;\n}\n\n.markdown > h2 > code {\n  @apply text-xl;\n}\n\n.markdown > .markdown ul {\n  @apply list-disc;\n}\n\n.markdown > hr {\n  @apply my-6 block border-b;\n}\n.markdown pre {\n  @apply p-3 rounded-lg  mb-6 overflow-y-scroll text-sm bg-gray-100;\n  background: #292d3e;\n}\n/* Blockquotes */\n.markdown blockquote {\n  @apply p-3 bg-gray-100 mb-6 border border-gray-300 border-l-4 rounded-sm text-sm leading-5;\n}\n.markdown blockquote > p {\n  @apply mb-0;\n}\n\n/* purgecss end ignore */\n"
  },
  {
    "path": "docs/src/components/clients/Client.js",
    "content": "import React from 'react'\nimport { LazyImage } from '../LazyImage'\nexport const Client = React.memo(({ name, image, style, ...rest }) => (\n  <span title={name} {...rest}>\n    <LazyImage\n      src={image}\n      alt={name}\n      width={150}\n      style={style}\n      className=\"inline\"\n    />\n  </span>\n))\n"
  },
  {
    "path": "docs/src/components/clients/ClientsMarquee.js",
    "content": "import React from 'react'\nimport { users } from 'users'\n\n// const pinnedLogos = users.filter(p => p.pinned)\n\nexport const ClientsMarquee = React.memo(props => {\n  return (\n    <div className=\"overflow-x-hidden\">\n      <div className=\"relative translate-x-1/2\" {...props}>\n        <div className=\"wrapper inline-block\">\n          {[...users, ...users, ...users].map((user, i) => (\n            <span\n              key={user + i}\n              className={`text-gray-300 inline-block text-2xl font-black m-1 ${i %\n                2 && 'text-gray-400'}`}\n            >\n              {user}\n            </span>\n          ))}\n        </div>\n\n        <style jsx global>{`\n          @keyframes slidein {\n            from {\n              transform: translate3d(0, 0, 0);\n            }\n\n            to {\n              transform: translate3d(-50%, 0, 0);\n            }\n          }\n          .wrapper {\n            position: relative;\n            white-space: nowrap;\n            display: inline-block;\n            animation: slidein 100s linear infinite;\n          }\n        `}</style>\n      </div>\n    </div>\n  )\n})\nClientsMarquee.displayName = 'ClientsMarquee'\n"
  },
  {
    "path": "docs/src/components/clients/Filters.js",
    "content": "import React from 'react'\nexport const Filters = () => (\n  <>\n    <svg width={0} height={0}>\n      <defs>\n        <filter id=\"high-threshold\">\n          <feColorMatrix type=\"saturate\" values=\"0\" />\n          <feComponentTransfer>\n            <feFuncR type=\"discrete\" tableValues=\"0\" />\n            <feFuncG type=\"discrete\" tableValues=\"0\" />\n            <feFuncB type=\"discrete\" tableValues=\"0\" />\n          </feComponentTransfer>\n        </filter>\n      </defs>\n    </svg>\n    <svg width={0} height={0}>\n      <defs>\n        <filter id=\"medium-threshold\">\n          <feColorMatrix type=\"saturate\" values=\"0\" />\n          <feComponentTransfer>\n            <feFuncR type=\"discrete\" tableValues=\"0 1\" />\n            <feFuncG type=\"discrete\" tableValues=\"0 1\" />\n            <feFuncB type=\"discrete\" tableValues=\"0 1\" />\n          </feComponentTransfer>\n        </filter>\n      </defs>\n    </svg>\n    <svg width={0} height={0}>\n      <defs>\n        <filter id=\"low-threshold\">\n          <feColorMatrix type=\"saturate\" values=\"0\" />\n          <feComponentTransfer>\n            <feFuncR type=\"discrete\" tableValues=\"0 0 0 0 1\" />\n            <feFuncG type=\"discrete\" tableValues=\"0 0 0 0 1\" />\n            <feFuncB type=\"discrete\" tableValues=\"0 0 0 0 1\" />\n          </feComponentTransfer>\n        </filter>\n      </defs>\n    </svg>\n  </>\n)\n"
  },
  {
    "path": "docs/src/components/forwardRefWithAs.js",
    "content": "import * as React from 'react';\n/**\n * React.Ref uses the readonly type `React.RefObject` instead of\n * `React.MutableRefObject`, We pretty much always assume ref objects are\n * mutable (at least when we create them), so this type is a workaround so some\n * of the weird mechanics of using refs with TS.\n */\n\n/**\n * This is a hack for sure. The thing is, getting a component to intelligently\n * infer props based on a component or JSX string passed into an `as` prop is\n * kind of a huge pain. Getting it to work and satisfy the constraints of\n * `forwardRef` seems dang near impossible. To avoid needing to do this awkward\n * type song-and-dance every time we want to forward a ref into a component\n * that accepts an `as` prop, we abstract all of that mess to this function for\n * the time time being.\n *\n * TODO: Eventually we should probably just try to get the type defs above\n * working across the board, but ain't nobody got time for that mess!\n *\n * @param Comp\n */\nexport function forwardRefWithAs(comp) {\n  return React.forwardRef(comp);\n}\n/*\nTest components to make sure our dynamic As prop components work as intended \ntype PopupProps = {\n  lol: string;\n  children?: React.ReactNode | ((value?: number) => JSX.Element);\n};\nexport const Popup = forwardRefWithAs<PopupProps, 'input'>(\n  ({ as: Comp = 'input', lol, className, children, ...props }, ref) => {\n    return (\n      <Comp ref={ref} {...props}>\n        {typeof children === 'function' ? children(56) : children}\n      </Comp>\n    );\n  }\n);\nexport const TryMe1: React.FC = () => {\n  return <Popup as=\"input\" lol=\"lol\" name=\"me\" />;\n};\nexport const TryMe2: React.FC = () => {\n  let ref = React.useRef(null);\n  return <Popup ref={ref} as=\"div\" lol=\"lol\" />;\n};\n\nexport const TryMe4: React.FC = () => {\n  return <Popup as={Whoa} lol=\"lol\" test=\"123\" name=\"boop\" />;\n};\nexport const Whoa: React.FC<{\n  help?: boolean;\n  lol: string;\n  name: string;\n  test: string;\n}> = props => {\n  return <input {...props} />;\n};\n*/\n// export const TryMe3: React.FC = () => {\n//   return <Popup as={Cool} lol=\"lol\" name=\"me\" test=\"123\" />;\n// };\n// let Cool = styled(Whoa)`\n//   padding: 10px;\n// `"
  },
  {
    "path": "docs/src/components/markdown.module.css",
    "content": "/* purgecss start ignore */\n.markdown {\n  @apply leading-relaxed text-gray-800 text-base;\n}\n\n/* \n  Add fake margin to offset the nav. This technique is stolen right from the Tailwind docs \n  @see https://tailwindcss.com/docs/customizing-colors/#app\n*/\n.markdown > h1:before,\n.markdown > a > h1:before,\n.markdown > h2:before,\n.markdown > a > h2:before,\n.markdown > h3:before,\n.markdown > a > h3:before,\n.markdown > h4:before,\n.markdown > a > h4:before,\n.markdown > h5:before,\n.markdown > a > h5:before,\n.markdown > h6:before,\n.markdown > a > h6:before {\n  display: block;\n  height: 6rem;\n  margin-top: -6rem;\n  visibility: hidden;\n  content: '';\n}\n\n.markdown > h1,\n.markdown > a > h1 {\n  @apply mb-6 text-4xl font-semibold leading-snug tracking-tighter text-gray-900;\n}\n\n.markdown > h2,\n.markdown > a > h2 {\n  @apply mt-12 mb-4 text-2xl font-semibold  text-gray-900;\n}\n\n.markdown > h2 code,\n.markdown > a > h2 code {\n  @apply text-xl;\n}\n\n.markdown > h3,\n.markdown > a > h3 {\n  @apply mt-8 mb-3 text-xl font-semibold  text-gray-900;\n}\n\n.markdown > h3 code,\n.markdown > a > h3 code {\n  @apply text-lg;\n}\n\n.markdown > h4,\n.markdown > a > h4 {\n  @apply pt-8 mb-3 text-lg font-semibold  text-gray-900;\n}\n\n.markdown > h4 code,\n.markdown > a > h4 code {\n  @apply text-base;\n}\n\n.markdown > p > a,\n.markdown > ul > li > a,\n.markdown > ol > li > a,\n.markdown > table > tbody > tr > td > a {\n  @apply text-blue-600 font-semibold transition-colors duration-150 ease-out;\n}\n\n.markdown > p > a:hover,\n.markdown > ul > li > a:hover,\n.markdown > ol > li > a:hover,\n.markdown > table > tbody > tr > td > a:hover {\n  @apply text-blue-800 transition-colors duration-150 ease-out;\n}\n\n.markdown strong {\n  @apply font-bold;\n}\n\n.markdown > p,\n.markdown > ul,\n.markdown > ol,\n.markdown > blockquote,\n.markdown > pre,\n.markdown > div > .code-block {\n  @apply mb-4;\n}\n\n.markdown > ul,\n.markdown > ul > li > ul {\n  @apply ml-8 list-disc;\n}\n\n.markdown > ol {\n  @apply ml-8 list-decimal;\n}\n\n.markdown > pre,\n.markdown > div > .code-block > pre {\n  color: #f8f8f2;\n  overflow: auto;\n}\n\n.markdown > table {\n  @apply mb-6 w-full text-gray-700 text-sm;\n}\n\n.markdown > table > thead > tr {\n  @apply border-b border-t;\n}\n\n.markdown > table > thead > tr > th {\n  @apply px-3 py-2 text-left text-sm font-bold bg-gray-100 text-gray-700;\n}\n\n.markdown > table > tbody > tr {\n  @apply border-b;\n}\n\n.markdown > table > tbody > tr > td {\n  @apply p-3;\n}\n\n.markdown > :not(pre):not(h3) > code,\n.markdown > ul > li > code,\n.markdown > blockquote > code,\n.markdown > blockquote > p > code,\n.markdown > ul > li > ul > li > code,\n.markdown > ol > li > code,\n.markdown > ol > li > ol > li > code,\n.markdown > p a > code,\n.markdown > table > tbody > tr > td:not(:first-child) > code {\n  @apply bg-gray-100 rounded-md px-1  border border-gray-300 text-gray-900;\n  margin-left: 2px;\n  margin-right: 2px;\n  padding-top: 2px;\n  padding-bottom: 2px;\n  word-break: keep-all;\n  font-size: 0.875em;\n}\n\n.markdown > table > tbody > tr > td:not(:first-child) > code {\n  @apply text-xs;\n}\n\n.markdown > table > tbody > tr > td > a > code,\n.markdown > table > tbody > tr > td > code {\n  @apply text-sm;\n}\n\n.markdown > h2 > code {\n  @apply text-xl;\n}\n\n.markdown > .markdown ul {\n  @apply list-disc;\n}\n\n.markdown > hr {\n  @apply my-6 block border-b;\n}\n\n/* Blockquotes */\n.markdown blockquote {\n  @apply p-3 bg-gray-100 mb-6 border border-gray-300 border-l-4 rounded-sm text-sm leading-5;\n}\n.markdown blockquote > p {\n  @apply mb-0;\n}\n\n/* purgecss end ignore */\n"
  },
  {
    "path": "docs/src/components/useBytesSubmit.js",
    "content": "import { useState } from 'react';\n\nfunction sendBytesOptIn({ email, influencer, source, referral }) {\n  return fetch(`https://bytes.dev/api/bytes-optin-cors`, {\n    method: 'POST',\n    body: JSON.stringify({ email, influencer, source, referral }),\n    headers: {\n      Accept: 'application/json',\n      'Content-Type': 'application/json',\n    },\n  }).then((res) => res.json())\n}\n\nexport default function useBytesSubmit() {\n  const [state, setState] = useState(\"initial\");\n  const [error, setError] = useState(null);\n\n  const handleSubmit = (e) => {\n    e.preventDefault();\n    const email = e.target.email_address.value;\n    setState(\"loading\");\n    sendBytesOptIn({ email, influencer: \"tanstack\"  })\n      .then(() => {\n        setState(\"submitted\");\n      })\n      .catch((err) => {\n        setError(err);\n      });\n  };\n\n  return { handleSubmit, state, error };\n}"
  },
  {
    "path": "docs/src/components/useClipboard.js",
    "content": "import * as React from 'react';\nimport copy from 'copy-to-clipboard';\n/**\n * React hook to copy content to clipboard\n *\n * @param text the text or value to copy\n * @param timeout delay (in ms) to switch back to initial state once copied.\n */\n\nexport function useClipboard(text, timeout = 1500) {\n  const [hasCopied, setHasCopied] = React.useState(false);\n  const onCopy = React.useCallback(() => {\n    const didCopy = copy(text);\n    setHasCopied(didCopy);\n  }, [text]); // @ts-ignore\n\n  React.useEffect(() => {\n    if (hasCopied) {\n      const id = setTimeout(() => {\n        setHasCopied(false);\n      }, timeout);\n      return () => clearTimeout(id);\n    }\n  }, [timeout, hasCopied]);\n  return [hasCopied, onCopy];\n}"
  },
  {
    "path": "docs/src/components/useIsMobile.js",
    "content": "import { useState, useCallback, useEffect } from 'react'\n\nconst useMediaQuery = width => {\n  const [targetReached, setTargetReached] = useState(false)\n  const updateTarget = useCallback(e => {\n    if (e.matches) {\n      setTargetReached(true)\n    } else {\n      setTargetReached(false)\n    }\n  }, [])\n  useEffect(() => {\n    const media = window.matchMedia(`(max-width: ${width}px)`)\n    media.addListener(updateTarget) // Check on mount (callback is not called until a change occurs)\n\n    if (media.matches) {\n      setTargetReached(true)\n    }\n\n    return () => media.removeListener(updateTarget)\n  }, [])\n  return targetReached\n}\n\nconst useIsMobile = () => {\n  return useMediaQuery(1024)\n}\n\nexport { useMediaQuery, useIsMobile }\n"
  },
  {
    "path": "docs/src/components/useOverScroll.js",
    "content": "import * as React from 'react';\nimport { useViewportScroll, useTransform } from 'framer-motion';\nimport { throttle } from './utils/throttle';\n\nconst throttleFn = cb => throttle(cb, 100);\n\nexport const useOverScroll = () => {\n  const {\n    scrollY\n  } = useViewportScroll();\n  const ref = React.useRef(null);\n  const refInner = React.useRef(null);\n  const [height, setHeight] = React.useState(typeof window !== 'undefined' ? window.innerHeight : 0);\n  const [rect, setRect] = React.useState({\n    top: 0,\n    left: 0,\n    right: 0,\n    bottom: 0,\n    x: 0,\n    y: 0\n  });\n  const [rectInner, setRectInner] = React.useState({\n    top: 0,\n    left: 0,\n    right: 0,\n    bottom: 0,\n    x: 0,\n    y: 0\n  });\n  const y = useTransform(scrollY, [rect.bottom - height, rect.top + 300], [0, -rectInner.height + rect.height]);\n  React.useEffect(() => {\n    if (ref.current) {\n      setRect(ref.current.getBoundingClientRect());\n    }\n  }, [setRect, ref]);\n  React.useEffect(() => {\n    if (refInner.current) {\n      setRectInner(refInner.current.getBoundingClientRect());\n    }\n  }, [setRectInner, refInner]);\n  return {\n    ref,\n    refInner,\n    y\n  };\n};"
  },
  {
    "path": "docs/src/components/useSearch.js",
    "content": "import React from 'react'\nimport { createPortal } from 'react-dom'\nimport Router from 'next/router'\nimport Head from 'next/head'\nimport Link from 'next/link'\nimport { useDocSearchKeyboardEvents } from '@docsearch/react'\nimport { siteConfig } from 'siteConfig'\n\nconst SearchContext = React.createContext()\nlet DocSearchModal = null\n\nexport const useSearch = () => React.useContext(SearchContext)\n\nexport function SearchProvider({\n  children,\n  searchParameters = {\n    hitsPerPage: 5,\n  },\n}) {\n  const [isShowing, setIsShowing] = React.useState(false)\n\n  const onOpen = React.useCallback(function onOpen() {\n    function importDocSearchModalIfNeeded() {\n      if (DocSearchModal) {\n        return Promise.resolve()\n      }\n\n      return import('@docsearch/react/modal').then(\n        ({ DocSearchModal: Modal }) => (DocSearchModal = Modal)\n      )\n    }\n\n    importDocSearchModalIfNeeded().then(() => {\n      setIsShowing(true)\n    })\n  }, [])\n\n  const onClose = React.useCallback(() => setIsShowing(false), [])\n\n  useDocSearchKeyboardEvents({\n    isOpen: isShowing,\n    onOpen,\n    onClose,\n  })\n\n  const options = {\n    appId: siteConfig.algolia.appId,\n    apiKey: siteConfig.algolia.apiKey,\n    indexName: siteConfig.algolia.indexName,\n    renderModal: true,\n  }\n\n  return (\n    <>\n      <Head>\n        <link\n          key=\"algolia\"\n          rel=\"preconnect\"\n          href={`https://${options.appId}-dsn.algolia.net`}\n          crossOrigin=\"true\"\n        />\n      </Head>\n\n      <SearchContext.Provider value={{ DocSearchModal, onOpen }}>\n        {children}\n      </SearchContext.Provider>\n\n      {isShowing &&\n        createPortal(\n          <DocSearchModal\n            {...options}\n            searchParameters={searchParameters}\n            onClose={onClose}\n            navigator={{\n              navigate({ suggestionUrl }) {\n                Router.push(suggestionUrl)\n              },\n            }}\n            transformItems={items => {\n              return items.map(item => {\n                const url = new URL(item.url)\n                return {\n                  ...item,\n                  url: item.url\n                    .replace(url.origin, '')\n                    .replace('#__next', '')\n                    .replace('/docs/#', '/docs/overview#'),\n                }\n              })\n            }}\n            hitComponent={Hit}\n          />,\n          document.body\n        )}\n    </>\n  )\n}\n\nfunction Hit({ hit, children }) {\n  return (\n    <Link href={hit.url.replace()}>\n      <a>{children}</a>\n    </Link>\n  )\n}\n"
  },
  {
    "path": "docs/src/components/useTocHighlight.js",
    "content": "import React from 'react';\n\n/**\n * Sets up Table of Contents highlighting. It requires that\n */\nexport function useTocHighlight(linkClassName, linkActiveClassName, topOffset, getHeaderAnchors, getHeaderDataFromAnchor, getAnchorHeaderIdentifier) {\n  const [lastActiveLink, setLastActiveLink] = React.useState(undefined);\n  const [headings, setHeadings] = React.useState([]);\n  React.useEffect(() => {\n    setHeadings(getHeaderAnchors().map(getHeaderDataFromAnchor));\n  }, [setHeadings]);\n  React.useEffect(() => {\n    let headersAnchors = [];\n    let links = [];\n\n    function setActiveLink() {\n      function getActiveHeaderAnchor() {\n        let index = 0;\n        let activeHeaderAnchor = null;\n        headersAnchors = getHeaderAnchors();\n\n        while (index < headersAnchors.length && !activeHeaderAnchor) {\n          const headerAnchor = headersAnchors[index];\n          const {\n            top\n          } = headerAnchor.getBoundingClientRect();\n\n          if (top >= 0 && top <= topOffset) {\n            activeHeaderAnchor = headerAnchor;\n          }\n\n          index += 1;\n        }\n\n        return activeHeaderAnchor;\n      }\n\n      const activeHeaderAnchor = getActiveHeaderAnchor();\n\n      if (activeHeaderAnchor) {\n        let index = 0;\n        let itemHighlighted = false;\n        links = document.getElementsByClassName(linkClassName);\n\n        while (index < links.length && !itemHighlighted) {\n          const link = links[index];\n          const {\n            href\n          } = link;\n          const anchorValue = decodeURIComponent(href.substring(href.indexOf('#') + 1));\n\n          if (getAnchorHeaderIdentifier(activeHeaderAnchor) === anchorValue) {\n            if (lastActiveLink) {\n              lastActiveLink.classList.remove(linkActiveClassName);\n            }\n\n            link.classList.add(linkActiveClassName);\n            setLastActiveLink(link);\n            itemHighlighted = true;\n          }\n\n          index += 1;\n        }\n      }\n    }\n\n    document.addEventListener('scroll', setActiveLink);\n    document.addEventListener('resize', setActiveLink);\n    setActiveLink();\n    return () => {\n      document.removeEventListener('scroll', setActiveLink);\n      document.removeEventListener('resize', setActiveLink);\n    };\n  });\n  return headings;\n}"
  },
  {
    "path": "docs/src/components/utils/throttle.js",
    "content": "export const throttle = (func, limit) => {\n  let inThrottle;\n  return function () {\n    const args = arguments; // @ts-ignore\n\n    const context = this;\n\n    if (!inThrottle) {\n      func.apply(context, args);\n      inThrottle = true;\n      setTimeout(() => inThrottle = false, limit);\n    }\n  };\n};"
  },
  {
    "path": "docs/src/manifests/getManifest.js",
    "content": "import manifest from './manifest.json'\n\nconst versions = {}\n\nexport const versionList = Object.keys(versions)\nexport const getManifest = tag => {\n  return tag ? versions[tag] : manifest\n}\n"
  },
  {
    "path": "docs/src/manifests/manifest.json",
    "content": "{\n  \"routes\": [\n    {\n      \"title\": \"Documentation\",\n      \"heading\": true,\n      \"routes\": [\n        {\n          \"title\": \"Overview\",\n          \"path\": \"/docs/overview\",\n          \"editUrl\": \"/docs/overview.md\"\n        },\n        {\n          \"title\": \"Installation\",\n          \"path\": \"/docs/installation\",\n          \"editUrl\": \"/docs/installation.md\"\n        },\n        {\n          \"title\": \"Getting Started\",\n          \"path\": \"/docs/getting-started\",\n          \"editUrl\": \"/docs/getting-started.md\"\n        },\n        {\n          \"title\": \"API Reference\",\n          \"path\": \"/docs/api\",\n          \"editUrl\": \"/docs/api.md\"\n        }\n      ]\n    },\n    {\n      \"title\": \"Examples\",\n      \"open\": true,\n      \"routes\": [\n        {\n          \"title\": \"Simple\",\n          \"path\": \"/examples/simple\",\n          \"editUrl\": \"/examples/simple.md\"\n        }\n      ]\n    }\n  ]\n}\n"
  },
  {
    "path": "docs/src/pages/_app.js",
    "content": "import React from 'react'\nimport '@docsearch/react/dist/style.css'\nimport '../styles/index.css'\nimport Head from 'next/head'\nimport { SearchProvider } from 'components/useSearch'\n\nfunction loadScript(src, attrs = {}) {\n  if (typeof document !== 'undefined') {\n    const script = document.createElement('script')\n    script.async = true\n    script.defer = true\n    Object.keys(attrs).forEach(attr => script.setAttribute(attr, attrs[attr]))\n    script.src = src\n    document.body.appendChild(script)\n  }\n}\n\nfunction MyApp({ Component, pageProps }) {\n  React.useEffect(() => {\n    loadScript('https://buttons.github.io/buttons.js')\n  }, [])\n\n  return (\n    <>\n      <Head>\n        <link\n          href=\"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap\"\n          rel=\"stylesheet\"\n        />\n        <style\n          dangerouslySetInnerHTML={{\n            __html: `\n        @media (max-width: 390px) {\n            .formkit-slide-in {\n              display: none;\n            }\n          }\n          @media (max-height: 740px) {\n            .formkit-slide-in {\n              display: none;\n            }\n          }\n          `,\n          }}\n        />\n      </Head>\n      <SearchProvider>\n        <Component {...pageProps} />\n      </SearchProvider>\n    </>\n  )\n}\n\nexport default MyApp\n"
  },
  {
    "path": "docs/src/pages/_document.js",
    "content": "import Document, { Html, Head, Main, NextScript } from 'next/document'\n\nclass MyDocument extends Document {\n  static async getInitialProps(ctx) {\n    const initialProps = await Document.getInitialProps(ctx)\n    return { ...initialProps }\n  }\n\n  render() {\n    return (\n      <Html>\n        <Head />\n        <body className=\"font-sans antialiased text-gray-900\">\n          <Main />\n          <NextScript />\n        </body>\n      </Html>\n    )\n  }\n}\n\nexport default MyDocument\n"
  },
  {
    "path": "docs/src/pages/docs/api.md",
    "content": "---\nid: api\ntitle: API\n---\n\n> 🚨 This documentation is for **Version 3.0.0, which is currently in beta and is a work-in-progress**. For now, please refer to the examples for any missing documentation.\n\n## Memoize your Props!\n\nThe React Charts `<Chart>` component has a few options that need to be **stable** or **memoized using either `React.useMemo` or `React.useCallback`**. Using an unstable option incorrectly shouldn't severly break any basic functionality, but could results in infinite change-detection loops in your app or at the very least, your charts will be severly non-performant. If an option says it needs to be stable, it's not kidding around!\n\n## Data Model\n\nReact Charts uses a data shape based on **arrays of series and nested arrays of datums in those series**.\n\n```js\nconst data = [\n  {\n    label: 'Purchases',\n    data: [\n      {\n        date: new Date(),\n        stars: 299320,\n      },\n      // ...etc\n    ],\n  },\n]\n```\n\nVisualization data can come in practically any shape and size, so **memoization of data into this shape is almost always necessary**.\n\n```tsx\nconst data = React.useMemo(\n  () => [\n    {\n      label: 'Series 1',\n      data: [\n        // ...\n      ],\n    },\n    {\n      label: 'Series 2',\n      data: [\n        // ...\n      ],\n    },\n    {\n      label: 'Series 3',\n      data: [\n        // ...\n      ],\n    },\n  ],\n  []\n)\n```\n\nThe individual datums in a series' `data` array can be anything you want! Just remember that most of the types for React Charts will require you to pass the type of your `Datum`s as the first generic type to work correctly.\n\n## Chart Component Props\n\nThe Chart component props can be passed in its `options` property object:\n\n```javascript\n<Chart\n  options={{\n    data,\n    primaryAxis,\n    secondaryAxes,\n  }}\n/>\n```\n\nThe data property should be an array of series, each series should be an array of objects.\nEach object should have two properties, by convention called primary and secondary, but it can be named as you want. One of these properties will be used as the primary axis and the other as the secondary axes.\n\n```javascript\nconst data = [\n  {\n    label: 'Series 1',\n    data: [\n      {\n        primary: '2022-02-03T00:00:00.000Z',\n        likes: 130,\n      },\n      {\n        primary: '2022-03-03T00:00:00.000Z',\n        likes: 150,\n      },\n    ],\n  },\n  {\n    label: 'Series 2',\n    data: [\n      {\n        primary: '2022-04-03T00:00:00.000Z',\n        likes: 200,\n      },\n      {\n        primary: '2022-05-03T00:00:00.000Z',\n        likes: 250,\n      },\n    ],\n  },\n]\n```\n\nThe `primaryAxis` and `secondaryAxes` options, should have a prop called getValue, which is a getter function that returns the axis value for the datum. Example:\n\n```javascript\nconst primaryAxis = React.useMemo(\n  () => ({\n    getValue: (datum: { primary: string }) => datum.primary,\n  }),\n  []\n)\nconst secondaryAxes = React.useMemo(\n  () => [\n    {\n      getValue: (datum: { likes: number }) => datum.likes,\n      elementType: 'area',\n    },\n  ],\n  []\n)\n```\n\nThe `initialHeight` and `initialWidth` expect a number, a default value is applied for each of those, 300 and 200 respectively. It's important to mention that these options are available SSR only.\nIf you'd like to have a custom height and width in the client side you may have a wrapper div that sets the width and height CSS attributes\n\n`interactionMode` expect an string wich can be \"primary\" or \"closest\". It's been using for the tooltip position. By default, primary is being set.\n\n`showVoronoi` expect a boolean, it's a debug option to visualize the interaction click-map that sits on top of the chart.\n\n`getSeriesOrder` expect a function, this option will allows you to reorder the series if you want.\n\n`primaryCursor` and `secondaryCursor` take the options that configure the line/rectangle that is drawn underneath your cursor when you hover over the chart. When both are used, it produces a kind of cross-hair. Both are set to true by default.\n\n## Axes\n\nReact Charts use axes to configure a fair amount of the charts. Axes handle many things like:\n\n- Accessing chart values from your series' `Datum`s\n- Optionally positioning your axis on the grid\n- Optionally configuring the scale type for your axis\n- Optionally configuring the element type for series that are tied to your axis\n\nTo date, we have the following scale types available:\n\n- `linear` - A continuous axis used for plotting numerical data on an evenly distributed scale. Works well both as a **primary and secondary** axis.\n- `band` - A banded axis commonly used to plot categories or ordinal information. Works well as the **primary** axis for bar charts with ordinal domains.\n- `time` - A continuous axis used for plotting UTC `Date`s on an evenly distributed scale. Works well as a **primary** axis.\n- `timeLocal` - Similar to the `time` scale, but uses localized `Date` objects instead of UTC. Works well as a **primary** axis.\n- `log` - A continuous axis used for plotting numerical data on a logarithmically distributed scale. Works well as a **secondary** axis\n\nAxes are a required component of a React Chart. Both a `primaryAxis` and at least one axis vis `secondaryAxes` must be configured.\n\n```javascript\nimport { Chart } from 'react-charts'\n\ntype MyDatum = { date: Date, stars: number }\n\nfunction MyChart() {\n  const data = [\n    {\n      label: 'React Charts',\n      data: [\n        {\n          date: new Date(),\n          stars: 23467238,\n        },\n      ],\n    },\n  ]\n\n  const primaryAxis = React.useMemo(\n    (): AxisOptions<MyDatum> => ({\n      getValue: datum => datum.date,\n    }),\n    []\n  )\n\n  const secondaryAxes = React.useMemo(\n    (): AxisOptions<MyDatum>[] => [\n      {\n        getValue: datum => datum.stars,\n      },\n    ],\n    []\n  )\n\n  return (\n    <Chart\n      options={{\n        data,\n        primaryAxis,\n        secondaryAxes,\n      }}\n    />\n  )\n}\n```\n\n## Secondary Axis Element Types\n\nSecondary axes for the most part are automatic, but can be optionally configured to render their respective series using 3 different element types using the `AxisOptions<TDatum>['scaleType']` property:\n\n- `line`\n  - 1 Line per series (optional, eg. for Bubble/Scatter charts)\n  - 1 Circle per datum (optional)\n- `area`\n  - 1 Enclosed area per series\n  - 1 Line per series (optional)\n  - 1 Circle per datum (optional)\n- `bar`\n  - 1 Rectangle per datum\n\nExample\n\n```javascript\nconst secondaryAxes = React.useMemo(\n  (): AxisOptions<MyDatum>[] => [\n    {\n      getValue: datum => datum.stars,\n      elementType: 'bar',\n    },\n  ],\n  []\n)\n```\n\n### Chart Component Props\n\nThe Chart component props can be passed in its **options** property object:\n\n```javascript\n<Chart\n  options={{\n    data,\n    primaryAxis,\n    secondaryAxes,\n  }}\n/>\n```\n\nThe data property should be an array of series, each series should be an array of objects.\nEach object should have two properties, by convention called primary and secondary, but it can be named as you want. One of these properties will be used as the primary axis and the other as the secondary axes.\n\n```javascript\nconst data = [\n  {\n    label: 'Series 1',\n    data: [\n      {\n        primary: '2022-02-03T00:00:00.000Z',\n        likes: 130,\n      },\n      {\n        primary: '2022-03-03T00:00:00.000Z',\n        likes: 150,\n      },\n    ],\n  },\n  {\n    label: 'Series 2',\n    data: [\n      {\n        primary: '2022-04-03T00:00:00.000Z',\n        likes: 200,\n      },\n      {\n        primary: '2022-05-03T00:00:00.000Z',\n        likes: 250,\n      },\n    ],\n  },\n]\n```\n\nThe **primaryAxis** and **secondaryAxes** options, should have a prop called getValue, which is a getter function that returns the axis value for the datum. Example:\n\n```javascript\nconst primaryAxis = React.useMemo(\n  () => ({\n    getValue: (datum: { primary: string }) => datum.primary,\n  }),\n  []\n)\nconst secondaryAxes = React.useMemo(\n  () => [\n    {\n      getValue: (datum: { likes: number }) => datum.likes,\n      elementType: 'area',\n    },\n  ],\n  []\n)\n```\n\n**initialHeight** and **initialWidth** expect a number, a default value is applied for each of those, 300 and 200 respectively. It's important to mention that these options are available SSR onoly. If you'd like to have a custom height and width in the client side you may have a wrapper div that sets the width and height CSS attributes\n\n**interactionMode** expect an string wich can be \"primary\" or \"closest\". It's been using for the tooltip position. By default, primary is being set.\n\n**showVoronoi** expect a boolean, it's a debug option to visualize the interaction click-map that sits on top of the chart.\n\n**getSeriesOrder** expect a function, this option will allows you to reorder the series if you want.\n\n**primaryCursor** and **secondaryCursor** take the options that configure the line/rectangle that is drawn underneath your cursor when you hover over the chart. When both are used, it produces a kind of cross-hair. Both are set to true by default.\n\n### Curve Types\n\nAll element types that support lines or curves can be configured by passing any `curve` generator function as the `AxisOptions<TDatum>['curve']` option. By default, horizontal and vertical series default to using `monotoneX` and `monotoneY` curves, respectively. More information can be found at [`d3-shape curves`](https://github.com/d3/d3-shape#curves)\n\n# API\n\n> Coming Soon! Feel free to consult the **[examples](/examples/simple)** or refer to the exported types in your favorite IDE for now.\n"
  },
  {
    "path": "docs/src/pages/docs/getting-started.md",
    "content": "---\nid: getting-started\ntitle: Getting Started\n---\n\nOut of the box, React Charts is very forgiving and requires very little to use. Let's get started by going over the bare minimum configuration required to render a chart!\n\n- An array of `Series` objects (more on this in a bit), each with a `data` property that is an array of `Datums` (be patient, we'll explain soon!)\n\n```ts\ntype DailyStars = {\n  date: Date,\n  stars: number,\n}\n\ntype Series = {\n  label: string,\n  data: DailyStars[]\n}\n\nconst data: Series[] = [\n  {\n    label: 'React Charts',\n    data: [\n      {\n        date: new Date(),\n        stars: 202123,\n      }\n      // ...\n    ]\n  },\n  {\n    label: 'React Query',\n    data: [\n      {\n        date: new Date(),\n        stars: 10234230,\n      }\n      // ...\n    ]\n  }\n]\n```\n\n- `primaryAxis: AxisOptions<TDatum>`\n  - Primary Value Accessor\n- `secondaryAxes: AxisOptions<TDatum>[]`\n  - Primary Value Accessor\n\n```tsx\nfunction App() {\n  const primaryAxis = React.useMemo(\n    (): AxisOptions<DailyStars> => ({\n      getValue: datum => datum.date,\n    }),\n    []\n  )\n\n  const secondaryAxes = React.useMemo(\n    (): AxisOptions<DailyStars>[] => [\n      {\n        getValue: datum => datum.stars,\n      },\n    ],\n    []\n  )\n\n  return (\n    <Chart\n      options={{\n        data,\n        primaryAxis,\n        secondaryAxes,\n      }}\n    />\n  )\n}\n```\n\nNow that you know how to build a simple chart, let's dive deeper!\n"
  },
  {
    "path": "docs/src/pages/docs/installation.md",
    "content": "---\nid: installation\ntitle: Installation\n---\n\nYou can install React Charts with [NPM](https://npmjs.com),\n[Yarn](https://yarnpkg.com), or a good ol' `<script>` via\n[unpkg.com](https://unpkg.com).\n\n### NPM\n\n```sh\nnpm install react-charts@beta --save\n```\n\nor\n\n```sh\nyarn add react-charts@beta\n```\n\nReact Charts is compatible with React v16.8+ and is compatible with ReactDOM only\n"
  },
  {
    "path": "docs/src/pages/docs/overview.md",
    "content": "---\nid: overview\ntitle: Overview\n---\n\nReact Charts is first and foremost a React component for rendering many many different variations of X/Y charts including, but not limited to, **line, area, bar, column and bubble charts**.\n\nOutside of providing custom styling and interfacing with some D3-supported options, you do not need any knowledge of SVG to use React Charts, nor should you, since you probably have better things to do than remember how to transpose the attributes of a `rect` from a vertical to horizontal orientation or heaven forbid, calculate an columnar-voronoi for faster closest-to-point tooltip performance.\n\nYou will, however, need general knowledge of:\n\n- Your data. If you don't know the data you want to visualize, you're not going to get far at all!\n\nIt's optional for basic charting, but if you really want to be productive, you'll want to understand:\n\n- High-level Scale Architypes, the differences in what they do, and why you would use one over the other. Again, you do not need to know how to build your own scales or use `d3-scale`, but knowing the concepts and ideas behind scale types like `time`, `linear/continuous`, and `ordinal/band` will go a long way. [Learn more at Observerble](https://observablehq.com/@d3/learn-d3-scales).\n\nI think that's it TBH! But this list might grow/shrink in the future. If you think something should be added to this list or changed in anyway, hit the **Edit this page on Github** link at the bottom!\n"
  },
  {
    "path": "docs/src/pages/docs/quick-start.md",
    "content": "---\nid: quick-start\ntitle: Quick Start\n---\n\n## Quick Start\n\nReact\n\nThis will render a very basic line chart:\n\n```javascript\nimport React from 'react'\nimport { Chart } from 'react-charts'\n\nfunction MyChart() {\n  const data = React.useMemo(\n    () => [\n      {\n        label: 'Series 1',\n        data: [\n          [0, 1],\n          [1, 2],\n          [2, 4],\n          [3, 2],\n          [4, 7],\n        ],\n      },\n      {\n        label: 'Series 2',\n        data: [\n          [0, 3],\n          [1, 1],\n          [2, 5],\n          [3, 6],\n          [4, 4],\n        ],\n      },\n    ],\n    []\n  )\n\n  const axes = React.useMemo(\n    () => [\n      { primary: true, type: 'linear', position: 'bottom' },\n      { type: 'linear', position: 'left' },\n    ],\n    []\n  )\n\n  const lineChart = (\n    // A react-chart hyper-responsively and continuously fills the available\n    // space of its parent element automatically\n    <div\n      style={{\n        width: '400px',\n        height: '300px',\n      }}\n    >\n      <Chart data={data} axes={axes} />\n    </div>\n  )\n}\n```\n"
  },
  {
    "path": "docs/src/pages/examples/simple.md",
    "content": "---\nid: simple\ntitle: Simple Examples\ntoc: false\n---\n\n- [Open in CodeSandbox](https://codesandbox.io/s/github/tannerlinsley/react-charts/tree/beta/examples/simple)\n- [View Source](https://github.com/tannerlinsley/react-charts/tree/beta/examples/simple)\n\n<iframe\n  src=\"https://codesandbox.io/embed/github/tannerlinsley/react-charts/tree/beta/examples/simple?autoresize=1&fontsize=14&theme=dark\"\n  title=\"tannerlinsley/react-charts: simple\"\n  sandbox=\"allow-forms allow-modals allow-popups allow-presentation allow-same-origin allow-scripts\"\n  style={{\n    width: '100%',\n    height: '80vh',\n    border: '0',\n    borderRadius: 8,\n    overflow: 'hidden',\n    position: 'static',\n    zIndex: 0,\n  }}\n></iframe>\n"
  },
  {
    "path": "docs/src/pages/examples/stress-test.md",
    "content": "---\nid: stress-test\ntitle: Stress Test\ntoc: false\n---\n\n- [Open in CodeSandbox](https://codesandbox.io/s/github/tannerlinsley/react-charts/tree/beta/examples/stress-test)\n- [View Source](https://github.com/tannerlinsley/react-charts/tree/beta/examples/stress-test)\n\n<iframe\n  src=\"https://codesandbox.io/embed/github/tannerlinsley/react-charts/tree/beta/examples/stress-test?autoresize=1&fontsize=14&theme=dark\"\n  title=\"tannerlinsley/react-charts: stress-test\"\n  sandbox=\"allow-forms allow-modals allow-popups allow-presentation allow-same-origin allow-scripts\"\n  style={{\n    width: '100%',\n    height: '80vh',\n    border: '0',\n    borderRadius: 8,\n    overflow: 'hidden',\n    position: 'static',\n    zIndex: 0,\n  }}\n></iframe>\n"
  },
  {
    "path": "docs/src/pages/index.js",
    "content": "import * as React from 'react'\nimport { Banner } from 'components/Banner'\nimport { Sticky } from 'components/Sticky'\nimport { Nav } from 'components/Nav'\nimport { siteConfig } from 'siteConfig'\nimport Link from 'next/link'\nimport { Footer } from 'components/Footer'\nimport { Seo } from 'components/Seo'\nimport Head from 'next/head'\nimport { ParentSize } from '@visx/responsive'\n\nconst Home = props => {\n  return (\n    <>\n      <Seo\n        title=\"React Charts\"\n        description=\"Hooks for building lightweight, fast and extendable datagrids for React\"\n      />\n      <Head>\n        <title>\n          React Charts - Simple, immersive & interactive charts for React\n        </title>\n      </Head>\n      <div className=\"bg-gray-50 h-full min-h-full\">\n        <Banner />\n        <Sticky>\n          <Nav />\n        </Sticky>\n        <div className=\"relative bg-white overflow-hidden\">\n          <div className=\"py-24 mx-auto container px-4 sm:mt-12  relative\">\n            <img\n              src={require('images/emblem-light.svg')}\n              className=\"absolute transform right-0 top-1/2 h-0 lg:h-full scale-150 translate-x-1/2 xl:translate-x-1/5 -translate-y-1/2\"\n              alt=\"React Charts Emblem\"\n            />\n            <div className=\"grid grid-cols-12 gap-8\">\n              <div className=\"col-span-12 lg:col-span-6 \">\n                <div className=\"text-center lg:text-left md:max-w-2xl md:mx-auto \">\n                  <h1 className=\"text-4xl tracking-tight leading-10 font-extrabold text-gray-900 sm:leading-none sm:text-6xl lg:text-5xl xl:text-6xl\">\n                    Beautiful, flexible, highly-performant\n                    <br className=\"hidden md:inline xl:hidden\" />{' '}\n                    <span>charts for React</span>\n                  </h1>\n                  <p className=\"mt-3 text-base text-gray-700 sm:mt-5 sm:text-xl lg:text-lg xl:text-xl\">\n                    So automagical and easy, you'll find any excuse to use it!\n                  </p>\n\n                  <div className=\"mt-5  mx-auto sm:flex sm:justify-center lg:justify-start lg:mx-0 md:mt-8\">\n                    <div className=\"rounded-md shadow\">\n                      <Link href=\"/docs/overview\">\n                        <a className=\"w-full flex items-center justify-center px-8 py-3 border border-transparent text-base leading-6 font-medium rounded-md text-white bg-coral hover:bg-coral-light focus:outline-none focus:border-coral focus:shadow-outline-coral transition duration-150 ease-in-out md:py-4 md:text-lg md:px-10\">\n                          Get Started\n                        </a>\n                      </Link>\n                    </div>\n                    <div className=\"mt-3 rounded-md shadow sm:mt-0 sm:ml-3\">\n                      <a\n                        href={siteConfig.repoUrl}\n                        target=\"_blank\"\n                        rel=\"noopener noreferrer\"\n                        className=\"w-full flex items-center justify-center px-8 py-3 border border-transparent text-base leading-6 font-medium rounded-md text-coral bg-white hover:text-coral-light focus:outline-none focus:border-coral-light focus:shadow-outline-coral transition duration-150 ease-in-out md:py-4 md:text-lg md:px-10\"\n                      >\n                        GitHub\n                      </a>\n                    </div>\n                  </div>\n                </div>\n              </div>\n            </div>\n          </div>\n        </div>\n        <div className=\"text-lg border-t border-gray-200 bg-gray-50 \">\n          <div className=\"py-24  \">\n            <div className=\"mx-auto container\">\n              <div className=\"lg:grid lg:grid-cols-3 lg:gap-8\">\n                <div>\n                  <div>\n                    <h3 className=\"text-xl leading-6 xl:text-2xl font-bold text-gray-900\">\n                      Succinct & Declarative\n                    </h3>\n                    <p className=\"mt-2 lg:mt-4 text-base xl:text-lg lg:leading-normal leading-6 text-gray-600\">\n                      Time is short for front-end developers as it is, so having\n                      a charting system that is great out of the box,\n                      declarative, succinct and requires as little imperative\n                      scripting as possible not only helps you keep moving\n                      forward but lets you express your data visualization needs\n                      at the speed of your creativity.\n                    </p>\n                  </div>\n                </div>\n                <div className=\"mt-10 lg:mt-0\">\n                  <div>\n                    <h3 className=\"text-xl leading-6 xl:text-2xl font-bold text-gray-900\">\n                      X/Y-Only Charts\n                    </h3>\n                    <div className=\"mt-2  lg:mt-4 text-base xl:text-lg lg:leading-normal leading-6 text-gray-600\">\n                      We believe data visualization is all about{' '}\n                      <strong>effectively conveying information</strong> to your\n                      users, and not about building <em>new</em> and\n                      <em>\"exciting\"</em> methods of indirection or{' '}\n                      <em>\"art\"</em> for them to ponder and decipher. To that\n                      end, React Charts only supports X/Y chart layouts and{' '}\n                      <a\n                        href=\"https://www.businessinsider.com/pie-charts-are-the-worst-2013-6\"\n                        target=\"_blank\"\n                        className=\"text-blue-800\"\n                      >\n                        purposefully does not have support for pie charts, radar\n                        charts, or other circular nonsense.\n                      </a>\n                      <br />\n                      <br />\n                      <div className=\"leading-none\">\n                        <sup>\n                          * Okay, there is a time and place for them, but not\n                          often and certainly not here 😜.\n                        </sup>\n                      </div>\n                    </div>\n                  </div>\n                </div>\n                <div className=\"mt-10 lg:mt-0\">\n                  <div>\n                    <h3 className=\"text-xl leading-6 xl:text-2xl font-bold text-gray-900\">\n                      SVG Knowledge Optional\n                    </h3>\n                    <p className=\"mt-2  lg:mt-4 text-base xl:text-lg lg:leading-normal leading-6 text-gray-600\">\n                      React Chart's API's goal is to remove the necessity of\n                      knowing how to write and manipulate SVG elements. While\n                      powerful, SVG elements can often create a new layer of\n                      indirection for accomplishing simple customization tasks\n                      like tooltips, labels, annotations, etc. React Charts make\n                      this a breeze!\n                    </p>\n                  </div>\n                </div>\n              </div>\n            </div>\n          </div>\n          {/* <div className=\"py-6\">\n            <div className=\"uppercase tracking-wider text-sm font-semibold text-center text-gray-400 mb-3\">\n              Trusted in Production by\n            </div>\n\n            <ClientsMarquee />\n          </div> */}\n        </div>\n        <div className=\"relative text-lg border-t border-gray-200 bg-gray-100 overflow-hidden\">\n          <div className=\"lg:block lg:absolute lg:inset-0\">\n            <svg\n              className=\"absolute top-1/2 left-1/2 transform -translate-y-1/2 -translate-x-1/2\"\n              width=\"2400\"\n              height=\"2400\"\n              fill=\"none\"\n              viewBox=\"0 0 2400 2400\"\n            >\n              <defs>\n                <pattern\n                  id=\"9ebea6f4-a1f5-4d96-8c4e-4c2abf658047\"\n                  x=\"0\"\n                  y=\"0\"\n                  width=\"20\"\n                  height=\"20\"\n                  patternUnits=\"userSpaceOnUse\"\n                >\n                  <rect\n                    x=\"0\"\n                    y=\"0\"\n                    width=\"4\"\n                    height=\"4\"\n                    className=\"text-gray-200\"\n                    fill=\"currentColor\"\n                  />\n                </pattern>\n              </defs>\n              <rect\n                x=\"0\"\n                width=\"2400\"\n                height=\"2400\"\n                fill=\"url(#9ebea6f4-a1f5-4d96-8c4e-4c2abf658047)\"\n              />\n            </svg>\n          </div>\n          <div className=\"relative\">\n            <h3 className=\"text-center text-3xl leading-8 font-extrabold tracking-tight text-gray-900 sm:text-4xl sm:leading-10 lg:leading-none mt-8\">\n              Sponsors\n            </h3>\n            <div className=\"py-4 flex flex-wrap mx-auto\" style={{ maxWidth: '95%' }}>\n              <ParentSize>\n                {({ width }) => {\n                  return (\n                    <iframe\n                      title=\"sponsors\"\n                      src=\"https://tanstack.com/sponsors-embed\"\n                      style={{\n                        width: width,\n                        height: width,\n                        overflow: 'hidden',\n                      }}\n                    />\n                  )\n                }}\n              </ParentSize>\n            </div>\n            <div className=\"text-center mb-8\">\n              <a\n                href=\"https://github.com/sponsors/tannerlinsley\"\n                className=\"inline-block bg-green-500 px-4 py-2 text-xl mx-auto leading-tight font-extrabold tracking-tight text-white rounded-full\"\n              >\n                Become a Sponsor!\n              </a>\n            </div>\n          </div>\n        </div>\n        <div className=\"bg-gray-100 relative py-24 border-t border-gray-200 \">\n          <div className=\"px-4 sm:px-6 lg:px-8  mx-auto container max-w-3xl sm:text-center\">\n            <h3 className=\"text-3xl leading-8 font-extrabold tracking-tight text-gray-900 sm:text-4xl sm:leading-10 lg:leading-none mt-2\">\n              Try it out! Right here. Right now!\n            </h3>\n            <p className=\"my-4 text-xl leading-7  text-gray-600\">\n              Get your data, pick your chart type and get your datavis on.\n            </p>\n          </div>\n          <div\n            style={{\n              height: 224,\n            }}\n          />\n        </div>\n\n        <section className=\"bg-gray-900 body-font\">\n          <div className=\"container max-w-7xl px-4  mx-auto -mt-72 relative\">\n            <iframe\n              src=\"https://codesandbox.io/embed/github/tannerlinsley/react-charts/tree/beta/examples/simple?autoresize=1&fontsize=16&theme=dark\"\n              title=\"tannerlinsley/react-charts: simple\"\n              sandbox=\"allow-forms allow-modals allow-popups allow-presentation allow-same-origin allow-scripts\"\n              className=\"shadow-2xl\"\n              style={{\n                width: '100%',\n                height: '80vh',\n                border: '0',\n                borderRadius: 8,\n                overflow: 'hidden',\n                position: 'static',\n                zIndex: 0,\n              }}\n            ></iframe>\n          </div>\n          <div className=\"py-24 px-4 sm:px-6 lg:px-8  mx-auto container\">\n            <div className=\" sm:text-center pb-16\">\n              <h3 className=\"text-3xl mx-auto leading-tight font-extrabold tracking-tight text-white sm:text-4xl  lg:leading-none mt-2\">\n                A knob, toggle and function for everything!\n              </h3>\n              <p className=\"mt-4 text-xl max-w-3xl mx-auto leading-7 text-gray-300\">\n                React Charts is designed to get out of your way. Inversion of\n                control is our name, and control is your game. If you want to\n                customize something, we'll give you a way to do it. Just be\n                careful what you wish for!\n              </p>\n            </div>\n            <div>\n              <div className=\"grid grid-flow-row grid-cols-1 sm:grid-cols-2 md:grid-cols-3  gap-4 text-white max-w-screen-lg mx-auto text-lg\">\n                {[\n                  'Hyper Responsive',\n                  'Line Charts',\n                  'Bar/Column Charts',\n                  'Bubble/Scatter Charts',\n                  'Area/Steam Charts',\n                  'Axis Stacking',\n                  'Inverted Axes',\n                  'Invisibly Powered by D3',\n                  'Declarative',\n                  'Mutliple Axes',\n                ].map(d => {\n                  return (\n                    <a className=\"mb-2\" key={d}>\n                      <span className=\"bg-coral text-gray-800 w-4 h-4 mr-2 rounded-full inline-flex items-center justify-center\">\n                        <Check />\n                      </span>\n                      {d}\n                    </a>\n                  )\n                })}\n              </div>\n            </div>\n          </div>\n        </section>\n        <div className=\"bg-gray-200 border-b border-gray-300\">\n          <div className=\"container mx-auto py-12 text-center\">\n            <h3 className=\"text-2xl md:text-5xl mx-auto leading-tight font-extrabold tracking-tight text-gray-800  lg:leading-none mt-2\">\n              Feeling Chatty?\n            </h3>\n            <a\n              href=\"https://discord.gg/WrRKjPJ\"\n              target=\"_blank\"\n              className=\"inline-block bg-gray-800 p-5 text-2xl mx-auto leading-tight font-extrabold tracking-tight text-white mt-12 rounded-full\"\n            >\n              Join the #TanStack Discord!\n            </a>\n          </div>\n        </div>\n        <div className=\"bg-gray-50 border-b border-gray-100\">\n          <div className=\"container mx-auto py-24 px-4 flex flex-wrap md:flex-no-wrap items-center justify-between md:space-x-8\">\n            <h2 className=\"text-3xl leading-9 font-extrabold tracking-tight text-gray-900 sm:text-4xl sm:leading-10\">\n              Wow, you've come a long way!\n            </h2>\n            <div className=\"mt-8 flex lg:flex-shrink-0 md:mt-0\">\n              <div className=\"inline-flex rounded-md shadow\">\n                <Link href=\"/docs/overview\">\n                  <a className=\"inline-flex items-center justify-center text-center px-5 py-3 border border-transparent text-base leading-6 font-medium rounded-md text-white bg-coral hover:bg-coral-light focus:outline-none focus:shadow-outline transition duration-150 ease-in-out\">\n                    Okay, let's get started!\n                  </a>\n                </Link>\n              </div>\n              <div className=\"ml-3 inline-flex rounded-md shadow\">\n                <a\n                  href={siteConfig.repoUrl}\n                  className=\"inline-flex items-center justify-center text-center px-5 py-3 border border-transparent text-base leading-6 font-medium rounded-md text-coral bg-white hover:text-coral-light focus:outline-none focus:shadow-outline transition duration-150 ease-in-out\"\n                >\n                  Take me to the GitHub repo.\n                </a>\n              </div>\n            </div>\n          </div>\n        </div>\n        <Footer />\n        <style jsx global>{`\n          .gradient {\n            -webkit-mask-image: linear-gradient(\n              180deg,\n              transparent 0,\n              #000 30px,\n              #000 calc(100% - 200px),\n              transparent calc(100% - 100px)\n            );\n          }\n        `}</style>\n      </div>\n    </>\n  )\n}\n\nexport default Home\nHome.displayName = 'Home'\nconst Check = React.memo(() => (\n  <svg\n    fill=\"none\"\n    stroke=\"currentColor\"\n    strokeLinecap=\"round\"\n    strokeLinejoin=\"round\"\n    strokeWidth=\"3\"\n    className=\"w-3 h-3\"\n    viewBox=\"0 0 24 24\"\n    aria-hidden=\"true\"\n  >\n    <path d=\"M20 6L9 17l-5-5\"></path>\n  </svg>\n))\n"
  },
  {
    "path": "docs/src/siteConfig.js",
    "content": "// List of projects/orgs using your project for the users page.\nexport const siteConfig = {\n  editUrl:\n    'https://github.com/tannerlinsley/react-charts/edit/master/docs/src/pages',\n  copyright: `Copyright © ${new Date().getFullYear()} Tanner Linsley. All Rights Reserved.`,\n  repoUrl: 'https://github.com/tannerlinsley/react-charts',\n  algolia: {\n    appId: 'BH4D9OD16A',\n    apiKey: 'f501b7d59335fb8731d2c76764c3fc86',\n    indexName: 'tanstack_react-charts', // algoliaOptions: {\n    //   facetFilters: ['version:VERSION'],\n    // },\n  },\n}\n"
  },
  {
    "path": "docs/src/styles/blog.module.css",
    "content": ".previewAlertContainer {\n  display: flex;\n  justify-content: center;\n}\n\n.previewAlert {\n  display: inline-flex;\n  align-items: center;\n  justify-content: space-between;\n  text-align: center;\n  border: 1px solid #eaeaea;\n  width: 400px;\n  padding: 16px;\n  border-radius: 5px;\n}\n\n.escapePreview {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  border: none;\n  background-color: black;\n  border: 1px solid black;\n  color: white;\n  padding: 10px;\n  height: 24px;\n  border-radius: 5px;\n  transition: all 0.2s ease 0s;\n}\n.escapePreview:hover {\n  background-color: white;\n  color: black;\n  border: 1px solid black;\n  cursor: pointer;\n}\n\n.titleContainer {\n  display: inline-flex;\n  align-items: center;\n  justify-content: flex-start;\n}\n.draftBadge {\n  border-radius: 16px;\n  background-color: black;\n  color: white;\n  font-size: 14px;\n  font-weight: 200;\n  padding: 2px 7px;\n  margin-right: 6px;\n}\n\n.noPosts {\n  text-align: center;\n}\n"
  },
  {
    "path": "docs/src/styles/index.css",
    "content": "/* purgecss start ignore */\n@tailwind base;\n@tailwind components;\n/* purgecss end ignore */\n\nbody,\nhtml {\n  text-rendering: optimizeLegibility;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale;\n}\n\n.top-24 {\n  top: 6rem;\n}\n\n.focus-ring {\n  outline: none;\n  @apply shadow-outline border-blue-400;\n}\n\n/* purgecss start ignore */\n\n.embed-responsive {\n  position: relative;\n  display: block;\n  height: 0;\n  padding: 0;\n  overflow: hidden;\n}\n\n.embed-responsive .embed-responsive-item,\n.embed-responsive iframe,\n.embed-responsive embed,\n.embed-responsive object,\n.embed-responsive video {\n  position: absolute;\n  top: 0;\n  left: 0;\n  bottom: 0;\n  height: 100%;\n  width: 100%;\n  border: 0;\n}\n\n.aspect-ratio-square {\n  padding-top: 100%;\n}\n\n.aspect-ratio-16-9 {\n  padding-top: 56.25%;\n}\n\n.aspect-ratio-4-3 {\n  padding-top: 75%;\n}\n\n.aspect-ratio-21-9 {\n  padding-top: 42.86%;\n}\n\n.anchor {\n  @apply text-gray-500 absolute ml-2 pr-1 underline;\n}\n\n.anchor::after {\n  content: '#';\n  visibility: hidden;\n}\n\nh1:hover .anchor::after,\nh2:hover .anchor::after,\nh3:hover .anchor::after,\nh4:hover .anchor::after,\nh5:hover .anchor::after,\nh6:hover .anchor::after {\n  visibility: visible;\n}\n\n/* Algolia v3 overrides */\n:root {\n  --docsearch-modal-background: #fff;\n  --docsearch-highlight-color: #1965e0;\n  --docsearch-primary-color: #0052cc;\n  --docsearch-searchbox-shadow: 0 0 0 3px rgba(66, 153, 225, 0.5);\n  --ifm-z-index-fixed: 1000;\n  --docsearch-searchbox-height: 48px;\n  --docsearch-icon-stroke-width: 1.4;\n  --hover-overlay: rgba(0, 0, 0, 0.05);\n  --fds-animation-fade-in: cubic-bezier(0, 0, 1, 1);\n  --fds-animation-fade-out: cubic-bezier(0, 0, 1, 1);\n}\n\n.DocSearch--active #__next {\n  -webkit-filter: blur(2px);\n  filter: blur(2px);\n}\n.DocSearch-SearchBar {\n  @apply mb-2;\n}\n\n.DocSearch-Form {\n  @apply rounded-md;\n}\n\n.DocSearch-Search-Icon {\n  height: 20px;\n  width: 20px;\n  stroke-width: 1.6;\n  @apply text-gray-600;\n}\n\n/* Custom Remark alerts */\n.alert {\n  @apply p-4 border-l-4  mb-4;\n}\n\n.alert.alert-danger {\n  @apply bg-red-50 text-red-800 border-red-500;\n}\n\n.alert.alert-success {\n  @apply bg-green-50 text-green-700 border-green-500;\n}\n\n.alert.alert-warning {\n  @apply bg-yellow-50 text-yellow-800 border-yellow-500;\n}\n\n.alert.alert-info {\n  @apply bg-blue-50 text-blue-800 border-blue-500;\n}\n\n.font-mono {\n  font-family: monospace;\n}\n\ndetails > p > a,\ndetails > ul > li > a,\ndetails > ol > li > a,\ndetails > ul > li a,\ndetails > ol > li a,\ndetails > table > tbody > tr > td > a {\n  @apply text-blue-600 font-semibold transition-colors duration-150 ease-out;\n}\n\ndetails > p > a:hover,\ndetails > ul > li > a:hover,\ndetails > ol > li > a:hover,\ndetails > table > tbody > tr > td > a:hover {\n  @apply text-blue-800 transition-colors duration-150 ease-out;\n}\n\ndetails strong {\n  @apply font-bold;\n}\n\ndetails > p,\ndetails > ul,\ndetails > ol,\ndetails > blockquote,\ndetails > pre,\ndetails > div > .code-block {\n  @apply mb-4;\n}\ndetails > ul,\ndetails > ul > li > ul {\n  @apply ml-8 list-disc;\n}\n\ndetails > ol {\n  @apply ml-8 list-decimal;\n}\ndetails {\n  @apply p-3 bg-gray-50 rounded-md border mb-3  text-sm leading-5 shadow-sm;\n}\ndetails > p {\n  @apply mt-2;\n}\ndetails > summary {\n  @apply font-bold text-base;\n}\n\n@tailwind utilities;\n/* purgecss end ignore */\n\n#carbonads * {\n  margin: initial;\n  padding: initial;\n}\n#carbonads {\n  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto,\n    Oxygen-Sans, Ubuntu, Cantarell, 'Helvetica Neue', Helvetica, Arial,\n    sans-serif;\n}\n#carbonads {\n  display: flex;\n  max-width: 330px;\n  background-color: hsl(0, 0%, 98%);\n  box-shadow: 0 1px 4px 1px hsla(0, 0%, 0%, 0.1);\n  z-index: 100;\n}\n#carbonads a {\n  color: inherit;\n  text-decoration: none;\n}\n#carbonads a:hover {\n  color: inherit;\n}\n#carbonads span {\n  position: relative;\n  display: block;\n  overflow: hidden;\n}\n#carbonads .carbon-wrap {\n  display: flex;\n}\n#carbonads .carbon-img {\n  display: block;\n  margin: 0;\n  line-height: 1;\n}\n#carbonads .carbon-img img {\n  display: block;\n}\n#carbonads .carbon-text {\n  font-size: 13px;\n  padding: 10px;\n  margin-bottom: 16px;\n  line-height: 1.5;\n  text-align: left;\n}\n#carbonads .carbon-poweredby {\n  display: block;\n  padding: 6px 8px;\n  background: #f1f1f2;\n  text-align: center;\n  text-transform: uppercase;\n  letter-spacing: 0.5px;\n  font-weight: 600;\n  font-size: 8px;\n  line-height: 1;\n  border-top-left-radius: 3px;\n  position: absolute;\n  bottom: 0;\n  right: 0;\n}\n"
  },
  {
    "path": "docs/src/styles/post.module.css",
    "content": "/* .post :global(video),\n.post :global(img), */\n.post :global(.asset-wrapper) {\n  margin: 2rem auto;\n  /* box-shadow: 0 8px 8px rgba(0, 0, 0, 0.3); */\n  max-width: 100%;\n  display: block;\n}\n\n.post :global(.twitter-tweet) {\n  margin: 2rem auto !important;\n  text-align: center;\n}\n\n.post :global(.callout) {\n  padding: 16px 16px 16px 12px;\n  display: flex;\n  width: 100%;\n  border-radius: 3px;\n  border-width: 1px;\n  border-style: solid;\n  border-color: transparent;\n  background: rgba(235, 236, 237, 0.6);\n  margin-top: 1rem;\n}\n\n.post :global(.callout .text) {\n  margin-left: 8px;\n}\n\n.postPreview :global(.posted) {\n  margin-bottom: 0.5em;\n}\n\n.post :global(hr) {\n  margin-bottom: 2em;\n}\n\n/* .post :global(a + p) {\n  margin-top: 0;\n} */\n/* purgecss end ignore */\n"
  },
  {
    "path": "docs/src/styles/shared.module.css",
    "content": ".layout img {\n  margin: auto;\n  max-width: 98%;\n  display: block;\n  height: auto;\n}\n"
  },
  {
    "path": "docs/src/users.js",
    "content": "export const users = [\n  'Intuit',\n  'Google',\n  'Amazon',\n  'Apple',\n  'AutoZone',\n  'Microsoft',\n  'Cisco',\n  'Uber',\n  'Salesforce',\n  'Walmart',\n  'Wix',\n  'HP',\n  'Docusign',\n  'Tripwire',\n  'Yahoo!',\n  'Ocado',\n  'Nordstrom',\n  'TicketMaster',\n  'Comcast Business',\n  'Nozzle.io',\n  // {\n  //   caption: 'Walmart',\n  //   image: require('images/logos/walmart.svg'),\n  //   infoLink: 'https://walmart.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'Lyft',\n  //   image: require('images/logos/lyft.svg'),\n  //   infoLink: 'https://lyft.com',\n  //   pinned: true,\n  //   style: {\n  //     maxWidth: 75,\n  //   },\n  // },\n  // {\n  //   caption: 'Nasa',\n  //   image: require('images/logos/nasa.svg'),\n  //   infoLink: 'https://www.nasa.gov',\n  //   pinned: true,\n  //   style: {\n  //     maxWidth: 80,\n  //   },\n  // },\n  // {\n  //   caption: 'Stripe',\n  //   image: require('images/logos/stripe.svg'),\n  //   infoLink: 'https://stripe.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'US Army',\n  //   image: require('images/logos/army.svg'),\n  //   infoLink: 'https://www.army.mil',\n  //   pinned: true,\n  //   style: {\n  //     maxWidth: 80,\n  //   },\n  // },\n  // {\n  //   caption: 'OpenTable',\n  //   image: require('images/logos/opentable.svg'),\n  //   infoLink: 'https://opentable.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'Priceline.com',\n  //   image: require('images/logos/priceline.png'),\n  //   infoLink: 'https://priceline.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'Booking.com',\n  //   image: require('images/logos/booking.svg'),\n  //   infoLink: 'https://booking.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'NASDAQ',\n  //   image: require('images/logos/nasdaq.svg'),\n  //   infoLink: 'https://www.nasdaq.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'PWC',\n  //   image: require('images/logos/pwc.svg'),\n  //   infoLink: 'https://www.pwc.com',\n  //   pinned: true,\n  //   style: {\n  //     maxWidth: 80,\n  //   },\n  // },\n  // {\n  //   caption: 'NOAA',\n  //   image: require('images/logos/noaa.svg'),\n  //   infoLink: 'https://www.noaa.gov',\n  //   pinned: true,\n  //   style: {\n  //     maxWidth: 80,\n  //   },\n  // },\n  // {\n  //   caption: 'Docker',\n  //   image: require('images/logos/docker.svg'),\n  //   infoLink: 'https://docker.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'Viacom',\n  //   image: require('images/logos/viacom.svg'),\n  //   infoLink: 'https://viacom.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'Nokia',\n  //   image: require('images/logos/nokia.svg'),\n  //   infoLink: 'https://nokia.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'Sony',\n  //   image: require('images/logos/sony.svg'),\n  //   infoLink: 'https://sony.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'State Street',\n  //   image: require('images/logos/state-street.png'),\n  //   infoLink: 'https://statestreet.com',\n  // },\n  // {\n  //   caption: 'Wayfair',\n  //   image: require('images/logos/wayfair.svg'),\n  //   infoLink: 'https://wayfair.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'Artsy',\n  //   image: require('images/logos/artsy.png'),\n  //   infoLink: 'https://artsy.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'Postmates',\n  //   image: require('images/logos/postmates.svg'),\n  //   infoLink: 'https://postmates.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'Capsule Health',\n  //   image: require('images/logos/capsule.svg'),\n  //   infoLink: 'https://capsulecares.com',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'Egghead',\n  //   image: require('images/logos/egghead.svg'),\n  //   infoLink: 'https://egghead.io',\n  //   pinned: true,\n  // },\n  // {\n  //   caption: 'Frame.io',\n  //   image: require('images/logos/frameio.png'),\n  //   infoLink: 'https://frame.io',\n  // },\n  // {\n  //   caption: 'RVshare',\n  //   image: require('images/logos/rvshare.svg'),\n  //   infoLink: 'https://rvshare.com',\n  // },\n  // {\n  //   caption: 'Extendi',\n  //   image: require('images/logos/extendi.svg'),\n  //   infoLink: 'https://www.extendi.it',\n  // },\n  // {\n  //   caption: 'Gusto',\n  //   image: require('images/logos/gusto.svg'),\n  //   infoLink: 'https://gusto.com',\n  // },\n  // {\n  //   caption: 'Campusjäger',\n  //   image: require('images/logos/campusjaeger.png'),\n  //   infoLink: 'https://www.campusjaeger.de/',\n  // },\n  // {\n  //   caption: 'Letgo',\n  //   image: require('images/logos/letgo-logo.png'),\n  //   infoLink: 'https://we.letgo.com/',\n  //   style: {\n  //     maxWidth: 100,\n  //   },\n  // },\n  // {\n  //   caption: 'gitconnected',\n  //   image: require('images/logos/gitconnected-logo.png'),\n  //   infoLink: 'https://gitconnected.com',\n  // },\n  // {\n  //   caption: 'zauberware',\n  //   image: require('images/logos/zauberware-logo.svg'),\n  //   infoLink: 'https://www.zauberware.com',\n  // },\n  // {\n  //   caption: 'brightwheel',\n  //   image: require('images/logos/brightwheel.svg'),\n  //   infoLink: 'https://mybrightwheel.com',\n  // },\n  // {\n  //   caption: 'restaurant365',\n  //   image: require('images/logos/restaurant365.svg'),\n  //   infoLink: 'https://restaurant365.com',\n  // },\n  // {\n  //   caption: 'CarGurus',\n  //   image: require('images/logos/cargurus.svg'),\n  //   infoLink: 'https://www.cargurus.com',\n  // },\n  // {\n  //   caption: 'Gremlin',\n  //   image: require('images/logos/gremlin.svg'),\n  //   infoLink: 'https://www.gremlin.com',\n  // },\n  // {\n  //   caption: 'Ubidots',\n  //   image: require('images/logos/ubidots.svg'),\n  //   infoLink: 'https://www.ubidots.com',\n  // },\n  // {\n  //   caption: 'SwissDev DevOps Jobs',\n  //   image: require('images/logos/swissdev-devops-jobs.svg'),\n  //   infoLink: 'https://swissdevjobs.ch/jobs/Dev-Ops/All',\n  //   style: {\n  //     maxWidth: 100,\n  //   },\n  // },\n]\n"
  },
  {
    "path": "docs/tailwind.config.js",
    "content": "// tailwind.config.js\n\nconst defaultTheme = require('tailwindcss/defaultTheme')\n\nmodule.exports = {\n  corePlugins: {\n    preflight: true,\n    float: false,\n  },\n  purge: {\n    enabled: process.env.NODE_ENV !== 'development',\n    content: ['./src/**/*.js'],\n    options: {\n      defaultExtractor: content => content.match(/[\\w-/.:]+(?<!:)/g) || [],\n    },\n  },\n  theme: {\n    extend: {\n      colors: {\n        coral: {\n          light: '#FF6070',\n          default: '#FF4154',\n          dark: '#EB2135',\n        },\n      },\n    },\n    fontFamily: {\n      sans: ['Inter', ...defaultTheme.fontFamily.sans],\n      serif: ['Inter', ...defaultTheme.fontFamily.serif],\n    },\n    screens: {\n      sm: '640px',\n      md: '768px',\n      lg: '1024px',\n      xl: '1400px',\n    },\n    rotate: {\n      ...defaultTheme.rotate,\n      '-30': '-30deg',\n    },\n    container: {\n      padding: '1rem',\n    },\n    customForms: theme => ({\n      sm: {\n        'input, textarea, multiselect, select': {\n          fontSize: theme('fontSize.sm'),\n          padding: `${theme('spacing.1')} ${theme('spacing.2')}`,\n        },\n        select: {\n          paddingRight: `${theme('spacing.4')}`,\n        },\n        'checkbox, radio': {\n          width: theme('spacing.3'),\n          height: theme('spacing.3'),\n        },\n      },\n    }),\n  },\n  variants: {},\n  plugins: [require('@tailwindcss/ui')],\n}\n"
  },
  {
    "path": "examples/simple/.babelrc",
    "content": "{\n  \"presets\": [\"react-app\"],\n  \"plugins\": [\"styled-components\"]\n}\n"
  },
  {
    "path": "examples/simple/.eslintrc",
    "content": "{\n  \"extends\": [\"react-app\", \"prettier\"],\n  \"rules\": {\n    // \"eqeqeq\": 0,\n    // \"jsx-a11y/anchor-is-valid\": 0\n  }\n}\n"
  },
  {
    "path": "examples/simple/.gitignore",
    "content": "# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.\n\n# dependencies\n/node_modules\n/.pnp\n.pnp.js\n\n# testing\n/coverage\n\n# production\n/build\n\n# misc\n.DS_Store\n.env.local\n.env.development.local\n.env.test.local\n.env.production.local\n\nnpm-debug.log*\nyarn-debug.log*\nyarn-error.log*\n"
  },
  {
    "path": "examples/simple/.prettierrc",
    "content": "{}\n"
  },
  {
    "path": "examples/simple/.rescriptsrc.js",
    "content": "const path = require(\"path\");\nconst resolveFrom = require(\"resolve-from\");\n\nconst fixLinkedDependencies = (config) => {\n  config.resolve = {\n    ...config.resolve,\n    alias: {\n      ...config.resolve.alias,\n      react$: resolveFrom(path.resolve(\"node_modules\"), \"react\"),\n      \"react-dom$\": resolveFrom(path.resolve(\"node_modules\"), \"react-dom\"),\n    },\n  };\n  return config;\n};\n\nconst includeSrcDirectory = (config) => {\n  config.resolve = {\n    ...config.resolve,\n    modules: [path.resolve(\"src\"), ...config.resolve.modules],\n  };\n  return config;\n};\n\nmodule.exports = [\n  [\"use-babel-config\", \".babelrc\"],\n  [\"use-eslint-config\", \".eslintrc\"],\n  fixLinkedDependencies,\n  // includeSrcDirectory,\n];\n"
  },
  {
    "path": "examples/simple/README.md",
    "content": "# Example\n\nTo run this example:\n\n- `npm install` or `yarn`\n- `npm run start` or `yarn start`\n"
  },
  {
    "path": "examples/simple/package.json",
    "content": "{\n  \"private\": true,\n  \"scripts\": {\n    \"start\": \"SKIP_PREFLIGHT_CHECK=true rescripts start\",\n    \"build\": \"SKIP_PREFLIGHT_CHECK=true rescripts build\",\n    \"test\": \"rescripts test\",\n    \"eject\": \"rescripts eject\",\n    \"serve\": \"serve build -s -p 3001\"\n  },\n  \"dependencies\": {\n    \"@react-hook/window-size\": \"3.0.7\",\n    \"d3\": \"^5.16.0\",\n    \"react\": \"^17.0.2\",\n    \"react-charts\": \"^3.0.0-beta.30\",\n    \"react-dom\": \"^17.0.2\",\n    \"react-json-tree\": \"^0.15.0\",\n    \"react-resizable\": \"^1.10.1\",\n    \"react-scripts\": \"3.4.3\",\n    \"styled-components\": \"^5.1.1\"\n  },\n  \"devDependencies\": {\n    \"@rescripts/cli\": \"^0.0.14\",\n    \"@rescripts/rescript-use-babel-config\": \"^0.0.10\",\n    \"@rescripts/rescript-use-eslint-config\": \"^0.0.11\",\n    \"babel-eslint\": \"10.1.0\",\n    \"serve\": \"^12.0.0\"\n  },\n  \"resolutions\": {\n    \"typescript\": \"^4.3.2\"\n  },\n  \"browserslist\": {\n    \"production\": [\n      \">0.2%\",\n      \"not dead\",\n      \"not op_mini all\"\n    ],\n    \"development\": [\n      \"last 1 chrome version\",\n      \"last 1 firefox version\",\n      \"last 1 safari version\"\n    ]\n  }\n}\n"
  },
  {
    "path": "examples/simple/public/index.html",
    "content": "<!DOCTYPE html>\n<html lang=\"en\">\n  <head>\n    <meta charset=\"utf-8\" />\n    <link rel=\"shortcut icon\" href=\"%PUBLIC_URL%/favicon.ico\" />\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\" />\n    <meta name=\"theme-color\" content=\"#000000\" />\n    <!--\n      manifest.json provides metadata used when your web app is installed on a\n      user's mobile device or desktop. See https://developers.google.com/web/fundamentals/web-app-manifest/\n    -->\n    <link rel=\"manifest\" href=\"%PUBLIC_URL%/manifest.json\" />\n    <!--\n      Notice the use of %PUBLIC_URL% in the tags above.\n      It will be replaced with the URL of the `public` folder during the build.\n      Only files inside the `public` folder can be referenced from the HTML.\n\n      Unlike \"/favicon.ico\" or \"favicon.ico\", \"%PUBLIC_URL%/favicon.ico\" will\n      work correctly both with client-side routing and a non-root public URL.\n      Learn how to configure a non-root public URL by running `npm run build`.\n    -->\n    <title>React App</title>\n  </head>\n  <body>\n    <noscript>You need to enable JavaScript to run this app.</noscript>\n    <div id=\"root\"></div>\n    <!--\n      This HTML file is a template.\n      If you open it directly in the browser, you will see an empty page.\n\n      You can add webfonts, meta tags, or analytics to this file.\n      The build step will place the bundled scripts into the <body> tag.\n\n      To begin the development, run `npm start` or `yarn start`.\n      To create a production bundle, use `npm run build` or `yarn build`.\n    -->\n  </body>\n</html>\n"
  },
  {
    "path": "examples/simple/public/manifest.json",
    "content": "{\n  \"short_name\": \"React App\",\n  \"name\": \"Create React App Sample\",\n  \"icons\": [\n    {\n      \"src\": \"favicon.ico\",\n      \"sizes\": \"64x64 32x32 24x24 16x16\",\n      \"type\": \"image/x-icon\"\n    }\n  ],\n  \"start_url\": \".\",\n  \"display\": \"standalone\",\n  \"theme_color\": \"#000000\",\n  \"background_color\": \"#ffffff\"\n}\n"
  },
  {
    "path": "examples/simple/report.20200723.110041.33247.0.001.json",
    "content": "\n{\n  \"header\": {\n    \"reportVersion\": 2,\n    \"event\": \"Allocation failed - JavaScript heap out of memory\",\n    \"trigger\": \"FatalError\",\n    \"filename\": \"report.20200723.110041.33247.0.001.json\",\n    \"dumpEventTime\": \"2020-07-23T11:00:41Z\",\n    \"dumpEventTimeStamp\": \"1595523641766\",\n    \"processId\": 33247,\n    \"threadId\": null,\n    \"cwd\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line-chart\",\n    \"commandLine\": [\n      \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n      \"/Users/tannerlinsley/GitHub/react-charts/examples/line-chart/node_modules/@rescripts/cli/scripts/start.js\"\n    ],\n    \"nodejsVersion\": \"v12.16.3\",\n    \"wordSize\": 64,\n    \"arch\": \"x64\",\n    \"platform\": \"darwin\",\n    \"componentVersions\": {\n      \"node\": \"12.16.3\",\n      \"v8\": \"7.8.279.23-node.35\",\n      \"uv\": \"1.34.2\",\n      \"zlib\": \"1.2.11\",\n      \"brotli\": \"1.0.7\",\n      \"ares\": \"1.16.0\",\n      \"modules\": \"72\",\n      \"nghttp2\": \"1.40.0\",\n      \"napi\": \"5\",\n      \"llhttp\": \"2.0.4\",\n      \"http_parser\": \"2.9.3\",\n      \"openssl\": \"1.1.1g\",\n      \"cldr\": \"36.0\",\n      \"icu\": \"65.1\",\n      \"tz\": \"2019c\",\n      \"unicode\": \"12.1\"\n    },\n    \"release\": {\n      \"name\": \"node\",\n      \"lts\": \"Erbium\",\n      \"headersUrl\": \"https://nodejs.org/download/release/v12.16.3/node-v12.16.3-headers.tar.gz\",\n      \"sourceUrl\": \"https://nodejs.org/download/release/v12.16.3/node-v12.16.3.tar.gz\"\n    },\n    \"osName\": \"Darwin\",\n    \"osRelease\": \"19.3.0\",\n    \"osVersion\": \"Darwin Kernel Version 19.3.0: Thu Jan  9 20:58:23 PST 2020; root:xnu-6153.81.5~1/RELEASE_X86_64\",\n    \"osMachine\": \"x86_64\",\n    \"cpus\": [\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 241595570,\n        \"nice\": 0,\n        \"sys\": 123482110,\n        \"idle\": 1100271500,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 8093830,\n        \"nice\": 0,\n        \"sys\": 6772640,\n        \"idle\": 1449279340,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 207372690,\n        \"nice\": 0,\n        \"sys\": 85894480,\n        \"idle\": 1170885840,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 7622170,\n        \"nice\": 0,\n        \"sys\": 5469170,\n        \"idle\": 1451054130,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 173097980,\n        \"nice\": 0,\n        \"sys\": 68941440,\n        \"idle\": 1222113280,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 7864830,\n        \"nice\": 0,\n        \"sys\": 4912180,\n        \"idle\": 1451368090,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 136232820,\n        \"nice\": 0,\n        \"sys\": 51614520,\n        \"idle\": 1276305030,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 8146130,\n        \"nice\": 0,\n        \"sys\": 4410640,\n        \"idle\": 1451587970,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 118000110,\n        \"nice\": 0,\n        \"sys\": 41710950,\n        \"idle\": 1304440990,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 8269890,\n        \"nice\": 0,\n        \"sys\": 3924550,\n        \"idle\": 1451949920,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 88590360,\n        \"nice\": 0,\n        \"sys\": 27513370,\n        \"idle\": 1348047980,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 8415110,\n        \"nice\": 0,\n        \"sys\": 3506460,\n        \"idle\": 1452222430,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 71700770,\n        \"nice\": 0,\n        \"sys\": 20526120,\n        \"idle\": 1371924440,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 8494980,\n        \"nice\": 0,\n        \"sys\": 3171550,\n        \"idle\": 1452477080,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 60481730,\n        \"nice\": 0,\n        \"sys\": 15739790,\n        \"idle\": 1387929420,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 8588150,\n        \"nice\": 0,\n        \"sys\": 2914910,\n        \"idle\": 1452640170,\n        \"irq\": 0\n      }\n    ],\n    \"networkInterfaces\": [\n      {\n        \"name\": \"lo0\",\n        \"internal\": true,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"127.0.0.1\",\n        \"netmask\": \"255.0.0.0\",\n        \"family\": \"IPv4\"\n      },\n      {\n        \"name\": \"lo0\",\n        \"internal\": true,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"::1\",\n        \"netmask\": \"ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 0\n      },\n      {\n        \"name\": \"lo0\",\n        \"internal\": true,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::1\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 1\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"fe80::4ed:ee34:a73:c21e\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 6\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"192.168.0.23\",\n        \"netmask\": \"255.255.255.0\",\n        \"family\": \"IPv4\"\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"2601:680:cb00:154b:8f6:51ab:3fe1:5491\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 0\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"2601:680:cb00:154b:e5a6:a81a:eb94:9701\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 0\n      },\n      {\n        \"name\": \"awdl0\",\n        \"internal\": false,\n        \"mac\": \"fa:7a:9b:3b:9e:30\",\n        \"address\": \"fe80::f87a:9bff:fe3b:9e30\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 8\n      },\n      {\n        \"name\": \"llw0\",\n        \"internal\": false,\n        \"mac\": \"fa:7a:9b:3b:9e:30\",\n        \"address\": \"fe80::f87a:9bff:fe3b:9e30\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 9\n      },\n      {\n        \"name\": \"utun0\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::6fc3:e997:275a:7897\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 15\n      },\n      {\n        \"name\": \"utun1\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::f5d5:557f:1fd4:8f69\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 16\n      },\n      {\n        \"name\": \"utun2\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::7db8:ff11:6199:49ee\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 17\n      },\n      {\n        \"name\": \"utun3\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::77dc:6930:1ef9:6f6f\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 18\n      },\n      {\n        \"name\": \"utun4\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::e2d9:a7f1:dfb1:bdec\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 19\n      },\n      {\n        \"name\": \"utun5\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::cbd8:8517:456c:2ab7\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 20\n      },\n      {\n        \"name\": \"en5\",\n        \"internal\": false,\n        \"mac\": \"ac:de:48:00:11:22\",\n        \"address\": \"fe80::aede:48ff:fe00:1122\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 4\n      }\n    ],\n    \"host\": \"Tanner-Linsleys-Macbook-Pro.local\"\n  },\n  \"javascriptStack\": {\n    \"message\": \"No stack.\",\n    \"stack\": [\n      \"Unavailable.\"\n    ]\n  },\n  \"nativeStack\": [\n    {\n      \"pc\": \"0x0000000100164e03\",\n      \"symbol\": \"report::TriggerNodeReport(v8::Isolate*, node::Environment*, char const*, char const*, std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, v8::Local<v8::String>) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010008645a\",\n      \"symbol\": \"node::OnFatalError(char const*, char const*) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100187c07\",\n      \"symbol\": \"v8::Utils::ReportOOMFailure(v8::internal::Isolate*, char const*, bool) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100187ba7\",\n      \"symbol\": \"v8::internal::V8::FatalProcessOutOfMemory(v8::internal::Isolate*, char const*, bool) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100315955\",\n      \"symbol\": \"v8::internal::Heap::FatalProcessOutOfMemory(char const*) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x00000001003171ca\",\n      \"symbol\": \"v8::internal::Heap::RecomputeLimits(v8::internal::GarbageCollector) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100313bfc\",\n      \"symbol\": \"v8::internal::Heap::PerformGarbageCollection(v8::internal::GarbageCollector, v8::GCCallbackFlags) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x00000001003119fe\",\n      \"symbol\": \"v8::internal::Heap::CollectGarbage(v8::internal::AllocationSpace, v8::internal::GarbageCollectionReason, v8::GCCallbackFlags) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010031d8ca\",\n      \"symbol\": \"v8::internal::Heap::AllocateRawWithLightRetry(int, v8::internal::AllocationType, v8::internal::AllocationOrigin, v8::internal::AllocationAlignment) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010031d951\",\n      \"symbol\": \"v8::internal::Heap::AllocateRawWithRetryOrFail(int, v8::internal::AllocationType, v8::internal::AllocationOrigin, v8::internal::AllocationAlignment) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x00000001002eb58a\",\n      \"symbol\": \"v8::internal::Factory::NewFillerObject(int, bool, v8::internal::AllocationType, v8::internal::AllocationOrigin) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010063e698\",\n      \"symbol\": \"v8::internal::Runtime_AllocateInYoungGeneration(int, unsigned long*, v8::internal::Isolate*) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010097cc39\",\n      \"symbol\": \"Builtins_CEntry_Return1_DontSaveFPRegs_ArgvOnStack_NoBuiltinExit [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    }\n  ],\n  \"javascriptHeap\": {\n    \"totalMemory\": 2155511808,\n    \"totalCommittedMemory\": 2154040696,\n    \"usedMemory\": 2125733056,\n    \"availableMemory\": 44552400,\n    \"memoryLimit\": 2197815296,\n    \"heapSpaces\": {\n      \"read_only_space\": {\n        \"memorySize\": 262144,\n        \"committedMemory\": 33088,\n        \"capacity\": 32808,\n        \"used\": 32808,\n        \"available\": 0\n      },\n      \"new_space\": {\n        \"memorySize\": 2097152,\n        \"committedMemory\": 1050424,\n        \"capacity\": 1047456,\n        \"used\": 1080,\n        \"available\": 1046376\n      },\n      \"old_space\": {\n        \"memorySize\": 2093621248,\n        \"committedMemory\": 2093479496,\n        \"capacity\": 2067962752,\n        \"used\": 2067807672,\n        \"available\": 155080\n      },\n      \"code_space\": {\n        \"memorySize\": 1478656,\n        \"committedMemory\": 1425472,\n        \"capacity\": 1262272,\n        \"used\": 1262272,\n        \"available\": 0\n      },\n      \"map_space\": {\n        \"memorySize\": 3674112,\n        \"committedMemory\": 3673720,\n        \"capacity\": 2413440,\n        \"used\": 2413440,\n        \"available\": 0\n      },\n      \"large_object_space\": {\n        \"memorySize\": 53755904,\n        \"committedMemory\": 53755904,\n        \"capacity\": 53671240,\n        \"used\": 53671240,\n        \"available\": 0\n      },\n      \"code_large_object_space\": {\n        \"memorySize\": 622592,\n        \"committedMemory\": 622592,\n        \"capacity\": 544544,\n        \"used\": 544544,\n        \"available\": 0\n      },\n      \"new_large_object_space\": {\n        \"memorySize\": 0,\n        \"committedMemory\": 0,\n        \"capacity\": 1047456,\n        \"used\": 0,\n        \"available\": 1047456\n      }\n    }\n  },\n  \"resourceUsage\": {\n    \"userCpuSeconds\": 99.2202,\n    \"kernelCpuSeconds\": 47.6506,\n    \"cpuConsumptionPercent\": 206.86,\n    \"maxRss\": 3027431849984,\n    \"pageFaults\": {\n      \"IORequired\": 33,\n      \"IONotRequired\": 977733\n    },\n    \"fsActivity\": {\n      \"reads\": 0,\n      \"writes\": 0\n    }\n  },\n  \"libuv\": [\n  ],\n  \"workers\": [\n  ],\n  \"environmentVariables\": {\n    \"npm_package_dependencies_react_charts\": \"next\",\n    \"TERM_PROGRAM\": \"Hyper\",\n    \"NODE\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n    \"npm_config_version_git_tag\": \"true\",\n    \"NVM_CD_FLAGS\": \"-q\",\n    \"INIT_CWD\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line-chart\",\n    \"TERM\": \"xterm-256color\",\n    \"SHELL\": \"/bin/zsh\",\n    \"TMPDIR\": \"/var/folders/wg/wzqxvxfn61sb5cxpkp9j5pg80000gn/T/\",\n    \"npm_config_email\": \"tannerlinsley@gmail.com\",\n    \"npm_config_init_license\": \"MIT\",\n    \"TERM_PROGRAM_VERSION\": \"3.0.2\",\n    \"npm_config_registry\": \"https://registry.yarnpkg.com\",\n    \"npm_package_private\": \"true\",\n    \"npm_package_dependencies_react_dom\": \"^16.8.6\",\n    \"ZSH\": \"/Users/tannerlinsley/.oh-my-zsh\",\n    \"npm_package_readmeFilename\": \"README.md\",\n    \"npm_package_description\": \"To run this example:\",\n    \"NVM_DIR\": \"/Users/tannerlinsley/.nvm\",\n    \"USER\": \"tannerlinsley\",\n    \"npm_package_browserslist_development_1\": \"last 1 firefox version\",\n    \"npm_package_browserslist_development_0\": \"last 1 chrome version\",\n    \"SSH_AUTH_SOCK\": \"/private/tmp/com.apple.launchd.w4HS6hadY4/Listeners\",\n    \"npm_package_dependencies_styled_components\": \"^4.3.2\",\n    \"npm_package_browserslist_development_2\": \"last 1 safari version\",\n    \"__CF_USER_TEXT_ENCODING\": \"0x1F5:0x0:0x0\",\n    \"npm_execpath\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/lib/node_modules/yarn/bin/yarn.js\",\n    \"PAGER\": \"less\",\n    \"LSCOLORS\": \"Gxfxcxdxbxegedabagacad\",\n    \"npm_config_argv\": \"{\\\"remain\\\":[],\\\"cooked\\\":[\\\"run\\\",\\\"start\\\"],\\\"original\\\":[\\\"start\\\"]}\",\n    \"PATH\": \"/var/folders/wg/wzqxvxfn61sb5cxpkp9j5pg80000gn/T/yarn--1595523570170-0.38719529019435006:/Users/tannerlinsley/GitHub/react-charts/examples/line-chart/node_modules/.bin:/Users/tannerlinsley/.config/yarn/link/node_modules/.bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/libexec/lib/node_modules/npm/bin/node-gyp-bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/lib/node_modules/npm/bin/node-gyp-bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node_modules/npm/bin/node-gyp-bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/Applications/Postgres.app/Contents/Versions/latest/bin:/Applications/Visual Studio Code.app/Contents/Resources/app/bin\",\n    \"npm_package_devDependencies__rescripts_cli\": \"^0.0.11\",\n    \"_\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line-chart/node_modules/.bin/rescripts\",\n    \"npm_package_browserslist_production_1\": \"not dead\",\n    \"npm_package_browserslist_production_0\": \">0.2%\",\n    \"PWD\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line-chart\",\n    \"npm_package_browserslist_production_2\": \"not op_mini all\",\n    \"npm_lifecycle_event\": \"start\",\n    \"EDITOR\": \"code\",\n    \"npm_package_name\": \"\",\n    \"LANG\": \"en_US.UTF-8\",\n    \"npm_config_version_commit_hooks\": \"true\",\n    \"npm_package_scripts_start\": \"rescripts start\",\n    \"npm_package_scripts_build\": \"rescripts build\",\n    \"npm_config_username\": \"tannerlinsley\",\n    \"XPC_FLAGS\": \"0x0\",\n    \"npm_config_bin_links\": \"true\",\n    \"npm_package_devDependencies__rescripts_rescript_use_eslint_config\": \"^0.0.9\",\n    \"npm_package_version\": \"\",\n    \"XPC_SERVICE_NAME\": \"0\",\n    \"npm_package_devDependencies__rescripts_rescript_use_babel_config\": \"^0.0.8\",\n    \"SHLVL\": \"2\",\n    \"HOME\": \"/Users/tannerlinsley\",\n    \"npm_package_scripts_test\": \"rescripts test\",\n    \"npm_config_strict_ssl\": \"true\",\n    \"npm_config_save_prefix\": \"^\",\n    \"npm_config_version_git_message\": \"v%s\",\n    \"npm_package_devDependencies_babel_eslint\": \"10.0.1\",\n    \"npm_package_dependencies_react_scripts\": \"3.0.1\",\n    \"YARN_WRAP_OUTPUT\": \"false\",\n    \"LESS\": \"-R\",\n    \"LOGNAME\": \"tannerlinsley\",\n    \"npm_lifecycle_script\": \"rescripts start\",\n    \"npm_package_dependencies_react\": \"^16.8.6\",\n    \"NVM_BIN\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin\",\n    \"npm_config_user_agent\": \"yarn/1.22.4 npm/? node/v12.16.3 darwin x64\",\n    \"npm_config_ignore_scripts\": \"\",\n    \"npm_config_version_git_sign\": \"\",\n    \"npm_config_ignore_optional\": \"\",\n    \"npm_config_init_version\": \"1.0.0\",\n    \"npm_config_init_author_name\": \"Tanner Linsley\",\n    \"npm_package_scripts_eject\": \"rescripts eject\",\n    \"npm_config_version_tag_prefix\": \"v\",\n    \"npm_node_execpath\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n    \"COLORTERM\": \"truecolor\",\n    \"BABEL_ENV\": \"development\",\n    \"NODE_ENV\": \"development\",\n    \"SKIP_PREFLIGHT_CHECK\": \"true\",\n    \"NODE_PATH\": \"\"\n  },\n  \"userLimits\": {\n    \"core_file_size_blocks\": {\n      \"soft\": 0,\n      \"hard\": \"unlimited\"\n    },\n    \"data_seg_size_kbytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"file_size_blocks\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"max_locked_memory_bytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"max_memory_size_kbytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"open_files\": {\n      \"soft\": 49152,\n      \"hard\": \"unlimited\"\n    },\n    \"stack_size_bytes\": {\n      \"soft\": 8388608,\n      \"hard\": 67104768\n    },\n    \"cpu_time_seconds\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"max_user_processes\": {\n      \"soft\": 5568,\n      \"hard\": 8352\n    },\n    \"virtual_memory_kbytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    }\n  },\n  \"sharedObjects\": [\n    \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n    \"/System/Library/Frameworks/CoreFoundation.framework/Versions/A/CoreFoundation\",\n    \"/usr/lib/libSystem.B.dylib\",\n    \"/usr/lib/libc++.1.dylib\",\n    \"/usr/lib/libobjc.A.dylib\",\n    \"/usr/lib/libfakelink.dylib\",\n    \"/usr/lib/libDiagnosticMessagesClient.dylib\",\n    \"/usr/lib/libicucore.A.dylib\",\n    \"/usr/lib/libz.1.dylib\",\n    \"/usr/lib/libc++abi.dylib\",\n    \"/usr/lib/system/libcache.dylib\",\n    \"/usr/lib/system/libcommonCrypto.dylib\",\n    \"/usr/lib/system/libcompiler_rt.dylib\",\n    \"/usr/lib/system/libcopyfile.dylib\",\n    \"/usr/lib/system/libcorecrypto.dylib\",\n    \"/usr/lib/system/libdispatch.dylib\",\n    \"/usr/lib/system/libdyld.dylib\",\n    \"/usr/lib/system/libkeymgr.dylib\",\n    \"/usr/lib/system/liblaunch.dylib\",\n    \"/usr/lib/system/libmacho.dylib\",\n    \"/usr/lib/system/libquarantine.dylib\",\n    \"/usr/lib/system/libremovefile.dylib\",\n    \"/usr/lib/system/libsystem_asl.dylib\",\n    \"/usr/lib/system/libsystem_blocks.dylib\",\n    \"/usr/lib/system/libsystem_c.dylib\",\n    \"/usr/lib/system/libsystem_configuration.dylib\",\n    \"/usr/lib/system/libsystem_coreservices.dylib\",\n    \"/usr/lib/system/libsystem_darwin.dylib\",\n    \"/usr/lib/system/libsystem_dnssd.dylib\",\n    \"/usr/lib/system/libsystem_featureflags.dylib\",\n    \"/usr/lib/system/libsystem_info.dylib\",\n    \"/usr/lib/system/libsystem_m.dylib\",\n    \"/usr/lib/system/libsystem_malloc.dylib\",\n    \"/usr/lib/system/libsystem_networkextension.dylib\",\n    \"/usr/lib/system/libsystem_notify.dylib\",\n    \"/usr/lib/system/libsystem_sandbox.dylib\",\n    \"/usr/lib/system/libsystem_secinit.dylib\",\n    \"/usr/lib/system/libsystem_kernel.dylib\",\n    \"/usr/lib/system/libsystem_platform.dylib\",\n    \"/usr/lib/system/libsystem_pthread.dylib\",\n    \"/usr/lib/system/libsystem_symptoms.dylib\",\n    \"/usr/lib/system/libsystem_trace.dylib\",\n    \"/usr/lib/system/libunwind.dylib\",\n    \"/usr/lib/system/libxpc.dylib\",\n    \"/Users/tannerlinsley/GitHub/react-charts/examples/line-chart/node_modules/fsevents/build/Release/fse.node\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/CoreServices\",\n    \"/System/Library/Frameworks/CFNetwork.framework/Versions/A/CFNetwork\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/FSEvents.framework/Versions/A/FSEvents\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/CarbonCore.framework/Versions/A/CarbonCore\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/Metadata.framework/Versions/A/Metadata\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/OSServices.framework/Versions/A/OSServices\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/SearchKit.framework/Versions/A/SearchKit\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/AE.framework/Versions/A/AE\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/LaunchServices.framework/Versions/A/LaunchServices\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/DictionaryServices.framework/Versions/A/DictionaryServices\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/SharedFileList.framework/Versions/A/SharedFileList\",\n    \"/System/Library/Frameworks/Foundation.framework/Versions/C/Foundation\",\n    \"/System/Library/Frameworks/IOKit.framework/Versions/A/IOKit\",\n    \"/System/Library/Frameworks/SystemConfiguration.framework/Versions/A/SystemConfiguration\",\n    \"/System/Library/Frameworks/Security.framework/Versions/A/Security\",\n    \"/usr/lib/libsqlite3.dylib\",\n    \"/usr/lib/libxml2.2.dylib\",\n    \"/usr/lib/libnetwork.dylib\",\n    \"/usr/lib/libapple_nghttp2.dylib\",\n    \"/usr/lib/libauto.dylib\",\n    \"/usr/lib/libcompression.dylib\",\n    \"/System/Library/Frameworks/DiskArbitration.framework/Versions/A/DiskArbitration\",\n    \"/usr/lib/libarchive.2.dylib\",\n    \"/usr/lib/liblangid.dylib\",\n    \"/usr/lib/libCRFSuite.dylib\",\n    \"/usr/lib/liblzma.5.dylib\",\n    \"/usr/lib/libenergytrace.dylib\",\n    \"/usr/lib/libbsm.0.dylib\",\n    \"/usr/lib/system/libkxld.dylib\",\n    \"/System/Library/PrivateFrameworks/AppleFSCompression.framework/Versions/A/AppleFSCompression\",\n    \"/usr/lib/libcoretls.dylib\",\n    \"/usr/lib/libcoretls_cfhelpers.dylib\",\n    \"/usr/lib/libpam.2.dylib\",\n    \"/usr/lib/libxar.1.dylib\",\n    \"/usr/lib/libbz2.1.0.dylib\",\n    \"/usr/lib/libiconv.2.dylib\",\n    \"/usr/lib/libcharset.1.dylib\",\n    \"/usr/lib/libpcap.A.dylib\",\n    \"/System/Library/Frameworks/NetFS.framework/Versions/A/NetFS\",\n    \"/System/Library/PrivateFrameworks/NetAuth.framework/Versions/A/NetAuth\",\n    \"/System/Library/PrivateFrameworks/login.framework/Versions/A/Frameworks/loginsupport.framework/Versions/A/loginsupport\",\n    \"/System/Library/PrivateFrameworks/TCC.framework/Versions/A/TCC\",\n    \"/System/Library/PrivateFrameworks/CoreNLP.framework/Versions/A/CoreNLP\",\n    \"/System/Library/PrivateFrameworks/MetadataUtilities.framework/Versions/A/MetadataUtilities\",\n    \"/usr/lib/libmecabra.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Accelerate\",\n    \"/usr/lib/libmecab.dylib\",\n    \"/usr/lib/libgermantok.dylib\",\n    \"/usr/lib/libThaiTokenizer.dylib\",\n    \"/usr/lib/libChineseTokenizer.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vImage.framework/Versions/A/vImage\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/vecLib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libvMisc.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libvDSP.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libBLAS.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libLAPACK.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libLinearAlgebra.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libSparseBLAS.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libQuadrature.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libBNNS.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libSparse.dylib\",\n    \"/System/Library/PrivateFrameworks/LanguageModeling.framework/Versions/A/LanguageModeling\",\n    \"/System/Library/PrivateFrameworks/CoreEmoji.framework/Versions/A/CoreEmoji\",\n    \"/System/Library/PrivateFrameworks/LinguisticData.framework/Versions/A/LinguisticData\",\n    \"/System/Library/PrivateFrameworks/Lexicon.framework/Versions/A/Lexicon\",\n    \"/usr/lib/libcmph.dylib\",\n    \"/System/Library/Frameworks/OpenDirectory.framework/Versions/A/Frameworks/CFOpenDirectory.framework/Versions/A/CFOpenDirectory\",\n    \"/System/Library/Frameworks/OpenDirectory.framework/Versions/A/OpenDirectory\",\n    \"/System/Library/PrivateFrameworks/APFS.framework/Versions/A/APFS\",\n    \"/System/Library/Frameworks/SecurityFoundation.framework/Versions/A/SecurityFoundation\",\n    \"/usr/lib/libutil.dylib\",\n    \"/System/Library/PrivateFrameworks/CoreServicesStore.framework/Versions/A/CoreServicesStore\",\n    \"/System/Library/Frameworks/ServiceManagement.framework/Versions/A/ServiceManagement\",\n    \"/System/Library/PrivateFrameworks/BackgroundTaskManagement.framework/Versions/A/BackgroundTaskManagement\",\n    \"/usr/lib/libxslt.1.dylib\"\n  ]\n}"
  },
  {
    "path": "examples/simple/report.20200813.175012.49872.0.001.json",
    "content": "\n{\n  \"header\": {\n    \"reportVersion\": 2,\n    \"event\": \"Allocation failed - JavaScript heap out of memory\",\n    \"trigger\": \"FatalError\",\n    \"filename\": \"report.20200813.175012.49872.0.001.json\",\n    \"dumpEventTime\": \"2020-08-13T17:50:12Z\",\n    \"dumpEventTimeStamp\": \"1597362612676\",\n    \"processId\": 49872,\n    \"threadId\": null,\n    \"cwd\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line\",\n    \"commandLine\": [\n      \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n      \"/Users/tannerlinsley/GitHub/react-charts/examples/line/node_modules/@rescripts/cli/scripts/start.js\"\n    ],\n    \"nodejsVersion\": \"v12.16.3\",\n    \"wordSize\": 64,\n    \"arch\": \"x64\",\n    \"platform\": \"darwin\",\n    \"componentVersions\": {\n      \"node\": \"12.16.3\",\n      \"v8\": \"7.8.279.23-node.35\",\n      \"uv\": \"1.34.2\",\n      \"zlib\": \"1.2.11\",\n      \"brotli\": \"1.0.7\",\n      \"ares\": \"1.16.0\",\n      \"modules\": \"72\",\n      \"nghttp2\": \"1.40.0\",\n      \"napi\": \"5\",\n      \"llhttp\": \"2.0.4\",\n      \"http_parser\": \"2.9.3\",\n      \"openssl\": \"1.1.1g\",\n      \"cldr\": \"36.0\",\n      \"icu\": \"65.1\",\n      \"tz\": \"2019c\",\n      \"unicode\": \"12.1\"\n    },\n    \"release\": {\n      \"name\": \"node\",\n      \"lts\": \"Erbium\",\n      \"headersUrl\": \"https://nodejs.org/download/release/v12.16.3/node-v12.16.3-headers.tar.gz\",\n      \"sourceUrl\": \"https://nodejs.org/download/release/v12.16.3/node-v12.16.3.tar.gz\"\n    },\n    \"osName\": \"Darwin\",\n    \"osRelease\": \"19.3.0\",\n    \"osVersion\": \"Darwin Kernel Version 19.3.0: Thu Jan  9 20:58:23 PST 2020; root:xnu-6153.81.5~1/RELEASE_X86_64\",\n    \"osMachine\": \"x86_64\",\n    \"cpus\": [\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 17514740,\n        \"nice\": 0,\n        \"sys\": 9813680,\n        \"idle\": 115668610,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 318080,\n        \"nice\": 0,\n        \"sys\": 405290,\n        \"idle\": 142101350,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 15020620,\n        \"nice\": 0,\n        \"sys\": 6857850,\n        \"idle\": 120948630,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 302700,\n        \"nice\": 0,\n        \"sys\": 340950,\n        \"idle\": 142180990,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 11840570,\n        \"nice\": 0,\n        \"sys\": 5239790,\n        \"idle\": 125746680,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 304730,\n        \"nice\": 0,\n        \"sys\": 296250,\n        \"idle\": 142223580,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 8507770,\n        \"nice\": 0,\n        \"sys\": 3626680,\n        \"idle\": 130692500,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 295110,\n        \"nice\": 0,\n        \"sys\": 251350,\n        \"idle\": 142278020,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 7206650,\n        \"nice\": 0,\n        \"sys\": 2872930,\n        \"idle\": 132747300,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 282440,\n        \"nice\": 0,\n        \"sys\": 211290,\n        \"idle\": 142330670,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 5096910,\n        \"nice\": 0,\n        \"sys\": 1803740,\n        \"idle\": 135926150,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 270580,\n        \"nice\": 0,\n        \"sys\": 177310,\n        \"idle\": 142376410,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 3922120,\n        \"nice\": 0,\n        \"sys\": 1307970,\n        \"idle\": 137596640,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 260510,\n        \"nice\": 0,\n        \"sys\": 154120,\n        \"idle\": 142409590,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 3134130,\n        \"nice\": 0,\n        \"sys\": 976570,\n        \"idle\": 138715940,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 253590,\n        \"nice\": 0,\n        \"sys\": 135250,\n        \"idle\": 142435300,\n        \"irq\": 0\n      }\n    ],\n    \"networkInterfaces\": [\n      {\n        \"name\": \"lo0\",\n        \"internal\": true,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"127.0.0.1\",\n        \"netmask\": \"255.0.0.0\",\n        \"family\": \"IPv4\"\n      },\n      {\n        \"name\": \"lo0\",\n        \"internal\": true,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"::1\",\n        \"netmask\": \"ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 0\n      },\n      {\n        \"name\": \"lo0\",\n        \"internal\": true,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::1\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 1\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"fe80::450:f69c:fb3e:764f\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 6\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"192.168.0.23\",\n        \"netmask\": \"255.255.255.0\",\n        \"family\": \"IPv4\"\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"2601:680:cb00:154b:8f6:51ab:3fe1:5491\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 0\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"2601:680:cb00:154b:1550:6018:4e12:5b67\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 0\n      },\n      {\n        \"name\": \"awdl0\",\n        \"internal\": false,\n        \"mac\": \"5a:f6:e9:83:3c:05\",\n        \"address\": \"fe80::58f6:e9ff:fe83:3c05\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 13\n      },\n      {\n        \"name\": \"llw0\",\n        \"internal\": false,\n        \"mac\": \"5a:f6:e9:83:3c:05\",\n        \"address\": \"fe80::58f6:e9ff:fe83:3c05\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 14\n      },\n      {\n        \"name\": \"en5\",\n        \"internal\": false,\n        \"mac\": \"ac:de:48:00:11:22\",\n        \"address\": \"fe80::aede:48ff:fe00:1122\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 5\n      },\n      {\n        \"name\": \"utun0\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::794b:ae5f:df5d:69fa\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 15\n      },\n      {\n        \"name\": \"utun1\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::c79f:2354:a0c3:6a8f\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 16\n      },\n      {\n        \"name\": \"utun2\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::817c:40d9:be3c:a26e\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 17\n      },\n      {\n        \"name\": \"utun3\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::a422:8846:d52e:f292\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 18\n      }\n    ],\n    \"host\": \"Tanner-Linsleys-Macbook-Pro.local\"\n  },\n  \"javascriptStack\": {\n    \"message\": \"No stack.\",\n    \"stack\": [\n      \"Unavailable.\"\n    ]\n  },\n  \"nativeStack\": [\n    {\n      \"pc\": \"0x0000000100164e03\",\n      \"symbol\": \"report::TriggerNodeReport(v8::Isolate*, node::Environment*, char const*, char const*, std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, v8::Local<v8::String>) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010008645a\",\n      \"symbol\": \"node::OnFatalError(char const*, char const*) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100187c07\",\n      \"symbol\": \"v8::Utils::ReportOOMFailure(v8::internal::Isolate*, char const*, bool) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100187ba7\",\n      \"symbol\": \"v8::internal::V8::FatalProcessOutOfMemory(v8::internal::Isolate*, char const*, bool) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100315955\",\n      \"symbol\": \"v8::internal::Heap::FatalProcessOutOfMemory(char const*) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x00000001003171ca\",\n      \"symbol\": \"v8::internal::Heap::RecomputeLimits(v8::internal::GarbageCollector) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100313bfc\",\n      \"symbol\": \"v8::internal::Heap::PerformGarbageCollection(v8::internal::GarbageCollector, v8::GCCallbackFlags) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x00000001003119fe\",\n      \"symbol\": \"v8::internal::Heap::CollectGarbage(v8::internal::AllocationSpace, v8::internal::GarbageCollectionReason, v8::GCCallbackFlags) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010031d8ca\",\n      \"symbol\": \"v8::internal::Heap::AllocateRawWithLightRetry(int, v8::internal::AllocationType, v8::internal::AllocationOrigin, v8::internal::AllocationAlignment) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010031d951\",\n      \"symbol\": \"v8::internal::Heap::AllocateRawWithRetryOrFail(int, v8::internal::AllocationType, v8::internal::AllocationOrigin, v8::internal::AllocationAlignment) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x00000001002eb58a\",\n      \"symbol\": \"v8::internal::Factory::NewFillerObject(int, bool, v8::internal::AllocationType, v8::internal::AllocationOrigin) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010063e698\",\n      \"symbol\": \"v8::internal::Runtime_AllocateInYoungGeneration(int, unsigned long*, v8::internal::Isolate*) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010097cc39\",\n      \"symbol\": \"Builtins_CEntry_Return1_DontSaveFPRegs_ArgvOnStack_NoBuiltinExit [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    }\n  ],\n  \"javascriptHeap\": {\n    \"totalMemory\": 2154164224,\n    \"totalCommittedMemory\": 2150597120,\n    \"usedMemory\": 2124141512,\n    \"availableMemory\": 48860896,\n    \"memoryLimit\": 2197815296,\n    \"heapSpaces\": {\n      \"read_only_space\": {\n        \"memorySize\": 262144,\n        \"committedMemory\": 33088,\n        \"capacity\": 32808,\n        \"used\": 32808,\n        \"available\": 0\n      },\n      \"new_space\": {\n        \"memorySize\": 4194304,\n        \"committedMemory\": 1269544,\n        \"capacity\": 2094912,\n        \"used\": 282912,\n        \"available\": 1812000\n      },\n      \"old_space\": {\n        \"memorySize\": 2087854080,\n        \"committedMemory\": 2087671136,\n        \"capacity\": 2064812984,\n        \"used\": 2063510072,\n        \"available\": 1302912\n      },\n      \"code_space\": {\n        \"memorySize\": 2002944,\n        \"committedMemory\": 1772992,\n        \"capacity\": 1635520,\n        \"used\": 1635520,\n        \"available\": 0\n      },\n      \"map_space\": {\n        \"memorySize\": 3674112,\n        \"committedMemory\": 3673720,\n        \"capacity\": 2686960,\n        \"used\": 2686960,\n        \"available\": 0\n      },\n      \"large_object_space\": {\n        \"memorySize\": 55554048,\n        \"committedMemory\": 55554048,\n        \"capacity\": 55448696,\n        \"used\": 55448696,\n        \"available\": 0\n      },\n      \"code_large_object_space\": {\n        \"memorySize\": 622592,\n        \"committedMemory\": 622592,\n        \"capacity\": 544544,\n        \"used\": 544544,\n        \"available\": 0\n      },\n      \"new_large_object_space\": {\n        \"memorySize\": 0,\n        \"committedMemory\": 0,\n        \"capacity\": 2094912,\n        \"used\": 0,\n        \"available\": 2094912\n      }\n    }\n  },\n  \"resourceUsage\": {\n    \"userCpuSeconds\": 149.1,\n    \"kernelCpuSeconds\": 53.5141,\n    \"cpuConsumptionPercent\": 12.6634,\n    \"maxRss\": 2923551522816,\n    \"pageFaults\": {\n      \"IORequired\": 34,\n      \"IONotRequired\": 1485043\n    },\n    \"fsActivity\": {\n      \"reads\": 0,\n      \"writes\": 0\n    }\n  },\n  \"libuv\": [\n  ],\n  \"workers\": [\n  ],\n  \"environmentVariables\": {\n    \"npm_package_dependencies_react_charts\": \"next\",\n    \"TERM_PROGRAM\": \"Hyper\",\n    \"NODE\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n    \"npm_config_version_git_tag\": \"true\",\n    \"NVM_CD_FLAGS\": \"-q\",\n    \"INIT_CWD\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line\",\n    \"TERM\": \"xterm-256color\",\n    \"SHELL\": \"/bin/zsh\",\n    \"TMPDIR\": \"/var/folders/wg/wzqxvxfn61sb5cxpkp9j5pg80000gn/T/\",\n    \"npm_config_email\": \"tannerlinsley@gmail.com\",\n    \"npm_config_init_license\": \"MIT\",\n    \"TERM_PROGRAM_VERSION\": \"3.0.2\",\n    \"npm_config_registry\": \"https://registry.yarnpkg.com\",\n    \"npm_package_private\": \"true\",\n    \"npm_package_dependencies_react_dom\": \"^16.8.6\",\n    \"ZSH\": \"/Users/tannerlinsley/.oh-my-zsh\",\n    \"npm_package_readmeFilename\": \"README.md\",\n    \"npm_package_description\": \"To run this example:\",\n    \"NVM_DIR\": \"/Users/tannerlinsley/.nvm\",\n    \"USER\": \"tannerlinsley\",\n    \"npm_package_browserslist_development_1\": \"last 1 firefox version\",\n    \"npm_package_browserslist_development_0\": \"last 1 chrome version\",\n    \"SSH_AUTH_SOCK\": \"/private/tmp/com.apple.launchd.y1vHD7roLs/Listeners\",\n    \"npm_package_dependencies_styled_components\": \"^4.3.2\",\n    \"npm_package_browserslist_development_2\": \"last 1 safari version\",\n    \"__CF_USER_TEXT_ENCODING\": \"0x1F5:0x0:0x0\",\n    \"npm_execpath\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/lib/node_modules/yarn/bin/yarn.js\",\n    \"PAGER\": \"less\",\n    \"LSCOLORS\": \"Gxfxcxdxbxegedabagacad\",\n    \"npm_config_argv\": \"{\\\"remain\\\":[],\\\"cooked\\\":[\\\"run\\\",\\\"start\\\"],\\\"original\\\":[\\\"start\\\"]}\",\n    \"PATH\": \"/var/folders/wg/wzqxvxfn61sb5cxpkp9j5pg80000gn/T/yarn--1597361011346-0.9297615518449156:/Users/tannerlinsley/GitHub/react-charts/examples/line/node_modules/.bin:/Users/tannerlinsley/.config/yarn/link/node_modules/.bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/libexec/lib/node_modules/npm/bin/node-gyp-bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/lib/node_modules/npm/bin/node-gyp-bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node_modules/npm/bin/node-gyp-bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/Applications/Postgres.app/Contents/Versions/latest/bin:/Applications/Visual Studio Code.app/Contents/Resources/app/bin\",\n    \"npm_package_devDependencies__rescripts_cli\": \"^0.0.11\",\n    \"_\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line/node_modules/.bin/rescripts\",\n    \"npm_package_browserslist_production_1\": \"not dead\",\n    \"npm_package_browserslist_production_0\": \">0.2%\",\n    \"PWD\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line\",\n    \"npm_package_browserslist_production_2\": \"not op_mini all\",\n    \"npm_lifecycle_event\": \"start\",\n    \"EDITOR\": \"code\",\n    \"npm_package_name\": \"\",\n    \"LANG\": \"en_US.UTF-8\",\n    \"npm_config_version_commit_hooks\": \"true\",\n    \"npm_package_scripts_start\": \"rescripts start\",\n    \"npm_package_scripts_build\": \"rescripts build\",\n    \"npm_config_username\": \"tannerlinsley\",\n    \"XPC_FLAGS\": \"0x0\",\n    \"npm_config_bin_links\": \"true\",\n    \"npm_package_dependencies__react_hook_window_size\": \"3.0.7\",\n    \"npm_package_devDependencies__rescripts_rescript_use_eslint_config\": \"^0.0.9\",\n    \"npm_package_version\": \"\",\n    \"XPC_SERVICE_NAME\": \"0\",\n    \"npm_package_devDependencies__rescripts_rescript_use_babel_config\": \"^0.0.8\",\n    \"SHLVL\": \"2\",\n    \"HOME\": \"/Users/tannerlinsley\",\n    \"npm_package_scripts_test\": \"rescripts test\",\n    \"npm_config_strict_ssl\": \"true\",\n    \"npm_config_save_prefix\": \"^\",\n    \"npm_config_version_git_message\": \"v%s\",\n    \"npm_package_devDependencies_babel_eslint\": \"10.0.1\",\n    \"npm_package_dependencies_react_scripts\": \"3.0.1\",\n    \"YARN_WRAP_OUTPUT\": \"false\",\n    \"LESS\": \"-R\",\n    \"LOGNAME\": \"tannerlinsley\",\n    \"npm_lifecycle_script\": \"rescripts start\",\n    \"npm_package_dependencies_react\": \"^16.8.6\",\n    \"NVM_BIN\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin\",\n    \"npm_config_user_agent\": \"yarn/1.22.4 npm/? node/v12.16.3 darwin x64\",\n    \"npm_config_ignore_scripts\": \"\",\n    \"npm_config_version_git_sign\": \"\",\n    \"npm_package_dependencies_react_resizable\": \"^1.10.1\",\n    \"npm_config_ignore_optional\": \"\",\n    \"npm_config_init_version\": \"1.0.0\",\n    \"npm_config_init_author_name\": \"Tanner Linsley\",\n    \"npm_package_scripts_eject\": \"rescripts eject\",\n    \"npm_config_version_tag_prefix\": \"v\",\n    \"npm_node_execpath\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n    \"COLORTERM\": \"truecolor\",\n    \"BABEL_ENV\": \"development\",\n    \"NODE_ENV\": \"development\",\n    \"SKIP_PREFLIGHT_CHECK\": \"true\",\n    \"NODE_PATH\": \"\"\n  },\n  \"userLimits\": {\n    \"core_file_size_blocks\": {\n      \"soft\": 0,\n      \"hard\": \"unlimited\"\n    },\n    \"data_seg_size_kbytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"file_size_blocks\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"max_locked_memory_bytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"max_memory_size_kbytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"open_files\": {\n      \"soft\": 49152,\n      \"hard\": \"unlimited\"\n    },\n    \"stack_size_bytes\": {\n      \"soft\": 8388608,\n      \"hard\": 67104768\n    },\n    \"cpu_time_seconds\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"max_user_processes\": {\n      \"soft\": 5568,\n      \"hard\": 8352\n    },\n    \"virtual_memory_kbytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    }\n  },\n  \"sharedObjects\": [\n    \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n    \"/System/Library/Frameworks/CoreFoundation.framework/Versions/A/CoreFoundation\",\n    \"/usr/lib/libSystem.B.dylib\",\n    \"/usr/lib/libc++.1.dylib\",\n    \"/usr/lib/libobjc.A.dylib\",\n    \"/usr/lib/libfakelink.dylib\",\n    \"/usr/lib/libDiagnosticMessagesClient.dylib\",\n    \"/usr/lib/libicucore.A.dylib\",\n    \"/usr/lib/libz.1.dylib\",\n    \"/usr/lib/libc++abi.dylib\",\n    \"/usr/lib/system/libcache.dylib\",\n    \"/usr/lib/system/libcommonCrypto.dylib\",\n    \"/usr/lib/system/libcompiler_rt.dylib\",\n    \"/usr/lib/system/libcopyfile.dylib\",\n    \"/usr/lib/system/libcorecrypto.dylib\",\n    \"/usr/lib/system/libdispatch.dylib\",\n    \"/usr/lib/system/libdyld.dylib\",\n    \"/usr/lib/system/libkeymgr.dylib\",\n    \"/usr/lib/system/liblaunch.dylib\",\n    \"/usr/lib/system/libmacho.dylib\",\n    \"/usr/lib/system/libquarantine.dylib\",\n    \"/usr/lib/system/libremovefile.dylib\",\n    \"/usr/lib/system/libsystem_asl.dylib\",\n    \"/usr/lib/system/libsystem_blocks.dylib\",\n    \"/usr/lib/system/libsystem_c.dylib\",\n    \"/usr/lib/system/libsystem_configuration.dylib\",\n    \"/usr/lib/system/libsystem_coreservices.dylib\",\n    \"/usr/lib/system/libsystem_darwin.dylib\",\n    \"/usr/lib/system/libsystem_dnssd.dylib\",\n    \"/usr/lib/system/libsystem_featureflags.dylib\",\n    \"/usr/lib/system/libsystem_info.dylib\",\n    \"/usr/lib/system/libsystem_m.dylib\",\n    \"/usr/lib/system/libsystem_malloc.dylib\",\n    \"/usr/lib/system/libsystem_networkextension.dylib\",\n    \"/usr/lib/system/libsystem_notify.dylib\",\n    \"/usr/lib/system/libsystem_sandbox.dylib\",\n    \"/usr/lib/system/libsystem_secinit.dylib\",\n    \"/usr/lib/system/libsystem_kernel.dylib\",\n    \"/usr/lib/system/libsystem_platform.dylib\",\n    \"/usr/lib/system/libsystem_pthread.dylib\",\n    \"/usr/lib/system/libsystem_symptoms.dylib\",\n    \"/usr/lib/system/libsystem_trace.dylib\",\n    \"/usr/lib/system/libunwind.dylib\",\n    \"/usr/lib/system/libxpc.dylib\",\n    \"/Users/tannerlinsley/GitHub/react-charts/examples/line/node_modules/fsevents/build/Release/fse.node\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/CoreServices\",\n    \"/System/Library/Frameworks/CFNetwork.framework/Versions/A/CFNetwork\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/FSEvents.framework/Versions/A/FSEvents\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/CarbonCore.framework/Versions/A/CarbonCore\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/Metadata.framework/Versions/A/Metadata\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/OSServices.framework/Versions/A/OSServices\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/SearchKit.framework/Versions/A/SearchKit\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/AE.framework/Versions/A/AE\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/LaunchServices.framework/Versions/A/LaunchServices\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/DictionaryServices.framework/Versions/A/DictionaryServices\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/SharedFileList.framework/Versions/A/SharedFileList\",\n    \"/System/Library/Frameworks/Foundation.framework/Versions/C/Foundation\",\n    \"/System/Library/Frameworks/IOKit.framework/Versions/A/IOKit\",\n    \"/System/Library/Frameworks/SystemConfiguration.framework/Versions/A/SystemConfiguration\",\n    \"/System/Library/Frameworks/Security.framework/Versions/A/Security\",\n    \"/usr/lib/libsqlite3.dylib\",\n    \"/usr/lib/libxml2.2.dylib\",\n    \"/usr/lib/libnetwork.dylib\",\n    \"/usr/lib/libapple_nghttp2.dylib\",\n    \"/usr/lib/libauto.dylib\",\n    \"/usr/lib/libcompression.dylib\",\n    \"/System/Library/Frameworks/DiskArbitration.framework/Versions/A/DiskArbitration\",\n    \"/usr/lib/libarchive.2.dylib\",\n    \"/usr/lib/liblangid.dylib\",\n    \"/usr/lib/libCRFSuite.dylib\",\n    \"/usr/lib/liblzma.5.dylib\",\n    \"/usr/lib/libenergytrace.dylib\",\n    \"/usr/lib/libbsm.0.dylib\",\n    \"/usr/lib/system/libkxld.dylib\",\n    \"/System/Library/PrivateFrameworks/AppleFSCompression.framework/Versions/A/AppleFSCompression\",\n    \"/usr/lib/libcoretls.dylib\",\n    \"/usr/lib/libcoretls_cfhelpers.dylib\",\n    \"/usr/lib/libpam.2.dylib\",\n    \"/usr/lib/libxar.1.dylib\",\n    \"/usr/lib/libbz2.1.0.dylib\",\n    \"/usr/lib/libiconv.2.dylib\",\n    \"/usr/lib/libcharset.1.dylib\",\n    \"/usr/lib/libpcap.A.dylib\",\n    \"/System/Library/Frameworks/NetFS.framework/Versions/A/NetFS\",\n    \"/System/Library/PrivateFrameworks/NetAuth.framework/Versions/A/NetAuth\",\n    \"/System/Library/PrivateFrameworks/login.framework/Versions/A/Frameworks/loginsupport.framework/Versions/A/loginsupport\",\n    \"/System/Library/PrivateFrameworks/TCC.framework/Versions/A/TCC\",\n    \"/System/Library/PrivateFrameworks/CoreNLP.framework/Versions/A/CoreNLP\",\n    \"/System/Library/PrivateFrameworks/MetadataUtilities.framework/Versions/A/MetadataUtilities\",\n    \"/usr/lib/libmecabra.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Accelerate\",\n    \"/usr/lib/libmecab.dylib\",\n    \"/usr/lib/libgermantok.dylib\",\n    \"/usr/lib/libThaiTokenizer.dylib\",\n    \"/usr/lib/libChineseTokenizer.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vImage.framework/Versions/A/vImage\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/vecLib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libvMisc.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libvDSP.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libBLAS.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libLAPACK.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libLinearAlgebra.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libSparseBLAS.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libQuadrature.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libBNNS.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libSparse.dylib\",\n    \"/System/Library/PrivateFrameworks/LanguageModeling.framework/Versions/A/LanguageModeling\",\n    \"/System/Library/PrivateFrameworks/CoreEmoji.framework/Versions/A/CoreEmoji\",\n    \"/System/Library/PrivateFrameworks/LinguisticData.framework/Versions/A/LinguisticData\",\n    \"/System/Library/PrivateFrameworks/Lexicon.framework/Versions/A/Lexicon\",\n    \"/usr/lib/libcmph.dylib\",\n    \"/System/Library/Frameworks/OpenDirectory.framework/Versions/A/Frameworks/CFOpenDirectory.framework/Versions/A/CFOpenDirectory\",\n    \"/System/Library/Frameworks/OpenDirectory.framework/Versions/A/OpenDirectory\",\n    \"/System/Library/PrivateFrameworks/APFS.framework/Versions/A/APFS\",\n    \"/System/Library/Frameworks/SecurityFoundation.framework/Versions/A/SecurityFoundation\",\n    \"/usr/lib/libutil.dylib\",\n    \"/System/Library/PrivateFrameworks/CoreServicesStore.framework/Versions/A/CoreServicesStore\",\n    \"/System/Library/Frameworks/ServiceManagement.framework/Versions/A/ServiceManagement\",\n    \"/System/Library/PrivateFrameworks/BackgroundTaskManagement.framework/Versions/A/BackgroundTaskManagement\",\n    \"/usr/lib/libxslt.1.dylib\"\n  ]\n}"
  },
  {
    "path": "examples/simple/report.20200818.145051.85738.0.001.json",
    "content": "\n{\n  \"header\": {\n    \"reportVersion\": 2,\n    \"event\": \"Allocation failed - JavaScript heap out of memory\",\n    \"trigger\": \"FatalError\",\n    \"filename\": \"report.20200818.145051.85738.0.001.json\",\n    \"dumpEventTime\": \"2020-08-18T14:50:51Z\",\n    \"dumpEventTimeStamp\": \"1597783851531\",\n    \"processId\": 85738,\n    \"threadId\": null,\n    \"cwd\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line\",\n    \"commandLine\": [\n      \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n      \"/Users/tannerlinsley/GitHub/react-charts/examples/line/node_modules/@rescripts/cli/scripts/start.js\"\n    ],\n    \"nodejsVersion\": \"v12.16.3\",\n    \"wordSize\": 64,\n    \"arch\": \"x64\",\n    \"platform\": \"darwin\",\n    \"componentVersions\": {\n      \"node\": \"12.16.3\",\n      \"v8\": \"7.8.279.23-node.35\",\n      \"uv\": \"1.34.2\",\n      \"zlib\": \"1.2.11\",\n      \"brotli\": \"1.0.7\",\n      \"ares\": \"1.16.0\",\n      \"modules\": \"72\",\n      \"nghttp2\": \"1.40.0\",\n      \"napi\": \"5\",\n      \"llhttp\": \"2.0.4\",\n      \"http_parser\": \"2.9.3\",\n      \"openssl\": \"1.1.1g\",\n      \"cldr\": \"36.0\",\n      \"icu\": \"65.1\",\n      \"tz\": \"2019c\",\n      \"unicode\": \"12.1\"\n    },\n    \"release\": {\n      \"name\": \"node\",\n      \"lts\": \"Erbium\",\n      \"headersUrl\": \"https://nodejs.org/download/release/v12.16.3/node-v12.16.3-headers.tar.gz\",\n      \"sourceUrl\": \"https://nodejs.org/download/release/v12.16.3/node-v12.16.3.tar.gz\"\n    },\n    \"osName\": \"Darwin\",\n    \"osRelease\": \"19.3.0\",\n    \"osVersion\": \"Darwin Kernel Version 19.3.0: Thu Jan  9 20:58:23 PST 2020; root:xnu-6153.81.5~1/RELEASE_X86_64\",\n    \"osMachine\": \"x86_64\",\n    \"cpus\": [\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 36728530,\n        \"nice\": 0,\n        \"sys\": 20082940,\n        \"idle\": 187908010,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 1148600,\n        \"nice\": 0,\n        \"sys\": 1629280,\n        \"idle\": 241655230,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 32645100,\n        \"nice\": 0,\n        \"sys\": 14337860,\n        \"idle\": 197453490,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 1101260,\n        \"nice\": 0,\n        \"sys\": 1461870,\n        \"idle\": 241869860,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 26857790,\n        \"nice\": 0,\n        \"sys\": 11444640,\n        \"idle\": 206133910,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 1146170,\n        \"nice\": 0,\n        \"sys\": 1363190,\n        \"idle\": 241923510,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 20639380,\n        \"nice\": 0,\n        \"sys\": 8451100,\n        \"idle\": 215345750,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 1171940,\n        \"nice\": 0,\n        \"sys\": 1263280,\n        \"idle\": 241997530,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 18174720,\n        \"nice\": 0,\n        \"sys\": 6967840,\n        \"idle\": 219293560,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 1177590,\n        \"nice\": 0,\n        \"sys\": 1171860,\n        \"idle\": 242083180,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 13963000,\n        \"nice\": 0,\n        \"sys\": 4794140,\n        \"idle\": 225678860,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 1181120,\n        \"nice\": 0,\n        \"sys\": 1089610,\n        \"idle\": 242161760,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 11612180,\n        \"nice\": 0,\n        \"sys\": 3781280,\n        \"idle\": 229042420,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 1182250,\n        \"nice\": 0,\n        \"sys\": 1029370,\n        \"idle\": 242220750,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 9909610,\n        \"nice\": 0,\n        \"sys\": 3069100,\n        \"idle\": 231457050,\n        \"irq\": 0\n      },\n      {\n        \"model\": \"Intel(R) Core(TM) i9-9880H CPU @ 2.30GHz\",\n        \"speed\": 2300,\n        \"user\": 1185520,\n        \"nice\": 0,\n        \"sys\": 980100,\n        \"idle\": 242266630,\n        \"irq\": 0\n      }\n    ],\n    \"networkInterfaces\": [\n      {\n        \"name\": \"lo0\",\n        \"internal\": true,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"127.0.0.1\",\n        \"netmask\": \"255.0.0.0\",\n        \"family\": \"IPv4\"\n      },\n      {\n        \"name\": \"lo0\",\n        \"internal\": true,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"::1\",\n        \"netmask\": \"ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 0\n      },\n      {\n        \"name\": \"lo0\",\n        \"internal\": true,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::1\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 1\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"fe80::450:f69c:fb3e:764f\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 6\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"192.168.0.23\",\n        \"netmask\": \"255.255.255.0\",\n        \"family\": \"IPv4\"\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"2601:680:cb00:154b:8f6:51ab:3fe1:5491\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 0\n      },\n      {\n        \"name\": \"en0\",\n        \"internal\": false,\n        \"mac\": \"f8:ff:c2:46:3b:67\",\n        \"address\": \"2601:680:cb00:154b:2466:64d0:2845:c4d2\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 0\n      },\n      {\n        \"name\": \"awdl0\",\n        \"internal\": false,\n        \"mac\": \"6a:fb:94:1e:10:4a\",\n        \"address\": \"fe80::68fb:94ff:fe1e:104a\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 13\n      },\n      {\n        \"name\": \"llw0\",\n        \"internal\": false,\n        \"mac\": \"6a:fb:94:1e:10:4a\",\n        \"address\": \"fe80::68fb:94ff:fe1e:104a\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 14\n      },\n      {\n        \"name\": \"en5\",\n        \"internal\": false,\n        \"mac\": \"ac:de:48:00:11:22\",\n        \"address\": \"fe80::aede:48ff:fe00:1122\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 5\n      },\n      {\n        \"name\": \"utun0\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::794b:ae5f:df5d:69fa\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 15\n      },\n      {\n        \"name\": \"utun1\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::c79f:2354:a0c3:6a8f\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 16\n      },\n      {\n        \"name\": \"utun2\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::817c:40d9:be3c:a26e\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 17\n      },\n      {\n        \"name\": \"utun3\",\n        \"internal\": false,\n        \"mac\": \"00:00:00:00:00:00\",\n        \"address\": \"fe80::a422:8846:d52e:f292\",\n        \"netmask\": \"ffff:ffff:ffff:ffff::\",\n        \"family\": \"IPv6\",\n        \"scopeid\": 18\n      }\n    ],\n    \"host\": \"Tanner-Linsleys-Macbook-Pro.local\"\n  },\n  \"javascriptStack\": {\n    \"message\": \"No stack.\",\n    \"stack\": [\n      \"Unavailable.\"\n    ]\n  },\n  \"nativeStack\": [\n    {\n      \"pc\": \"0x0000000100164e03\",\n      \"symbol\": \"report::TriggerNodeReport(v8::Isolate*, node::Environment*, char const*, char const*, std::__1::basic_string<char, std::__1::char_traits<char>, std::__1::allocator<char> > const&, v8::Local<v8::String>) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010008645a\",\n      \"symbol\": \"node::OnFatalError(char const*, char const*) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100187c07\",\n      \"symbol\": \"v8::Utils::ReportOOMFailure(v8::internal::Isolate*, char const*, bool) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100187ba7\",\n      \"symbol\": \"v8::internal::V8::FatalProcessOutOfMemory(v8::internal::Isolate*, char const*, bool) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100315955\",\n      \"symbol\": \"v8::internal::Heap::FatalProcessOutOfMemory(char const*) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x00000001003171ca\",\n      \"symbol\": \"v8::internal::Heap::RecomputeLimits(v8::internal::GarbageCollector) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x0000000100313bfc\",\n      \"symbol\": \"v8::internal::Heap::PerformGarbageCollection(v8::internal::GarbageCollector, v8::GCCallbackFlags) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x00000001003119fe\",\n      \"symbol\": \"v8::internal::Heap::CollectGarbage(v8::internal::AllocationSpace, v8::internal::GarbageCollectionReason, v8::GCCallbackFlags) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010031d8ca\",\n      \"symbol\": \"v8::internal::Heap::AllocateRawWithLightRetry(int, v8::internal::AllocationType, v8::internal::AllocationOrigin, v8::internal::AllocationAlignment) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010031d951\",\n      \"symbol\": \"v8::internal::Heap::AllocateRawWithRetryOrFail(int, v8::internal::AllocationType, v8::internal::AllocationOrigin, v8::internal::AllocationAlignment) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x00000001002eb58a\",\n      \"symbol\": \"v8::internal::Factory::NewFillerObject(int, bool, v8::internal::AllocationType, v8::internal::AllocationOrigin) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010063e698\",\n      \"symbol\": \"v8::internal::Runtime_AllocateInYoungGeneration(int, unsigned long*, v8::internal::Isolate*) [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    },\n    {\n      \"pc\": \"0x000000010097cc39\",\n      \"symbol\": \"Builtins_CEntry_Return1_DontSaveFPRegs_ArgvOnStack_NoBuiltinExit [/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node]\"\n    }\n  ],\n  \"javascriptHeap\": {\n    \"totalMemory\": 2179026944,\n    \"totalCommittedMemory\": 2168716192,\n    \"usedMemory\": 2112416872,\n    \"availableMemory\": 47076520,\n    \"memoryLimit\": 2197815296,\n    \"heapSpaces\": {\n      \"read_only_space\": {\n        \"memorySize\": 262144,\n        \"committedMemory\": 33088,\n        \"capacity\": 32808,\n        \"used\": 32808,\n        \"available\": 0\n      },\n      \"new_space\": {\n        \"memorySize\": 33554432,\n        \"committedMemory\": 23863920,\n        \"capacity\": 16759296,\n        \"used\": 5257144,\n        \"available\": 11502152\n      },\n      \"old_space\": {\n        \"memorySize\": 2057707520,\n        \"committedMemory\": 2057646344,\n        \"capacity\": 2021424504,\n        \"used\": 2021397784,\n        \"available\": 26720\n      },\n      \"code_space\": {\n        \"memorySize\": 2527232,\n        \"committedMemory\": 2197664,\n        \"capacity\": 1975712,\n        \"used\": 1975712,\n        \"available\": 0\n      },\n      \"map_space\": {\n        \"memorySize\": 4198400,\n        \"committedMemory\": 4197960,\n        \"capacity\": 3196400,\n        \"used\": 3196400,\n        \"available\": 0\n      },\n      \"large_object_space\": {\n        \"memorySize\": 80154624,\n        \"committedMemory\": 80154624,\n        \"capacity\": 80012480,\n        \"used\": 80012480,\n        \"available\": 0\n      },\n      \"code_large_object_space\": {\n        \"memorySize\": 622592,\n        \"committedMemory\": 622592,\n        \"capacity\": 544544,\n        \"used\": 544544,\n        \"available\": 0\n      },\n      \"new_large_object_space\": {\n        \"memorySize\": 0,\n        \"committedMemory\": 0,\n        \"capacity\": 16759296,\n        \"used\": 0,\n        \"available\": 16759296\n      }\n    }\n  },\n  \"resourceUsage\": {\n    \"userCpuSeconds\": 1755.06,\n    \"kernelCpuSeconds\": 144.618,\n    \"cpuConsumptionPercent\": 4.35027,\n    \"maxRss\": 2877472899072,\n    \"pageFaults\": {\n      \"IORequired\": 79,\n      \"IONotRequired\": 22001062\n    },\n    \"fsActivity\": {\n      \"reads\": 0,\n      \"writes\": 0\n    }\n  },\n  \"libuv\": [\n  ],\n  \"workers\": [\n  ],\n  \"environmentVariables\": {\n    \"npm_package_dependencies_react_charts\": \"next\",\n    \"TERM_PROGRAM\": \"Hyper\",\n    \"NODE\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n    \"npm_config_version_git_tag\": \"true\",\n    \"NVM_CD_FLAGS\": \"-q\",\n    \"INIT_CWD\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line\",\n    \"TERM\": \"xterm-256color\",\n    \"SHELL\": \"/bin/zsh\",\n    \"TMPDIR\": \"/var/folders/wg/wzqxvxfn61sb5cxpkp9j5pg80000gn/T/\",\n    \"npm_config_email\": \"tannerlinsley@gmail.com\",\n    \"npm_config_init_license\": \"MIT\",\n    \"TERM_PROGRAM_VERSION\": \"3.0.2\",\n    \"npm_config_registry\": \"https://registry.yarnpkg.com\",\n    \"npm_package_private\": \"true\",\n    \"npm_package_dependencies_react_dom\": \"^16.13.1\",\n    \"ZSH\": \"/Users/tannerlinsley/.oh-my-zsh\",\n    \"npm_package_readmeFilename\": \"README.md\",\n    \"npm_package_description\": \"To run this example:\",\n    \"NVM_DIR\": \"/Users/tannerlinsley/.nvm\",\n    \"USER\": \"tannerlinsley\",\n    \"npm_package_browserslist_development_1\": \"last 1 firefox version\",\n    \"npm_package_browserslist_development_0\": \"last 1 chrome version\",\n    \"SSH_AUTH_SOCK\": \"/private/tmp/com.apple.launchd.y1vHD7roLs/Listeners\",\n    \"npm_package_dependencies_styled_components\": \"^5.1.1\",\n    \"npm_package_browserslist_development_2\": \"last 1 safari version\",\n    \"__CF_USER_TEXT_ENCODING\": \"0x1F5:0x0:0x0\",\n    \"npm_execpath\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/lib/node_modules/yarn/bin/yarn.js\",\n    \"PAGER\": \"less\",\n    \"LSCOLORS\": \"Gxfxcxdxbxegedabagacad\",\n    \"npm_config_argv\": \"{\\\"remain\\\":[],\\\"cooked\\\":[\\\"run\\\",\\\"start\\\"],\\\"original\\\":[\\\"start\\\"]}\",\n    \"PATH\": \"/var/folders/wg/wzqxvxfn61sb5cxpkp9j5pg80000gn/T/yarn--1597697626544-0.40823564503316456:/Users/tannerlinsley/GitHub/react-charts/examples/line/node_modules/.bin:/Users/tannerlinsley/.config/yarn/link/node_modules/.bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/libexec/lib/node_modules/npm/bin/node-gyp-bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/lib/node_modules/npm/bin/node-gyp-bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node_modules/npm/bin/node-gyp-bin:/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/Applications/Postgres.app/Contents/Versions/latest/bin:/Applications/Visual Studio Code.app/Contents/Resources/app/bin\",\n    \"npm_package_devDependencies__rescripts_cli\": \"^0.0.14\",\n    \"_\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line/node_modules/.bin/rescripts\",\n    \"npm_package_browserslist_production_1\": \"not dead\",\n    \"npm_package_browserslist_production_0\": \">0.2%\",\n    \"PWD\": \"/Users/tannerlinsley/GitHub/react-charts/examples/line\",\n    \"npm_package_browserslist_production_2\": \"not op_mini all\",\n    \"npm_lifecycle_event\": \"start\",\n    \"EDITOR\": \"code\",\n    \"npm_package_name\": \"\",\n    \"LANG\": \"en_US.UTF-8\",\n    \"npm_config_version_commit_hooks\": \"true\",\n    \"npm_package_scripts_start\": \"rescripts start\",\n    \"npm_package_scripts_build\": \"rescripts build\",\n    \"npm_config_username\": \"tannerlinsley\",\n    \"XPC_FLAGS\": \"0x0\",\n    \"npm_config_bin_links\": \"true\",\n    \"npm_package_dependencies__react_hook_window_size\": \"3.0.7\",\n    \"npm_package_devDependencies__rescripts_rescript_use_eslint_config\": \"^0.0.11\",\n    \"npm_package_version\": \"\",\n    \"XPC_SERVICE_NAME\": \"0\",\n    \"npm_package_devDependencies__rescripts_rescript_use_babel_config\": \"^0.0.10\",\n    \"SHLVL\": \"2\",\n    \"HOME\": \"/Users/tannerlinsley\",\n    \"npm_package_scripts_test\": \"rescripts test\",\n    \"npm_config_strict_ssl\": \"true\",\n    \"npm_config_save_prefix\": \"^\",\n    \"npm_config_version_git_message\": \"v%s\",\n    \"npm_package_devDependencies_babel_eslint\": \"10.1.0\",\n    \"npm_package_dependencies_react_scripts\": \"3.4.3\",\n    \"YARN_WRAP_OUTPUT\": \"false\",\n    \"LESS\": \"-R\",\n    \"LOGNAME\": \"tannerlinsley\",\n    \"npm_lifecycle_script\": \"rescripts start\",\n    \"npm_package_dependencies_react\": \"^16.13.1\",\n    \"NVM_BIN\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin\",\n    \"npm_config_user_agent\": \"yarn/1.22.4 npm/? node/v12.16.3 darwin x64\",\n    \"npm_config_ignore_scripts\": \"\",\n    \"npm_config_version_git_sign\": \"\",\n    \"npm_package_dependencies_react_resizable\": \"^1.10.1\",\n    \"npm_config_ignore_optional\": \"\",\n    \"npm_config_init_version\": \"1.0.0\",\n    \"npm_config_init_author_name\": \"Tanner Linsley\",\n    \"npm_package_scripts_eject\": \"rescripts eject\",\n    \"npm_config_version_tag_prefix\": \"v\",\n    \"npm_node_execpath\": \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n    \"COLORTERM\": \"truecolor\",\n    \"BABEL_ENV\": \"development\",\n    \"NODE_ENV\": \"development\",\n    \"SKIP_PREFLIGHT_CHECK\": \"true\",\n    \"NODE_PATH\": \"\",\n    \"WEBPACK_DEV_SERVER\": \"true\"\n  },\n  \"userLimits\": {\n    \"core_file_size_blocks\": {\n      \"soft\": 0,\n      \"hard\": \"unlimited\"\n    },\n    \"data_seg_size_kbytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"file_size_blocks\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"max_locked_memory_bytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"max_memory_size_kbytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"open_files\": {\n      \"soft\": 49152,\n      \"hard\": \"unlimited\"\n    },\n    \"stack_size_bytes\": {\n      \"soft\": 8388608,\n      \"hard\": 67104768\n    },\n    \"cpu_time_seconds\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    },\n    \"max_user_processes\": {\n      \"soft\": 5568,\n      \"hard\": 8352\n    },\n    \"virtual_memory_kbytes\": {\n      \"soft\": \"unlimited\",\n      \"hard\": \"unlimited\"\n    }\n  },\n  \"sharedObjects\": [\n    \"/Users/tannerlinsley/.nvm/versions/node/v12.16.3/bin/node\",\n    \"/System/Library/Frameworks/CoreFoundation.framework/Versions/A/CoreFoundation\",\n    \"/usr/lib/libSystem.B.dylib\",\n    \"/usr/lib/libc++.1.dylib\",\n    \"/usr/lib/libobjc.A.dylib\",\n    \"/usr/lib/libfakelink.dylib\",\n    \"/usr/lib/libDiagnosticMessagesClient.dylib\",\n    \"/usr/lib/libicucore.A.dylib\",\n    \"/usr/lib/libz.1.dylib\",\n    \"/usr/lib/libc++abi.dylib\",\n    \"/usr/lib/system/libcache.dylib\",\n    \"/usr/lib/system/libcommonCrypto.dylib\",\n    \"/usr/lib/system/libcompiler_rt.dylib\",\n    \"/usr/lib/system/libcopyfile.dylib\",\n    \"/usr/lib/system/libcorecrypto.dylib\",\n    \"/usr/lib/system/libdispatch.dylib\",\n    \"/usr/lib/system/libdyld.dylib\",\n    \"/usr/lib/system/libkeymgr.dylib\",\n    \"/usr/lib/system/liblaunch.dylib\",\n    \"/usr/lib/system/libmacho.dylib\",\n    \"/usr/lib/system/libquarantine.dylib\",\n    \"/usr/lib/system/libremovefile.dylib\",\n    \"/usr/lib/system/libsystem_asl.dylib\",\n    \"/usr/lib/system/libsystem_blocks.dylib\",\n    \"/usr/lib/system/libsystem_c.dylib\",\n    \"/usr/lib/system/libsystem_configuration.dylib\",\n    \"/usr/lib/system/libsystem_coreservices.dylib\",\n    \"/usr/lib/system/libsystem_darwin.dylib\",\n    \"/usr/lib/system/libsystem_dnssd.dylib\",\n    \"/usr/lib/system/libsystem_featureflags.dylib\",\n    \"/usr/lib/system/libsystem_info.dylib\",\n    \"/usr/lib/system/libsystem_m.dylib\",\n    \"/usr/lib/system/libsystem_malloc.dylib\",\n    \"/usr/lib/system/libsystem_networkextension.dylib\",\n    \"/usr/lib/system/libsystem_notify.dylib\",\n    \"/usr/lib/system/libsystem_sandbox.dylib\",\n    \"/usr/lib/system/libsystem_secinit.dylib\",\n    \"/usr/lib/system/libsystem_kernel.dylib\",\n    \"/usr/lib/system/libsystem_platform.dylib\",\n    \"/usr/lib/system/libsystem_pthread.dylib\",\n    \"/usr/lib/system/libsystem_symptoms.dylib\",\n    \"/usr/lib/system/libsystem_trace.dylib\",\n    \"/usr/lib/system/libunwind.dylib\",\n    \"/usr/lib/system/libxpc.dylib\",\n    \"/Users/tannerlinsley/GitHub/react-charts/examples/line/node_modules/fsevents/build/Release/fse.node\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/CoreServices\",\n    \"/System/Library/Frameworks/CFNetwork.framework/Versions/A/CFNetwork\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/FSEvents.framework/Versions/A/FSEvents\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/CarbonCore.framework/Versions/A/CarbonCore\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/Metadata.framework/Versions/A/Metadata\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/OSServices.framework/Versions/A/OSServices\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/SearchKit.framework/Versions/A/SearchKit\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/AE.framework/Versions/A/AE\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/LaunchServices.framework/Versions/A/LaunchServices\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/DictionaryServices.framework/Versions/A/DictionaryServices\",\n    \"/System/Library/Frameworks/CoreServices.framework/Versions/A/Frameworks/SharedFileList.framework/Versions/A/SharedFileList\",\n    \"/System/Library/Frameworks/Foundation.framework/Versions/C/Foundation\",\n    \"/System/Library/Frameworks/IOKit.framework/Versions/A/IOKit\",\n    \"/System/Library/Frameworks/SystemConfiguration.framework/Versions/A/SystemConfiguration\",\n    \"/System/Library/Frameworks/Security.framework/Versions/A/Security\",\n    \"/usr/lib/libsqlite3.dylib\",\n    \"/usr/lib/libxml2.2.dylib\",\n    \"/usr/lib/libnetwork.dylib\",\n    \"/usr/lib/libapple_nghttp2.dylib\",\n    \"/usr/lib/libauto.dylib\",\n    \"/usr/lib/libcompression.dylib\",\n    \"/System/Library/Frameworks/DiskArbitration.framework/Versions/A/DiskArbitration\",\n    \"/usr/lib/libarchive.2.dylib\",\n    \"/usr/lib/liblangid.dylib\",\n    \"/usr/lib/libCRFSuite.dylib\",\n    \"/usr/lib/liblzma.5.dylib\",\n    \"/usr/lib/libenergytrace.dylib\",\n    \"/usr/lib/libbsm.0.dylib\",\n    \"/usr/lib/system/libkxld.dylib\",\n    \"/System/Library/PrivateFrameworks/AppleFSCompression.framework/Versions/A/AppleFSCompression\",\n    \"/usr/lib/libcoretls.dylib\",\n    \"/usr/lib/libcoretls_cfhelpers.dylib\",\n    \"/usr/lib/libpam.2.dylib\",\n    \"/usr/lib/libxar.1.dylib\",\n    \"/usr/lib/libbz2.1.0.dylib\",\n    \"/usr/lib/libiconv.2.dylib\",\n    \"/usr/lib/libcharset.1.dylib\",\n    \"/usr/lib/libpcap.A.dylib\",\n    \"/System/Library/Frameworks/NetFS.framework/Versions/A/NetFS\",\n    \"/System/Library/PrivateFrameworks/NetAuth.framework/Versions/A/NetAuth\",\n    \"/System/Library/PrivateFrameworks/login.framework/Versions/A/Frameworks/loginsupport.framework/Versions/A/loginsupport\",\n    \"/System/Library/PrivateFrameworks/TCC.framework/Versions/A/TCC\",\n    \"/System/Library/PrivateFrameworks/CoreNLP.framework/Versions/A/CoreNLP\",\n    \"/System/Library/PrivateFrameworks/MetadataUtilities.framework/Versions/A/MetadataUtilities\",\n    \"/usr/lib/libmecabra.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Accelerate\",\n    \"/usr/lib/libmecab.dylib\",\n    \"/usr/lib/libgermantok.dylib\",\n    \"/usr/lib/libThaiTokenizer.dylib\",\n    \"/usr/lib/libChineseTokenizer.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vImage.framework/Versions/A/vImage\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/vecLib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libvMisc.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libvDSP.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libBLAS.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libLAPACK.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libLinearAlgebra.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libSparseBLAS.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libQuadrature.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libBNNS.dylib\",\n    \"/System/Library/Frameworks/Accelerate.framework/Versions/A/Frameworks/vecLib.framework/Versions/A/libSparse.dylib\",\n    \"/System/Library/PrivateFrameworks/LanguageModeling.framework/Versions/A/LanguageModeling\",\n    \"/System/Library/PrivateFrameworks/CoreEmoji.framework/Versions/A/CoreEmoji\",\n    \"/System/Library/PrivateFrameworks/LinguisticData.framework/Versions/A/LinguisticData\",\n    \"/System/Library/PrivateFrameworks/Lexicon.framework/Versions/A/Lexicon\",\n    \"/usr/lib/libcmph.dylib\",\n    \"/System/Library/Frameworks/OpenDirectory.framework/Versions/A/Frameworks/CFOpenDirectory.framework/Versions/A/CFOpenDirectory\",\n    \"/System/Library/Frameworks/OpenDirectory.framework/Versions/A/OpenDirectory\",\n    \"/System/Library/PrivateFrameworks/APFS.framework/Versions/A/APFS\",\n    \"/System/Library/Frameworks/SecurityFoundation.framework/Versions/A/SecurityFoundation\",\n    \"/usr/lib/libutil.dylib\",\n    \"/System/Library/PrivateFrameworks/CoreServicesStore.framework/Versions/A/CoreServicesStore\",\n    \"/System/Library/Frameworks/ServiceManagement.framework/Versions/A/ServiceManagement\",\n    \"/System/Library/PrivateFrameworks/BackgroundTaskManagement.framework/Versions/A/BackgroundTaskManagement\",\n    \"/usr/lib/libxslt.1.dylib\",\n    \"/Users/tannerlinsley/GitHub/react-charts/examples/line/node_modules/watchpack/node_modules/fsevents/fsevents.node\"\n  ]\n}"
  },
  {
    "path": "examples/simple/src/ResizableBox.js",
    "content": "import React from \"react\";\nimport { ResizableBox as ReactResizableBox } from \"react-resizable\";\n\nimport \"react-resizable/css/styles.css\";\n\nexport default function ResizableBox({\n  children,\n  width = 600,\n  height = 300,\n  resizable = true,\n  style = {},\n  className = \"\",\n}) {\n  return (\n    <div style={{ marginLeft: 20 }}>\n      <div\n        style={{\n          display: \"inline-block\",\n          width: \"auto\",\n          background: \"white\",\n          padding: \".5rem\",\n          borderRadius: \"0.5rem\",\n          boxShadow: \"0 30px 40px rgba(0,0,0,.1)\",\n          ...style,\n        }}\n      >\n        {resizable ? (\n          <ReactResizableBox width={width} height={height}>\n            <div\n              style={{\n                width: \"100%\",\n                height: \"100%\",\n              }}\n              className={className}\n            >\n              {children}\n            </div>\n          </ReactResizableBox>\n        ) : (\n          <div\n            style={{\n              width: `${width}px`,\n              height: `${height}px`,\n            }}\n            className={className}\n          >\n            {children}\n          </div>\n        )}\n      </div>\n    </div>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/Area.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function Bar() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 10,\n    dataType: \"time\",\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary as Date,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n        stacked: true,\n        // OR\n        // elementType: \"area\",\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/Band.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport { stackOffsetWiggle } from \"d3-shape\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function Band() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 10,\n    dataType: \"ordinal\",\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      position: \"left\",\n      getValue: (datum) => datum.primary,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        position: \"top\",\n        show: false,\n        getValue: (datum) => datum.secondary,\n        stackOffset: stackOffsetWiggle,\n        stacked: true,\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/Bar.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function Bar() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 3,\n    dataType: \"ordinal\",\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/BarHorizontal.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function Bar() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 3,\n    dataType: \"ordinal\",\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      position: \"left\",\n      getValue: (datum) => datum.primary,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        position: \"bottom\",\n        getValue: (datum) => datum.secondary,\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/BarHorizontalStacked.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function BarHorizontalStacked() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 10,\n    dataType: \"ordinal\",\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      position: \"left\",\n      getValue: (datum) => datum.primary,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        position: \"bottom\",\n        getValue: (datum) => datum.secondary,\n        stacked: true,\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/BarStacked.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function BarStacked() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 10,\n    dataType: \"ordinal\",\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n        stacked: true,\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/Bubble.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function Bubble() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 10,\n    dataType: \"linear\",\n    useR: true,\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary as unknown as Date,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n        elementType: \"bubble\",\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n            interactionMode: \"closest\",\n            getDatumStyle: (datum) =>\n              ({\n                circle: { r: datum.originalDatum.radius },\n              } as any),\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/CustomStyles.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function CustomStyles() {\n  const [{ activeSeriesIndex, activeDatumIndex }, setState] = React.useState({\n    activeSeriesIndex: -1,\n    activeDatumIndex: -1,\n  });\n\n  return (\n    <div>\n      {JSON.stringify({ activeSeriesIndex, activeDatumIndex }, null, 2)}\n      <MyChart\n        elementType=\"line\"\n        setState={setState}\n        activeDatumIndex={activeDatumIndex}\n        activeSeriesIndex={activeSeriesIndex}\n      />\n      <MyChart\n        elementType=\"area\"\n        setState={setState}\n        activeDatumIndex={activeDatumIndex}\n        activeSeriesIndex={activeSeriesIndex}\n      />\n      <MyChart\n        elementType=\"bar\"\n        setState={setState}\n        activeDatumIndex={activeDatumIndex}\n        activeSeriesIndex={activeSeriesIndex}\n      />\n    </div>\n  );\n}\n\nfunction MyChart({\n  elementType,\n  activeDatumIndex,\n  activeSeriesIndex,\n  setState,\n}: any) {\n  const { data, interactionMode, randomizeData } = useDemoConfig({\n    series: 4,\n    interactionMode: \"primary\",\n    dataType: \"ordinal\",\n    show: [\"elementType\", \"interactionMode\"],\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n        elementType,\n      },\n    ],\n    [elementType]\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            interactionMode,\n            primaryAxis,\n            secondaryAxes,\n            getDatumStyle: (datum, status) =>\n              (activeDatumIndex === datum.index &&\n              activeSeriesIndex === datum.seriesIndex\n                ? {\n                    opacity: 1,\n                    circle: {\n                      r: 5,\n                    },\n                    rectangle: {\n                      stroke: \"black\",\n                      strokeWidth: 3,\n                    },\n                  }\n                : activeDatumIndex === datum.index\n                ? {\n                    opacity: 1,\n                    circle: {\n                      r: 3,\n                    },\n                    rectangle: {\n                      stroke: \"black\",\n                      strokeWidth: 1,\n                    },\n                  }\n                : datum.seriesIndex === activeSeriesIndex\n                ? {\n                    circle: {\n                      r: 3,\n                    },\n                    rectangle: {\n                      stroke: \"black\",\n                      strokeWidth: 1,\n                    },\n                  }\n                : status === \"groupFocused\"\n                ? {\n                    circle: {\n                      r: 2,\n                    },\n                    rectangle: {\n                      stroke: \"black\",\n                      strokeWidth: 0,\n                    },\n                  }\n                : {\n                    circle: {\n                      r: 2,\n                    },\n                    rectangle: {\n                      stroke: \"black\",\n                      strokeWidth: 0,\n                    },\n                  }) as any,\n            getSeriesStyle: (series) => {\n              return {\n                color: `url(#${series.index % 4})`,\n                opacity:\n                  activeSeriesIndex > -1\n                    ? series.index === activeSeriesIndex\n                      ? 1\n                      : 0.3\n                    : 1,\n              };\n            },\n            onFocusDatum: (focused) =>\n              setState({\n                activeSeriesIndex: focused ? focused.seriesIndex : -1,\n                activeDatumIndex: focused ? focused.index : -1,\n              }),\n\n            renderSVG: () => (\n              <defs>\n                <linearGradient id=\"0\" x1=\"0\" x2=\"0\" y1=\"1\" y2=\"0\">\n                  <stop offset=\"0%\" stopColor=\"#17EAD9\" />\n                  <stop offset=\"100%\" stopColor=\"#6078EA\" />\n                </linearGradient>\n                <linearGradient id=\"1\" x1=\"0\" x2=\"0\" y1=\"1\" y2=\"0\">\n                  <stop offset=\"0%\" stopColor=\"#ff8f10\" />\n                  <stop offset=\"100%\" stopColor=\"#ff3434\" />\n                </linearGradient>\n                <linearGradient id=\"2\" x1=\"0\" x2=\"0\" y1=\"1\" y2=\"0\">\n                  <stop offset=\"0%\" stopColor=\"#42E695\" />\n                  <stop offset=\"100%\" stopColor=\"#3BB2B8\" />\n                </linearGradient>\n                <linearGradient id=\"3\" x1=\"0\" x2=\"0\" y1=\"1\" y2=\"0\">\n                  <stop offset=\"0%\" stopColor=\"#ffb302\" />\n                  <stop offset=\"100%\" stopColor=\"#ead700\" />\n                </linearGradient>\n              </defs>\n            ),\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/DarkMode.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function DarkMode() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 10,\n    dataType: \"time\",\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary as unknown as Date,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox\n        style={{\n          background: \"rgba(0, 27, 45, 0.9)\",\n          padding: \".5rem\",\n          borderRadius: \"5px\",\n        }}\n      >\n        <div style={{ width: \"100%\", height: \"100%\" }}>\n          <Chart\n            options={{\n              data,\n              primaryAxis,\n              secondaryAxes,\n\n              dark: true,\n            }}\n          />\n        </div>\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/DynamicContainer.tsx",
    "content": "import useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function DyanmicContainer() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 10,\n    dataType: \"time\",\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary as unknown as Date,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <p>\n        This example demos a chart's ability to position itself responsively in\n        elements while respecting the box-model (margin, padding, and borders).\n        It also showcases the tooltip's ability to portal outside of an overflow\n        element (the blue border-box).\n      </p>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <div\n        style={{\n          display: \"flex\",\n          flexDirection: \"column\",\n          padding: \"12px\",\n          border: \"2px solid black\",\n          height: \"400px\",\n        }}\n      >\n        <div\n          style={{\n            flex: \"0 0 auto\",\n            padding: \"10px\",\n            border: \"1px solid red\",\n          }}\n        >\n          Header\n        </div>\n        <div\n          style={{\n            flex: 2,\n            border: \"5px solid blue\",\n            maxHeight: \"400px\",\n            margin: \"10px\",\n            overflow: \"hidden\",\n          }}\n        >\n          <Chart\n            options={{\n              data,\n              primaryAxis,\n              secondaryAxes,\n            }}\n          />\n        </div>\n      </div>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/InteractionMode.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\nimport Tree from \"react-json-tree\";\n\nexport default function GroupingModes() {\n  const [{ clicked, focused }, setState] = React.useState({\n    clicked: null,\n    focused: null,\n  });\n\n  const { data, interactionMode, elementType, randomizeData, Options } =\n    useDemoConfig({\n      series: 10,\n      show: [\"elementType\", \"interactionMode\"],\n    });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary as Date,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n        elementType,\n      },\n    ],\n    [elementType]\n  );\n\n  return (\n    <>\n      {Options}\n      <br />\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <em>Voronoi is shown for demonstration purposes</em>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            interactionMode,\n            primaryAxis,\n            secondaryAxes,\n            showVoronoi: true,\n            onClickDatum: (datum) => {\n              if (datum) setState((old) => ({ ...old, clicked: datum as any }));\n            },\n            onFocusDatum: (datum) => {\n              if (datum) setState((old) => ({ ...old, focused: datum as any }));\n            },\n          }}\n        />\n      </ResizableBox>\n      <br />\n      <div>Focused Datum:</div>\n      <Tree hideRoot data={focused} />\n      <div>Clicked Datum:</div>\n      <Tree hideRoot data={clicked} />\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/Line.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function Line() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 10,\n    dataType: \"time\",\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary as unknown as Date,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/MultipleAxes.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function MultipleAxes() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 6,\n    dataType: \"time\",\n  });\n\n  // @ts-ignore\n  data.forEach((d, i) => (d.secondaryAxisId = i > 2 ? \"2\" : undefined));\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary as unknown as Date,\n      // Pad the automatically detected time scale with half of the band-size\n      padBandRange: true,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n        elementType: \"bar\",\n        // stacked: true,\n      },\n      {\n        id: \"2\",\n        getValue: (datum) => datum.secondary,\n        elementType: \"line\",\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/SparkChart.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function Line() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 5,\n    dataType: \"time\",\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary as unknown as Date,\n      show: false,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n        show: false,\n        showDatumElements: false,\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox width={200} height={40}>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/Steam.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport { stackOffsetWiggle } from \"d3-shape\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function Steam() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 10,\n    dataType: \"time\",\n  });\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary as Date,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n        elementType: \"area\",\n        // or\n        // stacked: true,\n        stackOffset: stackOffsetWiggle,\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <ResizableBox>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n\n            getSeriesStyle: () => ({\n              line: { opacity: 0 },\n              area: { opacity: 1 },\n            }),\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/StressTest.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function StressTest() {\n  const [\n    {\n      chartCount,\n      seriesCount,\n      datumCount,\n      activeSeriesIndex,\n      liveData,\n      liveDataInterval,\n      showPoints,\n      memoizeSeries,\n      height,\n      showAxes,\n    },\n    setState,\n  ] = React.useState({\n    activeSeriesIndex: -1,\n    chartCount: 10,\n    seriesCount: 10,\n    datumCount: 20,\n    liveData: false,\n    liveDataInterval: 1000,\n    showPoints: true,\n    memoizeSeries: false,\n    height: 100,\n    showAxes: true,\n  });\n\n  const { data, randomizeData } = useDemoConfig({\n    series: seriesCount,\n    datums: datumCount,\n    dataType: \"time\",\n  });\n\n  const [primaryCursorValue, setPrimaryCursorValue] = React.useState();\n  const [secondaryCursorValue, setSecondaryCursorValue] = React.useState();\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary as unknown as Date,\n      show: showAxes,\n    }),\n    [showAxes]\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n        showDatumElements: showPoints,\n        show: showAxes,\n      },\n    ],\n    [showAxes, showPoints]\n  );\n\n  React.useEffect(() => {\n    let interval: ReturnType<typeof setTimeout>;\n\n    if (liveData) {\n      interval = setInterval(() => {\n        randomizeData();\n      }, liveDataInterval);\n    }\n\n    return () => {\n      clearInterval(interval);\n    };\n  }, [liveData, liveDataInterval, randomizeData]);\n\n  return (\n    <>\n      <h3>\n        {chartCount} Charts * 10 Series * 20 Datums (\n        {chartCount * seriesCount * datumCount} data elements) w/ Synced Cursors\n        & Series Highlighting\n      </h3>\n      <br />\n\n      <p>\n        NOTE: This example is best viewed in production for maximum performance.\n      </p>\n\n      <br />\n      <br />\n      <label>\n        Chart Count:{\" \"}\n        <input\n          type=\"number\"\n          min=\"1\"\n          value={chartCount}\n          onChange={(e) => {\n            e.persist();\n            setState((old) => ({\n              ...old,\n              chartCount: parseInt(e.target.value),\n            }));\n          }}\n        />\n      </label>\n      <br />\n      <label>\n        Series Count:{\" \"}\n        <input\n          type=\"number\"\n          min=\"1\"\n          value={seriesCount}\n          onChange={(e) => {\n            e.persist();\n            setState((old) => ({\n              ...old,\n              seriesCount: parseInt(e.target.value),\n            }));\n          }}\n        />\n      </label>\n      <br />\n      <label>\n        DatumCount Count:{\" \"}\n        <input\n          type=\"number\"\n          min=\"1\"\n          value={datumCount}\n          onChange={(e) => {\n            e.persist();\n            setState((old) => ({\n              ...old,\n              datumCount: parseInt(e.target.value),\n            }));\n          }}\n        />\n      </label>\n      <br />\n      <label>\n        Show Points:{\" \"}\n        <input\n          type=\"checkbox\"\n          checked={showPoints}\n          onChange={(e) => {\n            e.persist();\n            setState((old) => ({ ...old, showPoints: !!e.target.checked }));\n          }}\n        />\n      </label>\n      <label>\n        Show Axes:{\" \"}\n        <input\n          type=\"checkbox\"\n          checked={showAxes}\n          onChange={(e) => {\n            e.persist();\n            setState((old) => ({ ...old, showAxes: !!e.target.checked }));\n          }}\n        />\n      </label>\n      <br />\n      <label>\n        Memoize Series:{\" \"}\n        <input\n          type=\"checkbox\"\n          checked={memoizeSeries}\n          onChange={(e) => {\n            e.persist();\n            setState((old) => ({ ...old, memoizeSeries: !!e.target.checked }));\n          }}\n        />\n      </label>\n      <br />\n      <label>\n        Live Data:{\" \"}\n        <input\n          type=\"checkbox\"\n          checked={liveData}\n          onChange={(e) => {\n            e.persist();\n            setState((old) => ({ ...old, liveData: !!e.target.checked }));\n          }}\n        />\n      </label>\n      <br />\n      <label>\n        Live Data Update Interval:{\" \"}\n        <select\n          value={String(liveDataInterval)}\n          onChange={(e) => {\n            e.persist();\n            setState((old) => ({\n              ...old,\n              liveDataInterval: parseInt(e.target.value),\n            }));\n          }}\n        >\n          <option value=\"16\">16 ms</option>\n          <option value=\"32\">32 ms</option>\n          <option value=\"50\">50 ms</option>\n          <option value=\"100\">100 ms</option>\n          <option value=\"250\">250 ms</option>\n          <option value=\"500\">500 ms</option>\n          <option value=\"1000\">1000 ms</option>\n        </select>\n      </label>\n      <br />\n      <label>\n        Chart Height\n        <input\n          type=\"number\"\n          value={height}\n          onChange={(e) => {\n            setState((old) => ({ ...old, height: parseInt(e.target.value) }));\n          }}\n        />\n      </label>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      {[...new Array(chartCount)].map((d, i) => (\n        <ResizableBox key={i} height={height}>\n          <Chart\n            options={{\n              data,\n              primaryAxis,\n              secondaryAxes,\n              memoizeSeries,\n              getSeriesStyle: (series) => ({\n                opacity:\n                  activeSeriesIndex > -1\n                    ? series.index === activeSeriesIndex\n                      ? 1\n                      : 0.1\n                    : 1,\n              }),\n              primaryCursor: {\n                value: primaryCursorValue,\n                onChange: (value) => {\n                  setPrimaryCursorValue(value);\n                },\n              },\n              secondaryCursor: {\n                value: secondaryCursorValue,\n                onChange: (value) => {\n                  setSecondaryCursorValue(value);\n                },\n              },\n              onFocusDatum: (datum) => {\n                setState((old) => ({\n                  ...old,\n                  activeSeriesIndex: datum ? datum.seriesIndex : -1,\n                }));\n              },\n            }}\n          />\n        </ResizableBox>\n      ))}\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/components/SyncedCursors.tsx",
    "content": "import ResizableBox from \"../ResizableBox\";\nimport useDemoConfig from \"../useDemoConfig\";\nimport React from \"react\";\nimport { AxisOptions, Chart } from \"react-charts\";\n\nexport default function SyncedCursors() {\n  const { data, randomizeData } = useDemoConfig({\n    series: 10,\n    dataType: \"time\",\n  });\n\n  const [primaryCursorValue, setPrimaryCursorValue] = React.useState();\n  const [secondaryCursorValue, setSecondaryCursorValue] = React.useState();\n\n  const primaryAxis = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>\n  >(\n    () => ({\n      getValue: (datum) => datum.primary as unknown as Date,\n    }),\n    []\n  );\n\n  const secondaryAxes = React.useMemo<\n    AxisOptions<typeof data[number][\"data\"][number]>[]\n  >(\n    () => [\n      {\n        getValue: (datum) => datum.secondary,\n      },\n    ],\n    []\n  );\n\n  return (\n    <>\n      <button onClick={randomizeData}>Randomize Data</button>\n      <br />\n      <br />\n      <pre>\n        {JSON.stringify(\n          {\n            primaryCursorValue: primaryCursorValue ?? \"undefined\",\n            secondaryCursorValue: secondaryCursorValue ?? \"undefined\",\n          },\n          null,\n          2\n        )}\n      </pre>\n      <ResizableBox height={100} width={200}>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n            primaryCursor: {\n              value: primaryCursorValue,\n              onChange: (value) => {\n                setPrimaryCursorValue(value);\n              },\n            },\n            secondaryCursor: {\n              value: secondaryCursorValue,\n              onChange: (value) => {\n                setSecondaryCursorValue(value);\n              },\n            },\n          }}\n        />\n      </ResizableBox>\n      <div style={{ height: \"1rem\" }} />\n      <ResizableBox height={160} width={300}>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n            primaryCursor: {\n              value: primaryCursorValue,\n              onChange: (value) => {\n                setPrimaryCursorValue(value);\n              },\n            },\n            secondaryCursor: {\n              value: secondaryCursorValue,\n              onChange: (value) => {\n                setSecondaryCursorValue(value);\n              },\n            },\n          }}\n        />\n      </ResizableBox>\n      <div style={{ height: \"1rem\" }} />\n      <ResizableBox height={300} width={500}>\n        <Chart\n          options={{\n            data,\n            primaryAxis,\n            secondaryAxes,\n            primaryCursor: {\n              value: primaryCursorValue,\n              onChange: (value) => {\n                setPrimaryCursorValue(value);\n              },\n            },\n            secondaryCursor: {\n              value: secondaryCursorValue,\n              onChange: (value) => {\n                setSecondaryCursorValue(value);\n              },\n            },\n          }}\n        />\n      </ResizableBox>\n    </>\n  );\n}\n"
  },
  {
    "path": "examples/simple/src/index.tsx",
    "content": "import \"./styles.css\";\nimport useLagRadar from \"./useLagRadar\";\nimport React from \"react\";\nimport ReactDOM from \"react-dom\";\n\n//\n\nimport Area from \"./components/Area\";\nimport Band from \"./components/Band\";\nimport Bar from \"./components/Bar\";\nimport BarStacked from \"./components/BarStacked\";\nimport Bubble from \"./components/Bubble\";\nimport CustomStyles from \"./components/CustomStyles\";\nimport DarkMode from \"./components/DarkMode\";\nimport DynamicContainer from \"./components/DynamicContainer\";\nimport InteractionMode from \"./components/InteractionMode\";\nimport Line from \"./components/Line\";\nimport MultipleAxes from \"./components/MultipleAxes\";\nimport Steam from \"./components/Steam\";\nimport BarHorizontal from \"./components/BarHorizontal\";\nimport BarHorizontalStacked from \"./components/BarHorizontalStacked\";\nimport SparkChart from \"./components/SparkChart\";\nimport SyncedCursors from \"./components/SyncedCursors\";\nimport StressTest from \"./components/StressTest\";\n\nconst components = [\n  [\"Line\", Line],\n  [\"Bar\", Bar],\n  [\"Bar (Stacked)\", BarStacked],\n  [\"Bar (Horizontal)\", BarHorizontal],\n  [\"Bar (Horizontal + Stacked)\", BarHorizontalStacked],\n  [\"Band\", Band],\n  [\"Area\", Area],\n  [\"Bubble\", Bubble],\n  [\"Steam\", Steam],\n  [\"Spark Chart\", SparkChart],\n  [\"Multiple Axes\", MultipleAxes],\n  [\"Interaction Modes\", InteractionMode],\n  [\"Dark Mode\", DarkMode],\n  [\"Dynamic / Overflow Container\", DynamicContainer],\n  [\"Custom Styles\", CustomStyles],\n  [\"Synced Cursors\", SyncedCursors],\n  [\"Stress Test\", StressTest],\n];\n\nexport default function App() {\n  useLagRadar();\n\n  return (\n    <div>\n      {components.map(([label, Comp]) => {\n        return (\n          <div key={label + \"\"}>\n            <h1>{label}</h1>\n            <div>\n              <Comp />\n            </div>\n          </div>\n        );\n      })}\n      <div style={{ height: \"50rem\" }} />\n    </div>\n  );\n}\n\nconst rootElement = document.getElementById(\"root\");\nReactDOM.render(<App />, rootElement);\n"
  },
  {
    "path": "examples/simple/src/react-app-env.d.ts",
    "content": "/// <reference types=\"react-scripts\" />\n"
  },
  {
    "path": "examples/simple/src/styles.css",
    "content": "body {\n  background: rgba(0, 0, 0, 0.02);\n}\n\n.react-resizable {\n  max-width: 100%;\n}\n\n.react-resizable-handle {\n  bottom: -10px;\n  right: -10px;\n}\n\n.lagRadar {\n  position: fixed;\n  bottom: 0.5rem;\n  right: 0.5rem;\n}\n"
  },
  {
    "path": "examples/simple/src/useDemoConfig.tsx",
    "content": "import React from \"react\";\n\n//\n\nconst options = {\n  elementType: [\"line\", \"area\", \"bar\"],\n  primaryAxisType: [\"linear\", \"time\", \"log\", \"band\"],\n  secondaryAxisType: [\"linear\", \"time\", \"log\", \"band\"],\n  primaryAxisPosition: [\"top\", \"left\", \"right\", \"bottom\"],\n  secondaryAxisPosition: [\"top\", \"left\", \"right\", \"bottom\"],\n  secondaryAxisStack: [true, false],\n  primaryAxisShow: [true, false],\n  secondaryAxisShow: [true, false],\n  interactionMode: [\"primary\", \"closest\"],\n  tooltipGroupingMode: [\"single\", \"primary\", \"secondary\", \"series\"],\n  tooltipAnchor: [\n    \"closest\",\n    \"top\",\n    \"bottom\",\n    \"left\",\n    \"right\",\n    \"center\",\n    \"gridTop\",\n    \"gridBottom\",\n    \"gridLeft\",\n    \"gridRight\",\n    \"gridCenter\",\n    \"pointer\",\n  ],\n  tooltipAlign: [\n    \"auto\",\n    \"top\",\n    \"bottom\",\n    \"left\",\n    \"right\",\n    \"topLeft\",\n    \"topRight\",\n    \"bottomLeft\",\n    \"bottomRight\",\n    \"center\",\n  ],\n  snapCursor: [true, false],\n} as const;\n\ntype DataType = \"time\" | \"ordinal\" | \"linear\";\ntype ElementType = typeof options[\"elementType\"][number];\ntype PrimaryAxisType = typeof options[\"primaryAxisType\"][number];\ntype SecondaryAxisType = typeof options[\"secondaryAxisType\"][number];\ntype PrimaryAxisPosition = typeof options[\"primaryAxisPosition\"][number];\ntype SecondaryAxisPosition = typeof options[\"secondaryAxisPosition\"][number];\ntype TooltipAnchor = typeof options[\"tooltipAnchor\"][number];\ntype TooltipAlign = typeof options[\"tooltipAlign\"][number];\ntype InteractionMode = typeof options[\"interactionMode\"][number];\ntype TooltipGroupingMode = typeof options[\"tooltipGroupingMode\"][number];\n\nconst optionKeys = Object.keys(options) as (keyof typeof options)[];\n\nexport default function useChartConfig({\n  series,\n  datums = 10,\n  useR,\n  show = [],\n  count = 1,\n  resizable = true,\n  canRandomize = true,\n  dataType = \"time\",\n  elementType = \"line\",\n  primaryAxisType = \"time\",\n  secondaryAxisType = \"linear\",\n  primaryAxisPosition = \"bottom\",\n  secondaryAxisPosition = \"left\",\n  primaryAxisStack = false,\n  secondaryAxisStack = true,\n  primaryAxisShow = true,\n  secondaryAxisShow = true,\n  tooltipAnchor = \"closest\",\n  tooltipAlign = \"auto\",\n  interactionMode = \"primary\",\n  tooltipGroupingMode = \"primary\",\n  snapCursor = true,\n}: {\n  series: number;\n  datums?: number;\n  useR?: boolean;\n  show?: (keyof typeof options)[];\n  count?: number;\n  resizable?: boolean;\n  canRandomize?: boolean;\n  dataType?: DataType;\n  elementType?: ElementType;\n  primaryAxisType?: PrimaryAxisType;\n  secondaryAxisType?: SecondaryAxisType;\n  primaryAxisPosition?: PrimaryAxisPosition;\n  secondaryAxisPosition?: SecondaryAxisPosition;\n  primaryAxisStack?: boolean;\n  secondaryAxisStack?: boolean;\n  primaryAxisShow?: boolean;\n  secondaryAxisShow?: boolean;\n  tooltipAnchor?: TooltipAnchor;\n  tooltipAlign?: TooltipAlign;\n  interactionMode?: InteractionMode;\n  tooltipGroupingMode?: TooltipGroupingMode;\n  snapCursor?: boolean;\n}) {\n  const [state, setState] = React.useState({\n    count,\n    resizable,\n    canRandomize,\n    dataType,\n    elementType,\n    primaryAxisType,\n    secondaryAxisType,\n    primaryAxisPosition,\n    secondaryAxisPosition,\n    primaryAxisStack,\n    secondaryAxisStack,\n    primaryAxisShow,\n    secondaryAxisShow,\n    tooltipAnchor,\n    tooltipAlign,\n    interactionMode,\n    tooltipGroupingMode,\n    snapCursor,\n    datums,\n    data: makeDataFrom(dataType, series, datums, useR),\n  });\n\n  React.useEffect(() => {\n    setState((old) => ({\n      ...old,\n      data: makeDataFrom(dataType, series, datums, useR),\n    }));\n  }, [count, dataType, datums, series, useR]);\n\n  const randomizeData = () =>\n    setState((old) => ({\n      ...old,\n      data: makeDataFrom(dataType, series, datums, useR),\n    }));\n\n  const Options = optionKeys\n    .filter((option) => show.indexOf(option) > -1)\n    .map((option) => (\n      <div key={option}>\n        {option}: &nbsp;\n        <select\n          value={state[option] as string}\n          onChange={({ target: { value } }) =>\n            setState((old) => ({\n              ...old,\n              [option]:\n                typeof options[option][0] === \"boolean\"\n                  ? value === \"true\"\n                  : value,\n            }))\n          }\n        >\n          {options[option].map((d: any) => (\n            <option value={d as string} key={d.toString()}>\n              {d.toString()}\n            </option>\n          ))}\n        </select>\n        <br />\n      </div>\n    ));\n\n  return {\n    ...state,\n    randomizeData,\n    Options,\n  };\n}\n\nfunction makeDataFrom(\n  dataType: DataType,\n  series: number,\n  datums: number,\n  useR?: boolean\n) {\n  return [\n    ...new Array(series || Math.max(Math.round(Math.random() * 5), 1)),\n  ].map((d, i) => makeSeries(i, dataType, datums, useR));\n}\n\nfunction makeSeries(\n  i: number,\n  dataType: DataType,\n  datums: number,\n  useR?: boolean\n) {\n  const start = 0;\n  const startDate = new Date();\n  // startDate.setFullYear(2020);\n  startDate.setUTCHours(0);\n  startDate.setUTCMinutes(0);\n  startDate.setUTCSeconds(0);\n  startDate.setUTCMilliseconds(0);\n  // const length = 5 + Math.round(Math.random() * 15)\n  const length = datums;\n  const min = 0;\n  const max = 100;\n  const rMin = 2;\n  const rMax = 20;\n  const nullChance = 0;\n  return {\n    label: `Series ${i + 1}`,\n    data: [...new Array(length)].map((_, i) => {\n      let x;\n\n      if (dataType === \"ordinal\") {\n        x = `Ordinal Group ${start + i}`;\n      } else if (dataType === \"time\") {\n        x = new Date(startDate.getTime() + 60 * 1000 * 60 * 24 * i);\n      } else if (dataType === \"linear\") {\n        x =\n          Math.random() < nullChance\n            ? null\n            : min + Math.round(Math.random() * (max - min));\n      } else {\n        x = start + i;\n      }\n\n      const distribution = 1.1;\n\n      const y =\n        Math.random() < nullChance\n          ? null\n          : min + Math.round(Math.random() * (max - min));\n\n      const r = !useR\n        ? undefined\n        : rMax -\n          Math.floor(\n            Math.log(Math.random() * (distribution ** rMax - rMin) + rMin) /\n              Math.log(distribution)\n          );\n\n      return {\n        primary: x,\n        secondary: y,\n        radius: r,\n      };\n    }),\n  };\n}\n"
  },
  {
    "path": "examples/simple/src/useLagRadar.js",
    "content": "import React from \"react\";\n\nimport { useWindowSize } from \"@react-hook/window-size\";\n\nexport default function useLagRadar() {\n  const [width, height] = useWindowSize();\n\n  React.useEffect(() => {\n    return lagRadar({\n      frames: 60, // number of frames to draw, more = worse performance\n      speed: 0.0017, // how fast the sweep moves (rads per ms)\n      size: Math.min(width, height) / 3, // outer frame px\n      inset: 3, // circle inset px\n      parent: document.body, // DOM node to attach to\n    });\n  }, [width, height]);\n}\n\n/**\n * lagRadar\n * Licence: ISC copyright: @mobz 2018\n */\n\nfunction lagRadar(config = {}) {\n  const {\n    frames = 50, // number of frames to draw, more = worse performance\n    speed = 0.0017, // how fast the sweep moves (rads per ms)\n    size = 300, // outer frame px\n    inset = 3, // circle inset px\n    parent = document.body, // DOM node to attach to\n  } = config;\n\n  const svgns = \"http://www.w3.org/2000/svg\";\n\n  const styles = document.createTextNode(`\n    .lagRadar {\n      pointer-events: none;\n    }\n    .lagRadar-sweep > * {\n      shape-rendering: crispEdges;\n    }\n    .lagRadar-face {\n      fill: transparent;\n    }\n    .lagRadar-hand {\n      stroke-width: 4px;\n      stroke-linecap: round;\n    }\n  `);\n\n  function $svg(tag, props = {}, children = []) {\n    const el = document.createElementNS(svgns, tag);\n    Object.keys(props).forEach((prop) => el.setAttribute(prop, props[prop]));\n    children.forEach((child) => el.appendChild(child));\n    return el;\n  }\n\n  const PI2 = Math.PI * 2;\n  const middle = size / 2;\n  const radius = middle - inset;\n\n  const $hand = $svg(\"path\", { class: \"lagRadar-hand\" });\n  const $arcs = new Array(frames).fill(\"path\").map((t) => $svg(t));\n  const $root = $svg(\"svg\", { class: \"lagRadar\", height: size, width: size }, [\n    $svg(\"style\", { type: \"text/css\" }, [styles]),\n    $svg(\"g\", { class: \"lagRadar-sweep\" }, $arcs),\n    $hand,\n    $svg(\"circle\", {\n      class: \"lagRadar-face\",\n      cx: middle,\n      cy: middle,\n      r: radius,\n    }),\n  ]);\n\n  parent.appendChild($root);\n\n  let frame;\n  let framePtr = 0;\n  let last = {\n    rotation: 0,\n    now: Date.now(),\n    tx: middle + radius,\n    ty: middle,\n  };\n\n  const calcHue = (() => {\n    const max_hue = 120;\n    const max_ms = 1000;\n    const log_f = 10;\n    const mult = max_hue / Math.log(max_ms / log_f);\n    return function (ms_delta) {\n      return (\n        max_hue -\n        Math.max(0, Math.min(mult * Math.log(ms_delta / log_f), max_hue))\n      );\n    };\n  })();\n\n  function animate() {\n    const now = Date.now();\n    const rdelta = Math.min(PI2 - speed, speed * (now - last.now));\n    const rotation = (last.rotation + rdelta) % PI2;\n    const tx = middle + radius * Math.cos(rotation);\n    const ty = middle + radius * Math.sin(rotation);\n    const bigArc = rdelta < Math.PI ? \"0\" : \"1\";\n    const path = `M${tx} ${ty}A${radius} ${radius} 0 ${bigArc} 0 ${last.tx} ${last.ty}L${middle} ${middle}`;\n    const hue = calcHue(rdelta / speed);\n\n    $arcs[framePtr % frames].setAttribute(\"d\", path);\n    $arcs[framePtr % frames].setAttribute(\"fill\", `hsl(${hue}, 80%, 40%)`);\n    $hand.setAttribute(\"d\", `M${middle} ${middle}L${tx} ${ty}`);\n    $hand.setAttribute(\"stroke\", `hsl(${hue}, 80%, 60%)`);\n\n    for (let i = 0; i < frames; i++) {\n      $arcs[(frames + framePtr - i) % frames].style.fillOpacity =\n        1 - i / frames;\n    }\n\n    framePtr++;\n    last = {\n      now,\n      rotation,\n      tx,\n      ty,\n    };\n\n    frame = window.requestAnimationFrame(animate);\n  }\n\n  animate();\n\n  return function destroy() {\n    if (frame) {\n      window.cancelAnimationFrame(frame);\n    }\n    $root.remove();\n  };\n}\n"
  },
  {
    "path": "examples/simple/tsconfig.json",
    "content": "{\n  \"compilerOptions\": {\n    \"target\": \"es5\",\n    \"lib\": [\n      \"dom\",\n      \"dom.iterable\",\n      \"esnext\"\n    ],\n    \"allowJs\": true,\n    \"skipLibCheck\": true,\n    \"esModuleInterop\": true,\n    \"allowSyntheticDefaultImports\": true,\n    \"strict\": true,\n    \"forceConsistentCasingInFileNames\": true,\n    \"module\": \"esnext\",\n    \"moduleResolution\": \"node\",\n    \"resolveJsonModule\": true,\n    \"isolatedModules\": true,\n    \"noEmit\": true,\n    \"jsx\": \"react\"\n  },\n  \"include\": [\n    \"src\"\n  ]\n}\n"
  },
  {
    "path": "package.json",
    "content": "{\n  \"name\": \"react-charts\",\n  \"version\": \"1.0.0-semantic-release\",\n  \"description\": \"Simple, immersive & interactive charts for React. Flexible, declarative, and highly configurable.\",\n  \"author\": \"tannerlinsley\",\n  \"license\": \"MIT\",\n  \"repository\": \"tannerlinsley/react-charts\",\n  \"homepage\": \"https://github.com/tannerlinsley/react-charts#readme\",\n  \"funding\": {\n    \"type\": \"github\",\n    \"url\": \"https://github.com/sponsors/tannerlinsley\"\n  },\n  \"main\": \"lib/index.js\",\n  \"unpkg\": \"dist/react-charts.development.js\",\n  \"types\": \"types/index.d.ts\",\n  \"module\": \"es/index.js\",\n  \"files\": [\n    \"dist\",\n    \"es\",\n    \"lib\",\n    \"scripts\",\n    \"types\"\n  ],\n  \"scripts\": {\n    \"test\": \"is-ci \\\"test:ci\\\" \\\"test:dev\\\"\",\n    \"test:dev\": \"npm run test:types && npm run test:eslint && jest --watch\",\n    \"test:ci\": \"npm run test:types && npm run test:eslint && jest\",\n    \"test:coverage\": \"yarn test:ci; open coverage/lcov-report/index.html\",\n    \"test:types\": \"tsc\",\n    \"test:eslint\": \"eslint --ext .ts,.tsx ./src\",\n    \"build\": \"yarn build:commonjs && yarn build:es && yarn build:umd && yarn build:types\",\n    \"build:commonjs\": \"rimraf ./lib && cross-env BABEL_ENV=commonjs babel --extensions .ts,.tsx --ignore ./src/**/tests/**/* ./src --out-dir lib\",\n    \"build:es\": \"rimraf ./es && babel --extensions .ts,.tsx --ignore ./src/**/tests/**/* ./src --out-dir es\",\n    \"build:umd\": \"rimraf ./dist && cross-env NODE_ENV=production rollup -c && rollup-plugin-visualizer stats-react.json\",\n    \"build:types\": \"rimraf ./types && tsc --project ./tsconfig.types.json && replace 'import type' 'import' ./types -r --silent && replace 'export type' 'export' ./types -r --silent\",\n    \"watch\": \"yarn watch:commonjs & yarn watch:es & yarn watch:umd & yarn watch:types\",\n    \"watch:commonjs\": \"rimraf ./lib && cross-env BABEL_ENV=commonjs babel --watch --extensions .ts,.tsx --ignore ./src/**/tests/**/* ./src --out-dir lib\",\n    \"watch:es\": \"rimraf ./es && babel --watch --extensions .ts,.tsx --ignore ./src/**/tests/**/* ./src --out-dir es\",\n    \"watch:umd\": \"rimraf ./dist && cross-env NODE_ENV=production rollup -w -c && rollup-plugin-visualizer stats-react.json\",\n    \"watch:types\": \"rimraf ./types && tsc --watch --project ./tsconfig.types.json && replace 'import type' 'import' ./types -r --silent && replace 'export type' 'export' ./types -r --silent\",\n    \"now-build\": \"yarn && cd www && yarn && yarn build\",\n    \"start\": \"yarn watch\",\n    \"format\": \"prettier {.,src,src/**,example/src,example/src/**,types}/*.{md,js,jsx,tsx,json} --write\",\n    \"stats\": \"open ./stats.html\",\n    \"typedoc\": \"typedoc\"\n  },\n  \"peerDependencies\": {\n    \"react\": \">=16\",\n    \"react-dom\": \">=16\"\n  },\n  \"release\": {\n    \"branches\": [\n      \"+([0-9])?(.{+([0-9]),x}).x\",\n      \"main\",\n      \"next\",\n      \"next-major\",\n      {\n        \"name\": \"beta\",\n        \"prerelease\": true\n      },\n      {\n        \"name\": \"alpha\",\n        \"prerelease\": true\n      }\n    ]\n  },\n  \"husky\": {\n    \"hooks\": {\n      \"pre-commit\": \"tsdx lint\"\n    }\n  },\n  \"devDependencies\": {\n    \"@babel/cli\": \"^7.11.6\",\n    \"@babel/core\": \"^7.11.6\",\n    \"@babel/plugin-transform-runtime\": \"^7.11.5\",\n    \"@babel/preset-env\": \"^7.11.5\",\n    \"@babel/preset-react\": \"^7.10.4\",\n    \"@babel/preset-typescript\": \"^7.10.4\",\n    \"@rollup/plugin-replace\": \"^2.3.3\",\n    \"@svgr/rollup\": \"^5.4.0\",\n    \"@testing-library/react\": \"^12.0.0\",\n    \"@types/d3-delaunay\": \"^6.0.0\",\n    \"@types/d3-time-format\": \"^4.0.0\",\n    \"@types/jest\": \"^26.0.4\",\n    \"@typescript-eslint/eslint-plugin\": \"^4.8.1\",\n    \"@typescript-eslint/parser\": \"^4.8.1\",\n    \"babel-eslint\": \"^10.1.0\",\n    \"babel-jest\": \"^27.0.6\",\n    \"babel-plugin-const-enum\": \"^1.0.1\",\n    \"babel-plugin-transform-async-to-promises\": \"^0.8.15\",\n    \"cross-env\": \"^7.0.2\",\n    \"eslint\": \"7.x\",\n    \"eslint-config-prettier\": \"^8.3.0\",\n    \"eslint-config-react-app\": \"^6.0.0\",\n    \"eslint-config-standard\": \"^16.0.3\",\n    \"eslint-config-standard-react\": \"^11.0.1\",\n    \"eslint-plugin-flowtype\": \"5.x\",\n    \"eslint-plugin-import\": \"^2.22.1\",\n    \"eslint-plugin-jsx-a11y\": \"6.x\",\n    \"eslint-plugin-node\": \"^11.1.0\",\n    \"eslint-plugin-prettier\": \"^3.1.3\",\n    \"eslint-plugin-promise\": \"^5.1.0\",\n    \"eslint-plugin-react\": \"7.24.0\",\n    \"eslint-plugin-react-hooks\": \"4.2.0\",\n    \"eslint-plugin-standard\": \"^5.0.0\",\n    \"is-ci-cli\": \"^2.1.1\",\n    \"jest\": \"^27.0.6\",\n    \"prettier\": \"2.3.2\",\n    \"react\": \"^17.0.2\",\n    \"react-dom\": \"^17.0.2\",\n    \"react-error-boundary\": \"^3.1.3\",\n    \"replace\": \"^1.2.0\",\n    \"rimraf\": \"^3.0.2\",\n    \"rollup\": \"^2.16.1\",\n    \"rollup-plugin-babel\": \"^4.4.0\",\n    \"rollup-plugin-commonjs\": \"^10.1.0\",\n    \"rollup-plugin-jscc\": \"^2.0.0\",\n    \"rollup-plugin-node-resolve\": \"^5.2.0\",\n    \"rollup-plugin-peer-deps-external\": \"^2.2.2\",\n    \"rollup-plugin-prettier\": \"^2.1.0\",\n    \"rollup-plugin-size\": \"^0.2.2\",\n    \"rollup-plugin-terser\": \"^7.0.2\",\n    \"rollup-plugin-visualizer\": \"^5.5.2\",\n    \"typescript\": \"^4.3.5\"\n  },\n  \"dependencies\": {\n    \"@babel/runtime\": \"^7.14.6\",\n    \"@types/d3-array\": \"^3.0.1\",\n    \"@types/d3-scale\": \"^4.0.1\",\n    \"@types/d3-shape\": \"^3.0.1\",\n    \"@types/raf\": \"^3.4.0\",\n    \"@types/react\": \"^17.0.14\",\n    \"@types/react-dom\": \"^17.0.9\",\n    \"d3-array\": \"^2.12.1\",\n    \"d3-delaunay\": \"5.3.0\",\n    \"d3-scale\": \"^3.3.0\",\n    \"d3-shape\": \"^2.1.0\",\n    \"d3-time\": \"^2.1.1\",\n    \"d3-time-format\": \"^4.1.0\",\n    \"ts-toolbelt\": \"^9.6.0\"\n  },\n  \"resolutions\": {\n    \"d3-scale/d3-interpolate/d3-color\": \"^3.1.0\"\n  }\n}"
  },
  {
    "path": "prettier.config.js",
    "content": "module.exports = {\n  printWidth: 80,\n  tabWidth: 2,\n  useTabs: false,\n  semi: false,\n  singleQuote: true,\n  trailingComma: 'es5',\n  bracketSpacing: true,\n  jsxBracketSameLine: false,\n  arrowParens: 'avoid',\n  endOfLine: 'auto',\n  importOrder: ['^[@]', '[./]'],\n  importOrderSeparation: true,\n}\n"
  },
  {
    "path": "rollup.config.js",
    "content": "import babel from 'rollup-plugin-babel'\nimport commonJS from 'rollup-plugin-commonjs'\nimport resolve from 'rollup-plugin-node-resolve'\nimport externalDeps from 'rollup-plugin-peer-deps-external'\nimport size from 'rollup-plugin-size'\nimport { terser } from 'rollup-plugin-terser'\nimport visualizer from 'rollup-plugin-visualizer'\n\nimport replace from '@rollup/plugin-replace'\n\nconst external = ['react', 'react-dom', 'react-charts']\n\nconst globals = {\n  react: 'React',\n  'react-dom': 'ReactDOM',\n  'react-charts': 'ReactCharts',\n}\n\nconst inputSrcs = [['src/index.ts', 'ReactCharts', 'react-charts']]\n\nconst extensions = ['.js', '.jsx', '.es6', '.es', '.mjs', '.ts', '.tsx']\nconst babelConfig = { extensions, runtimeHelpers: true }\nconst resolveConfig = { extensions }\n\nexport default inputSrcs\n  .map(([input, name, file]) => {\n    return [\n      {\n        input: input,\n        output: {\n          name,\n          file: `dist/${file}.development.js`,\n          format: 'umd',\n          sourcemap: true,\n          globals,\n        },\n        external,\n        plugins: [\n          resolve(resolveConfig),\n          babel(babelConfig),\n          commonJS(),\n          externalDeps(),\n        ],\n      },\n      {\n        input: input,\n        output: {\n          name,\n          file: `dist/${file}.production.min.js`,\n          format: 'umd',\n          sourcemap: true,\n          globals,\n        },\n        external,\n        plugins: [\n          replace({\n            'process.env.NODE_ENV': `\"production\"`,\n            delimiters: ['', ''],\n          }),\n          resolve(resolveConfig),\n          babel(babelConfig),\n          commonJS(),\n          externalDeps(),\n          terser(),\n          size(),\n          visualizer({\n            filename: 'stats-react.json',\n            json: true,\n            gzipSize: true,\n            brotliSize: true,\n          }),\n        ],\n      },\n    ]\n  })\n  .flat()\n"
  },
  {
    "path": "src/components/AxisLinear.tsx",
    "content": "import React from 'react'\n\nimport { Axis, AxisLinear } from '../types'\nimport { translate } from '../utils/Utils'\nimport useChartContext from '../utils/chartContext'\n//\nimport useMeasure from './AxisLinear.useMeasure'\n\nexport default function AxisLinearComp<TDatum>(axis: Axis<TDatum>) {\n  const [showRotated, setShowRotated] = React.useState(false)\n  const { getOptions, gridDimensions, width, height } =\n    useChartContext<TDatum>()\n\n  const { dark, showDebugAxes } = getOptions()\n\n  const elRef = React.useRef<SVGGElement>(null)\n\n  useMeasure({\n    axis,\n    elRef,\n    gridDimensions,\n    showRotated,\n    setShowRotated,\n  })\n\n  const renderAxis = (isOuter: boolean) => {\n    const isRotated = !isOuter && showRotated\n\n    const scale = isOuter ? axis.outerScale : axis.scale\n    const [rangeStart, rangeEnd] = scale.range()\n\n    const getTicks = () => {\n      const anyAxis = axis as AxisLinear<TDatum>\n\n      if ((anyAxis as AxisLinear<TDatum>).outerScale.ticks!) {\n        if (typeof anyAxis.tickCount === 'number') {\n          return anyAxis.outerScale.ticks(anyAxis.tickCount)\n        }\n\n        const autoSpacing = anyAxis.isVertical ? 40 : 80\n        const range = anyAxis.outerScale.range()\n        const num = Math.abs(range[1] - range[0]) / autoSpacing\n\n        return anyAxis.outerScale.ticks(num)\n      }\n\n      return anyAxis.outerScale.domain()\n    }\n\n    const resolvedHeight = isOuter ? height : gridDimensions.height\n    const resolvedWidth = isOuter ? width : gridDimensions.width\n\n    const [lineFrom, lineTo] =\n      axis.position === 'left'\n        ? [\n            { x: 0, y: rangeStart },\n            { x: 0, y: rangeEnd },\n          ]\n        : axis.position === 'right'\n        ? [\n            { x: resolvedWidth, y: rangeStart },\n            { x: resolvedWidth, y: rangeEnd },\n          ]\n        : axis.position === 'top'\n        ? [\n            { x: rangeStart, y: 0 },\n            { x: rangeEnd, y: 0 },\n          ]\n        : [\n            { x: rangeStart, y: resolvedHeight },\n            { x: rangeEnd, y: resolvedHeight },\n          ]\n\n    const ticks = getTicks().map(tick => {\n      const px = getTickPx(scale, tick)\n\n      const [from, to, gridTo] =\n        axis.position === 'left'\n          ? [\n              { x: 0, y: px },\n              { x: -8, y: px },\n              { x: resolvedWidth, y: px },\n            ]\n          : axis.position === 'right'\n          ? [\n              { x: resolvedWidth, y: px },\n              { x: resolvedWidth + 8, y: px },\n              { x: 0, y: px },\n            ]\n          : axis.position === 'top'\n          ? [\n              { x: px, y: 0 },\n              { x: px, y: -8 },\n              { x: px, y: resolvedHeight },\n            ]\n          : [\n              { x: px, y: resolvedHeight },\n              { x: px, y: resolvedHeight + 8 },\n              { x: px, y: 0 },\n            ]\n\n      return {\n        value: tick,\n        from,\n        to,\n        gridTo,\n      }\n    })\n\n    return (\n      <g\n        key={`Axis-Group ${isOuter ? 'outer' : 'inner'}`}\n        className={`Axis-Group ${isOuter ? 'outer' : 'inner'}`}\n        style={{\n          transform: isOuter\n            ? undefined\n            : translate(gridDimensions.left, gridDimensions.top),\n        }}\n      >\n        <g\n          className={`Axis`}\n          style={{\n            ...(isOuter\n              ? {\n                  opacity: showDebugAxes ? 0.5 : 0,\n                  pointerEvents: 'none',\n                }\n              : {\n                  opacity: 1,\n                  pointerEvents: 'all',\n                }),\n          }}\n        >\n          <g className=\"domainAndTicks\">\n            <line\n              className=\"domain\"\n              x1={lineFrom.x}\n              y1={lineFrom.y}\n              x2={lineTo.x}\n              y2={lineTo.y}\n              stroke={dark ? 'rgba(255,255,255, .2)' : 'rgba(0,0,0, .2)'}\n            />\n            {ticks.map((tick, i) => {\n              let { x: tickLabelX, y: tickLabelY } = tick.to\n\n              if (axis.position === 'top') {\n                tickLabelY -= 5\n              } else if (axis.position === 'bottom') {\n                tickLabelY += 5\n              } else if (axis.position === 'left') {\n                tickLabelX -= 5\n              } else if (axis.position === 'right') {\n                tickLabelX += 5\n              }\n\n              return (\n                <g key={`vx-tick-${tick}-${i}`} className={'tick'}>\n                  {!isOuter ? (\n                    <line\n                      x1={tick.from.x}\n                      y1={tick.from.y}\n                      x2={tick.to.x}\n                      y2={tick.to.y}\n                      stroke={\n                        dark ? 'rgba(255,255,255, .2)' : 'rgba(0,0,0, .2)'\n                      }\n                    />\n                  ) : null}\n                  <text\n                    className=\"tickLabel\"\n                    style={{\n                      fontSize: 10,\n                      fill: dark ? 'rgba(255,255,255, .7)' : 'rgba(0,0,0, .7)',\n                      dominantBaseline: isRotated\n                        ? 'central'\n                        : axis.position === 'bottom'\n                        ? 'hanging'\n                        : axis.position === 'top'\n                        ? 'alphabetic'\n                        : 'central',\n                      textAnchor: isRotated\n                        ? 'end'\n                        : axis.position === 'right'\n                        ? 'start'\n                        : axis.position === 'left'\n                        ? 'end'\n                        : 'middle',\n                    }}\n                    transform={`translate(${tickLabelX}, ${tickLabelY}) rotate(${\n                      isRotated ? (axis.position === 'top' ? 60 : -60) : 0\n                    })`}\n                  >\n                    {(axis as AxisLinear<any>).formatters.scale(\n                      tick.value as number\n                    )}\n                  </text>\n                </g>\n              )\n            })}\n          </g>\n          <g className=\"grid\">\n            {ticks.map((tick, i) => {\n              return (\n                <g key={`vx-tick-${tick}-${i}`} className={'tick'}>\n                  {(axis.showGrid ?? true) && !isOuter ? (\n                    <line\n                      x1={tick.from.x}\n                      y1={tick.from.y}\n                      x2={tick.gridTo.x}\n                      y2={tick.gridTo.y}\n                      stroke={\n                        dark ? 'rgba(255,255,255, .05)' : 'rgba(0,0,0, .05)'\n                      }\n                    />\n                  ) : null}\n                </g>\n              )\n            })}\n          </g>\n        </g>\n      </g>\n    )\n  }\n\n  return axis.show ? (\n    <g ref={elRef}>\n      {renderAxis(false)}\n      {renderAxis(true)}\n    </g>\n  ) : null\n}\n\nfunction getTickPx<TDatum>(scale: Axis<TDatum>['scale'], value: any) {\n  let px = scale(value) ?? NaN\n\n  // @ts-ignore\n  if (scale.bandwidth) {\n    // @ts-ignore\n    return px + scale.bandwidth() / 2\n  }\n\n  return px\n}\n"
  },
  {
    "path": "src/components/AxisLinear.useMeasure.ts",
    "content": "import React, { MutableRefObject } from 'react'\n\nimport useIsomorphicLayoutEffect from '../hooks/useIsomorphicLayoutEffect'\nimport { Axis, AxisDimension, GridDimensions, Position } from '../types'\nimport useChartContext from '../utils/chartContext'\n\nconst getElBox = (el: Element) => {\n  var rect = el.getBoundingClientRect()\n  return {\n    top: Math.round(rect.top),\n    right: Math.round(rect.right),\n    bottom: Math.round(rect.bottom),\n    left: Math.round(rect.left),\n    width: Math.round(rect.width),\n    height: Math.round(rect.height),\n    x: Math.round(rect.x),\n    y: Math.round(rect.y),\n  }\n}\n\nexport default function useMeasure<TDatum>({\n  axis,\n  elRef,\n  gridDimensions,\n  setShowRotated,\n}: {\n  axis: Axis<TDatum>\n  elRef: MutableRefObject<SVGGElement | null>\n  gridDimensions: GridDimensions\n  showRotated: boolean\n  setShowRotated: (value: boolean) => void\n}) {\n  const { axisDimensionsState } = useChartContext<TDatum>()\n\n  const [axisDimensions, setAxisDimensions] = axisDimensionsState\n\n  const axisDimension = React.useMemo(() => {\n    return axisDimensions[axis.position as Position]?.[axis.id!]\n  }, [axisDimensions, axis.position, axis.id])\n\n  // const isLooping = useIsLooping()\n\n  const measureRotation = React.useCallback(() => {\n    if (!elRef.current) {\n      return\n    }\n\n    let gridSize = !axis.isVertical\n      ? gridDimensions.width\n      : gridDimensions.height\n\n    const staticLabelDims = Array.from(\n      elRef.current.querySelectorAll('.Axis-Group.outer .tickLabel')\n    ).map(el => getElBox(el))\n\n    // Determine the largest labels on the axis\n    let widestLabel: typeof staticLabelDims[number] | undefined\n\n    staticLabelDims.forEach(label => {\n      let resolvedLabel = widestLabel ?? { width: 0 }\n      if (label.width > 0 && label.width > resolvedLabel.width) {\n        widestLabel = label\n      }\n    })\n\n    let smallestTickGap = gridSize\n\n    if (staticLabelDims.length > 1) {\n      staticLabelDims.forEach((current, i) => {\n        const prev = staticLabelDims[i - 1]\n\n        if (prev) {\n          smallestTickGap = Math.min(\n            smallestTickGap,\n            axis.isVertical ? current.top - prev.top : current.left - prev.left\n          )\n        }\n      })\n    }\n\n    const shouldRotate =\n      (widestLabel?.width || 0) + axis.minTickPaddingForRotation >\n      smallestTickGap\n\n    // if (!isLooping) {\n    // Rotate ticks for non-time horizontal axes\n    if (!axis.isVertical) {\n      setShowRotated(shouldRotate)\n    }\n    // }\n  }, [\n    elRef,\n    axis.isVertical,\n    axis.minTickPaddingForRotation,\n    gridDimensions.width,\n    gridDimensions.height,\n    setShowRotated,\n  ])\n\n  const measureDimensions = React.useCallback(() => {\n    if (!elRef.current) {\n      if (axisDimension) {\n        // If the entire axis is hidden, then we need to remove the axis dimensions\n        setAxisDimensions(old => {\n          const newAxes = { ...(old[axis.position] ?? {}) }\n\n          delete newAxes[axis.id!]\n\n          return {\n            ...old,\n            [axis.position]: newAxes,\n          }\n        })\n      }\n      return\n    }\n\n    const newDimensions: AxisDimension = {\n      width: 0,\n      height: 0,\n      paddingTop: 0,\n      paddingBottom: 0,\n      paddingLeft: 0,\n      paddingRight: 0,\n    }\n\n    const currentEl = elRef.current\n\n    const axisEl = currentEl.querySelector(`.Axis-Group.inner .domainAndTicks`)\n    const domainEl = currentEl.querySelector(`.Axis-Group.inner .domain`)\n\n    if (!axisEl || !domainEl) {\n      return\n    }\n\n    const axisDims = getElBox(axisEl)\n    const domainDims = getElBox(domainEl)\n\n    if (!axisDims || !domainDims) {\n      return\n    }\n\n    // Axis overflow measurements\n    if (!axis.isVertical) {\n      newDimensions.paddingLeft = Math.round(\n        Math.max(0, domainDims.left - axisDims?.left)\n      )\n\n      newDimensions.paddingRight = Math.round(\n        Math.max(0, axisDims?.right - domainDims.right)\n      )\n\n      newDimensions.height = axisDims?.height\n    } else {\n      newDimensions.paddingTop = Math.round(\n        Math.max(0, domainDims.top - axisDims?.top)\n      )\n\n      newDimensions.paddingBottom = Math.round(\n        Math.max(0, axisDims?.bottom - domainDims.bottom)\n      )\n\n      newDimensions.width = axisDims?.width\n    }\n\n    // Only update the axisDimensions if something has changed\n    if (\n      // !isLooping &&\n      !axisDimensions ||\n      !axisDimension ||\n      Object.keys(newDimensions).some(key => {\n        // @ts-ignore\n        return newDimensions[key] !== axisDimension[key]\n      })\n    ) {\n      setAxisDimensions(old => ({\n        ...old,\n        [axis.position]: {\n          ...(old[axis.position] ?? {}),\n          [axis.id!]: newDimensions,\n        },\n      }))\n    }\n  }, [\n    axis.id,\n    axis.isVertical,\n    axis.position,\n    axisDimension,\n    axisDimensions,\n    elRef,\n    setAxisDimensions,\n  ])\n\n  // Measure after if needed\n  useIsomorphicLayoutEffect(() => {\n    // setTimeout(() => {\n    window.requestAnimationFrame(() => {\n      measureRotation()\n      measureDimensions()\n    })\n  }, [measureRotation])\n\n  // useIsomorphicLayoutEffect(() => {\n  //   // setTimeout(() => {\n  //   window.requestAnimationFrame(() => {\n  //   })\n  // }, [measureRotation])\n}\n"
  },
  {
    "path": "src/components/Chart.tsx",
    "content": "import { groups, sort, sum } from 'd3-array'\nimport React, { ComponentPropsWithoutRef } from 'react'\n\nimport useGetLatest from '../hooks/useGetLatest'\nimport useIsomorphicLayoutEffect from '../hooks/useIsomorphicLayoutEffect'\nimport Bar, { getPrimary } from '../seriesTypes/Bar'\nimport Line from '../seriesTypes/Line'\n//\nimport {\n  Axis,\n  AxisDimensions,\n  AxisOptions,\n  AxisOptionsWithScaleType,\n  BuildAxisOptions,\n  ChartContextValue,\n  ChartOptions,\n  Datum,\n  GridDimensions,\n  RequiredChartOptions,\n  Series,\n  UserSerie,\n} from '../types'\nimport {\n  materializeStyles,\n  getSeriesStatus,\n  getDatumStatus,\n} from '../utils/Utils'\nimport buildAxisLinear from '../utils/buildAxis.linear'\nimport { ChartContextProvider } from '../utils/chartContext'\nimport AxisLinear from './AxisLinear'\n// import Brush from './Brush'\nimport Cursors from './Cursors'\nimport Tooltip, { defaultTooltip } from './Tooltip'\nimport Voronoi from './Voronoi'\n\n//\n\n//\n\nconst defaultColorScheme = [\n  '#0f83ab',\n  '#faa43a',\n  '#fd6868',\n  '#53cfc9',\n  '#a2d925',\n  '#decf3f',\n  '#734fe9',\n  '#cd82ad',\n  '#006d92',\n  '#de7c00',\n  '#f33232',\n  '#3f9a80',\n  '#53c200',\n  '#d7af00',\n  '#4c26c9',\n  '#d44d99',\n]\n\nconst defaultPadding = 5\n\nfunction defaultChartOptions<TDatum>(\n  options: ChartOptions<TDatum>\n): RequiredChartOptions<TDatum> {\n  return {\n    ...options,\n    initialWidth: options.initialWidth ?? 300,\n    initialHeight: options.initialHeight ?? 200,\n    getSeriesOrder:\n      options.getSeriesOrder ?? ((series: Series<TDatum>[]) => series),\n    interactionMode: options.interactionMode ?? 'primary',\n    showVoronoi: options.showVoronoi ?? false,\n    defaultColors: options.defaultColors ?? defaultColorScheme,\n    useIntersectionObserver: options.useIntersectionObserver ?? false,\n    intersectionObserverRootMargin:\n      options.intersectionObserverRootMargin ?? '1000px',\n    primaryCursor: options.primaryCursor ?? true,\n    secondaryCursor: options.secondaryCursor ?? true,\n    padding: options.padding ?? defaultPadding,\n  }\n}\n\nexport function Chart<TDatum>({\n  options: userOptions,\n  className,\n  style = {},\n  ...rest\n}: ComponentPropsWithoutRef<'div'> & { options: ChartOptions<TDatum> }) {\n  const options = defaultChartOptions(userOptions)\n  const [chartElement, setContainerElement] =\n    React.useState<HTMLDivElement | null>(null)\n\n  const containerEl = chartElement?.parentElement\n\n  const nearestScrollableParent = React.useMemo(() => {\n    const run = (el?: Element | null): Element | null => {\n      if (!el) {\n        return null\n      }\n\n      const grandParent = el.parentElement\n\n      if (!grandParent) {\n        return null\n      }\n\n      if (grandParent.scrollHeight > grandParent.clientHeight) {\n        const { overflow } = window.getComputedStyle(grandParent)\n\n        if (overflow.includes('scroll') || overflow.includes('auto')) {\n          return grandParent\n        }\n      }\n\n      return run(grandParent)\n    }\n\n    return run(containerEl)\n  }, [containerEl])\n\n  const [{ width, height }, setDims] = React.useState({\n    width: options.initialWidth,\n    height: options.initialHeight,\n  })\n\n  useIsomorphicLayoutEffect(() => {\n    if (containerEl) {\n      const computed = window.getComputedStyle(containerEl)\n\n      if (!['relative', 'absolute', 'fixed'].includes(computed.position)) {\n        containerEl.style.position = 'relative'\n      }\n    }\n  }, [containerEl])\n\n  React.useEffect(() => {\n    if (!containerEl) {\n      return\n    }\n\n    const observer = new ResizeObserver(() => {\n      const rect = containerEl?.getBoundingClientRect()\n      const styles = window.getComputedStyle(containerEl)\n\n      if (rect) {\n        setDims({\n          width:\n            rect.width -\n            parseInt(styles.borderLeftWidth) -\n            parseInt(styles.borderRightWidth),\n          height:\n            rect.height -\n            parseInt(styles.borderTopWidth) -\n            parseInt(styles.borderBottomWidth),\n        })\n      }\n    })\n\n    observer.observe(containerEl)\n\n    return () => {\n      observer.unobserve(containerEl)\n    }\n  }, [containerEl])\n\n  const [isIntersecting, setIsIntersecting] = React.useState(true)\n\n  React.useEffect(() => {\n    if (!containerEl || !options.useIntersectionObserver) return\n\n    let observer = new IntersectionObserver(\n      entries => {\n        for (let entry of entries) {\n          if (entry.isIntersecting) {\n            setIsIntersecting(true)\n          } else {\n            setIsIntersecting(false)\n          }\n        }\n      },\n      {\n        root: nearestScrollableParent,\n        rootMargin: options.intersectionObserverRootMargin,\n      }\n    )\n\n    observer.observe(containerEl)\n\n    return () => {\n      observer.unobserve(containerEl)\n    }\n  }, [\n    containerEl,\n    nearestScrollableParent,\n    options.intersectionObserverRootMargin,\n    options.useIntersectionObserver,\n  ])\n\n  return (\n    <div\n      ref={setContainerElement}\n      {...rest}\n      className={`ReactChart ${className || ''}`}\n      style={{\n        fontFamily: 'sans-serif',\n        ...style,\n        position: 'absolute',\n        width,\n        height,\n      }}\n    >\n      {options.useIntersectionObserver && !isIntersecting ? null : (\n        <ChartInner options={options} {...{ width, height }} />\n      )}\n    </div>\n  )\n}\n\nfunction ChartInner<TDatum>({\n  options,\n  width,\n  height,\n}: {\n  options: RequiredChartOptions<TDatum>\n  width: number\n  height: number\n}) {\n  if (!options.primaryAxis) {\n    throw new Error('A primaryAxis is required')\n  }\n\n  if (!options.secondaryAxes.length) {\n    throw new Error('At least one secondaryAxis is required')\n  }\n\n  const primaryAxisOptions = React.useMemo((): BuildAxisOptions<TDatum> => {\n    const firstValue = getFirstDefinedValue(options.primaryAxis, options.data)\n    const axisOptions = axisOptionsWithScaleType(\n      options.primaryAxis,\n      firstValue\n    )\n\n    return { position: 'bottom', ...axisOptions }\n  }, [options.data, options.primaryAxis])\n\n  const secondaryAxesOptions = React.useMemo(() => {\n    return options.secondaryAxes.map(\n      (secondaryAxis, i): BuildAxisOptions<TDatum> => {\n        const firstValue = getFirstDefinedValue(secondaryAxis, options.data)\n\n        const axisOptions = axisOptionsWithScaleType(secondaryAxis, firstValue)\n\n        if (!axisOptions.elementType) {\n          if (primaryAxisOptions.scaleType === 'band') {\n            axisOptions.elementType = 'bar'\n          } else if (axisOptions.stacked) {\n            axisOptions.elementType = 'area'\n          }\n        }\n\n        if (\n          typeof axisOptions.stacked === 'undefined' &&\n          axisOptions.elementType &&\n          ['area'].includes(axisOptions.elementType)\n        ) {\n          axisOptions.stacked = true\n        }\n\n        return {\n          position: !i ? 'left' : 'right',\n          ...axisOptions,\n        }\n      }\n    )\n  }, [options.data, options.secondaryAxes, primaryAxisOptions])\n\n  // Resolve Tooltip Option\n  const tooltipOptions = React.useMemo(() => {\n    const tooltipOptions = defaultTooltip(options?.tooltip)\n    tooltipOptions.groupingMode =\n      tooltipOptions.groupingMode ??\n      (() => {\n        if (options.interactionMode === 'closest') {\n          return 'single'\n        }\n        return 'primary'\n      })()\n\n    return tooltipOptions\n  }, [options.interactionMode, options?.tooltip])\n\n  options = {\n    ...options,\n    tooltip: tooltipOptions,\n  }\n\n  //\n\n  const svgRef = React.useRef<SVGSVGElement>(null)\n  const getOptions = useGetLatest({ ...options, tooltip: tooltipOptions })\n\n  const axisDimensionsState = React.useState<AxisDimensions>({\n    left: {},\n    right: {},\n    top: {},\n    bottom: {},\n  })\n\n  const [axisDimensions] = axisDimensionsState\n\n  const isInteractingState = React.useState<boolean>(false)\n  const [isInteracting] = isInteractingState\n\n  const focusedDatumState = React.useState<Datum<TDatum> | null>(null)\n  const [focusedDatum] = focusedDatumState\n\n  // useAtom<Datum<TDatum> | null>(focusedDatumAtom)\n\n  const gridDimensions = React.useMemo((): GridDimensions => {\n    const padding = {\n      left:\n        typeof options.padding === 'object'\n          ? options.padding.left ?? defaultPadding\n          : options.padding,\n      right:\n        typeof options.padding === 'object'\n          ? options.padding.right ?? defaultPadding\n          : options.padding,\n      bottom:\n        typeof options.padding === 'object'\n          ? options.padding.bottom ?? defaultPadding\n          : options.padding,\n      top:\n        typeof options.padding === 'object'\n          ? options.padding.top ?? defaultPadding\n          : options.padding,\n    }\n\n    const left =\n      padding.left +\n      Math.max(\n        sum(Object.values(axisDimensions.left), d => d.width),\n        sum(Object.values(axisDimensions.top), d => d.paddingLeft),\n        sum(Object.values(axisDimensions.bottom), d => d.paddingLeft)\n      )\n\n    const top =\n      padding.top +\n      Math.max(\n        sum(Object.values(axisDimensions.top), d => d.height),\n        sum(Object.values(axisDimensions.left), d => d.paddingTop),\n        sum(Object.values(axisDimensions.right), d => d.paddingTop)\n      )\n\n    const right =\n      padding.right +\n      Math.max(\n        sum(Object.values(axisDimensions.right), d => d.width),\n        sum(Object.values(axisDimensions.top), d => d.paddingRight),\n        sum(Object.values(axisDimensions.bottom), d => d.paddingRight)\n      )\n\n    const bottom =\n      padding.bottom +\n      Math.max(\n        sum(Object.values(axisDimensions.bottom), d => d.height),\n        sum(Object.values(axisDimensions.left), d => d.paddingBottom),\n        sum(Object.values(axisDimensions.right), d => d.paddingBottom)\n      )\n\n    const gridWidth = Math.max(0, width - left - right)\n    const gridHeight = Math.max(0, height - top - bottom)\n\n    return { left, top, right, bottom, width: gridWidth, height: gridHeight }\n  }, [\n    options.padding,\n    axisDimensions.left,\n    axisDimensions.top,\n    axisDimensions.bottom,\n    axisDimensions.right,\n    width,\n    height,\n  ])\n\n  const series = React.useMemo(() => {\n    const series: Series<TDatum>[] = []\n\n    const indicesByAxisId: Record<string, number> = {}\n\n    for (\n      let seriesIndex = 0;\n      seriesIndex < options.data.length;\n      seriesIndex++\n    ) {\n      const originalSeries = options.data[seriesIndex]\n      const seriesId = originalSeries.id ?? seriesIndex + ''\n      const seriesLabel = originalSeries.label ?? `Series ${seriesIndex + 1}`\n      const secondaryAxisId = originalSeries.secondaryAxisId\n      const originalDatums = originalSeries.data\n      const datums = []\n\n      indicesByAxisId[`${secondaryAxisId}`] =\n        indicesByAxisId[`${secondaryAxisId}`] ?? 0\n      const seriesIndexPerAxis = indicesByAxisId[`${secondaryAxisId}`]\n\n      indicesByAxisId[`${secondaryAxisId}`]++\n\n      for (\n        let datumIndex = 0;\n        datumIndex < originalDatums.length;\n        datumIndex++\n      ) {\n        const originalDatum = originalDatums[datumIndex]\n        datums[datumIndex] = {\n          originalSeries,\n          seriesIndex,\n          seriesIndexPerAxis,\n          seriesId,\n          seriesLabel,\n          secondaryAxisId,\n          index: datumIndex,\n          originalDatum,\n        }\n      }\n\n      series[seriesIndex] = {\n        originalSeries,\n        index: seriesIndex,\n        id: seriesId,\n        label: seriesLabel,\n        indexPerAxis: seriesIndexPerAxis,\n        secondaryAxisId,\n        datums,\n      }\n    }\n\n    return series\n  }, [options.data])\n\n  let allDatums = React.useMemo(() => {\n    return series.map(s => s.datums).flat(2)\n  }, [series])\n\n  const primaryAxis = React.useMemo(() => {\n    return buildAxisLinear<TDatum>(\n      true,\n      primaryAxisOptions,\n      series,\n      allDatums,\n      gridDimensions,\n      width,\n      height\n    )\n  }, [allDatums, gridDimensions, height, primaryAxisOptions, series, width])\n\n  const secondaryAxes = React.useMemo(() => {\n    return secondaryAxesOptions.map(secondaryAxis => {\n      return buildAxisLinear<TDatum>(\n        false,\n        secondaryAxis,\n        series,\n        allDatums,\n        gridDimensions,\n        width,\n        height\n      )\n    })\n  }, [allDatums, gridDimensions, height, secondaryAxesOptions, series, width])\n\n  const [datumsByInteractionGroup, datumsByTooltipGroup] = React.useMemo(() => {\n    if (!isInteracting) {\n      return [new Map(), new Map()]\n    }\n\n    const datumsByInteractionGroup = new Map<any, Datum<TDatum>[]>()\n    const datumsByTooltipGroup = new Map<any, Datum<TDatum>[]>()\n\n    const allBarAndNotStacked = secondaryAxes.every(\n      d => d.elementType === 'bar' && !d.stacked\n    )\n\n    let getInteractionPrimary = (datum: Datum<TDatum>) => {\n      if (allBarAndNotStacked) {\n        const secondaryAxis = secondaryAxes.find(\n          d => d.id === datum.secondaryAxisId\n        )!\n\n        if (secondaryAxis.elementType === 'bar' && !secondaryAxis.stacked) {\n          return getPrimary(datum, primaryAxis, secondaryAxis)\n        }\n      }\n\n      return datum.primaryValue\n    }\n\n    let getInteractionKey = (datum: Datum<TDatum>) =>\n      `${getInteractionPrimary(datum)}`\n    let getTooltipKey = (datum: Datum<TDatum>) => `${datum.primaryValue}`\n\n    if (options.interactionMode === 'closest') {\n      getInteractionKey = datum =>\n        `${getInteractionPrimary(datum)}_${datum.secondaryValue}`\n    }\n\n    if (tooltipOptions.groupingMode === 'single') {\n      getTooltipKey = datum => `${datum.primaryValue}_${datum.secondaryValue}`\n    } else if (tooltipOptions.groupingMode === 'secondary') {\n      getTooltipKey = datum => `${datum.secondaryValue}`\n    } else if (tooltipOptions.groupingMode === 'series') {\n      getTooltipKey = datum => `${datum.seriesIndex}`\n    }\n\n    allDatums.forEach(datum => {\n      const interactionKey = (getInteractionKey as Function)(datum)\n      const tooltipKey = (getTooltipKey as Function)(datum)\n\n      if (!datumsByInteractionGroup.has(interactionKey)) {\n        datumsByInteractionGroup.set(interactionKey, [])\n      }\n\n      if (!datumsByTooltipGroup.has(tooltipKey)) {\n        datumsByTooltipGroup.set(tooltipKey, [])\n      }\n\n      datumsByInteractionGroup.get(interactionKey)!.push(datum)\n      datumsByTooltipGroup.get(tooltipKey)!.push(datum)\n    })\n\n    datumsByInteractionGroup.forEach((value, key) => {\n      datumsByInteractionGroup.set(\n        key,\n        sortDatumsBySecondaryPx(value, secondaryAxes)\n      )\n    })\n\n    datumsByTooltipGroup.forEach((value, key) => {\n      datumsByTooltipGroup.set(\n        key,\n        sortDatumsBySecondaryPx(value, secondaryAxes)\n      )\n    })\n\n    allDatums.forEach(datum => {\n      const interactionKey = (getInteractionKey as Function)(datum)\n      const tooltipKey = (getTooltipKey as Function)(datum)\n      datum.interactiveGroup = datumsByInteractionGroup.get(interactionKey)\n      datum.tooltipGroup = datumsByTooltipGroup.get(tooltipKey)\n    })\n\n    return [datumsByInteractionGroup, datumsByTooltipGroup]\n  }, [\n    isInteracting,\n    allDatums,\n    options.interactionMode,\n    primaryAxis,\n    secondaryAxes,\n    tooltipOptions.groupingMode,\n  ])\n\n  const getSeriesStatusStyle = React.useCallback(\n    (series: Series<TDatum>, focusedDatum: Datum<TDatum> | null) => {\n      const base = {\n        color:\n          getOptions().defaultColors[\n            series.index % getOptions().defaultColors.length\n          ],\n      }\n\n      const status = getSeriesStatus(series, focusedDatum)\n      const statusStyles = getOptions().getSeriesStyle?.(series, status) ?? {}\n      series.style = materializeStyles(statusStyles, base)\n      return series.style\n    },\n    [getOptions]\n  )\n\n  const getDatumStatusStyle = React.useCallback(\n    (datum: Datum<TDatum>, focusedDatum: Datum<TDatum> | null) => {\n      const base = {\n        ...series[datum.seriesIndex]?.style,\n        color:\n          getOptions().defaultColors[\n            datum.seriesIndex % getOptions().defaultColors.length\n          ],\n      }\n\n      const status = getDatumStatus(datum as Datum<TDatum>, focusedDatum)\n      const statusStyles =\n        getOptions().getDatumStyle?.(datum as Datum<TDatum>, status) ?? {}\n\n      datum.style = materializeStyles(statusStyles, base)\n\n      return datum.style\n    },\n    [getOptions, series]\n  )\n\n  // Reverse the stack order for proper z-indexing\n  let orderedSeries = React.useMemo(() => {\n    const reversedSeries = [...series].reverse()\n\n    return getOptions().getSeriesOrder(reversedSeries)\n  }, [getOptions, series])\n\n  useIsomorphicLayoutEffect(() => {\n    if (\n      svgRef.current &&\n      svgRef.current.parentElement &&\n      !svgRef.current.parentElement.style.position\n    ) {\n      svgRef.current.parentElement.style.position = 'relative'\n    }\n  })\n\n  const contextValue: ChartContextValue<TDatum> = {\n    getOptions,\n    gridDimensions,\n    primaryAxis,\n    secondaryAxes,\n    series,\n    orderedSeries,\n    datumsByInteractionGroup,\n    datumsByTooltipGroup,\n    width,\n    height,\n    getSeriesStatusStyle,\n    getDatumStatusStyle,\n    axisDimensionsState,\n    focusedDatumState,\n    svgRef,\n    isInteractingState,\n  }\n\n  const seriesByAxisId = React.useMemo(\n    () =>\n      sort(\n        groups(orderedSeries, d => d.secondaryAxisId),\n        ([key]) => secondaryAxes.findIndex(axis => axis.id === key)\n      ),\n    [orderedSeries, secondaryAxes]\n  )\n\n  // eslint-disable-next-line react-hooks/exhaustive-deps\n  let getSeriesInfo = () => ({\n    primaryAxis,\n    secondaryAxes,\n    seriesByAxisId,\n  })\n\n  let getMemoizedSeriesInfo = React.useCallback(\n    () => ({\n      primaryAxis,\n      secondaryAxes,\n      seriesByAxisId,\n    }),\n    [primaryAxis, secondaryAxes, seriesByAxisId]\n  )\n\n  if (options.memoizeSeries) {\n    getSeriesInfo = getMemoizedSeriesInfo\n  }\n\n  const seriesEl = React.useMemo(() => {\n    const { primaryAxis, secondaryAxes, seriesByAxisId } = getSeriesInfo()\n    return seriesByAxisId.map(([axisId, series]) => {\n      const secondaryAxis = secondaryAxes.find(d => d.id === axisId)\n\n      if (!secondaryAxis) {\n        return null\n      }\n\n      const { elementType } = secondaryAxis\n      const Component = (() => {\n        if (\n          elementType === 'line' ||\n          elementType === 'bubble' ||\n          elementType === 'area'\n        ) {\n          return Line\n        }\n        if (elementType === 'bar') {\n          return Bar\n        }\n        throw new Error('Invalid elementType')\n      })()\n\n      if (primaryAxis.isInvalid || secondaryAxis.isInvalid) {\n        return null\n      }\n\n      return (\n        <Component\n          key={axisId ?? '__default__'}\n          primaryAxis={primaryAxis}\n          secondaryAxis={secondaryAxis}\n          series={series}\n        />\n      )\n    })\n  }, [getSeriesInfo])\n\n  return (\n    <ChartContextProvider value={useGetLatest(contextValue)}>\n      <div>\n        <svg\n          ref={svgRef}\n          style={{\n            width,\n            height,\n            overflow: options.brush ? 'hidden' : 'visible',\n          }}\n          onClick={e => options.onClickDatum?.(focusedDatum, e)}\n          onMouseEnter={() => {\n            isInteractingState[1](true)\n          }}\n          onMouseLeave={() => {\n            isInteractingState[1](false)\n          }}\n        >\n          <g className=\"axes\">\n            {[primaryAxis, ...secondaryAxes].map(axis => (\n              <AxisLinear key={[axis.position, axis.id].join('')} {...axis} />\n            ))}\n          </g>\n          <g\n            className=\"Series\"\n            style={{\n              pointerEvents: 'none',\n            }}\n          >\n            {seriesEl}\n          </g>\n          <Voronoi />\n          {options.renderSVG?.() ?? null}\n        </svg>\n        <Cursors />\n        <Tooltip />\n      </div>\n    </ChartContextProvider>\n  )\n}\n\nfunction getFirstDefinedValue<TDatum>(\n  options: AxisOptions<TDatum>,\n  data: UserSerie<TDatum>[]\n) {\n  let firstDefinedValue: Date | number | string | undefined\n\n  data.some(serie => {\n    return serie.data.some(originalDatum => {\n      const value = options.getValue(originalDatum)\n      if (value !== null && typeof value !== 'undefined') {\n        firstDefinedValue = value\n        return true\n      }\n    })\n  })\n\n  return firstDefinedValue\n}\n\nfunction axisOptionsWithScaleType<TDatum>(\n  options: AxisOptions<TDatum>,\n  firstValue: Date | number | string | undefined\n): AxisOptionsWithScaleType<TDatum> {\n  let scaleType = options.scaleType\n\n  if (!options.scaleType) {\n    if (typeof firstValue === 'number') {\n      scaleType = 'linear'\n    } else if (typeof (firstValue as Date)?.getMonth === 'function') {\n      scaleType = 'time'\n    } else if (\n      typeof firstValue === 'string' ||\n      typeof firstValue === 'boolean'\n    ) {\n      scaleType = 'band'\n    } else {\n      throw new Error('Invalid scale type: Unable to infer type from data')\n    }\n  }\n\n  return { ...options, scaleType } as AxisOptionsWithScaleType<TDatum>\n}\n\nfunction sortDatumsBySecondaryPx<TDatum>(\n  datums: Datum<TDatum>[],\n  secondaryAxes: Axis<TDatum>[]\n) {\n  if (secondaryAxes.every(d => d.stacked)) {\n    const differingInverts =\n      secondaryAxes.some(d => d.invert) && secondaryAxes.some(d => !d.invert)\n\n    if (!differingInverts) {\n      return datums\n    }\n  }\n\n  return [...datums].sort((a, b) => {\n    const aAxis = secondaryAxes.find(d => d.id === a.secondaryAxisId)\n    const bAxis = secondaryAxes.find(d => d.id === b.secondaryAxisId)\n\n    const aPx =\n      aAxis?.scale(aAxis.stacked ? a.stackData?.[1] : a.secondaryValue) ?? NaN\n\n    const bPx =\n      bAxis?.scale(bAxis.stacked ? b.stackData?.[1] : b.secondaryValue) ?? NaN\n\n    return aPx > bPx ? 1 : aPx < bPx ? -1 : 0\n  })\n}\n"
  },
  {
    "path": "src/components/Cursors.tsx",
    "content": "import React from 'react'\nimport ReactDOM from 'react-dom'\nimport * as TSTB from 'ts-toolbelt'\n\nimport usePrevious from '../hooks/usePrevious'\nimport useLatestWhen from '../hooks/useLatestWhen'\nimport usePortalElement from '../hooks/usePortalElement'\nimport { AxisTime, CursorOptions, Datum } from '../types'\nimport { translate } from '../utils/Utils'\n//\nimport useChartContext from '../utils/chartContext'\nimport useRect from '../hooks/useRect'\nimport { useSpring } from '../hooks/useSpring'\nimport useGetLatest from '../hooks/useGetLatest'\n\ntype ResolvedCursorOptions = TSTB.Object.Required<\n  CursorOptions,\n  'show' | 'showLine' | 'showLabel'\n>\n\n//\n\nconst getLineBackgroundColor = (dark: boolean, bandWidth: number) =>\n  dark\n    ? `rgba(255,255,255,${bandWidth > 4 ? 0.15 : 0.3})`\n    : `rgba(0, 26, 39, ${bandWidth > 4 ? 0.15 : 0.3})`\n\nconst getBackgroundColor = (dark?: boolean) =>\n  dark ? 'rgba(255,255,255,.9)' : 'rgba(0, 26, 39, 0.9)'\n\nfunction defaultCursor(options: CursorOptions): ResolvedCursorOptions {\n  return {\n    ...options,\n    show: options.show ?? true,\n    showLine: options.showLine ?? true,\n    showLabel: options.showLabel ?? true,\n  }\n}\n\nexport default function Cursors<TDatum>() {\n  const { getOptions } = useChartContext<TDatum>()\n\n  let primaryOptions = getOptions().primaryCursor ?? true\n  let secondaryOptions = getOptions().secondaryCursor ?? true\n\n  const resolvedPrimaryOptions = React.useMemo(\n    () =>\n      defaultCursor(\n        !primaryOptions\n          ? { show: false }\n          : typeof primaryOptions === 'boolean'\n          ? {}\n          : primaryOptions\n      ),\n    [primaryOptions]\n  )\n\n  const resolvedSecondaryOptions = React.useMemo(\n    () =>\n      defaultCursor(\n        !secondaryOptions\n          ? { show: false }\n          : typeof secondaryOptions === 'boolean'\n          ? {}\n          : secondaryOptions\n      ),\n    [secondaryOptions]\n  )\n\n  return (\n    <>\n      {resolvedPrimaryOptions.show && (\n        <Cursor primary options={resolvedPrimaryOptions} />\n      )}\n      {resolvedSecondaryOptions.show && (\n        <Cursor options={resolvedSecondaryOptions} />\n      )}\n    </>\n  )\n}\n\nfunction Cursor<TDatum>(props: {\n  primary?: boolean\n  options: ResolvedCursorOptions\n}) {\n  const {\n    getOptions,\n    svgRef,\n    gridDimensions,\n    focusedDatumState,\n    primaryAxis,\n    secondaryAxes,\n  } = useChartContext<TDatum>()\n\n  const getTooltipOptions = useGetLatest(props.options)\n\n  const [focusedDatum] = focusedDatumState\n  const latestFocusedDatum = useLatestWhen(focusedDatum, !!focusedDatum)\n\n  const secondaryAxis =\n    secondaryAxes.find(d => d.id === latestFocusedDatum?.secondaryAxisId) ??\n    secondaryAxes[0]\n\n  const axis = props.primary ? primaryAxis : secondaryAxis\n\n  const siblingAxis = props.primary ? secondaryAxis : primaryAxis\n\n  const resolveValue = (d: Datum<TDatum> | null) =>\n    d\n      ? axis.stacked\n        ? d.stackData?.[1]\n        : props.primary\n        ? d.primaryValue\n        : d.secondaryValue\n      : undefined\n\n  const datumValue = resolveValue(focusedDatum)\n\n  React.useEffect(() => {\n    getTooltipOptions()?.onChange?.(datumValue)\n  }, [getTooltipOptions, datumValue])\n\n  const value = props.options.value ?? datumValue\n\n  const latestPropsValue = useLatestWhen(\n    props.options.value,\n    props.options.value != null\n  )\n\n  const latestDatumValue = useLatestWhen(\n    resolveValue(latestFocusedDatum),\n    resolveValue(latestFocusedDatum) != null\n  )\n\n  const latestValue = latestPropsValue ?? latestDatumValue\n\n  // Get the sibling range\n  const siblingRange = siblingAxis.scale.range()\n\n  let x\n  let y\n  let x1\n  let x2\n  let y1\n  let y2\n  let alignPctX\n  let alignPctY\n\n  const bandWidth = axis.axisFamily === 'band' ? axis.scale.bandwidth() : 1\n\n  const show = typeof value !== 'undefined' && !Number.isNaN(value)\n\n  let px = axis.scale(value)\n\n  // Vertical alignment\n  if (axis.isVertical) {\n    y = px\n    y1 = (y ?? 0) - 1\n    y2 = (y ?? 0) + bandWidth\n    if (axis.position === 'left') {\n      x1 = siblingRange[0]\n      x2 = siblingRange[1]\n    } else {\n      x1 = siblingRange[1]\n      x2 = siblingRange[0]\n    }\n  } else {\n    x = px\n    x1 = (x ?? 0) - 1\n    x2 = (x ?? 0) + bandWidth\n    if (axis.position === 'top') {\n      y1 = siblingRange[0]\n      y2 = siblingRange[1]\n    } else {\n      y1 = siblingRange[1]\n      y2 = siblingRange[0]\n    }\n  }\n\n  let lineStartX = Math.min(x1, x2)\n  let lineStartY = Math.min(y1, y2)\n  let lineEndX = Math.max(x1, x2)\n  let lineEndY = Math.max(y1, y2)\n  let lineHeight = Math.max(lineEndY - lineStartY, 0)\n  let lineWidth = Math.max(lineEndX - lineStartX, 0)\n\n  let bubbleX\n  let bubbleY\n\n  // Bubble placement\n  if (axis.isVertical) {\n    if (axis.position === 'left') {\n      bubbleX = lineStartX\n    } else {\n      bubbleX = lineEndX\n    }\n\n    bubbleY = lineStartY + lineHeight / 2\n  } else {\n    if (axis.position === 'top') {\n      bubbleY = lineStartY\n    } else {\n      bubbleY = lineEndY\n    }\n\n    bubbleX = lineStartX + lineWidth / 2\n  }\n\n  // Bubble anchoring\n  if (axis.isVertical) {\n    alignPctY = -50\n    if (axis.position === 'left') {\n      alignPctX = -100\n    } else {\n      alignPctX = 0\n    }\n  } else {\n    alignPctX = -50\n    if (axis.position === 'top') {\n      alignPctY = -100\n    } else {\n      alignPctY = 0\n    }\n  }\n\n  const formattedValue = (axis as AxisTime<any>).formatters.cursor(latestValue)\n\n  const svgRect = useRect(svgRef.current, show)\n\n  const lineRef = React.useRef<HTMLDivElement | null>(null)\n  const bubbleRef = React.useRef<HTMLDivElement | null>(null)\n\n  const latestLineStartX = useLatestWhen(lineStartX, px != null)\n  const latestLineStartY = useLatestWhen(lineStartY, px != null)\n  const latestBubbleX = useLatestWhen(bubbleX, px != null)\n  const latestBubbleY = useLatestWhen(bubbleY, px != null)\n\n  const previousTruePx = usePrevious(px)\n  const immediate = previousTruePx == null && px !== null\n\n  lineStartX = (px != null ? lineStartX : latestLineStartX) ?? NaN\n  lineStartY = (px != null ? lineStartY : latestLineStartY) ?? NaN\n  bubbleX = (px != null ? bubbleX : latestBubbleX) ?? NaN\n  bubbleY = (px != null ? bubbleY : latestBubbleY) ?? NaN\n\n  const lineXSpring = useSpring(\n    lineStartX,\n    [1, 210, 20],\n    () => {\n      if (lineRef.current) {\n        lineRef.current.style.transform = `translate(${lineXSpring.x()}px, ${lineYSpring.x()}px)`\n      }\n    },\n    immediate\n  )\n\n  const lineYSpring = useSpring(\n    lineStartY,\n    [1, 210, 20],\n    () => {\n      if (lineRef.current) {\n        lineRef.current.style.transform = `translate(${lineXSpring.x()}px, ${lineYSpring.x()}px)`\n      }\n    },\n    immediate\n  )\n\n  const bubbleXSpring = useSpring(\n    bubbleX,\n    [1, 210, 20],\n    () => {\n      if (bubbleRef.current) {\n        bubbleRef.current.style.transform = `translate(${bubbleXSpring.x()}px, ${bubbleYSpring.x()}px)`\n      }\n    },\n    immediate\n  )\n\n  const bubbleYSpring = useSpring(\n    bubbleY,\n    [1, 210, 20],\n    () => {\n      if (bubbleRef.current) {\n        bubbleRef.current.style.transform = `translate(${bubbleXSpring.x()}px, ${bubbleYSpring.x()}px)`\n      }\n    },\n    immediate\n  )\n\n  const portalEl = usePortalElement()\n\n  return portalEl\n    ? ReactDOM.createPortal(\n        <div\n          style={{\n            fontFamily: 'sans-serif',\n            pointerEvents: 'none',\n            position: 'absolute',\n            top: 0,\n            left: 0,\n            transform: translate(\n              svgRect.left + gridDimensions.left,\n              svgRect.top + gridDimensions.top\n            ),\n            opacity: show ? 1 : 0,\n            transition: 'opacity .3s ease',\n          }}\n          className=\"Cursor\"\n        >\n          {/* Render the cursor line */}\n          {props.options.showLine ? (\n            <div\n              ref={lineRef}\n              style={{\n                width: `${lineWidth}px`,\n                height: `${lineHeight}px`,\n                position: 'absolute',\n                top: 0,\n                left: 0,\n                background: getLineBackgroundColor(\n                  getOptions().dark ?? false,\n                  bandWidth\n                ),\n              }}\n            />\n          ) : null}\n          {/* Render the cursor bubble */}\n          {props.options.showLabel ? (\n            <div\n              ref={bubbleRef}\n              style={{\n                position: 'absolute',\n                top: 0,\n                left: 0,\n              }}\n            >\n              {/* Render the cursor label */}\n              <div\n                style={{\n                  padding: '5px',\n                  fontSize: '10px',\n                  background: getBackgroundColor(getOptions().dark),\n                  color: getBackgroundColor(!getOptions().dark),\n                  borderRadius: '3px',\n                  position: 'relative',\n                  transform: `translate3d(${alignPctX}%, ${alignPctY}%, 0)`,\n                  whiteSpace: 'nowrap',\n                }}\n              >\n                {formattedValue}\n              </div>\n            </div>\n          ) : null}\n        </div>,\n        portalEl\n      )\n    : null\n}\n"
  },
  {
    "path": "src/components/Tooltip.tsx",
    "content": "import React from 'react'\nimport ReactDOM from 'react-dom'\n\nimport { useAnchor } from '../hooks/useAnchor'\nimport useLatestWhen from '../hooks/useLatestWhen'\nimport usePortalElement from '../hooks/usePortalElement'\nimport usePrevious from '../hooks/usePrevious'\nimport { Datum, ResolvedTooltipOptions, TooltipOptions } from '../types'\n//\nimport useChartContext from '../utils/chartContext'\nimport TooltipRenderer from './TooltipRenderer'\nimport useRect from '../hooks/useRect'\nimport { useSpring } from '../hooks/useSpring'\n\n//\n\nexport function defaultTooltip<TDatum>(\n  options: boolean | TooltipOptions<TDatum> = {}\n): ResolvedTooltipOptions<TDatum> {\n  if (options === true) {\n    options = { show: true }\n  } else if (options === false) {\n    options = { show: false }\n  }\n\n  return {\n    show: true,\n    ...options,\n    align: options.align ?? 'auto',\n    alignPriority: options.alignPriority ?? [\n      'right',\n      'topRight',\n      'bottomRight',\n      'left',\n      'topLeft',\n      'bottomLeft',\n      'top',\n      'bottom',\n    ],\n    padding: options.padding ?? 5,\n    arrowPadding: options.arrowPadding ?? 7,\n    // anchor: options.anchor ?? 'closest',\n    render: options.render ?? TooltipRenderer,\n    showDatumInTooltip: options.showDatumInTooltip ?? (() => true),\n  }\n}\n\nexport default function Tooltip<TDatum>(): React.ReactPortal | null {\n  const {\n    focusedDatumState,\n    getOptions,\n    primaryAxis,\n    secondaryAxes,\n    getDatumStatusStyle,\n    svgRef,\n  } = useChartContext<TDatum>()\n\n  const [focusedDatum] = focusedDatumState\n  const latestFocusedDatum = useLatestWhen(focusedDatum, !!focusedDatum)\n\n  const secondaryAxis =\n    secondaryAxes.find(d => d.id === latestFocusedDatum?.secondaryAxisId) ??\n    secondaryAxes[0]\n\n  const portalEl = usePortalElement()\n\n  const [tooltipEl, setTooltipEl] = React.useState<HTMLDivElement | null>()\n\n  const svgRect = useRect(svgRef.current, !!focusedDatum?.element)\n\n  const anchorEl = React.useMemo(() => {\n    const anchorRect =\n      latestFocusedDatum?.element?.getBoundingClientRect() ?? null\n\n    if (!anchorRect) {\n      return null\n    }\n\n    if (!svgRect) return\n\n    const translateX = anchorRect.left ?? 0\n    const translateY = anchorRect.top ?? 0\n    const width = anchorRect.width ?? 0\n    const height = anchorRect.height ?? 0\n\n    const el = document.createElement('div')\n\n    el.getBoundingClientRect = () =>\n      ({\n        x: translateX,\n        y: translateY,\n        width: width,\n        height: height,\n        top: translateY,\n        left: translateX,\n        bottom: translateY + width,\n        right: translateX + height,\n      } as any)\n\n    return el\n  }, [latestFocusedDatum?.element, svgRect])\n\n  const anchor = useAnchor({\n    show: !!focusedDatum,\n    portalEl,\n    anchorEl,\n    tooltipEl,\n    side: ['right', 'left', 'top', 'bottom'],\n  })\n\n  const previousAnchor = usePrevious(anchor)\n  const latestStableAnchor = useLatestWhen(anchor, !!anchor.fit) ?? anchor\n\n  const { visibility, ...anchorStyle } = latestStableAnchor.style\n\n  const tooltipRef = React.useRef<HTMLDivElement | null>(null)\n\n  const immediate = Number.isNaN(previousAnchor?.style.left)\n\n  const tooltipXSpring = useSpring(\n    anchorStyle.left || 0,\n    [1, 210, 30],\n    () => {\n      if (tooltipRef.current) {\n        tooltipRef.current.style.transform = `translate(${tooltipXSpring.x()}px, ${tooltipYSpring.x()}px)`\n      }\n    },\n    immediate\n  )\n\n  const tooltipYSpring = useSpring(\n    anchorStyle.top || 0,\n    [1, 210, 30],\n    () => {\n      if (tooltipRef.current) {\n        tooltipRef.current.style.transform = `translate(${tooltipXSpring.x()}px, ${tooltipYSpring.x()}px)`\n      }\n    },\n    immediate\n  )\n\n  // const springProps = useSpring({\n  //   ...anchorStyle,\n  //   left: anchorStyle.left || 0,\n  //   top: anchorStyle.top || 0,\n  //   config: { mass: 1, tension: 210, friction: 30 },\n  //   immediate: key => {\n  //     if (['left', 'top'].includes(key)) {\n  //       return Number.isNaN(previousAnchor?.style.left)\n  //     }\n\n  //     return false\n  //   },\n  // })\n\n  const show = getOptions().tooltip.show\n\n  const latestFit = useLatestWhen(anchor.fit, !!anchor.fit)\n\n  return show && portalEl\n    ? ReactDOM.createPortal(\n        <div\n          ref={tooltipRef}\n          style={{\n            position: anchorStyle.position,\n            opacity: !!focusedDatum ? 1 : 0,\n            transition: 'opacity .3s ease',\n          }}\n        >\n          <div\n            ref={el => setTooltipEl(el)}\n            style={{\n              fontFamily: 'sans-serif',\n              ...(latestFit?.startKey === 'left'\n                ? {\n                    padding: '0 10px',\n                  }\n                : {\n                    padding: '10px 0',\n                  }),\n            }}\n          >\n            {getOptions().tooltip.render({\n              getOptions,\n              focusedDatum: latestFocusedDatum,\n              primaryAxis,\n              secondaryAxes,\n              secondaryAxis,\n              getDatumStyle: (datum: Datum<TDatum>) =>\n                getDatumStatusStyle(datum, focusedDatum),\n              anchor,\n            })}\n          </div>\n        </div>,\n        portalEl\n      )\n    : null\n}\n"
  },
  {
    "path": "src/components/TooltipRenderer.tsx",
    "content": "import { sum } from 'd3-array'\nimport React, { CSSProperties } from 'react'\n\nimport { useAnchor } from '../hooks/useAnchor'\nimport useLatestWhen from '../hooks/useLatestWhen'\nimport {\n  Axis,\n  AxisLinear,\n  AxisTime,\n  Datum,\n  ResolvedChartOptions,\n} from '../types'\n\n//\n//\n\nconst showCount = 10\n\nconst triangleSize = 7\n\nconst getBackgroundColor = (dark?: boolean) =>\n  dark ? 'rgba(255,255,255,.9)' : 'rgba(0, 26, 39, 0.9)'\n\nexport type TooltipRendererProps<TDatum> = {\n  focusedDatum: Datum<TDatum> | null\n  getOptions: () => ResolvedChartOptions<TDatum>\n  primaryAxis: Axis<TDatum>\n  secondaryAxes: Axis<TDatum>[]\n  secondaryAxis: Axis<TDatum>\n  getDatumStyle: (datum: Datum<TDatum>) => CSSProperties\n  anchor: ReturnType<typeof useAnchor>\n}\n\nexport default function tooltipRenderer<TDatum>(\n  props: TooltipRendererProps<TDatum>\n) {\n  return <TooltipRenderer {...props} />\n}\n\nfunction TooltipRenderer<TDatum>(props: TooltipRendererProps<TDatum>) {\n  const latestFit = useLatestWhen(props.anchor.fit, !!props.anchor.fit)\n\n  if (!props.focusedDatum) {\n    return null\n  }\n\n  const {\n    primaryAxis,\n    secondaryAxis,\n    getDatumStyle,\n    focusedDatum,\n    secondaryAxes,\n  } = props\n\n  const { tooltip, dark } = props.getOptions()\n\n  const groupDatums = (props.focusedDatum?.tooltipGroup ?? []).filter(\n    datum => tooltip.showDatumInTooltip?.(datum) ?? true\n  )\n\n  const resolvedShowCount = showCount % 2 === 0 ? showCount : showCount + 1\n  const length = groupDatums.length\n\n  // Get the focused series' index\n  const activeIndex = groupDatums.findIndex(d => d === focusedDatum)\n  // Get the start by going back half of the showCount\n  let start = activeIndex > -1 ? activeIndex - resolvedShowCount / 2 : 0\n  // Make sure it's at least 0\n  start = Math.max(start, 0)\n  // Use the start and add the showCount to get the end\n  let end = activeIndex > -1 ? start + resolvedShowCount : length\n  // Don't let the end go passed the length\n  end = Math.min(end, length)\n  // Double check we aren't clipping the start\n  start = Math.max(end - resolvedShowCount, 0)\n  // Slice the datums by start and end\n  const visibleSortedGroupDatums = groupDatums.slice(start, end)\n  // Detect if we have previous items\n  const hasPrevious = start > 0\n  // Or next items\n  const hasNext = end < length\n\n  const finalAlign = `${latestFit?.side}-${latestFit?.align}`\n\n  let arrowPosition\n  let triangleStyles\n\n  if (!arrowPosition) {\n    if (finalAlign === 'left-center') {\n      arrowPosition = 'right'\n    } else if (finalAlign === 'right-center') {\n      arrowPosition = 'left'\n    } else if (finalAlign === 'top-center') {\n      arrowPosition = 'bottom'\n    } else if (finalAlign === 'bottom-center') {\n      arrowPosition = 'top'\n    } else if (finalAlign === 'right-start') {\n      arrowPosition = 'bottomLeft'\n    } else if (finalAlign === 'right-end') {\n      arrowPosition = 'topLeft'\n    } else if (finalAlign === 'left-start') {\n      arrowPosition = 'bottomRight'\n    } else if (finalAlign === 'left-end') {\n      arrowPosition = 'topRight'\n    }\n  }\n\n  const backgroundColor = getBackgroundColor(dark)\n\n  if (arrowPosition === 'bottom') {\n    triangleStyles = {\n      top: '100%',\n      left: '50%',\n      transform: 'translate3d(-50%, 0%, 0)',\n      borderLeft: `${triangleSize * 0.8}px solid transparent`,\n      borderRight: `${triangleSize * 0.8}px solid transparent`,\n      borderTop: `${triangleSize}px solid ${backgroundColor}`,\n    }\n  } else if (arrowPosition === 'top') {\n    triangleStyles = {\n      top: '0%',\n      left: '50%',\n      transform: 'translate3d(-50%, -100%, 0)',\n      borderLeft: `${triangleSize * 0.8}px solid transparent`,\n      borderRight: `${triangleSize * 0.8}px solid transparent`,\n      borderBottom: `${triangleSize}px solid ${backgroundColor}`,\n    }\n  } else if (arrowPosition === 'right') {\n    triangleStyles = {\n      top: '50%',\n      left: '100%',\n      transform: 'translate3d(0%, -50%, 0)',\n      borderTop: `${triangleSize * 0.8}px solid transparent`,\n      borderBottom: `${triangleSize * 0.8}px solid transparent`,\n      borderLeft: `${triangleSize}px solid ${backgroundColor}`,\n    }\n  } else if (arrowPosition === 'left') {\n    triangleStyles = {\n      top: '50%',\n      left: '0%',\n      transform: 'translate3d(-100%, -50%, 0)',\n      borderTop: `${triangleSize * 0.8}px solid transparent`,\n      borderBottom: `${triangleSize * 0.8}px solid transparent`,\n      borderRight: `${triangleSize}px solid ${backgroundColor}`,\n    }\n  } else if (arrowPosition === 'topRight') {\n    triangleStyles = {\n      top: '0%',\n      left: '100%',\n      transform: 'translate3d(-50%, -50%, 0) rotate(-45deg)',\n      borderTop: `${triangleSize * 0.8}px solid transparent`,\n      borderBottom: `${triangleSize * 0.8}px solid transparent`,\n      borderLeft: `${triangleSize * 2}px solid ${backgroundColor}`,\n    }\n  } else if (arrowPosition === 'bottomRight') {\n    triangleStyles = {\n      top: '100%',\n      left: '100%',\n      transform: 'translate3d(-50%, -50%, 0) rotate(45deg)',\n      borderTop: `${triangleSize * 0.8}px solid transparent`,\n      borderBottom: `${triangleSize * 0.8}px solid transparent`,\n      borderLeft: `${triangleSize * 2}px solid ${backgroundColor}`,\n    }\n  } else if (arrowPosition === 'topLeft') {\n    triangleStyles = {\n      top: '0%',\n      left: '0%',\n      transform: 'translate3d(-50%, -50%, 0) rotate(45deg)',\n      borderTop: `${triangleSize * 0.8}px solid transparent`,\n      borderBottom: `${triangleSize * 0.8}px solid transparent`,\n      borderRight: `${triangleSize * 2}px solid ${backgroundColor}`,\n    }\n  } else if (arrowPosition === 'bottomLeft') {\n    triangleStyles = {\n      top: '100%',\n      left: '0%',\n      transform: 'translate3d(-50%, -50%, 0) rotate(-45deg)',\n      borderTop: `${triangleSize * 0.8}px solid transparent`,\n      borderBottom: `${triangleSize * 0.8}px solid transparent`,\n      borderRight: `${triangleSize * 2}px solid ${backgroundColor}`,\n    }\n  } else {\n    triangleStyles = {\n      opacity: 0,\n    }\n  }\n\n  return (\n    <div\n      style={{\n        position: 'relative',\n        fontSize: '10px',\n        padding: '5px',\n        background: getBackgroundColor(dark),\n        color: dark ? 'black' : 'white',\n        borderRadius: '3px',\n      }}\n    >\n      <div\n        style={{\n          position: 'absolute',\n          width: 0,\n          height: 0,\n          ...triangleStyles,\n        }}\n      />\n      <div>\n        <div\n          style={{\n            marginBottom: '3px',\n            textAlign: 'center',\n          }}\n        >\n          {tooltip.groupingMode === 'series' ? (\n            <strong>{focusedDatum.seriesLabel}</strong>\n          ) : tooltip.groupingMode === 'secondary' ? (\n            <strong>\n              {(secondaryAxis as AxisTime<any>).formatters.tooltip(\n                focusedDatum.secondaryValue\n              )}\n            </strong>\n          ) : (\n            <strong>\n              {(primaryAxis as AxisTime<any>).formatters.tooltip(\n                focusedDatum.primaryValue\n              )}\n            </strong>\n          )}\n        </div>\n        <table\n          style={{\n            whiteSpace: 'nowrap',\n          }}\n        >\n          <tbody>\n            {hasPrevious ? (\n              <tr\n                style={{\n                  opacity: 0.8,\n                }}\n              >\n                <td />\n                <td>...</td>\n                <td />\n              </tr>\n            ) : null}\n            {visibleSortedGroupDatums.map((sortedDatum, i) => {\n              const active = sortedDatum === focusedDatum\n\n              const datumSecondaryAxis = secondaryAxes.find(\n                d => d.id === sortedDatum.secondaryAxisId\n              )\n\n              return (\n                <tr\n                  key={i}\n                  style={{\n                    opacity: active ? 1 : 0.8,\n                    fontWeight: active ? 'bold' : undefined,\n                  }}\n                >\n                  <td\n                    style={{\n                      display: 'flex',\n                      alignItems: 'center',\n                      justifyContent: 'center',\n                    }}\n                  >\n                    <svg width=\"14\" height=\"14\">\n                      <circle\n                        cx=\"7\"\n                        cy=\"7\"\n                        r=\"5\"\n                        style={{\n                          ...getDatumStyle(sortedDatum),\n                          stroke: dark ? 'black' : 'white',\n                          strokeWidth: active ? 2 : 1,\n                        }}\n                      />\n                    </svg>\n                  </td>\n                  {tooltip.groupingMode === 'series' ? (\n                    <React.Fragment>\n                      <td>\n                        {(primaryAxis as AxisTime<any>).formatters.tooltip(\n                          sortedDatum.primaryValue\n                        )}\n                        : &nbsp;\n                      </td>\n                      <td\n                        style={{\n                          textAlign: 'right',\n                        }}\n                      >\n                        {(\n                          datumSecondaryAxis as AxisTime<any>\n                        ).formatters.tooltip(sortedDatum.secondaryValue)}\n                      </td>\n                    </React.Fragment>\n                  ) : tooltip.groupingMode === 'secondary' ? (\n                    <React.Fragment>\n                      <td>{sortedDatum.seriesLabel}: &nbsp;</td>\n                      <td\n                        style={{\n                          textAlign: 'right',\n                        }}\n                      >\n                        {(primaryAxis as AxisTime<any>).formatters.tooltip(\n                          sortedDatum.primaryValue\n                        )}\n                      </td>\n                    </React.Fragment>\n                  ) : (\n                    <React.Fragment>\n                      <td>{sortedDatum.seriesLabel}: &nbsp;</td>\n                      <td\n                        style={{\n                          textAlign: 'right',\n                        }}\n                      >\n                        {(\n                          datumSecondaryAxis as AxisTime<any>\n                        ).formatters.tooltip(sortedDatum.secondaryValue)}\n                      </td>\n                    </React.Fragment>\n                  )}\n                </tr>\n              )\n            })}\n            {hasNext ? (\n              <tr\n                style={{\n                  opacity: 0.8,\n                }}\n              >\n                <td />\n                <td>...</td>\n                <td />\n              </tr>\n            ) : null}\n            {(focusedDatum.tooltipGroup ?? []).length > 1\n              ? props.secondaryAxes\n                  .filter(d => d.stacked)\n                  .map((secondaryAxis, i) => {\n                    return (\n                      <tr key={`${secondaryAxis.id}_${i}`}>\n                        <td\n                          style={{\n                            paddingTop: '5px',\n                          }}\n                        >\n                          <div\n                            style={{\n                              width: '12px',\n                              height: '12px',\n                              backgroundColor: dark\n                                ? 'rgba(0, 26, 39, 0.3)'\n                                : 'rgba(255,255,255,.2)',\n                              borderRadius: '50px',\n                            }}\n                          />\n                        </td>\n                        <td\n                          style={{\n                            paddingTop: '5px',\n                          }}\n                        >\n                          {props.secondaryAxes.length > 1\n                            ? secondaryAxis.id ?? `Axis ${i + 1} `\n                            : ''}\n                          Total: &nbsp;\n                        </td>\n                        <td\n                          style={{\n                            paddingTop: '5px',\n                          }}\n                        >\n                          {/* {secondaryAxis.format(\n                  [...focusedDatum.group].reverse()[0].totalValue,\n                  -1\n                )} */}\n                          {(secondaryAxis as AxisLinear<any>).formatters.scale(\n                            sum(\n                              focusedDatum.tooltipGroup ?? [],\n                              d => d.secondaryValue\n                            )\n                          )}\n                        </td>\n                      </tr>\n                    )\n                  })\n              : null}\n          </tbody>\n        </table>\n      </div>\n    </div>\n  )\n}\n"
  },
  {
    "path": "src/components/Voronoi.tsx",
    "content": "import React from 'react'\nimport { Delaunay } from 'd3-delaunay'\n\n//\nimport { Axis, Datum } from '../types'\nimport { translate } from '../utils/Utils'\nimport useChartContext from '../utils/chartContext'\nimport { line } from 'd3-shape'\nimport { getPrimaryGroupLength, getPrimaryLength } from '../seriesTypes/Bar'\n\nexport default function Voronoi<TDatum>() {\n  const { getOptions, focusedDatumState, isInteractingState } =\n    useChartContext<TDatum>()\n\n  const [, setFocusedDatum] = focusedDatumState\n  const [isInteracting] = isInteractingState\n\n  const {\n    onFocusDatum,\n    onClickDatum,\n    tooltip,\n    primaryCursor,\n    secondaryCursor,\n    showVoronoi,\n    interactionMode,\n  } = getOptions()\n\n  const handleFocus = React.useCallback(\n    (datum: Datum<TDatum> | null) => {\n      getOptions().onFocusDatum?.(datum)\n      setFocusedDatum(datum)\n    },\n    [getOptions, setFocusedDatum]\n  )\n\n  const needsVoronoi =\n    isInteracting &&\n    (showVoronoi ||\n      onFocusDatum ||\n      onClickDatum ||\n      tooltip ||\n      primaryCursor ||\n      secondaryCursor)\n\n  if (!needsVoronoi) {\n    return null\n  }\n\n  const props = {\n    handleFocus,\n  }\n\n  if (interactionMode === 'closest') {\n    return <SingleVoronoi {...props} />\n  }\n\n  return <PrimaryVoronoi {...props} />\n}\n\nfunction PrimaryVoronoi<TDatum>({\n  handleFocus,\n}: {\n  handleFocus: (datum: Datum<TDatum> | null) => void\n}) {\n  const {\n    primaryAxis,\n    secondaryAxes,\n    getOptions,\n    gridDimensions,\n    datumsByInteractionGroup,\n  } = useChartContext<TDatum>()\n\n  const stackedVoronoi = secondaryAxes.length === 1 && secondaryAxes[0].stacked\n\n  const useBarPx = secondaryAxes.every(\n    d => d.elementType === 'bar' && !d.stacked\n  )\n\n  return React.useMemo(() => {\n    let preColumns = Array.from(datumsByInteractionGroup.entries())\n      .map(([_, datums]) => datums)\n      .filter(datums => {\n        const datum = datums[0]\n\n        if (!datum) {\n          return\n        }\n\n        const primaryValue = datum.primaryValue\n        return primaryValue !== 'undefined' && primaryValue !== null\n      })\n      .sort((a, b) => {\n        const aAxis = secondaryAxes.find(d => d.id === a[0].secondaryAxisId)!\n        const bAxis = secondaryAxes.find(d => d.id === b[0].secondaryAxisId)!\n\n        const aPx = getPrimary(a[0], primaryAxis, aAxis, useBarPx)\n        const bPx = getPrimary(b[0], primaryAxis, bAxis, useBarPx)\n\n        return aPx - bPx\n      })\n\n    if (primaryAxis.isVertical) {\n      preColumns.reverse()\n    }\n\n    const columns = preColumns.map((datums, i, all) => {\n      const datum = datums[0]\n\n      const prev = all[i - 1]\n      const next = all[i + 1]\n\n      const secondaryAxis = secondaryAxes.find(\n        d => d.id === datum.secondaryAxisId\n      )!\n      const primaryPx = getPrimary(datum, primaryAxis, secondaryAxis, useBarPx)\n\n      let range = primaryAxis?.scale.range() ?? [0, 0]\n\n      let [primaryStart, primaryEnd] = range\n\n      if (prev) {\n        const secondaryAxis = secondaryAxes.find(\n          d => d.id === prev[0].secondaryAxisId\n        )!\n        const prevPx = getPrimary(prev[0], primaryAxis, secondaryAxis, useBarPx)\n        primaryStart = primaryPx - (primaryPx - prevPx) / 2\n      }\n\n      if (next) {\n        const secondaryAxis = secondaryAxes.find(\n          d => d.id === next[0].secondaryAxisId\n        )!\n        const nextPx = getPrimary(next[0], primaryAxis, secondaryAxis, useBarPx)\n        primaryEnd = primaryPx + (nextPx - primaryPx) / 2\n      }\n\n      return {\n        primaryStart,\n        primaryEnd,\n        primaryPx,\n        datumBoundaries: datums\n          .filter(datum => {\n            const secondaryValue = datum.secondaryValue\n            return (\n              typeof secondaryValue !== 'undefined' && secondaryValue !== null\n            )\n          })\n          .map((datum, i, all) => {\n            const prev = all[i - 1]\n            const next = all[i + 1]\n\n            const secondaryAxis = secondaryAxes.find(\n              d => d.id === datum.secondaryAxisId\n            )\n\n            if (stackedVoronoi) {\n              let range = secondaryAxis?.scale.range() ?? [0, 0]\n\n              let stackData = [datum.stackData?.[0], datum.stackData?.[1]]\n\n              if (secondaryAxis?.isVertical) {\n                range.reverse()\n                stackData.reverse()\n              }\n\n              let [secondaryStart, secondaryEnd] = range\n\n              if (prev) {\n                secondaryStart =\n                  secondaryAxis?.scale(stackData[0] ?? NaN) ?? NaN\n              }\n\n              if (next) {\n                secondaryEnd = secondaryAxis?.scale(stackData[1] ?? NaN) ?? NaN\n              }\n\n              return {\n                secondaryStart,\n                secondaryEnd,\n                datum,\n              }\n            }\n\n            const value =\n              secondaryAxis?.scale(\n                secondaryAxis.stacked\n                  ? datum.stackData?.[1]\n                  : datum.secondaryValue\n              ) ?? NaN\n\n            let range = secondaryAxis?.scale.range() ?? [0, 0]\n\n            if (secondaryAxis?.isVertical) {\n              range.reverse()\n            }\n\n            let [secondaryStart, secondaryEnd] = range\n\n            if (prev) {\n              const prevAxis = secondaryAxes.find(\n                d => d.id === prev?.secondaryAxisId\n              )\n              const prevValue =\n                prevAxis?.scale(\n                  prevAxis.stacked ? prev.stackData?.[1] : prev.secondaryValue\n                ) ?? NaN\n              secondaryStart = value - (value - prevValue) / 2\n            }\n\n            if (next) {\n              const nextAxis = secondaryAxes.find(\n                d => d.id === next?.secondaryAxisId\n              )\n              const nextValue =\n                nextAxis?.scale(\n                  nextAxis.stacked ? next.stackData?.[1] : next.secondaryValue\n                ) ?? NaN\n              secondaryEnd = value + (nextValue - value) / 2\n            }\n\n            return {\n              secondaryStart,\n              secondaryEnd,\n              datum,\n            }\n          }),\n      }\n    })\n\n    return (\n      <g\n        {...{\n          onMouseLeave: () => handleFocus(null),\n          style: {\n            transform: translate(gridDimensions.left, gridDimensions.top),\n          },\n        }}\n      >\n        {columns.map((column, i) => {\n          return (\n            <g key={`${column.primaryPx}_${i}`}>\n              {column.datumBoundaries.map((datumBoundary, i) => {\n                const x1 = !primaryAxis.isVertical\n                  ? column.primaryStart\n                  : datumBoundary.secondaryStart\n                const x2 = !primaryAxis.isVertical\n                  ? column.primaryEnd\n                  : datumBoundary.secondaryEnd\n                const y1 = !primaryAxis.isVertical\n                  ? datumBoundary.secondaryStart\n                  : column.primaryStart\n                const y2 = !primaryAxis.isVertical\n                  ? datumBoundary.secondaryEnd\n                  : column.primaryEnd\n\n                const x = Math.min(x1, x2)\n                const y = Math.min(y1, y2)\n                const xEnd = Math.max(x1, x2)\n                const yEnd = Math.max(y1, y2)\n\n                const height = Math.max(yEnd - y, 0)\n                const width = Math.max(xEnd - x, 0)\n\n                return (\n                  <rect\n                    {...{\n                      key: i,\n                      x,\n                      y,\n                      width,\n                      height,\n                      className: 'action-voronoi',\n                      onMouseEnter: () => handleFocus(datumBoundary.datum),\n                      style: {\n                        fill: getOptions().dark\n                          ? '#ffffff33'\n                          : 'rgba(0,0,0,0.2)',\n                        strokeWidth: 1,\n                        stroke: getOptions().dark ? 'white' : 'black',\n                        opacity: getOptions().showVoronoi ? 1 : 0,\n                      },\n                    }}\n                  />\n                )\n              })}\n            </g>\n          )\n        })}\n      </g>\n    )\n  }, [\n    datumsByInteractionGroup,\n    primaryAxis,\n    gridDimensions.left,\n    gridDimensions.top,\n    secondaryAxes,\n    useBarPx,\n    stackedVoronoi,\n    handleFocus,\n    getOptions,\n  ])\n}\n\nconst delaunayLineFn = line()\n\nfunction SingleVoronoi<TDatum>({\n  handleFocus,\n}: {\n  handleFocus: (datum: Datum<TDatum> | null) => void\n}) {\n  const {\n    primaryAxis,\n    series,\n    secondaryAxes,\n    getOptions,\n    gridDimensions,\n    // datumsByInteractionGroup,\n  } = useChartContext<TDatum>()\n\n  let polygons = null\n\n  const voronoiData: { x: number; y: number; datum: Datum<TDatum> }[] = []\n\n  const useBarPx = secondaryAxes.every(\n    d => d.elementType === 'bar' && !d.stacked\n  )\n\n  series.forEach(serie => {\n    serie.datums\n      .filter(datum => {\n        const primaryValue = datum.primaryValue\n        const secondaryValue = datum.secondaryValue\n        return (\n          primaryValue !== 'undefined' &&\n          primaryValue !== null &&\n          secondaryValue !== 'undefined' &&\n          secondaryValue !== null\n        )\n      })\n      .forEach(datum => {\n        const secondaryAxis = secondaryAxes.find(\n          d => d.id === datum.secondaryAxisId\n        )\n        const x = getX(datum, primaryAxis, secondaryAxis!, useBarPx)\n        const y = getY(datum, primaryAxis, secondaryAxis!, useBarPx)\n\n        if (\n          typeof x !== 'number' ||\n          typeof y !== 'number' ||\n          Number.isNaN(y) ||\n          Number.isNaN(x)\n        ) {\n          return\n        }\n\n        voronoiData.push({\n          x,\n          y,\n          datum,\n        })\n      })\n  })\n\n  const delaunay = Delaunay.from(\n    voronoiData,\n    d => Math.max(d.x, 0),\n    d => Math.max(d.y, 0)\n  )\n\n  const voronoi = delaunay.voronoi([\n    0,\n    0,\n    gridDimensions.width,\n    gridDimensions.height,\n  ])\n\n  polygons = voronoi.cellPolygons()\n\n  polygons = Array.from(polygons)\n\n  return (\n    <g\n      {...{\n        onMouseLeave: () => handleFocus(null),\n        style: {\n          transform: translate(gridDimensions.left, gridDimensions.top),\n        },\n      }}\n    >\n      {polygons.map((points, i) => {\n        const index = points.index\n        const datum = voronoiData[index].datum\n        const path = delaunayLineFn(points as any) || undefined\n        return (\n          <path\n            {...{\n              key: i,\n              d: path,\n              className: 'action-voronoi',\n              onMouseEnter: () => handleFocus(datum),\n              style: {\n                fill: getOptions().dark ? '#ffffff33' : 'rgba(0,0,0,0.2)',\n                strokeWidth: 1,\n                stroke: getOptions().dark ? 'white' : 'black',\n                opacity: getOptions().showVoronoi ? 1 : 0,\n              },\n            }}\n          />\n        )\n      })}\n    </g>\n  )\n}\n\nfunction getX<TDatum>(\n  datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>,\n  secondaryAxis: Axis<TDatum>,\n  useBarPx: boolean\n): number {\n  return primaryAxis.isVertical\n    ? getSecondary(datum, secondaryAxis)\n    : getPrimary(datum, primaryAxis, secondaryAxis, useBarPx)\n}\n\nfunction getY<TDatum>(\n  datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>,\n  secondaryAxis: Axis<TDatum>,\n  useBarPx: boolean\n): number {\n  return primaryAxis.isVertical\n    ? getPrimary(datum, primaryAxis, secondaryAxis, useBarPx)\n    : getSecondary(datum, secondaryAxis)\n}\n\nfunction getPrimary<TDatum>(\n  datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>,\n  secondaryAxis: Axis<TDatum>,\n  useBarPx: boolean\n): number {\n  let primary = primaryAxis.scale(datum.primaryValue) ?? NaN\n\n  if (useBarPx && secondaryAxis.elementType === 'bar') {\n    if (!secondaryAxis.stacked) {\n      primary += primaryAxis.seriesBandScale!(datum.seriesIndex) ?? NaN\n      primary += getPrimaryLength(datum, primaryAxis, secondaryAxis) / 2\n    } else {\n      primary += getPrimaryGroupLength(datum, primaryAxis) / 2\n    }\n  }\n\n  return primary\n}\n\nfunction getSecondary<TDatum>(\n  datum: Datum<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  if (secondaryAxis.stacked) {\n    return secondaryAxis.scale(datum.stackData?.[1] ?? NaN) ?? NaN\n  }\n\n  return secondaryAxis.scale(datum.secondaryValue) ?? NaN\n}\n"
  },
  {
    "path": "src/hooks/useAnchor.tsx",
    "content": "import React from 'react'\n\nimport useRect from './useRect'\n\n//\n\n//\n\ntype AlignMode =\n  | 'center'\n  | 'start'\n  | 'end'\n  | 'top'\n  | 'right'\n  | 'bottom'\n  | 'left'\n\ntype Side = 'left' | 'right' | 'top' | 'bottom'\ntype SideOption = Side | `${Side} ${AlignMode}`\ntype SideAlign = [Side, AlignMode]\n\ntype StartKey = 'left' | 'top'\ntype LengthKey = 'width' | 'height'\n\ntype Dims = {\n  left: number\n  top: number\n  right: number\n  bottom: number\n  width: number\n  height: number\n}\n\n// These are the keys used internally to look up and measure\n// different sides of a bounding box within another\nconst sideSchemas = {\n  left: {\n    side: 'left',\n    startKey: 'left',\n    lengthKey: 'width',\n    crossStartKey: 'top',\n    crossLengthKey: 'height',\n    fromEnd: false,\n  },\n  right: {\n    side: 'right',\n    startKey: 'left',\n    lengthKey: 'width',\n    crossStartKey: 'top',\n    crossLengthKey: 'height',\n    fromEnd: true,\n  },\n  top: {\n    side: 'top',\n    startKey: 'top',\n    lengthKey: 'height',\n    crossStartKey: 'left',\n    crossLengthKey: 'width',\n    fromEnd: false,\n  },\n  bottom: {\n    side: 'bottom',\n    startKey: 'top',\n    lengthKey: 'height',\n    crossStartKey: 'left',\n    crossLengthKey: 'width',\n    fromEnd: true,\n  },\n} as const\n\n// This is the final Tootlip component. It's a render prop\n// that lets you attach handlers to elements, and render a tooltip\n// anchored to them in relation to the parent portal container (either the only\n// one defined or the one referenced by Id).\nexport function useAnchor(options: {\n  show: boolean\n  useLargest?: boolean\n  side: SideOption | SideOption[]\n  portalEl: Element | null | undefined\n  anchorEl: Element | null | undefined\n  tooltipEl: Element | null | undefined\n}) {\n  const portalDims = useRect(options.portalEl, options.show)\n  const anchorDims = useRect(options.anchorEl, options.show)\n  const tooltipDims = useRect(options.tooltipEl, options.show)\n\n  const sides = React.useMemo(() => {\n    const preSides = Array.isArray(options.side) ? options.side : [options.side]\n    return preSides.map(alignStr => {\n      const [side, align = 'center'] = alignStr.split(' ') as [Side, AlignMode]\n      const incompatibleSide = !['top', 'right', 'bottom', 'left'].find(\n        d => side === d\n      )\n\n      if (incompatibleSide) {\n        throw new Error(\n          `react-sticker: \"${side}\" is not a valid side! Must be one of ['top', 'right', 'bottom', 'left'].`\n        )\n      }\n\n      const incompatibleAlign = ![\n        'center',\n        'start',\n        'end',\n        'top',\n        'right',\n        'bottom',\n        'left',\n      ].find(d => align === d)\n\n      if (incompatibleAlign) {\n        throw new Error(\n          `react-sticker: \"${align}\" is not a valid side-alignment! Must be one of ['center', 'start', 'end', 'top', 'right', 'bottom', 'left'].`\n        )\n      }\n\n      return [side, align] as [Side, AlignMode]\n    })\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n  }, [JSON.stringify(options.side)])\n\n  // IF we have all of the dimensions needed to calculate\n  // fits, then calculate the fit\n  const ready = portalDims && tooltipDims && anchorDims\n\n  const fit = React.useMemo(\n    () =>\n      ready && options.show\n        ? fitOnBestSide({\n            portalDims,\n            tooltipDims,\n            anchorDims,\n            sides,\n            useLargest: options.useLargest,\n          })\n        : null,\n    [\n      anchorDims,\n      options.show,\n      options.useLargest,\n      portalDims,\n      ready,\n      sides,\n      tooltipDims,\n    ]\n  )\n\n  return {\n    fit,\n    style: {\n      position: 'absolute' as const,\n      visibility: ready ? ('visible' as const) : ('hidden' as const),\n      // The fit styles are applied here from the best fit\n      ...fit?.style,\n    },\n  }\n}\n\n// This function selects the best side for the tooltip by using\n// the ranked fits.\nfunction fitOnBestSide({\n  portalDims,\n  tooltipDims,\n  anchorDims,\n  sides,\n  useLargest,\n}: {\n  portalDims: Dims\n  tooltipDims: Dims\n  anchorDims: Dims\n  sides: SideAlign[]\n  useLargest?: boolean\n}) {\n  const fits = sides.map(([side, align]) =>\n    measureFit({\n      ...sideSchemas[side],\n      align,\n      portalDims,\n      tooltipDims,\n      anchorDims,\n    })\n  )\n\n  if (useLargest) {\n    fits.sort((a, b) => b.fitRatio - a.fitRatio)\n    return fits[0]\n  }\n\n  return fits.find(fit => fit.fitRatio >= 1) || fits[0]\n}\n\n// This function takes a side and bunch of calculated dimensions from\n// the portal, tooltip and target. Then it returns\n// the percentage fit and the style to achieve this specific fit\nfunction measureFit({\n  side,\n  align,\n  startKey,\n  lengthKey,\n  crossStartKey,\n  crossLengthKey,\n  fromEnd,\n  portalDims,\n  tooltipDims,\n  anchorDims,\n}: {\n  side: Side\n  align: AlignMode\n  startKey: StartKey\n  lengthKey: LengthKey\n  crossStartKey: StartKey\n  crossLengthKey: LengthKey\n  fromEnd: boolean\n  portalDims: Dims\n  tooltipDims: Dims\n  anchorDims: Dims\n}) {\n  const parentStart = portalDims[startKey]\n  const parentLength = portalDims[lengthKey]\n  const crossParentStart = portalDims[crossStartKey]\n  const crossParentLength = portalDims[crossLengthKey]\n  const anchorStart = anchorDims[startKey] - portalDims[startKey]\n  const anchorLength = anchorDims[lengthKey]\n  const crossAnchorStart = anchorDims[crossStartKey]\n  const crossAnchorLength = anchorDims[crossLengthKey]\n  const crossAnchorWidth = anchorDims[crossLengthKey]\n  const targetLength = tooltipDims[lengthKey]\n  const crossTargetLength = tooltipDims[crossLengthKey]\n\n  let targetStart: number\n  let fitRatio: number\n\n  if (!fromEnd) {\n    targetStart = anchorStart - targetLength\n    fitRatio = Math.min(anchorStart / targetLength)\n  } else {\n    targetStart = anchorStart + anchorLength\n    fitRatio = (parentLength - (anchorStart + anchorLength)) / targetLength\n  }\n\n  targetStart = Math.max(parentStart, Math.min(targetStart, parentLength))\n\n  let crossTargetStart: number\n\n  if (startKey === 'left') {\n    if (align === 'top') {\n      align = 'start'\n    } else if (align === 'bottom') {\n      align = 'end'\n    }\n  } else {\n    if (align === 'left') {\n      align = 'start'\n    } else if (align === 'right') {\n      align = 'end'\n    }\n  }\n\n  if (!['start', 'center', 'end'].includes(align)) {\n    align = 'center'\n  }\n\n  if (align === 'start') {\n    crossTargetStart = crossAnchorStart\n  } else if (align === 'end') {\n    crossTargetStart = crossAnchorStart + crossAnchorWidth - crossTargetLength\n  } else {\n    crossTargetStart =\n      crossAnchorStart + crossAnchorLength / 2 - crossTargetLength / 2\n  }\n\n  crossTargetStart = Math.max(\n    crossParentStart,\n    Math.min(crossTargetStart, crossParentLength - crossTargetLength)\n  )\n\n  return {\n    side,\n    align,\n    startKey,\n    lengthKey,\n    crossStartKey,\n    crossLengthKey,\n    fromEnd,\n    portalDims,\n    tooltipDims,\n    anchorDims,\n    fitRatio,\n    style: {\n      [startKey]: targetStart,\n      [crossStartKey]: crossTargetStart,\n    } as Record<StartKey, number>,\n  }\n}\n"
  },
  {
    "path": "src/hooks/useChanged.ts",
    "content": "import usePrevious from './usePrevious'\n\nexport default function useChanged(val: any) {\n  const previous = usePrevious(val)\n  return val !== previous\n}\n"
  },
  {
    "path": "src/hooks/useGetLatest.ts",
    "content": "import React from 'react'\n\nexport default function useGetLatest<T>(obj: T) {\n  const ref = React.useRef<T>(obj)\n  const getterRef = React.useRef<() => T>()\n\n  ref.current = obj\n  if (!getterRef.current) {\n    getterRef.current = () => ref.current\n  }\n\n  return getterRef.current\n}\n"
  },
  {
    "path": "src/hooks/useIsScrolling.ts",
    "content": "import * as React from 'react'\nimport ReactDOM from 'react-dom'\n\nexport const unstable_batchedUpdates = ReactDOM.unstable_batchedUpdates\n\nimport useIsomorphicLayoutEffect from './useIsomorphicLayoutEffect'\n\nexport default function useIsScrolling(debounce: number) {\n  const rerender = React.useReducer(() => ({}), {})[1]\n\n  const ref = React.useRef(false)\n\n  useIsomorphicLayoutEffect(() => {\n    let timeout: ReturnType<typeof setTimeout>\n\n    const cb = () => {\n      if (!ref.current) {\n        ref.current = true\n        rerender()\n      }\n\n      clearTimeout(timeout)\n\n      timeout = setTimeout(() => {\n        if (ref.current) {\n          ref.current = false\n          rerender()\n        }\n      }, debounce)\n    }\n\n    document.addEventListener('scroll', cb, true)\n\n    return () => {\n      clearTimeout(timeout)\n      document.removeEventListener('scroll', cb)\n    }\n  }, [debounce])\n\n  return ref.current\n}\n"
  },
  {
    "path": "src/hooks/useIsomorphicLayoutEffect.ts",
    "content": "import React from 'react'\n\nexport default typeof window !== 'undefined'\n  ? React.useLayoutEffect\n  : React.useEffect\n"
  },
  {
    "path": "src/hooks/useLatestWhen.ts",
    "content": "import React from 'react'\n\nexport default function useLatestWhen<T>(obj: T, when: boolean = true) {\n  const ref = React.useRef<T | null>(when ? obj : null)\n\n  if (when) {\n    ref.current = obj\n  }\n\n  return ref.current\n}\n"
  },
  {
    "path": "src/hooks/usePortalElement.ts",
    "content": "import * as React from 'react'\n\nimport useIsomorphicLayoutEffect from './useIsomorphicLayoutEffect'\n\nexport default function usePortalElement() {\n  const [portalEl, setPortalEl] = React.useState<HTMLDivElement | null>()\n\n  useIsomorphicLayoutEffect(() => {\n    if (!portalEl) {\n      let element = document.getElementById(\n        'react-charts-portal'\n      ) as HTMLDivElement\n\n      if (!element) {\n        element = document.createElement('div')\n\n        element.setAttribute('id', 'react-charts-portal')\n\n        Object.assign(element.style, {\n          pointerEvents: 'none',\n          position: 'fixed',\n          left: 0,\n          right: 0,\n          top: 0,\n          bottom: 0,\n          'z-index': 99999999999,\n        })\n\n        document.body.append(element)\n      }\n\n      setPortalEl(element)\n    }\n  })\n\n  return portalEl\n}\n"
  },
  {
    "path": "src/hooks/usePrevious.ts",
    "content": "import React from 'react'\n\nimport useIsomorphicLayoutEffect from './useIsomorphicLayoutEffect'\n\nexport default function usePrevious<T>(val: T) {\n  const ref = React.useRef<T>()\n\n  useIsomorphicLayoutEffect(() => {\n    ref.current = val\n  }, [val])\n\n  return ref.current\n}\n"
  },
  {
    "path": "src/hooks/useRect.ts",
    "content": "import React from 'react'\n\nexport default function useRect(\n  element: Element | null | undefined,\n  enabled: boolean\n): DOMRect {\n  const rerender = React.useReducer(() => ({}), [])[1]\n\n  const rectRef = React.useRef<DOMRect>({\n    width: 0,\n    height: 0,\n    x: 0,\n    y: 0,\n    left: 0,\n    top: 0,\n    right: 0,\n    bottom: 0,\n  } as DOMRect)\n\n  const measure = React.useCallback(() => {\n    if (element) {\n      rectRef.current = element.getBoundingClientRect()\n    }\n  }, [element])\n\n  if (!rectRef.current) {\n    measure()\n  }\n\n  React.useEffect(() => {\n    if (!element || !enabled) {\n      return\n    }\n\n    const cb = () => {\n      measure()\n      rerender()\n    }\n\n    document.addEventListener('scroll', cb, true)\n\n    return () => {\n      document.removeEventListener('scroll', cb, true)\n    }\n  }, [element, enabled, measure, rerender])\n\n  React.useEffect(() => {\n    if (!element || !enabled) {\n      return\n    }\n\n    measure()\n    rerender()\n\n    const observer = new ResizeObserver(() => {\n      measure()\n      rerender()\n    })\n\n    observer.observe(element as Element)\n\n    return () => {\n      observer.unobserve(element as Element)\n    }\n  }, [element, enabled, measure, rerender])\n\n  return rectRef.current\n}\n"
  },
  {
    "path": "src/hooks/useSpring.ts",
    "content": "import React from 'react'\nimport { Spring } from '../utils/spring'\nimport useGetLatest from './useGetLatest'\n\nexport function useSpring(\n  value: number,\n  config: [number, number, number],\n  cb: (x: number) => void,\n  immediate?: boolean,\n  _debug?: boolean\n) {\n  const springRef = React.useRef(new Spring(value, ...config))\n  const getValue = useGetLatest(value)\n\n  const [startRaf, stopRaf] = useRaf(() => {\n    cb(springRef.current.x())\n    return springRef.current.done()\n  })\n\n  const prevRef = React.useRef<any>()\n  const changed = prevRef.current !== value\n\n  React.useEffect(() => {\n    if (changed) {\n      if (immediate) {\n        springRef.current.snap(getValue())\n        startRaf()\n        return\n      }\n      springRef.current.setEnd(value)\n      startRaf()\n    }\n\n    prevRef.current = value\n  })\n\n  React.useEffect(() => {\n    return () => {\n      stopRaf()\n    }\n  }, [stopRaf])\n\n  return springRef.current\n}\n\nexport function useRaf(callback: () => any) {\n  const raf = React.useRef<number | null>(null)\n  const rafCallback = React.useRef(callback)\n  rafCallback.current = callback\n  const tick = React.useCallback(() => {\n    if (rafCallback.current()) return\n    raf.current = requestAnimationFrame(tick)\n  }, [])\n\n  return [\n    React.useMemo(() => tick, [tick]),\n    React.useMemo(\n      () => () => raf.current && cancelAnimationFrame(raf.current),\n      []\n    ),\n  ]\n}\n\n// Test\n"
  },
  {
    "path": "src/index.ts",
    "content": "export { Chart } from './components/Chart'\nexport * from './types'\n"
  },
  {
    "path": "src/seriesTypes/Bar.tsx",
    "content": "import React from 'react'\n\nimport { Axis, AxisBand, Datum, Series } from '../types'\nimport { translate } from '../utils/Utils'\nimport useChartContext from '../utils/chartContext'\n\n//\n\nexport default function BarComponent<TDatum>({\n  primaryAxis,\n  secondaryAxis,\n  series: allSeries,\n}: {\n  primaryAxis: Axis<TDatum>\n  secondaryAxis: Axis<TDatum>\n  series: Series<TDatum>[]\n}) {\n  const {\n    getSeriesStatusStyle,\n    getDatumStatusStyle,\n    focusedDatumState,\n    gridDimensions,\n  } = useChartContext<TDatum>()\n\n  const [focusedDatum] = focusedDatumState\n\n  const xAxis = primaryAxis.isVertical ? secondaryAxis : primaryAxis\n  const yAxis = primaryAxis.isVertical ? primaryAxis : secondaryAxis\n\n  return (\n    <g\n      style={{\n        transform: translate(gridDimensions.left, gridDimensions.top),\n      }}\n    >\n      {allSeries.map((series, i) => {\n        const style = getSeriesStatusStyle(series, focusedDatum)\n\n        return (\n          <g key={`lines-${i}`}>\n            {series.datums.map((datum, i) => {\n              const dataStyle = getDatumStatusStyle(datum, focusedDatum)\n\n              const [x, width] = clampPxToAxis(\n                getRectX(datum, primaryAxis, secondaryAxis) ?? NaN,\n                getWidth(datum, primaryAxis, secondaryAxis) ?? NaN,\n                xAxis\n              )\n              const [y, height] = clampPxToAxis(\n                getRectY(datum, primaryAxis, secondaryAxis) ?? NaN,\n                getHeight(datum, primaryAxis, secondaryAxis) ?? NaN,\n                yAxis\n              )\n\n              return (\n                <rect\n                  {...{\n                    ref: el => {\n                      datum.element = el\n                    },\n                    key: i,\n                    x,\n                    y,\n                    width,\n                    height,\n                    style: {\n                      strokeWidth: 0,\n                      ...style,\n                      ...style.rectangle,\n                      ...dataStyle,\n                      ...dataStyle.rectangle,\n                    },\n                  }}\n                />\n              )\n            })}\n          </g>\n        )\n      })}\n    </g>\n  )\n}\n\nfunction getWidth<TDatum>(\n  datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  return primaryAxis.isVertical\n    ? getSecondaryLength(datum, secondaryAxis)\n    : getPrimaryLength(datum, primaryAxis, secondaryAxis)\n}\n\nfunction getHeight<TDatum>(\n  datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  return primaryAxis.isVertical\n    ? getPrimaryLength(datum, primaryAxis, secondaryAxis)\n    : getSecondaryLength(datum, secondaryAxis)\n}\n\nexport function getPrimaryGroupLength<TDatum>(\n  _datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>\n) {\n  return Math.max(primaryAxis.primaryBandScale!.bandwidth(), 1)\n}\n\nexport function getPrimaryLength<TDatum>(\n  _datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>,\n  secondaryAxis: Axis<TDatum>\n) {\n  if (primaryAxis.axisFamily === 'band') {\n    const bandWidth = secondaryAxis.stacked\n      ? primaryAxis.scale.bandwidth()\n      : primaryAxis.seriesBandScale.bandwidth()\n\n    return Math.min(\n      Math.max(bandWidth, primaryAxis.minBandSize ?? 1),\n      primaryAxis.maxBandSize ?? 99999999\n    )\n  }\n\n  return Math.max(\n    secondaryAxis.stacked\n      ? primaryAxis.primaryBandScale!.bandwidth()\n      : primaryAxis.seriesBandScale!.bandwidth(),\n    1\n  )\n}\n\nfunction getSecondaryLength<TDatum>(\n  datum: Datum<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  const secondary = [\n    getSecondaryStart(datum, secondaryAxis),\n    getSecondary(datum, secondaryAxis),\n  ]\n\n  return Math.abs(secondary[1] - secondary[0])\n}\n\nfunction getRectX<TDatum>(\n  datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  return primaryAxis.isVertical\n    ? getSecondaryStart(datum, secondaryAxis)\n    : getPrimary(datum, primaryAxis, secondaryAxis)\n}\n\nfunction getRectY<TDatum>(\n  datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  return primaryAxis.isVertical\n    ? getPrimary(datum, primaryAxis, secondaryAxis)\n    : getSecondary(datum, secondaryAxis)\n}\n\nexport function getPrimary<TDatum>(\n  datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  let primary = primaryAxis.scale(datum.primaryValue) ?? NaN\n\n  if (primaryAxis.axisFamily !== 'band') {\n    primary -= getPrimaryGroupLength(datum, primaryAxis) / 2\n  }\n\n  if (!secondaryAxis.stacked) {\n    primary =\n      primary +\n      ((primaryAxis as AxisBand<any>).seriesBandScale(datum.seriesIndex) ?? NaN)\n  }\n\n  return primary\n}\n\nfunction getSecondaryStart<TDatum>(\n  datum: Datum<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  if (secondaryAxis.stacked) {\n    return secondaryAxis.scale(datum.stackData?.[0] ?? NaN) ?? NaN\n  }\n\n  return (\n    secondaryAxis.scale(datum.secondaryValue < 0 ? datum.secondaryValue : 0) ??\n    NaN\n  )\n}\n\nfunction getSecondary<TDatum>(\n  datum: Datum<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  if (secondaryAxis.stacked) {\n    return secondaryAxis.scale(datum.stackData?.[1] ?? NaN) ?? NaN\n  }\n\n  return (\n    secondaryAxis.scale(datum.secondaryValue < 0 ? 0 : datum.secondaryValue) ??\n    NaN\n  )\n}\n\nfunction clampPxToAxis<TDatum>(\n  startPx: number,\n  lengthPx: number,\n  axis: Axis<TDatum>\n) {\n  const range = axis.scale.range()\n\n  if (axis.isVertical) {\n    range.reverse()\n  }\n\n  const safe = (num: number) => Math.max(range[0], Math.min(num, range[1]))\n\n  const safeStart = safe(startPx)\n  const safeEnd = safe(startPx + lengthPx)\n  const safeLength = safeEnd - safeStart\n\n  return [safeStart, safeLength] as const\n}\n"
  },
  {
    "path": "src/seriesTypes/Line.tsx",
    "content": "import { area, line } from 'd3-shape'\nimport React from 'react'\n\nimport { Axis, Series, Datum } from '../types'\nimport { isDefined, translate } from '../utils/Utils'\nimport useChartContext from '../utils/chartContext'\n//\nimport { monotoneX } from '../utils/curveMonotone'\n\nexport default function Line<TDatum>({\n  primaryAxis,\n  secondaryAxis,\n  series: allSeries,\n}: {\n  primaryAxis: Axis<TDatum>\n  secondaryAxis: Axis<TDatum>\n  series: Series<TDatum>[]\n}) {\n  const {\n    getSeriesStatusStyle,\n    getDatumStatusStyle,\n    focusedDatumState,\n    gridDimensions,\n  } = useChartContext<TDatum>()\n\n  const curve = secondaryAxis.curve ?? monotoneX\n\n  const [focusedDatum] = focusedDatumState\n\n  return (\n    <g\n      style={{\n        transform: translate(gridDimensions.left, gridDimensions.top),\n      }}\n    >\n      {allSeries.map((series, i) => {\n        const style = getSeriesStatusStyle(series, focusedDatum)\n\n        let areaPath: null | string = null\n\n        if (secondaryAxis.elementType === 'area') {\n          const _x = (datum: Datum<TDatum>) => getPrimary(datum, primaryAxis)\n          const _y1 = (datum: Datum<TDatum>) =>\n            clampPxToAxis(\n              getSecondaryStart(datum, secondaryAxis),\n              secondaryAxis\n            )\n          const _y2 = (datum: Datum<TDatum>) =>\n            clampPxToAxis(getSecondary(datum, secondaryAxis), secondaryAxis)\n          const areaFn = area<Datum<TDatum>>(_x, _y1, _y2).curve(curve)\n\n          areaFn.defined(datum =>\n            [_x(datum), _y1(datum), _y2(datum)].every(isDefined)\n          )\n\n          areaPath = areaFn(series.datums)\n        }\n\n        const _x = (datum: Datum<TDatum>) => getPrimary(datum, primaryAxis)\n        const _y = (datum: Datum<TDatum>) => getSecondary(datum, secondaryAxis)\n        const lineFn = line<Datum<TDatum>>(_x, _y).curve(curve)\n        lineFn.defined(datum => [_x(datum), _y(datum)].every(isDefined))\n\n        const linePath =\n          secondaryAxis.elementType === 'area' ||\n          secondaryAxis.elementType === 'line'\n            ? lineFn(series.datums) ?? undefined\n            : undefined\n\n        const showDatumElements =\n          secondaryAxis.showDatumElements ??\n          (secondaryAxis.elementType === 'bubble' || 'onFocus')\n\n        return (\n          <g key={`lines-${i}`}>\n            {areaPath ? (\n              <path\n                d={areaPath}\n                style={{\n                  strokeWidth: 2,\n                  opacity: 0.5,\n                  ...style,\n                  ...style.area,\n                }}\n              />\n            ) : null}\n            {linePath ? (\n              <path\n                d={linePath}\n                style={{\n                  strokeWidth: 2,\n                  ...style,\n                  ...style.line,\n                  fill: 'none',\n                }}\n              />\n            ) : null}\n            {series.datums.map((datum, i) => {\n              const dataStyle = getDatumStatusStyle(datum, focusedDatum)\n\n              const radius =\n                showDatumElements === 'onFocus'\n                  ? datum === focusedDatum\n                    ? 4\n                    : 0\n                  : 2\n\n              const show =\n                showDatumElements === 'onFocus'\n                  ? datum === focusedDatum\n                  : secondaryAxis.showDatumElements ??\n                    secondaryAxis.elementType === 'bubble'\n\n              return (\n                <circle\n                  key={i}\n                  ref={el => {\n                    datum.element = el\n                  }}\n                  cx={getX(datum, primaryAxis, secondaryAxis) || 0}\n                  cy={getY(datum, primaryAxis, secondaryAxis) || 0}\n                  style={{\n                    // @ts-ignore\n                    r: radius,\n                    transition: 'all .3s ease-out',\n                    ...style,\n                    ...style.circle,\n                    ...dataStyle,\n                    ...dataStyle.circle,\n                    ...(!show ? { opacity: 0 } : {}),\n                  }}\n                />\n              )\n            })}\n          </g>\n        )\n      })}\n    </g>\n  )\n}\n\nfunction getX<TDatum>(\n  datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  return primaryAxis.isVertical\n    ? getSecondary(datum, secondaryAxis)\n    : getPrimary(datum, primaryAxis)\n}\n\nfunction getY<TDatum>(\n  datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  return primaryAxis.isVertical\n    ? getPrimary(datum, primaryAxis)\n    : getSecondary(datum, secondaryAxis)\n}\n\nfunction getPrimary<TDatum>(\n  datum: Datum<TDatum>,\n  primaryAxis: Axis<TDatum>\n): number {\n  let primary = primaryAxis.scale(datum.primaryValue) ?? NaN\n\n  if (primaryAxis.axisFamily === 'band') {\n    primary += primaryAxis.scale.bandwidth() / 2\n  }\n\n  return primary\n}\n\nfunction getSecondary<TDatum>(\n  datum: Datum<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  if (secondaryAxis.stacked) {\n    return secondaryAxis.scale(datum.stackData?.[1] ?? NaN) ?? NaN\n  }\n\n  return secondaryAxis.scale(datum.secondaryValue) ?? NaN\n}\n\nfunction getSecondaryStart<TDatum>(\n  datum: Datum<TDatum>,\n  secondaryAxis: Axis<TDatum>\n): number {\n  if (secondaryAxis.stacked) {\n    return secondaryAxis.scale(datum.stackData?.[0] ?? NaN) ?? NaN\n  }\n\n  return secondaryAxis.scale(0) ?? NaN\n}\n\nfunction clampPxToAxis<TDatum>(px: number, axis: Axis<TDatum>) {\n  const range = axis.scale.range()\n  if (axis.isVertical) {\n    range.reverse()\n  }\n\n  return Math.max(range[0], Math.min(px, range[1]))\n}\n"
  },
  {
    "path": "src/types.ts",
    "content": "import { ScaleBand, ScaleLinear, ScaleTime } from 'd3-scale'\nimport { CurveFactory, stackOffsetNone } from 'd3-shape'\nimport React, { CSSProperties, RefObject } from 'react'\nimport * as TSTB from 'ts-toolbelt'\n\nimport { TooltipRendererProps } from './components/TooltipRenderer'\n\nexport type ChartOptions<TDatum> = {\n  data: UserSerie<TDatum>[]\n  primaryAxis: AxisOptions<TDatum>\n  secondaryAxes: AxisOptions<TDatum>[]\n  padding?:\n  | number\n  | {\n    left?: number\n    right?: number\n    top?: number\n    bottom?: number\n  }\n  getSeriesStyle?: (\n    series: Series<TDatum>,\n    status: SeriesFocusStatus\n  ) => SeriesStyles\n  getDatumStyle?: (\n    datum: Datum<TDatum>,\n    status: DatumFocusStatus\n  ) => DatumStyles\n  getSeriesOrder?: (series: Series<TDatum>[]) => Series<TDatum>[]\n  interactionMode?: InteractionMode\n  showVoronoi?: boolean\n  showDebugAxes?: boolean\n  memoizeSeries?: boolean\n  defaultColors?: string[]\n  initialWidth?: number\n  initialHeight?: number\n  brush?: {\n    style?: CSSProperties\n    onSelect?: (selection: {\n      pointer: Pointer\n      start: unknown\n      end: unknown\n    }) => void\n  }\n  onFocusDatum?: (datum: Datum<TDatum> | null) => void\n  onClickDatum?: (\n    datum: Datum<TDatum> | null,\n    event: React.MouseEvent<SVGSVGElement, MouseEvent>\n  ) => void\n  dark?: boolean\n  renderSVG?: () => React.ReactNode\n  primaryCursor?: boolean | CursorOptions\n  secondaryCursor?: boolean | CursorOptions\n  tooltip?: boolean | TooltipOptions<TDatum>\n  useIntersectionObserver?: boolean\n  intersectionObserverRootMargin?:\n  | `${number}px`\n  | `${number}px ${number}px`\n  | `${number}px ${number}px ${number}px ${number}px`\n}\n\nexport type RequiredChartOptions<TDatum> = TSTB.Object.Required<\n  ChartOptions<TDatum>,\n  | 'getSeriesOrder'\n  | 'interactionMode'\n  | 'tooltipMode'\n  | 'showVoronoi'\n  | 'defaultColors'\n  | 'initialWidth'\n  | 'initialHeight'\n  | 'useIntersectionObserver'\n  | 'intersectionObserverThreshold'\n  | 'primaryCursor'\n  | 'secondaryCursor'\n  | 'padding'\n>\n\nexport type ResolvedChartOptions<TDatum> = Omit<\n  RequiredChartOptions<TDatum>,\n  'tooltip'\n> & {\n  tooltip: ResolvedTooltipOptions<TDatum>\n}\n\nexport type ChartContextValue<TDatum> = {\n  getOptions: () => ResolvedChartOptions<TDatum>\n  gridDimensions: GridDimensions\n  primaryAxis: Axis<TDatum>\n  secondaryAxes: Axis<TDatum>[]\n  series: Series<TDatum>[]\n  orderedSeries: Series<TDatum>[]\n  datumsByInteractionGroup: Map<any, Datum<TDatum>[]>\n  datumsByTooltipGroup: Map<any, Datum<TDatum>[]>\n  width: number\n  height: number\n  svgRef: RefObject<SVGSVGElement>\n  getSeriesStatusStyle: (\n    series: Series<TDatum>,\n    focusedDatum: Datum<TDatum> | null\n  ) => SeriesStyles\n  getDatumStatusStyle: (\n    datum: Datum<TDatum>,\n    focusedDatum: Datum<TDatum> | null\n  ) => DatumStyles\n  axisDimensionsState: [\n    AxisDimensions,\n    React.Dispatch<React.SetStateAction<AxisDimensions>>\n  ]\n  focusedDatumState: [\n    Datum<TDatum> | null,\n    React.Dispatch<React.SetStateAction<Datum<TDatum> | null>>\n  ]\n  isInteractingState: [boolean, React.Dispatch<React.SetStateAction<boolean>>]\n}\n\nexport type TooltipOptions<TDatum> = {\n  align?: AlignMode\n  alignPriority?: AlignPosition[]\n  padding?: number\n  arrowPadding?: number\n  groupingMode?: TooltipGroupingMode\n  show?: boolean\n  // anchor?: AnchorMode\n  // arrowPosition?: AlignPosition\n  render?: (props: TooltipRendererProps<TDatum>) => React.ReactNode\n  // formatSecondary?: (d: unknown) => string | number\n  // formatTertiary?: (d: unknown) => string | number\n  invert?: boolean,\n  showDatumInTooltip?: (datum: Datum<TDatum>) => boolean\n}\n\nexport type ResolvedTooltipOptions<TDatum> = TSTB.Object.Required<\n  TooltipOptions<TDatum>,\n  'align' | 'alignPriority' | 'padding' | 'arrowPadding' | 'anchor' | 'render'\n>\n\nexport type SeriesStyles = CSSProperties & {\n  area?: CSSProperties\n  line?: CSSProperties\n  circle?: CSSProperties\n  rectangle?: CSSProperties\n}\n\nexport type DatumStyles = CSSProperties & {\n  area?: CSSProperties\n  line?: CSSProperties\n  circle?: CSSProperties\n  rectangle?: CSSProperties\n}\n\nexport type Position = 'top' | 'right' | 'bottom' | 'left'\n\nexport type InteractionMode = 'closest' | 'primary'\nexport type TooltipGroupingMode = 'single' | 'primary' | 'secondary' | 'series'\n\nexport type AlignMode =\n  | 'auto'\n  | 'right'\n  | 'topRight'\n  | 'bottomRight'\n  | 'left'\n  | 'topLeft'\n  | 'bottomLeft'\n  | 'top'\n  | 'bottom'\n  | 'center'\n\nexport type AlignPosition =\n  | 'right'\n  | 'topRight'\n  | 'bottomRight'\n  | 'left'\n  | 'topLeft'\n  | 'bottomLeft'\n  | 'top'\n  | 'bottom'\n\nexport type AxisType = 'ordinal' | 'time' | 'localTime' | 'linear' | 'log'\n\nexport type AnchorMode =\n  | 'pointer'\n  | 'closest'\n  | 'center'\n  | 'top'\n  | 'bottom'\n  | 'left'\n  | 'right'\n  | 'gridTop'\n  | 'gridBottom'\n  | 'gridLeft'\n  | 'gridRight'\n  | 'gridCenter'\n\nexport type Side = 'left' | 'right' | 'top' | 'bottom'\n\ntype PointerBase = {\n  x: number\n  y: number\n  svgHovered: boolean\n}\n\nexport type PointerUnpressed = PointerBase & {\n  dragging: false\n}\n\nexport type PointerPressed = PointerBase & {\n  dragging: true\n  startX: number\n  startY: number\n}\n\nexport type Pointer = PointerUnpressed | PointerPressed\n\nexport type ChartOffset = {\n  left: number\n  top: number\n  width: number\n  height: number\n}\n\nexport type AxisDimension = {\n  paddingLeft: number\n  paddingRight: number\n  paddingTop: number\n  paddingBottom: number\n  width: number\n  height: number\n}\n\nexport type AxisDimensions = {\n  left: Record<string, AxisDimension>\n  right: Record<string, AxisDimension>\n  top: Record<string, AxisDimension>\n  bottom: Record<string, AxisDimension>\n}\n\nexport type AxisOptionsBase = {\n  primaryAxisId?: string\n  elementType?: 'line' | 'area' | 'bar' | 'bubble'\n  showDatumElements?: boolean | 'onFocus'\n  curve?: CurveFactory\n  invert?: boolean\n  position?: Position\n  minTickPaddingForRotation?: number\n  tickLabelRotationDeg?: number\n  tickCount?: number\n  shouldNice?: boolean\n  innerBandPadding?: number\n  outerBandPadding?: number\n  innerSeriesBandPadding?: number\n  outerSeriesBandPadding?: number\n  minBandSize?: number\n  maxBandSize?: number\n  minDomainLength?: number\n  showGrid?: boolean\n  show?: boolean\n  stacked?: boolean\n  stackOffset?: typeof stackOffsetNone\n  id?: string | number\n  styles?: CSSProperties & {\n    line?: CSSProperties\n    tick?: CSSProperties\n  }\n}\n\nexport type AxisTimeOptions<TDatum> = AxisOptionsBase & {\n  scaleType?: 'time' | 'localTime'\n  getValue: (datum: TDatum) => ChartValue<Date>\n  min?: Date\n  max?: Date\n  hardMin?: Date\n  hardMax?: Date\n  padBandRange?: boolean\n  formatters?: {\n    scale?: (\n      value: Date,\n      formatters: AxisTimeOptions<TDatum>['formatters']\n    ) => string\n    tooltip?: (\n      value: Date,\n      formatters: AxisTimeOptions<TDatum>['formatters']\n    ) => React.ReactNode\n    cursor?: (\n      value: Date,\n      formatters: AxisTimeOptions<TDatum>['formatters']\n    ) => React.ReactNode\n  }\n}\n\nexport type AxisLinearOptions<TDatum> = AxisOptionsBase & {\n  scaleType?: 'linear' | 'log'\n  getValue: (datum: TDatum) => ChartValue<number>\n  min?: number\n  max?: number\n  hardMin?: number\n  hardMax?: number\n  // base?: number\n  formatters?: {\n    scale?: (\n      value: number,\n      formatters: AxisLinearOptions<TDatum>['formatters']\n    ) => string\n    tooltip?: (\n      value: number,\n      formatters: AxisLinearOptions<TDatum>['formatters']\n    ) => React.ReactNode\n    cursor?: (\n      value: number,\n      formatters: AxisLinearOptions<TDatum>['formatters']\n    ) => React.ReactNode\n  }\n}\n\nexport type AxisBandOptions<TDatum> = AxisOptionsBase & {\n  scaleType?: 'band'\n  getValue: (datum: TDatum) => ChartValue<any>\n  originalSinBandSize?: number\n  formatters?: {\n    scale?: (\n      value: any,\n      formatters: AxisBandOptions<TDatum>['formatters']\n    ) => string\n    tooltip?: (\n      value: React.ReactNode,\n      formatters: AxisBandOptions<TDatum>['formatters']\n    ) => string\n    cursor?: (\n      value: React.ReactNode,\n      formatters: AxisBandOptions<TDatum>['formatters']\n    ) => string\n  }\n}\n\nexport type AxisOptions<TDatum> =\n  | AxisTimeOptions<TDatum>\n  | AxisLinearOptions<TDatum>\n  | AxisBandOptions<TDatum>\n\nexport type AxisOptionsWithScaleType<TDatum> = TSTB.Object.Required<\n  AxisOptions<TDatum>,\n  'scaleType'\n>\n\nexport type BuildAxisOptions<TDatum> = TSTB.Object.Required<\n  AxisOptions<TDatum>,\n  'position' | 'scaleType'\n>\n\nexport type ResolvedAxisOptions<TAxisOptions> = TSTB.Object.Required<\n  TAxisOptions & {},\n  | 'scaleType'\n  | 'position'\n  | 'minTickPaddingForRotation'\n  | 'tickLabelRotationDeg'\n  | 'innerBandPadding'\n  | 'outerBandPadding'\n  | 'innerSeriesBandPadding'\n  | 'outerSeriesBandPadding'\n  | 'show'\n  | 'stacked'\n>\n\nexport type ChartValue<T> = T | null | undefined\n\nexport type AxisBase = {\n  position: Position\n  isVertical: boolean\n  range: [number, number]\n}\n\nexport type AxisTime<TDatum> = Omit<\n  AxisBase & ResolvedAxisOptions<AxisTimeOptions<TDatum>>,\n  'format'\n> & {\n  isPrimary?: boolean\n  isInvalid: boolean\n  axisFamily: 'time'\n  scale: ScaleTime<number, number, never>\n  outerScale: ScaleTime<number, number, never>\n  primaryBandScale?: ScaleBand<number>\n  seriesBandScale?: ScaleBand<number>\n  formatters: {\n    default: (value: Date) => string\n    scale: (value: Date) => string\n    tooltip: (value: Date) => React.ReactNode\n    cursor: (value: Date) => React.ReactNode\n  }\n}\n\nexport type AxisLinear<TDatum> = Omit<\n  AxisBase & ResolvedAxisOptions<AxisLinearOptions<TDatum>>,\n  'format'\n> & {\n  isPrimary?: boolean\n  isInvalid: boolean\n  axisFamily: 'linear'\n  scale: ScaleLinear<number, number, never>\n  outerScale: ScaleLinear<number, number, never>\n  primaryBandScale?: ScaleBand<number>\n  seriesBandScale?: ScaleBand<number>\n  formatters: {\n    default: (value: ChartValue<any>) => string\n    scale: (value: number) => string\n    tooltip: (value: number) => React.ReactNode\n    cursor: (value: number) => React.ReactNode\n  }\n}\n\nexport type AxisBand<TDatum> = Omit<\n  AxisBase & ResolvedAxisOptions<AxisBandOptions<TDatum>>,\n  'format'\n> & {\n  isPrimary?: boolean\n  isInvalid: boolean\n  axisFamily: 'band'\n  scale: ScaleBand<any>\n  outerScale: ScaleBand<any>\n  primaryBandScale: ScaleBand<number>\n  seriesBandScale: ScaleBand<number>\n  formatters: {\n    default: (value: any) => string\n    scale: (value: any) => string\n    tooltip: (value: React.ReactNode) => string\n    cursor: (value: React.ReactNode) => string\n  }\n}\n\nexport type Axis<TDatum> =\n  | AxisTime<TDatum>\n  | AxisLinear<TDatum>\n  | AxisBand<TDatum>\n\nexport type UserSerie<TDatum> = {\n  data: TDatum[]\n  id?: string\n  label?: string\n  color?: string\n  primaryAxisId?: string\n  secondaryAxisId?: string\n}\n\n//\n\nexport type Series<TDatum> = {\n  originalSeries: UserSerie<TDatum>\n  index: number\n  indexPerAxis: number\n  id: string\n  label: string\n  secondaryAxisId?: string\n  datums: Datum<TDatum>[]\n  style?: CSSProperties\n}\n\nexport type Datum<TDatum> = {\n  originalSeries: UserSerie<TDatum>\n  seriesIndex: number\n  seriesId: string\n  seriesLabel: string\n  index: number\n  originalDatum: TDatum\n  secondaryAxisId?: string\n  seriesIndexPerAxis: number\n  primaryValue?: any\n  secondaryValue?: any\n  stackData?: StackDatum<TDatum>\n  interactiveGroup?: Datum<TDatum>[]\n  tooltipGroup?: Datum<TDatum>[]\n  style?: CSSProperties\n  element?: Element | null\n}\n\nexport type StackDatum<TDatum> = {\n  0: number\n  1: number\n  data: Datum<TDatum>\n  length: number\n}\n\n//\n\nexport type Measurement = Side | 'width' | 'height'\n\nexport type GridDimensions = {\n  left: number\n  top: number\n  right: number\n  bottom: number\n  width: number\n  height: number\n}\n\nexport type CursorOptions = {\n  value?: unknown\n  show?: boolean\n  showLine?: boolean\n  showLabel?: boolean\n  onChange?: (value: any) => void\n}\n\nexport type SeriesFocusStatus = 'none' | 'focused'\n\nexport type DatumFocusStatus = 'none' | 'focused' | 'groupFocused'\n"
  },
  {
    "path": "src/utils/Utils.ts",
    "content": "import {\n  Datum,\n  DatumFocusStatus,\n  DatumStyles,\n  Series,\n  SeriesFocusStatus,\n  SeriesStyles,\n} from '../types'\n\nexport function getSeriesStatus<TDatum>(\n  series: Series<TDatum>,\n  focusedDatum: Datum<TDatum> | null\n): SeriesFocusStatus {\n  if (focusedDatum?.seriesId === series.id) {\n    return 'focused'\n  }\n\n  return 'none'\n}\n\nexport function getDatumStatus<TDatum>(\n  datum: Datum<TDatum>,\n  focusedDatum: Datum<TDatum> | null\n): DatumFocusStatus {\n  if (datum === focusedDatum) {\n    return 'focused'\n  }\n\n  if (\n    datum.tooltipGroup?.some(groupDatum => {\n      groupDatum.seriesId === focusedDatum?.seriesId &&\n        groupDatum.index === focusedDatum?.index\n    })\n  ) {\n    return 'groupFocused'\n  }\n\n  return 'none'\n}\n\nconst elementTypes = ['area', 'line', 'rectangle', 'circle'] as const\n\nexport function materializeStyles(\n  style: SeriesStyles | DatumStyles = {},\n  defaults: SeriesStyles | DatumStyles = {}\n) {\n  style = normalizeColor(style, defaults)\n  for (let i = 0; i < elementTypes.length; i++) {\n    const type = elementTypes[i]\n    if (style[type] && defaults[type]) {\n      style[type] = materializeStyles(style[type], defaults)\n    }\n  }\n  return style\n}\n\nexport function translate(x: number, y: number) {\n  return `translate3d(${Math.round(x)}px, ${Math.round(y)}px, 0)`\n}\n\n//\n\nfunction normalizeColor(\n  style: SeriesStyles | DatumStyles,\n  defaults: SeriesStyles | DatumStyles\n): SeriesStyles | DatumStyles {\n  return {\n    ...style,\n    stroke: style.stroke || style.color || defaults.stroke || defaults.color,\n    fill: style.fill || style.color || defaults.fill || defaults.color,\n  }\n}\n\nexport function isDefined(num: number) {\n  return typeof num === 'number' && !Number.isNaN(num)\n}\n"
  },
  {
    "path": "src/utils/buildAxis.linear.ts",
    "content": "import { extent, max, median, min, range as d3Range } from 'd3-array'\nimport { stack, stackOffsetNone } from 'd3-shape'\nimport {\n  scaleLinear,\n  scaleLog,\n  scaleTime,\n  scaleUtc,\n  scaleBand,\n  ScaleTime,\n  ScaleLinear,\n  ScaleBand,\n} from 'd3-scale'\n\nimport {\n  timeSecond,\n  timeMinute,\n  timeHour,\n  timeDay,\n  timeMonth,\n  timeYear,\n  utcYear,\n  utcMonth,\n  utcDay,\n  utcHour,\n  utcMinute,\n  utcSecond,\n} from 'd3-time'\n\nimport { timeFormat, utcFormat } from 'd3-time-format'\n\nimport {\n  Axis,\n  AxisBand,\n  AxisBandOptions,\n  AxisLinear,\n  AxisLinearOptions,\n  AxisOptions,\n  AxisTime,\n  AxisTimeOptions,\n  BuildAxisOptions,\n  Datum,\n  GridDimensions,\n  ResolvedAxisOptions,\n  Series,\n  StackDatum,\n} from '../types'\n\nfunction defaultAxisOptions<TDatum>(\n  options: BuildAxisOptions<TDatum>\n): ResolvedAxisOptions<AxisOptions<TDatum>> {\n  return {\n    ...options,\n    elementType: options.elementType ?? 'line',\n    minTickPaddingForRotation: options.minTickPaddingForRotation ?? 10,\n    tickLabelRotationDeg: options.tickLabelRotationDeg ?? 60,\n    innerBandPadding: options.innerBandPadding ?? 0.5,\n    outerBandPadding: options.outerBandPadding ?? 0.2,\n    innerSeriesBandPadding: options.innerSeriesBandPadding ?? 0.2,\n    outerSeriesBandPadding: options.outerSeriesBandPadding ?? 0,\n    show: options.show ?? true,\n    stacked: options.stacked ?? false,\n    shouldNice: options.shouldNice ?? true,\n  }\n}\n\nexport default function buildAxisLinear<TDatum>(\n  isPrimary: boolean,\n  userOptions: BuildAxisOptions<TDatum>,\n  series: Series<TDatum>[],\n  allDatums: Datum<TDatum>[],\n  gridDimensions: GridDimensions,\n  width: number,\n  height: number\n): Axis<TDatum> {\n  const options = defaultAxisOptions(userOptions)\n\n  if (!options.position) {\n    throw new Error(`Chart axes must have a valid 'position' property`)\n  }\n\n  const isVertical = ['left', 'right'].indexOf(options.position) > -1\n\n  // Now we need to figure out the range\n  const range: [number, number] = isVertical\n    ? [gridDimensions.height, 0]\n    : [0, gridDimensions.width]\n\n  const outerRange: [number, number] = isVertical ? [height, 0] : [0, width]\n\n  // Give the scale a home\n  return options.scaleType === 'time' || options.scaleType === 'localTime'\n    ? buildTimeAxis(\n        isPrimary,\n        options,\n        series,\n        allDatums,\n        isVertical,\n        range,\n        outerRange\n      )\n    : options.scaleType === 'linear' || options.scaleType === 'log'\n    ? buildLinearAxis(\n        isPrimary,\n        options,\n        series,\n        allDatums,\n        isVertical,\n        range,\n        outerRange\n      )\n    : options.scaleType === 'band'\n    ? buildBandAxis(isPrimary, options, series, isVertical, range, outerRange)\n    : (() => {\n        throw new Error('Invalid scale type')\n      })()\n}\n\nfunction buildTimeAxis<TDatum>(\n  isPrimary: boolean,\n  options: ResolvedAxisOptions<AxisTimeOptions<TDatum>>,\n  series: Series<TDatum>[],\n  allDatums: Datum<TDatum>[],\n  isVertical: boolean,\n  range: [number, number],\n  outerRange: [number, number]\n): AxisTime<TDatum> {\n  const isLocal = options.scaleType === 'localTime'\n  const scaleFn = isLocal ? scaleTime : scaleUtc\n\n  let isInvalid = false\n\n  series = isPrimary\n    ? series\n    : series.filter(s => s.secondaryAxisId === options.id)\n\n  allDatums = isPrimary\n    ? allDatums\n    : allDatums.filter(d => d.secondaryAxisId === options.id)\n\n  // Now set the range\n  const scale = scaleFn(range)\n\n  let [minValue, maxValue] = extent(allDatums, datum => {\n    const value = options.getValue(datum.originalDatum)\n    datum[isPrimary ? 'primaryValue' : 'secondaryValue'] = value\n    return value\n  })\n\n  // Here, we find the maximum context (in descending order from year\n  // down to millisecond) needed to understand the\n  // dates in this dataset. If the min/max dates span multiples of\n  // any of the time units OR if the max date resides in a different\n  // unit boundary than today's, we use that unit as context.\n\n  let autoFormatStr: string\n\n  const units = isLocal\n    ? {\n        year: timeYear,\n        month: timeMonth,\n        day: timeDay,\n        hour: timeHour,\n        minute: timeMinute,\n        second: timeSecond,\n      }\n    : {\n        year: utcYear,\n        month: utcMonth,\n        day: utcDay,\n        hour: utcHour,\n        minute: utcMinute,\n        second: utcSecond,\n      }\n\n  if (minValue && maxValue) {\n    if (\n      units.year.count(minValue, maxValue) > 0 ||\n      units.year.floor(maxValue) < units.year()\n    ) {\n      autoFormatStr = '%b %-d, %Y %-I:%M:%S.%L %p'\n    } else if (\n      units.month.count(minValue, maxValue) > 0 ||\n      units.month.floor(maxValue) < units.month()\n    ) {\n      autoFormatStr = '%b %-d, %-I:%M:%S.%L %p'\n    } else if (\n      units.day.count(minValue, maxValue) > 0 ||\n      units.day.floor(maxValue) < units.day()\n    ) {\n      autoFormatStr = '%b %-d, %-I:%M:%S.%L %p'\n    } else if (\n      units.hour.count(minValue, maxValue) > 0 ||\n      units.hour.floor(maxValue) < units.hour()\n    ) {\n      autoFormatStr = '%-I:%M:%S.%L %p'\n    } else if (\n      units.minute.count(minValue, maxValue) > 0 ||\n      units.minute.floor(maxValue) < units.minute()\n    ) {\n      autoFormatStr = '%-I:%M:%S.%L'\n    } else if (\n      units.second.count(minValue, maxValue) > 0 ||\n      units.second.floor(maxValue) < units.second()\n    ) {\n      autoFormatStr = '%L'\n    }\n  }\n\n  const resolvedTimeFormat = isLocal ? timeFormat : utcFormat\n  const trimFormat = (str: string) => str.trim().replace(/(,$|^,)/, '')\n\n  const contextFormat = (format: string, date: Date) => {\n    if (units.second(date) < date) {\n      // milliseconds - Do not remove any context\n      return resolvedTimeFormat(format)(date)\n    }\n    if (units.minute(date) < date) {\n      // seconds - remove potential milliseconds\n      return resolvedTimeFormat(\n        trimFormat(format.replace(/\\.%L.*?(\\s|$)/, ''))\n      )(date)\n    }\n    if (units.hour(date) < date) {\n      // minutes - remove potential seconds and milliseconds\n      return resolvedTimeFormat(trimFormat(format.replace(/:%S.*?(\\s|$)/, '')))(\n        date\n      )\n    }\n    if (units.day(date) < date) {\n      // hours - remove potential minutes and seconds and milliseconds\n      return resolvedTimeFormat(trimFormat(format.replace(/:%M.*?(\\s|$)/, '')))(\n        date\n      )\n    }\n    if (units.month(date) < date) {\n      // days  - remove potential hours, minutes, seconds and milliseconds\n      return resolvedTimeFormat(trimFormat(format.replace(/%-I.*/, '')))(date)\n    }\n    if (units.year(date) < date) {\n      // months - remove potential days, hours, minutes, seconds and milliseconds\n      return resolvedTimeFormat(trimFormat(format.replace(/%-d.*/, '')))(date)\n    }\n    // years\n    return resolvedTimeFormat('%Y')(date)\n  }\n\n  let shouldNice = options.shouldNice\n\n  // see https://stackoverflow.com/a/2831422\n  if (Object.prototype.toString.call(options.min) === '[object Date]') {\n    minValue = min([options.min as Date, minValue as Date])\n    shouldNice = false\n  }\n\n  if (Object.prototype.toString.call(options.max) === '[object Date]') {\n    maxValue = max([options.max as Date, maxValue as Date])\n    shouldNice = false\n  }\n\n  if (Object.prototype.toString.call(options.hardMin) === '[object Date]') {\n    minValue = options.hardMin\n    shouldNice = false\n  }\n\n  if (Object.prototype.toString.call(options.hardMax) === '[object Date]') {\n    maxValue = options.hardMax\n    shouldNice = false\n  }\n\n  if (minValue === undefined || maxValue === undefined) {\n    console.info('Invalid scale min/max', {\n      options,\n      series,\n      range,\n      values: allDatums.map(d =>\n        isPrimary ? d.primaryValue : d.secondaryValue\n      ),\n    })\n    isInvalid = true\n  }\n\n  // Set the domain\n  scale.domain([minValue as Date, maxValue as Date])\n\n  if (options.invert) {\n    scale.domain(Array.from(scale.domain()).reverse())\n  }\n\n  if (shouldNice) {\n    scale.nice()\n  }\n\n  const outerScale = scale.copy().range(outerRange)\n\n  // Supplementary band scale\n  const primaryBandScale = isPrimary\n    ? buildPrimaryBandScale(options, scale, series, range)\n    : undefined\n\n  const seriesBandScale = primaryBandScale\n    ? buildSeriesBandScale(options, primaryBandScale, series)\n    : undefined\n\n  const primaryBandWidth = primaryBandScale?.bandwidth()\n\n  if (options.padBandRange && primaryBandWidth) {\n    const bandStart = scale.invert(0)\n    const bandEnd = scale.invert(primaryBandWidth)\n    const diff = bandEnd.valueOf() - bandStart.valueOf()\n\n    scale.domain([\n      new Date(scale.domain()[0].valueOf() - diff / 2),\n      new Date(scale.domain()[1].valueOf() + diff / 2),\n    ])\n  }\n\n  const formatters = {} as AxisTime<TDatum>['formatters']\n\n  const defaultFormat = scale.tickFormat()\n\n  const scaleFormat = (value: Date) =>\n    options.formatters?.scale?.(value, { ...formatters, scale: undefined }) ??\n    contextFormat(autoFormatStr, value)\n\n  const tooltipFormat = (value: Date) =>\n    options.formatters?.tooltip?.(value, {\n      ...formatters,\n      tooltip: undefined,\n    }) ?? scaleFormat(value)\n\n  const cursorFormat = (value: Date) =>\n    options.formatters?.cursor?.(value, { ...formatters, cursor: undefined }) ??\n    scaleFormat(value)\n\n  Object.assign(formatters, {\n    default: defaultFormat,\n    scale: scaleFormat,\n    tooltip: tooltipFormat,\n    cursor: cursorFormat,\n  })\n\n  return {\n    ...options,\n    isInvalid,\n    axisFamily: 'time',\n    isVertical,\n    scale,\n    range,\n    outerScale,\n    primaryBandScale,\n    seriesBandScale,\n    formatters: formatters,\n  }\n}\n\nfunction buildLinearAxis<TDatum>(\n  isPrimary: boolean,\n  options: ResolvedAxisOptions<AxisLinearOptions<TDatum>>,\n  series: Series<TDatum>[],\n  allDatums: Datum<TDatum>[],\n  isVertical: boolean,\n  range: [number, number],\n  outerRange: [number, number]\n): AxisLinear<TDatum> {\n  const scale = options.scaleType === 'log' ? scaleLog() : scaleLinear()\n\n  let isInvalid = false\n\n  series = isPrimary\n    ? series\n    : series.filter(s => s.secondaryAxisId === options.id)\n\n  allDatums = isPrimary\n    ? allDatums\n    : allDatums.filter(d => d.secondaryAxisId === options.id)\n\n  if (options.stacked) {\n    stackSeries(series, options)\n  }\n\n  let [minValue, maxValue] = options.stacked\n    ? extent(\n        series\n          .map(s =>\n            s.datums.map(datum => {\n              const value = options.getValue(datum.originalDatum)\n              datum[isPrimary ? 'primaryValue' : 'secondaryValue'] = value\n              return datum.stackData ?? []\n            })\n          )\n          .flat(2) as unknown as number[]\n      )\n    : extent(allDatums, datum => {\n        const value = options.getValue(datum.originalDatum)\n        datum[isPrimary ? 'primaryValue' : 'secondaryValue'] = value\n        return value\n      })\n\n  let shouldNice = options.shouldNice\n\n  if (typeof options.min === 'number') {\n    minValue = min([options.min, minValue as number])\n    shouldNice = false\n  }\n\n  if (typeof options.max === 'number') {\n    maxValue = max([options.max, maxValue as number])\n    shouldNice = false\n  }\n\n  if (\n    typeof options.minDomainLength === 'number' &&\n    !(minValue === undefined || maxValue === undefined)\n  ) {\n    const mid = median([minValue, maxValue])!\n    const top = mid + options.minDomainLength / 2\n    const bottom = mid - options.minDomainLength / 2\n    maxValue = Math.max(top, maxValue)\n    minValue = Math.min(bottom, minValue)\n  }\n\n  if (typeof options.hardMin === 'number') {\n    minValue = options.hardMin\n    shouldNice = false\n  }\n\n  if (typeof options.hardMax === 'number') {\n    maxValue = options.hardMax\n    shouldNice = false\n  }\n\n  if (minValue === undefined || maxValue === undefined) {\n    isInvalid = true\n    console.info('Invalid scale min/max', {\n      options,\n      series,\n      range,\n      values: allDatums.map(d =>\n        isPrimary ? d.primaryValue : d.secondaryValue\n      ),\n    })\n    minValue = minValue ?? 0\n    maxValue = maxValue ?? 0\n    // throw new Error('Invalid scale min/max'\n  }\n\n  // Set the domain\n  scale.domain([minValue, maxValue])\n\n  if (options.invert) {\n    scale.domain(Array.from(scale.domain()).reverse())\n  }\n\n  scale.range(range)\n\n  if (shouldNice) {\n    scale.nice()\n  }\n\n  const outerScale = scale.copy().range(outerRange)\n\n  const primaryBandScale = isPrimary\n    ? buildPrimaryBandScale(options, scale, series, range)\n    : undefined\n\n  const seriesBandScale = primaryBandScale\n    ? buildSeriesBandScale(options, primaryBandScale, series)\n    : undefined\n\n  const defaultFormat = scale.tickFormat()\n\n  const formatters = {} as AxisLinear<TDatum>['formatters']\n\n  const scaleFormat = (value: number) =>\n    options.formatters?.scale?.(value, { ...formatters, scale: undefined }) ??\n    defaultFormat(value)\n\n  const tooltipFormat = (value: number) =>\n    options.formatters?.tooltip?.(value, {\n      ...formatters,\n      tooltip: undefined,\n    }) ?? scaleFormat(value)\n\n  const cursorFormat = (value: number) =>\n    options.formatters?.cursor?.(value, { ...formatters, cursor: undefined }) ??\n    tooltipFormat(value)\n\n  Object.assign(formatters, {\n    default: defaultFormat,\n    scale: scaleFormat,\n    tooltip: tooltipFormat,\n    cursor: cursorFormat,\n  })\n\n  return {\n    ...options,\n    isInvalid,\n    axisFamily: 'linear',\n    isVertical,\n    scale,\n    range,\n    outerScale,\n    primaryBandScale,\n    seriesBandScale,\n    formatters,\n  }\n}\n\nfunction buildBandAxis<TDatum>(\n  isPrimary: boolean,\n  options: ResolvedAxisOptions<AxisBandOptions<TDatum>>,\n  series: Series<TDatum>[],\n  isVertical: boolean,\n  range: [number, number],\n  outerRange: [number, number]\n): AxisBand<TDatum> {\n  series = series.filter(d => d.secondaryAxisId === options.id)\n\n  let isInvalid = false\n\n  const domain = Array.from(\n    new Set(\n      series\n        .map(d => d.datums)\n        .flat()\n        .map(datum => {\n          const value = options.getValue(datum.originalDatum)\n          datum[isPrimary ? 'primaryValue' : 'secondaryValue'] = value\n          return value\n        })\n    )\n  )\n\n  const scale = scaleBand(domain, range)\n    .round(false)\n    .paddingOuter(options.outerBandPadding ?? 0)\n    .paddingInner(options.innerBandPadding ?? 0)\n\n  // Invert if necessary\n  if (options.invert) {\n    scale.domain(Array.from(scale.domain()).reverse())\n  }\n\n  const outerScale = scale.copy().range(outerRange)\n\n  const primaryBandScale = scale\n\n  const seriesBandScale = buildSeriesBandScale(\n    options,\n    primaryBandScale,\n    series\n  )\n\n  const defaultFormat = (d: { toString: () => string }) => d\n\n  const formatters = {} as AxisBand<TDatum>['formatters']\n\n  const scaleFormat = (value: number) =>\n    options.formatters?.scale?.(value, { ...formatters, scale: undefined }) ??\n    defaultFormat(value)\n\n  const tooltipFormat = (value: number) =>\n    options.formatters?.tooltip?.(value, {\n      ...formatters,\n      tooltip: undefined,\n    }) ?? scaleFormat(value)\n\n  const cursorFormat = (value: number) =>\n    options.formatters?.cursor?.(value, { ...formatters, cursor: undefined }) ??\n    tooltipFormat(value)\n\n  Object.assign(formatters, {\n    default: defaultFormat,\n    scale: scaleFormat,\n    tooltip: tooltipFormat,\n    cursor: cursorFormat,\n  })\n\n  return {\n    ...options,\n    isInvalid,\n    axisFamily: 'band',\n    isVertical,\n    scale,\n    range,\n    outerScale,\n    formatters,\n    primaryBandScale,\n    seriesBandScale,\n  }\n}\n\n//\n\nfunction stackSeries<TDatum>(\n  series: Series<TDatum>[],\n  axisOptions: AxisOptions<TDatum>\n) {\n  const seriesIndices = Object.keys(series)\n  const stacker = stack()\n    .keys(seriesIndices)\n    .value((_, seriesIndex, index) => {\n      const originalDatum =\n        series[Number(seriesIndex)]?.datums[index]?.originalDatum\n\n      const val =\n        typeof originalDatum !== 'undefined'\n          ? axisOptions.getValue(originalDatum)\n          : 0\n\n      if (typeof val === 'undefined' || val === null) {\n        return 0\n      }\n\n      return val\n    })\n    .offset(axisOptions.stackOffset ?? stackOffsetNone)\n\n  const stacked = stacker(\n    Array.from({\n      length: series.sort((a, b) => b.datums.length - a.datums.length)[0].datums\n        .length,\n    })\n  )\n\n  for (let sIndex = 0; sIndex < stacked.length; sIndex++) {\n    const s = stacked[sIndex]\n\n    for (let i = 0; i < s.length; i++) {\n      const datum = s[i]\n\n      if (series[sIndex].datums[i]) {\n        // @ts-ignore\n        datum.data = series[sIndex].datums[i]\n\n        series[sIndex].datums[i].stackData =\n          datum as unknown as StackDatum<TDatum>\n      }\n    }\n  }\n}\n\nfunction buildPrimaryBandScale<TDatum>(\n  options: ResolvedAxisOptions<AxisOptions<TDatum>>,\n  scale: ScaleTime<number, number, never> | ScaleLinear<number, number, never>,\n  series: Series<TDatum>[],\n  range: [number, number]\n) {\n  // Find the two closest points along axis\n  // Do not allow the band to be smaller than single pixel of the output range\n\n  let impliedBandWidth: number = Math.max(...range)\n  const bandRange: number = Math.max(...range)\n\n  ;(() => {\n    for (let i = 0; i < series.length; i++) {\n      const serie = series[i]\n\n      for (let j = 0; j < serie.datums.length; j++) {\n        const d1 = serie.datums[j]\n        const one = scale(d1.primaryValue ?? NaN)\n\n        for (let k = 0; k < serie.datums.length; k++) {\n          const d2 = serie.datums[k]\n          const two = scale(d2.primaryValue ?? NaN)\n\n          if (one === two) {\n            continue\n          }\n\n          const diff = Math.abs(Math.max(one, two) - Math.min(one, two))\n\n          if (diff < impliedBandWidth) {\n            impliedBandWidth = Math.max(diff, bandRange)\n\n            if (impliedBandWidth === bandRange) {\n              return\n            }\n          }\n        }\n      }\n    }\n  })()\n\n  const bandDomain = d3Range(bandRange / impliedBandWidth)\n\n  const primaryBandScale = scaleBand(bandDomain, range)\n    .round(false)\n    .paddingOuter(options.outerBandPadding ?? 0)\n    .paddingInner(options.innerBandPadding ?? 0)\n\n  return primaryBandScale\n}\n\nfunction buildSeriesBandScale<TDatum>(\n  options: ResolvedAxisOptions<AxisOptions<TDatum>>,\n  primaryBandScale: ScaleBand<number>,\n  series: Series<TDatum>[]\n) {\n  const bandDomain = d3Range(series.length)\n\n  const seriesBandScale = scaleBand(bandDomain, [\n    0,\n    primaryBandScale.bandwidth(),\n  ])\n    .round(false)\n    .paddingOuter(\n      options.outerSeriesBandPadding ??\n        (options.outerBandPadding ? options.outerBandPadding / 2 : 0)\n    )\n    .paddingInner(\n      options.innerSeriesBandPadding ??\n        (options.innerBandPadding ? options.innerBandPadding / 2 : 0)\n    )\n\n  const scale = (seriesIndex: number) =>\n    seriesBandScale(series.find(d => d.index === seriesIndex)!?.indexPerAxis)\n\n  return Object.assign(scale, seriesBandScale)\n}\n"
  },
  {
    "path": "src/utils/chartContext.tsx",
    "content": "import * as React from 'react'\n\nimport { ChartContextValue } from '../types'\n\nconst chartContext = React.createContext<any>(null!)\n\nexport function ChartContextProvider<TDatum>({\n  value,\n  children,\n}: {\n  value: () => ChartContextValue<TDatum>\n  children: React.ReactNode\n}) {\n  return <chartContext.Provider value={value} children={children} />\n}\n\nexport default function useChartContext<TDatum>() {\n  return React.useContext(chartContext)() as ChartContextValue<TDatum>\n}\n"
  },
  {
    "path": "src/utils/curveMonotone.ts",
    "content": "// @ts-nocheck\nimport { CurveFactory } from 'd3-shape'\n\nfunction sign(x) {\n  return x < 0 ? -1 : 1\n}\n\n// Calculate the slopes of the tangents (Hermite-type interpolation) based on\n// the following paper: Steffen, M. 1990. A Simple Method for Monotonic\n// Interpolation in One Dimension. Astronomy and Astrophysics, Vol. 239, NO.\n// NOV(II), P. 443, 1990.\nfunction slope3(that, x2, y2) {\n  var h0 = that._x1 - that._x0,\n    h1 = x2 - that._x1,\n    s0 = (that._y1 - that._y0) / (h0 || (h1 < 0 && -0)),\n    s1 = (y2 - that._y1) / (h1 || (h0 < 0 && -0)),\n    p = (s0 * h1 + s1 * h0) / (h0 + h1)\n  return (\n    (sign(s0) + sign(s1)) *\n      Math.min(Math.abs(s0), Math.abs(s1), 0.5 * Math.abs(p)) || 0\n  )\n}\n\n// Calculate a one-sided slope.\nfunction slope2(that, t) {\n  var h = that._x1 - that._x0\n  return h ? ((3 * (that._y1 - that._y0)) / h - t) / 2 : t\n}\n\n// According to https://en.wikipedia.org/wiki/Cubic_Hermite_spline#Representations\n// \"you can express cubic Hermite interpolation in terms of cubic Bézier curves\n// with respect to the four values p0, p0 + m0 / 3, p1 - m1 / 3, p1\".\nfunction point(that, t0, t1) {\n  var x0 = that._x0,\n    y0 = that._y0,\n    x1 = that._x1,\n    y1 = that._y1,\n    dx = (x1 - x0) / 3\n  that._context.bezierCurveTo(\n    x0 + dx,\n    y0 + dx * t0,\n    x1 - dx,\n    y1 - dx * t1,\n    x1,\n    y1\n  )\n}\n\nfunction MonotoneX(context) {\n  this._context = context\n}\n\nMonotoneX.prototype = {\n  areaStart: function () {\n    this._line = 0\n  },\n  areaEnd: function () {\n    this._line = NaN\n  },\n  lineStart: function () {\n    this._x0 = this._x1 = this._y0 = this._y1 = this._t0 = NaN\n    this._point = 0\n  },\n  lineEnd: function () {\n    switch (this._point) {\n      case 2:\n        this._context.lineTo(this._x1, this._y1)\n        break\n      case 3:\n        point(this, this._t0, slope2(this, this._t0))\n        break\n    }\n    if (this._line || (this._line !== 0 && this._point === 1))\n      this._context.closePath()\n    this._line = 1 - this._line\n  },\n  point: function (x, y) {\n    var t1 = NaN\n\n    ;(x = +x), (y = +y)\n    if (x === this._x1 && y === this._y1) return // Ignore coincident points.\n    switch (this._point) {\n      case 0:\n        this._point = 1\n        this._line ? this._context.lineTo(x, y) : this._context.moveTo(x, y)\n        break\n      case 1:\n        this._point = 2\n        break\n      case 2:\n        this._point = 3\n        point(this, slope2(this, (t1 = slope3(this, x, y))), t1)\n        break\n      default:\n        point(this, this._t0, (t1 = slope3(this, x, y)))\n        break\n    }\n\n    ;(this._x0 = this._x1), (this._x1 = x)\n    ;(this._y0 = this._y1), (this._y1 = y)\n    this._t0 = t1\n  },\n}\n\nfunction MonotoneY(context) {\n  this._context = new ReflectContext(context)\n}\n\n;(MonotoneY.prototype = Object.create(MonotoneX.prototype)).point = function (\n  x,\n  y\n) {\n  MonotoneX.prototype.point.call(this, y, x)\n}\n\nfunction ReflectContext(context) {\n  this._context = context\n}\n\nReflectContext.prototype = {\n  moveTo: function (x, y) {\n    this._context.moveTo(y, x)\n  },\n  closePath: function () {\n    this._context.closePath()\n  },\n  lineTo: function (x, y) {\n    this._context.lineTo(y, x)\n  },\n  bezierCurveTo: function (x1, y1, x2, y2, x, y) {\n    this._context.bezierCurveTo(y1, x1, y2, x2, y, x)\n  },\n}\n\nexport const monotoneX: CurveFactory = context => new MonotoneX(context)\n\nexport const monotoneY: CurveFactory = context => new MonotoneY(context)\n"
  },
  {
    "path": "src/utils/spring.ts",
    "content": "// Super fast physics simulations for JavaScript\n// Copyright 2014 Ralph Thomas\n// Licensed under the Apache License, Version 2.0\n// https://github.com/iamralpht/gravitas.js\n\n// Adapted to TypeScript and customized by Tanner Linsley (@tannerlinsley)\n\ntype Solution = {\n  x: (num: number) => number\n  dx: (num: number) => number\n}\n\nconst epsilon = 0.001\n\nfunction almostEqual(a: number, b: number) {\n  if (Number.isNaN(a) && Number.isNaN(b)) {\n    return true\n  }\n  return a > b - epsilon && a < b + epsilon\n}\n\nfunction almostZero(a: number) {\n  return almostEqual(a, 0)\n}\n\nexport class Spring {\n  private _m: number\n  private _k: number\n  private _c: number\n  private _solution: null | Solution\n  private _startTime: number\n  endPosition: number\n\n  constructor(\n    init: number,\n    mass: number,\n    springConstant: number,\n    damping: number\n  ) {\n    this._m = mass\n    this._k = springConstant\n    this._c = damping\n    this._solution = null\n    this.endPosition = init\n    this._startTime = 0\n  }\n\n  x(dt?: number) {\n    if (dt === undefined) {\n      dt = (new Date().getTime() - this._startTime) / 1000.0\n    }\n    return this._solution\n      ? this.endPosition + this._solution.x(dt)\n      : this.endPosition\n  }\n\n  private dx(dt?: number) {\n    if (dt === undefined) {\n      dt = (new Date().getTime() - this._startTime) / 1000.0\n    }\n    return this._solution ? this._solution.dx(dt) : 0\n  }\n\n  setEnd(x: number) {\n    const t = new Date().getTime()\n\n    let velocity = 0\n    let position = this.endPosition\n    if (this._solution) {\n      // Don't whack incoming velocity.\n      if (almostZero(velocity))\n        velocity = this._solution.dx((t - this._startTime) / 1000.0)\n      position = this._solution.x((t - this._startTime) / 1000.0)\n      if (almostZero(velocity)) velocity = 0\n      if (almostZero(position)) position = 0\n      position += this.endPosition\n    }\n    if (this._solution && almostZero(position - x) && almostZero(velocity)) {\n      return\n    }\n    this.endPosition = x\n    this._solution = this._solve(position - this.endPosition, velocity)\n    this._startTime = t\n  }\n\n  snap(x: number) {\n    this._startTime = new Date().getTime()\n    this.endPosition = x\n    this._solution = {\n      x() {\n        return 0\n      },\n      dx() {\n        return 0\n      },\n    }\n  }\n\n  done() {\n    return almostEqual(this.x(), this.endPosition) && almostZero(this.dx())\n  }\n\n  // reconfigure(mass: number, springConstant: number, damping: number) {\n  //   this._m = mass\n  //   this._k = springConstant\n  //   this._c = damping\n\n  //   if (this.done()) {\n  //     return\n  //   }\n  //   this._solution = this._solve(this.x() - this.endPosition, this.dx())\n  //   this._startTime = new Date().getTime()\n  // }\n\n  // springConstant() {\n  //   return this._k\n  // }\n\n  // damping() {\n  //   return this._c\n  // }\n\n  private _solve(initial: number, velocity: number): Solution {\n    const c = this._c\n    const m = this._m\n    const k = this._k\n    // Solve the quadratic equation; root = (-c +/- sqrt(c^2 - 4mk)) / 2m.\n    const cmk = c * c - 4 * m * k\n    if (cmk === 0) {\n      // The spring is critically damped.\n      // x = (c1 + c2*t) * e ^(-c/2m)*t\n      const r = -c / (2 * m)\n      const c1 = initial\n      const c2 = velocity / (r * initial)\n      return {\n        x(t) {\n          return (c1 + c2 * t) * Math.pow(Math.E, r * t)\n        },\n        dx(t) {\n          const pow = Math.pow(Math.E, r * t)\n          return r * (c1 + c2 * t) * pow + c2 * pow\n        },\n      }\n    } else if (cmk > 0) {\n      // The spring is overdamped; no bounces.\n      // x = c1*e^(r1*t) + c2*e^(r2t)\n      // Need to find r1 and r2, the roots, then solve c1 and c2.\n      const r1 = (-c - Math.sqrt(cmk)) / (2 * m)\n      const r2 = (-c + Math.sqrt(cmk)) / (2 * m)\n      const c2 = (velocity - r1 * initial) / (r2 - r1)\n      const c1 = initial - c2\n\n      return {\n        x(t) {\n          return c1 * Math.pow(Math.E, r1 * t) + c2 * Math.pow(Math.E, r2 * t)\n        },\n        dx(t) {\n          return (\n            c1 * r1 * Math.pow(Math.E, r1 * t) +\n            c2 * r2 * Math.pow(Math.E, r2 * t)\n          )\n        },\n      }\n    } else {\n      // The spring is underdamped, it has imaginary roots.\n      // r = -(c / 2*m) +- w*i\n      // w = sqrt(4mk - c^2) / 2m\n      // x = (e^-(c/2m)t) * (c1 * cos(wt) + c2 * sin(wt))\n      const w = Math.sqrt(4 * m * k - c * c) / (2 * m)\n      const r = -((c / 2) * m)\n      const c1 = initial\n      const c2 = (velocity - r * initial) / w\n\n      return {\n        x(t) {\n          return (\n            Math.pow(Math.E, r * t) *\n            (c1 * Math.cos(w * t) + c2 * Math.sin(w * t))\n          )\n        },\n        dx(t) {\n          const power = Math.pow(Math.E, r * t)\n          const cos = Math.cos(w * t)\n          const sin = Math.sin(w * t)\n          return (\n            power * (c2 * w * cos - c1 * w * sin) +\n            r * power * (c2 * sin + c1 * cos)\n          )\n        },\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "test/placeholder.test.tsx",
    "content": "import React from 'react'\nimport * as ReactDOM from 'react-dom'\n\ndescribe('Placeholder', () => {\n  it('Will add some tests', () => {})\n})\n"
  },
  {
    "path": "tsconfig.json",
    "content": "{\n  \"compilerOptions\": {\n    \"esModuleInterop\": true,\n    \"isolatedModules\": true,\n    \"jsx\": \"react\",\n    \"lib\": [\"ESNext\", \"dom\"],\n    \"target\": \"es5\",\n    \"noEmit\": true,\n    \"noImplicitAny\": true,\n    \"noImplicitReturns\": false,\n    \"noImplicitThis\": true,\n    \"noUnusedLocals\": true,\n    \"noUnusedParameters\": true,\n    \"skipLibCheck\": true,\n    \"strict\": true,\n    \"types\": [\"jest\"]\n  },\n  \"include\": [\"./src\"]\n}\n"
  },
  {
    "path": "tsconfig.types.json",
    "content": "{\n  \"extends\": \"./tsconfig.json\",\n  \"compilerOptions\": {\n    \"declaration\": true,\n    \"declarationDir\": \"./types\",\n    \"emitDeclarationOnly\": true,\n    \"noEmit\": false\n  },\n  \"files\": [\"./src/index.ts\"],\n  \"exclude\": [\"./src/**/*\"]\n}\n"
  },
  {
    "path": "typedoc.json",
    "content": "{\n  \"entryPoints\": [\"src/index.ts\"],\n  \"out\": \"typedocs\",\n  \"theme\": \"minimal\"\n}\n"
  },
  {
    "path": "typedocs/assets/css/main.css",
    "content": ":root {\n  --color-background: #fdfdfd;\n  --color-text: #222;\n  --color-text-aside: #707070;\n  --color-link: #4da6ff;\n  --color-menu-divider: #eee;\n  --color-menu-divider-focus: #000;\n  --color-menu-label: #707070;\n  --color-panel: #fff;\n  --color-panel-divider: #eee;\n  --color-comment-tag: #707070;\n  --color-comment-tag-text: #fff;\n  --color-code-background: rgba(0, 0, 0, 0.04);\n  --color-ts: #9600ff;\n  --color-ts-interface: #647f1b;\n  --color-ts-enum: #937210;\n  --color-ts-class: #0672de;\n  --color-ts-private: #707070;\n  --color-toolbar: #fff;\n  --color-toolbar-text: #333;\n}\n\n/*! normalize.css v1.1.3 | MIT License | git.io/normalize */\n/* ==========================================================================\n * * HTML5 display definitions\n * * ========================================================================== */\n/**\n * * Correct `block` display not defined in IE 6/7/8/9 and Firefox 3. */\narticle, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary {\n  display: block;\n}\n\n/**\n * * Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3. */\naudio, canvas, video {\n  display: inline-block;\n  *display: inline;\n  *zoom: 1;\n}\n\n/**\n * * Prevent modern browsers from displaying `audio` without controls.\n * * Remove excess height in iOS 5 devices. */\naudio:not([controls]) {\n  display: none;\n  height: 0;\n}\n\n/**\n * * Address styling not present in IE 7/8/9, Firefox 3, and Safari 4.\n * * Known issue: no IE 6 support. */\n[hidden] {\n  display: none;\n}\n\n/* ==========================================================================\n * * Base\n * * ========================================================================== */\n/**\n * * 1. Correct text resizing oddly in IE 6/7 when body `font-size` is set using\n * *    `em` units.\n * * 2. Prevent iOS text size adjust after orientation change, without disabling\n * *    user zoom. */\nhtml {\n  font-size: 100%;\n  /* 1 */\n  -ms-text-size-adjust: 100%;\n  /* 2 */\n  -webkit-text-size-adjust: 100%;\n  /* 2 */\n  font-family: sans-serif;\n}\n\n/**\n * * Address `font-family` inconsistency between `textarea` and other form\n * * elements. */\nbutton, input, select, textarea {\n  font-family: sans-serif;\n}\n\n/**\n * * Address margins handled incorrectly in IE 6/7. */\nbody {\n  margin: 0;\n}\n\n/* ==========================================================================\n * * Links\n * * ========================================================================== */\n/**\n * * Address `outline` inconsistency between Chrome and other browsers. */\na:focus {\n  outline: thin dotted;\n}\na:active, a:hover {\n  outline: 0;\n}\n\n/**\n * * Improve readability when focused and also mouse hovered in all browsers. */\n/* ==========================================================================\n * * Typography\n * * ========================================================================== */\n/**\n * * Address font sizes and margins set differently in IE 6/7.\n * * Address font sizes within `section` and `article` in Firefox 4+, Safari 5,\n * * and Chrome. */\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0;\n}\n\nh2 {\n  font-size: 1.5em;\n  margin: 0.83em 0;\n}\n\nh3 {\n  font-size: 1.17em;\n  margin: 1em 0;\n}\n\nh4, .tsd-index-panel h3 {\n  font-size: 1em;\n  margin: 1.33em 0;\n}\n\nh5 {\n  font-size: 0.83em;\n  margin: 1.67em 0;\n}\n\nh6 {\n  font-size: 0.67em;\n  margin: 2.33em 0;\n}\n\n/**\n * * Address styling not present in IE 7/8/9, Safari 5, and Chrome. */\nabbr[title] {\n  border-bottom: 1px dotted;\n}\n\n/**\n * * Address style set to `bolder` in Firefox 3+, Safari 4/5, and Chrome. */\nb, strong {\n  font-weight: bold;\n}\n\nblockquote {\n  margin: 1em 40px;\n}\n\n/**\n * * Address styling not present in Safari 5 and Chrome. */\ndfn {\n  font-style: italic;\n}\n\n/**\n * * Address differences between Firefox and other browsers.\n * * Known issue: no IE 6/7 normalization. */\nhr {\n  -moz-box-sizing: content-box;\n  box-sizing: content-box;\n  height: 0;\n}\n\n/**\n * * Address styling not present in IE 6/7/8/9. */\nmark {\n  background: #ff0;\n  color: #000;\n}\n\n/**\n * * Address margins set differently in IE 6/7. */\np, pre {\n  margin: 1em 0;\n}\n\n/**\n * * Correct font family set oddly in IE 6, Safari 4/5, and Chrome. */\ncode, kbd, pre, samp {\n  font-family: monospace, serif;\n  _font-family: \"courier new\", monospace;\n  font-size: 1em;\n}\n\n/**\n * * Improve readability of pre-formatted text in all browsers. */\npre {\n  white-space: pre;\n  white-space: pre-wrap;\n  word-wrap: break-word;\n}\n\n/**\n * * Address CSS quotes not supported in IE 6/7. */\nq {\n  quotes: none;\n}\nq:before, q:after {\n  content: \"\";\n  content: none;\n}\n\n/**\n * * Address `quotes` property not supported in Safari 4. */\n/**\n * * Address inconsistent and variable font size in all browsers. */\nsmall {\n  font-size: 80%;\n}\n\n/**\n * * Prevent `sub` and `sup` affecting `line-height` in all browsers. */\nsub {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n  top: -0.5em;\n}\n\nsub {\n  bottom: -0.25em;\n}\n\n/* ==========================================================================\n * * Lists\n * * ========================================================================== */\n/**\n * * Address margins set differently in IE 6/7. */\ndl, menu, ol, ul {\n  margin: 1em 0;\n}\n\ndd {\n  margin: 0 0 0 40px;\n}\n\n/**\n * * Address paddings set differently in IE 6/7. */\nmenu, ol, ul {\n  padding: 0 0 0 40px;\n}\n\n/**\n * * Correct list images handled incorrectly in IE 7. */\nnav ul, nav ol {\n  list-style: none;\n  list-style-image: none;\n}\n\n/* ==========================================================================\n * * Embedded content\n * * ========================================================================== */\n/**\n * * 1. Remove border when inside `a` element in IE 6/7/8/9 and Firefox 3.\n * * 2. Improve image quality when scaled in IE 7. */\nimg {\n  border: 0;\n  /* 1 */\n  -ms-interpolation-mode: bicubic;\n}\n\n/* 2 */\n/**\n * * Correct overflow displayed oddly in IE 9. */\nsvg:not(:root) {\n  overflow: hidden;\n}\n\n/* ==========================================================================\n * * Figures\n * * ========================================================================== */\n/**\n * * Address margin not present in IE 6/7/8/9, Safari 5, and Opera 11. */\nfigure, form {\n  margin: 0;\n}\n\n/* ==========================================================================\n * * Forms\n * * ========================================================================== */\n/**\n * * Correct margin displayed oddly in IE 6/7. */\n/**\n * * Define consistent border, margin, and padding. */\nfieldset {\n  border: 1px solid #c0c0c0;\n  margin: 0 2px;\n  padding: 0.35em 0.625em 0.75em;\n}\n\n/**\n * * 1. Correct color not being inherited in IE 6/7/8/9.\n * * 2. Correct text not wrapping in Firefox 3.\n * * 3. Correct alignment displayed oddly in IE 6/7. */\nlegend {\n  border: 0;\n  /* 1 */\n  padding: 0;\n  white-space: normal;\n  /* 2 */\n  *margin-left: -7px;\n}\n\n/* 3 */\n/**\n * * 1. Correct font size not being inherited in all browsers.\n * * 2. Address margins set differently in IE 6/7, Firefox 3+, Safari 5,\n * *    and Chrome.\n * * 3. Improve appearance and consistency in all browsers. */\nbutton, input, select, textarea {\n  font-size: 100%;\n  /* 1 */\n  margin: 0;\n  /* 2 */\n  vertical-align: baseline;\n  /* 3 */\n  *vertical-align: middle;\n}\n\n/* 3 */\n/**\n * * Address Firefox 3+ setting `line-height` on `input` using `!important` in\n * * the UA stylesheet. */\nbutton, input {\n  line-height: normal;\n}\n\n/**\n * * Address inconsistent `text-transform` inheritance for `button` and `select`.\n * * All other form control elements do not inherit `text-transform` values.\n * * Correct `button` style inheritance in Chrome, Safari 5+, and IE 6+.\n * * Correct `select` style inheritance in Firefox 4+ and Opera. */\nbutton, select {\n  text-transform: none;\n}\n\n/**\n * * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`\n * *    and `video` controls.\n * * 2. Correct inability to style clickable `input` types in iOS.\n * * 3. Improve usability and consistency of cursor style between image-type\n * *    `input` and others.\n * * 4. Remove inner spacing in IE 7 without affecting normal text inputs.\n * *    Known issue: inner spacing remains in IE 6. */\nbutton, html input[type=button] {\n  -webkit-appearance: button;\n  /* 2 */\n  cursor: pointer;\n  /* 3 */\n  *overflow: visible;\n}\n\n/* 4 */\ninput[type=reset], input[type=submit] {\n  -webkit-appearance: button;\n  /* 2 */\n  cursor: pointer;\n  /* 3 */\n  *overflow: visible;\n}\n\n/* 4 */\n/**\n * * Re-set default cursor for disabled elements. */\nbutton[disabled], html input[disabled] {\n  cursor: default;\n}\n\n/**\n * * 1. Address box sizing set to content-box in IE 8/9.\n * * 2. Remove excess padding in IE 8/9.\n * * 3. Remove excess padding in IE 7.\n * *    Known issue: excess padding remains in IE 6. */\ninput {\n  /* 3 */\n}\ninput[type=checkbox], input[type=radio] {\n  box-sizing: border-box;\n  /* 1 */\n  padding: 0;\n  /* 2 */\n  *height: 13px;\n  /* 3 */\n  *width: 13px;\n}\ninput[type=search] {\n  -webkit-appearance: textfield;\n  /* 1 */\n  -moz-box-sizing: content-box;\n  -webkit-box-sizing: content-box;\n  /* 2 */\n  box-sizing: content-box;\n}\ninput[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome.\n * * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome\n * *    (include `-moz` to future-proof). */\n/**\n * * Remove inner padding and search cancel button in Safari 5 and Chrome\n * * on OS X. */\n/**\n * * Remove inner padding and border in Firefox 3+. */\nbutton::-moz-focus-inner, input::-moz-focus-inner {\n  border: 0;\n  padding: 0;\n}\n\n/**\n * * 1. Remove default vertical scrollbar in IE 6/7/8/9.\n * * 2. Improve readability and alignment in all browsers. */\ntextarea {\n  overflow: auto;\n  /* 1 */\n  vertical-align: top;\n}\n\n/* 2 */\n/* ==========================================================================\n * * Tables\n * * ========================================================================== */\n/**\n * * Remove most spacing between table cells. */\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n}\n\nul.tsd-descriptions > li > :first-child, .tsd-panel > :first-child, .col > :first-child, .col-11 > :first-child, .col-10 > :first-child, .col-9 > :first-child, .col-8 > :first-child, .col-7 > :first-child, .col-6 > :first-child, .col-5 > :first-child, .col-4 > :first-child, .col-3 > :first-child, .col-2 > :first-child, .col-1 > :first-child,\nul.tsd-descriptions > li > :first-child > :first-child,\n.tsd-panel > :first-child > :first-child,\n.col > :first-child > :first-child,\n.col-11 > :first-child > :first-child,\n.col-10 > :first-child > :first-child,\n.col-9 > :first-child > :first-child,\n.col-8 > :first-child > :first-child,\n.col-7 > :first-child > :first-child,\n.col-6 > :first-child > :first-child,\n.col-5 > :first-child > :first-child,\n.col-4 > :first-child > :first-child,\n.col-3 > :first-child > :first-child,\n.col-2 > :first-child > :first-child,\n.col-1 > :first-child > :first-child,\nul.tsd-descriptions > li > :first-child > :first-child > :first-child,\n.tsd-panel > :first-child > :first-child > :first-child,\n.col > :first-child > :first-child > :first-child,\n.col-11 > :first-child > :first-child > :first-child,\n.col-10 > :first-child > :first-child > :first-child,\n.col-9 > :first-child > :first-child > :first-child,\n.col-8 > :first-child > :first-child > :first-child,\n.col-7 > :first-child > :first-child > :first-child,\n.col-6 > :first-child > :first-child > :first-child,\n.col-5 > :first-child > :first-child > :first-child,\n.col-4 > :first-child > :first-child > :first-child,\n.col-3 > :first-child > :first-child > :first-child,\n.col-2 > :first-child > :first-child > :first-child,\n.col-1 > :first-child > :first-child > :first-child {\n  margin-top: 0;\n}\nul.tsd-descriptions > li > :last-child, .tsd-panel > :last-child, .col > :last-child, .col-11 > :last-child, .col-10 > :last-child, .col-9 > :last-child, .col-8 > :last-child, .col-7 > :last-child, .col-6 > :last-child, .col-5 > :last-child, .col-4 > :last-child, .col-3 > :last-child, .col-2 > :last-child, .col-1 > :last-child,\nul.tsd-descriptions > li > :last-child > :last-child,\n.tsd-panel > :last-child > :last-child,\n.col > :last-child > :last-child,\n.col-11 > :last-child > :last-child,\n.col-10 > :last-child > :last-child,\n.col-9 > :last-child > :last-child,\n.col-8 > :last-child > :last-child,\n.col-7 > :last-child > :last-child,\n.col-6 > :last-child > :last-child,\n.col-5 > :last-child > :last-child,\n.col-4 > :last-child > :last-child,\n.col-3 > :last-child > :last-child,\n.col-2 > :last-child > :last-child,\n.col-1 > :last-child > :last-child,\nul.tsd-descriptions > li > :last-child > :last-child > :last-child,\n.tsd-panel > :last-child > :last-child > :last-child,\n.col > :last-child > :last-child > :last-child,\n.col-11 > :last-child > :last-child > :last-child,\n.col-10 > :last-child > :last-child > :last-child,\n.col-9 > :last-child > :last-child > :last-child,\n.col-8 > :last-child > :last-child > :last-child,\n.col-7 > :last-child > :last-child > :last-child,\n.col-6 > :last-child > :last-child > :last-child,\n.col-5 > :last-child > :last-child > :last-child,\n.col-4 > :last-child > :last-child > :last-child,\n.col-3 > :last-child > :last-child > :last-child,\n.col-2 > :last-child > :last-child > :last-child,\n.col-1 > :last-child > :last-child > :last-child {\n  margin-bottom: 0;\n}\n\n.container {\n  max-width: 1200px;\n  margin: 0 auto;\n  padding: 0 40px;\n}\n@media (max-width: 640px) {\n  .container {\n    padding: 0 20px;\n  }\n}\n\n.container-main {\n  padding-bottom: 200px;\n}\n\n.row {\n  display: flex;\n  position: relative;\n  margin: 0 -10px;\n}\n.row:after {\n  visibility: hidden;\n  display: block;\n  content: \"\";\n  clear: both;\n  height: 0;\n}\n\n.col, .col-11, .col-10, .col-9, .col-8, .col-7, .col-6, .col-5, .col-4, .col-3, .col-2, .col-1 {\n  box-sizing: border-box;\n  float: left;\n  padding: 0 10px;\n}\n\n.col-1 {\n  width: 8.3333333333%;\n}\n\n.offset-1 {\n  margin-left: 8.3333333333%;\n}\n\n.col-2 {\n  width: 16.6666666667%;\n}\n\n.offset-2 {\n  margin-left: 16.6666666667%;\n}\n\n.col-3 {\n  width: 25%;\n}\n\n.offset-3 {\n  margin-left: 25%;\n}\n\n.col-4 {\n  width: 33.3333333333%;\n}\n\n.offset-4 {\n  margin-left: 33.3333333333%;\n}\n\n.col-5 {\n  width: 41.6666666667%;\n}\n\n.offset-5 {\n  margin-left: 41.6666666667%;\n}\n\n.col-6 {\n  width: 50%;\n}\n\n.offset-6 {\n  margin-left: 50%;\n}\n\n.col-7 {\n  width: 58.3333333333%;\n}\n\n.offset-7 {\n  margin-left: 58.3333333333%;\n}\n\n.col-8 {\n  width: 66.6666666667%;\n}\n\n.offset-8 {\n  margin-left: 66.6666666667%;\n}\n\n.col-9 {\n  width: 75%;\n}\n\n.offset-9 {\n  margin-left: 75%;\n}\n\n.col-10 {\n  width: 83.3333333333%;\n}\n\n.offset-10 {\n  margin-left: 83.3333333333%;\n}\n\n.col-11 {\n  width: 91.6666666667%;\n}\n\n.offset-11 {\n  margin-left: 91.6666666667%;\n}\n\n.tsd-kind-icon {\n  display: block;\n  position: relative;\n  padding-left: 20px;\n  text-indent: -20px;\n}\n.tsd-kind-icon:before {\n  content: \"\";\n  display: inline-block;\n  vertical-align: middle;\n  width: 17px;\n  height: 17px;\n  margin: 0 3px 2px 0;\n  background-image: url(data:image/png;base64,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);\n}\n@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) {\n  .tsd-kind-icon:before {\n    background-image: url(data:image/png;base64,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);\n    background-size: 238px 204px;\n  }\n}\n\n.tsd-signature.tsd-kind-icon:before {\n  background-position: 0 -153px;\n}\n\n.tsd-kind-object-literal > .tsd-kind-icon:before {\n  background-position: 0px -17px;\n}\n.tsd-kind-object-literal.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -17px;\n}\n.tsd-kind-object-literal.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -17px;\n}\n\n.tsd-kind-class > .tsd-kind-icon:before {\n  background-position: 0px -34px;\n}\n.tsd-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -34px;\n}\n.tsd-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -34px;\n}\n\n.tsd-kind-class.tsd-has-type-parameter > .tsd-kind-icon:before {\n  background-position: 0px -51px;\n}\n.tsd-kind-class.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -51px;\n}\n.tsd-kind-class.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -51px;\n}\n\n.tsd-kind-interface > .tsd-kind-icon:before {\n  background-position: 0px -68px;\n}\n.tsd-kind-interface.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -68px;\n}\n.tsd-kind-interface.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -68px;\n}\n\n.tsd-kind-interface.tsd-has-type-parameter > .tsd-kind-icon:before {\n  background-position: 0px -85px;\n}\n.tsd-kind-interface.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -85px;\n}\n.tsd-kind-interface.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -85px;\n}\n\n.tsd-kind-namespace > .tsd-kind-icon:before {\n  background-position: 0px -102px;\n}\n.tsd-kind-namespace.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -102px;\n}\n.tsd-kind-namespace.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -102px;\n}\n\n.tsd-kind-module > .tsd-kind-icon:before {\n  background-position: 0px -102px;\n}\n.tsd-kind-module.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -102px;\n}\n.tsd-kind-module.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -102px;\n}\n\n.tsd-kind-enum > .tsd-kind-icon:before {\n  background-position: 0px -119px;\n}\n.tsd-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -119px;\n}\n.tsd-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -119px;\n}\n\n.tsd-kind-enum-member > .tsd-kind-icon:before {\n  background-position: 0px -136px;\n}\n.tsd-kind-enum-member.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -136px;\n}\n.tsd-kind-enum-member.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -136px;\n}\n\n.tsd-kind-signature > .tsd-kind-icon:before {\n  background-position: 0px -153px;\n}\n.tsd-kind-signature.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -153px;\n}\n.tsd-kind-signature.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -153px;\n}\n\n.tsd-kind-type-alias > .tsd-kind-icon:before {\n  background-position: 0px -170px;\n}\n.tsd-kind-type-alias.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -170px;\n}\n.tsd-kind-type-alias.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -170px;\n}\n\n.tsd-kind-type-alias.tsd-has-type-parameter > .tsd-kind-icon:before {\n  background-position: 0px -187px;\n}\n.tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -17px -187px;\n}\n.tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -34px -187px;\n}\n\n.tsd-kind-variable > .tsd-kind-icon:before {\n  background-position: -136px -0px;\n}\n.tsd-kind-variable.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -0px;\n}\n.tsd-kind-variable.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -0px;\n}\n.tsd-kind-variable.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -0px;\n}\n.tsd-kind-variable.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -0px;\n}\n.tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -0px;\n}\n.tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -0px;\n}\n.tsd-kind-variable.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -0px;\n}\n.tsd-kind-variable.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -0px;\n}\n.tsd-kind-variable.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -0px;\n}\n.tsd-kind-variable.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -0px;\n}\n.tsd-kind-variable.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -0px;\n}\n.tsd-kind-variable.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -0px;\n}\n\n.tsd-kind-property > .tsd-kind-icon:before {\n  background-position: -136px -0px;\n}\n.tsd-kind-property.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -0px;\n}\n.tsd-kind-property.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -0px;\n}\n.tsd-kind-property.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -0px;\n}\n.tsd-kind-property.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -0px;\n}\n.tsd-kind-property.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -0px;\n}\n.tsd-kind-property.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -0px;\n}\n.tsd-kind-property.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -0px;\n}\n.tsd-kind-property.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -0px;\n}\n.tsd-kind-property.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -0px;\n}\n.tsd-kind-property.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -0px;\n}\n.tsd-kind-property.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -0px;\n}\n.tsd-kind-property.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -0px;\n}\n\n.tsd-kind-get-signature > .tsd-kind-icon:before {\n  background-position: -136px -17px;\n}\n.tsd-kind-get-signature.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -17px;\n}\n.tsd-kind-get-signature.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -17px;\n}\n.tsd-kind-get-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -17px;\n}\n.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -17px;\n}\n.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -17px;\n}\n.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -17px;\n}\n.tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -17px;\n}\n.tsd-kind-get-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -17px;\n}\n.tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -17px;\n}\n.tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -17px;\n}\n.tsd-kind-get-signature.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -17px;\n}\n.tsd-kind-get-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -17px;\n}\n\n.tsd-kind-set-signature > .tsd-kind-icon:before {\n  background-position: -136px -34px;\n}\n.tsd-kind-set-signature.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -34px;\n}\n.tsd-kind-set-signature.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -34px;\n}\n.tsd-kind-set-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -34px;\n}\n.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -34px;\n}\n.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -34px;\n}\n.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -34px;\n}\n.tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -34px;\n}\n.tsd-kind-set-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -34px;\n}\n.tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -34px;\n}\n.tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -34px;\n}\n.tsd-kind-set-signature.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -34px;\n}\n.tsd-kind-set-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -34px;\n}\n\n.tsd-kind-accessor > .tsd-kind-icon:before {\n  background-position: -136px -51px;\n}\n.tsd-kind-accessor.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -51px;\n}\n.tsd-kind-accessor.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -51px;\n}\n.tsd-kind-accessor.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -51px;\n}\n.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -51px;\n}\n.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -51px;\n}\n.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -51px;\n}\n.tsd-kind-accessor.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -51px;\n}\n.tsd-kind-accessor.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -51px;\n}\n.tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -51px;\n}\n.tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -51px;\n}\n.tsd-kind-accessor.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -51px;\n}\n.tsd-kind-accessor.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -51px;\n}\n\n.tsd-kind-function > .tsd-kind-icon:before {\n  background-position: -136px -68px;\n}\n.tsd-kind-function.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -68px;\n}\n.tsd-kind-function.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -68px;\n}\n.tsd-kind-function.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -68px;\n}\n.tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -68px;\n}\n.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -68px;\n}\n.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -68px;\n}\n.tsd-kind-function.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -68px;\n}\n.tsd-kind-function.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -68px;\n}\n.tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -68px;\n}\n.tsd-kind-function.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -68px;\n}\n.tsd-kind-function.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -68px;\n}\n.tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -68px;\n}\n\n.tsd-kind-method > .tsd-kind-icon:before {\n  background-position: -136px -68px;\n}\n.tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -68px;\n}\n.tsd-kind-method.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -68px;\n}\n.tsd-kind-method.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -68px;\n}\n.tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -68px;\n}\n.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -68px;\n}\n.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -68px;\n}\n.tsd-kind-method.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -68px;\n}\n.tsd-kind-method.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -68px;\n}\n.tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -68px;\n}\n.tsd-kind-method.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -68px;\n}\n.tsd-kind-method.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -68px;\n}\n.tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -68px;\n}\n\n.tsd-kind-call-signature > .tsd-kind-icon:before {\n  background-position: -136px -68px;\n}\n.tsd-kind-call-signature.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -68px;\n}\n.tsd-kind-call-signature.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -68px;\n}\n.tsd-kind-call-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -68px;\n}\n.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -68px;\n}\n.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -68px;\n}\n.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -68px;\n}\n.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -68px;\n}\n.tsd-kind-call-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -68px;\n}\n.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -68px;\n}\n.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -68px;\n}\n.tsd-kind-call-signature.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -68px;\n}\n.tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -68px;\n}\n\n.tsd-kind-function.tsd-has-type-parameter > .tsd-kind-icon:before {\n  background-position: -136px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -85px;\n}\n.tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -85px;\n}\n\n.tsd-kind-method.tsd-has-type-parameter > .tsd-kind-icon:before {\n  background-position: -136px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -85px;\n}\n.tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -85px;\n}\n\n.tsd-kind-constructor > .tsd-kind-icon:before {\n  background-position: -136px -102px;\n}\n.tsd-kind-constructor.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -102px;\n}\n.tsd-kind-constructor.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -102px;\n}\n.tsd-kind-constructor.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -102px;\n}\n.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -102px;\n}\n.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -102px;\n}\n.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -102px;\n}\n.tsd-kind-constructor.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -102px;\n}\n.tsd-kind-constructor.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -102px;\n}\n.tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -102px;\n}\n.tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -102px;\n}\n.tsd-kind-constructor.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -102px;\n}\n.tsd-kind-constructor.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -102px;\n}\n\n.tsd-kind-constructor-signature > .tsd-kind-icon:before {\n  background-position: -136px -102px;\n}\n.tsd-kind-constructor-signature.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -102px;\n}\n.tsd-kind-constructor-signature.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -102px;\n}\n.tsd-kind-constructor-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -102px;\n}\n.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -102px;\n}\n.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -102px;\n}\n.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -102px;\n}\n.tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -102px;\n}\n.tsd-kind-constructor-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -102px;\n}\n.tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -102px;\n}\n.tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -102px;\n}\n.tsd-kind-constructor-signature.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -102px;\n}\n.tsd-kind-constructor-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -102px;\n}\n\n.tsd-kind-index-signature > .tsd-kind-icon:before {\n  background-position: -136px -119px;\n}\n.tsd-kind-index-signature.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -119px;\n}\n.tsd-kind-index-signature.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -119px;\n}\n.tsd-kind-index-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -119px;\n}\n.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -119px;\n}\n.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -119px;\n}\n.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -119px;\n}\n.tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -119px;\n}\n.tsd-kind-index-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -119px;\n}\n.tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -119px;\n}\n.tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -119px;\n}\n.tsd-kind-index-signature.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -119px;\n}\n.tsd-kind-index-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -119px;\n}\n\n.tsd-kind-event > .tsd-kind-icon:before {\n  background-position: -136px -136px;\n}\n.tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -136px;\n}\n.tsd-kind-event.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -136px;\n}\n.tsd-kind-event.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -136px;\n}\n.tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -136px;\n}\n.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -136px;\n}\n.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -136px;\n}\n.tsd-kind-event.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -136px;\n}\n.tsd-kind-event.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -136px;\n}\n.tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -136px;\n}\n.tsd-kind-event.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -136px;\n}\n.tsd-kind-event.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -136px;\n}\n.tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -136px;\n}\n\n.tsd-is-static > .tsd-kind-icon:before {\n  background-position: -136px -153px;\n}\n.tsd-is-static.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -153px;\n}\n.tsd-is-static.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -153px;\n}\n.tsd-is-static.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -153px;\n}\n.tsd-is-static.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -153px;\n}\n.tsd-is-static.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -153px;\n}\n.tsd-is-static.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -153px;\n}\n.tsd-is-static.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -153px;\n}\n.tsd-is-static.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -153px;\n}\n.tsd-is-static.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -153px;\n}\n.tsd-is-static.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -153px;\n}\n.tsd-is-static.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -153px;\n}\n.tsd-is-static.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -153px;\n}\n\n.tsd-is-static.tsd-kind-function > .tsd-kind-icon:before {\n  background-position: -136px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -170px;\n}\n.tsd-is-static.tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -170px;\n}\n\n.tsd-is-static.tsd-kind-method > .tsd-kind-icon:before {\n  background-position: -136px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -170px;\n}\n.tsd-is-static.tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -170px;\n}\n\n.tsd-is-static.tsd-kind-call-signature > .tsd-kind-icon:before {\n  background-position: -136px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -170px;\n}\n.tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -170px;\n}\n\n.tsd-is-static.tsd-kind-event > .tsd-kind-icon:before {\n  background-position: -136px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -153px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-parent-kind-class > .tsd-kind-icon:before {\n  background-position: -51px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -68px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -85px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -102px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum > .tsd-kind-icon:before {\n  background-position: -170px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n  background-position: -187px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n  background-position: -119px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-parent-kind-interface > .tsd-kind-icon:before {\n  background-position: -204px -187px;\n}\n.tsd-is-static.tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited > .tsd-kind-icon:before {\n  background-position: -221px -187px;\n}\n\n@keyframes fade-in {\n  from {\n    opacity: 0;\n  }\n  to {\n    opacity: 1;\n  }\n}\n@keyframes fade-out {\n  from {\n    opacity: 1;\n    visibility: visible;\n  }\n  to {\n    opacity: 0;\n  }\n}\n@keyframes fade-in-delayed {\n  0% {\n    opacity: 0;\n  }\n  33% {\n    opacity: 0;\n  }\n  100% {\n    opacity: 1;\n  }\n}\n@keyframes fade-out-delayed {\n  0% {\n    opacity: 1;\n    visibility: visible;\n  }\n  66% {\n    opacity: 0;\n  }\n  100% {\n    opacity: 0;\n  }\n}\n@keyframes shift-to-left {\n  from {\n    transform: translate(0, 0);\n  }\n  to {\n    transform: translate(-25%, 0);\n  }\n}\n@keyframes unshift-to-left {\n  from {\n    transform: translate(-25%, 0);\n  }\n  to {\n    transform: translate(0, 0);\n  }\n}\n@keyframes pop-in-from-right {\n  from {\n    transform: translate(100%, 0);\n  }\n  to {\n    transform: translate(0, 0);\n  }\n}\n@keyframes pop-out-to-right {\n  from {\n    transform: translate(0, 0);\n    visibility: visible;\n  }\n  to {\n    transform: translate(100%, 0);\n  }\n}\nbody {\n  background: var(--color-background);\n  font-family: \"Segoe UI\", sans-serif;\n  font-size: 16px;\n  color: var(--color-text);\n}\n\na {\n  color: var(--color-link);\n  text-decoration: none;\n}\na:hover {\n  text-decoration: underline;\n}\n\ncode, pre {\n  font-family: Menlo, Monaco, Consolas, \"Courier New\", monospace;\n  padding: 0.2em;\n  margin: 0;\n  font-size: 14px;\n  background-color: var(--color-code-background);\n}\n\npre {\n  padding: 10px;\n}\npre code {\n  padding: 0;\n  font-size: 100%;\n  background-color: transparent;\n}\n\nblockquote {\n  margin: 1em 0;\n  padding-left: 1em;\n  border-left: 4px solid gray;\n}\n\n.tsd-typography {\n  line-height: 1.333em;\n}\n.tsd-typography ul {\n  list-style: square;\n  padding: 0 0 0 20px;\n  margin: 0;\n}\n.tsd-typography h4, .tsd-typography .tsd-index-panel h3, .tsd-index-panel .tsd-typography h3, .tsd-typography h5, .tsd-typography h6 {\n  font-size: 1em;\n  margin: 0;\n}\n.tsd-typography h5, .tsd-typography h6 {\n  font-weight: normal;\n}\n.tsd-typography p, .tsd-typography ul, .tsd-typography ol {\n  margin: 1em 0;\n}\n\n@media (min-width: 901px) and (max-width: 1024px) {\n  html.default .col-content {\n    width: 72%;\n  }\n  html.default .col-menu {\n    width: 28%;\n  }\n  html.default .tsd-navigation {\n    padding-left: 10px;\n  }\n}\n@media (max-width: 900px) {\n  html.default .col-content {\n    float: none;\n    width: 100%;\n  }\n  html.default .col-menu {\n    position: fixed !important;\n    overflow: auto;\n    -webkit-overflow-scrolling: touch;\n    z-index: 1024;\n    top: 0 !important;\n    bottom: 0 !important;\n    left: auto !important;\n    right: 0 !important;\n    width: 100%;\n    padding: 20px 20px 0 0;\n    max-width: 450px;\n    visibility: hidden;\n    background-color: var(--color-panel);\n    transform: translate(100%, 0);\n  }\n  html.default .col-menu > *:last-child {\n    padding-bottom: 20px;\n  }\n  html.default .overlay {\n    content: \"\";\n    display: block;\n    position: fixed;\n    z-index: 1023;\n    top: 0;\n    left: 0;\n    right: 0;\n    bottom: 0;\n    background-color: rgba(0, 0, 0, 0.75);\n    visibility: hidden;\n  }\n  html.default.to-has-menu .overlay {\n    animation: fade-in 0.4s;\n  }\n  html.default.to-has-menu header,\nhtml.default.to-has-menu footer,\nhtml.default.to-has-menu .col-content {\n    animation: shift-to-left 0.4s;\n  }\n  html.default.to-has-menu .col-menu {\n    animation: pop-in-from-right 0.4s;\n  }\n  html.default.from-has-menu .overlay {\n    animation: fade-out 0.4s;\n  }\n  html.default.from-has-menu header,\nhtml.default.from-has-menu footer,\nhtml.default.from-has-menu .col-content {\n    animation: unshift-to-left 0.4s;\n  }\n  html.default.from-has-menu .col-menu {\n    animation: pop-out-to-right 0.4s;\n  }\n  html.default.has-menu body {\n    overflow: hidden;\n  }\n  html.default.has-menu .overlay {\n    visibility: visible;\n  }\n  html.default.has-menu header,\nhtml.default.has-menu footer,\nhtml.default.has-menu .col-content {\n    transform: translate(-25%, 0);\n  }\n  html.default.has-menu .col-menu {\n    visibility: visible;\n    transform: translate(0, 0);\n  }\n}\n\n.tsd-page-title {\n  padding: 70px 0 20px 0;\n  margin: 0 0 40px 0;\n  background: var(--color-panel);\n  box-shadow: 0 0 5px rgba(0, 0, 0, 0.35);\n}\n.tsd-page-title h1 {\n  margin: 0;\n}\n\n.tsd-breadcrumb {\n  margin: 0;\n  padding: 0;\n  color: var(--color-text-aside);\n}\n.tsd-breadcrumb a {\n  color: var(--color-text-aside);\n  text-decoration: none;\n}\n.tsd-breadcrumb a:hover {\n  text-decoration: underline;\n}\n.tsd-breadcrumb li {\n  display: inline;\n}\n.tsd-breadcrumb li:after {\n  content: \" / \";\n}\n\nhtml.minimal .container {\n  margin: 0;\n}\nhtml.minimal .container-main {\n  padding-top: 50px;\n  padding-bottom: 0;\n}\nhtml.minimal .content-wrap {\n  padding-left: 300px;\n}\nhtml.minimal .tsd-navigation {\n  position: fixed !important;\n  overflow: auto;\n  -webkit-overflow-scrolling: touch;\n  box-sizing: border-box;\n  z-index: 1;\n  left: 0;\n  top: 40px;\n  bottom: 0;\n  width: 300px;\n  padding: 20px;\n  margin: 0;\n}\nhtml.minimal .tsd-member .tsd-member {\n  margin-left: 0;\n}\nhtml.minimal .tsd-page-toolbar {\n  position: fixed;\n  z-index: 2;\n}\nhtml.minimal #tsd-filter .tsd-filter-group {\n  right: 0;\n  transform: none;\n}\nhtml.minimal footer {\n  background-color: transparent;\n}\nhtml.minimal footer .container {\n  padding: 0;\n}\nhtml.minimal .tsd-generator {\n  padding: 0;\n}\n@media (max-width: 900px) {\n  html.minimal .tsd-navigation {\n    display: none;\n  }\n  html.minimal .content-wrap {\n    padding-left: 0;\n  }\n}\n\ndl.tsd-comment-tags {\n  overflow: hidden;\n}\ndl.tsd-comment-tags dt {\n  float: left;\n  padding: 1px 5px;\n  margin: 0 10px 0 0;\n  border-radius: 4px;\n  border: 1px solid var(--color-comment-tag);\n  color: var(--color-comment-tag);\n  font-size: 0.8em;\n  font-weight: normal;\n}\ndl.tsd-comment-tags dd {\n  margin: 0 0 10px 0;\n}\ndl.tsd-comment-tags dd:before, dl.tsd-comment-tags dd:after {\n  display: table;\n  content: \" \";\n}\ndl.tsd-comment-tags dd pre, dl.tsd-comment-tags dd:after {\n  clear: both;\n}\ndl.tsd-comment-tags p {\n  margin: 0;\n}\n\n.tsd-panel.tsd-comment .lead {\n  font-size: 1.1em;\n  line-height: 1.333em;\n  margin-bottom: 2em;\n}\n.tsd-panel.tsd-comment .lead:last-child {\n  margin-bottom: 0;\n}\n\n.toggle-protected .tsd-is-private {\n  display: none;\n}\n\n.toggle-public .tsd-is-private,\n.toggle-public .tsd-is-protected,\n.toggle-public .tsd-is-private-protected {\n  display: none;\n}\n\n.toggle-inherited .tsd-is-inherited {\n  display: none;\n}\n\n.toggle-externals .tsd-is-external {\n  display: none;\n}\n\n#tsd-filter {\n  position: relative;\n  display: inline-block;\n  height: 40px;\n  vertical-align: bottom;\n}\n.no-filter #tsd-filter {\n  display: none;\n}\n#tsd-filter .tsd-filter-group {\n  display: inline-block;\n  height: 40px;\n  vertical-align: bottom;\n  white-space: nowrap;\n}\n#tsd-filter input {\n  display: none;\n}\n@media (max-width: 900px) {\n  #tsd-filter .tsd-filter-group {\n    display: block;\n    position: absolute;\n    top: 40px;\n    right: 20px;\n    height: auto;\n    background-color: var(--color-panel);\n    visibility: hidden;\n    transform: translate(50%, 0);\n    box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n  }\n  .has-options #tsd-filter .tsd-filter-group {\n    visibility: visible;\n  }\n  .to-has-options #tsd-filter .tsd-filter-group {\n    animation: fade-in 0.2s;\n  }\n  .from-has-options #tsd-filter .tsd-filter-group {\n    animation: fade-out 0.2s;\n  }\n  #tsd-filter label,\n#tsd-filter .tsd-select {\n    display: block;\n    padding-right: 20px;\n  }\n}\n\nfooter {\n  border-top: 1px solid var(--color-panel-divider);\n  background-color: var(--color-panel);\n}\nfooter.with-border-bottom {\n  border-bottom: 1px solid var(--color-panel-divider);\n}\nfooter .tsd-legend-group {\n  font-size: 0;\n}\nfooter .tsd-legend {\n  display: inline-block;\n  width: 25%;\n  padding: 0;\n  font-size: 16px;\n  list-style: none;\n  line-height: 1.333em;\n  vertical-align: top;\n}\n@media (max-width: 900px) {\n  footer .tsd-legend {\n    width: 50%;\n  }\n}\n\n.tsd-hierarchy {\n  list-style: square;\n  padding: 0 0 0 20px;\n  margin: 0;\n}\n.tsd-hierarchy .target {\n  font-weight: bold;\n}\n\n.tsd-index-panel .tsd-index-content {\n  margin-bottom: -30px !important;\n}\n.tsd-index-panel .tsd-index-section {\n  margin-bottom: 30px !important;\n}\n.tsd-index-panel h3 {\n  margin: 0 -20px 10px -20px;\n  padding: 0 20px 10px 20px;\n  border-bottom: 1px solid var(--color-panel-divider);\n}\n.tsd-index-panel ul.tsd-index-list {\n  -webkit-column-count: 3;\n  -moz-column-count: 3;\n  -ms-column-count: 3;\n  -o-column-count: 3;\n  column-count: 3;\n  -webkit-column-gap: 20px;\n  -moz-column-gap: 20px;\n  -ms-column-gap: 20px;\n  -o-column-gap: 20px;\n  column-gap: 20px;\n  padding: 0;\n  list-style: none;\n  line-height: 1.333em;\n}\n@media (max-width: 900px) {\n  .tsd-index-panel ul.tsd-index-list {\n    -webkit-column-count: 1;\n    -moz-column-count: 1;\n    -ms-column-count: 1;\n    -o-column-count: 1;\n    column-count: 1;\n  }\n}\n@media (min-width: 901px) and (max-width: 1024px) {\n  .tsd-index-panel ul.tsd-index-list {\n    -webkit-column-count: 2;\n    -moz-column-count: 2;\n    -ms-column-count: 2;\n    -o-column-count: 2;\n    column-count: 2;\n  }\n}\n.tsd-index-panel ul.tsd-index-list li {\n  -webkit-page-break-inside: avoid;\n  -moz-page-break-inside: avoid;\n  -ms-page-break-inside: avoid;\n  -o-page-break-inside: avoid;\n  page-break-inside: avoid;\n}\n.tsd-index-panel a,\n.tsd-index-panel .tsd-parent-kind-module a {\n  color: var(--color-ts);\n}\n.tsd-index-panel .tsd-parent-kind-interface a {\n  color: var(--color-ts-interface);\n}\n.tsd-index-panel .tsd-parent-kind-enum a {\n  color: var(--color-ts-enum);\n}\n.tsd-index-panel .tsd-parent-kind-class a {\n  color: var(--color-ts-class);\n}\n.tsd-index-panel .tsd-kind-module a {\n  color: var(--color-ts);\n}\n.tsd-index-panel .tsd-kind-interface a {\n  color: var(--color-ts-interface);\n}\n.tsd-index-panel .tsd-kind-enum a {\n  color: var(--color-ts-enum);\n}\n.tsd-index-panel .tsd-kind-class a {\n  color: var(--color-ts-class);\n}\n.tsd-index-panel .tsd-is-private a {\n  color: var(--color-ts-private);\n}\n\n.tsd-flag {\n  display: inline-block;\n  padding: 1px 5px;\n  border-radius: 4px;\n  color: var(--color-comment-tag-text);\n  background-color: var(--color-comment-tag);\n  text-indent: 0;\n  font-size: 14px;\n  font-weight: normal;\n}\n\n.tsd-anchor {\n  position: absolute;\n  top: -100px;\n}\n\n.tsd-member {\n  position: relative;\n}\n.tsd-member .tsd-anchor + h3 {\n  margin-top: 0;\n  margin-bottom: 0;\n  border-bottom: none;\n}\n.tsd-member a[data-tsd-kind] {\n  color: var(--color-ts);\n}\n.tsd-member a[data-tsd-kind=Interface] {\n  color: var(--color-ts-interface);\n}\n.tsd-member a[data-tsd-kind=Enum] {\n  color: var(--color-ts-enum);\n}\n.tsd-member a[data-tsd-kind=Class] {\n  color: var(--color-ts-class);\n}\n.tsd-member a[data-tsd-kind=Private] {\n  color: var(--color-ts-private);\n}\n\n.tsd-navigation {\n  margin: 0 0 0 40px;\n}\n.tsd-navigation a {\n  display: block;\n  padding-top: 2px;\n  padding-bottom: 2px;\n  border-left: 2px solid transparent;\n  color: var(--color-text);\n  text-decoration: none;\n  transition: border-left-color 0.1s;\n}\n.tsd-navigation a:hover {\n  text-decoration: underline;\n}\n.tsd-navigation ul {\n  margin: 0;\n  padding: 0;\n  list-style: none;\n}\n.tsd-navigation li {\n  padding: 0;\n}\n\n.tsd-navigation.primary {\n  padding-bottom: 40px;\n}\n.tsd-navigation.primary a {\n  display: block;\n  padding-top: 6px;\n  padding-bottom: 6px;\n}\n.tsd-navigation.primary ul li a {\n  padding-left: 5px;\n}\n.tsd-navigation.primary ul li li a {\n  padding-left: 25px;\n}\n.tsd-navigation.primary ul li li li a {\n  padding-left: 45px;\n}\n.tsd-navigation.primary ul li li li li a {\n  padding-left: 65px;\n}\n.tsd-navigation.primary ul li li li li li a {\n  padding-left: 85px;\n}\n.tsd-navigation.primary ul li li li li li li a {\n  padding-left: 105px;\n}\n.tsd-navigation.primary > ul {\n  border-bottom: 1px solid var(--color-panel-divider);\n}\n.tsd-navigation.primary li {\n  border-top: 1px solid var(--color-panel-divider);\n}\n.tsd-navigation.primary li.current > a {\n  font-weight: bold;\n}\n.tsd-navigation.primary li.label span {\n  display: block;\n  padding: 20px 0 6px 5px;\n  color: var(--color-menu-label);\n}\n.tsd-navigation.primary li.globals + li > span, .tsd-navigation.primary li.globals + li > a {\n  padding-top: 20px;\n}\n\n.tsd-navigation.secondary {\n  max-height: calc(100vh - 1rem - 40px);\n  overflow: auto;\n  position: -webkit-sticky;\n  position: sticky;\n  top: calc(.5rem + 40px);\n  transition: 0.3s;\n}\n.tsd-navigation.secondary.tsd-navigation--toolbar-hide {\n  max-height: calc(100vh - 1rem);\n  top: 0.5rem;\n}\n.tsd-navigation.secondary ul {\n  transition: opacity 0.2s;\n}\n.tsd-navigation.secondary ul li a {\n  padding-left: 25px;\n}\n.tsd-navigation.secondary ul li li a {\n  padding-left: 45px;\n}\n.tsd-navigation.secondary ul li li li a {\n  padding-left: 65px;\n}\n.tsd-navigation.secondary ul li li li li a {\n  padding-left: 85px;\n}\n.tsd-navigation.secondary ul li li li li li a {\n  padding-left: 105px;\n}\n.tsd-navigation.secondary ul li li li li li li a {\n  padding-left: 125px;\n}\n.tsd-navigation.secondary ul.current a {\n  border-left-color: var(--color-panel-divider);\n}\n.tsd-navigation.secondary li.focus > a,\n.tsd-navigation.secondary ul.current li.focus > a {\n  border-left-color: var(--color-menu-divider-focus);\n}\n.tsd-navigation.secondary li.current {\n  margin-top: 20px;\n  margin-bottom: 20px;\n  border-left-color: var(--color-panel-divider);\n}\n.tsd-navigation.secondary li.current > a {\n  font-weight: bold;\n}\n\n@media (min-width: 901px) {\n  .menu-sticky-wrap {\n    position: static;\n  }\n}\n\n.tsd-panel {\n  margin: 20px 0;\n  padding: 20px;\n  background-color: var(--color-panel);\n  box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n}\n.tsd-panel:empty {\n  display: none;\n}\n.tsd-panel > h1, .tsd-panel > h2, .tsd-panel > h3 {\n  margin: 1.5em -20px 10px -20px;\n  padding: 0 20px 10px 20px;\n  border-bottom: 1px solid var(--color-panel-divider);\n}\n.tsd-panel > h1.tsd-before-signature, .tsd-panel > h2.tsd-before-signature, .tsd-panel > h3.tsd-before-signature {\n  margin-bottom: 0;\n  border-bottom: 0;\n}\n.tsd-panel table {\n  display: block;\n  width: 100%;\n  overflow: auto;\n  margin-top: 10px;\n  word-break: normal;\n  word-break: keep-all;\n}\n.tsd-panel table th {\n  font-weight: bold;\n}\n.tsd-panel table th, .tsd-panel table td {\n  padding: 6px 13px;\n  border: 1px solid #ddd;\n}\n.tsd-panel table tr {\n  background-color: #fff;\n  border-top: 1px solid #ccc;\n}\n.tsd-panel table tr:nth-child(2n) {\n  background-color: #f8f8f8;\n}\n\n.tsd-panel-group {\n  margin: 60px 0;\n}\n.tsd-panel-group > h1, .tsd-panel-group > h2, .tsd-panel-group > h3 {\n  padding-left: 20px;\n  padding-right: 20px;\n}\n\n#tsd-search {\n  transition: background-color 0.2s;\n}\n#tsd-search .title {\n  position: relative;\n  z-index: 2;\n}\n#tsd-search .field {\n  position: absolute;\n  left: 0;\n  top: 0;\n  right: 40px;\n  height: 40px;\n}\n#tsd-search .field input {\n  box-sizing: border-box;\n  position: relative;\n  top: -50px;\n  z-index: 1;\n  width: 100%;\n  padding: 0 10px;\n  opacity: 0;\n  outline: 0;\n  border: 0;\n  background: transparent;\n  color: var(--color-text);\n}\n#tsd-search .field label {\n  position: absolute;\n  overflow: hidden;\n  right: -40px;\n}\n#tsd-search .field input,\n#tsd-search .title {\n  transition: opacity 0.2s;\n}\n#tsd-search .results {\n  position: absolute;\n  visibility: hidden;\n  top: 40px;\n  width: 100%;\n  margin: 0;\n  padding: 0;\n  list-style: none;\n  box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n}\n#tsd-search .results li {\n  padding: 0 10px;\n  background-color: var(--color-background);\n}\n#tsd-search .results li:nth-child(even) {\n  background-color: var(--color-panel);\n}\n#tsd-search .results li.state {\n  display: none;\n}\n#tsd-search .results li.current,\n#tsd-search .results li:hover {\n  background-color: var(--color-panel-divider);\n}\n#tsd-search .results a {\n  display: block;\n}\n#tsd-search .results a:before {\n  top: 10px;\n}\n#tsd-search .results span.parent {\n  color: var(--color-text-aside);\n  font-weight: normal;\n}\n#tsd-search.has-focus {\n  background-color: var(--color-panel-divider);\n}\n#tsd-search.has-focus .field input {\n  top: 0;\n  opacity: 1;\n}\n#tsd-search.has-focus .title {\n  z-index: 0;\n  opacity: 0;\n}\n#tsd-search.has-focus .results {\n  visibility: visible;\n}\n#tsd-search.loading .results li.state.loading {\n  display: block;\n}\n#tsd-search.failure .results li.state.failure {\n  display: block;\n}\n\n.tsd-signature {\n  margin: 0 0 1em 0;\n  padding: 10px;\n  border: 1px solid var(--color-panel-divider);\n  font-family: Menlo, Monaco, Consolas, \"Courier New\", monospace;\n  font-size: 14px;\n  overflow-x: auto;\n}\n.tsd-signature.tsd-kind-icon {\n  padding-left: 30px;\n}\n.tsd-signature.tsd-kind-icon:before {\n  top: 10px;\n  left: 10px;\n}\n.tsd-panel > .tsd-signature {\n  margin-left: -20px;\n  margin-right: -20px;\n  border-width: 1px 0;\n}\n.tsd-panel > .tsd-signature.tsd-kind-icon {\n  padding-left: 40px;\n}\n.tsd-panel > .tsd-signature.tsd-kind-icon:before {\n  left: 20px;\n}\n\n.tsd-signature-symbol {\n  color: var(--color-text-aside);\n  font-weight: normal;\n}\n\n.tsd-signature-type {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.tsd-signatures {\n  padding: 0;\n  margin: 0 0 1em 0;\n  border: 1px solid var(--color-panel-divider);\n}\n.tsd-signatures .tsd-signature {\n  margin: 0;\n  border-width: 1px 0 0 0;\n  transition: background-color 0.1s;\n}\n.tsd-signatures .tsd-signature:first-child {\n  border-top-width: 0;\n}\n.tsd-signatures .tsd-signature.current {\n  background-color: var(--color-panel-divider);\n}\n.tsd-signatures.active > .tsd-signature {\n  cursor: pointer;\n}\n.tsd-panel > .tsd-signatures {\n  margin-left: -20px;\n  margin-right: -20px;\n  border-width: 1px 0;\n}\n.tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon {\n  padding-left: 40px;\n}\n.tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon:before {\n  left: 20px;\n}\n.tsd-panel > a.anchor + .tsd-signatures {\n  border-top-width: 0;\n  margin-top: -20px;\n}\n\nul.tsd-descriptions {\n  position: relative;\n  overflow: hidden;\n  padding: 0;\n  list-style: none;\n}\nul.tsd-descriptions.active > .tsd-description {\n  display: none;\n}\nul.tsd-descriptions.active > .tsd-description.current {\n  display: block;\n}\nul.tsd-descriptions.active > .tsd-description.fade-in {\n  animation: fade-in-delayed 0.3s;\n}\nul.tsd-descriptions.active > .tsd-description.fade-out {\n  animation: fade-out-delayed 0.3s;\n  position: absolute;\n  display: block;\n  top: 0;\n  left: 0;\n  right: 0;\n  opacity: 0;\n  visibility: hidden;\n}\nul.tsd-descriptions h4, ul.tsd-descriptions .tsd-index-panel h3, .tsd-index-panel ul.tsd-descriptions h3 {\n  font-size: 16px;\n  margin: 1em 0 0.5em 0;\n}\n\nul.tsd-parameters,\nul.tsd-type-parameters {\n  list-style: square;\n  margin: 0;\n  padding-left: 20px;\n}\nul.tsd-parameters > li.tsd-parameter-signature,\nul.tsd-type-parameters > li.tsd-parameter-signature {\n  list-style: none;\n  margin-left: -20px;\n}\nul.tsd-parameters h5,\nul.tsd-type-parameters h5 {\n  font-size: 16px;\n  margin: 1em 0 0.5em 0;\n}\nul.tsd-parameters .tsd-comment,\nul.tsd-type-parameters .tsd-comment {\n  margin-top: -0.5em;\n}\n\n.tsd-sources {\n  font-size: 14px;\n  color: var(--color-text-aside);\n  margin: 0 0 1em 0;\n}\n.tsd-sources a {\n  color: var(--color-text-aside);\n  text-decoration: underline;\n}\n.tsd-sources ul, .tsd-sources p {\n  margin: 0 !important;\n}\n.tsd-sources ul {\n  list-style: none;\n  padding: 0;\n}\n\n.tsd-page-toolbar {\n  position: fixed;\n  z-index: 1;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 40px;\n  color: var(--color-toolbar-text);\n  background: var(--color-toolbar);\n  border-bottom: 1px solid var(--color-panel-divider);\n  transition: transform 0.3s linear;\n}\n.tsd-page-toolbar a {\n  color: var(--color-toolbar-text);\n  text-decoration: none;\n}\n.tsd-page-toolbar a.title {\n  font-weight: bold;\n}\n.tsd-page-toolbar a.title:hover {\n  text-decoration: underline;\n}\n.tsd-page-toolbar .table-wrap {\n  display: table;\n  width: 100%;\n  height: 40px;\n}\n.tsd-page-toolbar .table-cell {\n  display: table-cell;\n  position: relative;\n  white-space: nowrap;\n  line-height: 40px;\n}\n.tsd-page-toolbar .table-cell:first-child {\n  width: 100%;\n}\n\n.tsd-page-toolbar--hide {\n  transform: translateY(-100%);\n}\n\n.tsd-select .tsd-select-list li:before, .tsd-select .tsd-select-label:before, .tsd-widget:before {\n  content: \"\";\n  display: inline-block;\n  width: 40px;\n  height: 40px;\n  margin: 0 -8px 0 0;\n  background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAUAAAAAoCAQAAAAlSeuiAAABp0lEQVR4Ae3aUa3jQAyF4QNhIBTCQiiEQlgIhRAGhTAQBkIgBEIgDITZZGXNjZTePiSWYqn/54dGfbAq+SiTutWXAgAAAAAAAAAAAAA8NCz1UFSD2lKDS5d3NVzZj/BVNasaLoRZRUmj2lLrVVHWMUntQ13Wj/i1pWa9lprX6xMRnH4dx6Rjsn26+v+12ms+EcB37P0r+qH+DNQGXgMFcHzbregQ78B8eQCTJk0e979ZW7PdA2O49ceDsYexKgUNoI3EKYDWL3D8miaPh/uXtl6BHqEHFQvgXau/FsCiIWAAbST2fpQRT0sl70j3z5ZiBdD7CG5WZX8kxwmgjbiP5GQA9/3O2XaxnnHi53AEE0AbRh+JQwC3/fzC4hcb6xPvS4i3QaMdwX+0utsRPEY6gm2wNhKHAG77eUi7SIcK4G4NY4GMIan2u2Cxqzncl5DUn7Q8ArjvZ8JFOsl/Ed0jyBom+BomQKSto+9PcblHMM4iuu4X0QQw5hrGQY/gUxFkjZuf4m4alXVU+1De/VhEn5CvDSB/RsBzqWgAAAAAAAAAAAAAAACAfyyYJ5nhVuwIAAAAAElFTkSuQmCC);\n  background-repeat: no-repeat;\n  text-indent: -1024px;\n  vertical-align: bottom;\n}\n@media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) {\n  .tsd-select .tsd-select-list li:before, .tsd-select .tsd-select-label:before, .tsd-widget:before {\n    background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAoAAAABQCAMAAAC+sjQXAAAAM1BMVEUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACjBUbJAAAAEXRSTlMA3/+/UCBw7xCPYIBAMM+vn1qYQ7QAAALCSURBVHgB7MGBAAAAAICg/akXqQIAAAAAAAAAAAAAAAAAAJids9mdE4bhoDNZCITP93/aSmhV/9uwPWyi8jtkblws2IxsYpz9LwSAaJW8AreE16PxOsMYE6Q4DiYKF7X+8ZHXc/E608xv5snEyIuZrVwMZjbnujR6T3gsXmcLOIRNzD+Ig2UuVtt2+NbAiX/wVLzOlviD9L2BOfGBlL/3D1I+uDjGBJArBPxU3x+K15kCQFo2s21JAOHrKpz4SPrWv4IKA+uFaR6vMwMcb+emA2DWEfDglrkLqEBOKVslA8Dx14oPMiV4CtywWxdQgAwkq2QE0uTXUwJGk2G9s3mTFNBzAkC7HKPsX72AEVjMnAWIpsPCRRjXdQxcjCYpoOcEgHY5Rtk/slWSgM3M2aSeeVgjAOeVpKcdgGMdNAXMuIAqOcZzqF8L+WcAsi8wkTeheCWMegL6mgCorHHyEJ5TVfxrLWDrTUjZdhnhjYqAnlN8TaoELOLVC0gucmoz/3RKcPs2jAs4+J5ET8AEZF+TSgGLeC1V8YuGQQU2IV1Asq9JCwE9XitZVPxr34bpJRj8PqsFLOK108W9aVrWZRrR7Sm2HL4JCToCujHZ6gUs4jUz0P1TEvD+U5wMa363YeziBODIq1YbJrsv9QKW8Ry1nNp+GAHvuingRTfmYcjBf0QpAS37bdUL6PFKtHJq63EsZ5cxcKMkDVIClu1dAK1PcJ5TFQ0M9wZKDCPs3BD7MIJGTs3WfiTfDVQYx5q5ZekCauTU3P5Q0ukGCgh49oFURdobWBY9N/CxEuwGjpGLuPhTdwH1x7HqDDxNgRP2zQ8lraFyF/yJ9vH6QGqtgSbBOU8/j2VORz+Wqfle2d5Ae4R+ML0z7Y+W4P7XHN3AU+tzyK/24EAGAAAAYJC/9T2+CgAAAAAAAAAAAAAAAAAAAADgJpfzHyIKFFBKAAAAAElFTkSuQmCC);\n    background-size: 320px 40px;\n  }\n}\n\n.tsd-widget {\n  display: inline-block;\n  overflow: hidden;\n  opacity: 0.6;\n  height: 40px;\n  transition: opacity 0.1s, background-color 0.2s;\n  vertical-align: bottom;\n  cursor: pointer;\n}\n.tsd-widget:hover {\n  opacity: 0.8;\n}\n.tsd-widget.active {\n  opacity: 1;\n  background-color: var(--color-panel-divider);\n}\n.tsd-widget.no-caption {\n  width: 40px;\n}\n.tsd-widget.no-caption:before {\n  margin: 0;\n}\n.tsd-widget.search:before {\n  background-position: 0 0;\n}\n.tsd-widget.menu:before {\n  background-position: -40px 0;\n}\n.tsd-widget.options:before {\n  background-position: -80px 0;\n}\n.tsd-widget.options, .tsd-widget.menu {\n  display: none;\n}\n@media (max-width: 900px) {\n  .tsd-widget.options, .tsd-widget.menu {\n    display: inline-block;\n  }\n}\ninput[type=checkbox] + .tsd-widget:before {\n  background-position: -120px 0;\n}\ninput[type=checkbox]:checked + .tsd-widget:before {\n  background-position: -160px 0;\n}\n\n.tsd-select {\n  position: relative;\n  display: inline-block;\n  height: 40px;\n  transition: opacity 0.1s, background-color 0.2s;\n  vertical-align: bottom;\n  cursor: pointer;\n}\n.tsd-select .tsd-select-label {\n  opacity: 0.6;\n  transition: opacity 0.2s;\n}\n.tsd-select .tsd-select-label:before {\n  background-position: -240px 0;\n}\n.tsd-select.active .tsd-select-label {\n  opacity: 0.8;\n}\n.tsd-select.active .tsd-select-list {\n  visibility: visible;\n  opacity: 1;\n  transition-delay: 0s;\n}\n.tsd-select .tsd-select-list {\n  position: absolute;\n  visibility: hidden;\n  top: 40px;\n  left: 0;\n  margin: 0;\n  padding: 0;\n  opacity: 0;\n  list-style: none;\n  box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n  transition: visibility 0s 0.2s, opacity 0.2s;\n}\n.tsd-select .tsd-select-list li {\n  padding: 0 20px 0 0;\n  background-color: var(--color-background);\n}\n.tsd-select .tsd-select-list li:before {\n  background-position: 40px 0;\n}\n.tsd-select .tsd-select-list li:nth-child(even) {\n  background-color: var(--color-panel);\n}\n.tsd-select .tsd-select-list li:hover {\n  background-color: var(--color-panel-divider);\n}\n.tsd-select .tsd-select-list li.selected:before {\n  background-position: -200px 0;\n}\n@media (max-width: 900px) {\n  .tsd-select .tsd-select-list {\n    top: 0;\n    left: auto;\n    right: 100%;\n    margin-right: -5px;\n  }\n  .tsd-select .tsd-select-label:before {\n    background-position: -280px 0;\n  }\n}\n\nimg {\n  max-width: 100%;\n}\n"
  },
  {
    "path": "typedocs/assets/js/main.js",
    "content": "/*\n * ATTENTION: The \"eval\" devtool has been used (maybe by default in mode: \"development\").\n * This devtool is not neither made for production nor for readable output files.\n * It uses \"eval()\" calls to create a separate source file in the browser devtools.\n * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)\n * or disable the default devtool with \"devtool: false\".\n * If you are looking for production-ready output files, see mode: \"production\" (https://webpack.js.org/configuration/mode/).\n */\n/******/ (() => { // webpackBootstrap\n/******/ \tvar __webpack_modules__ = ({\n\n/***/ \"../node_modules/lunr/lunr.js\":\n/*!************************************!*\\\n  !*** ../node_modules/lunr/lunr.js ***!\n  \\************************************/\n/***/ ((module, exports, __webpack_require__) => {\n\neval(\"var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;/**\\n * lunr - http://lunrjs.com - A bit like Solr, but much smaller and not as bright - 2.3.9\\n * Copyright (C) 2020 Oliver Nightingale\\n * @license MIT\\n */\\n\\n;(function(){\\n\\n/**\\n * A convenience function for configuring and constructing\\n * a new lunr Index.\\n *\\n * A lunr.Builder instance is created and the pipeline setup\\n * with a trimmer, stop word filter and stemmer.\\n *\\n * This builder object is yielded to the configuration function\\n * that is passed as a parameter, allowing the list of fields\\n * and other builder parameters to be customised.\\n *\\n * All documents _must_ be added within the passed config function.\\n *\\n * @example\\n * var idx = lunr(function () {\\n *   this.field('title')\\n *   this.field('body')\\n *   this.ref('id')\\n *\\n *   documents.forEach(function (doc) {\\n *     this.add(doc)\\n *   }, this)\\n * })\\n *\\n * @see {@link lunr.Builder}\\n * @see {@link lunr.Pipeline}\\n * @see {@link lunr.trimmer}\\n * @see {@link lunr.stopWordFilter}\\n * @see {@link lunr.stemmer}\\n * @namespace {function} lunr\\n */\\nvar lunr = function (config) {\\n  var builder = new lunr.Builder\\n\\n  builder.pipeline.add(\\n    lunr.trimmer,\\n    lunr.stopWordFilter,\\n    lunr.stemmer\\n  )\\n\\n  builder.searchPipeline.add(\\n    lunr.stemmer\\n  )\\n\\n  config.call(builder, builder)\\n  return builder.build()\\n}\\n\\nlunr.version = \\\"2.3.9\\\"\\n/*!\\n * lunr.utils\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A namespace containing utils for the rest of the lunr library\\n * @namespace lunr.utils\\n */\\nlunr.utils = {}\\n\\n/**\\n * Print a warning message to the console.\\n *\\n * @param {String} message The message to be printed.\\n * @memberOf lunr.utils\\n * @function\\n */\\nlunr.utils.warn = (function (global) {\\n  /* eslint-disable no-console */\\n  return function (message) {\\n    if (global.console && console.warn) {\\n      console.warn(message)\\n    }\\n  }\\n  /* eslint-enable no-console */\\n})(this)\\n\\n/**\\n * Convert an object to a string.\\n *\\n * In the case of `null` and `undefined` the function returns\\n * the empty string, in all other cases the result of calling\\n * `toString` on the passed object is returned.\\n *\\n * @param {Any} obj The object to convert to a string.\\n * @return {String} string representation of the passed object.\\n * @memberOf lunr.utils\\n */\\nlunr.utils.asString = function (obj) {\\n  if (obj === void 0 || obj === null) {\\n    return \\\"\\\"\\n  } else {\\n    return obj.toString()\\n  }\\n}\\n\\n/**\\n * Clones an object.\\n *\\n * Will create a copy of an existing object such that any mutations\\n * on the copy cannot affect the original.\\n *\\n * Only shallow objects are supported, passing a nested object to this\\n * function will cause a TypeError.\\n *\\n * Objects with primitives, and arrays of primitives are supported.\\n *\\n * @param {Object} obj The object to clone.\\n * @return {Object} a clone of the passed object.\\n * @throws {TypeError} when a nested object is passed.\\n * @memberOf Utils\\n */\\nlunr.utils.clone = function (obj) {\\n  if (obj === null || obj === undefined) {\\n    return obj\\n  }\\n\\n  var clone = Object.create(null),\\n      keys = Object.keys(obj)\\n\\n  for (var i = 0; i < keys.length; i++) {\\n    var key = keys[i],\\n        val = obj[key]\\n\\n    if (Array.isArray(val)) {\\n      clone[key] = val.slice()\\n      continue\\n    }\\n\\n    if (typeof val === 'string' ||\\n        typeof val === 'number' ||\\n        typeof val === 'boolean') {\\n      clone[key] = val\\n      continue\\n    }\\n\\n    throw new TypeError(\\\"clone is not deep and does not support nested objects\\\")\\n  }\\n\\n  return clone\\n}\\nlunr.FieldRef = function (docRef, fieldName, stringValue) {\\n  this.docRef = docRef\\n  this.fieldName = fieldName\\n  this._stringValue = stringValue\\n}\\n\\nlunr.FieldRef.joiner = \\\"/\\\"\\n\\nlunr.FieldRef.fromString = function (s) {\\n  var n = s.indexOf(lunr.FieldRef.joiner)\\n\\n  if (n === -1) {\\n    throw \\\"malformed field ref string\\\"\\n  }\\n\\n  var fieldRef = s.slice(0, n),\\n      docRef = s.slice(n + 1)\\n\\n  return new lunr.FieldRef (docRef, fieldRef, s)\\n}\\n\\nlunr.FieldRef.prototype.toString = function () {\\n  if (this._stringValue == undefined) {\\n    this._stringValue = this.fieldName + lunr.FieldRef.joiner + this.docRef\\n  }\\n\\n  return this._stringValue\\n}\\n/*!\\n * lunr.Set\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A lunr set.\\n *\\n * @constructor\\n */\\nlunr.Set = function (elements) {\\n  this.elements = Object.create(null)\\n\\n  if (elements) {\\n    this.length = elements.length\\n\\n    for (var i = 0; i < this.length; i++) {\\n      this.elements[elements[i]] = true\\n    }\\n  } else {\\n    this.length = 0\\n  }\\n}\\n\\n/**\\n * A complete set that contains all elements.\\n *\\n * @static\\n * @readonly\\n * @type {lunr.Set}\\n */\\nlunr.Set.complete = {\\n  intersect: function (other) {\\n    return other\\n  },\\n\\n  union: function () {\\n    return this\\n  },\\n\\n  contains: function () {\\n    return true\\n  }\\n}\\n\\n/**\\n * An empty set that contains no elements.\\n *\\n * @static\\n * @readonly\\n * @type {lunr.Set}\\n */\\nlunr.Set.empty = {\\n  intersect: function () {\\n    return this\\n  },\\n\\n  union: function (other) {\\n    return other\\n  },\\n\\n  contains: function () {\\n    return false\\n  }\\n}\\n\\n/**\\n * Returns true if this set contains the specified object.\\n *\\n * @param {object} object - Object whose presence in this set is to be tested.\\n * @returns {boolean} - True if this set contains the specified object.\\n */\\nlunr.Set.prototype.contains = function (object) {\\n  return !!this.elements[object]\\n}\\n\\n/**\\n * Returns a new set containing only the elements that are present in both\\n * this set and the specified set.\\n *\\n * @param {lunr.Set} other - set to intersect with this set.\\n * @returns {lunr.Set} a new set that is the intersection of this and the specified set.\\n */\\n\\nlunr.Set.prototype.intersect = function (other) {\\n  var a, b, elements, intersection = []\\n\\n  if (other === lunr.Set.complete) {\\n    return this\\n  }\\n\\n  if (other === lunr.Set.empty) {\\n    return other\\n  }\\n\\n  if (this.length < other.length) {\\n    a = this\\n    b = other\\n  } else {\\n    a = other\\n    b = this\\n  }\\n\\n  elements = Object.keys(a.elements)\\n\\n  for (var i = 0; i < elements.length; i++) {\\n    var element = elements[i]\\n    if (element in b.elements) {\\n      intersection.push(element)\\n    }\\n  }\\n\\n  return new lunr.Set (intersection)\\n}\\n\\n/**\\n * Returns a new set combining the elements of this and the specified set.\\n *\\n * @param {lunr.Set} other - set to union with this set.\\n * @return {lunr.Set} a new set that is the union of this and the specified set.\\n */\\n\\nlunr.Set.prototype.union = function (other) {\\n  if (other === lunr.Set.complete) {\\n    return lunr.Set.complete\\n  }\\n\\n  if (other === lunr.Set.empty) {\\n    return this\\n  }\\n\\n  return new lunr.Set(Object.keys(this.elements).concat(Object.keys(other.elements)))\\n}\\n/**\\n * A function to calculate the inverse document frequency for\\n * a posting. This is shared between the builder and the index\\n *\\n * @private\\n * @param {object} posting - The posting for a given term\\n * @param {number} documentCount - The total number of documents.\\n */\\nlunr.idf = function (posting, documentCount) {\\n  var documentsWithTerm = 0\\n\\n  for (var fieldName in posting) {\\n    if (fieldName == '_index') continue // Ignore the term index, its not a field\\n    documentsWithTerm += Object.keys(posting[fieldName]).length\\n  }\\n\\n  var x = (documentCount - documentsWithTerm + 0.5) / (documentsWithTerm + 0.5)\\n\\n  return Math.log(1 + Math.abs(x))\\n}\\n\\n/**\\n * A token wraps a string representation of a token\\n * as it is passed through the text processing pipeline.\\n *\\n * @constructor\\n * @param {string} [str=''] - The string token being wrapped.\\n * @param {object} [metadata={}] - Metadata associated with this token.\\n */\\nlunr.Token = function (str, metadata) {\\n  this.str = str || \\\"\\\"\\n  this.metadata = metadata || {}\\n}\\n\\n/**\\n * Returns the token string that is being wrapped by this object.\\n *\\n * @returns {string}\\n */\\nlunr.Token.prototype.toString = function () {\\n  return this.str\\n}\\n\\n/**\\n * A token update function is used when updating or optionally\\n * when cloning a token.\\n *\\n * @callback lunr.Token~updateFunction\\n * @param {string} str - The string representation of the token.\\n * @param {Object} metadata - All metadata associated with this token.\\n */\\n\\n/**\\n * Applies the given function to the wrapped string token.\\n *\\n * @example\\n * token.update(function (str, metadata) {\\n *   return str.toUpperCase()\\n * })\\n *\\n * @param {lunr.Token~updateFunction} fn - A function to apply to the token string.\\n * @returns {lunr.Token}\\n */\\nlunr.Token.prototype.update = function (fn) {\\n  this.str = fn(this.str, this.metadata)\\n  return this\\n}\\n\\n/**\\n * Creates a clone of this token. Optionally a function can be\\n * applied to the cloned token.\\n *\\n * @param {lunr.Token~updateFunction} [fn] - An optional function to apply to the cloned token.\\n * @returns {lunr.Token}\\n */\\nlunr.Token.prototype.clone = function (fn) {\\n  fn = fn || function (s) { return s }\\n  return new lunr.Token (fn(this.str, this.metadata), this.metadata)\\n}\\n/*!\\n * lunr.tokenizer\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A function for splitting a string into tokens ready to be inserted into\\n * the search index. Uses `lunr.tokenizer.separator` to split strings, change\\n * the value of this property to change how strings are split into tokens.\\n *\\n * This tokenizer will convert its parameter to a string by calling `toString` and\\n * then will split this string on the character in `lunr.tokenizer.separator`.\\n * Arrays will have their elements converted to strings and wrapped in a lunr.Token.\\n *\\n * Optional metadata can be passed to the tokenizer, this metadata will be cloned and\\n * added as metadata to every token that is created from the object to be tokenized.\\n *\\n * @static\\n * @param {?(string|object|object[])} obj - The object to convert into tokens\\n * @param {?object} metadata - Optional metadata to associate with every token\\n * @returns {lunr.Token[]}\\n * @see {@link lunr.Pipeline}\\n */\\nlunr.tokenizer = function (obj, metadata) {\\n  if (obj == null || obj == undefined) {\\n    return []\\n  }\\n\\n  if (Array.isArray(obj)) {\\n    return obj.map(function (t) {\\n      return new lunr.Token(\\n        lunr.utils.asString(t).toLowerCase(),\\n        lunr.utils.clone(metadata)\\n      )\\n    })\\n  }\\n\\n  var str = obj.toString().toLowerCase(),\\n      len = str.length,\\n      tokens = []\\n\\n  for (var sliceEnd = 0, sliceStart = 0; sliceEnd <= len; sliceEnd++) {\\n    var char = str.charAt(sliceEnd),\\n        sliceLength = sliceEnd - sliceStart\\n\\n    if ((char.match(lunr.tokenizer.separator) || sliceEnd == len)) {\\n\\n      if (sliceLength > 0) {\\n        var tokenMetadata = lunr.utils.clone(metadata) || {}\\n        tokenMetadata[\\\"position\\\"] = [sliceStart, sliceLength]\\n        tokenMetadata[\\\"index\\\"] = tokens.length\\n\\n        tokens.push(\\n          new lunr.Token (\\n            str.slice(sliceStart, sliceEnd),\\n            tokenMetadata\\n          )\\n        )\\n      }\\n\\n      sliceStart = sliceEnd + 1\\n    }\\n\\n  }\\n\\n  return tokens\\n}\\n\\n/**\\n * The separator used to split a string into tokens. Override this property to change the behaviour of\\n * `lunr.tokenizer` behaviour when tokenizing strings. By default this splits on whitespace and hyphens.\\n *\\n * @static\\n * @see lunr.tokenizer\\n */\\nlunr.tokenizer.separator = /[\\\\s\\\\-]+/\\n/*!\\n * lunr.Pipeline\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.Pipelines maintain an ordered list of functions to be applied to all\\n * tokens in documents entering the search index and queries being ran against\\n * the index.\\n *\\n * An instance of lunr.Index created with the lunr shortcut will contain a\\n * pipeline with a stop word filter and an English language stemmer. Extra\\n * functions can be added before or after either of these functions or these\\n * default functions can be removed.\\n *\\n * When run the pipeline will call each function in turn, passing a token, the\\n * index of that token in the original list of all tokens and finally a list of\\n * all the original tokens.\\n *\\n * The output of functions in the pipeline will be passed to the next function\\n * in the pipeline. To exclude a token from entering the index the function\\n * should return undefined, the rest of the pipeline will not be called with\\n * this token.\\n *\\n * For serialisation of pipelines to work, all functions used in an instance of\\n * a pipeline should be registered with lunr.Pipeline. Registered functions can\\n * then be loaded. If trying to load a serialised pipeline that uses functions\\n * that are not registered an error will be thrown.\\n *\\n * If not planning on serialising the pipeline then registering pipeline functions\\n * is not necessary.\\n *\\n * @constructor\\n */\\nlunr.Pipeline = function () {\\n  this._stack = []\\n}\\n\\nlunr.Pipeline.registeredFunctions = Object.create(null)\\n\\n/**\\n * A pipeline function maps lunr.Token to lunr.Token. A lunr.Token contains the token\\n * string as well as all known metadata. A pipeline function can mutate the token string\\n * or mutate (or add) metadata for a given token.\\n *\\n * A pipeline function can indicate that the passed token should be discarded by returning\\n * null, undefined or an empty string. This token will not be passed to any downstream pipeline\\n * functions and will not be added to the index.\\n *\\n * Multiple tokens can be returned by returning an array of tokens. Each token will be passed\\n * to any downstream pipeline functions and all will returned tokens will be added to the index.\\n *\\n * Any number of pipeline functions may be chained together using a lunr.Pipeline.\\n *\\n * @interface lunr.PipelineFunction\\n * @param {lunr.Token} token - A token from the document being processed.\\n * @param {number} i - The index of this token in the complete list of tokens for this document/field.\\n * @param {lunr.Token[]} tokens - All tokens for this document/field.\\n * @returns {(?lunr.Token|lunr.Token[])}\\n */\\n\\n/**\\n * Register a function with the pipeline.\\n *\\n * Functions that are used in the pipeline should be registered if the pipeline\\n * needs to be serialised, or a serialised pipeline needs to be loaded.\\n *\\n * Registering a function does not add it to a pipeline, functions must still be\\n * added to instances of the pipeline for them to be used when running a pipeline.\\n *\\n * @param {lunr.PipelineFunction} fn - The function to check for.\\n * @param {String} label - The label to register this function with\\n */\\nlunr.Pipeline.registerFunction = function (fn, label) {\\n  if (label in this.registeredFunctions) {\\n    lunr.utils.warn('Overwriting existing registered function: ' + label)\\n  }\\n\\n  fn.label = label\\n  lunr.Pipeline.registeredFunctions[fn.label] = fn\\n}\\n\\n/**\\n * Warns if the function is not registered as a Pipeline function.\\n *\\n * @param {lunr.PipelineFunction} fn - The function to check for.\\n * @private\\n */\\nlunr.Pipeline.warnIfFunctionNotRegistered = function (fn) {\\n  var isRegistered = fn.label && (fn.label in this.registeredFunctions)\\n\\n  if (!isRegistered) {\\n    lunr.utils.warn('Function is not registered with pipeline. This may cause problems when serialising the index.\\\\n', fn)\\n  }\\n}\\n\\n/**\\n * Loads a previously serialised pipeline.\\n *\\n * All functions to be loaded must already be registered with lunr.Pipeline.\\n * If any function from the serialised data has not been registered then an\\n * error will be thrown.\\n *\\n * @param {Object} serialised - The serialised pipeline to load.\\n * @returns {lunr.Pipeline}\\n */\\nlunr.Pipeline.load = function (serialised) {\\n  var pipeline = new lunr.Pipeline\\n\\n  serialised.forEach(function (fnName) {\\n    var fn = lunr.Pipeline.registeredFunctions[fnName]\\n\\n    if (fn) {\\n      pipeline.add(fn)\\n    } else {\\n      throw new Error('Cannot load unregistered function: ' + fnName)\\n    }\\n  })\\n\\n  return pipeline\\n}\\n\\n/**\\n * Adds new functions to the end of the pipeline.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @param {lunr.PipelineFunction[]} functions - Any number of functions to add to the pipeline.\\n */\\nlunr.Pipeline.prototype.add = function () {\\n  var fns = Array.prototype.slice.call(arguments)\\n\\n  fns.forEach(function (fn) {\\n    lunr.Pipeline.warnIfFunctionNotRegistered(fn)\\n    this._stack.push(fn)\\n  }, this)\\n}\\n\\n/**\\n * Adds a single function after a function that already exists in the\\n * pipeline.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @param {lunr.PipelineFunction} existingFn - A function that already exists in the pipeline.\\n * @param {lunr.PipelineFunction} newFn - The new function to add to the pipeline.\\n */\\nlunr.Pipeline.prototype.after = function (existingFn, newFn) {\\n  lunr.Pipeline.warnIfFunctionNotRegistered(newFn)\\n\\n  var pos = this._stack.indexOf(existingFn)\\n  if (pos == -1) {\\n    throw new Error('Cannot find existingFn')\\n  }\\n\\n  pos = pos + 1\\n  this._stack.splice(pos, 0, newFn)\\n}\\n\\n/**\\n * Adds a single function before a function that already exists in the\\n * pipeline.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @param {lunr.PipelineFunction} existingFn - A function that already exists in the pipeline.\\n * @param {lunr.PipelineFunction} newFn - The new function to add to the pipeline.\\n */\\nlunr.Pipeline.prototype.before = function (existingFn, newFn) {\\n  lunr.Pipeline.warnIfFunctionNotRegistered(newFn)\\n\\n  var pos = this._stack.indexOf(existingFn)\\n  if (pos == -1) {\\n    throw new Error('Cannot find existingFn')\\n  }\\n\\n  this._stack.splice(pos, 0, newFn)\\n}\\n\\n/**\\n * Removes a function from the pipeline.\\n *\\n * @param {lunr.PipelineFunction} fn The function to remove from the pipeline.\\n */\\nlunr.Pipeline.prototype.remove = function (fn) {\\n  var pos = this._stack.indexOf(fn)\\n  if (pos == -1) {\\n    return\\n  }\\n\\n  this._stack.splice(pos, 1)\\n}\\n\\n/**\\n * Runs the current list of functions that make up the pipeline against the\\n * passed tokens.\\n *\\n * @param {Array} tokens The tokens to run through the pipeline.\\n * @returns {Array}\\n */\\nlunr.Pipeline.prototype.run = function (tokens) {\\n  var stackLength = this._stack.length\\n\\n  for (var i = 0; i < stackLength; i++) {\\n    var fn = this._stack[i]\\n    var memo = []\\n\\n    for (var j = 0; j < tokens.length; j++) {\\n      var result = fn(tokens[j], j, tokens)\\n\\n      if (result === null || result === void 0 || result === '') continue\\n\\n      if (Array.isArray(result)) {\\n        for (var k = 0; k < result.length; k++) {\\n          memo.push(result[k])\\n        }\\n      } else {\\n        memo.push(result)\\n      }\\n    }\\n\\n    tokens = memo\\n  }\\n\\n  return tokens\\n}\\n\\n/**\\n * Convenience method for passing a string through a pipeline and getting\\n * strings out. This method takes care of wrapping the passed string in a\\n * token and mapping the resulting tokens back to strings.\\n *\\n * @param {string} str - The string to pass through the pipeline.\\n * @param {?object} metadata - Optional metadata to associate with the token\\n * passed to the pipeline.\\n * @returns {string[]}\\n */\\nlunr.Pipeline.prototype.runString = function (str, metadata) {\\n  var token = new lunr.Token (str, metadata)\\n\\n  return this.run([token]).map(function (t) {\\n    return t.toString()\\n  })\\n}\\n\\n/**\\n * Resets the pipeline by removing any existing processors.\\n *\\n */\\nlunr.Pipeline.prototype.reset = function () {\\n  this._stack = []\\n}\\n\\n/**\\n * Returns a representation of the pipeline ready for serialisation.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @returns {Array}\\n */\\nlunr.Pipeline.prototype.toJSON = function () {\\n  return this._stack.map(function (fn) {\\n    lunr.Pipeline.warnIfFunctionNotRegistered(fn)\\n\\n    return fn.label\\n  })\\n}\\n/*!\\n * lunr.Vector\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A vector is used to construct the vector space of documents and queries. These\\n * vectors support operations to determine the similarity between two documents or\\n * a document and a query.\\n *\\n * Normally no parameters are required for initializing a vector, but in the case of\\n * loading a previously dumped vector the raw elements can be provided to the constructor.\\n *\\n * For performance reasons vectors are implemented with a flat array, where an elements\\n * index is immediately followed by its value. E.g. [index, value, index, value]. This\\n * allows the underlying array to be as sparse as possible and still offer decent\\n * performance when being used for vector calculations.\\n *\\n * @constructor\\n * @param {Number[]} [elements] - The flat list of element index and element value pairs.\\n */\\nlunr.Vector = function (elements) {\\n  this._magnitude = 0\\n  this.elements = elements || []\\n}\\n\\n\\n/**\\n * Calculates the position within the vector to insert a given index.\\n *\\n * This is used internally by insert and upsert. If there are duplicate indexes then\\n * the position is returned as if the value for that index were to be updated, but it\\n * is the callers responsibility to check whether there is a duplicate at that index\\n *\\n * @param {Number} insertIdx - The index at which the element should be inserted.\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.positionForIndex = function (index) {\\n  // For an empty vector the tuple can be inserted at the beginning\\n  if (this.elements.length == 0) {\\n    return 0\\n  }\\n\\n  var start = 0,\\n      end = this.elements.length / 2,\\n      sliceLength = end - start,\\n      pivotPoint = Math.floor(sliceLength / 2),\\n      pivotIndex = this.elements[pivotPoint * 2]\\n\\n  while (sliceLength > 1) {\\n    if (pivotIndex < index) {\\n      start = pivotPoint\\n    }\\n\\n    if (pivotIndex > index) {\\n      end = pivotPoint\\n    }\\n\\n    if (pivotIndex == index) {\\n      break\\n    }\\n\\n    sliceLength = end - start\\n    pivotPoint = start + Math.floor(sliceLength / 2)\\n    pivotIndex = this.elements[pivotPoint * 2]\\n  }\\n\\n  if (pivotIndex == index) {\\n    return pivotPoint * 2\\n  }\\n\\n  if (pivotIndex > index) {\\n    return pivotPoint * 2\\n  }\\n\\n  if (pivotIndex < index) {\\n    return (pivotPoint + 1) * 2\\n  }\\n}\\n\\n/**\\n * Inserts an element at an index within the vector.\\n *\\n * Does not allow duplicates, will throw an error if there is already an entry\\n * for this index.\\n *\\n * @param {Number} insertIdx - The index at which the element should be inserted.\\n * @param {Number} val - The value to be inserted into the vector.\\n */\\nlunr.Vector.prototype.insert = function (insertIdx, val) {\\n  this.upsert(insertIdx, val, function () {\\n    throw \\\"duplicate index\\\"\\n  })\\n}\\n\\n/**\\n * Inserts or updates an existing index within the vector.\\n *\\n * @param {Number} insertIdx - The index at which the element should be inserted.\\n * @param {Number} val - The value to be inserted into the vector.\\n * @param {function} fn - A function that is called for updates, the existing value and the\\n * requested value are passed as arguments\\n */\\nlunr.Vector.prototype.upsert = function (insertIdx, val, fn) {\\n  this._magnitude = 0\\n  var position = this.positionForIndex(insertIdx)\\n\\n  if (this.elements[position] == insertIdx) {\\n    this.elements[position + 1] = fn(this.elements[position + 1], val)\\n  } else {\\n    this.elements.splice(position, 0, insertIdx, val)\\n  }\\n}\\n\\n/**\\n * Calculates the magnitude of this vector.\\n *\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.magnitude = function () {\\n  if (this._magnitude) return this._magnitude\\n\\n  var sumOfSquares = 0,\\n      elementsLength = this.elements.length\\n\\n  for (var i = 1; i < elementsLength; i += 2) {\\n    var val = this.elements[i]\\n    sumOfSquares += val * val\\n  }\\n\\n  return this._magnitude = Math.sqrt(sumOfSquares)\\n}\\n\\n/**\\n * Calculates the dot product of this vector and another vector.\\n *\\n * @param {lunr.Vector} otherVector - The vector to compute the dot product with.\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.dot = function (otherVector) {\\n  var dotProduct = 0,\\n      a = this.elements, b = otherVector.elements,\\n      aLen = a.length, bLen = b.length,\\n      aVal = 0, bVal = 0,\\n      i = 0, j = 0\\n\\n  while (i < aLen && j < bLen) {\\n    aVal = a[i], bVal = b[j]\\n    if (aVal < bVal) {\\n      i += 2\\n    } else if (aVal > bVal) {\\n      j += 2\\n    } else if (aVal == bVal) {\\n      dotProduct += a[i + 1] * b[j + 1]\\n      i += 2\\n      j += 2\\n    }\\n  }\\n\\n  return dotProduct\\n}\\n\\n/**\\n * Calculates the similarity between this vector and another vector.\\n *\\n * @param {lunr.Vector} otherVector - The other vector to calculate the\\n * similarity with.\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.similarity = function (otherVector) {\\n  return this.dot(otherVector) / this.magnitude() || 0\\n}\\n\\n/**\\n * Converts the vector to an array of the elements within the vector.\\n *\\n * @returns {Number[]}\\n */\\nlunr.Vector.prototype.toArray = function () {\\n  var output = new Array (this.elements.length / 2)\\n\\n  for (var i = 1, j = 0; i < this.elements.length; i += 2, j++) {\\n    output[j] = this.elements[i]\\n  }\\n\\n  return output\\n}\\n\\n/**\\n * A JSON serializable representation of the vector.\\n *\\n * @returns {Number[]}\\n */\\nlunr.Vector.prototype.toJSON = function () {\\n  return this.elements\\n}\\n/* eslint-disable */\\n/*!\\n * lunr.stemmer\\n * Copyright (C) 2020 Oliver Nightingale\\n * Includes code from - http://tartarus.org/~martin/PorterStemmer/js.txt\\n */\\n\\n/**\\n * lunr.stemmer is an english language stemmer, this is a JavaScript\\n * implementation of the PorterStemmer taken from http://tartarus.org/~martin\\n *\\n * @static\\n * @implements {lunr.PipelineFunction}\\n * @param {lunr.Token} token - The string to stem\\n * @returns {lunr.Token}\\n * @see {@link lunr.Pipeline}\\n * @function\\n */\\nlunr.stemmer = (function(){\\n  var step2list = {\\n      \\\"ational\\\" : \\\"ate\\\",\\n      \\\"tional\\\" : \\\"tion\\\",\\n      \\\"enci\\\" : \\\"ence\\\",\\n      \\\"anci\\\" : \\\"ance\\\",\\n      \\\"izer\\\" : \\\"ize\\\",\\n      \\\"bli\\\" : \\\"ble\\\",\\n      \\\"alli\\\" : \\\"al\\\",\\n      \\\"entli\\\" : \\\"ent\\\",\\n      \\\"eli\\\" : \\\"e\\\",\\n      \\\"ousli\\\" : \\\"ous\\\",\\n      \\\"ization\\\" : \\\"ize\\\",\\n      \\\"ation\\\" : \\\"ate\\\",\\n      \\\"ator\\\" : \\\"ate\\\",\\n      \\\"alism\\\" : \\\"al\\\",\\n      \\\"iveness\\\" : \\\"ive\\\",\\n      \\\"fulness\\\" : \\\"ful\\\",\\n      \\\"ousness\\\" : \\\"ous\\\",\\n      \\\"aliti\\\" : \\\"al\\\",\\n      \\\"iviti\\\" : \\\"ive\\\",\\n      \\\"biliti\\\" : \\\"ble\\\",\\n      \\\"logi\\\" : \\\"log\\\"\\n    },\\n\\n    step3list = {\\n      \\\"icate\\\" : \\\"ic\\\",\\n      \\\"ative\\\" : \\\"\\\",\\n      \\\"alize\\\" : \\\"al\\\",\\n      \\\"iciti\\\" : \\\"ic\\\",\\n      \\\"ical\\\" : \\\"ic\\\",\\n      \\\"ful\\\" : \\\"\\\",\\n      \\\"ness\\\" : \\\"\\\"\\n    },\\n\\n    c = \\\"[^aeiou]\\\",          // consonant\\n    v = \\\"[aeiouy]\\\",          // vowel\\n    C = c + \\\"[^aeiouy]*\\\",    // consonant sequence\\n    V = v + \\\"[aeiou]*\\\",      // vowel sequence\\n\\n    mgr0 = \\\"^(\\\" + C + \\\")?\\\" + V + C,               // [C]VC... is m>0\\n    meq1 = \\\"^(\\\" + C + \\\")?\\\" + V + C + \\\"(\\\" + V + \\\")?$\\\",  // [C]VC[V] is m=1\\n    mgr1 = \\\"^(\\\" + C + \\\")?\\\" + V + C + V + C,       // [C]VCVC... is m>1\\n    s_v = \\\"^(\\\" + C + \\\")?\\\" + v;                   // vowel in stem\\n\\n  var re_mgr0 = new RegExp(mgr0);\\n  var re_mgr1 = new RegExp(mgr1);\\n  var re_meq1 = new RegExp(meq1);\\n  var re_s_v = new RegExp(s_v);\\n\\n  var re_1a = /^(.+?)(ss|i)es$/;\\n  var re2_1a = /^(.+?)([^s])s$/;\\n  var re_1b = /^(.+?)eed$/;\\n  var re2_1b = /^(.+?)(ed|ing)$/;\\n  var re_1b_2 = /.$/;\\n  var re2_1b_2 = /(at|bl|iz)$/;\\n  var re3_1b_2 = new RegExp(\\\"([^aeiouylsz])\\\\\\\\1$\\\");\\n  var re4_1b_2 = new RegExp(\\\"^\\\" + C + v + \\\"[^aeiouwxy]$\\\");\\n\\n  var re_1c = /^(.+?[^aeiou])y$/;\\n  var re_2 = /^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/;\\n\\n  var re_3 = /^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/;\\n\\n  var re_4 = /^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/;\\n  var re2_4 = /^(.+?)(s|t)(ion)$/;\\n\\n  var re_5 = /^(.+?)e$/;\\n  var re_5_1 = /ll$/;\\n  var re3_5 = new RegExp(\\\"^\\\" + C + v + \\\"[^aeiouwxy]$\\\");\\n\\n  var porterStemmer = function porterStemmer(w) {\\n    var stem,\\n      suffix,\\n      firstch,\\n      re,\\n      re2,\\n      re3,\\n      re4;\\n\\n    if (w.length < 3) { return w; }\\n\\n    firstch = w.substr(0,1);\\n    if (firstch == \\\"y\\\") {\\n      w = firstch.toUpperCase() + w.substr(1);\\n    }\\n\\n    // Step 1a\\n    re = re_1a\\n    re2 = re2_1a;\\n\\n    if (re.test(w)) { w = w.replace(re,\\\"$1$2\\\"); }\\n    else if (re2.test(w)) { w = w.replace(re2,\\\"$1$2\\\"); }\\n\\n    // Step 1b\\n    re = re_1b;\\n    re2 = re2_1b;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      re = re_mgr0;\\n      if (re.test(fp[1])) {\\n        re = re_1b_2;\\n        w = w.replace(re,\\\"\\\");\\n      }\\n    } else if (re2.test(w)) {\\n      var fp = re2.exec(w);\\n      stem = fp[1];\\n      re2 = re_s_v;\\n      if (re2.test(stem)) {\\n        w = stem;\\n        re2 = re2_1b_2;\\n        re3 = re3_1b_2;\\n        re4 = re4_1b_2;\\n        if (re2.test(w)) { w = w + \\\"e\\\"; }\\n        else if (re3.test(w)) { re = re_1b_2; w = w.replace(re,\\\"\\\"); }\\n        else if (re4.test(w)) { w = w + \\\"e\\\"; }\\n      }\\n    }\\n\\n    // Step 1c - replace suffix y or Y by i if preceded by a non-vowel which is not the first letter of the word (so cry -> cri, by -> by, say -> say)\\n    re = re_1c;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      w = stem + \\\"i\\\";\\n    }\\n\\n    // Step 2\\n    re = re_2;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      suffix = fp[2];\\n      re = re_mgr0;\\n      if (re.test(stem)) {\\n        w = stem + step2list[suffix];\\n      }\\n    }\\n\\n    // Step 3\\n    re = re_3;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      suffix = fp[2];\\n      re = re_mgr0;\\n      if (re.test(stem)) {\\n        w = stem + step3list[suffix];\\n      }\\n    }\\n\\n    // Step 4\\n    re = re_4;\\n    re2 = re2_4;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      re = re_mgr1;\\n      if (re.test(stem)) {\\n        w = stem;\\n      }\\n    } else if (re2.test(w)) {\\n      var fp = re2.exec(w);\\n      stem = fp[1] + fp[2];\\n      re2 = re_mgr1;\\n      if (re2.test(stem)) {\\n        w = stem;\\n      }\\n    }\\n\\n    // Step 5\\n    re = re_5;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      re = re_mgr1;\\n      re2 = re_meq1;\\n      re3 = re3_5;\\n      if (re.test(stem) || (re2.test(stem) && !(re3.test(stem)))) {\\n        w = stem;\\n      }\\n    }\\n\\n    re = re_5_1;\\n    re2 = re_mgr1;\\n    if (re.test(w) && re2.test(w)) {\\n      re = re_1b_2;\\n      w = w.replace(re,\\\"\\\");\\n    }\\n\\n    // and turn initial Y back to y\\n\\n    if (firstch == \\\"y\\\") {\\n      w = firstch.toLowerCase() + w.substr(1);\\n    }\\n\\n    return w;\\n  };\\n\\n  return function (token) {\\n    return token.update(porterStemmer);\\n  }\\n})();\\n\\nlunr.Pipeline.registerFunction(lunr.stemmer, 'stemmer')\\n/*!\\n * lunr.stopWordFilter\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.generateStopWordFilter builds a stopWordFilter function from the provided\\n * list of stop words.\\n *\\n * The built in lunr.stopWordFilter is built using this generator and can be used\\n * to generate custom stopWordFilters for applications or non English languages.\\n *\\n * @function\\n * @param {Array} token The token to pass through the filter\\n * @returns {lunr.PipelineFunction}\\n * @see lunr.Pipeline\\n * @see lunr.stopWordFilter\\n */\\nlunr.generateStopWordFilter = function (stopWords) {\\n  var words = stopWords.reduce(function (memo, stopWord) {\\n    memo[stopWord] = stopWord\\n    return memo\\n  }, {})\\n\\n  return function (token) {\\n    if (token && words[token.toString()] !== token.toString()) return token\\n  }\\n}\\n\\n/**\\n * lunr.stopWordFilter is an English language stop word list filter, any words\\n * contained in the list will not be passed through the filter.\\n *\\n * This is intended to be used in the Pipeline. If the token does not pass the\\n * filter then undefined will be returned.\\n *\\n * @function\\n * @implements {lunr.PipelineFunction}\\n * @params {lunr.Token} token - A token to check for being a stop word.\\n * @returns {lunr.Token}\\n * @see {@link lunr.Pipeline}\\n */\\nlunr.stopWordFilter = lunr.generateStopWordFilter([\\n  'a',\\n  'able',\\n  'about',\\n  'across',\\n  'after',\\n  'all',\\n  'almost',\\n  'also',\\n  'am',\\n  'among',\\n  'an',\\n  'and',\\n  'any',\\n  'are',\\n  'as',\\n  'at',\\n  'be',\\n  'because',\\n  'been',\\n  'but',\\n  'by',\\n  'can',\\n  'cannot',\\n  'could',\\n  'dear',\\n  'did',\\n  'do',\\n  'does',\\n  'either',\\n  'else',\\n  'ever',\\n  'every',\\n  'for',\\n  'from',\\n  'get',\\n  'got',\\n  'had',\\n  'has',\\n  'have',\\n  'he',\\n  'her',\\n  'hers',\\n  'him',\\n  'his',\\n  'how',\\n  'however',\\n  'i',\\n  'if',\\n  'in',\\n  'into',\\n  'is',\\n  'it',\\n  'its',\\n  'just',\\n  'least',\\n  'let',\\n  'like',\\n  'likely',\\n  'may',\\n  'me',\\n  'might',\\n  'most',\\n  'must',\\n  'my',\\n  'neither',\\n  'no',\\n  'nor',\\n  'not',\\n  'of',\\n  'off',\\n  'often',\\n  'on',\\n  'only',\\n  'or',\\n  'other',\\n  'our',\\n  'own',\\n  'rather',\\n  'said',\\n  'say',\\n  'says',\\n  'she',\\n  'should',\\n  'since',\\n  'so',\\n  'some',\\n  'than',\\n  'that',\\n  'the',\\n  'their',\\n  'them',\\n  'then',\\n  'there',\\n  'these',\\n  'they',\\n  'this',\\n  'tis',\\n  'to',\\n  'too',\\n  'twas',\\n  'us',\\n  'wants',\\n  'was',\\n  'we',\\n  'were',\\n  'what',\\n  'when',\\n  'where',\\n  'which',\\n  'while',\\n  'who',\\n  'whom',\\n  'why',\\n  'will',\\n  'with',\\n  'would',\\n  'yet',\\n  'you',\\n  'your'\\n])\\n\\nlunr.Pipeline.registerFunction(lunr.stopWordFilter, 'stopWordFilter')\\n/*!\\n * lunr.trimmer\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.trimmer is a pipeline function for trimming non word\\n * characters from the beginning and end of tokens before they\\n * enter the index.\\n *\\n * This implementation may not work correctly for non latin\\n * characters and should either be removed or adapted for use\\n * with languages with non-latin characters.\\n *\\n * @static\\n * @implements {lunr.PipelineFunction}\\n * @param {lunr.Token} token The token to pass through the filter\\n * @returns {lunr.Token}\\n * @see lunr.Pipeline\\n */\\nlunr.trimmer = function (token) {\\n  return token.update(function (s) {\\n    return s.replace(/^\\\\W+/, '').replace(/\\\\W+$/, '')\\n  })\\n}\\n\\nlunr.Pipeline.registerFunction(lunr.trimmer, 'trimmer')\\n/*!\\n * lunr.TokenSet\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A token set is used to store the unique list of all tokens\\n * within an index. Token sets are also used to represent an\\n * incoming query to the index, this query token set and index\\n * token set are then intersected to find which tokens to look\\n * up in the inverted index.\\n *\\n * A token set can hold multiple tokens, as in the case of the\\n * index token set, or it can hold a single token as in the\\n * case of a simple query token set.\\n *\\n * Additionally token sets are used to perform wildcard matching.\\n * Leading, contained and trailing wildcards are supported, and\\n * from this edit distance matching can also be provided.\\n *\\n * Token sets are implemented as a minimal finite state automata,\\n * where both common prefixes and suffixes are shared between tokens.\\n * This helps to reduce the space used for storing the token set.\\n *\\n * @constructor\\n */\\nlunr.TokenSet = function () {\\n  this.final = false\\n  this.edges = {}\\n  this.id = lunr.TokenSet._nextId\\n  lunr.TokenSet._nextId += 1\\n}\\n\\n/**\\n * Keeps track of the next, auto increment, identifier to assign\\n * to a new tokenSet.\\n *\\n * TokenSets require a unique identifier to be correctly minimised.\\n *\\n * @private\\n */\\nlunr.TokenSet._nextId = 1\\n\\n/**\\n * Creates a TokenSet instance from the given sorted array of words.\\n *\\n * @param {String[]} arr - A sorted array of strings to create the set from.\\n * @returns {lunr.TokenSet}\\n * @throws Will throw an error if the input array is not sorted.\\n */\\nlunr.TokenSet.fromArray = function (arr) {\\n  var builder = new lunr.TokenSet.Builder\\n\\n  for (var i = 0, len = arr.length; i < len; i++) {\\n    builder.insert(arr[i])\\n  }\\n\\n  builder.finish()\\n  return builder.root\\n}\\n\\n/**\\n * Creates a token set from a query clause.\\n *\\n * @private\\n * @param {Object} clause - A single clause from lunr.Query.\\n * @param {string} clause.term - The query clause term.\\n * @param {number} [clause.editDistance] - The optional edit distance for the term.\\n * @returns {lunr.TokenSet}\\n */\\nlunr.TokenSet.fromClause = function (clause) {\\n  if ('editDistance' in clause) {\\n    return lunr.TokenSet.fromFuzzyString(clause.term, clause.editDistance)\\n  } else {\\n    return lunr.TokenSet.fromString(clause.term)\\n  }\\n}\\n\\n/**\\n * Creates a token set representing a single string with a specified\\n * edit distance.\\n *\\n * Insertions, deletions, substitutions and transpositions are each\\n * treated as an edit distance of 1.\\n *\\n * Increasing the allowed edit distance will have a dramatic impact\\n * on the performance of both creating and intersecting these TokenSets.\\n * It is advised to keep the edit distance less than 3.\\n *\\n * @param {string} str - The string to create the token set from.\\n * @param {number} editDistance - The allowed edit distance to match.\\n * @returns {lunr.Vector}\\n */\\nlunr.TokenSet.fromFuzzyString = function (str, editDistance) {\\n  var root = new lunr.TokenSet\\n\\n  var stack = [{\\n    node: root,\\n    editsRemaining: editDistance,\\n    str: str\\n  }]\\n\\n  while (stack.length) {\\n    var frame = stack.pop()\\n\\n    // no edit\\n    if (frame.str.length > 0) {\\n      var char = frame.str.charAt(0),\\n          noEditNode\\n\\n      if (char in frame.node.edges) {\\n        noEditNode = frame.node.edges[char]\\n      } else {\\n        noEditNode = new lunr.TokenSet\\n        frame.node.edges[char] = noEditNode\\n      }\\n\\n      if (frame.str.length == 1) {\\n        noEditNode.final = true\\n      }\\n\\n      stack.push({\\n        node: noEditNode,\\n        editsRemaining: frame.editsRemaining,\\n        str: frame.str.slice(1)\\n      })\\n    }\\n\\n    if (frame.editsRemaining == 0) {\\n      continue\\n    }\\n\\n    // insertion\\n    if (\\\"*\\\" in frame.node.edges) {\\n      var insertionNode = frame.node.edges[\\\"*\\\"]\\n    } else {\\n      var insertionNode = new lunr.TokenSet\\n      frame.node.edges[\\\"*\\\"] = insertionNode\\n    }\\n\\n    if (frame.str.length == 0) {\\n      insertionNode.final = true\\n    }\\n\\n    stack.push({\\n      node: insertionNode,\\n      editsRemaining: frame.editsRemaining - 1,\\n      str: frame.str\\n    })\\n\\n    // deletion\\n    // can only do a deletion if we have enough edits remaining\\n    // and if there are characters left to delete in the string\\n    if (frame.str.length > 1) {\\n      stack.push({\\n        node: frame.node,\\n        editsRemaining: frame.editsRemaining - 1,\\n        str: frame.str.slice(1)\\n      })\\n    }\\n\\n    // deletion\\n    // just removing the last character from the str\\n    if (frame.str.length == 1) {\\n      frame.node.final = true\\n    }\\n\\n    // substitution\\n    // can only do a substitution if we have enough edits remaining\\n    // and if there are characters left to substitute\\n    if (frame.str.length >= 1) {\\n      if (\\\"*\\\" in frame.node.edges) {\\n        var substitutionNode = frame.node.edges[\\\"*\\\"]\\n      } else {\\n        var substitutionNode = new lunr.TokenSet\\n        frame.node.edges[\\\"*\\\"] = substitutionNode\\n      }\\n\\n      if (frame.str.length == 1) {\\n        substitutionNode.final = true\\n      }\\n\\n      stack.push({\\n        node: substitutionNode,\\n        editsRemaining: frame.editsRemaining - 1,\\n        str: frame.str.slice(1)\\n      })\\n    }\\n\\n    // transposition\\n    // can only do a transposition if there are edits remaining\\n    // and there are enough characters to transpose\\n    if (frame.str.length > 1) {\\n      var charA = frame.str.charAt(0),\\n          charB = frame.str.charAt(1),\\n          transposeNode\\n\\n      if (charB in frame.node.edges) {\\n        transposeNode = frame.node.edges[charB]\\n      } else {\\n        transposeNode = new lunr.TokenSet\\n        frame.node.edges[charB] = transposeNode\\n      }\\n\\n      if (frame.str.length == 1) {\\n        transposeNode.final = true\\n      }\\n\\n      stack.push({\\n        node: transposeNode,\\n        editsRemaining: frame.editsRemaining - 1,\\n        str: charA + frame.str.slice(2)\\n      })\\n    }\\n  }\\n\\n  return root\\n}\\n\\n/**\\n * Creates a TokenSet from a string.\\n *\\n * The string may contain one or more wildcard characters (*)\\n * that will allow wildcard matching when intersecting with\\n * another TokenSet.\\n *\\n * @param {string} str - The string to create a TokenSet from.\\n * @returns {lunr.TokenSet}\\n */\\nlunr.TokenSet.fromString = function (str) {\\n  var node = new lunr.TokenSet,\\n      root = node\\n\\n  /*\\n   * Iterates through all characters within the passed string\\n   * appending a node for each character.\\n   *\\n   * When a wildcard character is found then a self\\n   * referencing edge is introduced to continually match\\n   * any number of any characters.\\n   */\\n  for (var i = 0, len = str.length; i < len; i++) {\\n    var char = str[i],\\n        final = (i == len - 1)\\n\\n    if (char == \\\"*\\\") {\\n      node.edges[char] = node\\n      node.final = final\\n\\n    } else {\\n      var next = new lunr.TokenSet\\n      next.final = final\\n\\n      node.edges[char] = next\\n      node = next\\n    }\\n  }\\n\\n  return root\\n}\\n\\n/**\\n * Converts this TokenSet into an array of strings\\n * contained within the TokenSet.\\n *\\n * This is not intended to be used on a TokenSet that\\n * contains wildcards, in these cases the results are\\n * undefined and are likely to cause an infinite loop.\\n *\\n * @returns {string[]}\\n */\\nlunr.TokenSet.prototype.toArray = function () {\\n  var words = []\\n\\n  var stack = [{\\n    prefix: \\\"\\\",\\n    node: this\\n  }]\\n\\n  while (stack.length) {\\n    var frame = stack.pop(),\\n        edges = Object.keys(frame.node.edges),\\n        len = edges.length\\n\\n    if (frame.node.final) {\\n      /* In Safari, at this point the prefix is sometimes corrupted, see:\\n       * https://github.com/olivernn/lunr.js/issues/279 Calling any\\n       * String.prototype method forces Safari to \\\"cast\\\" this string to what\\n       * it's supposed to be, fixing the bug. */\\n      frame.prefix.charAt(0)\\n      words.push(frame.prefix)\\n    }\\n\\n    for (var i = 0; i < len; i++) {\\n      var edge = edges[i]\\n\\n      stack.push({\\n        prefix: frame.prefix.concat(edge),\\n        node: frame.node.edges[edge]\\n      })\\n    }\\n  }\\n\\n  return words\\n}\\n\\n/**\\n * Generates a string representation of a TokenSet.\\n *\\n * This is intended to allow TokenSets to be used as keys\\n * in objects, largely to aid the construction and minimisation\\n * of a TokenSet. As such it is not designed to be a human\\n * friendly representation of the TokenSet.\\n *\\n * @returns {string}\\n */\\nlunr.TokenSet.prototype.toString = function () {\\n  // NOTE: Using Object.keys here as this.edges is very likely\\n  // to enter 'hash-mode' with many keys being added\\n  //\\n  // avoiding a for-in loop here as it leads to the function\\n  // being de-optimised (at least in V8). From some simple\\n  // benchmarks the performance is comparable, but allowing\\n  // V8 to optimize may mean easy performance wins in the future.\\n\\n  if (this._str) {\\n    return this._str\\n  }\\n\\n  var str = this.final ? '1' : '0',\\n      labels = Object.keys(this.edges).sort(),\\n      len = labels.length\\n\\n  for (var i = 0; i < len; i++) {\\n    var label = labels[i],\\n        node = this.edges[label]\\n\\n    str = str + label + node.id\\n  }\\n\\n  return str\\n}\\n\\n/**\\n * Returns a new TokenSet that is the intersection of\\n * this TokenSet and the passed TokenSet.\\n *\\n * This intersection will take into account any wildcards\\n * contained within the TokenSet.\\n *\\n * @param {lunr.TokenSet} b - An other TokenSet to intersect with.\\n * @returns {lunr.TokenSet}\\n */\\nlunr.TokenSet.prototype.intersect = function (b) {\\n  var output = new lunr.TokenSet,\\n      frame = undefined\\n\\n  var stack = [{\\n    qNode: b,\\n    output: output,\\n    node: this\\n  }]\\n\\n  while (stack.length) {\\n    frame = stack.pop()\\n\\n    // NOTE: As with the #toString method, we are using\\n    // Object.keys and a for loop instead of a for-in loop\\n    // as both of these objects enter 'hash' mode, causing\\n    // the function to be de-optimised in V8\\n    var qEdges = Object.keys(frame.qNode.edges),\\n        qLen = qEdges.length,\\n        nEdges = Object.keys(frame.node.edges),\\n        nLen = nEdges.length\\n\\n    for (var q = 0; q < qLen; q++) {\\n      var qEdge = qEdges[q]\\n\\n      for (var n = 0; n < nLen; n++) {\\n        var nEdge = nEdges[n]\\n\\n        if (nEdge == qEdge || qEdge == '*') {\\n          var node = frame.node.edges[nEdge],\\n              qNode = frame.qNode.edges[qEdge],\\n              final = node.final && qNode.final,\\n              next = undefined\\n\\n          if (nEdge in frame.output.edges) {\\n            // an edge already exists for this character\\n            // no need to create a new node, just set the finality\\n            // bit unless this node is already final\\n            next = frame.output.edges[nEdge]\\n            next.final = next.final || final\\n\\n          } else {\\n            // no edge exists yet, must create one\\n            // set the finality bit and insert it\\n            // into the output\\n            next = new lunr.TokenSet\\n            next.final = final\\n            frame.output.edges[nEdge] = next\\n          }\\n\\n          stack.push({\\n            qNode: qNode,\\n            output: next,\\n            node: node\\n          })\\n        }\\n      }\\n    }\\n  }\\n\\n  return output\\n}\\nlunr.TokenSet.Builder = function () {\\n  this.previousWord = \\\"\\\"\\n  this.root = new lunr.TokenSet\\n  this.uncheckedNodes = []\\n  this.minimizedNodes = {}\\n}\\n\\nlunr.TokenSet.Builder.prototype.insert = function (word) {\\n  var node,\\n      commonPrefix = 0\\n\\n  if (word < this.previousWord) {\\n    throw new Error (\\\"Out of order word insertion\\\")\\n  }\\n\\n  for (var i = 0; i < word.length && i < this.previousWord.length; i++) {\\n    if (word[i] != this.previousWord[i]) break\\n    commonPrefix++\\n  }\\n\\n  this.minimize(commonPrefix)\\n\\n  if (this.uncheckedNodes.length == 0) {\\n    node = this.root\\n  } else {\\n    node = this.uncheckedNodes[this.uncheckedNodes.length - 1].child\\n  }\\n\\n  for (var i = commonPrefix; i < word.length; i++) {\\n    var nextNode = new lunr.TokenSet,\\n        char = word[i]\\n\\n    node.edges[char] = nextNode\\n\\n    this.uncheckedNodes.push({\\n      parent: node,\\n      char: char,\\n      child: nextNode\\n    })\\n\\n    node = nextNode\\n  }\\n\\n  node.final = true\\n  this.previousWord = word\\n}\\n\\nlunr.TokenSet.Builder.prototype.finish = function () {\\n  this.minimize(0)\\n}\\n\\nlunr.TokenSet.Builder.prototype.minimize = function (downTo) {\\n  for (var i = this.uncheckedNodes.length - 1; i >= downTo; i--) {\\n    var node = this.uncheckedNodes[i],\\n        childKey = node.child.toString()\\n\\n    if (childKey in this.minimizedNodes) {\\n      node.parent.edges[node.char] = this.minimizedNodes[childKey]\\n    } else {\\n      // Cache the key for this node since\\n      // we know it can't change anymore\\n      node.child._str = childKey\\n\\n      this.minimizedNodes[childKey] = node.child\\n    }\\n\\n    this.uncheckedNodes.pop()\\n  }\\n}\\n/*!\\n * lunr.Index\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * An index contains the built index of all documents and provides a query interface\\n * to the index.\\n *\\n * Usually instances of lunr.Index will not be created using this constructor, instead\\n * lunr.Builder should be used to construct new indexes, or lunr.Index.load should be\\n * used to load previously built and serialized indexes.\\n *\\n * @constructor\\n * @param {Object} attrs - The attributes of the built search index.\\n * @param {Object} attrs.invertedIndex - An index of term/field to document reference.\\n * @param {Object<string, lunr.Vector>} attrs.fieldVectors - Field vectors\\n * @param {lunr.TokenSet} attrs.tokenSet - An set of all corpus tokens.\\n * @param {string[]} attrs.fields - The names of indexed document fields.\\n * @param {lunr.Pipeline} attrs.pipeline - The pipeline to use for search terms.\\n */\\nlunr.Index = function (attrs) {\\n  this.invertedIndex = attrs.invertedIndex\\n  this.fieldVectors = attrs.fieldVectors\\n  this.tokenSet = attrs.tokenSet\\n  this.fields = attrs.fields\\n  this.pipeline = attrs.pipeline\\n}\\n\\n/**\\n * A result contains details of a document matching a search query.\\n * @typedef {Object} lunr.Index~Result\\n * @property {string} ref - The reference of the document this result represents.\\n * @property {number} score - A number between 0 and 1 representing how similar this document is to the query.\\n * @property {lunr.MatchData} matchData - Contains metadata about this match including which term(s) caused the match.\\n */\\n\\n/**\\n * Although lunr provides the ability to create queries using lunr.Query, it also provides a simple\\n * query language which itself is parsed into an instance of lunr.Query.\\n *\\n * For programmatically building queries it is advised to directly use lunr.Query, the query language\\n * is best used for human entered text rather than program generated text.\\n *\\n * At its simplest queries can just be a single term, e.g. `hello`, multiple terms are also supported\\n * and will be combined with OR, e.g `hello world` will match documents that contain either 'hello'\\n * or 'world', though those that contain both will rank higher in the results.\\n *\\n * Wildcards can be included in terms to match one or more unspecified characters, these wildcards can\\n * be inserted anywhere within the term, and more than one wildcard can exist in a single term. Adding\\n * wildcards will increase the number of documents that will be found but can also have a negative\\n * impact on query performance, especially with wildcards at the beginning of a term.\\n *\\n * Terms can be restricted to specific fields, e.g. `title:hello`, only documents with the term\\n * hello in the title field will match this query. Using a field not present in the index will lead\\n * to an error being thrown.\\n *\\n * Modifiers can also be added to terms, lunr supports edit distance and boost modifiers on terms. A term\\n * boost will make documents matching that term score higher, e.g. `foo^5`. Edit distance is also supported\\n * to provide fuzzy matching, e.g. 'hello~2' will match documents with hello with an edit distance of 2.\\n * Avoid large values for edit distance to improve query performance.\\n *\\n * Each term also supports a presence modifier. By default a term's presence in document is optional, however\\n * this can be changed to either required or prohibited. For a term's presence to be required in a document the\\n * term should be prefixed with a '+', e.g. `+foo bar` is a search for documents that must contain 'foo' and\\n * optionally contain 'bar'. Conversely a leading '-' sets the terms presence to prohibited, i.e. it must not\\n * appear in a document, e.g. `-foo bar` is a search for documents that do not contain 'foo' but may contain 'bar'.\\n *\\n * To escape special characters the backslash character '\\\\' can be used, this allows searches to include\\n * characters that would normally be considered modifiers, e.g. `foo\\\\~2` will search for a term \\\"foo~2\\\" instead\\n * of attempting to apply a boost of 2 to the search term \\\"foo\\\".\\n *\\n * @typedef {string} lunr.Index~QueryString\\n * @example <caption>Simple single term query</caption>\\n * hello\\n * @example <caption>Multiple term query</caption>\\n * hello world\\n * @example <caption>term scoped to a field</caption>\\n * title:hello\\n * @example <caption>term with a boost of 10</caption>\\n * hello^10\\n * @example <caption>term with an edit distance of 2</caption>\\n * hello~2\\n * @example <caption>terms with presence modifiers</caption>\\n * -foo +bar baz\\n */\\n\\n/**\\n * Performs a search against the index using lunr query syntax.\\n *\\n * Results will be returned sorted by their score, the most relevant results\\n * will be returned first.  For details on how the score is calculated, please see\\n * the {@link https://lunrjs.com/guides/searching.html#scoring|guide}.\\n *\\n * For more programmatic querying use lunr.Index#query.\\n *\\n * @param {lunr.Index~QueryString} queryString - A string containing a lunr query.\\n * @throws {lunr.QueryParseError} If the passed query string cannot be parsed.\\n * @returns {lunr.Index~Result[]}\\n */\\nlunr.Index.prototype.search = function (queryString) {\\n  return this.query(function (query) {\\n    var parser = new lunr.QueryParser(queryString, query)\\n    parser.parse()\\n  })\\n}\\n\\n/**\\n * A query builder callback provides a query object to be used to express\\n * the query to perform on the index.\\n *\\n * @callback lunr.Index~queryBuilder\\n * @param {lunr.Query} query - The query object to build up.\\n * @this lunr.Query\\n */\\n\\n/**\\n * Performs a query against the index using the yielded lunr.Query object.\\n *\\n * If performing programmatic queries against the index, this method is preferred\\n * over lunr.Index#search so as to avoid the additional query parsing overhead.\\n *\\n * A query object is yielded to the supplied function which should be used to\\n * express the query to be run against the index.\\n *\\n * Note that although this function takes a callback parameter it is _not_ an\\n * asynchronous operation, the callback is just yielded a query object to be\\n * customized.\\n *\\n * @param {lunr.Index~queryBuilder} fn - A function that is used to build the query.\\n * @returns {lunr.Index~Result[]}\\n */\\nlunr.Index.prototype.query = function (fn) {\\n  // for each query clause\\n  // * process terms\\n  // * expand terms from token set\\n  // * find matching documents and metadata\\n  // * get document vectors\\n  // * score documents\\n\\n  var query = new lunr.Query(this.fields),\\n      matchingFields = Object.create(null),\\n      queryVectors = Object.create(null),\\n      termFieldCache = Object.create(null),\\n      requiredMatches = Object.create(null),\\n      prohibitedMatches = Object.create(null)\\n\\n  /*\\n   * To support field level boosts a query vector is created per\\n   * field. An empty vector is eagerly created to support negated\\n   * queries.\\n   */\\n  for (var i = 0; i < this.fields.length; i++) {\\n    queryVectors[this.fields[i]] = new lunr.Vector\\n  }\\n\\n  fn.call(query, query)\\n\\n  for (var i = 0; i < query.clauses.length; i++) {\\n    /*\\n     * Unless the pipeline has been disabled for this term, which is\\n     * the case for terms with wildcards, we need to pass the clause\\n     * term through the search pipeline. A pipeline returns an array\\n     * of processed terms. Pipeline functions may expand the passed\\n     * term, which means we may end up performing multiple index lookups\\n     * for a single query term.\\n     */\\n    var clause = query.clauses[i],\\n        terms = null,\\n        clauseMatches = lunr.Set.empty\\n\\n    if (clause.usePipeline) {\\n      terms = this.pipeline.runString(clause.term, {\\n        fields: clause.fields\\n      })\\n    } else {\\n      terms = [clause.term]\\n    }\\n\\n    for (var m = 0; m < terms.length; m++) {\\n      var term = terms[m]\\n\\n      /*\\n       * Each term returned from the pipeline needs to use the same query\\n       * clause object, e.g. the same boost and or edit distance. The\\n       * simplest way to do this is to re-use the clause object but mutate\\n       * its term property.\\n       */\\n      clause.term = term\\n\\n      /*\\n       * From the term in the clause we create a token set which will then\\n       * be used to intersect the indexes token set to get a list of terms\\n       * to lookup in the inverted index\\n       */\\n      var termTokenSet = lunr.TokenSet.fromClause(clause),\\n          expandedTerms = this.tokenSet.intersect(termTokenSet).toArray()\\n\\n      /*\\n       * If a term marked as required does not exist in the tokenSet it is\\n       * impossible for the search to return any matches. We set all the field\\n       * scoped required matches set to empty and stop examining any further\\n       * clauses.\\n       */\\n      if (expandedTerms.length === 0 && clause.presence === lunr.Query.presence.REQUIRED) {\\n        for (var k = 0; k < clause.fields.length; k++) {\\n          var field = clause.fields[k]\\n          requiredMatches[field] = lunr.Set.empty\\n        }\\n\\n        break\\n      }\\n\\n      for (var j = 0; j < expandedTerms.length; j++) {\\n        /*\\n         * For each term get the posting and termIndex, this is required for\\n         * building the query vector.\\n         */\\n        var expandedTerm = expandedTerms[j],\\n            posting = this.invertedIndex[expandedTerm],\\n            termIndex = posting._index\\n\\n        for (var k = 0; k < clause.fields.length; k++) {\\n          /*\\n           * For each field that this query term is scoped by (by default\\n           * all fields are in scope) we need to get all the document refs\\n           * that have this term in that field.\\n           *\\n           * The posting is the entry in the invertedIndex for the matching\\n           * term from above.\\n           */\\n          var field = clause.fields[k],\\n              fieldPosting = posting[field],\\n              matchingDocumentRefs = Object.keys(fieldPosting),\\n              termField = expandedTerm + \\\"/\\\" + field,\\n              matchingDocumentsSet = new lunr.Set(matchingDocumentRefs)\\n\\n          /*\\n           * if the presence of this term is required ensure that the matching\\n           * documents are added to the set of required matches for this clause.\\n           *\\n           */\\n          if (clause.presence == lunr.Query.presence.REQUIRED) {\\n            clauseMatches = clauseMatches.union(matchingDocumentsSet)\\n\\n            if (requiredMatches[field] === undefined) {\\n              requiredMatches[field] = lunr.Set.complete\\n            }\\n          }\\n\\n          /*\\n           * if the presence of this term is prohibited ensure that the matching\\n           * documents are added to the set of prohibited matches for this field,\\n           * creating that set if it does not yet exist.\\n           */\\n          if (clause.presence == lunr.Query.presence.PROHIBITED) {\\n            if (prohibitedMatches[field] === undefined) {\\n              prohibitedMatches[field] = lunr.Set.empty\\n            }\\n\\n            prohibitedMatches[field] = prohibitedMatches[field].union(matchingDocumentsSet)\\n\\n            /*\\n             * Prohibited matches should not be part of the query vector used for\\n             * similarity scoring and no metadata should be extracted so we continue\\n             * to the next field\\n             */\\n            continue\\n          }\\n\\n          /*\\n           * The query field vector is populated using the termIndex found for\\n           * the term and a unit value with the appropriate boost applied.\\n           * Using upsert because there could already be an entry in the vector\\n           * for the term we are working with. In that case we just add the scores\\n           * together.\\n           */\\n          queryVectors[field].upsert(termIndex, clause.boost, function (a, b) { return a + b })\\n\\n          /**\\n           * If we've already seen this term, field combo then we've already collected\\n           * the matching documents and metadata, no need to go through all that again\\n           */\\n          if (termFieldCache[termField]) {\\n            continue\\n          }\\n\\n          for (var l = 0; l < matchingDocumentRefs.length; l++) {\\n            /*\\n             * All metadata for this term/field/document triple\\n             * are then extracted and collected into an instance\\n             * of lunr.MatchData ready to be returned in the query\\n             * results\\n             */\\n            var matchingDocumentRef = matchingDocumentRefs[l],\\n                matchingFieldRef = new lunr.FieldRef (matchingDocumentRef, field),\\n                metadata = fieldPosting[matchingDocumentRef],\\n                fieldMatch\\n\\n            if ((fieldMatch = matchingFields[matchingFieldRef]) === undefined) {\\n              matchingFields[matchingFieldRef] = new lunr.MatchData (expandedTerm, field, metadata)\\n            } else {\\n              fieldMatch.add(expandedTerm, field, metadata)\\n            }\\n\\n          }\\n\\n          termFieldCache[termField] = true\\n        }\\n      }\\n    }\\n\\n    /**\\n     * If the presence was required we need to update the requiredMatches field sets.\\n     * We do this after all fields for the term have collected their matches because\\n     * the clause terms presence is required in _any_ of the fields not _all_ of the\\n     * fields.\\n     */\\n    if (clause.presence === lunr.Query.presence.REQUIRED) {\\n      for (var k = 0; k < clause.fields.length; k++) {\\n        var field = clause.fields[k]\\n        requiredMatches[field] = requiredMatches[field].intersect(clauseMatches)\\n      }\\n    }\\n  }\\n\\n  /**\\n   * Need to combine the field scoped required and prohibited\\n   * matching documents into a global set of required and prohibited\\n   * matches\\n   */\\n  var allRequiredMatches = lunr.Set.complete,\\n      allProhibitedMatches = lunr.Set.empty\\n\\n  for (var i = 0; i < this.fields.length; i++) {\\n    var field = this.fields[i]\\n\\n    if (requiredMatches[field]) {\\n      allRequiredMatches = allRequiredMatches.intersect(requiredMatches[field])\\n    }\\n\\n    if (prohibitedMatches[field]) {\\n      allProhibitedMatches = allProhibitedMatches.union(prohibitedMatches[field])\\n    }\\n  }\\n\\n  var matchingFieldRefs = Object.keys(matchingFields),\\n      results = [],\\n      matches = Object.create(null)\\n\\n  /*\\n   * If the query is negated (contains only prohibited terms)\\n   * we need to get _all_ fieldRefs currently existing in the\\n   * index. This is only done when we know that the query is\\n   * entirely prohibited terms to avoid any cost of getting all\\n   * fieldRefs unnecessarily.\\n   *\\n   * Additionally, blank MatchData must be created to correctly\\n   * populate the results.\\n   */\\n  if (query.isNegated()) {\\n    matchingFieldRefs = Object.keys(this.fieldVectors)\\n\\n    for (var i = 0; i < matchingFieldRefs.length; i++) {\\n      var matchingFieldRef = matchingFieldRefs[i]\\n      var fieldRef = lunr.FieldRef.fromString(matchingFieldRef)\\n      matchingFields[matchingFieldRef] = new lunr.MatchData\\n    }\\n  }\\n\\n  for (var i = 0; i < matchingFieldRefs.length; i++) {\\n    /*\\n     * Currently we have document fields that match the query, but we\\n     * need to return documents. The matchData and scores are combined\\n     * from multiple fields belonging to the same document.\\n     *\\n     * Scores are calculated by field, using the query vectors created\\n     * above, and combined into a final document score using addition.\\n     */\\n    var fieldRef = lunr.FieldRef.fromString(matchingFieldRefs[i]),\\n        docRef = fieldRef.docRef\\n\\n    if (!allRequiredMatches.contains(docRef)) {\\n      continue\\n    }\\n\\n    if (allProhibitedMatches.contains(docRef)) {\\n      continue\\n    }\\n\\n    var fieldVector = this.fieldVectors[fieldRef],\\n        score = queryVectors[fieldRef.fieldName].similarity(fieldVector),\\n        docMatch\\n\\n    if ((docMatch = matches[docRef]) !== undefined) {\\n      docMatch.score += score\\n      docMatch.matchData.combine(matchingFields[fieldRef])\\n    } else {\\n      var match = {\\n        ref: docRef,\\n        score: score,\\n        matchData: matchingFields[fieldRef]\\n      }\\n      matches[docRef] = match\\n      results.push(match)\\n    }\\n  }\\n\\n  /*\\n   * Sort the results objects by score, highest first.\\n   */\\n  return results.sort(function (a, b) {\\n    return b.score - a.score\\n  })\\n}\\n\\n/**\\n * Prepares the index for JSON serialization.\\n *\\n * The schema for this JSON blob will be described in a\\n * separate JSON schema file.\\n *\\n * @returns {Object}\\n */\\nlunr.Index.prototype.toJSON = function () {\\n  var invertedIndex = Object.keys(this.invertedIndex)\\n    .sort()\\n    .map(function (term) {\\n      return [term, this.invertedIndex[term]]\\n    }, this)\\n\\n  var fieldVectors = Object.keys(this.fieldVectors)\\n    .map(function (ref) {\\n      return [ref, this.fieldVectors[ref].toJSON()]\\n    }, this)\\n\\n  return {\\n    version: lunr.version,\\n    fields: this.fields,\\n    fieldVectors: fieldVectors,\\n    invertedIndex: invertedIndex,\\n    pipeline: this.pipeline.toJSON()\\n  }\\n}\\n\\n/**\\n * Loads a previously serialized lunr.Index\\n *\\n * @param {Object} serializedIndex - A previously serialized lunr.Index\\n * @returns {lunr.Index}\\n */\\nlunr.Index.load = function (serializedIndex) {\\n  var attrs = {},\\n      fieldVectors = {},\\n      serializedVectors = serializedIndex.fieldVectors,\\n      invertedIndex = Object.create(null),\\n      serializedInvertedIndex = serializedIndex.invertedIndex,\\n      tokenSetBuilder = new lunr.TokenSet.Builder,\\n      pipeline = lunr.Pipeline.load(serializedIndex.pipeline)\\n\\n  if (serializedIndex.version != lunr.version) {\\n    lunr.utils.warn(\\\"Version mismatch when loading serialised index. Current version of lunr '\\\" + lunr.version + \\\"' does not match serialized index '\\\" + serializedIndex.version + \\\"'\\\")\\n  }\\n\\n  for (var i = 0; i < serializedVectors.length; i++) {\\n    var tuple = serializedVectors[i],\\n        ref = tuple[0],\\n        elements = tuple[1]\\n\\n    fieldVectors[ref] = new lunr.Vector(elements)\\n  }\\n\\n  for (var i = 0; i < serializedInvertedIndex.length; i++) {\\n    var tuple = serializedInvertedIndex[i],\\n        term = tuple[0],\\n        posting = tuple[1]\\n\\n    tokenSetBuilder.insert(term)\\n    invertedIndex[term] = posting\\n  }\\n\\n  tokenSetBuilder.finish()\\n\\n  attrs.fields = serializedIndex.fields\\n\\n  attrs.fieldVectors = fieldVectors\\n  attrs.invertedIndex = invertedIndex\\n  attrs.tokenSet = tokenSetBuilder.root\\n  attrs.pipeline = pipeline\\n\\n  return new lunr.Index(attrs)\\n}\\n/*!\\n * lunr.Builder\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.Builder performs indexing on a set of documents and\\n * returns instances of lunr.Index ready for querying.\\n *\\n * All configuration of the index is done via the builder, the\\n * fields to index, the document reference, the text processing\\n * pipeline and document scoring parameters are all set on the\\n * builder before indexing.\\n *\\n * @constructor\\n * @property {string} _ref - Internal reference to the document reference field.\\n * @property {string[]} _fields - Internal reference to the document fields to index.\\n * @property {object} invertedIndex - The inverted index maps terms to document fields.\\n * @property {object} documentTermFrequencies - Keeps track of document term frequencies.\\n * @property {object} documentLengths - Keeps track of the length of documents added to the index.\\n * @property {lunr.tokenizer} tokenizer - Function for splitting strings into tokens for indexing.\\n * @property {lunr.Pipeline} pipeline - The pipeline performs text processing on tokens before indexing.\\n * @property {lunr.Pipeline} searchPipeline - A pipeline for processing search terms before querying the index.\\n * @property {number} documentCount - Keeps track of the total number of documents indexed.\\n * @property {number} _b - A parameter to control field length normalization, setting this to 0 disabled normalization, 1 fully normalizes field lengths, the default value is 0.75.\\n * @property {number} _k1 - A parameter to control how quickly an increase in term frequency results in term frequency saturation, the default value is 1.2.\\n * @property {number} termIndex - A counter incremented for each unique term, used to identify a terms position in the vector space.\\n * @property {array} metadataWhitelist - A list of metadata keys that have been whitelisted for entry in the index.\\n */\\nlunr.Builder = function () {\\n  this._ref = \\\"id\\\"\\n  this._fields = Object.create(null)\\n  this._documents = Object.create(null)\\n  this.invertedIndex = Object.create(null)\\n  this.fieldTermFrequencies = {}\\n  this.fieldLengths = {}\\n  this.tokenizer = lunr.tokenizer\\n  this.pipeline = new lunr.Pipeline\\n  this.searchPipeline = new lunr.Pipeline\\n  this.documentCount = 0\\n  this._b = 0.75\\n  this._k1 = 1.2\\n  this.termIndex = 0\\n  this.metadataWhitelist = []\\n}\\n\\n/**\\n * Sets the document field used as the document reference. Every document must have this field.\\n * The type of this field in the document should be a string, if it is not a string it will be\\n * coerced into a string by calling toString.\\n *\\n * The default ref is 'id'.\\n *\\n * The ref should _not_ be changed during indexing, it should be set before any documents are\\n * added to the index. Changing it during indexing can lead to inconsistent results.\\n *\\n * @param {string} ref - The name of the reference field in the document.\\n */\\nlunr.Builder.prototype.ref = function (ref) {\\n  this._ref = ref\\n}\\n\\n/**\\n * A function that is used to extract a field from a document.\\n *\\n * Lunr expects a field to be at the top level of a document, if however the field\\n * is deeply nested within a document an extractor function can be used to extract\\n * the right field for indexing.\\n *\\n * @callback fieldExtractor\\n * @param {object} doc - The document being added to the index.\\n * @returns {?(string|object|object[])} obj - The object that will be indexed for this field.\\n * @example <caption>Extracting a nested field</caption>\\n * function (doc) { return doc.nested.field }\\n */\\n\\n/**\\n * Adds a field to the list of document fields that will be indexed. Every document being\\n * indexed should have this field. Null values for this field in indexed documents will\\n * not cause errors but will limit the chance of that document being retrieved by searches.\\n *\\n * All fields should be added before adding documents to the index. Adding fields after\\n * a document has been indexed will have no effect on already indexed documents.\\n *\\n * Fields can be boosted at build time. This allows terms within that field to have more\\n * importance when ranking search results. Use a field boost to specify that matches within\\n * one field are more important than other fields.\\n *\\n * @param {string} fieldName - The name of a field to index in all documents.\\n * @param {object} attributes - Optional attributes associated with this field.\\n * @param {number} [attributes.boost=1] - Boost applied to all terms within this field.\\n * @param {fieldExtractor} [attributes.extractor] - Function to extract a field from a document.\\n * @throws {RangeError} fieldName cannot contain unsupported characters '/'\\n */\\nlunr.Builder.prototype.field = function (fieldName, attributes) {\\n  if (/\\\\//.test(fieldName)) {\\n    throw new RangeError (\\\"Field '\\\" + fieldName + \\\"' contains illegal character '/'\\\")\\n  }\\n\\n  this._fields[fieldName] = attributes || {}\\n}\\n\\n/**\\n * A parameter to tune the amount of field length normalisation that is applied when\\n * calculating relevance scores. A value of 0 will completely disable any normalisation\\n * and a value of 1 will fully normalise field lengths. The default is 0.75. Values of b\\n * will be clamped to the range 0 - 1.\\n *\\n * @param {number} number - The value to set for this tuning parameter.\\n */\\nlunr.Builder.prototype.b = function (number) {\\n  if (number < 0) {\\n    this._b = 0\\n  } else if (number > 1) {\\n    this._b = 1\\n  } else {\\n    this._b = number\\n  }\\n}\\n\\n/**\\n * A parameter that controls the speed at which a rise in term frequency results in term\\n * frequency saturation. The default value is 1.2. Setting this to a higher value will give\\n * slower saturation levels, a lower value will result in quicker saturation.\\n *\\n * @param {number} number - The value to set for this tuning parameter.\\n */\\nlunr.Builder.prototype.k1 = function (number) {\\n  this._k1 = number\\n}\\n\\n/**\\n * Adds a document to the index.\\n *\\n * Before adding fields to the index the index should have been fully setup, with the document\\n * ref and all fields to index already having been specified.\\n *\\n * The document must have a field name as specified by the ref (by default this is 'id') and\\n * it should have all fields defined for indexing, though null or undefined values will not\\n * cause errors.\\n *\\n * Entire documents can be boosted at build time. Applying a boost to a document indicates that\\n * this document should rank higher in search results than other documents.\\n *\\n * @param {object} doc - The document to add to the index.\\n * @param {object} attributes - Optional attributes associated with this document.\\n * @param {number} [attributes.boost=1] - Boost applied to all terms within this document.\\n */\\nlunr.Builder.prototype.add = function (doc, attributes) {\\n  var docRef = doc[this._ref],\\n      fields = Object.keys(this._fields)\\n\\n  this._documents[docRef] = attributes || {}\\n  this.documentCount += 1\\n\\n  for (var i = 0; i < fields.length; i++) {\\n    var fieldName = fields[i],\\n        extractor = this._fields[fieldName].extractor,\\n        field = extractor ? extractor(doc) : doc[fieldName],\\n        tokens = this.tokenizer(field, {\\n          fields: [fieldName]\\n        }),\\n        terms = this.pipeline.run(tokens),\\n        fieldRef = new lunr.FieldRef (docRef, fieldName),\\n        fieldTerms = Object.create(null)\\n\\n    this.fieldTermFrequencies[fieldRef] = fieldTerms\\n    this.fieldLengths[fieldRef] = 0\\n\\n    // store the length of this field for this document\\n    this.fieldLengths[fieldRef] += terms.length\\n\\n    // calculate term frequencies for this field\\n    for (var j = 0; j < terms.length; j++) {\\n      var term = terms[j]\\n\\n      if (fieldTerms[term] == undefined) {\\n        fieldTerms[term] = 0\\n      }\\n\\n      fieldTerms[term] += 1\\n\\n      // add to inverted index\\n      // create an initial posting if one doesn't exist\\n      if (this.invertedIndex[term] == undefined) {\\n        var posting = Object.create(null)\\n        posting[\\\"_index\\\"] = this.termIndex\\n        this.termIndex += 1\\n\\n        for (var k = 0; k < fields.length; k++) {\\n          posting[fields[k]] = Object.create(null)\\n        }\\n\\n        this.invertedIndex[term] = posting\\n      }\\n\\n      // add an entry for this term/fieldName/docRef to the invertedIndex\\n      if (this.invertedIndex[term][fieldName][docRef] == undefined) {\\n        this.invertedIndex[term][fieldName][docRef] = Object.create(null)\\n      }\\n\\n      // store all whitelisted metadata about this token in the\\n      // inverted index\\n      for (var l = 0; l < this.metadataWhitelist.length; l++) {\\n        var metadataKey = this.metadataWhitelist[l],\\n            metadata = term.metadata[metadataKey]\\n\\n        if (this.invertedIndex[term][fieldName][docRef][metadataKey] == undefined) {\\n          this.invertedIndex[term][fieldName][docRef][metadataKey] = []\\n        }\\n\\n        this.invertedIndex[term][fieldName][docRef][metadataKey].push(metadata)\\n      }\\n    }\\n\\n  }\\n}\\n\\n/**\\n * Calculates the average document length for this index\\n *\\n * @private\\n */\\nlunr.Builder.prototype.calculateAverageFieldLengths = function () {\\n\\n  var fieldRefs = Object.keys(this.fieldLengths),\\n      numberOfFields = fieldRefs.length,\\n      accumulator = {},\\n      documentsWithField = {}\\n\\n  for (var i = 0; i < numberOfFields; i++) {\\n    var fieldRef = lunr.FieldRef.fromString(fieldRefs[i]),\\n        field = fieldRef.fieldName\\n\\n    documentsWithField[field] || (documentsWithField[field] = 0)\\n    documentsWithField[field] += 1\\n\\n    accumulator[field] || (accumulator[field] = 0)\\n    accumulator[field] += this.fieldLengths[fieldRef]\\n  }\\n\\n  var fields = Object.keys(this._fields)\\n\\n  for (var i = 0; i < fields.length; i++) {\\n    var fieldName = fields[i]\\n    accumulator[fieldName] = accumulator[fieldName] / documentsWithField[fieldName]\\n  }\\n\\n  this.averageFieldLength = accumulator\\n}\\n\\n/**\\n * Builds a vector space model of every document using lunr.Vector\\n *\\n * @private\\n */\\nlunr.Builder.prototype.createFieldVectors = function () {\\n  var fieldVectors = {},\\n      fieldRefs = Object.keys(this.fieldTermFrequencies),\\n      fieldRefsLength = fieldRefs.length,\\n      termIdfCache = Object.create(null)\\n\\n  for (var i = 0; i < fieldRefsLength; i++) {\\n    var fieldRef = lunr.FieldRef.fromString(fieldRefs[i]),\\n        fieldName = fieldRef.fieldName,\\n        fieldLength = this.fieldLengths[fieldRef],\\n        fieldVector = new lunr.Vector,\\n        termFrequencies = this.fieldTermFrequencies[fieldRef],\\n        terms = Object.keys(termFrequencies),\\n        termsLength = terms.length\\n\\n\\n    var fieldBoost = this._fields[fieldName].boost || 1,\\n        docBoost = this._documents[fieldRef.docRef].boost || 1\\n\\n    for (var j = 0; j < termsLength; j++) {\\n      var term = terms[j],\\n          tf = termFrequencies[term],\\n          termIndex = this.invertedIndex[term]._index,\\n          idf, score, scoreWithPrecision\\n\\n      if (termIdfCache[term] === undefined) {\\n        idf = lunr.idf(this.invertedIndex[term], this.documentCount)\\n        termIdfCache[term] = idf\\n      } else {\\n        idf = termIdfCache[term]\\n      }\\n\\n      score = idf * ((this._k1 + 1) * tf) / (this._k1 * (1 - this._b + this._b * (fieldLength / this.averageFieldLength[fieldName])) + tf)\\n      score *= fieldBoost\\n      score *= docBoost\\n      scoreWithPrecision = Math.round(score * 1000) / 1000\\n      // Converts 1.23456789 to 1.234.\\n      // Reducing the precision so that the vectors take up less\\n      // space when serialised. Doing it now so that they behave\\n      // the same before and after serialisation. Also, this is\\n      // the fastest approach to reducing a number's precision in\\n      // JavaScript.\\n\\n      fieldVector.insert(termIndex, scoreWithPrecision)\\n    }\\n\\n    fieldVectors[fieldRef] = fieldVector\\n  }\\n\\n  this.fieldVectors = fieldVectors\\n}\\n\\n/**\\n * Creates a token set of all tokens in the index using lunr.TokenSet\\n *\\n * @private\\n */\\nlunr.Builder.prototype.createTokenSet = function () {\\n  this.tokenSet = lunr.TokenSet.fromArray(\\n    Object.keys(this.invertedIndex).sort()\\n  )\\n}\\n\\n/**\\n * Builds the index, creating an instance of lunr.Index.\\n *\\n * This completes the indexing process and should only be called\\n * once all documents have been added to the index.\\n *\\n * @returns {lunr.Index}\\n */\\nlunr.Builder.prototype.build = function () {\\n  this.calculateAverageFieldLengths()\\n  this.createFieldVectors()\\n  this.createTokenSet()\\n\\n  return new lunr.Index({\\n    invertedIndex: this.invertedIndex,\\n    fieldVectors: this.fieldVectors,\\n    tokenSet: this.tokenSet,\\n    fields: Object.keys(this._fields),\\n    pipeline: this.searchPipeline\\n  })\\n}\\n\\n/**\\n * Applies a plugin to the index builder.\\n *\\n * A plugin is a function that is called with the index builder as its context.\\n * Plugins can be used to customise or extend the behaviour of the index\\n * in some way. A plugin is just a function, that encapsulated the custom\\n * behaviour that should be applied when building the index.\\n *\\n * The plugin function will be called with the index builder as its argument, additional\\n * arguments can also be passed when calling use. The function will be called\\n * with the index builder as its context.\\n *\\n * @param {Function} plugin The plugin to apply.\\n */\\nlunr.Builder.prototype.use = function (fn) {\\n  var args = Array.prototype.slice.call(arguments, 1)\\n  args.unshift(this)\\n  fn.apply(this, args)\\n}\\n/**\\n * Contains and collects metadata about a matching document.\\n * A single instance of lunr.MatchData is returned as part of every\\n * lunr.Index~Result.\\n *\\n * @constructor\\n * @param {string} term - The term this match data is associated with\\n * @param {string} field - The field in which the term was found\\n * @param {object} metadata - The metadata recorded about this term in this field\\n * @property {object} metadata - A cloned collection of metadata associated with this document.\\n * @see {@link lunr.Index~Result}\\n */\\nlunr.MatchData = function (term, field, metadata) {\\n  var clonedMetadata = Object.create(null),\\n      metadataKeys = Object.keys(metadata || {})\\n\\n  // Cloning the metadata to prevent the original\\n  // being mutated during match data combination.\\n  // Metadata is kept in an array within the inverted\\n  // index so cloning the data can be done with\\n  // Array#slice\\n  for (var i = 0; i < metadataKeys.length; i++) {\\n    var key = metadataKeys[i]\\n    clonedMetadata[key] = metadata[key].slice()\\n  }\\n\\n  this.metadata = Object.create(null)\\n\\n  if (term !== undefined) {\\n    this.metadata[term] = Object.create(null)\\n    this.metadata[term][field] = clonedMetadata\\n  }\\n}\\n\\n/**\\n * An instance of lunr.MatchData will be created for every term that matches a\\n * document. However only one instance is required in a lunr.Index~Result. This\\n * method combines metadata from another instance of lunr.MatchData with this\\n * objects metadata.\\n *\\n * @param {lunr.MatchData} otherMatchData - Another instance of match data to merge with this one.\\n * @see {@link lunr.Index~Result}\\n */\\nlunr.MatchData.prototype.combine = function (otherMatchData) {\\n  var terms = Object.keys(otherMatchData.metadata)\\n\\n  for (var i = 0; i < terms.length; i++) {\\n    var term = terms[i],\\n        fields = Object.keys(otherMatchData.metadata[term])\\n\\n    if (this.metadata[term] == undefined) {\\n      this.metadata[term] = Object.create(null)\\n    }\\n\\n    for (var j = 0; j < fields.length; j++) {\\n      var field = fields[j],\\n          keys = Object.keys(otherMatchData.metadata[term][field])\\n\\n      if (this.metadata[term][field] == undefined) {\\n        this.metadata[term][field] = Object.create(null)\\n      }\\n\\n      for (var k = 0; k < keys.length; k++) {\\n        var key = keys[k]\\n\\n        if (this.metadata[term][field][key] == undefined) {\\n          this.metadata[term][field][key] = otherMatchData.metadata[term][field][key]\\n        } else {\\n          this.metadata[term][field][key] = this.metadata[term][field][key].concat(otherMatchData.metadata[term][field][key])\\n        }\\n\\n      }\\n    }\\n  }\\n}\\n\\n/**\\n * Add metadata for a term/field pair to this instance of match data.\\n *\\n * @param {string} term - The term this match data is associated with\\n * @param {string} field - The field in which the term was found\\n * @param {object} metadata - The metadata recorded about this term in this field\\n */\\nlunr.MatchData.prototype.add = function (term, field, metadata) {\\n  if (!(term in this.metadata)) {\\n    this.metadata[term] = Object.create(null)\\n    this.metadata[term][field] = metadata\\n    return\\n  }\\n\\n  if (!(field in this.metadata[term])) {\\n    this.metadata[term][field] = metadata\\n    return\\n  }\\n\\n  var metadataKeys = Object.keys(metadata)\\n\\n  for (var i = 0; i < metadataKeys.length; i++) {\\n    var key = metadataKeys[i]\\n\\n    if (key in this.metadata[term][field]) {\\n      this.metadata[term][field][key] = this.metadata[term][field][key].concat(metadata[key])\\n    } else {\\n      this.metadata[term][field][key] = metadata[key]\\n    }\\n  }\\n}\\n/**\\n * A lunr.Query provides a programmatic way of defining queries to be performed\\n * against a {@link lunr.Index}.\\n *\\n * Prefer constructing a lunr.Query using the {@link lunr.Index#query} method\\n * so the query object is pre-initialized with the right index fields.\\n *\\n * @constructor\\n * @property {lunr.Query~Clause[]} clauses - An array of query clauses.\\n * @property {string[]} allFields - An array of all available fields in a lunr.Index.\\n */\\nlunr.Query = function (allFields) {\\n  this.clauses = []\\n  this.allFields = allFields\\n}\\n\\n/**\\n * Constants for indicating what kind of automatic wildcard insertion will be used when constructing a query clause.\\n *\\n * This allows wildcards to be added to the beginning and end of a term without having to manually do any string\\n * concatenation.\\n *\\n * The wildcard constants can be bitwise combined to select both leading and trailing wildcards.\\n *\\n * @constant\\n * @default\\n * @property {number} wildcard.NONE - The term will have no wildcards inserted, this is the default behaviour\\n * @property {number} wildcard.LEADING - Prepend the term with a wildcard, unless a leading wildcard already exists\\n * @property {number} wildcard.TRAILING - Append a wildcard to the term, unless a trailing wildcard already exists\\n * @see lunr.Query~Clause\\n * @see lunr.Query#clause\\n * @see lunr.Query#term\\n * @example <caption>query term with trailing wildcard</caption>\\n * query.term('foo', { wildcard: lunr.Query.wildcard.TRAILING })\\n * @example <caption>query term with leading and trailing wildcard</caption>\\n * query.term('foo', {\\n *   wildcard: lunr.Query.wildcard.LEADING | lunr.Query.wildcard.TRAILING\\n * })\\n */\\n\\nlunr.Query.wildcard = new String (\\\"*\\\")\\nlunr.Query.wildcard.NONE = 0\\nlunr.Query.wildcard.LEADING = 1\\nlunr.Query.wildcard.TRAILING = 2\\n\\n/**\\n * Constants for indicating what kind of presence a term must have in matching documents.\\n *\\n * @constant\\n * @enum {number}\\n * @see lunr.Query~Clause\\n * @see lunr.Query#clause\\n * @see lunr.Query#term\\n * @example <caption>query term with required presence</caption>\\n * query.term('foo', { presence: lunr.Query.presence.REQUIRED })\\n */\\nlunr.Query.presence = {\\n  /**\\n   * Term's presence in a document is optional, this is the default value.\\n   */\\n  OPTIONAL: 1,\\n\\n  /**\\n   * Term's presence in a document is required, documents that do not contain\\n   * this term will not be returned.\\n   */\\n  REQUIRED: 2,\\n\\n  /**\\n   * Term's presence in a document is prohibited, documents that do contain\\n   * this term will not be returned.\\n   */\\n  PROHIBITED: 3\\n}\\n\\n/**\\n * A single clause in a {@link lunr.Query} contains a term and details on how to\\n * match that term against a {@link lunr.Index}.\\n *\\n * @typedef {Object} lunr.Query~Clause\\n * @property {string[]} fields - The fields in an index this clause should be matched against.\\n * @property {number} [boost=1] - Any boost that should be applied when matching this clause.\\n * @property {number} [editDistance] - Whether the term should have fuzzy matching applied, and how fuzzy the match should be.\\n * @property {boolean} [usePipeline] - Whether the term should be passed through the search pipeline.\\n * @property {number} [wildcard=lunr.Query.wildcard.NONE] - Whether the term should have wildcards appended or prepended.\\n * @property {number} [presence=lunr.Query.presence.OPTIONAL] - The terms presence in any matching documents.\\n */\\n\\n/**\\n * Adds a {@link lunr.Query~Clause} to this query.\\n *\\n * Unless the clause contains the fields to be matched all fields will be matched. In addition\\n * a default boost of 1 is applied to the clause.\\n *\\n * @param {lunr.Query~Clause} clause - The clause to add to this query.\\n * @see lunr.Query~Clause\\n * @returns {lunr.Query}\\n */\\nlunr.Query.prototype.clause = function (clause) {\\n  if (!('fields' in clause)) {\\n    clause.fields = this.allFields\\n  }\\n\\n  if (!('boost' in clause)) {\\n    clause.boost = 1\\n  }\\n\\n  if (!('usePipeline' in clause)) {\\n    clause.usePipeline = true\\n  }\\n\\n  if (!('wildcard' in clause)) {\\n    clause.wildcard = lunr.Query.wildcard.NONE\\n  }\\n\\n  if ((clause.wildcard & lunr.Query.wildcard.LEADING) && (clause.term.charAt(0) != lunr.Query.wildcard)) {\\n    clause.term = \\\"*\\\" + clause.term\\n  }\\n\\n  if ((clause.wildcard & lunr.Query.wildcard.TRAILING) && (clause.term.slice(-1) != lunr.Query.wildcard)) {\\n    clause.term = \\\"\\\" + clause.term + \\\"*\\\"\\n  }\\n\\n  if (!('presence' in clause)) {\\n    clause.presence = lunr.Query.presence.OPTIONAL\\n  }\\n\\n  this.clauses.push(clause)\\n\\n  return this\\n}\\n\\n/**\\n * A negated query is one in which every clause has a presence of\\n * prohibited. These queries require some special processing to return\\n * the expected results.\\n *\\n * @returns boolean\\n */\\nlunr.Query.prototype.isNegated = function () {\\n  for (var i = 0; i < this.clauses.length; i++) {\\n    if (this.clauses[i].presence != lunr.Query.presence.PROHIBITED) {\\n      return false\\n    }\\n  }\\n\\n  return true\\n}\\n\\n/**\\n * Adds a term to the current query, under the covers this will create a {@link lunr.Query~Clause}\\n * to the list of clauses that make up this query.\\n *\\n * The term is used as is, i.e. no tokenization will be performed by this method. Instead conversion\\n * to a token or token-like string should be done before calling this method.\\n *\\n * The term will be converted to a string by calling `toString`. Multiple terms can be passed as an\\n * array, each term in the array will share the same options.\\n *\\n * @param {object|object[]} term - The term(s) to add to the query.\\n * @param {object} [options] - Any additional properties to add to the query clause.\\n * @returns {lunr.Query}\\n * @see lunr.Query#clause\\n * @see lunr.Query~Clause\\n * @example <caption>adding a single term to a query</caption>\\n * query.term(\\\"foo\\\")\\n * @example <caption>adding a single term to a query and specifying search fields, term boost and automatic trailing wildcard</caption>\\n * query.term(\\\"foo\\\", {\\n *   fields: [\\\"title\\\"],\\n *   boost: 10,\\n *   wildcard: lunr.Query.wildcard.TRAILING\\n * })\\n * @example <caption>using lunr.tokenizer to convert a string to tokens before using them as terms</caption>\\n * query.term(lunr.tokenizer(\\\"foo bar\\\"))\\n */\\nlunr.Query.prototype.term = function (term, options) {\\n  if (Array.isArray(term)) {\\n    term.forEach(function (t) { this.term(t, lunr.utils.clone(options)) }, this)\\n    return this\\n  }\\n\\n  var clause = options || {}\\n  clause.term = term.toString()\\n\\n  this.clause(clause)\\n\\n  return this\\n}\\nlunr.QueryParseError = function (message, start, end) {\\n  this.name = \\\"QueryParseError\\\"\\n  this.message = message\\n  this.start = start\\n  this.end = end\\n}\\n\\nlunr.QueryParseError.prototype = new Error\\nlunr.QueryLexer = function (str) {\\n  this.lexemes = []\\n  this.str = str\\n  this.length = str.length\\n  this.pos = 0\\n  this.start = 0\\n  this.escapeCharPositions = []\\n}\\n\\nlunr.QueryLexer.prototype.run = function () {\\n  var state = lunr.QueryLexer.lexText\\n\\n  while (state) {\\n    state = state(this)\\n  }\\n}\\n\\nlunr.QueryLexer.prototype.sliceString = function () {\\n  var subSlices = [],\\n      sliceStart = this.start,\\n      sliceEnd = this.pos\\n\\n  for (var i = 0; i < this.escapeCharPositions.length; i++) {\\n    sliceEnd = this.escapeCharPositions[i]\\n    subSlices.push(this.str.slice(sliceStart, sliceEnd))\\n    sliceStart = sliceEnd + 1\\n  }\\n\\n  subSlices.push(this.str.slice(sliceStart, this.pos))\\n  this.escapeCharPositions.length = 0\\n\\n  return subSlices.join('')\\n}\\n\\nlunr.QueryLexer.prototype.emit = function (type) {\\n  this.lexemes.push({\\n    type: type,\\n    str: this.sliceString(),\\n    start: this.start,\\n    end: this.pos\\n  })\\n\\n  this.start = this.pos\\n}\\n\\nlunr.QueryLexer.prototype.escapeCharacter = function () {\\n  this.escapeCharPositions.push(this.pos - 1)\\n  this.pos += 1\\n}\\n\\nlunr.QueryLexer.prototype.next = function () {\\n  if (this.pos >= this.length) {\\n    return lunr.QueryLexer.EOS\\n  }\\n\\n  var char = this.str.charAt(this.pos)\\n  this.pos += 1\\n  return char\\n}\\n\\nlunr.QueryLexer.prototype.width = function () {\\n  return this.pos - this.start\\n}\\n\\nlunr.QueryLexer.prototype.ignore = function () {\\n  if (this.start == this.pos) {\\n    this.pos += 1\\n  }\\n\\n  this.start = this.pos\\n}\\n\\nlunr.QueryLexer.prototype.backup = function () {\\n  this.pos -= 1\\n}\\n\\nlunr.QueryLexer.prototype.acceptDigitRun = function () {\\n  var char, charCode\\n\\n  do {\\n    char = this.next()\\n    charCode = char.charCodeAt(0)\\n  } while (charCode > 47 && charCode < 58)\\n\\n  if (char != lunr.QueryLexer.EOS) {\\n    this.backup()\\n  }\\n}\\n\\nlunr.QueryLexer.prototype.more = function () {\\n  return this.pos < this.length\\n}\\n\\nlunr.QueryLexer.EOS = 'EOS'\\nlunr.QueryLexer.FIELD = 'FIELD'\\nlunr.QueryLexer.TERM = 'TERM'\\nlunr.QueryLexer.EDIT_DISTANCE = 'EDIT_DISTANCE'\\nlunr.QueryLexer.BOOST = 'BOOST'\\nlunr.QueryLexer.PRESENCE = 'PRESENCE'\\n\\nlunr.QueryLexer.lexField = function (lexer) {\\n  lexer.backup()\\n  lexer.emit(lunr.QueryLexer.FIELD)\\n  lexer.ignore()\\n  return lunr.QueryLexer.lexText\\n}\\n\\nlunr.QueryLexer.lexTerm = function (lexer) {\\n  if (lexer.width() > 1) {\\n    lexer.backup()\\n    lexer.emit(lunr.QueryLexer.TERM)\\n  }\\n\\n  lexer.ignore()\\n\\n  if (lexer.more()) {\\n    return lunr.QueryLexer.lexText\\n  }\\n}\\n\\nlunr.QueryLexer.lexEditDistance = function (lexer) {\\n  lexer.ignore()\\n  lexer.acceptDigitRun()\\n  lexer.emit(lunr.QueryLexer.EDIT_DISTANCE)\\n  return lunr.QueryLexer.lexText\\n}\\n\\nlunr.QueryLexer.lexBoost = function (lexer) {\\n  lexer.ignore()\\n  lexer.acceptDigitRun()\\n  lexer.emit(lunr.QueryLexer.BOOST)\\n  return lunr.QueryLexer.lexText\\n}\\n\\nlunr.QueryLexer.lexEOS = function (lexer) {\\n  if (lexer.width() > 0) {\\n    lexer.emit(lunr.QueryLexer.TERM)\\n  }\\n}\\n\\n// This matches the separator used when tokenising fields\\n// within a document. These should match otherwise it is\\n// not possible to search for some tokens within a document.\\n//\\n// It is possible for the user to change the separator on the\\n// tokenizer so it _might_ clash with any other of the special\\n// characters already used within the search string, e.g. :.\\n//\\n// This means that it is possible to change the separator in\\n// such a way that makes some words unsearchable using a search\\n// string.\\nlunr.QueryLexer.termSeparator = lunr.tokenizer.separator\\n\\nlunr.QueryLexer.lexText = function (lexer) {\\n  while (true) {\\n    var char = lexer.next()\\n\\n    if (char == lunr.QueryLexer.EOS) {\\n      return lunr.QueryLexer.lexEOS\\n    }\\n\\n    // Escape character is '\\\\'\\n    if (char.charCodeAt(0) == 92) {\\n      lexer.escapeCharacter()\\n      continue\\n    }\\n\\n    if (char == \\\":\\\") {\\n      return lunr.QueryLexer.lexField\\n    }\\n\\n    if (char == \\\"~\\\") {\\n      lexer.backup()\\n      if (lexer.width() > 0) {\\n        lexer.emit(lunr.QueryLexer.TERM)\\n      }\\n      return lunr.QueryLexer.lexEditDistance\\n    }\\n\\n    if (char == \\\"^\\\") {\\n      lexer.backup()\\n      if (lexer.width() > 0) {\\n        lexer.emit(lunr.QueryLexer.TERM)\\n      }\\n      return lunr.QueryLexer.lexBoost\\n    }\\n\\n    // \\\"+\\\" indicates term presence is required\\n    // checking for length to ensure that only\\n    // leading \\\"+\\\" are considered\\n    if (char == \\\"+\\\" && lexer.width() === 1) {\\n      lexer.emit(lunr.QueryLexer.PRESENCE)\\n      return lunr.QueryLexer.lexText\\n    }\\n\\n    // \\\"-\\\" indicates term presence is prohibited\\n    // checking for length to ensure that only\\n    // leading \\\"-\\\" are considered\\n    if (char == \\\"-\\\" && lexer.width() === 1) {\\n      lexer.emit(lunr.QueryLexer.PRESENCE)\\n      return lunr.QueryLexer.lexText\\n    }\\n\\n    if (char.match(lunr.QueryLexer.termSeparator)) {\\n      return lunr.QueryLexer.lexTerm\\n    }\\n  }\\n}\\n\\nlunr.QueryParser = function (str, query) {\\n  this.lexer = new lunr.QueryLexer (str)\\n  this.query = query\\n  this.currentClause = {}\\n  this.lexemeIdx = 0\\n}\\n\\nlunr.QueryParser.prototype.parse = function () {\\n  this.lexer.run()\\n  this.lexemes = this.lexer.lexemes\\n\\n  var state = lunr.QueryParser.parseClause\\n\\n  while (state) {\\n    state = state(this)\\n  }\\n\\n  return this.query\\n}\\n\\nlunr.QueryParser.prototype.peekLexeme = function () {\\n  return this.lexemes[this.lexemeIdx]\\n}\\n\\nlunr.QueryParser.prototype.consumeLexeme = function () {\\n  var lexeme = this.peekLexeme()\\n  this.lexemeIdx += 1\\n  return lexeme\\n}\\n\\nlunr.QueryParser.prototype.nextClause = function () {\\n  var completedClause = this.currentClause\\n  this.query.clause(completedClause)\\n  this.currentClause = {}\\n}\\n\\nlunr.QueryParser.parseClause = function (parser) {\\n  var lexeme = parser.peekLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  switch (lexeme.type) {\\n    case lunr.QueryLexer.PRESENCE:\\n      return lunr.QueryParser.parsePresence\\n    case lunr.QueryLexer.FIELD:\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.TERM:\\n      return lunr.QueryParser.parseTerm\\n    default:\\n      var errorMessage = \\\"expected either a field or a term, found \\\" + lexeme.type\\n\\n      if (lexeme.str.length >= 1) {\\n        errorMessage += \\\" with value '\\\" + lexeme.str + \\\"'\\\"\\n      }\\n\\n      throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parsePresence = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  switch (lexeme.str) {\\n    case \\\"-\\\":\\n      parser.currentClause.presence = lunr.Query.presence.PROHIBITED\\n      break\\n    case \\\"+\\\":\\n      parser.currentClause.presence = lunr.Query.presence.REQUIRED\\n      break\\n    default:\\n      var errorMessage = \\\"unrecognised presence operator'\\\" + lexeme.str + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    var errorMessage = \\\"expecting term or field, found nothing\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.FIELD:\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.TERM:\\n      return lunr.QueryParser.parseTerm\\n    default:\\n      var errorMessage = \\\"expecting term or field, found '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseField = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  if (parser.query.allFields.indexOf(lexeme.str) == -1) {\\n    var possibleFields = parser.query.allFields.map(function (f) { return \\\"'\\\" + f + \\\"'\\\" }).join(', '),\\n        errorMessage = \\\"unrecognised field '\\\" + lexeme.str + \\\"', possible fields: \\\" + possibleFields\\n\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  parser.currentClause.fields = [lexeme.str]\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    var errorMessage = \\\"expecting term, found nothing\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      return lunr.QueryParser.parseTerm\\n    default:\\n      var errorMessage = \\\"expecting term, found '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseTerm = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  parser.currentClause.term = lexeme.str.toLowerCase()\\n\\n  if (lexeme.str.indexOf(\\\"*\\\") != -1) {\\n    parser.currentClause.usePipeline = false\\n  }\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    parser.nextClause()\\n    return\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseTerm\\n    case lunr.QueryLexer.FIELD:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.EDIT_DISTANCE:\\n      return lunr.QueryParser.parseEditDistance\\n    case lunr.QueryLexer.BOOST:\\n      return lunr.QueryParser.parseBoost\\n    case lunr.QueryLexer.PRESENCE:\\n      parser.nextClause()\\n      return lunr.QueryParser.parsePresence\\n    default:\\n      var errorMessage = \\\"Unexpected lexeme type '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseEditDistance = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  var editDistance = parseInt(lexeme.str, 10)\\n\\n  if (isNaN(editDistance)) {\\n    var errorMessage = \\\"edit distance must be numeric\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  parser.currentClause.editDistance = editDistance\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    parser.nextClause()\\n    return\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseTerm\\n    case lunr.QueryLexer.FIELD:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.EDIT_DISTANCE:\\n      return lunr.QueryParser.parseEditDistance\\n    case lunr.QueryLexer.BOOST:\\n      return lunr.QueryParser.parseBoost\\n    case lunr.QueryLexer.PRESENCE:\\n      parser.nextClause()\\n      return lunr.QueryParser.parsePresence\\n    default:\\n      var errorMessage = \\\"Unexpected lexeme type '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseBoost = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  var boost = parseInt(lexeme.str, 10)\\n\\n  if (isNaN(boost)) {\\n    var errorMessage = \\\"boost must be numeric\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  parser.currentClause.boost = boost\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    parser.nextClause()\\n    return\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseTerm\\n    case lunr.QueryLexer.FIELD:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.EDIT_DISTANCE:\\n      return lunr.QueryParser.parseEditDistance\\n    case lunr.QueryLexer.BOOST:\\n      return lunr.QueryParser.parseBoost\\n    case lunr.QueryLexer.PRESENCE:\\n      parser.nextClause()\\n      return lunr.QueryParser.parsePresence\\n    default:\\n      var errorMessage = \\\"Unexpected lexeme type '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\n  /**\\n   * export the module via AMD, CommonJS or as a browser global\\n   * Export code from https://github.com/umdjs/umd/blob/master/returnExports.js\\n   */\\n  ;(function (root, factory) {\\n    if (true) {\\n      // AMD. Register as an anonymous module.\\n      !(__WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\\n\\t\\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\\n\\t\\t(__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :\\n\\t\\t__WEBPACK_AMD_DEFINE_FACTORY__),\\n\\t\\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__))\\n    } else {}\\n  }(this, function () {\\n    /**\\n     * Just return a value to define the module export.\\n     * This example returns an object, but the module\\n     * can return a function as the exported value.\\n     */\\n    return lunr\\n  }))\\n})();\\n\\n\\n//# sourceURL=webpack:///../node_modules/lunr/lunr.js?\");\n\n/***/ }),\n\n/***/ \"./default/assets/css/main.sass\":\n/*!**************************************!*\\\n  !*** ./default/assets/css/main.sass ***!\n  \\**************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n// extracted by mini-css-extract-plugin\\n\\n\\n//# sourceURL=webpack:///./default/assets/css/main.sass?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/bootstrap.ts\":\n/*!********************************************!*\\\n  !*** ./default/assets/js/src/bootstrap.ts ***!\n  \\********************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony import */ var _typedoc_Application__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typedoc/Application */ \\\"./default/assets/js/src/typedoc/Application.ts\\\");\\n/* harmony import */ var _typedoc_components_MenuHighlight__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./typedoc/components/MenuHighlight */ \\\"./default/assets/js/src/typedoc/components/MenuHighlight.ts\\\");\\n/* harmony import */ var _typedoc_components_Search__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./typedoc/components/Search */ \\\"./default/assets/js/src/typedoc/components/Search.ts\\\");\\n/* harmony import */ var _typedoc_components_Signature__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./typedoc/components/Signature */ \\\"./default/assets/js/src/typedoc/components/Signature.ts\\\");\\n/* harmony import */ var _typedoc_components_Toggle__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./typedoc/components/Toggle */ \\\"./default/assets/js/src/typedoc/components/Toggle.ts\\\");\\n/* harmony import */ var _typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./typedoc/components/Filter */ \\\"./default/assets/js/src/typedoc/components/Filter.ts\\\");\\n/* harmony import */ var _css_main_sass__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../css/main.sass */ \\\"./default/assets/css/main.sass\\\");\\n\\n\\n\\n\\n\\n\\n\\n(0,_typedoc_components_Search__WEBPACK_IMPORTED_MODULE_2__.initSearch)();\\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_MenuHighlight__WEBPACK_IMPORTED_MODULE_1__.MenuHighlight, \\\".menu-highlight\\\");\\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_Signature__WEBPACK_IMPORTED_MODULE_3__.Signature, \\\".tsd-signatures\\\");\\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_Toggle__WEBPACK_IMPORTED_MODULE_4__.Toggle, \\\"a[data-toggle]\\\");\\nif (_typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_5__.Filter.isSupported()) {\\n    (0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_5__.Filter, \\\"#tsd-filter\\\");\\n}\\nelse {\\n    document.documentElement.classList.add(\\\"no-filter\\\");\\n}\\nvar app = new _typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.Application();\\nObject.defineProperty(window, \\\"app\\\", { value: app });\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/bootstrap.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/Application.ts\":\n/*!******************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/Application.ts ***!\n  \\******************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"registerComponent\\\": () => /* binding */ registerComponent,\\n/* harmony export */   \\\"Application\\\": () => /* binding */ Application\\n/* harmony export */ });\\n/**\\n * List of all known components.\\n */\\nvar components = [];\\n/**\\n * Register a new component.\\n */\\nfunction registerComponent(constructor, selector) {\\n    components.push({\\n        selector: selector,\\n        constructor: constructor,\\n    });\\n}\\n/**\\n * TypeDoc application class.\\n */\\nvar Application = /** @class */ (function () {\\n    /**\\n     * Create a new Application instance.\\n     */\\n    function Application() {\\n        this.createComponents(document.body);\\n    }\\n    /**\\n     * Create all components beneath the given jQuery element.\\n     */\\n    Application.prototype.createComponents = function (context) {\\n        components.forEach(function (c) {\\n            context.querySelectorAll(c.selector).forEach(function (el) {\\n                if (!el.dataset.hasInstance) {\\n                    new c.constructor({ el: el });\\n                    el.dataset.hasInstance = String(true);\\n                }\\n            });\\n        });\\n    };\\n    return Application;\\n}());\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/Application.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/Component.ts\":\n/*!****************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/Component.ts ***!\n  \\****************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"Component\\\": () => /* binding */ Component\\n/* harmony export */ });\\n/**\\n * TypeDoc component class.\\n */\\nvar Component = /** @class */ (function () {\\n    function Component(options) {\\n        this.el = options.el;\\n    }\\n    return Component;\\n}());\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/Component.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/EventTarget.ts\":\n/*!******************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/EventTarget.ts ***!\n  \\******************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"EventTarget\\\": () => /* binding */ EventTarget\\n/* harmony export */ });\\n/**\\n * TypeDoc event target class.\\n */\\nvar EventTarget = /** @class */ (function () {\\n    function EventTarget() {\\n        this.listeners = {};\\n    }\\n    EventTarget.prototype.addEventListener = function (type, callback) {\\n        if (!(type in this.listeners)) {\\n            this.listeners[type] = [];\\n        }\\n        this.listeners[type].push(callback);\\n    };\\n    EventTarget.prototype.removeEventListener = function (type, callback) {\\n        if (!(type in this.listeners)) {\\n            return;\\n        }\\n        var stack = this.listeners[type];\\n        for (var i = 0, l = stack.length; i < l; i++) {\\n            if (stack[i] === callback) {\\n                stack.splice(i, 1);\\n                return;\\n            }\\n        }\\n    };\\n    EventTarget.prototype.dispatchEvent = function (event) {\\n        if (!(event.type in this.listeners)) {\\n            return true;\\n        }\\n        var stack = this.listeners[event.type].slice();\\n        for (var i = 0, l = stack.length; i < l; i++) {\\n            stack[i].call(this, event);\\n        }\\n        return !event.defaultPrevented;\\n    };\\n    return EventTarget;\\n}());\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/EventTarget.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/components/Filter.ts\":\n/*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Filter.ts ***!\n  \\************************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"Filter\\\": () => /* binding */ Filter\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \\\"./default/assets/js/src/typedoc/Component.ts\\\");\\n/* harmony import */ var _utils_pointer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/pointer */ \\\"./default/assets/js/src/typedoc/utils/pointer.ts\\\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\nvar FilterItem = /** @class */ (function () {\\n    function FilterItem(key, value) {\\n        this.key = key;\\n        this.value = value;\\n        this.defaultValue = value;\\n        this.initialize();\\n        if (window.localStorage[this.key]) {\\n            this.setValue(this.fromLocalStorage(window.localStorage[this.key]));\\n        }\\n    }\\n    FilterItem.prototype.initialize = function () { };\\n    FilterItem.prototype.setValue = function (value) {\\n        if (this.value == value)\\n            return;\\n        var oldValue = this.value;\\n        this.value = value;\\n        window.localStorage[this.key] = this.toLocalStorage(value);\\n        this.handleValueChange(oldValue, value);\\n    };\\n    return FilterItem;\\n}());\\nvar FilterItemCheckbox = /** @class */ (function (_super) {\\n    __extends(FilterItemCheckbox, _super);\\n    function FilterItemCheckbox() {\\n        return _super !== null && _super.apply(this, arguments) || this;\\n    }\\n    FilterItemCheckbox.prototype.initialize = function () {\\n        var _this = this;\\n        var checkbox = document.querySelector(\\\"#tsd-filter-\\\" + this.key);\\n        if (!checkbox)\\n            return;\\n        this.checkbox = checkbox;\\n        this.checkbox.addEventListener(\\\"change\\\", function () {\\n            _this.setValue(_this.checkbox.checked);\\n        });\\n    };\\n    FilterItemCheckbox.prototype.handleValueChange = function (oldValue, newValue) {\\n        if (!this.checkbox)\\n            return;\\n        this.checkbox.checked = this.value;\\n        document.documentElement.classList.toggle(\\\"toggle-\\\" + this.key, this.value != this.defaultValue);\\n    };\\n    FilterItemCheckbox.prototype.fromLocalStorage = function (value) {\\n        return value == \\\"true\\\";\\n    };\\n    FilterItemCheckbox.prototype.toLocalStorage = function (value) {\\n        return value ? \\\"true\\\" : \\\"false\\\";\\n    };\\n    return FilterItemCheckbox;\\n}(FilterItem));\\nvar FilterItemSelect = /** @class */ (function (_super) {\\n    __extends(FilterItemSelect, _super);\\n    function FilterItemSelect() {\\n        return _super !== null && _super.apply(this, arguments) || this;\\n    }\\n    FilterItemSelect.prototype.initialize = function () {\\n        var _this = this;\\n        document.documentElement.classList.add(\\\"toggle-\\\" + this.key + this.value);\\n        var select = document.querySelector(\\\"#tsd-filter-\\\" + this.key);\\n        if (!select)\\n            return;\\n        this.select = select;\\n        var onActivate = function () {\\n            _this.select.classList.add(\\\"active\\\");\\n        };\\n        var onDeactivate = function () {\\n            _this.select.classList.remove(\\\"active\\\");\\n        };\\n        this.select.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, onActivate);\\n        this.select.addEventListener(\\\"mouseover\\\", onActivate);\\n        this.select.addEventListener(\\\"mouseleave\\\", onDeactivate);\\n        this.select.querySelectorAll(\\\"li\\\").forEach(function (el) {\\n            el.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, function (e) {\\n                select.classList.remove(\\\"active\\\");\\n                _this.setValue(e.target.dataset.value || \\\"\\\");\\n            });\\n        });\\n        document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, function (e) {\\n            if (_this.select.contains(e.target))\\n                return;\\n            _this.select.classList.remove(\\\"active\\\");\\n        });\\n    };\\n    FilterItemSelect.prototype.handleValueChange = function (oldValue, newValue) {\\n        this.select.querySelectorAll(\\\"li.selected\\\").forEach(function (el) {\\n            el.classList.remove(\\\"selected\\\");\\n        });\\n        var selected = this.select.querySelector('li[data-value=\\\"' + newValue + '\\\"]');\\n        var label = this.select.querySelector(\\\".tsd-select-label\\\");\\n        if (selected && label) {\\n            selected.classList.add(\\\"selected\\\");\\n            label.textContent = selected.textContent;\\n        }\\n        document.documentElement.classList.remove(\\\"toggle-\\\" + oldValue);\\n        document.documentElement.classList.add(\\\"toggle-\\\" + newValue);\\n    };\\n    FilterItemSelect.prototype.fromLocalStorage = function (value) {\\n        return value;\\n    };\\n    FilterItemSelect.prototype.toLocalStorage = function (value) {\\n        return value;\\n    };\\n    return FilterItemSelect;\\n}(FilterItem));\\nvar Filter = /** @class */ (function (_super) {\\n    __extends(Filter, _super);\\n    function Filter(options) {\\n        var _this = _super.call(this, options) || this;\\n        _this.optionVisibility = new FilterItemSelect(\\\"visibility\\\", \\\"private\\\");\\n        _this.optionInherited = new FilterItemCheckbox(\\\"inherited\\\", true);\\n        _this.optionExternals = new FilterItemCheckbox(\\\"externals\\\", true);\\n        return _this;\\n    }\\n    Filter.isSupported = function () {\\n        try {\\n            return typeof window.localStorage != \\\"undefined\\\";\\n        }\\n        catch (e) {\\n            return false;\\n        }\\n    };\\n    return Filter;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Filter.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/components/MenuHighlight.ts\":\n/*!*******************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/MenuHighlight.ts ***!\n  \\*******************************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"MenuHighlight\\\": () => /* binding */ MenuHighlight\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \\\"./default/assets/js/src/typedoc/Component.ts\\\");\\n/* harmony import */ var _services_Viewport__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../services/Viewport */ \\\"./default/assets/js/src/typedoc/services/Viewport.ts\\\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\n/**\\n * Manages the sticky state of the navigation and moves the highlight\\n * to the current navigation item.\\n */\\nvar MenuHighlight = /** @class */ (function (_super) {\\n    __extends(MenuHighlight, _super);\\n    /**\\n     * Create a new MenuHighlight instance.\\n     *\\n     * @param options  Backbone view constructor options.\\n     */\\n    function MenuHighlight(options) {\\n        var _this = _super.call(this, options) || this;\\n        /**\\n         * List of all discovered anchors.\\n         */\\n        _this.anchors = [];\\n        /**\\n         * Index of the currently highlighted anchor.\\n         */\\n        _this.index = -1;\\n        _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.addEventListener(\\\"resize\\\", function () { return _this.onResize(); });\\n        _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.addEventListener(\\\"scroll\\\", function (e) { return _this.onScroll(e); });\\n        _this.createAnchors();\\n        return _this;\\n    }\\n    /**\\n     * Find all anchors on the current page.\\n     */\\n    MenuHighlight.prototype.createAnchors = function () {\\n        var _this = this;\\n        var base = window.location.href;\\n        if (base.indexOf(\\\"#\\\") != -1) {\\n            base = base.substr(0, base.indexOf(\\\"#\\\"));\\n        }\\n        this.el.querySelectorAll(\\\"a\\\").forEach(function (el) {\\n            var href = el.href;\\n            if (href.indexOf(\\\"#\\\") == -1)\\n                return;\\n            if (href.substr(0, base.length) != base)\\n                return;\\n            var hash = href.substr(href.indexOf(\\\"#\\\") + 1);\\n            var anchor = document.querySelector(\\\"a.tsd-anchor[name=\\\" + hash + \\\"]\\\");\\n            var link = el.parentNode;\\n            if (!anchor || !link)\\n                return;\\n            _this.anchors.push({\\n                link: link,\\n                anchor: anchor,\\n                position: 0,\\n            });\\n        });\\n        this.onResize();\\n    };\\n    /**\\n     * Triggered after the viewport was resized.\\n     */\\n    MenuHighlight.prototype.onResize = function () {\\n        var anchor;\\n        for (var index = 0, count = this.anchors.length; index < count; index++) {\\n            anchor = this.anchors[index];\\n            var rect = anchor.anchor.getBoundingClientRect();\\n            anchor.position = rect.top + document.body.scrollTop;\\n        }\\n        this.anchors.sort(function (a, b) {\\n            return a.position - b.position;\\n        });\\n        var event = new CustomEvent(\\\"scroll\\\", {\\n            detail: {\\n                scrollTop: _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.scrollTop,\\n            },\\n        });\\n        this.onScroll(event);\\n    };\\n    /**\\n     * Triggered after the viewport was scrolled.\\n     *\\n     * @param event  The custom event with the current vertical scroll position.\\n     */\\n    MenuHighlight.prototype.onScroll = function (event) {\\n        var scrollTop = event.detail.scrollTop + 5;\\n        var anchors = this.anchors;\\n        var count = anchors.length - 1;\\n        var index = this.index;\\n        while (index > -1 && anchors[index].position > scrollTop) {\\n            index -= 1;\\n        }\\n        while (index < count && anchors[index + 1].position < scrollTop) {\\n            index += 1;\\n        }\\n        if (this.index != index) {\\n            if (this.index > -1)\\n                this.anchors[this.index].link.classList.remove(\\\"focus\\\");\\n            this.index = index;\\n            if (this.index > -1)\\n                this.anchors[this.index].link.classList.add(\\\"focus\\\");\\n        }\\n    };\\n    return MenuHighlight;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/MenuHighlight.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/components/Search.ts\":\n/*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Search.ts ***!\n  \\************************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"initSearch\\\": () => /* binding */ initSearch\\n/* harmony export */ });\\n/* harmony import */ var _utils_debounce__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/debounce */ \\\"./default/assets/js/src/typedoc/utils/debounce.ts\\\");\\n/* harmony import */ var lunr__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! lunr */ \\\"../node_modules/lunr/lunr.js\\\");\\n/* harmony import */ var lunr__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(lunr__WEBPACK_IMPORTED_MODULE_1__);\\n\\n\\nfunction initSearch() {\\n    var searchEl = document.getElementById(\\\"tsd-search\\\");\\n    if (!searchEl)\\n        return;\\n    var searchScript = document.getElementById(\\\"search-script\\\");\\n    searchEl.classList.add(\\\"loading\\\");\\n    if (searchScript) {\\n        searchScript.addEventListener(\\\"error\\\", function () {\\n            searchEl.classList.remove(\\\"loading\\\");\\n            searchEl.classList.add(\\\"failure\\\");\\n        });\\n        searchScript.addEventListener(\\\"load\\\", function () {\\n            searchEl.classList.remove(\\\"loading\\\");\\n            searchEl.classList.add(\\\"ready\\\");\\n        });\\n        if (window.searchData) {\\n            searchEl.classList.remove(\\\"loading\\\");\\n        }\\n    }\\n    var field = document.querySelector(\\\"#tsd-search-field\\\");\\n    var results = document.querySelector(\\\".results\\\");\\n    if (!field || !results) {\\n        throw new Error(\\\"The input field or the result list wrapper was not found\\\");\\n    }\\n    var resultClicked = false;\\n    results.addEventListener(\\\"mousedown\\\", function () { return (resultClicked = true); });\\n    results.addEventListener(\\\"mouseup\\\", function () {\\n        resultClicked = false;\\n        searchEl.classList.remove(\\\"has-focus\\\");\\n    });\\n    field.addEventListener(\\\"focus\\\", function () { return searchEl.classList.add(\\\"has-focus\\\"); });\\n    field.addEventListener(\\\"blur\\\", function () {\\n        if (!resultClicked) {\\n            resultClicked = false;\\n            searchEl.classList.remove(\\\"has-focus\\\");\\n        }\\n    });\\n    var state = {\\n        base: searchEl.dataset.base + \\\"/\\\",\\n    };\\n    bindEvents(searchEl, results, field, state);\\n}\\nfunction bindEvents(searchEl, results, field, state) {\\n    field.addEventListener(\\\"input\\\", (0,_utils_debounce__WEBPACK_IMPORTED_MODULE_0__.debounce)(function () {\\n        updateResults(searchEl, results, field, state);\\n    }, 200));\\n    var preventPress = false;\\n    field.addEventListener(\\\"keydown\\\", function (e) {\\n        preventPress = true;\\n        if (e.key == \\\"Enter\\\") {\\n            gotoCurrentResult(results, field);\\n        }\\n        else if (e.key == \\\"Escape\\\") {\\n            field.blur();\\n        }\\n        else if (e.key == \\\"ArrowUp\\\") {\\n            setCurrentResult(results, -1);\\n        }\\n        else if (e.key === \\\"ArrowDown\\\") {\\n            setCurrentResult(results, 1);\\n        }\\n        else {\\n            preventPress = false;\\n        }\\n    });\\n    field.addEventListener(\\\"keypress\\\", function (e) {\\n        if (preventPress)\\n            e.preventDefault();\\n    });\\n    /**\\n     * Start searching by pressing slash.\\n     */\\n    document.body.addEventListener(\\\"keydown\\\", function (e) {\\n        if (e.altKey || e.ctrlKey || e.metaKey)\\n            return;\\n        if (!field.matches(\\\":focus\\\") && e.key === \\\"/\\\") {\\n            field.focus();\\n            e.preventDefault();\\n        }\\n    });\\n}\\nfunction checkIndex(state, searchEl) {\\n    if (state.index)\\n        return;\\n    if (window.searchData) {\\n        searchEl.classList.remove(\\\"loading\\\");\\n        searchEl.classList.add(\\\"ready\\\");\\n        state.data = window.searchData;\\n        state.index = lunr__WEBPACK_IMPORTED_MODULE_1__.Index.load(window.searchData.index);\\n    }\\n}\\nfunction updateResults(searchEl, results, query, state) {\\n    checkIndex(state, searchEl);\\n    // Don't clear results if loading state is not ready,\\n    // because loading or error message can be removed.\\n    if (!state.index || !state.data)\\n        return;\\n    results.textContent = \\\"\\\";\\n    var searchText = query.value.trim();\\n    // Perform a wildcard search\\n    var res = state.index.search(\\\"*\\\" + searchText + \\\"*\\\");\\n    for (var i = 0, c = Math.min(10, res.length); i < c; i++) {\\n        var row = state.data.rows[Number(res[i].ref)];\\n        // Bold the matched part of the query in the search results\\n        var name_1 = boldMatches(row.name, searchText);\\n        if (row.parent) {\\n            name_1 = \\\"<span class=\\\\\\\"parent\\\\\\\">\\\" + boldMatches(row.parent, searchText) + \\\".</span>\\\" + name_1;\\n        }\\n        var item = document.createElement(\\\"li\\\");\\n        item.classList.value = row.classes;\\n        var anchor = document.createElement(\\\"a\\\");\\n        anchor.href = state.base + row.url;\\n        anchor.classList.add(\\\"tsd-kind-icon\\\");\\n        anchor.innerHTML = name_1;\\n        item.append(anchor);\\n        results.appendChild(item);\\n    }\\n}\\n/**\\n * Move the highlight within the result set.\\n */\\nfunction setCurrentResult(results, dir) {\\n    var current = results.querySelector(\\\".current\\\");\\n    if (!current) {\\n        current = results.querySelector(dir == 1 ? \\\"li:first-child\\\" : \\\"li:last-child\\\");\\n        if (current) {\\n            current.classList.add(\\\"current\\\");\\n        }\\n    }\\n    else {\\n        var rel = dir == 1\\n            ? current.nextElementSibling\\n            : current.previousElementSibling;\\n        if (rel) {\\n            current.classList.remove(\\\"current\\\");\\n            rel.classList.add(\\\"current\\\");\\n        }\\n    }\\n}\\n/**\\n * Navigate to the highlighted result.\\n */\\nfunction gotoCurrentResult(results, field) {\\n    var current = results.querySelector(\\\".current\\\");\\n    if (!current) {\\n        current = results.querySelector(\\\"li:first-child\\\");\\n    }\\n    if (current) {\\n        var link = current.querySelector(\\\"a\\\");\\n        if (link) {\\n            window.location.href = link.href;\\n        }\\n        field.blur();\\n    }\\n}\\nfunction boldMatches(text, search) {\\n    if (search === \\\"\\\") {\\n        return text;\\n    }\\n    var lowerText = text.toLocaleLowerCase();\\n    var lowerSearch = search.toLocaleLowerCase();\\n    var parts = [];\\n    var lastIndex = 0;\\n    var index = lowerText.indexOf(lowerSearch);\\n    while (index != -1) {\\n        parts.push(escapeHtml(text.substring(lastIndex, index)), \\\"<b>\\\" + escapeHtml(text.substring(index, index + lowerSearch.length)) + \\\"</b>\\\");\\n        lastIndex = index + lowerSearch.length;\\n        index = lowerText.indexOf(lowerSearch, lastIndex);\\n    }\\n    parts.push(escapeHtml(text.substring(lastIndex)));\\n    return parts.join(\\\"\\\");\\n}\\nvar SPECIAL_HTML = {\\n    \\\"&\\\": \\\"&amp;\\\",\\n    \\\"<\\\": \\\"&lt;\\\",\\n    \\\">\\\": \\\"&gt;\\\",\\n    \\\"'\\\": \\\"&#039;\\\",\\n    '\\\"': \\\"&quot;\\\",\\n};\\nfunction escapeHtml(text) {\\n    return text.replace(/[&<>\\\"'\\\"]/g, function (match) { return SPECIAL_HTML[match]; });\\n}\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Search.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/components/Signature.ts\":\n/*!***************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Signature.ts ***!\n  \\***************************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"Signature\\\": () => /* binding */ Signature\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \\\"./default/assets/js/src/typedoc/Component.ts\\\");\\n/* harmony import */ var _services_Viewport__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../services/Viewport */ \\\"./default/assets/js/src/typedoc/services/Viewport.ts\\\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\n/**\\n * Holds a signature and its description.\\n */\\nvar SignatureGroup = /** @class */ (function () {\\n    /**\\n     * Create a new SignatureGroup instance.\\n     *\\n     * @param signature    The target signature.\\n     * @param description  The description for the signature.\\n     */\\n    function SignatureGroup(signature, description) {\\n        this.signature = signature;\\n        this.description = description;\\n    }\\n    /**\\n     * Add the given class to all elements of the group.\\n     *\\n     * @param className  The class name to add.\\n     */\\n    SignatureGroup.prototype.addClass = function (className) {\\n        this.signature.classList.add(className);\\n        this.description.classList.add(className);\\n        return this;\\n    };\\n    /**\\n     * Remove the given class from all elements of the group.\\n     *\\n     * @param className  The class name to remove.\\n     */\\n    SignatureGroup.prototype.removeClass = function (className) {\\n        this.signature.classList.remove(className);\\n        this.description.classList.remove(className);\\n        return this;\\n    };\\n    return SignatureGroup;\\n}());\\n/**\\n * Controls the tab like behaviour of methods and functions with multiple signatures.\\n */\\nvar Signature = /** @class */ (function (_super) {\\n    __extends(Signature, _super);\\n    /**\\n     * Create a new Signature instance.\\n     *\\n     * @param options  Backbone view constructor options.\\n     */\\n    function Signature(options) {\\n        var _this = _super.call(this, options) || this;\\n        /**\\n         * List of found signature groups.\\n         */\\n        _this.groups = [];\\n        /**\\n         * The index of the currently displayed signature.\\n         */\\n        _this.index = -1;\\n        _this.createGroups();\\n        if (_this.container) {\\n            _this.el.classList.add(\\\"active\\\");\\n            Array.from(_this.el.children).forEach(function (signature) {\\n                signature.addEventListener(\\\"touchstart\\\", function (event) {\\n                    return _this.onClick(event);\\n                });\\n                signature.addEventListener(\\\"click\\\", function (event) {\\n                    return _this.onClick(event);\\n                });\\n            });\\n            _this.container.classList.add(\\\"active\\\");\\n            _this.setIndex(0);\\n        }\\n        return _this;\\n    }\\n    /**\\n     * Set the index of the active signature.\\n     *\\n     * @param index  The index of the signature to activate.\\n     */\\n    Signature.prototype.setIndex = function (index) {\\n        if (index < 0)\\n            index = 0;\\n        if (index > this.groups.length - 1)\\n            index = this.groups.length - 1;\\n        if (this.index == index)\\n            return;\\n        var to = this.groups[index];\\n        if (this.index > -1) {\\n            var from_1 = this.groups[this.index];\\n            from_1.removeClass(\\\"current\\\").addClass(\\\"fade-out\\\");\\n            to.addClass(\\\"current\\\");\\n            to.addClass(\\\"fade-in\\\");\\n            _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.triggerResize();\\n            setTimeout(function () {\\n                from_1.removeClass(\\\"fade-out\\\");\\n                to.removeClass(\\\"fade-in\\\");\\n            }, 300);\\n        }\\n        else {\\n            to.addClass(\\\"current\\\");\\n            _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.triggerResize();\\n        }\\n        this.index = index;\\n    };\\n    /**\\n     * Find all signature/description groups.\\n     */\\n    Signature.prototype.createGroups = function () {\\n        var signatures = this.el.children;\\n        if (signatures.length < 2)\\n            return;\\n        this.container = this.el.nextElementSibling;\\n        var descriptions = this.container.children;\\n        this.groups = [];\\n        for (var index = 0; index < signatures.length; index++) {\\n            this.groups.push(new SignatureGroup(signatures[index], descriptions[index]));\\n        }\\n    };\\n    /**\\n     * Triggered when the user clicks onto a signature header.\\n     *\\n     * @param e  The related event object.\\n     */\\n    Signature.prototype.onClick = function (e) {\\n        var _this = this;\\n        this.groups.forEach(function (group, index) {\\n            if (group.signature === e.currentTarget) {\\n                _this.setIndex(index);\\n            }\\n        });\\n    };\\n    return Signature;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Signature.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/components/Toggle.ts\":\n/*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Toggle.ts ***!\n  \\************************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"Toggle\\\": () => /* binding */ Toggle\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \\\"./default/assets/js/src/typedoc/Component.ts\\\");\\n/* harmony import */ var _utils_pointer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/pointer */ \\\"./default/assets/js/src/typedoc/utils/pointer.ts\\\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\nvar Toggle = /** @class */ (function (_super) {\\n    __extends(Toggle, _super);\\n    function Toggle(options) {\\n        var _this = _super.call(this, options) || this;\\n        _this.className = _this.el.dataset.toggle || \\\"\\\";\\n        _this.el.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, function (e) { return _this.onPointerUp(e); });\\n        _this.el.addEventListener(\\\"click\\\", function (e) { return e.preventDefault(); });\\n        document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, function (e) {\\n            return _this.onDocumentPointerDown(e);\\n        });\\n        document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, function (e) {\\n            return _this.onDocumentPointerUp(e);\\n        });\\n        return _this;\\n    }\\n    Toggle.prototype.setActive = function (value) {\\n        if (this.active == value)\\n            return;\\n        this.active = value;\\n        document.documentElement.classList.toggle(\\\"has-\\\" + this.className, value);\\n        this.el.classList.toggle(\\\"active\\\", value);\\n        var transition = (this.active ? \\\"to-has-\\\" : \\\"from-has-\\\") + this.className;\\n        document.documentElement.classList.add(transition);\\n        setTimeout(function () { return document.documentElement.classList.remove(transition); }, 500);\\n    };\\n    Toggle.prototype.onPointerUp = function (event) {\\n        if (_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.hasPointerMoved)\\n            return;\\n        this.setActive(true);\\n        event.preventDefault();\\n    };\\n    Toggle.prototype.onDocumentPointerDown = function (e) {\\n        if (this.active) {\\n            if (e.target.closest(\\\".col-menu, .tsd-filter-group\\\")) {\\n                return;\\n            }\\n            this.setActive(false);\\n        }\\n    };\\n    Toggle.prototype.onDocumentPointerUp = function (e) {\\n        var _this = this;\\n        if (_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.hasPointerMoved)\\n            return;\\n        if (this.active) {\\n            if (e.target.closest(\\\".col-menu\\\")) {\\n                var link = e.target.closest(\\\"a\\\");\\n                if (link) {\\n                    var href = window.location.href;\\n                    if (href.indexOf(\\\"#\\\") != -1) {\\n                        href = href.substr(0, href.indexOf(\\\"#\\\"));\\n                    }\\n                    if (link.href.substr(0, href.length) == href) {\\n                        setTimeout(function () { return _this.setActive(false); }, 250);\\n                    }\\n                }\\n            }\\n        }\\n    };\\n    return Toggle;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Toggle.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/services/Viewport.ts\":\n/*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/services/Viewport.ts ***!\n  \\************************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"Viewport\\\": () => /* binding */ Viewport\\n/* harmony export */ });\\n/* harmony import */ var _EventTarget__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../EventTarget */ \\\"./default/assets/js/src/typedoc/EventTarget.ts\\\");\\n/* harmony import */ var _utils_trottle__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/trottle */ \\\"./default/assets/js/src/typedoc/utils/trottle.ts\\\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\n/**\\n * A global service that monitors the window size and scroll position.\\n */\\nvar Viewport = /** @class */ (function (_super) {\\n    __extends(Viewport, _super);\\n    /**\\n     * Create new Viewport instance.\\n     */\\n    function Viewport() {\\n        var _this = _super.call(this) || this;\\n        /**\\n         * The current scroll position.\\n         */\\n        _this.scrollTop = 0;\\n        /**\\n         * The previous scrollTop.\\n         */\\n        _this.lastY = 0;\\n        /**\\n         * The width of the window.\\n         */\\n        _this.width = 0;\\n        /**\\n         * The height of the window.\\n         */\\n        _this.height = 0;\\n        /**\\n         * Boolean indicating whether the toolbar is shown.\\n         */\\n        _this.showToolbar = true;\\n        _this.toolbar = (document.querySelector(\\\".tsd-page-toolbar\\\"));\\n        _this.secondaryNav = (document.querySelector(\\\".tsd-navigation.secondary\\\"));\\n        window.addEventListener(\\\"scroll\\\", (0,_utils_trottle__WEBPACK_IMPORTED_MODULE_1__.throttle)(function () { return _this.onScroll(); }, 10));\\n        window.addEventListener(\\\"resize\\\", (0,_utils_trottle__WEBPACK_IMPORTED_MODULE_1__.throttle)(function () { return _this.onResize(); }, 10));\\n        _this.onResize();\\n        _this.onScroll();\\n        return _this;\\n    }\\n    /**\\n     * Trigger a resize event.\\n     */\\n    Viewport.prototype.triggerResize = function () {\\n        var event = new CustomEvent(\\\"resize\\\", {\\n            detail: {\\n                width: this.width,\\n                height: this.height,\\n            },\\n        });\\n        this.dispatchEvent(event);\\n    };\\n    /**\\n     * Triggered when the size of the window has changed.\\n     */\\n    Viewport.prototype.onResize = function () {\\n        this.width = window.innerWidth || 0;\\n        this.height = window.innerHeight || 0;\\n        var event = new CustomEvent(\\\"resize\\\", {\\n            detail: {\\n                width: this.width,\\n                height: this.height,\\n            },\\n        });\\n        this.dispatchEvent(event);\\n    };\\n    /**\\n     * Triggered when the user scrolled the viewport.\\n     */\\n    Viewport.prototype.onScroll = function () {\\n        this.scrollTop = window.scrollY || 0;\\n        var event = new CustomEvent(\\\"scroll\\\", {\\n            detail: {\\n                scrollTop: this.scrollTop,\\n            },\\n        });\\n        this.dispatchEvent(event);\\n        this.hideShowToolbar();\\n    };\\n    /**\\n     * Handle hiding/showing of the toolbar.\\n     */\\n    Viewport.prototype.hideShowToolbar = function () {\\n        var isShown = this.showToolbar;\\n        this.showToolbar = this.lastY >= this.scrollTop || this.scrollTop <= 0;\\n        if (isShown !== this.showToolbar) {\\n            this.toolbar.classList.toggle(\\\"tsd-page-toolbar--hide\\\");\\n            this.secondaryNav.classList.toggle(\\\"tsd-navigation--toolbar-hide\\\");\\n        }\\n        this.lastY = this.scrollTop;\\n    };\\n    Viewport.instance = new Viewport();\\n    return Viewport;\\n}(_EventTarget__WEBPACK_IMPORTED_MODULE_0__.EventTarget));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/services/Viewport.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/utils/debounce.ts\":\n/*!*********************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/utils/debounce.ts ***!\n  \\*********************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"debounce\\\": () => /* binding */ debounce\\n/* harmony export */ });\\nvar debounce = function (fn, wait) {\\n    if (wait === void 0) { wait = 100; }\\n    var timeout;\\n    return function () {\\n        var args = [];\\n        for (var _i = 0; _i < arguments.length; _i++) {\\n            args[_i] = arguments[_i];\\n        }\\n        clearTimeout(timeout);\\n        timeout = setTimeout(function () { return fn(args); }, wait);\\n    };\\n};\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/debounce.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/utils/pointer.ts\":\n/*!********************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/utils/pointer.ts ***!\n  \\********************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"pointerDown\\\": () => /* binding */ pointerDown,\\n/* harmony export */   \\\"pointerMove\\\": () => /* binding */ pointerMove,\\n/* harmony export */   \\\"pointerUp\\\": () => /* binding */ pointerUp,\\n/* harmony export */   \\\"pointerDownPosition\\\": () => /* binding */ pointerDownPosition,\\n/* harmony export */   \\\"preventNextClick\\\": () => /* binding */ preventNextClick,\\n/* harmony export */   \\\"isPointerDown\\\": () => /* binding */ isPointerDown,\\n/* harmony export */   \\\"isPointerTouch\\\": () => /* binding */ isPointerTouch,\\n/* harmony export */   \\\"hasPointerMoved\\\": () => /* binding */ hasPointerMoved,\\n/* harmony export */   \\\"isMobile\\\": () => /* binding */ isMobile\\n/* harmony export */ });\\n/**\\n * Event name of the pointer down event.\\n */\\nvar pointerDown = \\\"mousedown\\\";\\n/**\\n * Event name of the pointer move event.\\n */\\nvar pointerMove = \\\"mousemove\\\";\\n/**\\n * Event name of the pointer up event.\\n */\\nvar pointerUp = \\\"mouseup\\\";\\n/**\\n * Position the pointer was pressed at.\\n */\\nvar pointerDownPosition = { x: 0, y: 0 };\\n/**\\n * Should the next click on the document be supressed?\\n */\\nvar preventNextClick = false;\\n/**\\n * Is the pointer down?\\n */\\nvar isPointerDown = false;\\n/**\\n * Is the pointer a touch point?\\n */\\nvar isPointerTouch = false;\\n/**\\n * Did the pointer move since the last down event?\\n */\\nvar hasPointerMoved = false;\\n/**\\n * Is the user agent a mobile agent?\\n */\\nvar isMobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);\\ndocument.documentElement.classList.add(isMobile ? \\\"is-mobile\\\" : \\\"not-mobile\\\");\\nif (isMobile && \\\"ontouchstart\\\" in document.documentElement) {\\n    isPointerTouch = true;\\n    pointerDown = \\\"touchstart\\\";\\n    pointerMove = \\\"touchmove\\\";\\n    pointerUp = \\\"touchend\\\";\\n}\\ndocument.addEventListener(pointerDown, function (e) {\\n    isPointerDown = true;\\n    hasPointerMoved = false;\\n    var t = pointerDown == \\\"touchstart\\\"\\n        ? e.targetTouches[0]\\n        : e;\\n    pointerDownPosition.y = t.pageY || 0;\\n    pointerDownPosition.x = t.pageX || 0;\\n});\\ndocument.addEventListener(pointerMove, function (e) {\\n    if (!isPointerDown)\\n        return;\\n    if (!hasPointerMoved) {\\n        var t = pointerDown == \\\"touchstart\\\"\\n            ? e.targetTouches[0]\\n            : e;\\n        var x = pointerDownPosition.x - (t.pageX || 0);\\n        var y = pointerDownPosition.y - (t.pageY || 0);\\n        hasPointerMoved = Math.sqrt(x * x + y * y) > 10;\\n    }\\n});\\ndocument.addEventListener(pointerUp, function () {\\n    isPointerDown = false;\\n});\\ndocument.addEventListener(\\\"click\\\", function (e) {\\n    if (preventNextClick) {\\n        e.preventDefault();\\n        e.stopImmediatePropagation();\\n        preventNextClick = false;\\n    }\\n});\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/pointer.ts?\");\n\n/***/ }),\n\n/***/ \"./default/assets/js/src/typedoc/utils/trottle.ts\":\n/*!********************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/utils/trottle.ts ***!\n  \\********************************************************/\n/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {\n\n\"use strict\";\neval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \\\"throttle\\\": () => /* binding */ throttle\\n/* harmony export */ });\\nvar throttle = function (fn, wait) {\\n    if (wait === void 0) { wait = 100; }\\n    var time = Date.now();\\n    return function () {\\n        var args = [];\\n        for (var _i = 0; _i < arguments.length; _i++) {\\n            args[_i] = arguments[_i];\\n        }\\n        if (time + wait - Date.now() < 0) {\\n            fn.apply(void 0, args);\\n            time = Date.now();\\n        }\\n    };\\n};\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/trottle.ts?\");\n\n/***/ })\n\n/******/ \t});\n/************************************************************************/\n/******/ \t// The module cache\n/******/ \tvar __webpack_module_cache__ = {};\n/******/ \t\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(__webpack_module_cache__[moduleId]) {\n/******/ \t\t\treturn __webpack_module_cache__[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = __webpack_module_cache__[moduleId] = {\n/******/ \t\t\t// no module.id needed\n/******/ \t\t\t// no module.loaded needed\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/ \t\n/******/ \t\t// Execute the module function\n/******/ \t\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n/******/ \t\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/ \t\n/************************************************************************/\n/******/ \t/* webpack/runtime/compat get default export */\n/******/ \t(() => {\n/******/ \t\t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t\t__webpack_require__.n = (module) => {\n/******/ \t\t\tvar getter = module && module.__esModule ?\n/******/ \t\t\t\t() => module['default'] :\n/******/ \t\t\t\t() => module;\n/******/ \t\t\t__webpack_require__.d(getter, { a: getter });\n/******/ \t\t\treturn getter;\n/******/ \t\t};\n/******/ \t})();\n/******/ \t\n/******/ \t/* webpack/runtime/define property getters */\n/******/ \t(() => {\n/******/ \t\t// define getter functions for harmony exports\n/******/ \t\t__webpack_require__.d = (exports, definition) => {\n/******/ \t\t\tfor(var key in definition) {\n/******/ \t\t\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n/******/ \t\t\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n/******/ \t\t\t\t}\n/******/ \t\t\t}\n/******/ \t\t};\n/******/ \t})();\n/******/ \t\n/******/ \t/* webpack/runtime/hasOwnProperty shorthand */\n/******/ \t(() => {\n/******/ \t\t__webpack_require__.o = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop)\n/******/ \t})();\n/******/ \t\n/******/ \t/* webpack/runtime/make namespace object */\n/******/ \t(() => {\n/******/ \t\t// define __esModule on exports\n/******/ \t\t__webpack_require__.r = (exports) => {\n/******/ \t\t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t\t}\n/******/ \t\t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t\t};\n/******/ \t})();\n/******/ \t\n/************************************************************************/\n/******/ \t// startup\n/******/ \t// Load entry module\n/******/ \t__webpack_require__(\"./default/assets/js/src/bootstrap.ts\");\n/******/ \t// This entry module used 'exports' so it can't be inlined\n/******/ })()\n;"
  },
  {
    "path": "typedocs/assets/js/search.js",
    "content": "window.searchData = {\n  kinds: {\n    64: 'Function',\n    1024: 'Property',\n    65536: 'Type literal',\n    4194304: 'Type alias',\n  },\n  rows: [\n    {\n      id: 0,\n      kind: 64,\n      name: 'Chart',\n      url: 'modules.html#chart',\n      classes: 'tsd-kind-function tsd-has-type-parameter',\n    },\n    {\n      id: 1,\n      kind: 4194304,\n      name: 'ChartOptions',\n      url: 'modules.html#chartoptions',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 2,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartoptions.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'ChartOptions',\n    },\n    {\n      id: 3,\n      kind: 1024,\n      name: 'data',\n      url: 'modules.html#chartoptions.__type.data',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 4,\n      kind: 1024,\n      name: 'primaryAxis',\n      url: 'modules.html#chartoptions.__type.primaryaxis',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 5,\n      kind: 1024,\n      name: 'secondaryAxes',\n      url: 'modules.html#chartoptions.__type.secondaryaxes',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 6,\n      kind: 1024,\n      name: 'getSeriesStyle',\n      url: 'modules.html#chartoptions.__type.getseriesstyle',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 7,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartoptions.__type.__type-5',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 8,\n      kind: 1024,\n      name: 'getDatumStyle',\n      url: 'modules.html#chartoptions.__type.getdatumstyle',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 9,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartoptions.__type.__type-3',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 10,\n      kind: 1024,\n      name: 'getSeriesOrder',\n      url: 'modules.html#chartoptions.__type.getseriesorder',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 11,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartoptions.__type.__type-4',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 12,\n      kind: 1024,\n      name: 'interactionMode',\n      url: 'modules.html#chartoptions.__type.groupingmode',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 13,\n      kind: 1024,\n      name: 'showVoronoi',\n      url: 'modules.html#chartoptions.__type.showvoronoi',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 14,\n      kind: 1024,\n      name: 'showDebugAxes',\n      url: 'modules.html#chartoptions.__type.showdebugaxes',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 15,\n      kind: 1024,\n      name: 'defaultColors',\n      url: 'modules.html#chartoptions.__type.defaultcolors',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 16,\n      kind: 1024,\n      name: 'initialWidth',\n      url: 'modules.html#chartoptions.__type.initialwidth',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 17,\n      kind: 1024,\n      name: 'initialHeight',\n      url: 'modules.html#chartoptions.__type.initialheight',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 18,\n      kind: 1024,\n      name: 'brush',\n      url: 'modules.html#chartoptions.__type.brush',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 19,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartoptions.__type.__type-1',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 20,\n      kind: 1024,\n      name: 'style',\n      url: 'modules.html#chartoptions.__type.__type-1.style',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type.__type',\n    },\n    {\n      id: 21,\n      kind: 1024,\n      name: 'onSelect',\n      url: 'modules.html#chartoptions.__type.__type-1.onselect',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type.__type',\n    },\n    {\n      id: 22,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartoptions.__type.__type-1.__type-2',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type.__type',\n    },\n    {\n      id: 23,\n      kind: 1024,\n      name: 'onFocusDatum',\n      url: 'modules.html#chartoptions.__type.onfocusdatum',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 24,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartoptions.__type.__type-7',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 25,\n      kind: 1024,\n      name: 'onClickDatum',\n      url: 'modules.html#chartoptions.__type.onclickdatum',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 26,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartoptions.__type.__type-6',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 27,\n      kind: 1024,\n      name: 'dark',\n      url: 'modules.html#chartoptions.__type.dark',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 28,\n      kind: 1024,\n      name: 'renderSVG',\n      url: 'modules.html#chartoptions.__type.rendersvg',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 29,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartoptions.__type.__type-8',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 30,\n      kind: 1024,\n      name: 'primaryCursor',\n      url: 'modules.html#chartoptions.__type.primarycursor',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 31,\n      kind: 1024,\n      name: 'secondaryCursor',\n      url: 'modules.html#chartoptions.__type.secondarycursor',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 32,\n      kind: 1024,\n      name: 'tooltip',\n      url: 'modules.html#chartoptions.__type.tooltip',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOptions.__type',\n    },\n    {\n      id: 33,\n      kind: 4194304,\n      name: 'RequiredChartOptions',\n      url: 'modules.html#requiredchartoptions',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 34,\n      kind: 4194304,\n      name: 'ChartContextValue',\n      url: 'modules.html#chartcontextvalue',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 35,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartcontextvalue.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'ChartContextValue',\n    },\n    {\n      id: 36,\n      kind: 1024,\n      name: 'getOptions',\n      url: 'modules.html#chartcontextvalue.__type.getoptions',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 37,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartcontextvalue.__type.__type-2',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 38,\n      kind: 1024,\n      name: 'gridDimensions',\n      url: 'modules.html#chartcontextvalue.__type.griddimensions',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 39,\n      kind: 1024,\n      name: 'primaryAxis',\n      url: 'modules.html#chartcontextvalue.__type.primaryaxis',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 40,\n      kind: 1024,\n      name: 'secondaryAxes',\n      url: 'modules.html#chartcontextvalue.__type.secondaryaxes',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 41,\n      kind: 1024,\n      name: 'axesInfo',\n      url: 'modules.html#chartcontextvalue.__type.axesinfo',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 42,\n      kind: 1024,\n      name: 'series',\n      url: 'modules.html#chartcontextvalue.__type.series',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 43,\n      kind: 1024,\n      name: 'orderedSeries',\n      url: 'modules.html#chartcontextvalue.__type.orderedseries',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 44,\n      kind: 1024,\n      name: 'datumsByInteractionGroup',\n      url: 'modules.html#chartcontextvalue.__type.groupeddatums',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 45,\n      kind: 1024,\n      name: 'width',\n      url: 'modules.html#chartcontextvalue.__type.width',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 46,\n      kind: 1024,\n      name: 'height',\n      url: 'modules.html#chartcontextvalue.__type.height',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 47,\n      kind: 1024,\n      name: 'svgRect',\n      url: 'modules.html#chartcontextvalue.__type.svgrect',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 48,\n      kind: 1024,\n      name: 'getSeriesStatusStyle',\n      url: 'modules.html#chartcontextvalue.__type.getseriesstatusstyle',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 49,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartcontextvalue.__type.__type-3',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 50,\n      kind: 1024,\n      name: 'getDatumStatusStyle',\n      url: 'modules.html#chartcontextvalue.__type.getdatumstatusstyle',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 51,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartcontextvalue.__type.__type-1',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 52,\n      kind: 1024,\n      name: 'useAxisDimensionsAtom',\n      url: 'modules.html#chartcontextvalue.__type.useaxisdimensionsatom',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 53,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartcontextvalue.__type.__type-4',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 54,\n      kind: 1024,\n      name: 'useFocusedDatumAtom',\n      url: 'modules.html#chartcontextvalue.__type.usefocuseddatumatom',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 55,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartcontextvalue.__type.__type-5',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'ChartContextValue.__type',\n    },\n    {\n      id: 56,\n      kind: 4194304,\n      name: 'TooltipOptions',\n      url: 'modules.html#tooltipoptions',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 57,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#tooltipoptions.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'TooltipOptions',\n    },\n    {\n      id: 58,\n      kind: 1024,\n      name: 'align',\n      url: 'modules.html#tooltipoptions.__type.align',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'TooltipOptions.__type',\n    },\n    {\n      id: 59,\n      kind: 1024,\n      name: 'alignPriority',\n      url: 'modules.html#tooltipoptions.__type.alignpriority',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'TooltipOptions.__type',\n    },\n    {\n      id: 60,\n      kind: 1024,\n      name: 'padding',\n      url: 'modules.html#tooltipoptions.__type.padding',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'TooltipOptions.__type',\n    },\n    {\n      id: 61,\n      kind: 1024,\n      name: 'tooltipArrowPadding',\n      url: 'modules.html#tooltipoptions.__type.tooltiparrowpadding',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'TooltipOptions.__type',\n    },\n    {\n      id: 62,\n      kind: 1024,\n      name: 'render',\n      url: 'modules.html#tooltipoptions.__type.render',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'TooltipOptions.__type',\n    },\n    {\n      id: 63,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#tooltipoptions.__type.__type-1',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'TooltipOptions.__type',\n    },\n    {\n      id: 64,\n      kind: 1024,\n      name: 'invert',\n      url: 'modules.html#tooltipoptions.__type.invert',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'TooltipOptions.__type',\n    },\n    {\n      id: 65,\n      kind: 4194304,\n      name: 'ResolvedTooltipOptions',\n      url: 'modules.html#resolvedtooltipoptions',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 66,\n      kind: 4194304,\n      name: 'SeriesStyles',\n      url: 'modules.html#seriesstyles',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 67,\n      kind: 4194304,\n      name: 'DatumStyles',\n      url: 'modules.html#datumstyles',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 68,\n      kind: 4194304,\n      name: 'Position',\n      url: 'modules.html#position',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 69,\n      kind: 4194304,\n      name: 'GroupingMode',\n      url: 'modules.html#groupingmode',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 70,\n      kind: 4194304,\n      name: 'AlignMode',\n      url: 'modules.html#alignmode',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 71,\n      kind: 4194304,\n      name: 'AlignPosition',\n      url: 'modules.html#alignposition',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 72,\n      kind: 4194304,\n      name: 'AxisType',\n      url: 'modules.html#axistype',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 73,\n      kind: 4194304,\n      name: 'AnchorMode',\n      url: 'modules.html#anchormode',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 74,\n      kind: 4194304,\n      name: 'Side',\n      url: 'modules.html#side',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 75,\n      kind: 4194304,\n      name: 'PointerUnpressed',\n      url: 'modules.html#pointerunpressed',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 76,\n      kind: 4194304,\n      name: 'PointerPressed',\n      url: 'modules.html#pointerpressed',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 77,\n      kind: 4194304,\n      name: 'Pointer',\n      url: 'modules.html#pointer',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 78,\n      kind: 4194304,\n      name: 'ChartOffset',\n      url: 'modules.html#chartoffset',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 79,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#chartoffset.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'ChartOffset',\n    },\n    {\n      id: 80,\n      kind: 1024,\n      name: 'left',\n      url: 'modules.html#chartoffset.__type.left',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOffset.__type',\n    },\n    {\n      id: 81,\n      kind: 1024,\n      name: 'top',\n      url: 'modules.html#chartoffset.__type.top',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOffset.__type',\n    },\n    {\n      id: 82,\n      kind: 1024,\n      name: 'width',\n      url: 'modules.html#chartoffset.__type.width',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOffset.__type',\n    },\n    {\n      id: 83,\n      kind: 1024,\n      name: 'height',\n      url: 'modules.html#chartoffset.__type.height',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'ChartOffset.__type',\n    },\n    {\n      id: 84,\n      kind: 4194304,\n      name: 'AxisDimension',\n      url: 'modules.html#axisdimension',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 85,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#axisdimension.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'AxisDimension',\n    },\n    {\n      id: 86,\n      kind: 1024,\n      name: 'left',\n      url: 'modules.html#axisdimension.__type.left',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisDimension.__type',\n    },\n    {\n      id: 87,\n      kind: 1024,\n      name: 'right',\n      url: 'modules.html#axisdimension.__type.right',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisDimension.__type',\n    },\n    {\n      id: 88,\n      kind: 1024,\n      name: 'top',\n      url: 'modules.html#axisdimension.__type.top',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisDimension.__type',\n    },\n    {\n      id: 89,\n      kind: 1024,\n      name: 'bottom',\n      url: 'modules.html#axisdimension.__type.bottom',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisDimension.__type',\n    },\n    {\n      id: 90,\n      kind: 1024,\n      name: 'width',\n      url: 'modules.html#axisdimension.__type.width',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisDimension.__type',\n    },\n    {\n      id: 91,\n      kind: 1024,\n      name: 'height',\n      url: 'modules.html#axisdimension.__type.height',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisDimension.__type',\n    },\n    {\n      id: 92,\n      kind: 4194304,\n      name: 'AxisDimensions',\n      url: 'modules.html#axisdimensions',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 93,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#axisdimensions.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'AxisDimensions',\n    },\n    {\n      id: 94,\n      kind: 1024,\n      name: 'left',\n      url: 'modules.html#axisdimensions.__type.left',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisDimensions.__type',\n    },\n    {\n      id: 95,\n      kind: 1024,\n      name: 'right',\n      url: 'modules.html#axisdimensions.__type.right',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisDimensions.__type',\n    },\n    {\n      id: 96,\n      kind: 1024,\n      name: 'top',\n      url: 'modules.html#axisdimensions.__type.top',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisDimensions.__type',\n    },\n    {\n      id: 97,\n      kind: 1024,\n      name: 'bottom',\n      url: 'modules.html#axisdimensions.__type.bottom',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisDimensions.__type',\n    },\n    {\n      id: 98,\n      kind: 4194304,\n      name: 'AxisOptionsBase',\n      url: 'modules.html#axisoptionsbase',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 99,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#axisoptionsbase.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'AxisOptionsBase',\n    },\n    {\n      id: 100,\n      kind: 1024,\n      name: 'isPrimary',\n      url: 'modules.html#axisoptionsbase.__type.isprimary',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 101,\n      kind: 1024,\n      name: 'primaryAxisId',\n      url: 'modules.html#axisoptionsbase.__type.primaryaxisid',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 102,\n      kind: 1024,\n      name: 'elementType',\n      url: 'modules.html#axisoptionsbase.__type.elementtype',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 103,\n      kind: 1024,\n      name: 'showDatumElements',\n      url: 'modules.html#axisoptionsbase.__type.showdatumelements',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 104,\n      kind: 1024,\n      name: 'showOrphanDatumElements',\n      url: 'modules.html#axisoptionsbase.__type.showorphandatumelements',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 105,\n      kind: 1024,\n      name: 'curve',\n      url: 'modules.html#axisoptionsbase.__type.curve',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 106,\n      kind: 1024,\n      name: 'invert',\n      url: 'modules.html#axisoptionsbase.__type.invert',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 107,\n      kind: 1024,\n      name: 'position',\n      url: 'modules.html#axisoptionsbase.__type.position',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 108,\n      kind: 1024,\n      name: 'minTickPaddingForRotation',\n      url: 'modules.html#axisoptionsbase.__type.mintickpaddingforrotation',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 109,\n      kind: 1024,\n      name: 'tickLabelRotationDeg',\n      url: 'modules.html#axisoptionsbase.__type.ticklabelrotationdeg',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 110,\n      kind: 1024,\n      name: 'innerBandPadding',\n      url: 'modules.html#axisoptionsbase.__type.innerbandpadding',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 111,\n      kind: 1024,\n      name: 'outerBandPadding',\n      url: 'modules.html#axisoptionsbase.__type.outerbandpadding',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 112,\n      kind: 1024,\n      name: 'showGrid',\n      url: 'modules.html#axisoptionsbase.__type.showgrid',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 113,\n      kind: 1024,\n      name: 'show',\n      url: 'modules.html#axisoptionsbase.__type.show',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 114,\n      kind: 1024,\n      name: 'stacked',\n      url: 'modules.html#axisoptionsbase.__type.stacked',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 115,\n      kind: 1024,\n      name: 'stackOffset',\n      url: 'modules.html#axisoptionsbase.__type.stackoffset',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 116,\n      kind: 1024,\n      name: 'id',\n      url: 'modules.html#axisoptionsbase.__type.id',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 117,\n      kind: 1024,\n      name: 'styles',\n      url: 'modules.html#axisoptionsbase.__type.styles',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisOptionsBase.__type',\n    },\n    {\n      id: 118,\n      kind: 4194304,\n      name: 'AxisTimeOptions',\n      url: 'modules.html#axistimeoptions',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 119,\n      kind: 4194304,\n      name: 'AxisOrdinalOptions',\n      url: 'modules.html#axisordinaloptions',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 120,\n      kind: 4194304,\n      name: 'AxisBandOptions',\n      url: 'modules.html#axisbandoptions',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 121,\n      kind: 4194304,\n      name: 'AxisLinearOptions',\n      url: 'modules.html#axislinearoptions',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 122,\n      kind: 4194304,\n      name: 'AxisOptions',\n      url: 'modules.html#axisoptions',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 123,\n      kind: 4194304,\n      name: 'ResolvedAxisOptions',\n      url: 'modules.html#resolvedaxisoptions',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 124,\n      kind: 4194304,\n      name: 'ChartValue',\n      url: 'modules.html#chartvalue',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 125,\n      kind: 4194304,\n      name: 'AxisBase',\n      url: 'modules.html#axisbase',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 126,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#axisbase.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'AxisBase',\n    },\n    {\n      id: 127,\n      kind: 1024,\n      name: '_',\n      url: 'modules.html#axisbase.__type._',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisBase.__type',\n    },\n    {\n      id: 128,\n      kind: 1024,\n      name: 'isVertical',\n      url: 'modules.html#axisbase.__type.isvertical',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisBase.__type',\n    },\n    {\n      id: 129,\n      kind: 1024,\n      name: 'range',\n      url: 'modules.html#axisbase.__type.range',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxisBase.__type',\n    },\n    {\n      id: 130,\n      kind: 4194304,\n      name: 'AxisTime',\n      url: 'modules.html#axistime',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 131,\n      kind: 4194304,\n      name: 'AxisLinear',\n      url: 'modules.html#axislinear',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 132,\n      kind: 4194304,\n      name: 'AxisBand',\n      url: 'modules.html#axisband',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 133,\n      kind: 4194304,\n      name: 'Axis',\n      url: 'modules.html#axis',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 134,\n      kind: 4194304,\n      name: 'UserSerie',\n      url: 'modules.html#userserie',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 135,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#userserie.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'UserSerie',\n    },\n    {\n      id: 136,\n      kind: 1024,\n      name: 'data',\n      url: 'modules.html#userserie.__type.data',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'UserSerie.__type',\n    },\n    {\n      id: 137,\n      kind: 1024,\n      name: 'id',\n      url: 'modules.html#userserie.__type.id',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'UserSerie.__type',\n    },\n    {\n      id: 138,\n      kind: 1024,\n      name: 'label',\n      url: 'modules.html#userserie.__type.label',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'UserSerie.__type',\n    },\n    {\n      id: 139,\n      kind: 1024,\n      name: 'color',\n      url: 'modules.html#userserie.__type.color',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'UserSerie.__type',\n    },\n    {\n      id: 140,\n      kind: 1024,\n      name: 'primaryAxisId',\n      url: 'modules.html#userserie.__type.primaryaxisid',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'UserSerie.__type',\n    },\n    {\n      id: 141,\n      kind: 1024,\n      name: 'secondaryAxisId',\n      url: 'modules.html#userserie.__type.secondaryaxisid',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'UserSerie.__type',\n    },\n    {\n      id: 142,\n      kind: 4194304,\n      name: 'Series',\n      url: 'modules.html#series',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 143,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#series.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'Series',\n    },\n    {\n      id: 144,\n      kind: 1024,\n      name: 'originalSeries',\n      url: 'modules.html#series.__type.originalseries',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Series.__type',\n    },\n    {\n      id: 145,\n      kind: 1024,\n      name: 'index',\n      url: 'modules.html#series.__type.index',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Series.__type',\n    },\n    {\n      id: 146,\n      kind: 1024,\n      name: 'id',\n      url: 'modules.html#series.__type.id',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Series.__type',\n    },\n    {\n      id: 147,\n      kind: 1024,\n      name: 'label',\n      url: 'modules.html#series.__type.label',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Series.__type',\n    },\n    {\n      id: 148,\n      kind: 1024,\n      name: 'secondaryAxisId',\n      url: 'modules.html#series.__type.secondaryaxisid',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Series.__type',\n    },\n    {\n      id: 149,\n      kind: 1024,\n      name: 'datums',\n      url: 'modules.html#series.__type.datums',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Series.__type',\n    },\n    {\n      id: 150,\n      kind: 1024,\n      name: 'style',\n      url: 'modules.html#series.__type.style',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Series.__type',\n    },\n    {\n      id: 151,\n      kind: 4194304,\n      name: 'Datum',\n      url: 'modules.html#datum',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 152,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#datum.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'Datum',\n    },\n    {\n      id: 153,\n      kind: 1024,\n      name: 'originalSeries',\n      url: 'modules.html#datum.__type.originalseries',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Datum.__type',\n    },\n    {\n      id: 154,\n      kind: 1024,\n      name: 'seriesIndex',\n      url: 'modules.html#datum.__type.seriesindex',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Datum.__type',\n    },\n    {\n      id: 155,\n      kind: 1024,\n      name: 'seriesId',\n      url: 'modules.html#datum.__type.seriesid',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Datum.__type',\n    },\n    {\n      id: 156,\n      kind: 1024,\n      name: 'seriesLabel',\n      url: 'modules.html#datum.__type.serieslabel',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Datum.__type',\n    },\n    {\n      id: 157,\n      kind: 1024,\n      name: 'index',\n      url: 'modules.html#datum.__type.index',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Datum.__type',\n    },\n    {\n      id: 158,\n      kind: 1024,\n      name: 'originalDatum',\n      url: 'modules.html#datum.__type.originaldatum',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Datum.__type',\n    },\n    {\n      id: 159,\n      kind: 1024,\n      name: 'secondaryAxisId',\n      url: 'modules.html#datum.__type.secondaryaxisid',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Datum.__type',\n    },\n    {\n      id: 160,\n      kind: 1024,\n      name: 'stackData',\n      url: 'modules.html#datum.__type.stackdata',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Datum.__type',\n    },\n    {\n      id: 161,\n      kind: 1024,\n      name: 'group',\n      url: 'modules.html#datum.__type.group',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Datum.__type',\n    },\n    {\n      id: 162,\n      kind: 1024,\n      name: 'style',\n      url: 'modules.html#datum.__type.style',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Datum.__type',\n    },\n    {\n      id: 163,\n      kind: 1024,\n      name: 'element',\n      url: 'modules.html#datum.__type.element',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'Datum.__type',\n    },\n    {\n      id: 164,\n      kind: 4194304,\n      name: 'StackDatum',\n      url: 'modules.html#stackdatum',\n      classes: 'tsd-kind-type-alias tsd-has-type-parameter',\n    },\n    {\n      id: 165,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#stackdatum.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'StackDatum',\n    },\n    {\n      id: 166,\n      kind: 1024,\n      name: '0',\n      url: 'modules.html#stackdatum.__type.0',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'StackDatum.__type',\n    },\n    {\n      id: 167,\n      kind: 1024,\n      name: '1',\n      url: 'modules.html#stackdatum.__type.1',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'StackDatum.__type',\n    },\n    {\n      id: 168,\n      kind: 1024,\n      name: 'data',\n      url: 'modules.html#stackdatum.__type.data',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'StackDatum.__type',\n    },\n    {\n      id: 169,\n      kind: 4194304,\n      name: 'Measurement',\n      url: 'modules.html#measurement',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 170,\n      kind: 4194304,\n      name: 'GridDimensions',\n      url: 'modules.html#griddimensions',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 171,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#griddimensions.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'GridDimensions',\n    },\n    {\n      id: 172,\n      kind: 1024,\n      name: 'gridX',\n      url: 'modules.html#griddimensions.__type.gridx',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'GridDimensions.__type',\n    },\n    {\n      id: 173,\n      kind: 1024,\n      name: 'gridY',\n      url: 'modules.html#griddimensions.__type.gridy',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'GridDimensions.__type',\n    },\n    {\n      id: 174,\n      kind: 1024,\n      name: 'width',\n      url: 'modules.html#griddimensions.__type.gridwidth',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'GridDimensions.__type',\n    },\n    {\n      id: 175,\n      kind: 1024,\n      name: 'height',\n      url: 'modules.html#griddimensions.__type.gridheight',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'GridDimensions.__type',\n    },\n    {\n      id: 176,\n      kind: 4194304,\n      name: 'AxesInfo',\n      url: 'modules.html#axesinfo',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 177,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#axesinfo.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'AxesInfo',\n    },\n    {\n      id: 178,\n      kind: 1024,\n      name: 'xKey',\n      url: 'modules.html#axesinfo.__type.xkey',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxesInfo.__type',\n    },\n    {\n      id: 179,\n      kind: 1024,\n      name: 'yKey',\n      url: 'modules.html#axesinfo.__type.ykey',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'AxesInfo.__type',\n    },\n    {\n      id: 180,\n      kind: 4194304,\n      name: 'CursorOptions',\n      url: 'modules.html#cursoroptions',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 181,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#cursoroptions.__type',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-alias',\n      parent: 'CursorOptions',\n    },\n    {\n      id: 182,\n      kind: 1024,\n      name: 'value',\n      url: 'modules.html#cursoroptions.__type.value',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'CursorOptions.__type',\n    },\n    {\n      id: 183,\n      kind: 1024,\n      name: 'show',\n      url: 'modules.html#cursoroptions.__type.show',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'CursorOptions.__type',\n    },\n    {\n      id: 184,\n      kind: 1024,\n      name: 'showLine',\n      url: 'modules.html#cursoroptions.__type.showline',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'CursorOptions.__type',\n    },\n    {\n      id: 185,\n      kind: 1024,\n      name: 'showLabel',\n      url: 'modules.html#cursoroptions.__type.showlabel',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'CursorOptions.__type',\n    },\n    {\n      id: 186,\n      kind: 1024,\n      name: 'axisId',\n      url: 'modules.html#cursoroptions.__type.axisid',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'CursorOptions.__type',\n    },\n    {\n      id: 187,\n      kind: 1024,\n      name: 'onChange',\n      url: 'modules.html#cursoroptions.__type.onchange',\n      classes: 'tsd-kind-property tsd-parent-kind-type-literal',\n      parent: 'CursorOptions.__type',\n    },\n    {\n      id: 188,\n      kind: 65536,\n      name: '__type',\n      url: 'modules.html#cursoroptions.__type.__type-1',\n      classes: 'tsd-kind-type-literal tsd-parent-kind-type-literal',\n      parent: 'CursorOptions.__type',\n    },\n    {\n      id: 189,\n      kind: 4194304,\n      name: 'SeriesFocusStatus',\n      url: 'modules.html#seriesfocusstatus',\n      classes: 'tsd-kind-type-alias',\n    },\n    {\n      id: 190,\n      kind: 4194304,\n      name: 'DatumFocusStatus',\n      url: 'modules.html#datumfocusstatus',\n      classes: 'tsd-kind-type-alias',\n    },\n  ],\n  index: {\n    version: '2.3.9',\n    fields: ['name', 'parent'],\n    fieldVectors: [\n      ['name/0', [0, 48.52]],\n      ['parent/0', []],\n      ['name/1', [1, 43.412]],\n      ['parent/1', []],\n      ['name/2', [2, 18.398]],\n      ['parent/2', [1, 3.868]],\n      ['name/3', [3, 40.047]],\n      ['parent/3', [4, 1.731]],\n      ['name/4', [5, 43.412]],\n      ['parent/4', [4, 1.731]],\n      ['name/5', [6, 43.412]],\n      ['parent/5', [4, 1.731]],\n      ['name/6', [7, 48.52]],\n      ['parent/6', [4, 1.731]],\n      ['name/7', [2, 18.398]],\n      ['parent/7', [4, 1.731]],\n      ['name/8', [8, 48.52]],\n      ['parent/8', [4, 1.731]],\n      ['name/9', [2, 18.398]],\n      ['parent/9', [4, 1.731]],\n      ['name/10', [9, 48.52]],\n      ['parent/10', [4, 1.731]],\n      ['name/11', [2, 18.398]],\n      ['parent/11', [4, 1.731]],\n      ['name/12', [10, 43.412]],\n      ['parent/12', [4, 1.731]],\n      ['name/13', [11, 48.52]],\n      ['parent/13', [4, 1.731]],\n      ['name/14', [12, 48.52]],\n      ['parent/14', [4, 1.731]],\n      ['name/15', [13, 48.52]],\n      ['parent/15', [4, 1.731]],\n      ['name/16', [14, 48.52]],\n      ['parent/16', [4, 1.731]],\n      ['name/17', [15, 48.52]],\n      ['parent/17', [4, 1.731]],\n      ['name/18', [16, 48.52]],\n      ['parent/18', [4, 1.731]],\n      ['name/19', [2, 18.398]],\n      ['parent/19', [4, 1.731]],\n      ['name/20', [17, 40.047]],\n      ['parent/20', [18, 3.568]],\n      ['name/21', [19, 48.52]],\n      ['parent/21', [18, 3.568]],\n      ['name/22', [2, 18.398]],\n      ['parent/22', [18, 3.568]],\n      ['name/23', [20, 48.52]],\n      ['parent/23', [4, 1.731]],\n      ['name/24', [2, 18.398]],\n      ['parent/24', [4, 1.731]],\n      ['name/25', [21, 48.52]],\n      ['parent/25', [4, 1.731]],\n      ['name/26', [2, 18.398]],\n      ['parent/26', [4, 1.731]],\n      ['name/27', [22, 48.52]],\n      ['parent/27', [4, 1.731]],\n      ['name/28', [23, 48.52]],\n      ['parent/28', [4, 1.731]],\n      ['name/29', [2, 18.398]],\n      ['parent/29', [4, 1.731]],\n      ['name/30', [24, 48.52]],\n      ['parent/30', [4, 1.731]],\n      ['name/31', [25, 48.52]],\n      ['parent/31', [4, 1.731]],\n      ['name/32', [26, 48.52]],\n      ['parent/32', [4, 1.731]],\n      ['name/33', [27, 48.52]],\n      ['parent/33', []],\n      ['name/34', [28, 43.412]],\n      ['parent/34', []],\n      ['name/35', [2, 18.398]],\n      ['parent/35', [28, 3.868]],\n      ['name/36', [29, 48.52]],\n      ['parent/36', [30, 1.993]],\n      ['name/37', [2, 18.398]],\n      ['parent/37', [30, 1.993]],\n      ['name/38', [31, 40.047]],\n      ['parent/38', [30, 1.993]],\n      ['name/39', [5, 43.412]],\n      ['parent/39', [30, 1.993]],\n      ['name/40', [6, 43.412]],\n      ['parent/40', [30, 1.993]],\n      ['name/41', [32, 40.047]],\n      ['parent/41', [30, 1.993]],\n      ['name/42', [33, 40.047]],\n      ['parent/42', [30, 1.993]],\n      ['name/43', [34, 48.52]],\n      ['parent/43', [30, 1.993]],\n      ['name/44', [35, 48.52]],\n      ['parent/44', [30, 1.993]],\n      ['name/45', [36, 40.047]],\n      ['parent/45', [30, 1.993]],\n      ['name/46', [37, 40.047]],\n      ['parent/46', [30, 1.993]],\n      ['name/47', [38, 48.52]],\n      ['parent/47', [30, 1.993]],\n      ['name/48', [39, 48.52]],\n      ['parent/48', [30, 1.993]],\n      ['name/49', [2, 18.398]],\n      ['parent/49', [30, 1.993]],\n      ['name/50', [40, 48.52]],\n      ['parent/50', [30, 1.993]],\n      ['name/51', [2, 18.398]],\n      ['parent/51', [30, 1.993]],\n      ['name/52', [41, 48.52]],\n      ['parent/52', [30, 1.993]],\n      ['name/53', [2, 18.398]],\n      ['parent/53', [30, 1.993]],\n      ['name/54', [42, 48.52]],\n      ['parent/54', [30, 1.993]],\n      ['name/55', [2, 18.398]],\n      ['parent/55', [30, 1.993]],\n      ['name/56', [43, 43.412]],\n      ['parent/56', []],\n      ['name/57', [2, 18.398]],\n      ['parent/57', [43, 3.868]],\n      ['name/58', [44, 48.52]],\n      ['parent/58', [45, 2.889]],\n      ['name/59', [46, 48.52]],\n      ['parent/59', [45, 2.889]],\n      ['name/60', [47, 48.52]],\n      ['parent/60', [45, 2.889]],\n      ['name/61', [48, 48.52]],\n      ['parent/61', [45, 2.889]],\n      ['name/62', [49, 48.52]],\n      ['parent/62', [45, 2.889]],\n      ['name/63', [2, 18.398]],\n      ['parent/63', [45, 2.889]],\n      ['name/64', [50, 43.412]],\n      ['parent/64', [45, 2.889]],\n      ['name/65', [51, 48.52]],\n      ['parent/65', []],\n      ['name/66', [52, 48.52]],\n      ['parent/66', []],\n      ['name/67', [53, 48.52]],\n      ['parent/67', []],\n      ['name/68', [54, 43.412]],\n      ['parent/68', []],\n      ['name/69', [10, 43.412]],\n      ['parent/69', []],\n      ['name/70', [55, 48.52]],\n      ['parent/70', []],\n      ['name/71', [56, 48.52]],\n      ['parent/71', []],\n      ['name/72', [57, 48.52]],\n      ['parent/72', []],\n      ['name/73', [58, 48.52]],\n      ['parent/73', []],\n      ['name/74', [59, 48.52]],\n      ['parent/74', []],\n      ['name/75', [60, 48.52]],\n      ['parent/75', []],\n      ['name/76', [61, 48.52]],\n      ['parent/76', []],\n      ['name/77', [62, 48.52]],\n      ['parent/77', []],\n      ['name/78', [63, 43.412]],\n      ['parent/78', []],\n      ['name/79', [2, 18.398]],\n      ['parent/79', [63, 3.868]],\n      ['name/80', [64, 40.047]],\n      ['parent/80', [65, 3.344]],\n      ['name/81', [66, 40.047]],\n      ['parent/81', [65, 3.344]],\n      ['name/82', [36, 40.047]],\n      ['parent/82', [65, 3.344]],\n      ['name/83', [37, 40.047]],\n      ['parent/83', [65, 3.344]],\n      ['name/84', [67, 43.412]],\n      ['parent/84', []],\n      ['name/85', [2, 18.398]],\n      ['parent/85', [67, 3.868]],\n      ['name/86', [64, 40.047]],\n      ['parent/86', [68, 3.016]],\n      ['name/87', [69, 43.412]],\n      ['parent/87', [68, 3.016]],\n      ['name/88', [66, 40.047]],\n      ['parent/88', [68, 3.016]],\n      ['name/89', [70, 43.412]],\n      ['parent/89', [68, 3.016]],\n      ['name/90', [36, 40.047]],\n      ['parent/90', [68, 3.016]],\n      ['name/91', [37, 40.047]],\n      ['parent/91', [68, 3.016]],\n      ['name/92', [71, 43.412]],\n      ['parent/92', []],\n      ['name/93', [2, 18.398]],\n      ['parent/93', [71, 3.868]],\n      ['name/94', [64, 40.047]],\n      ['parent/94', [72, 3.344]],\n      ['name/95', [69, 43.412]],\n      ['parent/95', [72, 3.344]],\n      ['name/96', [66, 40.047]],\n      ['parent/96', [72, 3.344]],\n      ['name/97', [70, 43.412]],\n      ['parent/97', [72, 3.344]],\n      ['name/98', [73, 43.412]],\n      ['parent/98', []],\n      ['name/99', [2, 18.398]],\n      ['parent/99', [73, 3.868]],\n      ['name/100', [74, 48.52]],\n      ['parent/100', [75, 2.084]],\n      ['name/101', [76, 43.412]],\n      ['parent/101', [75, 2.084]],\n      ['name/102', [77, 48.52]],\n      ['parent/102', [75, 2.084]],\n      ['name/103', [78, 48.52]],\n      ['parent/103', [75, 2.084]],\n      ['name/104', [79, 48.52]],\n      ['parent/104', [75, 2.084]],\n      ['name/105', [80, 48.52]],\n      ['parent/105', [75, 2.084]],\n      ['name/106', [50, 43.412]],\n      ['parent/106', [75, 2.084]],\n      ['name/107', [54, 43.412]],\n      ['parent/107', [75, 2.084]],\n      ['name/108', [81, 48.52]],\n      ['parent/108', [75, 2.084]],\n      ['name/109', [82, 48.52]],\n      ['parent/109', [75, 2.084]],\n      ['name/110', [83, 48.52]],\n      ['parent/110', [75, 2.084]],\n      ['name/111', [84, 48.52]],\n      ['parent/111', [75, 2.084]],\n      ['name/112', [85, 48.52]],\n      ['parent/112', [75, 2.084]],\n      ['name/113', [86, 43.412]],\n      ['parent/113', [75, 2.084]],\n      ['name/114', [87, 48.52]],\n      ['parent/114', [75, 2.084]],\n      ['name/115', [88, 48.52]],\n      ['parent/115', [75, 2.084]],\n      ['name/116', [89, 40.047]],\n      ['parent/116', [75, 2.084]],\n      ['name/117', [90, 48.52]],\n      ['parent/117', [75, 2.084]],\n      ['name/118', [91, 48.52]],\n      ['parent/118', []],\n      ['name/119', [92, 48.52]],\n      ['parent/119', []],\n      ['name/120', [93, 48.52]],\n      ['parent/120', []],\n      ['name/121', [94, 48.52]],\n      ['parent/121', []],\n      ['name/122', [95, 48.52]],\n      ['parent/122', []],\n      ['name/123', [96, 48.52]],\n      ['parent/123', []],\n      ['name/124', [97, 48.52]],\n      ['parent/124', []],\n      ['name/125', [98, 43.412]],\n      ['parent/125', []],\n      ['name/126', [2, 18.398]],\n      ['parent/126', [98, 3.868]],\n      ['name/127', [99, 48.52]],\n      ['parent/127', [100, 3.568]],\n      ['name/128', [101, 48.52]],\n      ['parent/128', [100, 3.568]],\n      ['name/129', [102, 48.52]],\n      ['parent/129', [100, 3.568]],\n      ['name/130', [103, 48.52]],\n      ['parent/130', []],\n      ['name/131', [104, 48.52]],\n      ['parent/131', []],\n      ['name/132', [105, 48.52]],\n      ['parent/132', []],\n      ['name/133', [106, 48.52]],\n      ['parent/133', []],\n      ['name/134', [107, 43.412]],\n      ['parent/134', []],\n      ['name/135', [2, 18.398]],\n      ['parent/135', [107, 3.868]],\n      ['name/136', [3, 40.047]],\n      ['parent/136', [108, 3.016]],\n      ['name/137', [89, 40.047]],\n      ['parent/137', [108, 3.016]],\n      ['name/138', [109, 43.412]],\n      ['parent/138', [108, 3.016]],\n      ['name/139', [110, 48.52]],\n      ['parent/139', [108, 3.016]],\n      ['name/140', [76, 43.412]],\n      ['parent/140', [108, 3.016]],\n      ['name/141', [111, 40.047]],\n      ['parent/141', [108, 3.016]],\n      ['name/142', [33, 40.047]],\n      ['parent/142', []],\n      ['name/143', [2, 18.398]],\n      ['parent/143', [33, 3.568]],\n      ['name/144', [112, 43.412]],\n      ['parent/144', [113, 2.889]],\n      ['name/145', [114, 43.412]],\n      ['parent/145', [113, 2.889]],\n      ['name/146', [89, 40.047]],\n      ['parent/146', [113, 2.889]],\n      ['name/147', [109, 43.412]],\n      ['parent/147', [113, 2.889]],\n      ['name/148', [111, 40.047]],\n      ['parent/148', [113, 2.889]],\n      ['name/149', [115, 48.52]],\n      ['parent/149', [113, 2.889]],\n      ['name/150', [17, 40.047]],\n      ['parent/150', [113, 2.889]],\n      ['name/151', [116, 43.412]],\n      ['parent/151', []],\n      ['name/152', [2, 18.398]],\n      ['parent/152', [116, 3.868]],\n      ['name/153', [112, 43.412]],\n      ['parent/153', [117, 2.508]],\n      ['name/154', [118, 48.52]],\n      ['parent/154', [117, 2.508]],\n      ['name/155', [119, 48.52]],\n      ['parent/155', [117, 2.508]],\n      ['name/156', [120, 48.52]],\n      ['parent/156', [117, 2.508]],\n      ['name/157', [114, 43.412]],\n      ['parent/157', [117, 2.508]],\n      ['name/158', [121, 48.52]],\n      ['parent/158', [117, 2.508]],\n      ['name/159', [111, 40.047]],\n      ['parent/159', [117, 2.508]],\n      ['name/160', [122, 48.52]],\n      ['parent/160', [117, 2.508]],\n      ['name/161', [123, 48.52]],\n      ['parent/161', [117, 2.508]],\n      ['name/162', [17, 40.047]],\n      ['parent/162', [117, 2.508]],\n      ['name/163', [124, 48.52]],\n      ['parent/163', [117, 2.508]],\n      ['name/164', [125, 43.412]],\n      ['parent/164', []],\n      ['name/165', [2, 18.398]],\n      ['parent/165', [125, 3.868]],\n      ['name/166', [126, 48.52]],\n      ['parent/166', [127, 3.568]],\n      ['name/167', [128, 48.52]],\n      ['parent/167', [127, 3.568]],\n      ['name/168', [3, 40.047]],\n      ['parent/168', [127, 3.568]],\n      ['name/169', [129, 48.52]],\n      ['parent/169', []],\n      ['name/170', [31, 40.047]],\n      ['parent/170', []],\n      ['name/171', [2, 18.398]],\n      ['parent/171', [31, 3.568]],\n      ['name/172', [130, 48.52]],\n      ['parent/172', [131, 3.344]],\n      ['name/173', [132, 48.52]],\n      ['parent/173', [131, 3.344]],\n      ['name/174', [133, 48.52]],\n      ['parent/174', [131, 3.344]],\n      ['name/175', [134, 48.52]],\n      ['parent/175', [131, 3.344]],\n      ['name/176', [32, 40.047]],\n      ['parent/176', []],\n      ['name/177', [2, 18.398]],\n      ['parent/177', [32, 3.568]],\n      ['name/178', [135, 48.52]],\n      ['parent/178', [136, 3.868]],\n      ['name/179', [137, 48.52]],\n      ['parent/179', [136, 3.868]],\n      ['name/180', [138, 43.412]],\n      ['parent/180', []],\n      ['name/181', [2, 18.398]],\n      ['parent/181', [138, 3.868]],\n      ['name/182', [139, 48.52]],\n      ['parent/182', [140, 2.889]],\n      ['name/183', [86, 43.412]],\n      ['parent/183', [140, 2.889]],\n      ['name/184', [141, 48.52]],\n      ['parent/184', [140, 2.889]],\n      ['name/185', [142, 48.52]],\n      ['parent/185', [140, 2.889]],\n      ['name/186', [143, 48.52]],\n      ['parent/186', [140, 2.889]],\n      ['name/187', [144, 48.52]],\n      ['parent/187', [140, 2.889]],\n      ['name/188', [2, 18.398]],\n      ['parent/188', [140, 2.889]],\n      ['name/189', [145, 48.52]],\n      ['parent/189', []],\n      ['name/190', [146, 48.52]],\n      ['parent/190', []],\n    ],\n    invertedIndex: [\n      ['0', { _index: 126, name: { 166: {} }, parent: {} }],\n      ['1', { _index: 128, name: { 167: {} }, parent: {} }],\n      ['_', { _index: 99, name: { 127: {} }, parent: {} }],\n      [\n        '__type',\n        {\n          _index: 2,\n          name: {\n            2: {},\n            7: {},\n            9: {},\n            11: {},\n            19: {},\n            22: {},\n            24: {},\n            26: {},\n            29: {},\n            35: {},\n            37: {},\n            49: {},\n            51: {},\n            53: {},\n            55: {},\n            57: {},\n            63: {},\n            79: {},\n            85: {},\n            93: {},\n            99: {},\n            126: {},\n            135: {},\n            143: {},\n            152: {},\n            165: {},\n            171: {},\n            177: {},\n            181: {},\n            188: {},\n          },\n          parent: {},\n        },\n      ],\n      ['align', { _index: 44, name: { 58: {} }, parent: {} }],\n      ['alignmode', { _index: 55, name: { 70: {} }, parent: {} }],\n      ['alignposition', { _index: 56, name: { 71: {} }, parent: {} }],\n      ['alignpriority', { _index: 46, name: { 59: {} }, parent: {} }],\n      ['anchormode', { _index: 58, name: { 73: {} }, parent: {} }],\n      [\n        'axesinfo',\n        { _index: 32, name: { 41: {}, 176: {} }, parent: { 177: {} } },\n      ],\n      [\n        'axesinfo.__type',\n        { _index: 136, name: {}, parent: { 178: {}, 179: {} } },\n      ],\n      ['axis', { _index: 106, name: { 133: {} }, parent: {} }],\n      ['axisband', { _index: 105, name: { 132: {} }, parent: {} }],\n      ['axisbandoptions', { _index: 93, name: { 120: {} }, parent: {} }],\n      ['axisbase', { _index: 98, name: { 125: {} }, parent: { 126: {} } }],\n      [\n        'axisbase.__type',\n        { _index: 100, name: {}, parent: { 127: {}, 128: {}, 129: {} } },\n      ],\n      ['axisdimension', { _index: 67, name: { 84: {} }, parent: { 85: {} } }],\n      [\n        'axisdimension.__type',\n        {\n          _index: 68,\n          name: {},\n          parent: { 86: {}, 87: {}, 88: {}, 89: {}, 90: {}, 91: {} },\n        },\n      ],\n      ['axisdimensions', { _index: 71, name: { 92: {} }, parent: { 93: {} } }],\n      [\n        'axisdimensions.__type',\n        { _index: 72, name: {}, parent: { 94: {}, 95: {}, 96: {}, 97: {} } },\n      ],\n      ['axisid', { _index: 143, name: { 186: {} }, parent: {} }],\n      ['axislinear', { _index: 104, name: { 131: {} }, parent: {} }],\n      ['axislinearoptions', { _index: 94, name: { 121: {} }, parent: {} }],\n      ['axisoptions', { _index: 95, name: { 122: {} }, parent: {} }],\n      ['axisoptionsbase', { _index: 73, name: { 98: {} }, parent: { 99: {} } }],\n      [\n        'axisoptionsbase.__type',\n        {\n          _index: 75,\n          name: {},\n          parent: {\n            100: {},\n            101: {},\n            102: {},\n            103: {},\n            104: {},\n            105: {},\n            106: {},\n            107: {},\n            108: {},\n            109: {},\n            110: {},\n            111: {},\n            112: {},\n            113: {},\n            114: {},\n            115: {},\n            116: {},\n            117: {},\n          },\n        },\n      ],\n      ['axisordinaloptions', { _index: 92, name: { 119: {} }, parent: {} }],\n      ['axistime', { _index: 103, name: { 130: {} }, parent: {} }],\n      ['axistimeoptions', { _index: 91, name: { 118: {} }, parent: {} }],\n      ['axistype', { _index: 57, name: { 72: {} }, parent: {} }],\n      ['bottom', { _index: 70, name: { 89: {}, 97: {} }, parent: {} }],\n      ['brush', { _index: 16, name: { 18: {} }, parent: {} }],\n      ['chart', { _index: 0, name: { 0: {} }, parent: {} }],\n      [\n        'chartcontextvalue',\n        { _index: 28, name: { 34: {} }, parent: { 35: {} } },\n      ],\n      [\n        'chartcontextvalue.__type',\n        {\n          _index: 30,\n          name: {},\n          parent: {\n            36: {},\n            37: {},\n            38: {},\n            39: {},\n            40: {},\n            41: {},\n            42: {},\n            43: {},\n            44: {},\n            45: {},\n            46: {},\n            47: {},\n            48: {},\n            49: {},\n            50: {},\n            51: {},\n            52: {},\n            53: {},\n            54: {},\n            55: {},\n          },\n        },\n      ],\n      ['chartoffset', { _index: 63, name: { 78: {} }, parent: { 79: {} } }],\n      [\n        'chartoffset.__type',\n        { _index: 65, name: {}, parent: { 80: {}, 81: {}, 82: {}, 83: {} } },\n      ],\n      ['chartoptions', { _index: 1, name: { 1: {} }, parent: { 2: {} } }],\n      [\n        'chartoptions.__type',\n        {\n          _index: 4,\n          name: {},\n          parent: {\n            3: {},\n            4: {},\n            5: {},\n            6: {},\n            7: {},\n            8: {},\n            9: {},\n            10: {},\n            11: {},\n            12: {},\n            13: {},\n            14: {},\n            15: {},\n            16: {},\n            17: {},\n            18: {},\n            19: {},\n            23: {},\n            24: {},\n            25: {},\n            26: {},\n            27: {},\n            28: {},\n            29: {},\n            30: {},\n            31: {},\n            32: {},\n          },\n        },\n      ],\n      [\n        'chartoptions.__type.__type',\n        { _index: 18, name: {}, parent: { 20: {}, 21: {}, 22: {} } },\n      ],\n      ['chartvalue', { _index: 97, name: { 124: {} }, parent: {} }],\n      ['color', { _index: 110, name: { 139: {} }, parent: {} }],\n      [\n        'cursoroptions',\n        { _index: 138, name: { 180: {} }, parent: { 181: {} } },\n      ],\n      [\n        'cursoroptions.__type',\n        {\n          _index: 140,\n          name: {},\n          parent: {\n            182: {},\n            183: {},\n            184: {},\n            185: {},\n            186: {},\n            187: {},\n            188: {},\n          },\n        },\n      ],\n      ['curve', { _index: 80, name: { 105: {} }, parent: {} }],\n      ['dark', { _index: 22, name: { 27: {} }, parent: {} }],\n      ['data', { _index: 3, name: { 3: {}, 136: {}, 168: {} }, parent: {} }],\n      ['datum', { _index: 116, name: { 151: {} }, parent: { 152: {} } }],\n      [\n        'datum.__type',\n        {\n          _index: 117,\n          name: {},\n          parent: {\n            153: {},\n            154: {},\n            155: {},\n            156: {},\n            157: {},\n            158: {},\n            159: {},\n            160: {},\n            161: {},\n            162: {},\n            163: {},\n          },\n        },\n      ],\n      ['datumfocusstatus', { _index: 146, name: { 190: {} }, parent: {} }],\n      ['datums', { _index: 115, name: { 149: {} }, parent: {} }],\n      ['datumstyles', { _index: 53, name: { 67: {} }, parent: {} }],\n      ['defaultcolors', { _index: 13, name: { 15: {} }, parent: {} }],\n      ['element', { _index: 124, name: { 163: {} }, parent: {} }],\n      ['elementtype', { _index: 77, name: { 102: {} }, parent: {} }],\n      ['getdatumstatusstyle', { _index: 40, name: { 50: {} }, parent: {} }],\n      ['getdatumstyle', { _index: 8, name: { 8: {} }, parent: {} }],\n      ['getoptions', { _index: 29, name: { 36: {} }, parent: {} }],\n      ['getseriesorder', { _index: 9, name: { 10: {} }, parent: {} }],\n      ['getseriesstatusstyle', { _index: 39, name: { 48: {} }, parent: {} }],\n      ['getseriesstyle', { _index: 7, name: { 6: {} }, parent: {} }],\n      [\n        'griddimensions',\n        { _index: 31, name: { 38: {}, 170: {} }, parent: { 171: {} } },\n      ],\n      [\n        'griddimensions.__type',\n        {\n          _index: 131,\n          name: {},\n          parent: { 172: {}, 173: {}, 174: {}, 175: {} },\n        },\n      ],\n      ['gridheight', { _index: 134, name: { 175: {} }, parent: {} }],\n      ['gridwidth', { _index: 133, name: { 174: {} }, parent: {} }],\n      ['gridx', { _index: 130, name: { 172: {} }, parent: {} }],\n      ['gridy', { _index: 132, name: { 173: {} }, parent: {} }],\n      ['group', { _index: 123, name: { 161: {} }, parent: {} }],\n      ['groupeddatums', { _index: 35, name: { 44: {} }, parent: {} }],\n      ['groupingmode', { _index: 10, name: { 12: {}, 69: {} }, parent: {} }],\n      ['height', { _index: 37, name: { 46: {}, 83: {}, 91: {} }, parent: {} }],\n      ['id', { _index: 89, name: { 116: {}, 137: {}, 146: {} }, parent: {} }],\n      ['index', { _index: 114, name: { 145: {}, 157: {} }, parent: {} }],\n      ['initialheight', { _index: 15, name: { 17: {} }, parent: {} }],\n      ['initialwidth', { _index: 14, name: { 16: {} }, parent: {} }],\n      ['innerbandpadding', { _index: 83, name: { 110: {} }, parent: {} }],\n      ['invert', { _index: 50, name: { 64: {}, 106: {} }, parent: {} }],\n      ['isprimary', { _index: 74, name: { 100: {} }, parent: {} }],\n      ['isvertical', { _index: 101, name: { 128: {} }, parent: {} }],\n      ['label', { _index: 109, name: { 138: {}, 147: {} }, parent: {} }],\n      ['left', { _index: 64, name: { 80: {}, 86: {}, 94: {} }, parent: {} }],\n      ['measurement', { _index: 129, name: { 169: {} }, parent: {} }],\n      [\n        'mintickpaddingforrotation',\n        { _index: 81, name: { 108: {} }, parent: {} },\n      ],\n      ['onchange', { _index: 144, name: { 187: {} }, parent: {} }],\n      ['onclickdatum', { _index: 21, name: { 25: {} }, parent: {} }],\n      ['onfocusdatum', { _index: 20, name: { 23: {} }, parent: {} }],\n      ['onselect', { _index: 19, name: { 21: {} }, parent: {} }],\n      ['orderedseries', { _index: 34, name: { 43: {} }, parent: {} }],\n      ['originaldatum', { _index: 121, name: { 158: {} }, parent: {} }],\n      [\n        'originalseries',\n        { _index: 112, name: { 144: {}, 153: {} }, parent: {} },\n      ],\n      ['outerbandpadding', { _index: 84, name: { 111: {} }, parent: {} }],\n      ['padding', { _index: 47, name: { 60: {} }, parent: {} }],\n      ['pointer', { _index: 62, name: { 77: {} }, parent: {} }],\n      ['pointerpressed', { _index: 61, name: { 76: {} }, parent: {} }],\n      ['pointerunpressed', { _index: 60, name: { 75: {} }, parent: {} }],\n      ['position', { _index: 54, name: { 68: {}, 107: {} }, parent: {} }],\n      ['primaryaxis', { _index: 5, name: { 4: {}, 39: {} }, parent: {} }],\n      ['primaryaxisid', { _index: 76, name: { 101: {}, 140: {} }, parent: {} }],\n      ['primarycursor', { _index: 24, name: { 30: {} }, parent: {} }],\n      ['range', { _index: 102, name: { 129: {} }, parent: {} }],\n      ['render', { _index: 49, name: { 62: {} }, parent: {} }],\n      ['rendersvg', { _index: 23, name: { 28: {} }, parent: {} }],\n      ['requiredchartoptions', { _index: 27, name: { 33: {} }, parent: {} }],\n      ['resolvedaxisoptions', { _index: 96, name: { 123: {} }, parent: {} }],\n      ['resolvedtooltipoptions', { _index: 51, name: { 65: {} }, parent: {} }],\n      ['right', { _index: 69, name: { 87: {}, 95: {} }, parent: {} }],\n      ['secondaryaxes', { _index: 6, name: { 5: {}, 40: {} }, parent: {} }],\n      [\n        'secondaryaxisid',\n        { _index: 111, name: { 141: {}, 148: {}, 159: {} }, parent: {} },\n      ],\n      ['secondarycursor', { _index: 25, name: { 31: {} }, parent: {} }],\n      [\n        'series',\n        { _index: 33, name: { 42: {}, 142: {} }, parent: { 143: {} } },\n      ],\n      [\n        'series.__type',\n        {\n          _index: 113,\n          name: {},\n          parent: {\n            144: {},\n            145: {},\n            146: {},\n            147: {},\n            148: {},\n            149: {},\n            150: {},\n          },\n        },\n      ],\n      ['seriesfocusstatus', { _index: 145, name: { 189: {} }, parent: {} }],\n      ['seriesid', { _index: 119, name: { 155: {} }, parent: {} }],\n      ['seriesindex', { _index: 118, name: { 154: {} }, parent: {} }],\n      ['serieslabel', { _index: 120, name: { 156: {} }, parent: {} }],\n      ['seriesstyles', { _index: 52, name: { 66: {} }, parent: {} }],\n      ['show', { _index: 86, name: { 113: {}, 183: {} }, parent: {} }],\n      ['showdatumelements', { _index: 78, name: { 103: {} }, parent: {} }],\n      ['showdebugaxes', { _index: 12, name: { 14: {} }, parent: {} }],\n      ['showgrid', { _index: 85, name: { 112: {} }, parent: {} }],\n      ['showlabel', { _index: 142, name: { 185: {} }, parent: {} }],\n      ['showline', { _index: 141, name: { 184: {} }, parent: {} }],\n      [\n        'showorphandatumelements',\n        { _index: 79, name: { 104: {} }, parent: {} },\n      ],\n      ['showvoronoi', { _index: 11, name: { 13: {} }, parent: {} }],\n      ['side', { _index: 59, name: { 74: {} }, parent: {} }],\n      ['stackdata', { _index: 122, name: { 160: {} }, parent: {} }],\n      ['stackdatum', { _index: 125, name: { 164: {} }, parent: { 165: {} } }],\n      [\n        'stackdatum.__type',\n        { _index: 127, name: {}, parent: { 166: {}, 167: {}, 168: {} } },\n      ],\n      ['stacked', { _index: 87, name: { 114: {} }, parent: {} }],\n      ['stackoffset', { _index: 88, name: { 115: {} }, parent: {} }],\n      ['style', { _index: 17, name: { 20: {}, 150: {}, 162: {} }, parent: {} }],\n      ['styles', { _index: 90, name: { 117: {} }, parent: {} }],\n      ['svgrect', { _index: 38, name: { 47: {} }, parent: {} }],\n      ['ticklabelrotationdeg', { _index: 82, name: { 109: {} }, parent: {} }],\n      ['tooltip', { _index: 26, name: { 32: {} }, parent: {} }],\n      ['tooltiparrowpadding', { _index: 48, name: { 61: {} }, parent: {} }],\n      ['tooltipoptions', { _index: 43, name: { 56: {} }, parent: { 57: {} } }],\n      [\n        'tooltipoptions.__type',\n        {\n          _index: 45,\n          name: {},\n          parent: { 58: {}, 59: {}, 60: {}, 61: {}, 62: {}, 63: {}, 64: {} },\n        },\n      ],\n      ['top', { _index: 66, name: { 81: {}, 88: {}, 96: {} }, parent: {} }],\n      ['useaxisdimensionsatom', { _index: 41, name: { 52: {} }, parent: {} }],\n      ['usefocuseddatumatom', { _index: 42, name: { 54: {} }, parent: {} }],\n      ['userserie', { _index: 107, name: { 134: {} }, parent: { 135: {} } }],\n      [\n        'userserie.__type',\n        {\n          _index: 108,\n          name: {},\n          parent: { 136: {}, 137: {}, 138: {}, 139: {}, 140: {}, 141: {} },\n        },\n      ],\n      ['value', { _index: 139, name: { 182: {} }, parent: {} }],\n      ['width', { _index: 36, name: { 45: {}, 82: {}, 90: {} }, parent: {} }],\n      ['xkey', { _index: 135, name: { 178: {} }, parent: {} }],\n      ['ykey', { _index: 137, name: { 179: {} }, parent: {} }],\n    ],\n    pipeline: [],\n  },\n}\n"
  },
  {
    "path": "typedocs/index.html",
    "content": "<!DOCTYPE html>\n<html class=\"minimal no-js\">\n  <head>\n    <meta charset=\"utf-8\" />\n    <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\" />\n    <title>react-charts | react-charts</title>\n    <meta name=\"description\" content=\"Documentation for react-charts\" />\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\" />\n    <style type=\"text/css\">\n      :root {\n        --color-background: #fdfdfd;\n        --color-text: #222;\n        --color-text-aside: #707070;\n        --color-link: #4da6ff;\n        --color-menu-divider: #eee;\n        --color-menu-divider-focus: #000;\n        --color-menu-label: #707070;\n        --color-panel: #fff;\n        --color-panel-divider: #eee;\n        --color-comment-tag: #707070;\n        --color-comment-tag-text: #fff;\n        --color-code-background: rgba(0, 0, 0, 0.04);\n        --color-ts: #9600ff;\n        --color-ts-interface: #647f1b;\n        --color-ts-enum: #937210;\n        --color-ts-class: #0672de;\n        --color-ts-private: #707070;\n        --color-toolbar: #fff;\n        --color-toolbar-text: #333;\n      }\n\n      /*! normalize.css v1.1.3 | MIT License | git.io/normalize */\n      /* ==========================================================================\n * * HTML5 display definitions\n * * ========================================================================== */\n      /**\n * * Correct `block` display not defined in IE 6/7/8/9 and Firefox 3. */\n      article,\n      aside,\n      details,\n      figcaption,\n      figure,\n      footer,\n      header,\n      hgroup,\n      main,\n      nav,\n      section,\n      summary {\n        display: block;\n      }\n\n      /**\n * * Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3. */\n      audio,\n      canvas,\n      video {\n        display: inline-block;\n        *display: inline;\n        *zoom: 1;\n      }\n\n      /**\n * * Prevent modern browsers from displaying `audio` without controls.\n * * Remove excess height in iOS 5 devices. */\n      audio:not([controls]) {\n        display: none;\n        height: 0;\n      }\n\n      /**\n * * Address styling not present in IE 7/8/9, Firefox 3, and Safari 4.\n * * Known issue: no IE 6 support. */\n      [hidden] {\n        display: none;\n      }\n\n      /* ==========================================================================\n * * Base\n * * ========================================================================== */\n      /**\n * * 1. Correct text resizing oddly in IE 6/7 when body `font-size` is set using\n * *    `em` units.\n * * 2. Prevent iOS text size adjust after orientation change, without disabling\n * *    user zoom. */\n      html {\n        font-size: 100%;\n        /* 1 */\n        -ms-text-size-adjust: 100%;\n        /* 2 */\n        -webkit-text-size-adjust: 100%;\n        /* 2 */\n        font-family: sans-serif;\n      }\n\n      /**\n * * Address `font-family` inconsistency between `textarea` and other form\n * * elements. */\n      button,\n      input,\n      select,\n      textarea {\n        font-family: sans-serif;\n      }\n\n      /**\n * * Address margins handled incorrectly in IE 6/7. */\n      body {\n        margin: 0;\n      }\n\n      /* ==========================================================================\n * * Links\n * * ========================================================================== */\n      /**\n * * Address `outline` inconsistency between Chrome and other browsers. */\n      a:focus {\n        outline: thin dotted;\n      }\n      a:active,\n      a:hover {\n        outline: 0;\n      }\n\n      /**\n * * Improve readability when focused and also mouse hovered in all browsers. */\n      /* ==========================================================================\n * * Typography\n * * ========================================================================== */\n      /**\n * * Address font sizes and margins set differently in IE 6/7.\n * * Address font sizes within `section` and `article` in Firefox 4+, Safari 5,\n * * and Chrome. */\n      h1 {\n        font-size: 2em;\n        margin: 0.67em 0;\n      }\n\n      h2 {\n        font-size: 1.5em;\n        margin: 0.83em 0;\n      }\n\n      h3 {\n        font-size: 1.17em;\n        margin: 1em 0;\n      }\n\n      h4,\n      .tsd-index-panel h3 {\n        font-size: 1em;\n        margin: 1.33em 0;\n      }\n\n      h5 {\n        font-size: 0.83em;\n        margin: 1.67em 0;\n      }\n\n      h6 {\n        font-size: 0.67em;\n        margin: 2.33em 0;\n      }\n\n      /**\n * * Address styling not present in IE 7/8/9, Safari 5, and Chrome. */\n      abbr[title] {\n        border-bottom: 1px dotted;\n      }\n\n      /**\n * * Address style set to `bolder` in Firefox 3+, Safari 4/5, and Chrome. */\n      b,\n      strong {\n        font-weight: bold;\n      }\n\n      blockquote {\n        margin: 1em 40px;\n      }\n\n      /**\n * * Address styling not present in Safari 5 and Chrome. */\n      dfn {\n        font-style: italic;\n      }\n\n      /**\n * * Address differences between Firefox and other browsers.\n * * Known issue: no IE 6/7 normalization. */\n      hr {\n        -moz-box-sizing: content-box;\n        box-sizing: content-box;\n        height: 0;\n      }\n\n      /**\n * * Address styling not present in IE 6/7/8/9. */\n      mark {\n        background: #ff0;\n        color: #000;\n      }\n\n      /**\n * * Address margins set differently in IE 6/7. */\n      p,\n      pre {\n        margin: 1em 0;\n      }\n\n      /**\n * * Correct font family set oddly in IE 6, Safari 4/5, and Chrome. */\n      code,\n      kbd,\n      pre,\n      samp {\n        font-family: monospace, serif;\n        _font-family: 'courier new', monospace;\n        font-size: 1em;\n      }\n\n      /**\n * * Improve readability of pre-formatted text in all browsers. */\n      pre {\n        white-space: pre;\n        white-space: pre-wrap;\n        word-wrap: break-word;\n      }\n\n      /**\n * * Address CSS quotes not supported in IE 6/7. */\n      q {\n        quotes: none;\n      }\n      q:before,\n      q:after {\n        content: '';\n        content: none;\n      }\n\n      /**\n * * Address `quotes` property not supported in Safari 4. */\n      /**\n * * Address inconsistent and variable font size in all browsers. */\n      small {\n        font-size: 80%;\n      }\n\n      /**\n * * Prevent `sub` and `sup` affecting `line-height` in all browsers. */\n      sub {\n        font-size: 75%;\n        line-height: 0;\n        position: relative;\n        vertical-align: baseline;\n      }\n\n      sup {\n        font-size: 75%;\n        line-height: 0;\n        position: relative;\n        vertical-align: baseline;\n        top: -0.5em;\n      }\n\n      sub {\n        bottom: -0.25em;\n      }\n\n      /* ==========================================================================\n * * Lists\n * * ========================================================================== */\n      /**\n * * Address margins set differently in IE 6/7. */\n      dl,\n      menu,\n      ol,\n      ul {\n        margin: 1em 0;\n      }\n\n      dd {\n        margin: 0 0 0 40px;\n      }\n\n      /**\n * * Address paddings set differently in IE 6/7. */\n      menu,\n      ol,\n      ul {\n        padding: 0 0 0 40px;\n      }\n\n      /**\n * * Correct list images handled incorrectly in IE 7. */\n      nav ul,\n      nav ol {\n        list-style: none;\n        list-style-image: none;\n      }\n\n      /* ==========================================================================\n * * Embedded content\n * * ========================================================================== */\n      /**\n * * 1. Remove border when inside `a` element in IE 6/7/8/9 and Firefox 3.\n * * 2. Improve image quality when scaled in IE 7. */\n      img {\n        border: 0;\n        /* 1 */\n        -ms-interpolation-mode: bicubic;\n      }\n\n      /* 2 */\n      /**\n * * Correct overflow displayed oddly in IE 9. */\n      svg:not(:root) {\n        overflow: hidden;\n      }\n\n      /* ==========================================================================\n * * Figures\n * * ========================================================================== */\n      /**\n * * Address margin not present in IE 6/7/8/9, Safari 5, and Opera 11. */\n      figure,\n      form {\n        margin: 0;\n      }\n\n      /* ==========================================================================\n * * Forms\n * * ========================================================================== */\n      /**\n * * Correct margin displayed oddly in IE 6/7. */\n      /**\n * * Define consistent border, margin, and padding. */\n      fieldset {\n        border: 1px solid #c0c0c0;\n        margin: 0 2px;\n        padding: 0.35em 0.625em 0.75em;\n      }\n\n      /**\n * * 1. Correct color not being inherited in IE 6/7/8/9.\n * * 2. Correct text not wrapping in Firefox 3.\n * * 3. Correct alignment displayed oddly in IE 6/7. */\n      legend {\n        border: 0;\n        /* 1 */\n        padding: 0;\n        white-space: normal;\n        /* 2 */\n        *margin-left: -7px;\n      }\n\n      /* 3 */\n      /**\n * * 1. Correct font size not being inherited in all browsers.\n * * 2. Address margins set differently in IE 6/7, Firefox 3+, Safari 5,\n * *    and Chrome.\n * * 3. Improve appearance and consistency in all browsers. */\n      button,\n      input,\n      select,\n      textarea {\n        font-size: 100%;\n        /* 1 */\n        margin: 0;\n        /* 2 */\n        vertical-align: baseline;\n        /* 3 */\n        *vertical-align: middle;\n      }\n\n      /* 3 */\n      /**\n * * Address Firefox 3+ setting `line-height` on `input` using `!important` in\n * * the UA stylesheet. */\n      button,\n      input {\n        line-height: normal;\n      }\n\n      /**\n * * Address inconsistent `text-transform` inheritance for `button` and `select`.\n * * All other form control elements do not inherit `text-transform` values.\n * * Correct `button` style inheritance in Chrome, Safari 5+, and IE 6+.\n * * Correct `select` style inheritance in Firefox 4+ and Opera. */\n      button,\n      select {\n        text-transform: none;\n      }\n\n      /**\n * * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`\n * *    and `video` controls.\n * * 2. Correct inability to style clickable `input` types in iOS.\n * * 3. Improve usability and consistency of cursor style between image-type\n * *    `input` and others.\n * * 4. Remove inner spacing in IE 7 without affecting normal text inputs.\n * *    Known issue: inner spacing remains in IE 6. */\n      button,\n      html input[type='button'] {\n        -webkit-appearance: button;\n        /* 2 */\n        cursor: pointer;\n        /* 3 */\n        *overflow: visible;\n      }\n\n      /* 4 */\n      input[type='reset'],\n      input[type='submit'] {\n        -webkit-appearance: button;\n        /* 2 */\n        cursor: pointer;\n        /* 3 */\n        *overflow: visible;\n      }\n\n      /* 4 */\n      /**\n * * Re-set default cursor for disabled elements. */\n      button[disabled],\n      html input[disabled] {\n        cursor: default;\n      }\n\n      /**\n * * 1. Address box sizing set to content-box in IE 8/9.\n * * 2. Remove excess padding in IE 8/9.\n * * 3. Remove excess padding in IE 7.\n * *    Known issue: excess padding remains in IE 6. */\n      input {\n        /* 3 */\n      }\n      input[type='checkbox'],\n      input[type='radio'] {\n        box-sizing: border-box;\n        /* 1 */\n        padding: 0;\n        /* 2 */\n        *height: 13px;\n        /* 3 */\n        *width: 13px;\n      }\n      input[type='search'] {\n        -webkit-appearance: textfield;\n        /* 1 */\n        -moz-box-sizing: content-box;\n        -webkit-box-sizing: content-box;\n        /* 2 */\n        box-sizing: content-box;\n      }\n      input[type='search']::-webkit-search-cancel-button,\n      input[type='search']::-webkit-search-decoration {\n        -webkit-appearance: none;\n      }\n\n      /**\n * * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome.\n * * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome\n * *    (include `-moz` to future-proof). */\n      /**\n * * Remove inner padding and search cancel button in Safari 5 and Chrome\n * * on OS X. */\n      /**\n * * Remove inner padding and border in Firefox 3+. */\n      button::-moz-focus-inner,\n      input::-moz-focus-inner {\n        border: 0;\n        padding: 0;\n      }\n\n      /**\n * * 1. Remove default vertical scrollbar in IE 6/7/8/9.\n * * 2. Improve readability and alignment in all browsers. */\n      textarea {\n        overflow: auto;\n        /* 1 */\n        vertical-align: top;\n      }\n\n      /* 2 */\n      /* ==========================================================================\n * * Tables\n * * ========================================================================== */\n      /**\n * * Remove most spacing between table cells. */\n      table {\n        border-collapse: collapse;\n        border-spacing: 0;\n      }\n\n      ul.tsd-descriptions > li > :first-child,\n      .tsd-panel > :first-child,\n      .col > :first-child,\n      .col-11 > :first-child,\n      .col-10 > :first-child,\n      .col-9 > :first-child,\n      .col-8 > :first-child,\n      .col-7 > :first-child,\n      .col-6 > :first-child,\n      .col-5 > :first-child,\n      .col-4 > :first-child,\n      .col-3 > :first-child,\n      .col-2 > :first-child,\n      .col-1 > :first-child,\n      ul.tsd-descriptions > li > :first-child > :first-child,\n      .tsd-panel > :first-child > :first-child,\n      .col > :first-child > :first-child,\n      .col-11 > :first-child > :first-child,\n      .col-10 > :first-child > :first-child,\n      .col-9 > :first-child > :first-child,\n      .col-8 > :first-child > :first-child,\n      .col-7 > :first-child > :first-child,\n      .col-6 > :first-child > :first-child,\n      .col-5 > :first-child > :first-child,\n      .col-4 > :first-child > :first-child,\n      .col-3 > :first-child > :first-child,\n      .col-2 > :first-child > :first-child,\n      .col-1 > :first-child > :first-child,\n      ul.tsd-descriptions > li > :first-child > :first-child > :first-child,\n      .tsd-panel > :first-child > :first-child > :first-child,\n      .col > :first-child > :first-child > :first-child,\n      .col-11 > :first-child > :first-child > :first-child,\n      .col-10 > :first-child > :first-child > :first-child,\n      .col-9 > :first-child > :first-child > :first-child,\n      .col-8 > :first-child > :first-child > :first-child,\n      .col-7 > :first-child > :first-child > :first-child,\n      .col-6 > :first-child > :first-child > :first-child,\n      .col-5 > :first-child > :first-child > :first-child,\n      .col-4 > :first-child > :first-child > :first-child,\n      .col-3 > :first-child > :first-child > :first-child,\n      .col-2 > :first-child > :first-child > :first-child,\n      .col-1 > :first-child > :first-child > :first-child {\n        margin-top: 0;\n      }\n      ul.tsd-descriptions > li > :last-child,\n      .tsd-panel > :last-child,\n      .col > :last-child,\n      .col-11 > :last-child,\n      .col-10 > :last-child,\n      .col-9 > :last-child,\n      .col-8 > :last-child,\n      .col-7 > :last-child,\n      .col-6 > :last-child,\n      .col-5 > :last-child,\n      .col-4 > :last-child,\n      .col-3 > :last-child,\n      .col-2 > :last-child,\n      .col-1 > :last-child,\n      ul.tsd-descriptions > li > :last-child > :last-child,\n      .tsd-panel > :last-child > :last-child,\n      .col > :last-child > :last-child,\n      .col-11 > :last-child > :last-child,\n      .col-10 > :last-child > :last-child,\n      .col-9 > :last-child > :last-child,\n      .col-8 > :last-child > :last-child,\n      .col-7 > :last-child > :last-child,\n      .col-6 > :last-child > :last-child,\n      .col-5 > :last-child > :last-child,\n      .col-4 > :last-child > :last-child,\n      .col-3 > :last-child > :last-child,\n      .col-2 > :last-child > :last-child,\n      .col-1 > :last-child > :last-child,\n      ul.tsd-descriptions > li > :last-child > :last-child > :last-child,\n      .tsd-panel > :last-child > :last-child > :last-child,\n      .col > :last-child > :last-child > :last-child,\n      .col-11 > :last-child > :last-child > :last-child,\n      .col-10 > :last-child > :last-child > :last-child,\n      .col-9 > :last-child > :last-child > :last-child,\n      .col-8 > :last-child > :last-child > :last-child,\n      .col-7 > :last-child > :last-child > :last-child,\n      .col-6 > :last-child > :last-child > :last-child,\n      .col-5 > :last-child > :last-child > :last-child,\n      .col-4 > :last-child > :last-child > :last-child,\n      .col-3 > :last-child > :last-child > :last-child,\n      .col-2 > :last-child > :last-child > :last-child,\n      .col-1 > :last-child > :last-child > :last-child {\n        margin-bottom: 0;\n      }\n\n      .container {\n        max-width: 1200px;\n        margin: 0 auto;\n        padding: 0 40px;\n      }\n      @media (max-width: 640px) {\n        .container {\n          padding: 0 20px;\n        }\n      }\n\n      .container-main {\n        padding-bottom: 200px;\n      }\n\n      .row {\n        display: flex;\n        position: relative;\n        margin: 0 -10px;\n      }\n      .row:after {\n        visibility: hidden;\n        display: block;\n        content: '';\n        clear: both;\n        height: 0;\n      }\n\n      .col,\n      .col-11,\n      .col-10,\n      .col-9,\n      .col-8,\n      .col-7,\n      .col-6,\n      .col-5,\n      .col-4,\n      .col-3,\n      .col-2,\n      .col-1 {\n        box-sizing: border-box;\n        float: left;\n        padding: 0 10px;\n      }\n\n      .col-1 {\n        width: 8.3333333333%;\n      }\n\n      .offset-1 {\n        margin-left: 8.3333333333%;\n      }\n\n      .col-2 {\n        width: 16.6666666667%;\n      }\n\n      .offset-2 {\n        margin-left: 16.6666666667%;\n      }\n\n      .col-3 {\n        width: 25%;\n      }\n\n      .offset-3 {\n        margin-left: 25%;\n      }\n\n      .col-4 {\n        width: 33.3333333333%;\n      }\n\n      .offset-4 {\n        margin-left: 33.3333333333%;\n      }\n\n      .col-5 {\n        width: 41.6666666667%;\n      }\n\n      .offset-5 {\n        margin-left: 41.6666666667%;\n      }\n\n      .col-6 {\n        width: 50%;\n      }\n\n      .offset-6 {\n        margin-left: 50%;\n      }\n\n      .col-7 {\n        width: 58.3333333333%;\n      }\n\n      .offset-7 {\n        margin-left: 58.3333333333%;\n      }\n\n      .col-8 {\n        width: 66.6666666667%;\n      }\n\n      .offset-8 {\n        margin-left: 66.6666666667%;\n      }\n\n      .col-9 {\n        width: 75%;\n      }\n\n      .offset-9 {\n        margin-left: 75%;\n      }\n\n      .col-10 {\n        width: 83.3333333333%;\n      }\n\n      .offset-10 {\n        margin-left: 83.3333333333%;\n      }\n\n      .col-11 {\n        width: 91.6666666667%;\n      }\n\n      .offset-11 {\n        margin-left: 91.6666666667%;\n      }\n\n      .tsd-kind-icon {\n        display: block;\n        position: relative;\n        padding-left: 20px;\n        text-indent: -20px;\n      }\n      .tsd-kind-icon:before {\n        content: '';\n        display: inline-block;\n        vertical-align: middle;\n        width: 17px;\n        height: 17px;\n        margin: 0 3px 2px 0;\n        background-image: url(data:image/png;base64,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);\n      }\n      @media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) {\n        .tsd-kind-icon:before {\n          background-image: url(data:image/png;base64,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);\n          background-size: 238px 204px;\n        }\n      }\n\n      .tsd-signature.tsd-kind-icon:before {\n        background-position: 0 -153px;\n      }\n\n      .tsd-kind-object-literal > .tsd-kind-icon:before {\n        background-position: 0px -17px;\n      }\n      .tsd-kind-object-literal.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -17px;\n      }\n      .tsd-kind-object-literal.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -17px;\n      }\n\n      .tsd-kind-class > .tsd-kind-icon:before {\n        background-position: 0px -34px;\n      }\n      .tsd-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -34px;\n      }\n      .tsd-kind-class.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -34px;\n      }\n\n      .tsd-kind-class.tsd-has-type-parameter > .tsd-kind-icon:before {\n        background-position: 0px -51px;\n      }\n      .tsd-kind-class.tsd-has-type-parameter.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -17px -51px;\n      }\n      .tsd-kind-class.tsd-has-type-parameter.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -34px -51px;\n      }\n\n      .tsd-kind-interface > .tsd-kind-icon:before {\n        background-position: 0px -68px;\n      }\n      .tsd-kind-interface.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -68px;\n      }\n      .tsd-kind-interface.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -68px;\n      }\n\n      .tsd-kind-interface.tsd-has-type-parameter > .tsd-kind-icon:before {\n        background-position: 0px -85px;\n      }\n      .tsd-kind-interface.tsd-has-type-parameter.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -17px -85px;\n      }\n      .tsd-kind-interface.tsd-has-type-parameter.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -34px -85px;\n      }\n\n      .tsd-kind-namespace > .tsd-kind-icon:before {\n        background-position: 0px -102px;\n      }\n      .tsd-kind-namespace.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -102px;\n      }\n      .tsd-kind-namespace.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -102px;\n      }\n\n      .tsd-kind-module > .tsd-kind-icon:before {\n        background-position: 0px -102px;\n      }\n      .tsd-kind-module.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -102px;\n      }\n      .tsd-kind-module.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -102px;\n      }\n\n      .tsd-kind-enum > .tsd-kind-icon:before {\n        background-position: 0px -119px;\n      }\n      .tsd-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -119px;\n      }\n      .tsd-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -119px;\n      }\n\n      .tsd-kind-enum-member > .tsd-kind-icon:before {\n        background-position: 0px -136px;\n      }\n      .tsd-kind-enum-member.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -136px;\n      }\n      .tsd-kind-enum-member.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -136px;\n      }\n\n      .tsd-kind-signature > .tsd-kind-icon:before {\n        background-position: 0px -153px;\n      }\n      .tsd-kind-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -153px;\n      }\n      .tsd-kind-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -153px;\n      }\n\n      .tsd-kind-type-alias > .tsd-kind-icon:before {\n        background-position: 0px -170px;\n      }\n      .tsd-kind-type-alias.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -170px;\n      }\n      .tsd-kind-type-alias.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -170px;\n      }\n\n      .tsd-kind-type-alias.tsd-has-type-parameter > .tsd-kind-icon:before {\n        background-position: 0px -187px;\n      }\n      .tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -17px -187px;\n      }\n      .tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -34px -187px;\n      }\n\n      .tsd-kind-variable > .tsd-kind-icon:before {\n        background-position: -136px -0px;\n      }\n      .tsd-kind-variable.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -0px;\n      }\n      .tsd-kind-variable.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -0px;\n      }\n\n      .tsd-kind-property > .tsd-kind-icon:before {\n        background-position: -136px -0px;\n      }\n      .tsd-kind-property.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -0px;\n      }\n      .tsd-kind-property.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -0px;\n      }\n\n      .tsd-kind-get-signature > .tsd-kind-icon:before {\n        background-position: -136px -17px;\n      }\n      .tsd-kind-get-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -17px;\n      }\n      .tsd-kind-get-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -17px;\n      }\n\n      .tsd-kind-set-signature > .tsd-kind-icon:before {\n        background-position: -136px -34px;\n      }\n      .tsd-kind-set-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -34px;\n      }\n      .tsd-kind-set-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -34px;\n      }\n\n      .tsd-kind-accessor > .tsd-kind-icon:before {\n        background-position: -136px -51px;\n      }\n      .tsd-kind-accessor.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -51px;\n      }\n      .tsd-kind-accessor.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -51px;\n      }\n\n      .tsd-kind-function > .tsd-kind-icon:before {\n        background-position: -136px -68px;\n      }\n      .tsd-kind-function.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -68px;\n      }\n      .tsd-kind-function.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -68px;\n      }\n\n      .tsd-kind-method > .tsd-kind-icon:before {\n        background-position: -136px -68px;\n      }\n      .tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -68px;\n      }\n      .tsd-kind-method.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -68px;\n      }\n\n      .tsd-kind-call-signature > .tsd-kind-icon:before {\n        background-position: -136px -68px;\n      }\n      .tsd-kind-call-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -68px;\n      }\n      .tsd-kind-call-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -68px;\n      }\n\n      .tsd-kind-function.tsd-has-type-parameter > .tsd-kind-icon:before {\n        background-position: -136px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -153px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -85px;\n      }\n\n      .tsd-kind-method.tsd-has-type-parameter > .tsd-kind-icon:before {\n        background-position: -136px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -153px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -85px;\n      }\n\n      .tsd-kind-constructor > .tsd-kind-icon:before {\n        background-position: -136px -102px;\n      }\n      .tsd-kind-constructor.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -102px;\n      }\n      .tsd-kind-constructor.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -102px;\n      }\n\n      .tsd-kind-constructor-signature > .tsd-kind-icon:before {\n        background-position: -136px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -102px;\n      }\n\n      .tsd-kind-index-signature > .tsd-kind-icon:before {\n        background-position: -136px -119px;\n      }\n      .tsd-kind-index-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -119px;\n      }\n      .tsd-kind-index-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -119px;\n      }\n\n      .tsd-kind-event > .tsd-kind-icon:before {\n        background-position: -136px -136px;\n      }\n      .tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -136px;\n      }\n      .tsd-kind-event.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -136px;\n      }\n\n      .tsd-is-static > .tsd-kind-icon:before {\n        background-position: -136px -153px;\n      }\n      .tsd-is-static.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -153px;\n      }\n      .tsd-is-static.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -153px;\n      }\n\n      .tsd-is-static.tsd-kind-function > .tsd-kind-icon:before {\n        background-position: -136px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -153px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -170px;\n      }\n\n      .tsd-is-static.tsd-kind-method > .tsd-kind-icon:before {\n        background-position: -136px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -170px;\n      }\n\n      .tsd-is-static.tsd-kind-call-signature > .tsd-kind-icon:before {\n        background-position: -136px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -153px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -170px;\n      }\n\n      .tsd-is-static.tsd-kind-event > .tsd-kind-icon:before {\n        background-position: -136px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -187px;\n      }\n\n      @keyframes fade-in {\n        from {\n          opacity: 0;\n        }\n        to {\n          opacity: 1;\n        }\n      }\n      @keyframes fade-out {\n        from {\n          opacity: 1;\n          visibility: visible;\n        }\n        to {\n          opacity: 0;\n        }\n      }\n      @keyframes fade-in-delayed {\n        0% {\n          opacity: 0;\n        }\n        33% {\n          opacity: 0;\n        }\n        100% {\n          opacity: 1;\n        }\n      }\n      @keyframes fade-out-delayed {\n        0% {\n          opacity: 1;\n          visibility: visible;\n        }\n        66% {\n          opacity: 0;\n        }\n        100% {\n          opacity: 0;\n        }\n      }\n      @keyframes shift-to-left {\n        from {\n          transform: translate(0, 0);\n        }\n        to {\n          transform: translate(-25%, 0);\n        }\n      }\n      @keyframes unshift-to-left {\n        from {\n          transform: translate(-25%, 0);\n        }\n        to {\n          transform: translate(0, 0);\n        }\n      }\n      @keyframes pop-in-from-right {\n        from {\n          transform: translate(100%, 0);\n        }\n        to {\n          transform: translate(0, 0);\n        }\n      }\n      @keyframes pop-out-to-right {\n        from {\n          transform: translate(0, 0);\n          visibility: visible;\n        }\n        to {\n          transform: translate(100%, 0);\n        }\n      }\n      body {\n        background: var(--color-background);\n        font-family: 'Segoe UI', sans-serif;\n        font-size: 16px;\n        color: var(--color-text);\n      }\n\n      a {\n        color: var(--color-link);\n        text-decoration: none;\n      }\n      a:hover {\n        text-decoration: underline;\n      }\n\n      code,\n      pre {\n        font-family: Menlo, Monaco, Consolas, 'Courier New', monospace;\n        padding: 0.2em;\n        margin: 0;\n        font-size: 14px;\n        background-color: var(--color-code-background);\n      }\n\n      pre {\n        padding: 10px;\n      }\n      pre code {\n        padding: 0;\n        font-size: 100%;\n        background-color: transparent;\n      }\n\n      blockquote {\n        margin: 1em 0;\n        padding-left: 1em;\n        border-left: 4px solid gray;\n      }\n\n      .tsd-typography {\n        line-height: 1.333em;\n      }\n      .tsd-typography ul {\n        list-style: square;\n        padding: 0 0 0 20px;\n        margin: 0;\n      }\n      .tsd-typography h4,\n      .tsd-typography .tsd-index-panel h3,\n      .tsd-index-panel .tsd-typography h3,\n      .tsd-typography h5,\n      .tsd-typography h6 {\n        font-size: 1em;\n        margin: 0;\n      }\n      .tsd-typography h5,\n      .tsd-typography h6 {\n        font-weight: normal;\n      }\n      .tsd-typography p,\n      .tsd-typography ul,\n      .tsd-typography ol {\n        margin: 1em 0;\n      }\n\n      @media (min-width: 901px) and (max-width: 1024px) {\n        html.default .col-content {\n          width: 72%;\n        }\n        html.default .col-menu {\n          width: 28%;\n        }\n        html.default .tsd-navigation {\n          padding-left: 10px;\n        }\n      }\n      @media (max-width: 900px) {\n        html.default .col-content {\n          float: none;\n          width: 100%;\n        }\n        html.default .col-menu {\n          position: fixed !important;\n          overflow: auto;\n          -webkit-overflow-scrolling: touch;\n          z-index: 1024;\n          top: 0 !important;\n          bottom: 0 !important;\n          left: auto !important;\n          right: 0 !important;\n          width: 100%;\n          padding: 20px 20px 0 0;\n          max-width: 450px;\n          visibility: hidden;\n          background-color: var(--color-panel);\n          transform: translate(100%, 0);\n        }\n        html.default .col-menu > *:last-child {\n          padding-bottom: 20px;\n        }\n        html.default .overlay {\n          content: '';\n          display: block;\n          position: fixed;\n          z-index: 1023;\n          top: 0;\n          left: 0;\n          right: 0;\n          bottom: 0;\n          background-color: rgba(0, 0, 0, 0.75);\n          visibility: hidden;\n        }\n        html.default.to-has-menu .overlay {\n          animation: fade-in 0.4s;\n        }\n        html.default.to-has-menu header,\n        html.default.to-has-menu footer,\n        html.default.to-has-menu .col-content {\n          animation: shift-to-left 0.4s;\n        }\n        html.default.to-has-menu .col-menu {\n          animation: pop-in-from-right 0.4s;\n        }\n        html.default.from-has-menu .overlay {\n          animation: fade-out 0.4s;\n        }\n        html.default.from-has-menu header,\n        html.default.from-has-menu footer,\n        html.default.from-has-menu .col-content {\n          animation: unshift-to-left 0.4s;\n        }\n        html.default.from-has-menu .col-menu {\n          animation: pop-out-to-right 0.4s;\n        }\n        html.default.has-menu body {\n          overflow: hidden;\n        }\n        html.default.has-menu .overlay {\n          visibility: visible;\n        }\n        html.default.has-menu header,\n        html.default.has-menu footer,\n        html.default.has-menu .col-content {\n          transform: translate(-25%, 0);\n        }\n        html.default.has-menu .col-menu {\n          visibility: visible;\n          transform: translate(0, 0);\n        }\n      }\n\n      .tsd-page-title {\n        padding: 70px 0 20px 0;\n        margin: 0 0 40px 0;\n        background: var(--color-panel);\n        box-shadow: 0 0 5px rgba(0, 0, 0, 0.35);\n      }\n      .tsd-page-title h1 {\n        margin: 0;\n      }\n\n      .tsd-breadcrumb {\n        margin: 0;\n        padding: 0;\n        color: var(--color-text-aside);\n      }\n      .tsd-breadcrumb a {\n        color: var(--color-text-aside);\n        text-decoration: none;\n      }\n      .tsd-breadcrumb a:hover {\n        text-decoration: underline;\n      }\n      .tsd-breadcrumb li {\n        display: inline;\n      }\n      .tsd-breadcrumb li:after {\n        content: ' / ';\n      }\n\n      html.minimal .container {\n        margin: 0;\n      }\n      html.minimal .container-main {\n        padding-top: 50px;\n        padding-bottom: 0;\n      }\n      html.minimal .content-wrap {\n        padding-left: 300px;\n      }\n      html.minimal .tsd-navigation {\n        position: fixed !important;\n        overflow: auto;\n        -webkit-overflow-scrolling: touch;\n        box-sizing: border-box;\n        z-index: 1;\n        left: 0;\n        top: 40px;\n        bottom: 0;\n        width: 300px;\n        padding: 20px;\n        margin: 0;\n      }\n      html.minimal .tsd-member .tsd-member {\n        margin-left: 0;\n      }\n      html.minimal .tsd-page-toolbar {\n        position: fixed;\n        z-index: 2;\n      }\n      html.minimal #tsd-filter .tsd-filter-group {\n        right: 0;\n        transform: none;\n      }\n      html.minimal footer {\n        background-color: transparent;\n      }\n      html.minimal footer .container {\n        padding: 0;\n      }\n      html.minimal .tsd-generator {\n        padding: 0;\n      }\n      @media (max-width: 900px) {\n        html.minimal .tsd-navigation {\n          display: none;\n        }\n        html.minimal .content-wrap {\n          padding-left: 0;\n        }\n      }\n\n      dl.tsd-comment-tags {\n        overflow: hidden;\n      }\n      dl.tsd-comment-tags dt {\n        float: left;\n        padding: 1px 5px;\n        margin: 0 10px 0 0;\n        border-radius: 4px;\n        border: 1px solid var(--color-comment-tag);\n        color: var(--color-comment-tag);\n        font-size: 0.8em;\n        font-weight: normal;\n      }\n      dl.tsd-comment-tags dd {\n        margin: 0 0 10px 0;\n      }\n      dl.tsd-comment-tags dd:before,\n      dl.tsd-comment-tags dd:after {\n        display: table;\n        content: ' ';\n      }\n      dl.tsd-comment-tags dd pre,\n      dl.tsd-comment-tags dd:after {\n        clear: both;\n      }\n      dl.tsd-comment-tags p {\n        margin: 0;\n      }\n\n      .tsd-panel.tsd-comment .lead {\n        font-size: 1.1em;\n        line-height: 1.333em;\n        margin-bottom: 2em;\n      }\n      .tsd-panel.tsd-comment .lead:last-child {\n        margin-bottom: 0;\n      }\n\n      .toggle-protected .tsd-is-private {\n        display: none;\n      }\n\n      .toggle-public .tsd-is-private,\n      .toggle-public .tsd-is-protected,\n      .toggle-public .tsd-is-private-protected {\n        display: none;\n      }\n\n      .toggle-inherited .tsd-is-inherited {\n        display: none;\n      }\n\n      .toggle-externals .tsd-is-external {\n        display: none;\n      }\n\n      #tsd-filter {\n        position: relative;\n        display: inline-block;\n        height: 40px;\n        vertical-align: bottom;\n      }\n      .no-filter #tsd-filter {\n        display: none;\n      }\n      #tsd-filter .tsd-filter-group {\n        display: inline-block;\n        height: 40px;\n        vertical-align: bottom;\n        white-space: nowrap;\n      }\n      #tsd-filter input {\n        display: none;\n      }\n      @media (max-width: 900px) {\n        #tsd-filter .tsd-filter-group {\n          display: block;\n          position: absolute;\n          top: 40px;\n          right: 20px;\n          height: auto;\n          background-color: var(--color-panel);\n          visibility: hidden;\n          transform: translate(50%, 0);\n          box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n        }\n        .has-options #tsd-filter .tsd-filter-group {\n          visibility: visible;\n        }\n        .to-has-options #tsd-filter .tsd-filter-group {\n          animation: fade-in 0.2s;\n        }\n        .from-has-options #tsd-filter .tsd-filter-group {\n          animation: fade-out 0.2s;\n        }\n        #tsd-filter label,\n        #tsd-filter .tsd-select {\n          display: block;\n          padding-right: 20px;\n        }\n      }\n\n      footer {\n        border-top: 1px solid var(--color-panel-divider);\n        background-color: var(--color-panel);\n      }\n      footer.with-border-bottom {\n        border-bottom: 1px solid var(--color-panel-divider);\n      }\n      footer .tsd-legend-group {\n        font-size: 0;\n      }\n      footer .tsd-legend {\n        display: inline-block;\n        width: 25%;\n        padding: 0;\n        font-size: 16px;\n        list-style: none;\n        line-height: 1.333em;\n        vertical-align: top;\n      }\n      @media (max-width: 900px) {\n        footer .tsd-legend {\n          width: 50%;\n        }\n      }\n\n      .tsd-hierarchy {\n        list-style: square;\n        padding: 0 0 0 20px;\n        margin: 0;\n      }\n      .tsd-hierarchy .target {\n        font-weight: bold;\n      }\n\n      .tsd-index-panel .tsd-index-content {\n        margin-bottom: -30px !important;\n      }\n      .tsd-index-panel .tsd-index-section {\n        margin-bottom: 30px !important;\n      }\n      .tsd-index-panel h3 {\n        margin: 0 -20px 10px -20px;\n        padding: 0 20px 10px 20px;\n        border-bottom: 1px solid var(--color-panel-divider);\n      }\n      .tsd-index-panel ul.tsd-index-list {\n        -webkit-column-count: 3;\n        -moz-column-count: 3;\n        -ms-column-count: 3;\n        -o-column-count: 3;\n        column-count: 3;\n        -webkit-column-gap: 20px;\n        -moz-column-gap: 20px;\n        -ms-column-gap: 20px;\n        -o-column-gap: 20px;\n        column-gap: 20px;\n        padding: 0;\n        list-style: none;\n        line-height: 1.333em;\n      }\n      @media (max-width: 900px) {\n        .tsd-index-panel ul.tsd-index-list {\n          -webkit-column-count: 1;\n          -moz-column-count: 1;\n          -ms-column-count: 1;\n          -o-column-count: 1;\n          column-count: 1;\n        }\n      }\n      @media (min-width: 901px) and (max-width: 1024px) {\n        .tsd-index-panel ul.tsd-index-list {\n          -webkit-column-count: 2;\n          -moz-column-count: 2;\n          -ms-column-count: 2;\n          -o-column-count: 2;\n          column-count: 2;\n        }\n      }\n      .tsd-index-panel ul.tsd-index-list li {\n        -webkit-page-break-inside: avoid;\n        -moz-page-break-inside: avoid;\n        -ms-page-break-inside: avoid;\n        -o-page-break-inside: avoid;\n        page-break-inside: avoid;\n      }\n      .tsd-index-panel a,\n      .tsd-index-panel .tsd-parent-kind-module a {\n        color: var(--color-ts);\n      }\n      .tsd-index-panel .tsd-parent-kind-interface a {\n        color: var(--color-ts-interface);\n      }\n      .tsd-index-panel .tsd-parent-kind-enum a {\n        color: var(--color-ts-enum);\n      }\n      .tsd-index-panel .tsd-parent-kind-class a {\n        color: var(--color-ts-class);\n      }\n      .tsd-index-panel .tsd-kind-module a {\n        color: var(--color-ts);\n      }\n      .tsd-index-panel .tsd-kind-interface a {\n        color: var(--color-ts-interface);\n      }\n      .tsd-index-panel .tsd-kind-enum a {\n        color: var(--color-ts-enum);\n      }\n      .tsd-index-panel .tsd-kind-class a {\n        color: var(--color-ts-class);\n      }\n      .tsd-index-panel .tsd-is-private a {\n        color: var(--color-ts-private);\n      }\n\n      .tsd-flag {\n        display: inline-block;\n        padding: 1px 5px;\n        border-radius: 4px;\n        color: var(--color-comment-tag-text);\n        background-color: var(--color-comment-tag);\n        text-indent: 0;\n        font-size: 14px;\n        font-weight: normal;\n      }\n\n      .tsd-anchor {\n        position: absolute;\n        top: -100px;\n      }\n\n      .tsd-member {\n        position: relative;\n      }\n      .tsd-member .tsd-anchor + h3 {\n        margin-top: 0;\n        margin-bottom: 0;\n        border-bottom: none;\n      }\n      .tsd-member a[data-tsd-kind] {\n        color: var(--color-ts);\n      }\n      .tsd-member a[data-tsd-kind='Interface'] {\n        color: var(--color-ts-interface);\n      }\n      .tsd-member a[data-tsd-kind='Enum'] {\n        color: var(--color-ts-enum);\n      }\n      .tsd-member a[data-tsd-kind='Class'] {\n        color: var(--color-ts-class);\n      }\n      .tsd-member a[data-tsd-kind='Private'] {\n        color: var(--color-ts-private);\n      }\n\n      .tsd-navigation {\n        margin: 0 0 0 40px;\n      }\n      .tsd-navigation a {\n        display: block;\n        padding-top: 2px;\n        padding-bottom: 2px;\n        border-left: 2px solid transparent;\n        color: var(--color-text);\n        text-decoration: none;\n        transition: border-left-color 0.1s;\n      }\n      .tsd-navigation a:hover {\n        text-decoration: underline;\n      }\n      .tsd-navigation ul {\n        margin: 0;\n        padding: 0;\n        list-style: none;\n      }\n      .tsd-navigation li {\n        padding: 0;\n      }\n\n      .tsd-navigation.primary {\n        padding-bottom: 40px;\n      }\n      .tsd-navigation.primary a {\n        display: block;\n        padding-top: 6px;\n        padding-bottom: 6px;\n      }\n      .tsd-navigation.primary ul li a {\n        padding-left: 5px;\n      }\n      .tsd-navigation.primary ul li li a {\n        padding-left: 25px;\n      }\n      .tsd-navigation.primary ul li li li a {\n        padding-left: 45px;\n      }\n      .tsd-navigation.primary ul li li li li a {\n        padding-left: 65px;\n      }\n      .tsd-navigation.primary ul li li li li li a {\n        padding-left: 85px;\n      }\n      .tsd-navigation.primary ul li li li li li li a {\n        padding-left: 105px;\n      }\n      .tsd-navigation.primary > ul {\n        border-bottom: 1px solid var(--color-panel-divider);\n      }\n      .tsd-navigation.primary li {\n        border-top: 1px solid var(--color-panel-divider);\n      }\n      .tsd-navigation.primary li.current > a {\n        font-weight: bold;\n      }\n      .tsd-navigation.primary li.label span {\n        display: block;\n        padding: 20px 0 6px 5px;\n        color: var(--color-menu-label);\n      }\n      .tsd-navigation.primary li.globals + li > span,\n      .tsd-navigation.primary li.globals + li > a {\n        padding-top: 20px;\n      }\n\n      .tsd-navigation.secondary {\n        max-height: calc(100vh - 1rem - 40px);\n        overflow: auto;\n        position: -webkit-sticky;\n        position: sticky;\n        top: calc(0.5rem + 40px);\n        transition: 0.3s;\n      }\n      .tsd-navigation.secondary.tsd-navigation--toolbar-hide {\n        max-height: calc(100vh - 1rem);\n        top: 0.5rem;\n      }\n      .tsd-navigation.secondary ul {\n        transition: opacity 0.2s;\n      }\n      .tsd-navigation.secondary ul li a {\n        padding-left: 25px;\n      }\n      .tsd-navigation.secondary ul li li a {\n        padding-left: 45px;\n      }\n      .tsd-navigation.secondary ul li li li a {\n        padding-left: 65px;\n      }\n      .tsd-navigation.secondary ul li li li li a {\n        padding-left: 85px;\n      }\n      .tsd-navigation.secondary ul li li li li li a {\n        padding-left: 105px;\n      }\n      .tsd-navigation.secondary ul li li li li li li a {\n        padding-left: 125px;\n      }\n      .tsd-navigation.secondary ul.current a {\n        border-left-color: var(--color-panel-divider);\n      }\n      .tsd-navigation.secondary li.focus > a,\n      .tsd-navigation.secondary ul.current li.focus > a {\n        border-left-color: var(--color-menu-divider-focus);\n      }\n      .tsd-navigation.secondary li.current {\n        margin-top: 20px;\n        margin-bottom: 20px;\n        border-left-color: var(--color-panel-divider);\n      }\n      .tsd-navigation.secondary li.current > a {\n        font-weight: bold;\n      }\n\n      @media (min-width: 901px) {\n        .menu-sticky-wrap {\n          position: static;\n        }\n      }\n\n      .tsd-panel {\n        margin: 20px 0;\n        padding: 20px;\n        background-color: var(--color-panel);\n        box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n      }\n      .tsd-panel:empty {\n        display: none;\n      }\n      .tsd-panel > h1,\n      .tsd-panel > h2,\n      .tsd-panel > h3 {\n        margin: 1.5em -20px 10px -20px;\n        padding: 0 20px 10px 20px;\n        border-bottom: 1px solid var(--color-panel-divider);\n      }\n      .tsd-panel > h1.tsd-before-signature,\n      .tsd-panel > h2.tsd-before-signature,\n      .tsd-panel > h3.tsd-before-signature {\n        margin-bottom: 0;\n        border-bottom: 0;\n      }\n      .tsd-panel table {\n        display: block;\n        width: 100%;\n        overflow: auto;\n        margin-top: 10px;\n        word-break: normal;\n        word-break: keep-all;\n      }\n      .tsd-panel table th {\n        font-weight: bold;\n      }\n      .tsd-panel table th,\n      .tsd-panel table td {\n        padding: 6px 13px;\n        border: 1px solid #ddd;\n      }\n      .tsd-panel table tr {\n        background-color: #fff;\n        border-top: 1px solid #ccc;\n      }\n      .tsd-panel table tr:nth-child(2n) {\n        background-color: #f8f8f8;\n      }\n\n      .tsd-panel-group {\n        margin: 60px 0;\n      }\n      .tsd-panel-group > h1,\n      .tsd-panel-group > h2,\n      .tsd-panel-group > h3 {\n        padding-left: 20px;\n        padding-right: 20px;\n      }\n\n      #tsd-search {\n        transition: background-color 0.2s;\n      }\n      #tsd-search .title {\n        position: relative;\n        z-index: 2;\n      }\n      #tsd-search .field {\n        position: absolute;\n        left: 0;\n        top: 0;\n        right: 40px;\n        height: 40px;\n      }\n      #tsd-search .field input {\n        box-sizing: border-box;\n        position: relative;\n        top: -50px;\n        z-index: 1;\n        width: 100%;\n        padding: 0 10px;\n        opacity: 0;\n        outline: 0;\n        border: 0;\n        background: transparent;\n        color: var(--color-text);\n      }\n      #tsd-search .field label {\n        position: absolute;\n        overflow: hidden;\n        right: -40px;\n      }\n      #tsd-search .field input,\n      #tsd-search .title {\n        transition: opacity 0.2s;\n      }\n      #tsd-search .results {\n        position: absolute;\n        visibility: hidden;\n        top: 40px;\n        width: 100%;\n        margin: 0;\n        padding: 0;\n        list-style: none;\n        box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n      }\n      #tsd-search .results li {\n        padding: 0 10px;\n        background-color: var(--color-background);\n      }\n      #tsd-search .results li:nth-child(even) {\n        background-color: var(--color-panel);\n      }\n      #tsd-search .results li.state {\n        display: none;\n      }\n      #tsd-search .results li.current,\n      #tsd-search .results li:hover {\n        background-color: var(--color-panel-divider);\n      }\n      #tsd-search .results a {\n        display: block;\n      }\n      #tsd-search .results a:before {\n        top: 10px;\n      }\n      #tsd-search .results span.parent {\n        color: var(--color-text-aside);\n        font-weight: normal;\n      }\n      #tsd-search.has-focus {\n        background-color: var(--color-panel-divider);\n      }\n      #tsd-search.has-focus .field input {\n        top: 0;\n        opacity: 1;\n      }\n      #tsd-search.has-focus .title {\n        z-index: 0;\n        opacity: 0;\n      }\n      #tsd-search.has-focus .results {\n        visibility: visible;\n      }\n      #tsd-search.loading .results li.state.loading {\n        display: block;\n      }\n      #tsd-search.failure .results li.state.failure {\n        display: block;\n      }\n\n      .tsd-signature {\n        margin: 0 0 1em 0;\n        padding: 10px;\n        border: 1px solid var(--color-panel-divider);\n        font-family: Menlo, Monaco, Consolas, 'Courier New', monospace;\n        font-size: 14px;\n        overflow-x: auto;\n      }\n      .tsd-signature.tsd-kind-icon {\n        padding-left: 30px;\n      }\n      .tsd-signature.tsd-kind-icon:before {\n        top: 10px;\n        left: 10px;\n      }\n      .tsd-panel > .tsd-signature {\n        margin-left: -20px;\n        margin-right: -20px;\n        border-width: 1px 0;\n      }\n      .tsd-panel > .tsd-signature.tsd-kind-icon {\n        padding-left: 40px;\n      }\n      .tsd-panel > .tsd-signature.tsd-kind-icon:before {\n        left: 20px;\n      }\n\n      .tsd-signature-symbol {\n        color: var(--color-text-aside);\n        font-weight: normal;\n      }\n\n      .tsd-signature-type {\n        font-style: italic;\n        font-weight: normal;\n      }\n\n      .tsd-signatures {\n        padding: 0;\n        margin: 0 0 1em 0;\n        border: 1px solid var(--color-panel-divider);\n      }\n      .tsd-signatures .tsd-signature {\n        margin: 0;\n        border-width: 1px 0 0 0;\n        transition: background-color 0.1s;\n      }\n      .tsd-signatures .tsd-signature:first-child {\n        border-top-width: 0;\n      }\n      .tsd-signatures .tsd-signature.current {\n        background-color: var(--color-panel-divider);\n      }\n      .tsd-signatures.active > .tsd-signature {\n        cursor: pointer;\n      }\n      .tsd-panel > .tsd-signatures {\n        margin-left: -20px;\n        margin-right: -20px;\n        border-width: 1px 0;\n      }\n      .tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon {\n        padding-left: 40px;\n      }\n      .tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon:before {\n        left: 20px;\n      }\n      .tsd-panel > a.anchor + .tsd-signatures {\n        border-top-width: 0;\n        margin-top: -20px;\n      }\n\n      ul.tsd-descriptions {\n        position: relative;\n        overflow: hidden;\n        padding: 0;\n        list-style: none;\n      }\n      ul.tsd-descriptions.active > .tsd-description {\n        display: none;\n      }\n      ul.tsd-descriptions.active > .tsd-description.current {\n        display: block;\n      }\n      ul.tsd-descriptions.active > .tsd-description.fade-in {\n        animation: fade-in-delayed 0.3s;\n      }\n      ul.tsd-descriptions.active > .tsd-description.fade-out {\n        animation: fade-out-delayed 0.3s;\n        position: absolute;\n        display: block;\n        top: 0;\n        left: 0;\n        right: 0;\n        opacity: 0;\n        visibility: hidden;\n      }\n      ul.tsd-descriptions h4,\n      ul.tsd-descriptions .tsd-index-panel h3,\n      .tsd-index-panel ul.tsd-descriptions h3 {\n        font-size: 16px;\n        margin: 1em 0 0.5em 0;\n      }\n\n      ul.tsd-parameters,\n      ul.tsd-type-parameters {\n        list-style: square;\n        margin: 0;\n        padding-left: 20px;\n      }\n      ul.tsd-parameters > li.tsd-parameter-signature,\n      ul.tsd-type-parameters > li.tsd-parameter-signature {\n        list-style: none;\n        margin-left: -20px;\n      }\n      ul.tsd-parameters h5,\n      ul.tsd-type-parameters h5 {\n        font-size: 16px;\n        margin: 1em 0 0.5em 0;\n      }\n      ul.tsd-parameters .tsd-comment,\n      ul.tsd-type-parameters .tsd-comment {\n        margin-top: -0.5em;\n      }\n\n      .tsd-sources {\n        font-size: 14px;\n        color: var(--color-text-aside);\n        margin: 0 0 1em 0;\n      }\n      .tsd-sources a {\n        color: var(--color-text-aside);\n        text-decoration: underline;\n      }\n      .tsd-sources ul,\n      .tsd-sources p {\n        margin: 0 !important;\n      }\n      .tsd-sources ul {\n        list-style: none;\n        padding: 0;\n      }\n\n      .tsd-page-toolbar {\n        position: fixed;\n        z-index: 1;\n        top: 0;\n        left: 0;\n        width: 100%;\n        height: 40px;\n        color: var(--color-toolbar-text);\n        background: var(--color-toolbar);\n        border-bottom: 1px solid var(--color-panel-divider);\n        transition: transform 0.3s linear;\n      }\n      .tsd-page-toolbar a {\n        color: var(--color-toolbar-text);\n        text-decoration: none;\n      }\n      .tsd-page-toolbar a.title {\n        font-weight: bold;\n      }\n      .tsd-page-toolbar a.title:hover {\n        text-decoration: underline;\n      }\n      .tsd-page-toolbar .table-wrap {\n        display: table;\n        width: 100%;\n        height: 40px;\n      }\n      .tsd-page-toolbar .table-cell {\n        display: table-cell;\n        position: relative;\n        white-space: nowrap;\n        line-height: 40px;\n      }\n      .tsd-page-toolbar .table-cell:first-child {\n        width: 100%;\n      }\n\n      .tsd-page-toolbar--hide {\n        transform: translateY(-100%);\n      }\n\n      .tsd-select .tsd-select-list li:before,\n      .tsd-select .tsd-select-label:before,\n      .tsd-widget:before {\n        content: '';\n        display: inline-block;\n        width: 40px;\n        height: 40px;\n        margin: 0 -8px 0 0;\n        background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAUAAAAAoCAQAAAAlSeuiAAABp0lEQVR4Ae3aUa3jQAyF4QNhIBTCQiiEQlgIhRAGhTAQBkIgBEIgDITZZGXNjZTePiSWYqn/54dGfbAq+SiTutWXAgAAAAAAAAAAAAA8NCz1UFSD2lKDS5d3NVzZj/BVNasaLoRZRUmj2lLrVVHWMUntQ13Wj/i1pWa9lprX6xMRnH4dx6Rjsn26+v+12ms+EcB37P0r+qH+DNQGXgMFcHzbregQ78B8eQCTJk0e979ZW7PdA2O49ceDsYexKgUNoI3EKYDWL3D8miaPh/uXtl6BHqEHFQvgXau/FsCiIWAAbST2fpQRT0sl70j3z5ZiBdD7CG5WZX8kxwmgjbiP5GQA9/3O2XaxnnHi53AEE0AbRh+JQwC3/fzC4hcb6xPvS4i3QaMdwX+0utsRPEY6gm2wNhKHAG77eUi7SIcK4G4NY4GMIan2u2Cxqzncl5DUn7Q8ArjvZ8JFOsl/Ed0jyBom+BomQKSto+9PcblHMM4iuu4X0QQw5hrGQY/gUxFkjZuf4m4alXVU+1De/VhEn5CvDSB/RsBzqWgAAAAAAAAAAAAAAACAfyyYJ5nhVuwIAAAAAElFTkSuQmCC);\n        background-repeat: no-repeat;\n        text-indent: -1024px;\n        vertical-align: bottom;\n      }\n      @media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) {\n        .tsd-select .tsd-select-list li:before,\n        .tsd-select .tsd-select-label:before,\n        .tsd-widget:before {\n          background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAoAAAABQCAMAAAC+sjQXAAAAM1BMVEUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACjBUbJAAAAEXRSTlMA3/+/UCBw7xCPYIBAMM+vn1qYQ7QAAALCSURBVHgB7MGBAAAAAICg/akXqQIAAAAAAAAAAAAAAAAAAJids9mdE4bhoDNZCITP93/aSmhV/9uwPWyi8jtkblws2IxsYpz9LwSAaJW8AreE16PxOsMYE6Q4DiYKF7X+8ZHXc/E608xv5snEyIuZrVwMZjbnujR6T3gsXmcLOIRNzD+Ig2UuVtt2+NbAiX/wVLzOlviD9L2BOfGBlL/3D1I+uDjGBJArBPxU3x+K15kCQFo2s21JAOHrKpz4SPrWv4IKA+uFaR6vMwMcb+emA2DWEfDglrkLqEBOKVslA8Dx14oPMiV4CtywWxdQgAwkq2QE0uTXUwJGk2G9s3mTFNBzAkC7HKPsX72AEVjMnAWIpsPCRRjXdQxcjCYpoOcEgHY5Rtk/slWSgM3M2aSeeVgjAOeVpKcdgGMdNAXMuIAqOcZzqF8L+WcAsi8wkTeheCWMegL6mgCorHHyEJ5TVfxrLWDrTUjZdhnhjYqAnlN8TaoELOLVC0gucmoz/3RKcPs2jAs4+J5ET8AEZF+TSgGLeC1V8YuGQQU2IV1Asq9JCwE9XitZVPxr34bpJRj8PqsFLOK108W9aVrWZRrR7Sm2HL4JCToCujHZ6gUs4jUz0P1TEvD+U5wMa363YeziBODIq1YbJrsv9QKW8Ry1nNp+GAHvuingRTfmYcjBf0QpAS37bdUL6PFKtHJq63EsZ5cxcKMkDVIClu1dAK1PcJ5TFQ0M9wZKDCPs3BD7MIJGTs3WfiTfDVQYx5q5ZekCauTU3P5Q0ukGCgh49oFURdobWBY9N/CxEuwGjpGLuPhTdwH1x7HqDDxNgRP2zQ8lraFyF/yJ9vH6QGqtgSbBOU8/j2VORz+Wqfle2d5Ae4R+ML0z7Y+W4P7XHN3AU+tzyK/24EAGAAAAYJC/9T2+CgAAAAAAAAAAAAAAAAAAAADgJpfzHyIKFFBKAAAAAElFTkSuQmCC);\n          background-size: 320px 40px;\n        }\n      }\n\n      .tsd-widget {\n        display: inline-block;\n        overflow: hidden;\n        opacity: 0.6;\n        height: 40px;\n        transition: opacity 0.1s, background-color 0.2s;\n        vertical-align: bottom;\n        cursor: pointer;\n      }\n      .tsd-widget:hover {\n        opacity: 0.8;\n      }\n      .tsd-widget.active {\n        opacity: 1;\n        background-color: var(--color-panel-divider);\n      }\n      .tsd-widget.no-caption {\n        width: 40px;\n      }\n      .tsd-widget.no-caption:before {\n        margin: 0;\n      }\n      .tsd-widget.search:before {\n        background-position: 0 0;\n      }\n      .tsd-widget.menu:before {\n        background-position: -40px 0;\n      }\n      .tsd-widget.options:before {\n        background-position: -80px 0;\n      }\n      .tsd-widget.options,\n      .tsd-widget.menu {\n        display: none;\n      }\n      @media (max-width: 900px) {\n        .tsd-widget.options,\n        .tsd-widget.menu {\n          display: inline-block;\n        }\n      }\n      input[type='checkbox'] + .tsd-widget:before {\n        background-position: -120px 0;\n      }\n      input[type='checkbox']:checked + .tsd-widget:before {\n        background-position: -160px 0;\n      }\n\n      .tsd-select {\n        position: relative;\n        display: inline-block;\n        height: 40px;\n        transition: opacity 0.1s, background-color 0.2s;\n        vertical-align: bottom;\n        cursor: pointer;\n      }\n      .tsd-select .tsd-select-label {\n        opacity: 0.6;\n        transition: opacity 0.2s;\n      }\n      .tsd-select .tsd-select-label:before {\n        background-position: -240px 0;\n      }\n      .tsd-select.active .tsd-select-label {\n        opacity: 0.8;\n      }\n      .tsd-select.active .tsd-select-list {\n        visibility: visible;\n        opacity: 1;\n        transition-delay: 0s;\n      }\n      .tsd-select .tsd-select-list {\n        position: absolute;\n        visibility: hidden;\n        top: 40px;\n        left: 0;\n        margin: 0;\n        padding: 0;\n        opacity: 0;\n        list-style: none;\n        box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n        transition: visibility 0s 0.2s, opacity 0.2s;\n      }\n      .tsd-select .tsd-select-list li {\n        padding: 0 20px 0 0;\n        background-color: var(--color-background);\n      }\n      .tsd-select .tsd-select-list li:before {\n        background-position: 40px 0;\n      }\n      .tsd-select .tsd-select-list li:nth-child(even) {\n        background-color: var(--color-panel);\n      }\n      .tsd-select .tsd-select-list li:hover {\n        background-color: var(--color-panel-divider);\n      }\n      .tsd-select .tsd-select-list li.selected:before {\n        background-position: -200px 0;\n      }\n      @media (max-width: 900px) {\n        .tsd-select .tsd-select-list {\n          top: 0;\n          left: auto;\n          right: 100%;\n          margin-right: -5px;\n        }\n        .tsd-select .tsd-select-label:before {\n          background-position: -280px 0;\n        }\n      }\n\n      img {\n        max-width: 100%;\n      }\n    </style>\n  </head>\n  <body>\n    <header>\n      <div class=\"tsd-page-toolbar\">\n        <div class=\"container\">\n          <div class=\"table-wrap\">\n            <div class=\"table-cell\">\n              <strong><a href=\"index.html\">react-charts</a></strong>\n            </div>\n            <div class=\"table-cell\" id=\"tsd-widgets\">\n              <div id=\"tsd-filter\">\n                <a\n                  href=\"#\"\n                  class=\"tsd-widget options no-caption\"\n                  data-toggle=\"options\"\n                  >Options</a\n                >\n                <div class=\"tsd-filter-group\">\n                  <div class=\"tsd-select\" id=\"tsd-filter-visibility\">\n                    <span class=\"tsd-select-label\">All</span>\n                    <ul class=\"tsd-select-list\">\n                      <li data-value=\"public\">Public</li>\n                      <li data-value=\"protected\">Public/Protected</li>\n                      <li data-value=\"private\" class=\"selected\">All</li>\n                    </ul>\n                  </div>\n                  <input type=\"checkbox\" id=\"tsd-filter-inherited\" checked />\n                  <label class=\"tsd-widget\" for=\"tsd-filter-inherited\"\n                    >Inherited</label\n                  >\n                  <input type=\"checkbox\" id=\"tsd-filter-externals\" checked />\n                  <label class=\"tsd-widget\" for=\"tsd-filter-externals\"\n                    >Externals</label\n                  >\n                  <input type=\"checkbox\" id=\"tsd-filter-only-exported\" />\n                  <label class=\"tsd-widget\" for=\"tsd-filter-only-exported\"\n                    >Only exported</label\n                  >\n                </div>\n              </div>\n              <a href=\"#typedoc-main-index\" class=\"tsd-widget menu no-caption\"\n                >Menu</a\n              >\n            </div>\n          </div>\n        </div>\n      </div>\n    </header>\n    <nav class=\"tsd-navigation secondary\">\n      <ul>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#alignmode\" class=\"tsd-kind-icon\"\n            >Align<wbr />Mode</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#alignposition\" class=\"tsd-kind-icon\"\n            >Align<wbr />Position</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#anchormode\" class=\"tsd-kind-icon\"\n            >Anchor<wbr />Mode</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#axesinfo\" class=\"tsd-kind-icon\"\n            >Axes<wbr />Info</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axis\" class=\"tsd-kind-icon\">Axis</a>\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axisband\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Band</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axisbandoptions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Band<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axisbase\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Base</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#axisdimension\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Dimension</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#axisdimensions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Dimensions</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axislinear\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Linear</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axislinearoptions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Linear<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axisoptions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#axisoptionsbase\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Options<wbr />Base</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axisordinaloptions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Ordinal<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axistime\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Time</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axistimeoptions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Time<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#axistype\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Type</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#chartcontextvalue\" class=\"tsd-kind-icon\"\n            >Chart<wbr />Context<wbr />Value</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#chartoffset\" class=\"tsd-kind-icon\"\n            >Chart<wbr />Offset</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#chartoptions\" class=\"tsd-kind-icon\"\n            >Chart<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#chartvalue\" class=\"tsd-kind-icon\"\n            >Chart<wbr />Value</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#cursoroptions\" class=\"tsd-kind-icon\"\n            >Cursor<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#datum\" class=\"tsd-kind-icon\">Datum</a>\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#datumfocusstatus\" class=\"tsd-kind-icon\"\n            >Datum<wbr />Focus<wbr />Status</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#datumstyles\" class=\"tsd-kind-icon\"\n            >Datum<wbr />Styles</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#griddimensions\" class=\"tsd-kind-icon\"\n            >Grid<wbr />Dimensions</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#groupingmode\" class=\"tsd-kind-icon\"\n            >Grouping<wbr />Mode</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#measurement\" class=\"tsd-kind-icon\"\n            >Measurement</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#pointer\" class=\"tsd-kind-icon\">Pointer</a>\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#pointerpressed\" class=\"tsd-kind-icon\"\n            >Pointer<wbr />Pressed</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#pointerunpressed\" class=\"tsd-kind-icon\"\n            >Pointer<wbr />Unpressed</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#position\" class=\"tsd-kind-icon\">Position</a>\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#requiredchartoptions\" class=\"tsd-kind-icon\"\n            >Required<wbr />Chart<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#resolvedaxisoptions\" class=\"tsd-kind-icon\"\n            >Resolved<wbr />Axis<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#resolvedtooltipoptions\" class=\"tsd-kind-icon\"\n            >Resolved<wbr />Tooltip<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#series\" class=\"tsd-kind-icon\">Series</a>\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#seriesfocusstatus\" class=\"tsd-kind-icon\"\n            >Series<wbr />Focus<wbr />Status</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#seriesstyles\" class=\"tsd-kind-icon\"\n            >Series<wbr />Styles</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#side\" class=\"tsd-kind-icon\">Side</a>\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#stackdatum\" class=\"tsd-kind-icon\"\n            >Stack<wbr />Datum</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#tooltipoptions\" class=\"tsd-kind-icon\"\n            >Tooltip<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#userserie\" class=\"tsd-kind-icon\"\n            >User<wbr />Serie</a\n          >\n        </li>\n        <li class=\"tsd-kind-function tsd-has-type-parameter\">\n          <a href=\"modules.html#chart\" class=\"tsd-kind-icon\">Chart</a>\n        </li>\n      </ul>\n    </nav>\n    <div class=\"container container-main\">\n      <div class=\"content-wrap\">\n        <div class=\"tsd-panel tsd-typography\">\n          <p>\n            <img\n              src=\"https://github.com/tannerlinsley/react-charts/raw/next/media/repo-dark.png\"\n              alt=\"React Charts Header\"\n            />\n          </p>\n          <p>Simple, immersive and interactive charts for React</p>\n          <a\n            href=\"https://twitter.com/intent/tweet?button_hashtag=TanStack\"\n            target=\"\\_parent\"\n          >\n            <img\n              alt=\"#TanStack\"\n              src=\"https://img.shields.io/twitter/url?color=%2308a0e9&label=%23TanStack&style=social&url=https%3A%2F%2Ftwitter.com%2Fintent%2Ftweet%3Fbutton_hashtag%3DTanStack\"\n            />\n          </a>\n          <a href=\"https://npmjs.com/package/react-charts\" target=\"\\_parent\">\n            <img alt=\"\" src=\"https://img.shields.io/npm/dm/react-charts.svg\" />\n          </a>\n          <a\n            href=\"https://bundlephobia.com/result?p=react-charts\"\n            target=\"\\_parent\"\n          >\n            <img\n              alt=\"\"\n              src=\"https://badgen.net/bundlephobia/minzip/react-charts\"\n            />\n          </a>\n          <a href=\"https://spectrum.chat/react-charts\">\n            <img\n              alt=\"Join the community on Spectrum\"\n              src=\"https://withspectrum.github.io/badge/badge.svg\"\n            />\n          </a>\n          <a\n            href=\"https://github.com/react-charts/react-charts\"\n            target=\"\\_parent\"\n          >\n            <img\n              alt=\"\"\n              src=\"https://img.shields.io/github/stars/react-charts/react-charts.svg?style=social&label=Star\"\n            />\n          </a>\n          <a href=\"https://twitter.com/tannerlinsley\" target=\"\\_parent\">\n            <img\n              alt=\"\"\n              src=\"https://img.shields.io/twitter/follow/tannerlinsley.svg?style=social&label=Follow\"\n            />\n          </a>\n          <br />\n          <br />\n          <p>\n            Enjoy this library? Try the entire\n            <a href=\"https://tanstack.com\">TanStack</a>!\n            <a href=\"https://github.com/tannerlinsley/react-table\"\n              >React Table</a\n            >,\n            <a href=\"https://github.com/tannerlinsley/react-query\"\n              >React Query</a\n            >,\n            <a href=\"https://github.com/tannerlinsley/react-form\">React Form</a>\n          </p>\n          <a\n            href=\"#visit-react-chartstanstackcom-for-docs-guides-api-and-more\"\n            id=\"visit-react-chartstanstackcom-for-docs-guides-api-and-more\"\n            style=\"color: inherit; text-decoration: none\"\n          >\n            <h2>\n              Visit\n              <a href=\"https://react-charts.tanstack.com\"\n                >react-charts.tanstack.com</a\n              >\n              for docs, guides, API and more!\n            </h2>\n          </a>\n          <a\n            href=\"#quick-features\"\n            id=\"quick-features\"\n            style=\"color: inherit; text-decoration: none\"\n          >\n            <h2>Quick Features</h2>\n          </a>\n          <ul>\n            <li>Line Charts</li>\n            <li>Bar Charts</li>\n            <li>Column Charts</li>\n            <li>Bubble Charts</li>\n            <li>Area Charts</li>\n            <li>Axis Stacking</li>\n            <li>Inverted Axes</li>\n            <li>Hyper Responsive</li>\n            <li>Invisibly Powered by D3</li>\n            <li>Declarative</li>\n            <li>Mutliple Axes</li>\n          </ul>\n          <a\n            href=\"#become-a-sponsor\"\n            id=\"become-a-sponsor\"\n            style=\"color: inherit; text-decoration: none\"\n          >\n            <h3>\n              <a href=\"https://github.com/sponsors/tannerlinsley/\"\n                >Become a Sponsor!</a\n              >\n            </h3>\n          </a>\n          <a\n            href=\"#contributors-✨\"\n            id=\"contributors-✨\"\n            style=\"color: inherit; text-decoration: none\"\n          >\n            <h1>Contributors ✨</h1>\n          </a>\n          <p>\n            Thanks goes to these wonderful people (<a\n              href=\"https://allcontributors.org/docs/en/emoji-key\"\n              >emoji key</a\n            >):\n          </p>\n          <!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->\n          <!-- prettier-ignore-start -->\n          <!-- markdownlint-disable -->\n          <table>\n            <tr>\n              <td align=\"center\">\n                <a href=\"https://tannerlinsley.com\"\n                  ><img\n                    src=\"https://avatars0.githubusercontent.com/u/5580297?v=4\"\n                    width=\"100px;\"\n                    alt=\"\"\n                  /><br /><sub><b>Tanner Linsley</b></sub></a\n                ><br /><a\n                  href=\"https://github.com/tannerlinsley/react-charts/commits?author=tannerlinsley\"\n                  title=\"Code\"\n                  >💻</a\n                >\n                <a\n                  href=\"#ideas-tannerlinsley\"\n                  title=\"Ideas, Planning, & Feedback\"\n                  >🤔</a\n                >\n                <a href=\"#example-tannerlinsley\" title=\"Examples\">💡</a>\n                <a href=\"#maintenance-tannerlinsley\" title=\"Maintenance\">🚧</a>\n                <a\n                  href=\"https://github.com/tannerlinsley/react-charts/pulls?q=is%3Apr+reviewed-by%3Atannerlinsley\"\n                  title=\"Reviewed Pull Requests\"\n                  >👀</a\n                >\n              </td>\n            </tr>\n          </table>\n          <!-- markdownlint-enable -->\n          <!-- prettier-ignore-end -->\n          <!-- ALL-CONTRIBUTORS-LIST:END -->\n          <p>\n            This project follows the\n            <a href=\"https://github.com/all-contributors/all-contributors\"\n              >all-contributors</a\n            >\n            specification. Contributions of any kind welcome!\n          </p>\n          <!-- Force 1 -->\n        </div>\n        <div style=\"position: relative\">\n          <a name=\"typedoc-main-index\" class=\"tsd-anchor\"></a>\n        </div>\n        <section class=\"tsd-panel-group tsd-index-group\">\n          <h2>Index</h2>\n          <section class=\"tsd-panel tsd-index-panel\">\n            <div class=\"tsd-index-content\">\n              <section class=\"tsd-index-section\">\n                <h3>Type aliases</h3>\n                <ul class=\"tsd-index-list\">\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#alignmode\" class=\"tsd-kind-icon\"\n                      >Align<wbr />Mode</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#alignposition\" class=\"tsd-kind-icon\"\n                      >Align<wbr />Position</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#anchormode\" class=\"tsd-kind-icon\"\n                      >Anchor<wbr />Mode</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#axesinfo\" class=\"tsd-kind-icon\"\n                      >Axes<wbr />Info</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axis\" class=\"tsd-kind-icon\">Axis</a>\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axisband\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Band</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axisbandoptions\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Band<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axisbase\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Base</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#axisdimension\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Dimension</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#axisdimensions\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Dimensions</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axislinear\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Linear</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#axislinearoptions\"\n                      class=\"tsd-kind-icon\"\n                      >Axis<wbr />Linear<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axisoptions\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#axisoptionsbase\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Options<wbr />Base</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#axisordinaloptions\"\n                      class=\"tsd-kind-icon\"\n                      >Axis<wbr />Ordinal<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axistime\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Time</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axistimeoptions\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Time<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#axistype\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Type</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#chartcontextvalue\"\n                      class=\"tsd-kind-icon\"\n                      >Chart<wbr />Context<wbr />Value</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#chartoffset\" class=\"tsd-kind-icon\"\n                      >Chart<wbr />Offset</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#chartoptions\" class=\"tsd-kind-icon\"\n                      >Chart<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#chartvalue\" class=\"tsd-kind-icon\"\n                      >Chart<wbr />Value</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#cursoroptions\" class=\"tsd-kind-icon\"\n                      >Cursor<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#datum\" class=\"tsd-kind-icon\">Datum</a>\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a\n                      href=\"modules.html#datumfocusstatus\"\n                      class=\"tsd-kind-icon\"\n                      >Datum<wbr />Focus<wbr />Status</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#datumstyles\" class=\"tsd-kind-icon\"\n                      >Datum<wbr />Styles</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#griddimensions\" class=\"tsd-kind-icon\"\n                      >Grid<wbr />Dimensions</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#groupingmode\" class=\"tsd-kind-icon\"\n                      >Grouping<wbr />Mode</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#measurement\" class=\"tsd-kind-icon\"\n                      >Measurement</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#pointer\" class=\"tsd-kind-icon\"\n                      >Pointer</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#pointerpressed\" class=\"tsd-kind-icon\"\n                      >Pointer<wbr />Pressed</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a\n                      href=\"modules.html#pointerunpressed\"\n                      class=\"tsd-kind-icon\"\n                      >Pointer<wbr />Unpressed</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#position\" class=\"tsd-kind-icon\"\n                      >Position</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#requiredchartoptions\"\n                      class=\"tsd-kind-icon\"\n                      >Required<wbr />Chart<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#resolvedaxisoptions\"\n                      class=\"tsd-kind-icon\"\n                      >Resolved<wbr />Axis<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#resolvedtooltipoptions\"\n                      class=\"tsd-kind-icon\"\n                      >Resolved<wbr />Tooltip<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#series\" class=\"tsd-kind-icon\"\n                      >Series</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a\n                      href=\"modules.html#seriesfocusstatus\"\n                      class=\"tsd-kind-icon\"\n                      >Series<wbr />Focus<wbr />Status</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#seriesstyles\" class=\"tsd-kind-icon\"\n                      >Series<wbr />Styles</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#side\" class=\"tsd-kind-icon\">Side</a>\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#stackdatum\" class=\"tsd-kind-icon\"\n                      >Stack<wbr />Datum</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#tooltipoptions\" class=\"tsd-kind-icon\"\n                      >Tooltip<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#userserie\" class=\"tsd-kind-icon\"\n                      >User<wbr />Serie</a\n                    >\n                  </li>\n                </ul>\n              </section>\n              <section class=\"tsd-index-section\">\n                <h3>Functions</h3>\n                <ul class=\"tsd-index-list\">\n                  <li class=\"tsd-kind-function tsd-has-type-parameter\">\n                    <a href=\"modules.html#chart\" class=\"tsd-kind-icon\">Chart</a>\n                  </li>\n                </ul>\n              </section>\n            </div>\n          </section>\n        </section>\n        <section class=\"tsd-panel-group tsd-member-group\">\n          <h2>Type aliases</h2>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"alignmode\" class=\"tsd-anchor\"></a>\n            <h3>Align<wbr />Mode</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Align<wbr />Mode<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;auto&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;right&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;topRight&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottomRight&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;left&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;topLeft&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottomLeft&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;top&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottom&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;center&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L132\"\n                    >types.ts:132</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"alignposition\" class=\"tsd-anchor\"></a>\n            <h3>Align<wbr />Position</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Align<wbr />Position<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;right&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;topRight&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottomRight&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;left&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;topLeft&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottomLeft&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;top&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottom&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L144\"\n                    >types.ts:144</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"anchormode\" class=\"tsd-anchor\"></a>\n            <h3>Anchor<wbr />Mode</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Anchor<wbr />Mode<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;pointer&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;closest&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;center&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;top&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottom&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;left&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;right&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;gridTop&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;gridBottom&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;gridLeft&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;gridRight&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;gridCenter&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L156\"\n                    >types.ts:156</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"axesinfo\" class=\"tsd-anchor\"></a>\n            <h3>Axes<wbr />Info</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axes<wbr />Info<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>xKey<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;primary&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;secondary&quot;</span\n              ><span class=\"tsd-signature-symbol\">; </span>yKey<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;primary&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;secondary&quot;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L415\"\n                    >types.ts:415</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    x<wbr />Key<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">&quot;primary&quot;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\"\n                      >&quot;secondary&quot;</span\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    y<wbr />Key<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">&quot;primary&quot;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\"\n                      >&quot;secondary&quot;</span\n                    >\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axis\" class=\"tsd-anchor\"></a>\n            <h3>Axis</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis&lt;TDatum&gt;<span class=\"tsd-signature-symbol\">:</span>\n              <a\n                href=\"modules.html#axistime\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisTime</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#axislinear\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisLinear</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#axisband\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBand</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L358\"\n                    >types.ts:358</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axisband\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Band</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Band&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">Omit</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axisbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBase</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><a\n                href=\"modules.html#resolvedaxisoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ResolvedAxisOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axisbandoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBandOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">&quot;format&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>axisFamily<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;band&quot;</span\n              ><span class=\"tsd-signature-symbol\">; </span>format<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span>value<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#chartvalue\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartValue</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>outerScale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleBand</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>scale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleBand</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L348\"\n                    >types.ts:348</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axisbandoptions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Band<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Band<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <a\n                href=\"modules.html#axisoptionsbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptionsBase</a\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>getValue<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#chartvalue\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartValue</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>minBandSize<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>scaleType<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;band&quot;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L261\"\n                    >types.ts:261</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axisbase\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Base</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Base&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>_<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">; </span>isVertical<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>range<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">[</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">]</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L302\"\n                    >types.ts:302</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    _<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">TDatum</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    is<wbr />Vertical<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    range<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-symbol\">[</span\n                    ><span class=\"tsd-signature-type\">number</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><span class=\"tsd-signature-type\">number</span\n                    ><span class=\"tsd-signature-symbol\">]</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"axisdimension\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Dimension</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Dimension<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>bottom<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>height<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>left<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>right<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>top<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>width<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L197\"\n                    >types.ts:197</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    bottom<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    height<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    left<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    right<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    top<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    width<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"axisdimensions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Dimensions</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Dimensions<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>bottom<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">Record</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><a\n                href=\"modules.html#axisdimension\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimension</a\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>left<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">Record</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><a\n                href=\"modules.html#axisdimension\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimension</a\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>right<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">Record</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><a\n                href=\"modules.html#axisdimension\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimension</a\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>top<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">Record</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><a\n                href=\"modules.html#axisdimension\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimension</a\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L206\"\n                    >types.ts:206</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    bottom<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">Record</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">string</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><a\n                      href=\"modules.html#axisdimension\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimension</a\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    left<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">Record</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">string</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><a\n                      href=\"modules.html#axisdimension\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimension</a\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    right<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">Record</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">string</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><a\n                      href=\"modules.html#axisdimension\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimension</a\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    top<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">Record</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">string</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><a\n                      href=\"modules.html#axisdimension\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimension</a\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axislinear\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Linear</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Linear&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">Omit</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axisbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBase</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><a\n                href=\"modules.html#resolvedaxisoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ResolvedAxisOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axislinearoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisLinearOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">&quot;format&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>axisFamily<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;linear&quot;</span\n              ><span class=\"tsd-signature-symbol\">; </span>bandScale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleBand</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>format<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ReturnType</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">ScaleLinear</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[</span\n              ><span class=\"tsd-signature-type\">&quot;tickFormat&quot;</span\n              ><span class=\"tsd-signature-symbol\">]</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>outerScale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleLinear</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>scale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleLinear</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L337\"\n                    >types.ts:337</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axislinearoptions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Linear<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Linear<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <a\n                href=\"modules.html#axisoptionsbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptionsBase</a\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>base<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>getValue<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#chartvalue\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartValue</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>hardMax<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>hardMin<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>max<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>min<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>scaleType<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;linear&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;log&quot;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L267\"\n                    >types.ts:267</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axisoptions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Options&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <a\n                href=\"modules.html#axistimeoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisTimeOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#axisordinaloptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOrdinalOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#axisbandoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBandOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#axislinearoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisLinearOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L277\"\n                    >types.ts:277</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"axisoptionsbase\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Options<wbr />Base</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Options<wbr />Base<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>curve<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CurveFactory</span\n              ><span class=\"tsd-signature-symbol\">; </span>elementType<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">&quot;line&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;area&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bar&quot;</span\n              ><span class=\"tsd-signature-symbol\">; </span>id<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>innerBandPadding<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>invert<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>isPrimary<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >minTickPaddingForRotation<span class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>outerBandPadding<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>position<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#position\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Position</a\n              ><span class=\"tsd-signature-symbol\">; </span>primaryAxisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>show<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >showDatumElements<span class=\"tsd-signature-symbol\">?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>showGrid<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >showOrphanDatumElements<span class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>stackOffset<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">typeof </span\n              ><span class=\"tsd-signature-type\">stackOffsetNone</span\n              ><span class=\"tsd-signature-symbol\">; </span>stacked<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>styles<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>line<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>tick<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >tickLabelRotationDeg<span class=\"tsd-signature-symbol\">?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L213\"\n                    >types.ts:213</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    curve<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">CurveFactory</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    element<wbr />Type<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">&quot;line&quot;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">&quot;area&quot;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">&quot;bar&quot;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    id<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    inner<wbr />Band<wbr />Padding<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    invert<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    is<wbr />Primary<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    min<wbr />Tick<wbr />Padding<wbr />For<wbr />Rotation<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    outer<wbr />Band<wbr />Padding<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    position<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#position\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Position</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    primary<wbr />Axis<wbr />Id<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Datum<wbr />Elements<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Grid<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Orphan<wbr />Datum<wbr />Elements<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    stack<wbr />Offset<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">typeof </span\n                    ><span class=\"tsd-signature-type\">stackOffsetNone</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    stacked<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    styles<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span\n                    ><span class=\"tsd-signature-symbol\"> &amp; </span\n                    ><span class=\"tsd-signature-symbol\">{ </span>line<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span\n                    ><span class=\"tsd-signature-symbol\">; </span>tick<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span\n                    ><span class=\"tsd-signature-symbol\"> }</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    tick<wbr />Label<wbr />Rotation<wbr />Deg<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axisordinaloptions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Ordinal<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Ordinal<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <a\n                href=\"modules.html#axisoptionsbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptionsBase</a\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>getValue<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#chartvalue\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartValue</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>scaleType<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;ordinal&quot;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L256\"\n                    >types.ts:256</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axistime\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Time</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Time&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">Omit</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axisbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBase</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><a\n                href=\"modules.html#resolvedaxisoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ResolvedAxisOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axistimeoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisTimeOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">&quot;format&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>axisFamily<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;time&quot;</span\n              ><span class=\"tsd-signature-symbol\">; </span>bandScale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleBand</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>format<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ReturnType</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">ScaleTime</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[</span\n              ><span class=\"tsd-signature-type\">&quot;tickFormat&quot;</span\n              ><span class=\"tsd-signature-symbol\">]</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>outerScale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleTime</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>scale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleTime</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L326\"\n                    >types.ts:326</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axistimeoptions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Time<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Time<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <a\n                href=\"modules.html#axisoptionsbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptionsBase</a\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>base<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>getValue<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#chartvalue\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartValue</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">Date</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>hardMax<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>hardMin<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>max<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>min<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>scaleType<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;time&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;localTime&quot;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L246\"\n                    >types.ts:246</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"axistype\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Type</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Type<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;ordinal&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;time&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;localTime&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;linear&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;log&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L154\"\n                    >types.ts:154</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"chartcontextvalue\" class=\"tsd-anchor\"></a>\n            <h3>Chart<wbr />Context<wbr />Value</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Chart<wbr />Context<wbr />Value&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>axesInfo<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#axesinfo\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxesInfo</a\n              ><span class=\"tsd-signature-symbol\">; </span\n              >getDatumStatusStyle<span class=\"tsd-signature-symbol\">: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>, focusedDatum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#datumstyles\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >DatumStyles</a\n              ><span class=\"tsd-signature-symbol\">; </span>getOptions<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#requiredchartoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >RequiredChartOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >getSeriesStatusStyle<span class=\"tsd-signature-symbol\">: </span\n              ><span class=\"tsd-signature-symbol\">(</span>series<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>, focusedDatum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#seriesstyles\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >SeriesStyles</a\n              ><span class=\"tsd-signature-symbol\">; </span>gridDimensions<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#griddimensions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >GridDimensions</a\n              ><span class=\"tsd-signature-symbol\">; </span\n              >datumsByInteractionGroup<span class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">Map</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>height<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>orderedSeries<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>primaryAxis<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#axis\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Axis</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryAxes<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#axis\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Axis</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>series<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>svgRect<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ClientRect</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >useAxisDimensionsAtom<span class=\"tsd-signature-symbol\">: </span\n              ><span class=\"tsd-signature-symbol\">(</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-symbol\">[</span\n              ><a\n                href=\"modules.html#axisdimensions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimensions</a\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">SetAtom</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">SetStateAction</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axisdimensions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimensions</a\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">]</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >useFocusedDatumAtom<span class=\"tsd-signature-symbol\">: </span\n              ><span class=\"tsd-signature-symbol\">(</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-symbol\">[</span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">SetAtom</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">SetStateAction</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">]</span\n              ><span class=\"tsd-signature-symbol\">; </span>width<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L61\"\n                    >types.ts:61</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    axes<wbr />Info<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#axesinfo\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxesInfo</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    get<wbr />Datum<wbr />Status<wbr />Style<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                    focusedDatum<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#datumstyles\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >DatumStyles</a\n                    >\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>datum<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                          focusedDatum<span class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#datumstyles\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >DatumStyles</a\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                datum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                            <li>\n                              <h5>\n                                focusedDatum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span\n                                ><span class=\"tsd-signature-symbol\"> | </span\n                                ><span class=\"tsd-signature-type\">null</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#datumstyles\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >DatumStyles</a\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    get<wbr />Options<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-symbol\">(</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#requiredchartoptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >RequiredChartOptions</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#requiredchartoptions\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >RequiredChartOptions</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#requiredchartoptions\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >RequiredChartOptions</a\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\">TDatum</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    get<wbr />Series<wbr />Status<wbr />Style<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>series<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                    focusedDatum<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#seriesstyles\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >SeriesStyles</a\n                    >\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>series<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#series\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Series</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                          focusedDatum<span class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#seriesstyles\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >SeriesStyles</a\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                series:\n                                <a\n                                  href=\"modules.html#series\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Series</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                            <li>\n                              <h5>\n                                focusedDatum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span\n                                ><span class=\"tsd-signature-symbol\"> | </span\n                                ><span class=\"tsd-signature-type\">null</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#seriesstyles\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >SeriesStyles</a\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    grid<wbr />Dimensions<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#griddimensions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >GridDimensions</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    grouped<wbr />Datums<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">Map</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">any</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    height<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    ordered<wbr />Series<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    primary<wbr />Axis<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#axis\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Axis</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    secondary<wbr />Axes<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#axis\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Axis</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    series<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    svg<wbr />Rect<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">ClientRect</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    use<wbr />Axis<wbr />Dimensions<wbr />Atom<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-symbol\">(</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-symbol\">[</span\n                    ><a\n                      href=\"modules.html#axisdimensions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimensions</a\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><span class=\"tsd-signature-type\">SetAtom</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">SetStateAction</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><a\n                      href=\"modules.html#axisdimensions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimensions</a\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">]</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-symbol\">[</span\n                          ><a\n                            href=\"modules.html#axisdimensions\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >AxisDimensions</a\n                          ><span class=\"tsd-signature-symbol\">, </span\n                          ><span class=\"tsd-signature-type\">SetAtom</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">SetStateAction</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><a\n                            href=\"modules.html#axisdimensions\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >AxisDimensions</a\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">]</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-returns-title\">\n                            Returns <span class=\"tsd-signature-symbol\">[</span\n                            ><a\n                              href=\"modules.html#axisdimensions\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >AxisDimensions</a\n                            ><span class=\"tsd-signature-symbol\">, </span\n                            ><span class=\"tsd-signature-type\">SetAtom</span\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\"\n                              >SetStateAction</span\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><a\n                              href=\"modules.html#axisdimensions\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >AxisDimensions</a\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\">]</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    use<wbr />Focused<wbr />Datum<wbr />Atom<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-symbol\">(</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-symbol\">[</span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><span class=\"tsd-signature-type\">SetAtom</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">SetStateAction</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">]</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-symbol\">[</span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span\n                          ><span class=\"tsd-signature-symbol\">, </span\n                          ><span class=\"tsd-signature-type\">SetAtom</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">SetStateAction</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">]</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-returns-title\">\n                            Returns <span class=\"tsd-signature-symbol\">[</span\n                            ><a\n                              href=\"modules.html#datum\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >Datum</a\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\">TDatum</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\"> | </span\n                            ><span class=\"tsd-signature-type\">null</span\n                            ><span class=\"tsd-signature-symbol\">, </span\n                            ><span class=\"tsd-signature-type\">SetAtom</span\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\"\n                              >SetStateAction</span\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><a\n                              href=\"modules.html#datum\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >Datum</a\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\">TDatum</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\"> | </span\n                            ><span class=\"tsd-signature-type\">null</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\">]</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    width<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"chartoffset\" class=\"tsd-anchor\"></a>\n            <h3>Chart<wbr />Offset</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Chart<wbr />Offset<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>height<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>left<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>top<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>width<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L190\"\n                    >types.ts:190</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    height<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    left<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    top<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    width<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"chartoptions\" class=\"tsd-anchor\"></a>\n            <h3>Chart<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Chart<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>brush<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">{ </span>onSelect<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>selection<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">{ </span>end<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">unknown</span\n              ><span class=\"tsd-signature-symbol\">; </span>pointer<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#pointer\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Pointer</a\n              ><span class=\"tsd-signature-symbol\">; </span>start<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">unknown</span\n              ><span class=\"tsd-signature-symbol\"> }</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">void</span\n              ><span class=\"tsd-signature-symbol\">; </span>style<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span\n              ><span class=\"tsd-signature-symbol\">; </span>dark<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>data<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#userserie\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >UserSerie</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>defaultColors<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>getDatumStyle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>, status<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datumfocusstatus\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >DatumFocusStatus</a\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#datumstyles\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >DatumStyles</a\n              ><span class=\"tsd-signature-symbol\">; </span>getSeriesOrder<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>series<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>getSeriesStyle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>series<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>, status<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#seriesfocusstatus\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >SeriesFocusStatus</a\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#seriesstyles\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >SeriesStyles</a\n              ><span class=\"tsd-signature-symbol\">; </span>interactionMode<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><a\n                href=\"modules.html#groupingmode\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >GroupingMode</a\n              ><span class=\"tsd-signature-symbol\">; </span>initialHeight<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>initialWidth<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>onClickDatum<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span>, event<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">React.MouseEvent</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">SVGSVGElement</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">MouseEvent</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">void</span\n              ><span class=\"tsd-signature-symbol\">; </span>onFocusDatum<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">void</span\n              ><span class=\"tsd-signature-symbol\">; </span>primaryAxis<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#axisoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>primaryCursor<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#cursoroptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >CursorOptions</a\n              ><span class=\"tsd-signature-symbol\">; </span>renderSVG<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">React.ReactNode</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryAxes<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#axisoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryCursor<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#cursoroptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >CursorOptions</a\n              ><span class=\"tsd-signature-symbol\">; </span>showDebugAxes<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>showVoronoi<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>tooltip<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#tooltipoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >TooltipOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L10\"\n                    >types.ts:10</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    brush<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-symbol\">{ </span>onSelect<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>selection<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-symbol\">{ </span>end<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">unknown</span\n                    ><span class=\"tsd-signature-symbol\">; </span>pointer<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#pointer\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Pointer</a\n                    ><span class=\"tsd-signature-symbol\">; </span>start<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">unknown</span\n                    ><span class=\"tsd-signature-symbol\"> }</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">void</span\n                    ><span class=\"tsd-signature-symbol\">; </span>style<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span\n                    ><span class=\"tsd-signature-symbol\"> }</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter\">\n                      <h5>\n                        <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                        on<wbr />Select<span class=\"tsd-signature-symbol\"\n                          >?: </span\n                        ><span class=\"tsd-signature-symbol\">(</span\n                        >selection<span class=\"tsd-signature-symbol\">: </span\n                        ><span class=\"tsd-signature-symbol\">{ </span>end<span\n                          class=\"tsd-signature-symbol\"\n                          >: </span\n                        ><span class=\"tsd-signature-type\">unknown</span\n                        ><span class=\"tsd-signature-symbol\">; </span\n                        >pointer<span class=\"tsd-signature-symbol\">: </span\n                        ><a\n                          href=\"modules.html#pointer\"\n                          class=\"tsd-signature-type\"\n                          data-tsd-kind=\"Type alias\"\n                          >Pointer</a\n                        ><span class=\"tsd-signature-symbol\">; </span>start<span\n                          class=\"tsd-signature-symbol\"\n                          >: </span\n                        ><span class=\"tsd-signature-type\">unknown</span\n                        ><span class=\"tsd-signature-symbol\"> }</span\n                        ><span class=\"tsd-signature-symbol\">)</span\n                        ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                        ><span class=\"tsd-signature-type\">void</span>\n                      </h5>\n                      <ul class=\"tsd-parameters\">\n                        <li class=\"tsd-parameter-signature\">\n                          <ul\n                            class=\"\n                              tsd-signatures\n                              tsd-kind-type-literal\n                              tsd-parent-kind-type-literal\n                            \"\n                          >\n                            <li class=\"tsd-signature tsd-kind-icon\">\n                              <span class=\"tsd-signature-symbol\">(</span\n                              >selection<span class=\"tsd-signature-symbol\"\n                                >: </span\n                              ><span class=\"tsd-signature-symbol\">{ </span\n                              >end<span class=\"tsd-signature-symbol\">: </span\n                              ><span class=\"tsd-signature-type\">unknown</span\n                              ><span class=\"tsd-signature-symbol\">; </span\n                              >pointer<span class=\"tsd-signature-symbol\"\n                                >: </span\n                              ><a\n                                href=\"modules.html#pointer\"\n                                class=\"tsd-signature-type\"\n                                data-tsd-kind=\"Type alias\"\n                                >Pointer</a\n                              ><span class=\"tsd-signature-symbol\">; </span\n                              >start<span class=\"tsd-signature-symbol\">: </span\n                              ><span class=\"tsd-signature-type\">unknown</span\n                              ><span class=\"tsd-signature-symbol\"> }</span\n                              ><span class=\"tsd-signature-symbol\">)</span\n                              ><span class=\"tsd-signature-symbol\">: </span\n                              ><span class=\"tsd-signature-type\">void</span>\n                            </li>\n                          </ul>\n                          <ul class=\"tsd-descriptions\">\n                            <li class=\"tsd-description\">\n                              <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                              <ul class=\"tsd-parameters\">\n                                <li>\n                                  <h5>\n                                    selection:\n                                    <span class=\"tsd-signature-symbol\">{ </span\n                                    >end<span class=\"tsd-signature-symbol\"\n                                      >: </span\n                                    ><span class=\"tsd-signature-type\"\n                                      >unknown</span\n                                    ><span class=\"tsd-signature-symbol\">; </span\n                                    >pointer<span class=\"tsd-signature-symbol\"\n                                      >: </span\n                                    ><a\n                                      href=\"modules.html#pointer\"\n                                      class=\"tsd-signature-type\"\n                                      data-tsd-kind=\"Type alias\"\n                                      >Pointer</a\n                                    ><span class=\"tsd-signature-symbol\">; </span\n                                    >start<span class=\"tsd-signature-symbol\"\n                                      >: </span\n                                    ><span class=\"tsd-signature-type\"\n                                      >unknown</span\n                                    ><span class=\"tsd-signature-symbol\">\n                                      }</span\n                                    >\n                                  </h5>\n                                  <ul class=\"tsd-parameters\">\n                                    <li class=\"tsd-parameter\">\n                                      <h5>\n                                        end<span class=\"tsd-signature-symbol\"\n                                          >: </span\n                                        ><span class=\"tsd-signature-type\"\n                                          >unknown</span\n                                        >\n                                      </h5>\n                                    </li>\n                                    <li class=\"tsd-parameter\">\n                                      <h5>\n                                        pointer<span\n                                          class=\"tsd-signature-symbol\"\n                                          >: </span\n                                        ><a\n                                          href=\"modules.html#pointer\"\n                                          class=\"tsd-signature-type\"\n                                          data-tsd-kind=\"Type alias\"\n                                          >Pointer</a\n                                        >\n                                      </h5>\n                                    </li>\n                                    <li class=\"tsd-parameter\">\n                                      <h5>\n                                        start<span class=\"tsd-signature-symbol\"\n                                          >: </span\n                                        ><span class=\"tsd-signature-type\"\n                                          >unknown</span\n                                        >\n                                      </h5>\n                                    </li>\n                                  </ul>\n                                </li>\n                              </ul>\n                              <h4 class=\"tsd-returns-title\">\n                                Returns\n                                <span class=\"tsd-signature-type\">void</span>\n                              </h4>\n                            </li>\n                          </ul>\n                        </li>\n                      </ul>\n                    </li>\n                    <li class=\"tsd-parameter\">\n                      <h5>\n                        <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                        style<span class=\"tsd-signature-symbol\">?: </span\n                        ><span class=\"tsd-signature-type\">CSSProperties</span>\n                      </h5>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    dark<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    data<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#userserie\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >UserSerie</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    default<wbr />Colors<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    get<wbr />Datum<wbr />Style<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>, status<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#datumfocusstatus\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >DatumFocusStatus</a\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#datumstyles\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >DatumStyles</a\n                    >\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>datum<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                          status<span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#datumfocusstatus\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >DatumFocusStatus</a\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#datumstyles\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >DatumStyles</a\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                datum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                            <li>\n                              <h5>\n                                status:\n                                <a\n                                  href=\"modules.html#datumfocusstatus\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >DatumFocusStatus</a\n                                >\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#datumstyles\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >DatumStyles</a\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    get<wbr />Series<wbr />Order<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>series<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>series<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#series\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Series</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">[]</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#series\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Series</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">[]</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                series:\n                                <a\n                                  href=\"modules.html#series\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Series</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span\n                                ><span class=\"tsd-signature-symbol\">[]</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#series\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >Series</a\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\">TDatum</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\">[]</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    get<wbr />Series<wbr />Style<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>series<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>, status<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#seriesfocusstatus\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >SeriesFocusStatus</a\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#seriesstyles\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >SeriesStyles</a\n                    >\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>series<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#series\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Series</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                          status<span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#seriesfocusstatus\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >SeriesFocusStatus</a\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#seriesstyles\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >SeriesStyles</a\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                series:\n                                <a\n                                  href=\"modules.html#series\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Series</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                            <li>\n                              <h5>\n                                status:\n                                <a\n                                  href=\"modules.html#seriesfocusstatus\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >SeriesFocusStatus</a\n                                >\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#seriesstyles\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >SeriesStyles</a\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    grouping<wbr />Mode<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><a\n                      href=\"modules.html#groupingmode\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >GroupingMode</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    initial<wbr />Height<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    initial<wbr />Width<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    on<wbr />Click<wbr />Datum<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span>, event<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">React.MouseEvent</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">SVGSVGElement</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><span class=\"tsd-signature-type\">MouseEvent</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">void</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>datum<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span>,\n                          event<span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\"\n                            >React.MouseEvent</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">SVGSVGElement</span\n                          ><span class=\"tsd-signature-symbol\">, </span\n                          ><span class=\"tsd-signature-type\">MouseEvent</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\">void</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                datum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span\n                                ><span class=\"tsd-signature-symbol\"> | </span\n                                ><span class=\"tsd-signature-type\">null</span>\n                              </h5>\n                            </li>\n                            <li>\n                              <h5>\n                                event:\n                                <span class=\"tsd-signature-type\"\n                                  >React.MouseEvent</span\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\"\n                                  >SVGSVGElement</span\n                                ><span class=\"tsd-signature-symbol\">, </span\n                                ><span class=\"tsd-signature-type\"\n                                  >MouseEvent</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns <span class=\"tsd-signature-type\">void</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    on<wbr />Focus<wbr />Datum<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">void</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>datum<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\">void</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                datum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span\n                                ><span class=\"tsd-signature-symbol\"> | </span\n                                ><span class=\"tsd-signature-type\">null</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns <span class=\"tsd-signature-type\">void</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    primary<wbr />Axis<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#axisoptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisOptions</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    primary<wbr />Cursor<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><a\n                      href=\"modules.html#cursoroptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >CursorOptions</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    renderSVG<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">React.ReactNode</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\"\n                            >React.ReactNode</span\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <span class=\"tsd-signature-type\"\n                              >React.ReactNode</span\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    secondary<wbr />Axes<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#axisoptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisOptions</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    secondary<wbr />Cursor<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><a\n                      href=\"modules.html#cursoroptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >CursorOptions</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Debug<wbr />Axes<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Voronoi<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    tooltip<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><a\n                      href=\"modules.html#tooltipoptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >TooltipOptions</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"chartvalue\" class=\"tsd-anchor\"></a>\n            <h3>Chart<wbr />Value</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Chart<wbr />Value&lt;T&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">T</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">undefined</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L300\"\n                    >types.ts:300</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>T</h4>\n              </li>\n            </ul>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"cursoroptions\" class=\"tsd-anchor\"></a>\n            <h3>Cursor<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Cursor<wbr />Options<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>axisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>onChange<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">void</span\n              ><span class=\"tsd-signature-symbol\">; </span>show<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>showLabel<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>showLine<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>value<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">unknown</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L420\"\n                    >types.ts:420</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    axis<wbr />Id<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    on<wbr />Change<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">void</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\">void</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-returns-title\">\n                            Returns <span class=\"tsd-signature-type\">void</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Label<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Line<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    value<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">unknown</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"datum\" class=\"tsd-anchor\"></a>\n            <h3>Datum</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Datum&lt;TDatum&gt;<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>element<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">Element</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">; </span>group<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>index<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>originalDatum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">; </span>originalSeries<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#userserie\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >UserSerie</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryAxisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>seriesId<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>seriesIndex<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>seriesLabel<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>stackData<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><a\n                href=\"modules.html#stackdatum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >StackDatum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>style<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L384\"\n                    >types.ts:384</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    element<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">Element</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    group<span class=\"tsd-signature-symbol\">?: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    index<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    original<wbr />Datum<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">TDatum</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    original<wbr />Series<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#userserie\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >UserSerie</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    secondary<wbr />Axis<wbr />Id<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    series<wbr />Id<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    series<wbr />Index<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    series<wbr />Label<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    stack<wbr />Data<span class=\"tsd-signature-symbol\">?: </span\n                    ><a\n                      href=\"modules.html#stackdatum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >StackDatum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    style<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"datumfocusstatus\" class=\"tsd-anchor\"></a>\n            <h3>Datum<wbr />Focus<wbr />Status</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Datum<wbr />Focus<wbr />Status<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">&quot;none&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;focused&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;groupFocused&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L431\"\n                    >types.ts:431</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"datumstyles\" class=\"tsd-anchor\"></a>\n            <h3>Datum<wbr />Styles</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Datum<wbr />Styles<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>area<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>circle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>line<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>rectangle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L121\"\n                    >types.ts:121</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"griddimensions\" class=\"tsd-anchor\"></a>\n            <h3>Grid<wbr />Dimensions</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Grid<wbr />Dimensions<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>height<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>width<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>gridX<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>gridY<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L408\"\n                    >types.ts:408</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    grid<wbr />Height<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    grid<wbr />Width<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    gridX<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    gridY<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"groupingmode\" class=\"tsd-anchor\"></a>\n            <h3>Grouping<wbr />Mode</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Grouping<wbr />Mode<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;single&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;series&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;primary&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;secondary&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L130\"\n                    >types.ts:130</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"measurement\" class=\"tsd-anchor\"></a>\n            <h3>Measurement</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Measurement<span class=\"tsd-signature-symbol\">:</span>\n              <a\n                href=\"modules.html#side\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Side</a\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;width&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;height&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L406\"\n                    >types.ts:406</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"pointer\" class=\"tsd-anchor\"></a>\n            <h3>Pointer</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Pointer<span class=\"tsd-signature-symbol\">:</span>\n              <a\n                href=\"modules.html#pointerunpressed\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >PointerUnpressed</a\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#pointerpressed\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >PointerPressed</a\n              >\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L188\"\n                    >types.ts:188</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"pointerpressed\" class=\"tsd-anchor\"></a>\n            <h3>Pointer<wbr />Pressed</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Pointer<wbr />Pressed<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">PointerBase</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>dragging<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">true</span\n              ><span class=\"tsd-signature-symbol\">; </span>startX<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>startY<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L182\"\n                    >types.ts:182</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"pointerunpressed\" class=\"tsd-anchor\"></a>\n            <h3>Pointer<wbr />Unpressed</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Pointer<wbr />Unpressed<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">PointerBase</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>dragging<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">false</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L178\"\n                    >types.ts:178</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"position\" class=\"tsd-anchor\"></a>\n            <h3>Position</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Position<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;top&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;right&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottom&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;left&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L128\"\n                    >types.ts:128</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"requiredchartoptions\" class=\"tsd-anchor\"></a>\n            <h3>Required<wbr />Chart<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Required<wbr />Chart<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">TSTB.Object.Required</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#chartoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">&quot;getSeriesStyle&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;getDatumStyle&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;getSeriesOrder&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;interactionMode&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;showVoronoi&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;defaultColors&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;initialWidth&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;initialHeight&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L49\"\n                    >types.ts:49</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"resolvedaxisoptions\" class=\"tsd-anchor\"></a>\n            <h3>Resolved<wbr />Axis<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Resolved<wbr />Axis<wbr />Options&lt;TAxisOptions&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">TSTB.Object.Required</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TAxisOptions</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{}</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;minTickPaddingForRotation&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;tickLabelRotationDeg&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;innerBandPadding&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;outerBandPadding&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;show&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;stacked&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L283\"\n                    >types.ts:283</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TAxisOptions</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"resolvedtooltipoptions\" class=\"tsd-anchor\"></a>\n            <h3>Resolved<wbr />Tooltip<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Resolved<wbr />Tooltip<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">TSTB.Object.Required</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#tooltipoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >TooltipOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">&quot;align&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;alignPriority&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;padding&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;tooltipArrowPadding&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;anchor&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;render&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L104\"\n                    >types.ts:104</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"series\" class=\"tsd-anchor\"></a>\n            <h3>Series</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Series&lt;TDatum&gt;<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>datums<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>id<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>index<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>label<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>originalSeries<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#userserie\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >UserSerie</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryAxisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>style<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L374\"\n                    >types.ts:374</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    datums<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    id<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    index<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    label<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    original<wbr />Series<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#userserie\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >UserSerie</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    secondary<wbr />Axis<wbr />Id<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    style<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"seriesfocusstatus\" class=\"tsd-anchor\"></a>\n            <h3>Series<wbr />Focus<wbr />Status</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Series<wbr />Focus<wbr />Status<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">&quot;none&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;focused&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L429\"\n                    >types.ts:429</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"seriesstyles\" class=\"tsd-anchor\"></a>\n            <h3>Series<wbr />Styles</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Series<wbr />Styles<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>area<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>circle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>line<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>rectangle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L114\"\n                    >types.ts:114</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"side\" class=\"tsd-anchor\"></a>\n            <h3>Side</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Side<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;left&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;right&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;top&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottom&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L170\"\n                    >types.ts:170</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"stackdatum\" class=\"tsd-anchor\"></a>\n            <h3>Stack<wbr />Datum</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Stack<wbr />Datum&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>0<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>1<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>data<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L398\"\n                    >types.ts:398</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    0<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    1<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    data<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"tooltipoptions\" class=\"tsd-anchor\"></a>\n            <h3>Tooltip<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Tooltip<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>align<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><a\n                href=\"modules.html#alignmode\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AlignMode</a\n              ><span class=\"tsd-signature-symbol\">; </span>alignPriority<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><a\n                href=\"modules.html#alignposition\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AlignPosition</a\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>invert<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>padding<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>render<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>props<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TooltipRendererProps</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">React.ReactNode</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >tooltipArrowPadding<span class=\"tsd-signature-symbol\">?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L91\"\n                    >types.ts:91</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    align<span class=\"tsd-signature-symbol\">?: </span\n                    ><a\n                      href=\"modules.html#alignmode\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AlignMode</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    align<wbr />Priority<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><a\n                      href=\"modules.html#alignposition\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AlignPosition</a\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    invert<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    padding<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    render<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>props<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">TooltipRendererProps</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">React.ReactNode</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>props<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><span class=\"tsd-signature-type\"\n                            >TooltipRendererProps</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\"\n                            >React.ReactNode</span\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                props:\n                                <span class=\"tsd-signature-type\"\n                                  >TooltipRendererProps</span\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <span class=\"tsd-signature-type\"\n                              >React.ReactNode</span\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    tooltip<wbr />Arrow<wbr />Padding<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"userserie\" class=\"tsd-anchor\"></a>\n            <h3>User<wbr />Serie</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              User<wbr />Serie&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>color<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>data<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>id<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>label<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>primaryAxisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryAxisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L363\"\n                    >types.ts:363</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    color<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    data<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    id<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    label<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    primary<wbr />Axis<wbr />Id<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    secondary<wbr />Axis<wbr />Id<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n        </section>\n        <section class=\"tsd-panel-group tsd-member-group\">\n          <h2>Functions</h2>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-function tsd-has-type-parameter\n            \"\n          >\n            <a name=\"chart\" class=\"tsd-anchor\"></a>\n            <h3>Chart</h3>\n            <ul class=\"tsd-signatures tsd-kind-function tsd-has-type-parameter\">\n              <li class=\"tsd-signature tsd-kind-icon\">\n                Chart&lt;TDatum&gt;<span class=\"tsd-signature-symbol\">(</span\n                >__namedParameters<span class=\"tsd-signature-symbol\">: </span\n                ><span class=\"tsd-signature-type\">ComponentPropsWithoutRef</span\n                ><span class=\"tsd-signature-symbol\">&lt;</span\n                ><span class=\"tsd-signature-type\">&quot;div&quot;</span\n                ><span class=\"tsd-signature-symbol\">&gt;</span\n                ><span class=\"tsd-signature-symbol\"> &amp; </span\n                ><span class=\"tsd-signature-symbol\">{ </span>options<span\n                  class=\"tsd-signature-symbol\"\n                  >: </span\n                ><a\n                  href=\"modules.html#chartoptions\"\n                  class=\"tsd-signature-type\"\n                  data-tsd-kind=\"Type alias\"\n                  >ChartOptions</a\n                ><span class=\"tsd-signature-symbol\">&lt;</span\n                ><span class=\"tsd-signature-type\">TDatum</span\n                ><span class=\"tsd-signature-symbol\">&gt;</span\n                ><span class=\"tsd-signature-symbol\"> }</span\n                ><span class=\"tsd-signature-symbol\">)</span\n                ><span class=\"tsd-signature-symbol\">: </span\n                ><span class=\"tsd-signature-type\">Element</span>\n              </li>\n            </ul>\n            <ul class=\"tsd-descriptions\">\n              <li class=\"tsd-description\">\n                <aside class=\"tsd-sources\">\n                  <ul>\n                    <li>\n                      Defined in\n                      <a\n                        href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/components/Chart.tsx#L94\"\n                        >components/Chart.tsx:94</a\n                      >\n                    </li>\n                  </ul>\n                </aside>\n                <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n                <ul class=\"tsd-type-parameters\">\n                  <li>\n                    <h4>TDatum</h4>\n                  </li>\n                </ul>\n                <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                <ul class=\"tsd-parameters\">\n                  <li>\n                    <h5>\n                      __namedParameters:\n                      <span class=\"tsd-signature-type\"\n                        >ComponentPropsWithoutRef</span\n                      ><span class=\"tsd-signature-symbol\">&lt;</span\n                      ><span class=\"tsd-signature-type\">&quot;div&quot;</span\n                      ><span class=\"tsd-signature-symbol\">&gt;</span\n                      ><span class=\"tsd-signature-symbol\"> &amp; </span\n                      ><span class=\"tsd-signature-symbol\">{ </span>options<span\n                        class=\"tsd-signature-symbol\"\n                        >: </span\n                      ><a\n                        href=\"modules.html#chartoptions\"\n                        class=\"tsd-signature-type\"\n                        data-tsd-kind=\"Type alias\"\n                        >ChartOptions</a\n                      ><span class=\"tsd-signature-symbol\">&lt;</span\n                      ><span class=\"tsd-signature-type\">TDatum</span\n                      ><span class=\"tsd-signature-symbol\">&gt;</span\n                      ><span class=\"tsd-signature-symbol\"> }</span>\n                    </h5>\n                  </li>\n                </ul>\n                <h4 class=\"tsd-returns-title\">\n                  Returns <span class=\"tsd-signature-type\">Element</span>\n                </h4>\n              </li>\n            </ul>\n          </section>\n        </section>\n        <footer class=\"with-border-bottom\">\n          <div class=\"container\">\n            <h2>Legend</h2>\n            <div class=\"tsd-legend-group\"></div>\n          </div>\n        </footer>\n        <div class=\"container tsd-generator\">\n          <p>\n            Generated using\n            <a href=\"https://typedoc.org/\" target=\"_blank\">TypeDoc</a>\n          </p>\n        </div>\n      </div>\n    </div>\n    <script type=\"text/javascript\">\n      /*\n       * ATTENTION: The \"eval\" devtool has been used (maybe by default in mode: \"development\").\n       * This devtool is not neither made for production nor for readable output files.\n       * It uses \"eval()\" calls to create a separate source file in the browser devtools.\n       * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)\n       * or disable the default devtool with \"devtool: false\".\n       * If you are looking for production-ready output files, see mode: \"production\" (https://webpack.js.org/configuration/mode/).\n       */\n      /******/ ;(() => {\n        // webpackBootstrap\n        /******/ var __webpack_modules__ = {\n          /***/ '../node_modules/lunr/lunr.js':\n            /*!************************************!*\\\n  !*** ../node_modules/lunr/lunr.js ***!\n  \\************************************/\n            /***/ (module, exports, __webpack_require__) => {\n              eval(\n                \"var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;/**\\n * lunr - http://lunrjs.com - A bit like Solr, but much smaller and not as bright - 2.3.9\\n * Copyright (C) 2020 Oliver Nightingale\\n * @license MIT\\n */\\n\\n;(function(){\\n\\n/**\\n * A convenience function for configuring and constructing\\n * a new lunr Index.\\n *\\n * A lunr.Builder instance is created and the pipeline setup\\n * with a trimmer, stop word filter and stemmer.\\n *\\n * This builder object is yielded to the configuration function\\n * that is passed as a parameter, allowing the list of fields\\n * and other builder parameters to be customised.\\n *\\n * All documents _must_ be added within the passed config function.\\n *\\n * @example\\n * var idx = lunr(function () {\\n *   this.field('title')\\n *   this.field('body')\\n *   this.ref('id')\\n *\\n *   documents.forEach(function (doc) {\\n *     this.add(doc)\\n *   }, this)\\n * })\\n *\\n * @see {@link lunr.Builder}\\n * @see {@link lunr.Pipeline}\\n * @see {@link lunr.trimmer}\\n * @see {@link lunr.stopWordFilter}\\n * @see {@link lunr.stemmer}\\n * @namespace {function} lunr\\n */\\nvar lunr = function (config) {\\n  var builder = new lunr.Builder\\n\\n  builder.pipeline.add(\\n    lunr.trimmer,\\n    lunr.stopWordFilter,\\n    lunr.stemmer\\n  )\\n\\n  builder.searchPipeline.add(\\n    lunr.stemmer\\n  )\\n\\n  config.call(builder, builder)\\n  return builder.build()\\n}\\n\\nlunr.version = \\\"2.3.9\\\"\\n/*!\\n * lunr.utils\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A namespace containing utils for the rest of the lunr library\\n * @namespace lunr.utils\\n */\\nlunr.utils = {}\\n\\n/**\\n * Print a warning message to the console.\\n *\\n * @param {String} message The message to be printed.\\n * @memberOf lunr.utils\\n * @function\\n */\\nlunr.utils.warn = (function (global) {\\n  /* eslint-disable no-console */\\n  return function (message) {\\n    if (global.console && console.warn) {\\n      console.warn(message)\\n    }\\n  }\\n  /* eslint-enable no-console */\\n})(this)\\n\\n/**\\n * Convert an object to a string.\\n *\\n * In the case of `null` and `undefined` the function returns\\n * the empty string, in all other cases the result of calling\\n * `toString` on the passed object is returned.\\n *\\n * @param {Any} obj The object to convert to a string.\\n * @return {String} string representation of the passed object.\\n * @memberOf lunr.utils\\n */\\nlunr.utils.asString = function (obj) {\\n  if (obj === void 0 || obj === null) {\\n    return \\\"\\\"\\n  } else {\\n    return obj.toString()\\n  }\\n}\\n\\n/**\\n * Clones an object.\\n *\\n * Will create a copy of an existing object such that any mutations\\n * on the copy cannot affect the original.\\n *\\n * Only shallow objects are supported, passing a nested object to this\\n * function will cause a TypeError.\\n *\\n * Objects with primitives, and arrays of primitives are supported.\\n *\\n * @param {Object} obj The object to clone.\\n * @return {Object} a clone of the passed object.\\n * @throws {TypeError} when a nested object is passed.\\n * @memberOf Utils\\n */\\nlunr.utils.clone = function (obj) {\\n  if (obj === null || obj === undefined) {\\n    return obj\\n  }\\n\\n  var clone = Object.create(null),\\n      keys = Object.keys(obj)\\n\\n  for (var i = 0; i < keys.length; i++) {\\n    var key = keys[i],\\n        val = obj[key]\\n\\n    if (Array.isArray(val)) {\\n      clone[key] = val.slice()\\n      continue\\n    }\\n\\n    if (typeof val === 'string' ||\\n        typeof val === 'number' ||\\n        typeof val === 'boolean') {\\n      clone[key] = val\\n      continue\\n    }\\n\\n    throw new TypeError(\\\"clone is not deep and does not support nested objects\\\")\\n  }\\n\\n  return clone\\n}\\nlunr.FieldRef = function (docRef, fieldName, stringValue) {\\n  this.docRef = docRef\\n  this.fieldName = fieldName\\n  this._stringValue = stringValue\\n}\\n\\nlunr.FieldRef.joiner = \\\"/\\\"\\n\\nlunr.FieldRef.fromString = function (s) {\\n  var n = s.indexOf(lunr.FieldRef.joiner)\\n\\n  if (n === -1) {\\n    throw \\\"malformed field ref string\\\"\\n  }\\n\\n  var fieldRef = s.slice(0, n),\\n      docRef = s.slice(n + 1)\\n\\n  return new lunr.FieldRef (docRef, fieldRef, s)\\n}\\n\\nlunr.FieldRef.prototype.toString = function () {\\n  if (this._stringValue == undefined) {\\n    this._stringValue = this.fieldName + lunr.FieldRef.joiner + this.docRef\\n  }\\n\\n  return this._stringValue\\n}\\n/*!\\n * lunr.Set\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A lunr set.\\n *\\n * @constructor\\n */\\nlunr.Set = function (elements) {\\n  this.elements = Object.create(null)\\n\\n  if (elements) {\\n    this.length = elements.length\\n\\n    for (var i = 0; i < this.length; i++) {\\n      this.elements[elements[i]] = true\\n    }\\n  } else {\\n    this.length = 0\\n  }\\n}\\n\\n/**\\n * A complete set that contains all elements.\\n *\\n * @static\\n * @readonly\\n * @type {lunr.Set}\\n */\\nlunr.Set.complete = {\\n  intersect: function (other) {\\n    return other\\n  },\\n\\n  union: function () {\\n    return this\\n  },\\n\\n  contains: function () {\\n    return true\\n  }\\n}\\n\\n/**\\n * An empty set that contains no elements.\\n *\\n * @static\\n * @readonly\\n * @type {lunr.Set}\\n */\\nlunr.Set.empty = {\\n  intersect: function () {\\n    return this\\n  },\\n\\n  union: function (other) {\\n    return other\\n  },\\n\\n  contains: function () {\\n    return false\\n  }\\n}\\n\\n/**\\n * Returns true if this set contains the specified object.\\n *\\n * @param {object} object - Object whose presence in this set is to be tested.\\n * @returns {boolean} - True if this set contains the specified object.\\n */\\nlunr.Set.prototype.contains = function (object) {\\n  return !!this.elements[object]\\n}\\n\\n/**\\n * Returns a new set containing only the elements that are present in both\\n * this set and the specified set.\\n *\\n * @param {lunr.Set} other - set to intersect with this set.\\n * @returns {lunr.Set} a new set that is the intersection of this and the specified set.\\n */\\n\\nlunr.Set.prototype.intersect = function (other) {\\n  var a, b, elements, intersection = []\\n\\n  if (other === lunr.Set.complete) {\\n    return this\\n  }\\n\\n  if (other === lunr.Set.empty) {\\n    return other\\n  }\\n\\n  if (this.length < other.length) {\\n    a = this\\n    b = other\\n  } else {\\n    a = other\\n    b = this\\n  }\\n\\n  elements = Object.keys(a.elements)\\n\\n  for (var i = 0; i < elements.length; i++) {\\n    var element = elements[i]\\n    if (element in b.elements) {\\n      intersection.push(element)\\n    }\\n  }\\n\\n  return new lunr.Set (intersection)\\n}\\n\\n/**\\n * Returns a new set combining the elements of this and the specified set.\\n *\\n * @param {lunr.Set} other - set to union with this set.\\n * @return {lunr.Set} a new set that is the union of this and the specified set.\\n */\\n\\nlunr.Set.prototype.union = function (other) {\\n  if (other === lunr.Set.complete) {\\n    return lunr.Set.complete\\n  }\\n\\n  if (other === lunr.Set.empty) {\\n    return this\\n  }\\n\\n  return new lunr.Set(Object.keys(this.elements).concat(Object.keys(other.elements)))\\n}\\n/**\\n * A function to calculate the inverse document frequency for\\n * a posting. This is shared between the builder and the index\\n *\\n * @private\\n * @param {object} posting - The posting for a given term\\n * @param {number} documentCount - The total number of documents.\\n */\\nlunr.idf = function (posting, documentCount) {\\n  var documentsWithTerm = 0\\n\\n  for (var fieldName in posting) {\\n    if (fieldName == '_index') continue // Ignore the term index, its not a field\\n    documentsWithTerm += Object.keys(posting[fieldName]).length\\n  }\\n\\n  var x = (documentCount - documentsWithTerm + 0.5) / (documentsWithTerm + 0.5)\\n\\n  return Math.log(1 + Math.abs(x))\\n}\\n\\n/**\\n * A token wraps a string representation of a token\\n * as it is passed through the text processing pipeline.\\n *\\n * @constructor\\n * @param {string} [str=''] - The string token being wrapped.\\n * @param {object} [metadata={}] - Metadata associated with this token.\\n */\\nlunr.Token = function (str, metadata) {\\n  this.str = str || \\\"\\\"\\n  this.metadata = metadata || {}\\n}\\n\\n/**\\n * Returns the token string that is being wrapped by this object.\\n *\\n * @returns {string}\\n */\\nlunr.Token.prototype.toString = function () {\\n  return this.str\\n}\\n\\n/**\\n * A token update function is used when updating or optionally\\n * when cloning a token.\\n *\\n * @callback lunr.Token~updateFunction\\n * @param {string} str - The string representation of the token.\\n * @param {Object} metadata - All metadata associated with this token.\\n */\\n\\n/**\\n * Applies the given function to the wrapped string token.\\n *\\n * @example\\n * token.update(function (str, metadata) {\\n *   return str.toUpperCase()\\n * })\\n *\\n * @param {lunr.Token~updateFunction} fn - A function to apply to the token string.\\n * @returns {lunr.Token}\\n */\\nlunr.Token.prototype.update = function (fn) {\\n  this.str = fn(this.str, this.metadata)\\n  return this\\n}\\n\\n/**\\n * Creates a clone of this token. Optionally a function can be\\n * applied to the cloned token.\\n *\\n * @param {lunr.Token~updateFunction} [fn] - An optional function to apply to the cloned token.\\n * @returns {lunr.Token}\\n */\\nlunr.Token.prototype.clone = function (fn) {\\n  fn = fn || function (s) { return s }\\n  return new lunr.Token (fn(this.str, this.metadata), this.metadata)\\n}\\n/*!\\n * lunr.tokenizer\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A function for splitting a string into tokens ready to be inserted into\\n * the search index. Uses `lunr.tokenizer.separator` to split strings, change\\n * the value of this property to change how strings are split into tokens.\\n *\\n * This tokenizer will convert its parameter to a string by calling `toString` and\\n * then will split this string on the character in `lunr.tokenizer.separator`.\\n * Arrays will have their elements converted to strings and wrapped in a lunr.Token.\\n *\\n * Optional metadata can be passed to the tokenizer, this metadata will be cloned and\\n * added as metadata to every token that is created from the object to be tokenized.\\n *\\n * @static\\n * @param {?(string|object|object[])} obj - The object to convert into tokens\\n * @param {?object} metadata - Optional metadata to associate with every token\\n * @returns {lunr.Token[]}\\n * @see {@link lunr.Pipeline}\\n */\\nlunr.tokenizer = function (obj, metadata) {\\n  if (obj == null || obj == undefined) {\\n    return []\\n  }\\n\\n  if (Array.isArray(obj)) {\\n    return obj.map(function (t) {\\n      return new lunr.Token(\\n        lunr.utils.asString(t).toLowerCase(),\\n        lunr.utils.clone(metadata)\\n      )\\n    })\\n  }\\n\\n  var str = obj.toString().toLowerCase(),\\n      len = str.length,\\n      tokens = []\\n\\n  for (var sliceEnd = 0, sliceStart = 0; sliceEnd <= len; sliceEnd++) {\\n    var char = str.charAt(sliceEnd),\\n        sliceLength = sliceEnd - sliceStart\\n\\n    if ((char.match(lunr.tokenizer.separator) || sliceEnd == len)) {\\n\\n      if (sliceLength > 0) {\\n        var tokenMetadata = lunr.utils.clone(metadata) || {}\\n        tokenMetadata[\\\"position\\\"] = [sliceStart, sliceLength]\\n        tokenMetadata[\\\"index\\\"] = tokens.length\\n\\n        tokens.push(\\n          new lunr.Token (\\n            str.slice(sliceStart, sliceEnd),\\n            tokenMetadata\\n          )\\n        )\\n      }\\n\\n      sliceStart = sliceEnd + 1\\n    }\\n\\n  }\\n\\n  return tokens\\n}\\n\\n/**\\n * The separator used to split a string into tokens. Override this property to change the behaviour of\\n * `lunr.tokenizer` behaviour when tokenizing strings. By default this splits on whitespace and hyphens.\\n *\\n * @static\\n * @see lunr.tokenizer\\n */\\nlunr.tokenizer.separator = /[\\\\s\\\\-]+/\\n/*!\\n * lunr.Pipeline\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.Pipelines maintain an ordered list of functions to be applied to all\\n * tokens in documents entering the search index and queries being ran against\\n * the index.\\n *\\n * An instance of lunr.Index created with the lunr shortcut will contain a\\n * pipeline with a stop word filter and an English language stemmer. Extra\\n * functions can be added before or after either of these functions or these\\n * default functions can be removed.\\n *\\n * When run the pipeline will call each function in turn, passing a token, the\\n * index of that token in the original list of all tokens and finally a list of\\n * all the original tokens.\\n *\\n * The output of functions in the pipeline will be passed to the next function\\n * in the pipeline. To exclude a token from entering the index the function\\n * should return undefined, the rest of the pipeline will not be called with\\n * this token.\\n *\\n * For serialisation of pipelines to work, all functions used in an instance of\\n * a pipeline should be registered with lunr.Pipeline. Registered functions can\\n * then be loaded. If trying to load a serialised pipeline that uses functions\\n * that are not registered an error will be thrown.\\n *\\n * If not planning on serialising the pipeline then registering pipeline functions\\n * is not necessary.\\n *\\n * @constructor\\n */\\nlunr.Pipeline = function () {\\n  this._stack = []\\n}\\n\\nlunr.Pipeline.registeredFunctions = Object.create(null)\\n\\n/**\\n * A pipeline function maps lunr.Token to lunr.Token. A lunr.Token contains the token\\n * string as well as all known metadata. A pipeline function can mutate the token string\\n * or mutate (or add) metadata for a given token.\\n *\\n * A pipeline function can indicate that the passed token should be discarded by returning\\n * null, undefined or an empty string. This token will not be passed to any downstream pipeline\\n * functions and will not be added to the index.\\n *\\n * Multiple tokens can be returned by returning an array of tokens. Each token will be passed\\n * to any downstream pipeline functions and all will returned tokens will be added to the index.\\n *\\n * Any number of pipeline functions may be chained together using a lunr.Pipeline.\\n *\\n * @interface lunr.PipelineFunction\\n * @param {lunr.Token} token - A token from the document being processed.\\n * @param {number} i - The index of this token in the complete list of tokens for this document/field.\\n * @param {lunr.Token[]} tokens - All tokens for this document/field.\\n * @returns {(?lunr.Token|lunr.Token[])}\\n */\\n\\n/**\\n * Register a function with the pipeline.\\n *\\n * Functions that are used in the pipeline should be registered if the pipeline\\n * needs to be serialised, or a serialised pipeline needs to be loaded.\\n *\\n * Registering a function does not add it to a pipeline, functions must still be\\n * added to instances of the pipeline for them to be used when running a pipeline.\\n *\\n * @param {lunr.PipelineFunction} fn - The function to check for.\\n * @param {String} label - The label to register this function with\\n */\\nlunr.Pipeline.registerFunction = function (fn, label) {\\n  if (label in this.registeredFunctions) {\\n    lunr.utils.warn('Overwriting existing registered function: ' + label)\\n  }\\n\\n  fn.label = label\\n  lunr.Pipeline.registeredFunctions[fn.label] = fn\\n}\\n\\n/**\\n * Warns if the function is not registered as a Pipeline function.\\n *\\n * @param {lunr.PipelineFunction} fn - The function to check for.\\n * @private\\n */\\nlunr.Pipeline.warnIfFunctionNotRegistered = function (fn) {\\n  var isRegistered = fn.label && (fn.label in this.registeredFunctions)\\n\\n  if (!isRegistered) {\\n    lunr.utils.warn('Function is not registered with pipeline. This may cause problems when serialising the index.\\\\n', fn)\\n  }\\n}\\n\\n/**\\n * Loads a previously serialised pipeline.\\n *\\n * All functions to be loaded must already be registered with lunr.Pipeline.\\n * If any function from the serialised data has not been registered then an\\n * error will be thrown.\\n *\\n * @param {Object} serialised - The serialised pipeline to load.\\n * @returns {lunr.Pipeline}\\n */\\nlunr.Pipeline.load = function (serialised) {\\n  var pipeline = new lunr.Pipeline\\n\\n  serialised.forEach(function (fnName) {\\n    var fn = lunr.Pipeline.registeredFunctions[fnName]\\n\\n    if (fn) {\\n      pipeline.add(fn)\\n    } else {\\n      throw new Error('Cannot load unregistered function: ' + fnName)\\n    }\\n  })\\n\\n  return pipeline\\n}\\n\\n/**\\n * Adds new functions to the end of the pipeline.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @param {lunr.PipelineFunction[]} functions - Any number of functions to add to the pipeline.\\n */\\nlunr.Pipeline.prototype.add = function () {\\n  var fns = Array.prototype.slice.call(arguments)\\n\\n  fns.forEach(function (fn) {\\n    lunr.Pipeline.warnIfFunctionNotRegistered(fn)\\n    this._stack.push(fn)\\n  }, this)\\n}\\n\\n/**\\n * Adds a single function after a function that already exists in the\\n * pipeline.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @param {lunr.PipelineFunction} existingFn - A function that already exists in the pipeline.\\n * @param {lunr.PipelineFunction} newFn - The new function to add to the pipeline.\\n */\\nlunr.Pipeline.prototype.after = function (existingFn, newFn) {\\n  lunr.Pipeline.warnIfFunctionNotRegistered(newFn)\\n\\n  var pos = this._stack.indexOf(existingFn)\\n  if (pos == -1) {\\n    throw new Error('Cannot find existingFn')\\n  }\\n\\n  pos = pos + 1\\n  this._stack.splice(pos, 0, newFn)\\n}\\n\\n/**\\n * Adds a single function before a function that already exists in the\\n * pipeline.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @param {lunr.PipelineFunction} existingFn - A function that already exists in the pipeline.\\n * @param {lunr.PipelineFunction} newFn - The new function to add to the pipeline.\\n */\\nlunr.Pipeline.prototype.before = function (existingFn, newFn) {\\n  lunr.Pipeline.warnIfFunctionNotRegistered(newFn)\\n\\n  var pos = this._stack.indexOf(existingFn)\\n  if (pos == -1) {\\n    throw new Error('Cannot find existingFn')\\n  }\\n\\n  this._stack.splice(pos, 0, newFn)\\n}\\n\\n/**\\n * Removes a function from the pipeline.\\n *\\n * @param {lunr.PipelineFunction} fn The function to remove from the pipeline.\\n */\\nlunr.Pipeline.prototype.remove = function (fn) {\\n  var pos = this._stack.indexOf(fn)\\n  if (pos == -1) {\\n    return\\n  }\\n\\n  this._stack.splice(pos, 1)\\n}\\n\\n/**\\n * Runs the current list of functions that make up the pipeline against the\\n * passed tokens.\\n *\\n * @param {Array} tokens The tokens to run through the pipeline.\\n * @returns {Array}\\n */\\nlunr.Pipeline.prototype.run = function (tokens) {\\n  var stackLength = this._stack.length\\n\\n  for (var i = 0; i < stackLength; i++) {\\n    var fn = this._stack[i]\\n    var memo = []\\n\\n    for (var j = 0; j < tokens.length; j++) {\\n      var result = fn(tokens[j], j, tokens)\\n\\n      if (result === null || result === void 0 || result === '') continue\\n\\n      if (Array.isArray(result)) {\\n        for (var k = 0; k < result.length; k++) {\\n          memo.push(result[k])\\n        }\\n      } else {\\n        memo.push(result)\\n      }\\n    }\\n\\n    tokens = memo\\n  }\\n\\n  return tokens\\n}\\n\\n/**\\n * Convenience method for passing a string through a pipeline and getting\\n * strings out. This method takes care of wrapping the passed string in a\\n * token and mapping the resulting tokens back to strings.\\n *\\n * @param {string} str - The string to pass through the pipeline.\\n * @param {?object} metadata - Optional metadata to associate with the token\\n * passed to the pipeline.\\n * @returns {string[]}\\n */\\nlunr.Pipeline.prototype.runString = function (str, metadata) {\\n  var token = new lunr.Token (str, metadata)\\n\\n  return this.run([token]).map(function (t) {\\n    return t.toString()\\n  })\\n}\\n\\n/**\\n * Resets the pipeline by removing any existing processors.\\n *\\n */\\nlunr.Pipeline.prototype.reset = function () {\\n  this._stack = []\\n}\\n\\n/**\\n * Returns a representation of the pipeline ready for serialisation.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @returns {Array}\\n */\\nlunr.Pipeline.prototype.toJSON = function () {\\n  return this._stack.map(function (fn) {\\n    lunr.Pipeline.warnIfFunctionNotRegistered(fn)\\n\\n    return fn.label\\n  })\\n}\\n/*!\\n * lunr.Vector\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A vector is used to construct the vector space of documents and queries. These\\n * vectors support operations to determine the similarity between two documents or\\n * a document and a query.\\n *\\n * Normally no parameters are required for initializing a vector, but in the case of\\n * loading a previously dumped vector the raw elements can be provided to the constructor.\\n *\\n * For performance reasons vectors are implemented with a flat array, where an elements\\n * index is immediately followed by its value. E.g. [index, value, index, value]. This\\n * allows the underlying array to be as sparse as possible and still offer decent\\n * performance when being used for vector calculations.\\n *\\n * @constructor\\n * @param {Number[]} [elements] - The flat list of element index and element value pairs.\\n */\\nlunr.Vector = function (elements) {\\n  this._magnitude = 0\\n  this.elements = elements || []\\n}\\n\\n\\n/**\\n * Calculates the position within the vector to insert a given index.\\n *\\n * This is used internally by insert and upsert. If there are duplicate indexes then\\n * the position is returned as if the value for that index were to be updated, but it\\n * is the callers responsibility to check whether there is a duplicate at that index\\n *\\n * @param {Number} insertIdx - The index at which the element should be inserted.\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.positionForIndex = function (index) {\\n  // For an empty vector the tuple can be inserted at the beginning\\n  if (this.elements.length == 0) {\\n    return 0\\n  }\\n\\n  var start = 0,\\n      end = this.elements.length / 2,\\n      sliceLength = end - start,\\n      pivotPoint = Math.floor(sliceLength / 2),\\n      pivotIndex = this.elements[pivotPoint * 2]\\n\\n  while (sliceLength > 1) {\\n    if (pivotIndex < index) {\\n      start = pivotPoint\\n    }\\n\\n    if (pivotIndex > index) {\\n      end = pivotPoint\\n    }\\n\\n    if (pivotIndex == index) {\\n      break\\n    }\\n\\n    sliceLength = end - start\\n    pivotPoint = start + Math.floor(sliceLength / 2)\\n    pivotIndex = this.elements[pivotPoint * 2]\\n  }\\n\\n  if (pivotIndex == index) {\\n    return pivotPoint * 2\\n  }\\n\\n  if (pivotIndex > index) {\\n    return pivotPoint * 2\\n  }\\n\\n  if (pivotIndex < index) {\\n    return (pivotPoint + 1) * 2\\n  }\\n}\\n\\n/**\\n * Inserts an element at an index within the vector.\\n *\\n * Does not allow duplicates, will throw an error if there is already an entry\\n * for this index.\\n *\\n * @param {Number} insertIdx - The index at which the element should be inserted.\\n * @param {Number} val - The value to be inserted into the vector.\\n */\\nlunr.Vector.prototype.insert = function (insertIdx, val) {\\n  this.upsert(insertIdx, val, function () {\\n    throw \\\"duplicate index\\\"\\n  })\\n}\\n\\n/**\\n * Inserts or updates an existing index within the vector.\\n *\\n * @param {Number} insertIdx - The index at which the element should be inserted.\\n * @param {Number} val - The value to be inserted into the vector.\\n * @param {function} fn - A function that is called for updates, the existing value and the\\n * requested value are passed as arguments\\n */\\nlunr.Vector.prototype.upsert = function (insertIdx, val, fn) {\\n  this._magnitude = 0\\n  var position = this.positionForIndex(insertIdx)\\n\\n  if (this.elements[position] == insertIdx) {\\n    this.elements[position + 1] = fn(this.elements[position + 1], val)\\n  } else {\\n    this.elements.splice(position, 0, insertIdx, val)\\n  }\\n}\\n\\n/**\\n * Calculates the magnitude of this vector.\\n *\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.magnitude = function () {\\n  if (this._magnitude) return this._magnitude\\n\\n  var sumOfSquares = 0,\\n      elementsLength = this.elements.length\\n\\n  for (var i = 1; i < elementsLength; i += 2) {\\n    var val = this.elements[i]\\n    sumOfSquares += val * val\\n  }\\n\\n  return this._magnitude = Math.sqrt(sumOfSquares)\\n}\\n\\n/**\\n * Calculates the dot product of this vector and another vector.\\n *\\n * @param {lunr.Vector} otherVector - The vector to compute the dot product with.\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.dot = function (otherVector) {\\n  var dotProduct = 0,\\n      a = this.elements, b = otherVector.elements,\\n      aLen = a.length, bLen = b.length,\\n      aVal = 0, bVal = 0,\\n      i = 0, j = 0\\n\\n  while (i < aLen && j < bLen) {\\n    aVal = a[i], bVal = b[j]\\n    if (aVal < bVal) {\\n      i += 2\\n    } else if (aVal > bVal) {\\n      j += 2\\n    } else if (aVal == bVal) {\\n      dotProduct += a[i + 1] * b[j + 1]\\n      i += 2\\n      j += 2\\n    }\\n  }\\n\\n  return dotProduct\\n}\\n\\n/**\\n * Calculates the similarity between this vector and another vector.\\n *\\n * @param {lunr.Vector} otherVector - The other vector to calculate the\\n * similarity with.\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.similarity = function (otherVector) {\\n  return this.dot(otherVector) / this.magnitude() || 0\\n}\\n\\n/**\\n * Converts the vector to an array of the elements within the vector.\\n *\\n * @returns {Number[]}\\n */\\nlunr.Vector.prototype.toArray = function () {\\n  var output = new Array (this.elements.length / 2)\\n\\n  for (var i = 1, j = 0; i < this.elements.length; i += 2, j++) {\\n    output[j] = this.elements[i]\\n  }\\n\\n  return output\\n}\\n\\n/**\\n * A JSON serializable representation of the vector.\\n *\\n * @returns {Number[]}\\n */\\nlunr.Vector.prototype.toJSON = function () {\\n  return this.elements\\n}\\n/* eslint-disable */\\n/*!\\n * lunr.stemmer\\n * Copyright (C) 2020 Oliver Nightingale\\n * Includes code from - http://tartarus.org/~martin/PorterStemmer/js.txt\\n */\\n\\n/**\\n * lunr.stemmer is an english language stemmer, this is a JavaScript\\n * implementation of the PorterStemmer taken from http://tartarus.org/~martin\\n *\\n * @static\\n * @implements {lunr.PipelineFunction}\\n * @param {lunr.Token} token - The string to stem\\n * @returns {lunr.Token}\\n * @see {@link lunr.Pipeline}\\n * @function\\n */\\nlunr.stemmer = (function(){\\n  var step2list = {\\n      \\\"ational\\\" : \\\"ate\\\",\\n      \\\"tional\\\" : \\\"tion\\\",\\n      \\\"enci\\\" : \\\"ence\\\",\\n      \\\"anci\\\" : \\\"ance\\\",\\n      \\\"izer\\\" : \\\"ize\\\",\\n      \\\"bli\\\" : \\\"ble\\\",\\n      \\\"alli\\\" : \\\"al\\\",\\n      \\\"entli\\\" : \\\"ent\\\",\\n      \\\"eli\\\" : \\\"e\\\",\\n      \\\"ousli\\\" : \\\"ous\\\",\\n      \\\"ization\\\" : \\\"ize\\\",\\n      \\\"ation\\\" : \\\"ate\\\",\\n      \\\"ator\\\" : \\\"ate\\\",\\n      \\\"alism\\\" : \\\"al\\\",\\n      \\\"iveness\\\" : \\\"ive\\\",\\n      \\\"fulness\\\" : \\\"ful\\\",\\n      \\\"ousness\\\" : \\\"ous\\\",\\n      \\\"aliti\\\" : \\\"al\\\",\\n      \\\"iviti\\\" : \\\"ive\\\",\\n      \\\"biliti\\\" : \\\"ble\\\",\\n      \\\"logi\\\" : \\\"log\\\"\\n    },\\n\\n    step3list = {\\n      \\\"icate\\\" : \\\"ic\\\",\\n      \\\"ative\\\" : \\\"\\\",\\n      \\\"alize\\\" : \\\"al\\\",\\n      \\\"iciti\\\" : \\\"ic\\\",\\n      \\\"ical\\\" : \\\"ic\\\",\\n      \\\"ful\\\" : \\\"\\\",\\n      \\\"ness\\\" : \\\"\\\"\\n    },\\n\\n    c = \\\"[^aeiou]\\\",          // consonant\\n    v = \\\"[aeiouy]\\\",          // vowel\\n    C = c + \\\"[^aeiouy]*\\\",    // consonant sequence\\n    V = v + \\\"[aeiou]*\\\",      // vowel sequence\\n\\n    mgr0 = \\\"^(\\\" + C + \\\")?\\\" + V + C,               // [C]VC... is m>0\\n    meq1 = \\\"^(\\\" + C + \\\")?\\\" + V + C + \\\"(\\\" + V + \\\")?$\\\",  // [C]VC[V] is m=1\\n    mgr1 = \\\"^(\\\" + C + \\\")?\\\" + V + C + V + C,       // [C]VCVC... is m>1\\n    s_v = \\\"^(\\\" + C + \\\")?\\\" + v;                   // vowel in stem\\n\\n  var re_mgr0 = new RegExp(mgr0);\\n  var re_mgr1 = new RegExp(mgr1);\\n  var re_meq1 = new RegExp(meq1);\\n  var re_s_v = new RegExp(s_v);\\n\\n  var re_1a = /^(.+?)(ss|i)es$/;\\n  var re2_1a = /^(.+?)([^s])s$/;\\n  var re_1b = /^(.+?)eed$/;\\n  var re2_1b = /^(.+?)(ed|ing)$/;\\n  var re_1b_2 = /.$/;\\n  var re2_1b_2 = /(at|bl|iz)$/;\\n  var re3_1b_2 = new RegExp(\\\"([^aeiouylsz])\\\\\\\\1$\\\");\\n  var re4_1b_2 = new RegExp(\\\"^\\\" + C + v + \\\"[^aeiouwxy]$\\\");\\n\\n  var re_1c = /^(.+?[^aeiou])y$/;\\n  var re_2 = /^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/;\\n\\n  var re_3 = /^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/;\\n\\n  var re_4 = /^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/;\\n  var re2_4 = /^(.+?)(s|t)(ion)$/;\\n\\n  var re_5 = /^(.+?)e$/;\\n  var re_5_1 = /ll$/;\\n  var re3_5 = new RegExp(\\\"^\\\" + C + v + \\\"[^aeiouwxy]$\\\");\\n\\n  var porterStemmer = function porterStemmer(w) {\\n    var stem,\\n      suffix,\\n      firstch,\\n      re,\\n      re2,\\n      re3,\\n      re4;\\n\\n    if (w.length < 3) { return w; }\\n\\n    firstch = w.substr(0,1);\\n    if (firstch == \\\"y\\\") {\\n      w = firstch.toUpperCase() + w.substr(1);\\n    }\\n\\n    // Step 1a\\n    re = re_1a\\n    re2 = re2_1a;\\n\\n    if (re.test(w)) { w = w.replace(re,\\\"$1$2\\\"); }\\n    else if (re2.test(w)) { w = w.replace(re2,\\\"$1$2\\\"); }\\n\\n    // Step 1b\\n    re = re_1b;\\n    re2 = re2_1b;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      re = re_mgr0;\\n      if (re.test(fp[1])) {\\n        re = re_1b_2;\\n        w = w.replace(re,\\\"\\\");\\n      }\\n    } else if (re2.test(w)) {\\n      var fp = re2.exec(w);\\n      stem = fp[1];\\n      re2 = re_s_v;\\n      if (re2.test(stem)) {\\n        w = stem;\\n        re2 = re2_1b_2;\\n        re3 = re3_1b_2;\\n        re4 = re4_1b_2;\\n        if (re2.test(w)) { w = w + \\\"e\\\"; }\\n        else if (re3.test(w)) { re = re_1b_2; w = w.replace(re,\\\"\\\"); }\\n        else if (re4.test(w)) { w = w + \\\"e\\\"; }\\n      }\\n    }\\n\\n    // Step 1c - replace suffix y or Y by i if preceded by a non-vowel which is not the first letter of the word (so cry -> cri, by -> by, say -> say)\\n    re = re_1c;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      w = stem + \\\"i\\\";\\n    }\\n\\n    // Step 2\\n    re = re_2;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      suffix = fp[2];\\n      re = re_mgr0;\\n      if (re.test(stem)) {\\n        w = stem + step2list[suffix];\\n      }\\n    }\\n\\n    // Step 3\\n    re = re_3;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      suffix = fp[2];\\n      re = re_mgr0;\\n      if (re.test(stem)) {\\n        w = stem + step3list[suffix];\\n      }\\n    }\\n\\n    // Step 4\\n    re = re_4;\\n    re2 = re2_4;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      re = re_mgr1;\\n      if (re.test(stem)) {\\n        w = stem;\\n      }\\n    } else if (re2.test(w)) {\\n      var fp = re2.exec(w);\\n      stem = fp[1] + fp[2];\\n      re2 = re_mgr1;\\n      if (re2.test(stem)) {\\n        w = stem;\\n      }\\n    }\\n\\n    // Step 5\\n    re = re_5;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      re = re_mgr1;\\n      re2 = re_meq1;\\n      re3 = re3_5;\\n      if (re.test(stem) || (re2.test(stem) && !(re3.test(stem)))) {\\n        w = stem;\\n      }\\n    }\\n\\n    re = re_5_1;\\n    re2 = re_mgr1;\\n    if (re.test(w) && re2.test(w)) {\\n      re = re_1b_2;\\n      w = w.replace(re,\\\"\\\");\\n    }\\n\\n    // and turn initial Y back to y\\n\\n    if (firstch == \\\"y\\\") {\\n      w = firstch.toLowerCase() + w.substr(1);\\n    }\\n\\n    return w;\\n  };\\n\\n  return function (token) {\\n    return token.update(porterStemmer);\\n  }\\n})();\\n\\nlunr.Pipeline.registerFunction(lunr.stemmer, 'stemmer')\\n/*!\\n * lunr.stopWordFilter\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.generateStopWordFilter builds a stopWordFilter function from the provided\\n * list of stop words.\\n *\\n * The built in lunr.stopWordFilter is built using this generator and can be used\\n * to generate custom stopWordFilters for applications or non English languages.\\n *\\n * @function\\n * @param {Array} token The token to pass through the filter\\n * @returns {lunr.PipelineFunction}\\n * @see lunr.Pipeline\\n * @see lunr.stopWordFilter\\n */\\nlunr.generateStopWordFilter = function (stopWords) {\\n  var words = stopWords.reduce(function (memo, stopWord) {\\n    memo[stopWord] = stopWord\\n    return memo\\n  }, {})\\n\\n  return function (token) {\\n    if (token && words[token.toString()] !== token.toString()) return token\\n  }\\n}\\n\\n/**\\n * lunr.stopWordFilter is an English language stop word list filter, any words\\n * contained in the list will not be passed through the filter.\\n *\\n * This is intended to be used in the Pipeline. If the token does not pass the\\n * filter then undefined will be returned.\\n *\\n * @function\\n * @implements {lunr.PipelineFunction}\\n * @params {lunr.Token} token - A token to check for being a stop word.\\n * @returns {lunr.Token}\\n * @see {@link lunr.Pipeline}\\n */\\nlunr.stopWordFilter = lunr.generateStopWordFilter([\\n  'a',\\n  'able',\\n  'about',\\n  'across',\\n  'after',\\n  'all',\\n  'almost',\\n  'also',\\n  'am',\\n  'among',\\n  'an',\\n  'and',\\n  'any',\\n  'are',\\n  'as',\\n  'at',\\n  'be',\\n  'because',\\n  'been',\\n  'but',\\n  'by',\\n  'can',\\n  'cannot',\\n  'could',\\n  'dear',\\n  'did',\\n  'do',\\n  'does',\\n  'either',\\n  'else',\\n  'ever',\\n  'every',\\n  'for',\\n  'from',\\n  'get',\\n  'got',\\n  'had',\\n  'has',\\n  'have',\\n  'he',\\n  'her',\\n  'hers',\\n  'him',\\n  'his',\\n  'how',\\n  'however',\\n  'i',\\n  'if',\\n  'in',\\n  'into',\\n  'is',\\n  'it',\\n  'its',\\n  'just',\\n  'least',\\n  'let',\\n  'like',\\n  'likely',\\n  'may',\\n  'me',\\n  'might',\\n  'most',\\n  'must',\\n  'my',\\n  'neither',\\n  'no',\\n  'nor',\\n  'not',\\n  'of',\\n  'off',\\n  'often',\\n  'on',\\n  'only',\\n  'or',\\n  'other',\\n  'our',\\n  'own',\\n  'rather',\\n  'said',\\n  'say',\\n  'says',\\n  'she',\\n  'should',\\n  'since',\\n  'so',\\n  'some',\\n  'than',\\n  'that',\\n  'the',\\n  'their',\\n  'them',\\n  'then',\\n  'there',\\n  'these',\\n  'they',\\n  'this',\\n  'tis',\\n  'to',\\n  'too',\\n  'twas',\\n  'us',\\n  'wants',\\n  'was',\\n  'we',\\n  'were',\\n  'what',\\n  'when',\\n  'where',\\n  'which',\\n  'while',\\n  'who',\\n  'whom',\\n  'why',\\n  'will',\\n  'with',\\n  'would',\\n  'yet',\\n  'you',\\n  'your'\\n])\\n\\nlunr.Pipeline.registerFunction(lunr.stopWordFilter, 'stopWordFilter')\\n/*!\\n * lunr.trimmer\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.trimmer is a pipeline function for trimming non word\\n * characters from the beginning and end of tokens before they\\n * enter the index.\\n *\\n * This implementation may not work correctly for non latin\\n * characters and should either be removed or adapted for use\\n * with languages with non-latin characters.\\n *\\n * @static\\n * @implements {lunr.PipelineFunction}\\n * @param {lunr.Token} token The token to pass through the filter\\n * @returns {lunr.Token}\\n * @see lunr.Pipeline\\n */\\nlunr.trimmer = function (token) {\\n  return token.update(function (s) {\\n    return s.replace(/^\\\\W+/, '').replace(/\\\\W+$/, '')\\n  })\\n}\\n\\nlunr.Pipeline.registerFunction(lunr.trimmer, 'trimmer')\\n/*!\\n * lunr.TokenSet\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A token set is used to store the unique list of all tokens\\n * within an index. Token sets are also used to represent an\\n * incoming query to the index, this query token set and index\\n * token set are then intersected to find which tokens to look\\n * up in the inverted index.\\n *\\n * A token set can hold multiple tokens, as in the case of the\\n * index token set, or it can hold a single token as in the\\n * case of a simple query token set.\\n *\\n * Additionally token sets are used to perform wildcard matching.\\n * Leading, contained and trailing wildcards are supported, and\\n * from this edit distance matching can also be provided.\\n *\\n * Token sets are implemented as a minimal finite state automata,\\n * where both common prefixes and suffixes are shared between tokens.\\n * This helps to reduce the space used for storing the token set.\\n *\\n * @constructor\\n */\\nlunr.TokenSet = function () {\\n  this.final = false\\n  this.edges = {}\\n  this.id = lunr.TokenSet._nextId\\n  lunr.TokenSet._nextId += 1\\n}\\n\\n/**\\n * Keeps track of the next, auto increment, identifier to assign\\n * to a new tokenSet.\\n *\\n * TokenSets require a unique identifier to be correctly minimised.\\n *\\n * @private\\n */\\nlunr.TokenSet._nextId = 1\\n\\n/**\\n * Creates a TokenSet instance from the given sorted array of words.\\n *\\n * @param {String[]} arr - A sorted array of strings to create the set from.\\n * @returns {lunr.TokenSet}\\n * @throws Will throw an error if the input array is not sorted.\\n */\\nlunr.TokenSet.fromArray = function (arr) {\\n  var builder = new lunr.TokenSet.Builder\\n\\n  for (var i = 0, len = arr.length; i < len; i++) {\\n    builder.insert(arr[i])\\n  }\\n\\n  builder.finish()\\n  return builder.root\\n}\\n\\n/**\\n * Creates a token set from a query clause.\\n *\\n * @private\\n * @param {Object} clause - A single clause from lunr.Query.\\n * @param {string} clause.term - The query clause term.\\n * @param {number} [clause.editDistance] - The optional edit distance for the term.\\n * @returns {lunr.TokenSet}\\n */\\nlunr.TokenSet.fromClause = function (clause) {\\n  if ('editDistance' in clause) {\\n    return lunr.TokenSet.fromFuzzyString(clause.term, clause.editDistance)\\n  } else {\\n    return lunr.TokenSet.fromString(clause.term)\\n  }\\n}\\n\\n/**\\n * Creates a token set representing a single string with a specified\\n * edit distance.\\n *\\n * Insertions, deletions, substitutions and transpositions are each\\n * treated as an edit distance of 1.\\n *\\n * Increasing the allowed edit distance will have a dramatic impact\\n * on the performance of both creating and intersecting these TokenSets.\\n * It is advised to keep the edit distance less than 3.\\n *\\n * @param {string} str - The string to create the token set from.\\n * @param {number} editDistance - The allowed edit distance to match.\\n * @returns {lunr.Vector}\\n */\\nlunr.TokenSet.fromFuzzyString = function (str, editDistance) {\\n  var root = new lunr.TokenSet\\n\\n  var stack = [{\\n    node: root,\\n    editsRemaining: editDistance,\\n    str: str\\n  }]\\n\\n  while (stack.length) {\\n    var frame = stack.pop()\\n\\n    // no edit\\n    if (frame.str.length > 0) {\\n      var char = frame.str.charAt(0),\\n          noEditNode\\n\\n      if (char in frame.node.edges) {\\n        noEditNode = frame.node.edges[char]\\n      } else {\\n        noEditNode = new lunr.TokenSet\\n        frame.node.edges[char] = noEditNode\\n      }\\n\\n      if (frame.str.length == 1) {\\n        noEditNode.final = true\\n      }\\n\\n      stack.push({\\n        node: noEditNode,\\n        editsRemaining: frame.editsRemaining,\\n        str: frame.str.slice(1)\\n      })\\n    }\\n\\n    if (frame.editsRemaining == 0) {\\n      continue\\n    }\\n\\n    // insertion\\n    if (\\\"*\\\" in frame.node.edges) {\\n      var insertionNode = frame.node.edges[\\\"*\\\"]\\n    } else {\\n      var insertionNode = new lunr.TokenSet\\n      frame.node.edges[\\\"*\\\"] = insertionNode\\n    }\\n\\n    if (frame.str.length == 0) {\\n      insertionNode.final = true\\n    }\\n\\n    stack.push({\\n      node: insertionNode,\\n      editsRemaining: frame.editsRemaining - 1,\\n      str: frame.str\\n    })\\n\\n    // deletion\\n    // can only do a deletion if we have enough edits remaining\\n    // and if there are characters left to delete in the string\\n    if (frame.str.length > 1) {\\n      stack.push({\\n        node: frame.node,\\n        editsRemaining: frame.editsRemaining - 1,\\n        str: frame.str.slice(1)\\n      })\\n    }\\n\\n    // deletion\\n    // just removing the last character from the str\\n    if (frame.str.length == 1) {\\n      frame.node.final = true\\n    }\\n\\n    // substitution\\n    // can only do a substitution if we have enough edits remaining\\n    // and if there are characters left to substitute\\n    if (frame.str.length >= 1) {\\n      if (\\\"*\\\" in frame.node.edges) {\\n        var substitutionNode = frame.node.edges[\\\"*\\\"]\\n      } else {\\n        var substitutionNode = new lunr.TokenSet\\n        frame.node.edges[\\\"*\\\"] = substitutionNode\\n      }\\n\\n      if (frame.str.length == 1) {\\n        substitutionNode.final = true\\n      }\\n\\n      stack.push({\\n        node: substitutionNode,\\n        editsRemaining: frame.editsRemaining - 1,\\n        str: frame.str.slice(1)\\n      })\\n    }\\n\\n    // transposition\\n    // can only do a transposition if there are edits remaining\\n    // and there are enough characters to transpose\\n    if (frame.str.length > 1) {\\n      var charA = frame.str.charAt(0),\\n          charB = frame.str.charAt(1),\\n          transposeNode\\n\\n      if (charB in frame.node.edges) {\\n        transposeNode = frame.node.edges[charB]\\n      } else {\\n        transposeNode = new lunr.TokenSet\\n        frame.node.edges[charB] = transposeNode\\n      }\\n\\n      if (frame.str.length == 1) {\\n        transposeNode.final = true\\n      }\\n\\n      stack.push({\\n        node: transposeNode,\\n        editsRemaining: frame.editsRemaining - 1,\\n        str: charA + frame.str.slice(2)\\n      })\\n    }\\n  }\\n\\n  return root\\n}\\n\\n/**\\n * Creates a TokenSet from a string.\\n *\\n * The string may contain one or more wildcard characters (*)\\n * that will allow wildcard matching when intersecting with\\n * another TokenSet.\\n *\\n * @param {string} str - The string to create a TokenSet from.\\n * @returns {lunr.TokenSet}\\n */\\nlunr.TokenSet.fromString = function (str) {\\n  var node = new lunr.TokenSet,\\n      root = node\\n\\n  /*\\n   * Iterates through all characters within the passed string\\n   * appending a node for each character.\\n   *\\n   * When a wildcard character is found then a self\\n   * referencing edge is introduced to continually match\\n   * any number of any characters.\\n   */\\n  for (var i = 0, len = str.length; i < len; i++) {\\n    var char = str[i],\\n        final = (i == len - 1)\\n\\n    if (char == \\\"*\\\") {\\n      node.edges[char] = node\\n      node.final = final\\n\\n    } else {\\n      var next = new lunr.TokenSet\\n      next.final = final\\n\\n      node.edges[char] = next\\n      node = next\\n    }\\n  }\\n\\n  return root\\n}\\n\\n/**\\n * Converts this TokenSet into an array of strings\\n * contained within the TokenSet.\\n *\\n * This is not intended to be used on a TokenSet that\\n * contains wildcards, in these cases the results are\\n * undefined and are likely to cause an infinite loop.\\n *\\n * @returns {string[]}\\n */\\nlunr.TokenSet.prototype.toArray = function () {\\n  var words = []\\n\\n  var stack = [{\\n    prefix: \\\"\\\",\\n    node: this\\n  }]\\n\\n  while (stack.length) {\\n    var frame = stack.pop(),\\n        edges = Object.keys(frame.node.edges),\\n        len = edges.length\\n\\n    if (frame.node.final) {\\n      /* In Safari, at this point the prefix is sometimes corrupted, see:\\n       * https://github.com/olivernn/lunr.js/issues/279 Calling any\\n       * String.prototype method forces Safari to \\\"cast\\\" this string to what\\n       * it's supposed to be, fixing the bug. */\\n      frame.prefix.charAt(0)\\n      words.push(frame.prefix)\\n    }\\n\\n    for (var i = 0; i < len; i++) {\\n      var edge = edges[i]\\n\\n      stack.push({\\n        prefix: frame.prefix.concat(edge),\\n        node: frame.node.edges[edge]\\n      })\\n    }\\n  }\\n\\n  return words\\n}\\n\\n/**\\n * Generates a string representation of a TokenSet.\\n *\\n * This is intended to allow TokenSets to be used as keys\\n * in objects, largely to aid the construction and minimisation\\n * of a TokenSet. As such it is not designed to be a human\\n * friendly representation of the TokenSet.\\n *\\n * @returns {string}\\n */\\nlunr.TokenSet.prototype.toString = function () {\\n  // NOTE: Using Object.keys here as this.edges is very likely\\n  // to enter 'hash-mode' with many keys being added\\n  //\\n  // avoiding a for-in loop here as it leads to the function\\n  // being de-optimised (at least in V8). From some simple\\n  // benchmarks the performance is comparable, but allowing\\n  // V8 to optimize may mean easy performance wins in the future.\\n\\n  if (this._str) {\\n    return this._str\\n  }\\n\\n  var str = this.final ? '1' : '0',\\n      labels = Object.keys(this.edges).sort(),\\n      len = labels.length\\n\\n  for (var i = 0; i < len; i++) {\\n    var label = labels[i],\\n        node = this.edges[label]\\n\\n    str = str + label + node.id\\n  }\\n\\n  return str\\n}\\n\\n/**\\n * Returns a new TokenSet that is the intersection of\\n * this TokenSet and the passed TokenSet.\\n *\\n * This intersection will take into account any wildcards\\n * contained within the TokenSet.\\n *\\n * @param {lunr.TokenSet} b - An other TokenSet to intersect with.\\n * @returns {lunr.TokenSet}\\n */\\nlunr.TokenSet.prototype.intersect = function (b) {\\n  var output = new lunr.TokenSet,\\n      frame = undefined\\n\\n  var stack = [{\\n    qNode: b,\\n    output: output,\\n    node: this\\n  }]\\n\\n  while (stack.length) {\\n    frame = stack.pop()\\n\\n    // NOTE: As with the #toString method, we are using\\n    // Object.keys and a for loop instead of a for-in loop\\n    // as both of these objects enter 'hash' mode, causing\\n    // the function to be de-optimised in V8\\n    var qEdges = Object.keys(frame.qNode.edges),\\n        qLen = qEdges.length,\\n        nEdges = Object.keys(frame.node.edges),\\n        nLen = nEdges.length\\n\\n    for (var q = 0; q < qLen; q++) {\\n      var qEdge = qEdges[q]\\n\\n      for (var n = 0; n < nLen; n++) {\\n        var nEdge = nEdges[n]\\n\\n        if (nEdge == qEdge || qEdge == '*') {\\n          var node = frame.node.edges[nEdge],\\n              qNode = frame.qNode.edges[qEdge],\\n              final = node.final && qNode.final,\\n              next = undefined\\n\\n          if (nEdge in frame.output.edges) {\\n            // an edge already exists for this character\\n            // no need to create a new node, just set the finality\\n            // bit unless this node is already final\\n            next = frame.output.edges[nEdge]\\n            next.final = next.final || final\\n\\n          } else {\\n            // no edge exists yet, must create one\\n            // set the finality bit and insert it\\n            // into the output\\n            next = new lunr.TokenSet\\n            next.final = final\\n            frame.output.edges[nEdge] = next\\n          }\\n\\n          stack.push({\\n            qNode: qNode,\\n            output: next,\\n            node: node\\n          })\\n        }\\n      }\\n    }\\n  }\\n\\n  return output\\n}\\nlunr.TokenSet.Builder = function () {\\n  this.previousWord = \\\"\\\"\\n  this.root = new lunr.TokenSet\\n  this.uncheckedNodes = []\\n  this.minimizedNodes = {}\\n}\\n\\nlunr.TokenSet.Builder.prototype.insert = function (word) {\\n  var node,\\n      commonPrefix = 0\\n\\n  if (word < this.previousWord) {\\n    throw new Error (\\\"Out of order word insertion\\\")\\n  }\\n\\n  for (var i = 0; i < word.length && i < this.previousWord.length; i++) {\\n    if (word[i] != this.previousWord[i]) break\\n    commonPrefix++\\n  }\\n\\n  this.minimize(commonPrefix)\\n\\n  if (this.uncheckedNodes.length == 0) {\\n    node = this.root\\n  } else {\\n    node = this.uncheckedNodes[this.uncheckedNodes.length - 1].child\\n  }\\n\\n  for (var i = commonPrefix; i < word.length; i++) {\\n    var nextNode = new lunr.TokenSet,\\n        char = word[i]\\n\\n    node.edges[char] = nextNode\\n\\n    this.uncheckedNodes.push({\\n      parent: node,\\n      char: char,\\n      child: nextNode\\n    })\\n\\n    node = nextNode\\n  }\\n\\n  node.final = true\\n  this.previousWord = word\\n}\\n\\nlunr.TokenSet.Builder.prototype.finish = function () {\\n  this.minimize(0)\\n}\\n\\nlunr.TokenSet.Builder.prototype.minimize = function (downTo) {\\n  for (var i = this.uncheckedNodes.length - 1; i >= downTo; i--) {\\n    var node = this.uncheckedNodes[i],\\n        childKey = node.child.toString()\\n\\n    if (childKey in this.minimizedNodes) {\\n      node.parent.edges[node.char] = this.minimizedNodes[childKey]\\n    } else {\\n      // Cache the key for this node since\\n      // we know it can't change anymore\\n      node.child._str = childKey\\n\\n      this.minimizedNodes[childKey] = node.child\\n    }\\n\\n    this.uncheckedNodes.pop()\\n  }\\n}\\n/*!\\n * lunr.Index\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * An index contains the built index of all documents and provides a query interface\\n * to the index.\\n *\\n * Usually instances of lunr.Index will not be created using this constructor, instead\\n * lunr.Builder should be used to construct new indexes, or lunr.Index.load should be\\n * used to load previously built and serialized indexes.\\n *\\n * @constructor\\n * @param {Object} attrs - The attributes of the built search index.\\n * @param {Object} attrs.invertedIndex - An index of term/field to document reference.\\n * @param {Object<string, lunr.Vector>} attrs.fieldVectors - Field vectors\\n * @param {lunr.TokenSet} attrs.tokenSet - An set of all corpus tokens.\\n * @param {string[]} attrs.fields - The names of indexed document fields.\\n * @param {lunr.Pipeline} attrs.pipeline - The pipeline to use for search terms.\\n */\\nlunr.Index = function (attrs) {\\n  this.invertedIndex = attrs.invertedIndex\\n  this.fieldVectors = attrs.fieldVectors\\n  this.tokenSet = attrs.tokenSet\\n  this.fields = attrs.fields\\n  this.pipeline = attrs.pipeline\\n}\\n\\n/**\\n * A result contains details of a document matching a search query.\\n * @typedef {Object} lunr.Index~Result\\n * @property {string} ref - The reference of the document this result represents.\\n * @property {number} score - A number between 0 and 1 representing how similar this document is to the query.\\n * @property {lunr.MatchData} matchData - Contains metadata about this match including which term(s) caused the match.\\n */\\n\\n/**\\n * Although lunr provides the ability to create queries using lunr.Query, it also provides a simple\\n * query language which itself is parsed into an instance of lunr.Query.\\n *\\n * For programmatically building queries it is advised to directly use lunr.Query, the query language\\n * is best used for human entered text rather than program generated text.\\n *\\n * At its simplest queries can just be a single term, e.g. `hello`, multiple terms are also supported\\n * and will be combined with OR, e.g `hello world` will match documents that contain either 'hello'\\n * or 'world', though those that contain both will rank higher in the results.\\n *\\n * Wildcards can be included in terms to match one or more unspecified characters, these wildcards can\\n * be inserted anywhere within the term, and more than one wildcard can exist in a single term. Adding\\n * wildcards will increase the number of documents that will be found but can also have a negative\\n * impact on query performance, especially with wildcards at the beginning of a term.\\n *\\n * Terms can be restricted to specific fields, e.g. `title:hello`, only documents with the term\\n * hello in the title field will match this query. Using a field not present in the index will lead\\n * to an error being thrown.\\n *\\n * Modifiers can also be added to terms, lunr supports edit distance and boost modifiers on terms. A term\\n * boost will make documents matching that term score higher, e.g. `foo^5`. Edit distance is also supported\\n * to provide fuzzy matching, e.g. 'hello~2' will match documents with hello with an edit distance of 2.\\n * Avoid large values for edit distance to improve query performance.\\n *\\n * Each term also supports a presence modifier. By default a term's presence in document is optional, however\\n * this can be changed to either required or prohibited. For a term's presence to be required in a document the\\n * term should be prefixed with a '+', e.g. `+foo bar` is a search for documents that must contain 'foo' and\\n * optionally contain 'bar'. Conversely a leading '-' sets the terms presence to prohibited, i.e. it must not\\n * appear in a document, e.g. `-foo bar` is a search for documents that do not contain 'foo' but may contain 'bar'.\\n *\\n * To escape special characters the backslash character '\\\\' can be used, this allows searches to include\\n * characters that would normally be considered modifiers, e.g. `foo\\\\~2` will search for a term \\\"foo~2\\\" instead\\n * of attempting to apply a boost of 2 to the search term \\\"foo\\\".\\n *\\n * @typedef {string} lunr.Index~QueryString\\n * @example <caption>Simple single term query</caption>\\n * hello\\n * @example <caption>Multiple term query</caption>\\n * hello world\\n * @example <caption>term scoped to a field</caption>\\n * title:hello\\n * @example <caption>term with a boost of 10</caption>\\n * hello^10\\n * @example <caption>term with an edit distance of 2</caption>\\n * hello~2\\n * @example <caption>terms with presence modifiers</caption>\\n * -foo +bar baz\\n */\\n\\n/**\\n * Performs a search against the index using lunr query syntax.\\n *\\n * Results will be returned sorted by their score, the most relevant results\\n * will be returned first.  For details on how the score is calculated, please see\\n * the {@link https://lunrjs.com/guides/searching.html#scoring|guide}.\\n *\\n * For more programmatic querying use lunr.Index#query.\\n *\\n * @param {lunr.Index~QueryString} queryString - A string containing a lunr query.\\n * @throws {lunr.QueryParseError} If the passed query string cannot be parsed.\\n * @returns {lunr.Index~Result[]}\\n */\\nlunr.Index.prototype.search = function (queryString) {\\n  return this.query(function (query) {\\n    var parser = new lunr.QueryParser(queryString, query)\\n    parser.parse()\\n  })\\n}\\n\\n/**\\n * A query builder callback provides a query object to be used to express\\n * the query to perform on the index.\\n *\\n * @callback lunr.Index~queryBuilder\\n * @param {lunr.Query} query - The query object to build up.\\n * @this lunr.Query\\n */\\n\\n/**\\n * Performs a query against the index using the yielded lunr.Query object.\\n *\\n * If performing programmatic queries against the index, this method is preferred\\n * over lunr.Index#search so as to avoid the additional query parsing overhead.\\n *\\n * A query object is yielded to the supplied function which should be used to\\n * express the query to be run against the index.\\n *\\n * Note that although this function takes a callback parameter it is _not_ an\\n * asynchronous operation, the callback is just yielded a query object to be\\n * customized.\\n *\\n * @param {lunr.Index~queryBuilder} fn - A function that is used to build the query.\\n * @returns {lunr.Index~Result[]}\\n */\\nlunr.Index.prototype.query = function (fn) {\\n  // for each query clause\\n  // * process terms\\n  // * expand terms from token set\\n  // * find matching documents and metadata\\n  // * get document vectors\\n  // * score documents\\n\\n  var query = new lunr.Query(this.fields),\\n      matchingFields = Object.create(null),\\n      queryVectors = Object.create(null),\\n      termFieldCache = Object.create(null),\\n      requiredMatches = Object.create(null),\\n      prohibitedMatches = Object.create(null)\\n\\n  /*\\n   * To support field level boosts a query vector is created per\\n   * field. An empty vector is eagerly created to support negated\\n   * queries.\\n   */\\n  for (var i = 0; i < this.fields.length; i++) {\\n    queryVectors[this.fields[i]] = new lunr.Vector\\n  }\\n\\n  fn.call(query, query)\\n\\n  for (var i = 0; i < query.clauses.length; i++) {\\n    /*\\n     * Unless the pipeline has been disabled for this term, which is\\n     * the case for terms with wildcards, we need to pass the clause\\n     * term through the search pipeline. A pipeline returns an array\\n     * of processed terms. Pipeline functions may expand the passed\\n     * term, which means we may end up performing multiple index lookups\\n     * for a single query term.\\n     */\\n    var clause = query.clauses[i],\\n        terms = null,\\n        clauseMatches = lunr.Set.empty\\n\\n    if (clause.usePipeline) {\\n      terms = this.pipeline.runString(clause.term, {\\n        fields: clause.fields\\n      })\\n    } else {\\n      terms = [clause.term]\\n    }\\n\\n    for (var m = 0; m < terms.length; m++) {\\n      var term = terms[m]\\n\\n      /*\\n       * Each term returned from the pipeline needs to use the same query\\n       * clause object, e.g. the same boost and or edit distance. The\\n       * simplest way to do this is to re-use the clause object but mutate\\n       * its term property.\\n       */\\n      clause.term = term\\n\\n      /*\\n       * From the term in the clause we create a token set which will then\\n       * be used to intersect the indexes token set to get a list of terms\\n       * to lookup in the inverted index\\n       */\\n      var termTokenSet = lunr.TokenSet.fromClause(clause),\\n          expandedTerms = this.tokenSet.intersect(termTokenSet).toArray()\\n\\n      /*\\n       * If a term marked as required does not exist in the tokenSet it is\\n       * impossible for the search to return any matches. We set all the field\\n       * scoped required matches set to empty and stop examining any further\\n       * clauses.\\n       */\\n      if (expandedTerms.length === 0 && clause.presence === lunr.Query.presence.REQUIRED) {\\n        for (var k = 0; k < clause.fields.length; k++) {\\n          var field = clause.fields[k]\\n          requiredMatches[field] = lunr.Set.empty\\n        }\\n\\n        break\\n      }\\n\\n      for (var j = 0; j < expandedTerms.length; j++) {\\n        /*\\n         * For each term get the posting and termIndex, this is required for\\n         * building the query vector.\\n         */\\n        var expandedTerm = expandedTerms[j],\\n            posting = this.invertedIndex[expandedTerm],\\n            termIndex = posting._index\\n\\n        for (var k = 0; k < clause.fields.length; k++) {\\n          /*\\n           * For each field that this query term is scoped by (by default\\n           * all fields are in scope) we need to get all the document refs\\n           * that have this term in that field.\\n           *\\n           * The posting is the entry in the invertedIndex for the matching\\n           * term from above.\\n           */\\n          var field = clause.fields[k],\\n              fieldPosting = posting[field],\\n              matchingDocumentRefs = Object.keys(fieldPosting),\\n              termField = expandedTerm + \\\"/\\\" + field,\\n              matchingDocumentsSet = new lunr.Set(matchingDocumentRefs)\\n\\n          /*\\n           * if the presence of this term is required ensure that the matching\\n           * documents are added to the set of required matches for this clause.\\n           *\\n           */\\n          if (clause.presence == lunr.Query.presence.REQUIRED) {\\n            clauseMatches = clauseMatches.union(matchingDocumentsSet)\\n\\n            if (requiredMatches[field] === undefined) {\\n              requiredMatches[field] = lunr.Set.complete\\n            }\\n          }\\n\\n          /*\\n           * if the presence of this term is prohibited ensure that the matching\\n           * documents are added to the set of prohibited matches for this field,\\n           * creating that set if it does not yet exist.\\n           */\\n          if (clause.presence == lunr.Query.presence.PROHIBITED) {\\n            if (prohibitedMatches[field] === undefined) {\\n              prohibitedMatches[field] = lunr.Set.empty\\n            }\\n\\n            prohibitedMatches[field] = prohibitedMatches[field].union(matchingDocumentsSet)\\n\\n            /*\\n             * Prohibited matches should not be part of the query vector used for\\n             * similarity scoring and no metadata should be extracted so we continue\\n             * to the next field\\n             */\\n            continue\\n          }\\n\\n          /*\\n           * The query field vector is populated using the termIndex found for\\n           * the term and a unit value with the appropriate boost applied.\\n           * Using upsert because there could already be an entry in the vector\\n           * for the term we are working with. In that case we just add the scores\\n           * together.\\n           */\\n          queryVectors[field].upsert(termIndex, clause.boost, function (a, b) { return a + b })\\n\\n          /**\\n           * If we've already seen this term, field combo then we've already collected\\n           * the matching documents and metadata, no need to go through all that again\\n           */\\n          if (termFieldCache[termField]) {\\n            continue\\n          }\\n\\n          for (var l = 0; l < matchingDocumentRefs.length; l++) {\\n            /*\\n             * All metadata for this term/field/document triple\\n             * are then extracted and collected into an instance\\n             * of lunr.MatchData ready to be returned in the query\\n             * results\\n             */\\n            var matchingDocumentRef = matchingDocumentRefs[l],\\n                matchingFieldRef = new lunr.FieldRef (matchingDocumentRef, field),\\n                metadata = fieldPosting[matchingDocumentRef],\\n                fieldMatch\\n\\n            if ((fieldMatch = matchingFields[matchingFieldRef]) === undefined) {\\n              matchingFields[matchingFieldRef] = new lunr.MatchData (expandedTerm, field, metadata)\\n            } else {\\n              fieldMatch.add(expandedTerm, field, metadata)\\n            }\\n\\n          }\\n\\n          termFieldCache[termField] = true\\n        }\\n      }\\n    }\\n\\n    /**\\n     * If the presence was required we need to update the requiredMatches field sets.\\n     * We do this after all fields for the term have collected their matches because\\n     * the clause terms presence is required in _any_ of the fields not _all_ of the\\n     * fields.\\n     */\\n    if (clause.presence === lunr.Query.presence.REQUIRED) {\\n      for (var k = 0; k < clause.fields.length; k++) {\\n        var field = clause.fields[k]\\n        requiredMatches[field] = requiredMatches[field].intersect(clauseMatches)\\n      }\\n    }\\n  }\\n\\n  /**\\n   * Need to combine the field scoped required and prohibited\\n   * matching documents into a global set of required and prohibited\\n   * matches\\n   */\\n  var allRequiredMatches = lunr.Set.complete,\\n      allProhibitedMatches = lunr.Set.empty\\n\\n  for (var i = 0; i < this.fields.length; i++) {\\n    var field = this.fields[i]\\n\\n    if (requiredMatches[field]) {\\n      allRequiredMatches = allRequiredMatches.intersect(requiredMatches[field])\\n    }\\n\\n    if (prohibitedMatches[field]) {\\n      allProhibitedMatches = allProhibitedMatches.union(prohibitedMatches[field])\\n    }\\n  }\\n\\n  var matchingFieldRefs = Object.keys(matchingFields),\\n      results = [],\\n      matches = Object.create(null)\\n\\n  /*\\n   * If the query is negated (contains only prohibited terms)\\n   * we need to get _all_ fieldRefs currently existing in the\\n   * index. This is only done when we know that the query is\\n   * entirely prohibited terms to avoid any cost of getting all\\n   * fieldRefs unnecessarily.\\n   *\\n   * Additionally, blank MatchData must be created to correctly\\n   * populate the results.\\n   */\\n  if (query.isNegated()) {\\n    matchingFieldRefs = Object.keys(this.fieldVectors)\\n\\n    for (var i = 0; i < matchingFieldRefs.length; i++) {\\n      var matchingFieldRef = matchingFieldRefs[i]\\n      var fieldRef = lunr.FieldRef.fromString(matchingFieldRef)\\n      matchingFields[matchingFieldRef] = new lunr.MatchData\\n    }\\n  }\\n\\n  for (var i = 0; i < matchingFieldRefs.length; i++) {\\n    /*\\n     * Currently we have document fields that match the query, but we\\n     * need to return documents. The matchData and scores are combined\\n     * from multiple fields belonging to the same document.\\n     *\\n     * Scores are calculated by field, using the query vectors created\\n     * above, and combined into a final document score using addition.\\n     */\\n    var fieldRef = lunr.FieldRef.fromString(matchingFieldRefs[i]),\\n        docRef = fieldRef.docRef\\n\\n    if (!allRequiredMatches.contains(docRef)) {\\n      continue\\n    }\\n\\n    if (allProhibitedMatches.contains(docRef)) {\\n      continue\\n    }\\n\\n    var fieldVector = this.fieldVectors[fieldRef],\\n        score = queryVectors[fieldRef.fieldName].similarity(fieldVector),\\n        docMatch\\n\\n    if ((docMatch = matches[docRef]) !== undefined) {\\n      docMatch.score += score\\n      docMatch.matchData.combine(matchingFields[fieldRef])\\n    } else {\\n      var match = {\\n        ref: docRef,\\n        score: score,\\n        matchData: matchingFields[fieldRef]\\n      }\\n      matches[docRef] = match\\n      results.push(match)\\n    }\\n  }\\n\\n  /*\\n   * Sort the results objects by score, highest first.\\n   */\\n  return results.sort(function (a, b) {\\n    return b.score - a.score\\n  })\\n}\\n\\n/**\\n * Prepares the index for JSON serialization.\\n *\\n * The schema for this JSON blob will be described in a\\n * separate JSON schema file.\\n *\\n * @returns {Object}\\n */\\nlunr.Index.prototype.toJSON = function () {\\n  var invertedIndex = Object.keys(this.invertedIndex)\\n    .sort()\\n    .map(function (term) {\\n      return [term, this.invertedIndex[term]]\\n    }, this)\\n\\n  var fieldVectors = Object.keys(this.fieldVectors)\\n    .map(function (ref) {\\n      return [ref, this.fieldVectors[ref].toJSON()]\\n    }, this)\\n\\n  return {\\n    version: lunr.version,\\n    fields: this.fields,\\n    fieldVectors: fieldVectors,\\n    invertedIndex: invertedIndex,\\n    pipeline: this.pipeline.toJSON()\\n  }\\n}\\n\\n/**\\n * Loads a previously serialized lunr.Index\\n *\\n * @param {Object} serializedIndex - A previously serialized lunr.Index\\n * @returns {lunr.Index}\\n */\\nlunr.Index.load = function (serializedIndex) {\\n  var attrs = {},\\n      fieldVectors = {},\\n      serializedVectors = serializedIndex.fieldVectors,\\n      invertedIndex = Object.create(null),\\n      serializedInvertedIndex = serializedIndex.invertedIndex,\\n      tokenSetBuilder = new lunr.TokenSet.Builder,\\n      pipeline = lunr.Pipeline.load(serializedIndex.pipeline)\\n\\n  if (serializedIndex.version != lunr.version) {\\n    lunr.utils.warn(\\\"Version mismatch when loading serialised index. Current version of lunr '\\\" + lunr.version + \\\"' does not match serialized index '\\\" + serializedIndex.version + \\\"'\\\")\\n  }\\n\\n  for (var i = 0; i < serializedVectors.length; i++) {\\n    var tuple = serializedVectors[i],\\n        ref = tuple[0],\\n        elements = tuple[1]\\n\\n    fieldVectors[ref] = new lunr.Vector(elements)\\n  }\\n\\n  for (var i = 0; i < serializedInvertedIndex.length; i++) {\\n    var tuple = serializedInvertedIndex[i],\\n        term = tuple[0],\\n        posting = tuple[1]\\n\\n    tokenSetBuilder.insert(term)\\n    invertedIndex[term] = posting\\n  }\\n\\n  tokenSetBuilder.finish()\\n\\n  attrs.fields = serializedIndex.fields\\n\\n  attrs.fieldVectors = fieldVectors\\n  attrs.invertedIndex = invertedIndex\\n  attrs.tokenSet = tokenSetBuilder.root\\n  attrs.pipeline = pipeline\\n\\n  return new lunr.Index(attrs)\\n}\\n/*!\\n * lunr.Builder\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.Builder performs indexing on a set of documents and\\n * returns instances of lunr.Index ready for querying.\\n *\\n * All configuration of the index is done via the builder, the\\n * fields to index, the document reference, the text processing\\n * pipeline and document scoring parameters are all set on the\\n * builder before indexing.\\n *\\n * @constructor\\n * @property {string} _ref - Internal reference to the document reference field.\\n * @property {string[]} _fields - Internal reference to the document fields to index.\\n * @property {object} invertedIndex - The inverted index maps terms to document fields.\\n * @property {object} documentTermFrequencies - Keeps track of document term frequencies.\\n * @property {object} documentLengths - Keeps track of the length of documents added to the index.\\n * @property {lunr.tokenizer} tokenizer - Function for splitting strings into tokens for indexing.\\n * @property {lunr.Pipeline} pipeline - The pipeline performs text processing on tokens before indexing.\\n * @property {lunr.Pipeline} searchPipeline - A pipeline for processing search terms before querying the index.\\n * @property {number} documentCount - Keeps track of the total number of documents indexed.\\n * @property {number} _b - A parameter to control field length normalization, setting this to 0 disabled normalization, 1 fully normalizes field lengths, the default value is 0.75.\\n * @property {number} _k1 - A parameter to control how quickly an increase in term frequency results in term frequency saturation, the default value is 1.2.\\n * @property {number} termIndex - A counter incremented for each unique term, used to identify a terms position in the vector space.\\n * @property {array} metadataWhitelist - A list of metadata keys that have been whitelisted for entry in the index.\\n */\\nlunr.Builder = function () {\\n  this._ref = \\\"id\\\"\\n  this._fields = Object.create(null)\\n  this._documents = Object.create(null)\\n  this.invertedIndex = Object.create(null)\\n  this.fieldTermFrequencies = {}\\n  this.fieldLengths = {}\\n  this.tokenizer = lunr.tokenizer\\n  this.pipeline = new lunr.Pipeline\\n  this.searchPipeline = new lunr.Pipeline\\n  this.documentCount = 0\\n  this._b = 0.75\\n  this._k1 = 1.2\\n  this.termIndex = 0\\n  this.metadataWhitelist = []\\n}\\n\\n/**\\n * Sets the document field used as the document reference. Every document must have this field.\\n * The type of this field in the document should be a string, if it is not a string it will be\\n * coerced into a string by calling toString.\\n *\\n * The default ref is 'id'.\\n *\\n * The ref should _not_ be changed during indexing, it should be set before any documents are\\n * added to the index. Changing it during indexing can lead to inconsistent results.\\n *\\n * @param {string} ref - The name of the reference field in the document.\\n */\\nlunr.Builder.prototype.ref = function (ref) {\\n  this._ref = ref\\n}\\n\\n/**\\n * A function that is used to extract a field from a document.\\n *\\n * Lunr expects a field to be at the top level of a document, if however the field\\n * is deeply nested within a document an extractor function can be used to extract\\n * the right field for indexing.\\n *\\n * @callback fieldExtractor\\n * @param {object} doc - The document being added to the index.\\n * @returns {?(string|object|object[])} obj - The object that will be indexed for this field.\\n * @example <caption>Extracting a nested field</caption>\\n * function (doc) { return doc.nested.field }\\n */\\n\\n/**\\n * Adds a field to the list of document fields that will be indexed. Every document being\\n * indexed should have this field. Null values for this field in indexed documents will\\n * not cause errors but will limit the chance of that document being retrieved by searches.\\n *\\n * All fields should be added before adding documents to the index. Adding fields after\\n * a document has been indexed will have no effect on already indexed documents.\\n *\\n * Fields can be boosted at build time. This allows terms within that field to have more\\n * importance when ranking search results. Use a field boost to specify that matches within\\n * one field are more important than other fields.\\n *\\n * @param {string} fieldName - The name of a field to index in all documents.\\n * @param {object} attributes - Optional attributes associated with this field.\\n * @param {number} [attributes.boost=1] - Boost applied to all terms within this field.\\n * @param {fieldExtractor} [attributes.extractor] - Function to extract a field from a document.\\n * @throws {RangeError} fieldName cannot contain unsupported characters '/'\\n */\\nlunr.Builder.prototype.field = function (fieldName, attributes) {\\n  if (/\\\\//.test(fieldName)) {\\n    throw new RangeError (\\\"Field '\\\" + fieldName + \\\"' contains illegal character '/'\\\")\\n  }\\n\\n  this._fields[fieldName] = attributes || {}\\n}\\n\\n/**\\n * A parameter to tune the amount of field length normalisation that is applied when\\n * calculating relevance scores. A value of 0 will completely disable any normalisation\\n * and a value of 1 will fully normalise field lengths. The default is 0.75. Values of b\\n * will be clamped to the range 0 - 1.\\n *\\n * @param {number} number - The value to set for this tuning parameter.\\n */\\nlunr.Builder.prototype.b = function (number) {\\n  if (number < 0) {\\n    this._b = 0\\n  } else if (number > 1) {\\n    this._b = 1\\n  } else {\\n    this._b = number\\n  }\\n}\\n\\n/**\\n * A parameter that controls the speed at which a rise in term frequency results in term\\n * frequency saturation. The default value is 1.2. Setting this to a higher value will give\\n * slower saturation levels, a lower value will result in quicker saturation.\\n *\\n * @param {number} number - The value to set for this tuning parameter.\\n */\\nlunr.Builder.prototype.k1 = function (number) {\\n  this._k1 = number\\n}\\n\\n/**\\n * Adds a document to the index.\\n *\\n * Before adding fields to the index the index should have been fully setup, with the document\\n * ref and all fields to index already having been specified.\\n *\\n * The document must have a field name as specified by the ref (by default this is 'id') and\\n * it should have all fields defined for indexing, though null or undefined values will not\\n * cause errors.\\n *\\n * Entire documents can be boosted at build time. Applying a boost to a document indicates that\\n * this document should rank higher in search results than other documents.\\n *\\n * @param {object} doc - The document to add to the index.\\n * @param {object} attributes - Optional attributes associated with this document.\\n * @param {number} [attributes.boost=1] - Boost applied to all terms within this document.\\n */\\nlunr.Builder.prototype.add = function (doc, attributes) {\\n  var docRef = doc[this._ref],\\n      fields = Object.keys(this._fields)\\n\\n  this._documents[docRef] = attributes || {}\\n  this.documentCount += 1\\n\\n  for (var i = 0; i < fields.length; i++) {\\n    var fieldName = fields[i],\\n        extractor = this._fields[fieldName].extractor,\\n        field = extractor ? extractor(doc) : doc[fieldName],\\n        tokens = this.tokenizer(field, {\\n          fields: [fieldName]\\n        }),\\n        terms = this.pipeline.run(tokens),\\n        fieldRef = new lunr.FieldRef (docRef, fieldName),\\n        fieldTerms = Object.create(null)\\n\\n    this.fieldTermFrequencies[fieldRef] = fieldTerms\\n    this.fieldLengths[fieldRef] = 0\\n\\n    // store the length of this field for this document\\n    this.fieldLengths[fieldRef] += terms.length\\n\\n    // calculate term frequencies for this field\\n    for (var j = 0; j < terms.length; j++) {\\n      var term = terms[j]\\n\\n      if (fieldTerms[term] == undefined) {\\n        fieldTerms[term] = 0\\n      }\\n\\n      fieldTerms[term] += 1\\n\\n      // add to inverted index\\n      // create an initial posting if one doesn't exist\\n      if (this.invertedIndex[term] == undefined) {\\n        var posting = Object.create(null)\\n        posting[\\\"_index\\\"] = this.termIndex\\n        this.termIndex += 1\\n\\n        for (var k = 0; k < fields.length; k++) {\\n          posting[fields[k]] = Object.create(null)\\n        }\\n\\n        this.invertedIndex[term] = posting\\n      }\\n\\n      // add an entry for this term/fieldName/docRef to the invertedIndex\\n      if (this.invertedIndex[term][fieldName][docRef] == undefined) {\\n        this.invertedIndex[term][fieldName][docRef] = Object.create(null)\\n      }\\n\\n      // store all whitelisted metadata about this token in the\\n      // inverted index\\n      for (var l = 0; l < this.metadataWhitelist.length; l++) {\\n        var metadataKey = this.metadataWhitelist[l],\\n            metadata = term.metadata[metadataKey]\\n\\n        if (this.invertedIndex[term][fieldName][docRef][metadataKey] == undefined) {\\n          this.invertedIndex[term][fieldName][docRef][metadataKey] = []\\n        }\\n\\n        this.invertedIndex[term][fieldName][docRef][metadataKey].push(metadata)\\n      }\\n    }\\n\\n  }\\n}\\n\\n/**\\n * Calculates the average document length for this index\\n *\\n * @private\\n */\\nlunr.Builder.prototype.calculateAverageFieldLengths = function () {\\n\\n  var fieldRefs = Object.keys(this.fieldLengths),\\n      numberOfFields = fieldRefs.length,\\n      accumulator = {},\\n      documentsWithField = {}\\n\\n  for (var i = 0; i < numberOfFields; i++) {\\n    var fieldRef = lunr.FieldRef.fromString(fieldRefs[i]),\\n        field = fieldRef.fieldName\\n\\n    documentsWithField[field] || (documentsWithField[field] = 0)\\n    documentsWithField[field] += 1\\n\\n    accumulator[field] || (accumulator[field] = 0)\\n    accumulator[field] += this.fieldLengths[fieldRef]\\n  }\\n\\n  var fields = Object.keys(this._fields)\\n\\n  for (var i = 0; i < fields.length; i++) {\\n    var fieldName = fields[i]\\n    accumulator[fieldName] = accumulator[fieldName] / documentsWithField[fieldName]\\n  }\\n\\n  this.averageFieldLength = accumulator\\n}\\n\\n/**\\n * Builds a vector space model of every document using lunr.Vector\\n *\\n * @private\\n */\\nlunr.Builder.prototype.createFieldVectors = function () {\\n  var fieldVectors = {},\\n      fieldRefs = Object.keys(this.fieldTermFrequencies),\\n      fieldRefsLength = fieldRefs.length,\\n      termIdfCache = Object.create(null)\\n\\n  for (var i = 0; i < fieldRefsLength; i++) {\\n    var fieldRef = lunr.FieldRef.fromString(fieldRefs[i]),\\n        fieldName = fieldRef.fieldName,\\n        fieldLength = this.fieldLengths[fieldRef],\\n        fieldVector = new lunr.Vector,\\n        termFrequencies = this.fieldTermFrequencies[fieldRef],\\n        terms = Object.keys(termFrequencies),\\n        termsLength = terms.length\\n\\n\\n    var fieldBoost = this._fields[fieldName].boost || 1,\\n        docBoost = this._documents[fieldRef.docRef].boost || 1\\n\\n    for (var j = 0; j < termsLength; j++) {\\n      var term = terms[j],\\n          tf = termFrequencies[term],\\n          termIndex = this.invertedIndex[term]._index,\\n          idf, score, scoreWithPrecision\\n\\n      if (termIdfCache[term] === undefined) {\\n        idf = lunr.idf(this.invertedIndex[term], this.documentCount)\\n        termIdfCache[term] = idf\\n      } else {\\n        idf = termIdfCache[term]\\n      }\\n\\n      score = idf * ((this._k1 + 1) * tf) / (this._k1 * (1 - this._b + this._b * (fieldLength / this.averageFieldLength[fieldName])) + tf)\\n      score *= fieldBoost\\n      score *= docBoost\\n      scoreWithPrecision = Math.round(score * 1000) / 1000\\n      // Converts 1.23456789 to 1.234.\\n      // Reducing the precision so that the vectors take up less\\n      // space when serialised. Doing it now so that they behave\\n      // the same before and after serialisation. Also, this is\\n      // the fastest approach to reducing a number's precision in\\n      // JavaScript.\\n\\n      fieldVector.insert(termIndex, scoreWithPrecision)\\n    }\\n\\n    fieldVectors[fieldRef] = fieldVector\\n  }\\n\\n  this.fieldVectors = fieldVectors\\n}\\n\\n/**\\n * Creates a token set of all tokens in the index using lunr.TokenSet\\n *\\n * @private\\n */\\nlunr.Builder.prototype.createTokenSet = function () {\\n  this.tokenSet = lunr.TokenSet.fromArray(\\n    Object.keys(this.invertedIndex).sort()\\n  )\\n}\\n\\n/**\\n * Builds the index, creating an instance of lunr.Index.\\n *\\n * This completes the indexing process and should only be called\\n * once all documents have been added to the index.\\n *\\n * @returns {lunr.Index}\\n */\\nlunr.Builder.prototype.build = function () {\\n  this.calculateAverageFieldLengths()\\n  this.createFieldVectors()\\n  this.createTokenSet()\\n\\n  return new lunr.Index({\\n    invertedIndex: this.invertedIndex,\\n    fieldVectors: this.fieldVectors,\\n    tokenSet: this.tokenSet,\\n    fields: Object.keys(this._fields),\\n    pipeline: this.searchPipeline\\n  })\\n}\\n\\n/**\\n * Applies a plugin to the index builder.\\n *\\n * A plugin is a function that is called with the index builder as its context.\\n * Plugins can be used to customise or extend the behaviour of the index\\n * in some way. A plugin is just a function, that encapsulated the custom\\n * behaviour that should be applied when building the index.\\n *\\n * The plugin function will be called with the index builder as its argument, additional\\n * arguments can also be passed when calling use. The function will be called\\n * with the index builder as its context.\\n *\\n * @param {Function} plugin The plugin to apply.\\n */\\nlunr.Builder.prototype.use = function (fn) {\\n  var args = Array.prototype.slice.call(arguments, 1)\\n  args.unshift(this)\\n  fn.apply(this, args)\\n}\\n/**\\n * Contains and collects metadata about a matching document.\\n * A single instance of lunr.MatchData is returned as part of every\\n * lunr.Index~Result.\\n *\\n * @constructor\\n * @param {string} term - The term this match data is associated with\\n * @param {string} field - The field in which the term was found\\n * @param {object} metadata - The metadata recorded about this term in this field\\n * @property {object} metadata - A cloned collection of metadata associated with this document.\\n * @see {@link lunr.Index~Result}\\n */\\nlunr.MatchData = function (term, field, metadata) {\\n  var clonedMetadata = Object.create(null),\\n      metadataKeys = Object.keys(metadata || {})\\n\\n  // Cloning the metadata to prevent the original\\n  // being mutated during match data combination.\\n  // Metadata is kept in an array within the inverted\\n  // index so cloning the data can be done with\\n  // Array#slice\\n  for (var i = 0; i < metadataKeys.length; i++) {\\n    var key = metadataKeys[i]\\n    clonedMetadata[key] = metadata[key].slice()\\n  }\\n\\n  this.metadata = Object.create(null)\\n\\n  if (term !== undefined) {\\n    this.metadata[term] = Object.create(null)\\n    this.metadata[term][field] = clonedMetadata\\n  }\\n}\\n\\n/**\\n * An instance of lunr.MatchData will be created for every term that matches a\\n * document. However only one instance is required in a lunr.Index~Result. This\\n * method combines metadata from another instance of lunr.MatchData with this\\n * objects metadata.\\n *\\n * @param {lunr.MatchData} otherMatchData - Another instance of match data to merge with this one.\\n * @see {@link lunr.Index~Result}\\n */\\nlunr.MatchData.prototype.combine = function (otherMatchData) {\\n  var terms = Object.keys(otherMatchData.metadata)\\n\\n  for (var i = 0; i < terms.length; i++) {\\n    var term = terms[i],\\n        fields = Object.keys(otherMatchData.metadata[term])\\n\\n    if (this.metadata[term] == undefined) {\\n      this.metadata[term] = Object.create(null)\\n    }\\n\\n    for (var j = 0; j < fields.length; j++) {\\n      var field = fields[j],\\n          keys = Object.keys(otherMatchData.metadata[term][field])\\n\\n      if (this.metadata[term][field] == undefined) {\\n        this.metadata[term][field] = Object.create(null)\\n      }\\n\\n      for (var k = 0; k < keys.length; k++) {\\n        var key = keys[k]\\n\\n        if (this.metadata[term][field][key] == undefined) {\\n          this.metadata[term][field][key] = otherMatchData.metadata[term][field][key]\\n        } else {\\n          this.metadata[term][field][key] = this.metadata[term][field][key].concat(otherMatchData.metadata[term][field][key])\\n        }\\n\\n      }\\n    }\\n  }\\n}\\n\\n/**\\n * Add metadata for a term/field pair to this instance of match data.\\n *\\n * @param {string} term - The term this match data is associated with\\n * @param {string} field - The field in which the term was found\\n * @param {object} metadata - The metadata recorded about this term in this field\\n */\\nlunr.MatchData.prototype.add = function (term, field, metadata) {\\n  if (!(term in this.metadata)) {\\n    this.metadata[term] = Object.create(null)\\n    this.metadata[term][field] = metadata\\n    return\\n  }\\n\\n  if (!(field in this.metadata[term])) {\\n    this.metadata[term][field] = metadata\\n    return\\n  }\\n\\n  var metadataKeys = Object.keys(metadata)\\n\\n  for (var i = 0; i < metadataKeys.length; i++) {\\n    var key = metadataKeys[i]\\n\\n    if (key in this.metadata[term][field]) {\\n      this.metadata[term][field][key] = this.metadata[term][field][key].concat(metadata[key])\\n    } else {\\n      this.metadata[term][field][key] = metadata[key]\\n    }\\n  }\\n}\\n/**\\n * A lunr.Query provides a programmatic way of defining queries to be performed\\n * against a {@link lunr.Index}.\\n *\\n * Prefer constructing a lunr.Query using the {@link lunr.Index#query} method\\n * so the query object is pre-initialized with the right index fields.\\n *\\n * @constructor\\n * @property {lunr.Query~Clause[]} clauses - An array of query clauses.\\n * @property {string[]} allFields - An array of all available fields in a lunr.Index.\\n */\\nlunr.Query = function (allFields) {\\n  this.clauses = []\\n  this.allFields = allFields\\n}\\n\\n/**\\n * Constants for indicating what kind of automatic wildcard insertion will be used when constructing a query clause.\\n *\\n * This allows wildcards to be added to the beginning and end of a term without having to manually do any string\\n * concatenation.\\n *\\n * The wildcard constants can be bitwise combined to select both leading and trailing wildcards.\\n *\\n * @constant\\n * @default\\n * @property {number} wildcard.NONE - The term will have no wildcards inserted, this is the default behaviour\\n * @property {number} wildcard.LEADING - Prepend the term with a wildcard, unless a leading wildcard already exists\\n * @property {number} wildcard.TRAILING - Append a wildcard to the term, unless a trailing wildcard already exists\\n * @see lunr.Query~Clause\\n * @see lunr.Query#clause\\n * @see lunr.Query#term\\n * @example <caption>query term with trailing wildcard</caption>\\n * query.term('foo', { wildcard: lunr.Query.wildcard.TRAILING })\\n * @example <caption>query term with leading and trailing wildcard</caption>\\n * query.term('foo', {\\n *   wildcard: lunr.Query.wildcard.LEADING | lunr.Query.wildcard.TRAILING\\n * })\\n */\\n\\nlunr.Query.wildcard = new String (\\\"*\\\")\\nlunr.Query.wildcard.NONE = 0\\nlunr.Query.wildcard.LEADING = 1\\nlunr.Query.wildcard.TRAILING = 2\\n\\n/**\\n * Constants for indicating what kind of presence a term must have in matching documents.\\n *\\n * @constant\\n * @enum {number}\\n * @see lunr.Query~Clause\\n * @see lunr.Query#clause\\n * @see lunr.Query#term\\n * @example <caption>query term with required presence</caption>\\n * query.term('foo', { presence: lunr.Query.presence.REQUIRED })\\n */\\nlunr.Query.presence = {\\n  /**\\n   * Term's presence in a document is optional, this is the default value.\\n   */\\n  OPTIONAL: 1,\\n\\n  /**\\n   * Term's presence in a document is required, documents that do not contain\\n   * this term will not be returned.\\n   */\\n  REQUIRED: 2,\\n\\n  /**\\n   * Term's presence in a document is prohibited, documents that do contain\\n   * this term will not be returned.\\n   */\\n  PROHIBITED: 3\\n}\\n\\n/**\\n * A single clause in a {@link lunr.Query} contains a term and details on how to\\n * match that term against a {@link lunr.Index}.\\n *\\n * @typedef {Object} lunr.Query~Clause\\n * @property {string[]} fields - The fields in an index this clause should be matched against.\\n * @property {number} [boost=1] - Any boost that should be applied when matching this clause.\\n * @property {number} [editDistance] - Whether the term should have fuzzy matching applied, and how fuzzy the match should be.\\n * @property {boolean} [usePipeline] - Whether the term should be passed through the search pipeline.\\n * @property {number} [wildcard=lunr.Query.wildcard.NONE] - Whether the term should have wildcards appended or prepended.\\n * @property {number} [presence=lunr.Query.presence.OPTIONAL] - The terms presence in any matching documents.\\n */\\n\\n/**\\n * Adds a {@link lunr.Query~Clause} to this query.\\n *\\n * Unless the clause contains the fields to be matched all fields will be matched. In addition\\n * a default boost of 1 is applied to the clause.\\n *\\n * @param {lunr.Query~Clause} clause - The clause to add to this query.\\n * @see lunr.Query~Clause\\n * @returns {lunr.Query}\\n */\\nlunr.Query.prototype.clause = function (clause) {\\n  if (!('fields' in clause)) {\\n    clause.fields = this.allFields\\n  }\\n\\n  if (!('boost' in clause)) {\\n    clause.boost = 1\\n  }\\n\\n  if (!('usePipeline' in clause)) {\\n    clause.usePipeline = true\\n  }\\n\\n  if (!('wildcard' in clause)) {\\n    clause.wildcard = lunr.Query.wildcard.NONE\\n  }\\n\\n  if ((clause.wildcard & lunr.Query.wildcard.LEADING) && (clause.term.charAt(0) != lunr.Query.wildcard)) {\\n    clause.term = \\\"*\\\" + clause.term\\n  }\\n\\n  if ((clause.wildcard & lunr.Query.wildcard.TRAILING) && (clause.term.slice(-1) != lunr.Query.wildcard)) {\\n    clause.term = \\\"\\\" + clause.term + \\\"*\\\"\\n  }\\n\\n  if (!('presence' in clause)) {\\n    clause.presence = lunr.Query.presence.OPTIONAL\\n  }\\n\\n  this.clauses.push(clause)\\n\\n  return this\\n}\\n\\n/**\\n * A negated query is one in which every clause has a presence of\\n * prohibited. These queries require some special processing to return\\n * the expected results.\\n *\\n * @returns boolean\\n */\\nlunr.Query.prototype.isNegated = function () {\\n  for (var i = 0; i < this.clauses.length; i++) {\\n    if (this.clauses[i].presence != lunr.Query.presence.PROHIBITED) {\\n      return false\\n    }\\n  }\\n\\n  return true\\n}\\n\\n/**\\n * Adds a term to the current query, under the covers this will create a {@link lunr.Query~Clause}\\n * to the list of clauses that make up this query.\\n *\\n * The term is used as is, i.e. no tokenization will be performed by this method. Instead conversion\\n * to a token or token-like string should be done before calling this method.\\n *\\n * The term will be converted to a string by calling `toString`. Multiple terms can be passed as an\\n * array, each term in the array will share the same options.\\n *\\n * @param {object|object[]} term - The term(s) to add to the query.\\n * @param {object} [options] - Any additional properties to add to the query clause.\\n * @returns {lunr.Query}\\n * @see lunr.Query#clause\\n * @see lunr.Query~Clause\\n * @example <caption>adding a single term to a query</caption>\\n * query.term(\\\"foo\\\")\\n * @example <caption>adding a single term to a query and specifying search fields, term boost and automatic trailing wildcard</caption>\\n * query.term(\\\"foo\\\", {\\n *   fields: [\\\"title\\\"],\\n *   boost: 10,\\n *   wildcard: lunr.Query.wildcard.TRAILING\\n * })\\n * @example <caption>using lunr.tokenizer to convert a string to tokens before using them as terms</caption>\\n * query.term(lunr.tokenizer(\\\"foo bar\\\"))\\n */\\nlunr.Query.prototype.term = function (term, options) {\\n  if (Array.isArray(term)) {\\n    term.forEach(function (t) { this.term(t, lunr.utils.clone(options)) }, this)\\n    return this\\n  }\\n\\n  var clause = options || {}\\n  clause.term = term.toString()\\n\\n  this.clause(clause)\\n\\n  return this\\n}\\nlunr.QueryParseError = function (message, start, end) {\\n  this.name = \\\"QueryParseError\\\"\\n  this.message = message\\n  this.start = start\\n  this.end = end\\n}\\n\\nlunr.QueryParseError.prototype = new Error\\nlunr.QueryLexer = function (str) {\\n  this.lexemes = []\\n  this.str = str\\n  this.length = str.length\\n  this.pos = 0\\n  this.start = 0\\n  this.escapeCharPositions = []\\n}\\n\\nlunr.QueryLexer.prototype.run = function () {\\n  var state = lunr.QueryLexer.lexText\\n\\n  while (state) {\\n    state = state(this)\\n  }\\n}\\n\\nlunr.QueryLexer.prototype.sliceString = function () {\\n  var subSlices = [],\\n      sliceStart = this.start,\\n      sliceEnd = this.pos\\n\\n  for (var i = 0; i < this.escapeCharPositions.length; i++) {\\n    sliceEnd = this.escapeCharPositions[i]\\n    subSlices.push(this.str.slice(sliceStart, sliceEnd))\\n    sliceStart = sliceEnd + 1\\n  }\\n\\n  subSlices.push(this.str.slice(sliceStart, this.pos))\\n  this.escapeCharPositions.length = 0\\n\\n  return subSlices.join('')\\n}\\n\\nlunr.QueryLexer.prototype.emit = function (type) {\\n  this.lexemes.push({\\n    type: type,\\n    str: this.sliceString(),\\n    start: this.start,\\n    end: this.pos\\n  })\\n\\n  this.start = this.pos\\n}\\n\\nlunr.QueryLexer.prototype.escapeCharacter = function () {\\n  this.escapeCharPositions.push(this.pos - 1)\\n  this.pos += 1\\n}\\n\\nlunr.QueryLexer.prototype.next = function () {\\n  if (this.pos >= this.length) {\\n    return lunr.QueryLexer.EOS\\n  }\\n\\n  var char = this.str.charAt(this.pos)\\n  this.pos += 1\\n  return char\\n}\\n\\nlunr.QueryLexer.prototype.width = function () {\\n  return this.pos - this.start\\n}\\n\\nlunr.QueryLexer.prototype.ignore = function () {\\n  if (this.start == this.pos) {\\n    this.pos += 1\\n  }\\n\\n  this.start = this.pos\\n}\\n\\nlunr.QueryLexer.prototype.backup = function () {\\n  this.pos -= 1\\n}\\n\\nlunr.QueryLexer.prototype.acceptDigitRun = function () {\\n  var char, charCode\\n\\n  do {\\n    char = this.next()\\n    charCode = char.charCodeAt(0)\\n  } while (charCode > 47 && charCode < 58)\\n\\n  if (char != lunr.QueryLexer.EOS) {\\n    this.backup()\\n  }\\n}\\n\\nlunr.QueryLexer.prototype.more = function () {\\n  return this.pos < this.length\\n}\\n\\nlunr.QueryLexer.EOS = 'EOS'\\nlunr.QueryLexer.FIELD = 'FIELD'\\nlunr.QueryLexer.TERM = 'TERM'\\nlunr.QueryLexer.EDIT_DISTANCE = 'EDIT_DISTANCE'\\nlunr.QueryLexer.BOOST = 'BOOST'\\nlunr.QueryLexer.PRESENCE = 'PRESENCE'\\n\\nlunr.QueryLexer.lexField = function (lexer) {\\n  lexer.backup()\\n  lexer.emit(lunr.QueryLexer.FIELD)\\n  lexer.ignore()\\n  return lunr.QueryLexer.lexText\\n}\\n\\nlunr.QueryLexer.lexTerm = function (lexer) {\\n  if (lexer.width() > 1) {\\n    lexer.backup()\\n    lexer.emit(lunr.QueryLexer.TERM)\\n  }\\n\\n  lexer.ignore()\\n\\n  if (lexer.more()) {\\n    return lunr.QueryLexer.lexText\\n  }\\n}\\n\\nlunr.QueryLexer.lexEditDistance = function (lexer) {\\n  lexer.ignore()\\n  lexer.acceptDigitRun()\\n  lexer.emit(lunr.QueryLexer.EDIT_DISTANCE)\\n  return lunr.QueryLexer.lexText\\n}\\n\\nlunr.QueryLexer.lexBoost = function (lexer) {\\n  lexer.ignore()\\n  lexer.acceptDigitRun()\\n  lexer.emit(lunr.QueryLexer.BOOST)\\n  return lunr.QueryLexer.lexText\\n}\\n\\nlunr.QueryLexer.lexEOS = function (lexer) {\\n  if (lexer.width() > 0) {\\n    lexer.emit(lunr.QueryLexer.TERM)\\n  }\\n}\\n\\n// This matches the separator used when tokenising fields\\n// within a document. These should match otherwise it is\\n// not possible to search for some tokens within a document.\\n//\\n// It is possible for the user to change the separator on the\\n// tokenizer so it _might_ clash with any other of the special\\n// characters already used within the search string, e.g. :.\\n//\\n// This means that it is possible to change the separator in\\n// such a way that makes some words unsearchable using a search\\n// string.\\nlunr.QueryLexer.termSeparator = lunr.tokenizer.separator\\n\\nlunr.QueryLexer.lexText = function (lexer) {\\n  while (true) {\\n    var char = lexer.next()\\n\\n    if (char == lunr.QueryLexer.EOS) {\\n      return lunr.QueryLexer.lexEOS\\n    }\\n\\n    // Escape character is '\\\\'\\n    if (char.charCodeAt(0) == 92) {\\n      lexer.escapeCharacter()\\n      continue\\n    }\\n\\n    if (char == \\\":\\\") {\\n      return lunr.QueryLexer.lexField\\n    }\\n\\n    if (char == \\\"~\\\") {\\n      lexer.backup()\\n      if (lexer.width() > 0) {\\n        lexer.emit(lunr.QueryLexer.TERM)\\n      }\\n      return lunr.QueryLexer.lexEditDistance\\n    }\\n\\n    if (char == \\\"^\\\") {\\n      lexer.backup()\\n      if (lexer.width() > 0) {\\n        lexer.emit(lunr.QueryLexer.TERM)\\n      }\\n      return lunr.QueryLexer.lexBoost\\n    }\\n\\n    // \\\"+\\\" indicates term presence is required\\n    // checking for length to ensure that only\\n    // leading \\\"+\\\" are considered\\n    if (char == \\\"+\\\" && lexer.width() === 1) {\\n      lexer.emit(lunr.QueryLexer.PRESENCE)\\n      return lunr.QueryLexer.lexText\\n    }\\n\\n    // \\\"-\\\" indicates term presence is prohibited\\n    // checking for length to ensure that only\\n    // leading \\\"-\\\" are considered\\n    if (char == \\\"-\\\" && lexer.width() === 1) {\\n      lexer.emit(lunr.QueryLexer.PRESENCE)\\n      return lunr.QueryLexer.lexText\\n    }\\n\\n    if (char.match(lunr.QueryLexer.termSeparator)) {\\n      return lunr.QueryLexer.lexTerm\\n    }\\n  }\\n}\\n\\nlunr.QueryParser = function (str, query) {\\n  this.lexer = new lunr.QueryLexer (str)\\n  this.query = query\\n  this.currentClause = {}\\n  this.lexemeIdx = 0\\n}\\n\\nlunr.QueryParser.prototype.parse = function () {\\n  this.lexer.run()\\n  this.lexemes = this.lexer.lexemes\\n\\n  var state = lunr.QueryParser.parseClause\\n\\n  while (state) {\\n    state = state(this)\\n  }\\n\\n  return this.query\\n}\\n\\nlunr.QueryParser.prototype.peekLexeme = function () {\\n  return this.lexemes[this.lexemeIdx]\\n}\\n\\nlunr.QueryParser.prototype.consumeLexeme = function () {\\n  var lexeme = this.peekLexeme()\\n  this.lexemeIdx += 1\\n  return lexeme\\n}\\n\\nlunr.QueryParser.prototype.nextClause = function () {\\n  var completedClause = this.currentClause\\n  this.query.clause(completedClause)\\n  this.currentClause = {}\\n}\\n\\nlunr.QueryParser.parseClause = function (parser) {\\n  var lexeme = parser.peekLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  switch (lexeme.type) {\\n    case lunr.QueryLexer.PRESENCE:\\n      return lunr.QueryParser.parsePresence\\n    case lunr.QueryLexer.FIELD:\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.TERM:\\n      return lunr.QueryParser.parseTerm\\n    default:\\n      var errorMessage = \\\"expected either a field or a term, found \\\" + lexeme.type\\n\\n      if (lexeme.str.length >= 1) {\\n        errorMessage += \\\" with value '\\\" + lexeme.str + \\\"'\\\"\\n      }\\n\\n      throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parsePresence = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  switch (lexeme.str) {\\n    case \\\"-\\\":\\n      parser.currentClause.presence = lunr.Query.presence.PROHIBITED\\n      break\\n    case \\\"+\\\":\\n      parser.currentClause.presence = lunr.Query.presence.REQUIRED\\n      break\\n    default:\\n      var errorMessage = \\\"unrecognised presence operator'\\\" + lexeme.str + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    var errorMessage = \\\"expecting term or field, found nothing\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.FIELD:\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.TERM:\\n      return lunr.QueryParser.parseTerm\\n    default:\\n      var errorMessage = \\\"expecting term or field, found '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseField = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  if (parser.query.allFields.indexOf(lexeme.str) == -1) {\\n    var possibleFields = parser.query.allFields.map(function (f) { return \\\"'\\\" + f + \\\"'\\\" }).join(', '),\\n        errorMessage = \\\"unrecognised field '\\\" + lexeme.str + \\\"', possible fields: \\\" + possibleFields\\n\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  parser.currentClause.fields = [lexeme.str]\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    var errorMessage = \\\"expecting term, found nothing\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      return lunr.QueryParser.parseTerm\\n    default:\\n      var errorMessage = \\\"expecting term, found '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseTerm = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  parser.currentClause.term = lexeme.str.toLowerCase()\\n\\n  if (lexeme.str.indexOf(\\\"*\\\") != -1) {\\n    parser.currentClause.usePipeline = false\\n  }\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    parser.nextClause()\\n    return\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseTerm\\n    case lunr.QueryLexer.FIELD:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.EDIT_DISTANCE:\\n      return lunr.QueryParser.parseEditDistance\\n    case lunr.QueryLexer.BOOST:\\n      return lunr.QueryParser.parseBoost\\n    case lunr.QueryLexer.PRESENCE:\\n      parser.nextClause()\\n      return lunr.QueryParser.parsePresence\\n    default:\\n      var errorMessage = \\\"Unexpected lexeme type '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseEditDistance = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  var editDistance = parseInt(lexeme.str, 10)\\n\\n  if (isNaN(editDistance)) {\\n    var errorMessage = \\\"edit distance must be numeric\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  parser.currentClause.editDistance = editDistance\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    parser.nextClause()\\n    return\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseTerm\\n    case lunr.QueryLexer.FIELD:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.EDIT_DISTANCE:\\n      return lunr.QueryParser.parseEditDistance\\n    case lunr.QueryLexer.BOOST:\\n      return lunr.QueryParser.parseBoost\\n    case lunr.QueryLexer.PRESENCE:\\n      parser.nextClause()\\n      return lunr.QueryParser.parsePresence\\n    default:\\n      var errorMessage = \\\"Unexpected lexeme type '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseBoost = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  var boost = parseInt(lexeme.str, 10)\\n\\n  if (isNaN(boost)) {\\n    var errorMessage = \\\"boost must be numeric\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  parser.currentClause.boost = boost\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    parser.nextClause()\\n    return\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseTerm\\n    case lunr.QueryLexer.FIELD:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.EDIT_DISTANCE:\\n      return lunr.QueryParser.parseEditDistance\\n    case lunr.QueryLexer.BOOST:\\n      return lunr.QueryParser.parseBoost\\n    case lunr.QueryLexer.PRESENCE:\\n      parser.nextClause()\\n      return lunr.QueryParser.parsePresence\\n    default:\\n      var errorMessage = \\\"Unexpected lexeme type '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\n  /**\\n   * export the module via AMD, CommonJS or as a browser global\\n   * Export code from https://github.com/umdjs/umd/blob/master/returnExports.js\\n   */\\n  ;(function (root, factory) {\\n    if (true) {\\n      // AMD. Register as an anonymous module.\\n      !(__WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\\n\\t\\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\\n\\t\\t(__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :\\n\\t\\t__WEBPACK_AMD_DEFINE_FACTORY__),\\n\\t\\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__))\\n    } else {}\\n  }(this, function () {\\n    /**\\n     * Just return a value to define the module export.\\n     * This example returns an object, but the module\\n     * can return a function as the exported value.\\n     */\\n    return lunr\\n  }))\\n})();\\n\\n\\n//# sourceURL=webpack:///../node_modules/lunr/lunr.js?\"\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/css/main.sass':\n            /*!**************************************!*\\\n  !*** ./default/assets/css/main.sass ***!\n  \\**************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n// extracted by mini-css-extract-plugin\\n\\n\\n//# sourceURL=webpack:///./default/assets/css/main.sass?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/bootstrap.ts':\n            /*!********************************************!*\\\n  !*** ./default/assets/js/src/bootstrap.ts ***!\n  \\********************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony import */ var _typedoc_Application__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typedoc/Application */ \"./default/assets/js/src/typedoc/Application.ts\");\\n/* harmony import */ var _typedoc_components_MenuHighlight__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./typedoc/components/MenuHighlight */ \"./default/assets/js/src/typedoc/components/MenuHighlight.ts\");\\n/* harmony import */ var _typedoc_components_Search__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./typedoc/components/Search */ \"./default/assets/js/src/typedoc/components/Search.ts\");\\n/* harmony import */ var _typedoc_components_Signature__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./typedoc/components/Signature */ \"./default/assets/js/src/typedoc/components/Signature.ts\");\\n/* harmony import */ var _typedoc_components_Toggle__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./typedoc/components/Toggle */ \"./default/assets/js/src/typedoc/components/Toggle.ts\");\\n/* harmony import */ var _typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./typedoc/components/Filter */ \"./default/assets/js/src/typedoc/components/Filter.ts\");\\n/* harmony import */ var _css_main_sass__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../css/main.sass */ \"./default/assets/css/main.sass\");\\n\\n\\n\\n\\n\\n\\n\\n(0,_typedoc_components_Search__WEBPACK_IMPORTED_MODULE_2__.initSearch)();\\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_MenuHighlight__WEBPACK_IMPORTED_MODULE_1__.MenuHighlight, \".menu-highlight\");\\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_Signature__WEBPACK_IMPORTED_MODULE_3__.Signature, \".tsd-signatures\");\\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_Toggle__WEBPACK_IMPORTED_MODULE_4__.Toggle, \"a[data-toggle]\");\\nif (_typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_5__.Filter.isSupported()) {\\n    (0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_5__.Filter, \"#tsd-filter\");\\n}\\nelse {\\n    document.documentElement.classList.add(\"no-filter\");\\n}\\nvar app = new _typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.Application();\\nObject.defineProperty(window, \"app\", { value: app });\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/bootstrap.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/Application.ts':\n            /*!******************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/Application.ts ***!\n  \\******************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"registerComponent\": () => /* binding */ registerComponent,\\n/* harmony export */   \"Application\": () => /* binding */ Application\\n/* harmony export */ });\\n/**\\n * List of all known components.\\n */\\nvar components = [];\\n/**\\n * Register a new component.\\n */\\nfunction registerComponent(constructor, selector) {\\n    components.push({\\n        selector: selector,\\n        constructor: constructor,\\n    });\\n}\\n/**\\n * TypeDoc application class.\\n */\\nvar Application = /** @class */ (function () {\\n    /**\\n     * Create a new Application instance.\\n     */\\n    function Application() {\\n        this.createComponents(document.body);\\n    }\\n    /**\\n     * Create all components beneath the given jQuery element.\\n     */\\n    Application.prototype.createComponents = function (context) {\\n        components.forEach(function (c) {\\n            context.querySelectorAll(c.selector).forEach(function (el) {\\n                if (!el.dataset.hasInstance) {\\n                    new c.constructor({ el: el });\\n                    el.dataset.hasInstance = String(true);\\n                }\\n            });\\n        });\\n    };\\n    return Application;\\n}());\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/Application.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/Component.ts':\n            /*!****************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/Component.ts ***!\n  \\****************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"Component\": () => /* binding */ Component\\n/* harmony export */ });\\n/**\\n * TypeDoc component class.\\n */\\nvar Component = /** @class */ (function () {\\n    function Component(options) {\\n        this.el = options.el;\\n    }\\n    return Component;\\n}());\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/Component.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/EventTarget.ts':\n            /*!******************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/EventTarget.ts ***!\n  \\******************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"EventTarget\": () => /* binding */ EventTarget\\n/* harmony export */ });\\n/**\\n * TypeDoc event target class.\\n */\\nvar EventTarget = /** @class */ (function () {\\n    function EventTarget() {\\n        this.listeners = {};\\n    }\\n    EventTarget.prototype.addEventListener = function (type, callback) {\\n        if (!(type in this.listeners)) {\\n            this.listeners[type] = [];\\n        }\\n        this.listeners[type].push(callback);\\n    };\\n    EventTarget.prototype.removeEventListener = function (type, callback) {\\n        if (!(type in this.listeners)) {\\n            return;\\n        }\\n        var stack = this.listeners[type];\\n        for (var i = 0, l = stack.length; i < l; i++) {\\n            if (stack[i] === callback) {\\n                stack.splice(i, 1);\\n                return;\\n            }\\n        }\\n    };\\n    EventTarget.prototype.dispatchEvent = function (event) {\\n        if (!(event.type in this.listeners)) {\\n            return true;\\n        }\\n        var stack = this.listeners[event.type].slice();\\n        for (var i = 0, l = stack.length; i < l; i++) {\\n            stack[i].call(this, event);\\n        }\\n        return !event.defaultPrevented;\\n    };\\n    return EventTarget;\\n}());\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/EventTarget.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/components/Filter.ts':\n            /*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Filter.ts ***!\n  \\************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"Filter\": () => /* binding */ Filter\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\\n/* harmony import */ var _utils_pointer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/pointer */ \"./default/assets/js/src/typedoc/utils/pointer.ts\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\nvar FilterItem = /** @class */ (function () {\\n    function FilterItem(key, value) {\\n        this.key = key;\\n        this.value = value;\\n        this.defaultValue = value;\\n        this.initialize();\\n        if (window.localStorage[this.key]) {\\n            this.setValue(this.fromLocalStorage(window.localStorage[this.key]));\\n        }\\n    }\\n    FilterItem.prototype.initialize = function () { };\\n    FilterItem.prototype.setValue = function (value) {\\n        if (this.value == value)\\n            return;\\n        var oldValue = this.value;\\n        this.value = value;\\n        window.localStorage[this.key] = this.toLocalStorage(value);\\n        this.handleValueChange(oldValue, value);\\n    };\\n    return FilterItem;\\n}());\\nvar FilterItemCheckbox = /** @class */ (function (_super) {\\n    __extends(FilterItemCheckbox, _super);\\n    function FilterItemCheckbox() {\\n        return _super !== null && _super.apply(this, arguments) || this;\\n    }\\n    FilterItemCheckbox.prototype.initialize = function () {\\n        var _this = this;\\n        var checkbox = document.querySelector(\"#tsd-filter-\" + this.key);\\n        if (!checkbox)\\n            return;\\n        this.checkbox = checkbox;\\n        this.checkbox.addEventListener(\"change\", function () {\\n            _this.setValue(_this.checkbox.checked);\\n        });\\n    };\\n    FilterItemCheckbox.prototype.handleValueChange = function (oldValue, newValue) {\\n        if (!this.checkbox)\\n            return;\\n        this.checkbox.checked = this.value;\\n        document.documentElement.classList.toggle(\"toggle-\" + this.key, this.value != this.defaultValue);\\n    };\\n    FilterItemCheckbox.prototype.fromLocalStorage = function (value) {\\n        return value == \"true\";\\n    };\\n    FilterItemCheckbox.prototype.toLocalStorage = function (value) {\\n        return value ? \"true\" : \"false\";\\n    };\\n    return FilterItemCheckbox;\\n}(FilterItem));\\nvar FilterItemSelect = /** @class */ (function (_super) {\\n    __extends(FilterItemSelect, _super);\\n    function FilterItemSelect() {\\n        return _super !== null && _super.apply(this, arguments) || this;\\n    }\\n    FilterItemSelect.prototype.initialize = function () {\\n        var _this = this;\\n        document.documentElement.classList.add(\"toggle-\" + this.key + this.value);\\n        var select = document.querySelector(\"#tsd-filter-\" + this.key);\\n        if (!select)\\n            return;\\n        this.select = select;\\n        var onActivate = function () {\\n            _this.select.classList.add(\"active\");\\n        };\\n        var onDeactivate = function () {\\n            _this.select.classList.remove(\"active\");\\n        };\\n        this.select.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, onActivate);\\n        this.select.addEventListener(\"mouseover\", onActivate);\\n        this.select.addEventListener(\"mouseleave\", onDeactivate);\\n        this.select.querySelectorAll(\"li\").forEach(function (el) {\\n            el.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, function (e) {\\n                select.classList.remove(\"active\");\\n                _this.setValue(e.target.dataset.value || \"\");\\n            });\\n        });\\n        document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, function (e) {\\n            if (_this.select.contains(e.target))\\n                return;\\n            _this.select.classList.remove(\"active\");\\n        });\\n    };\\n    FilterItemSelect.prototype.handleValueChange = function (oldValue, newValue) {\\n        this.select.querySelectorAll(\"li.selected\").forEach(function (el) {\\n            el.classList.remove(\"selected\");\\n        });\\n        var selected = this.select.querySelector(\\'li[data-value=\"\\' + newValue + \\'\"]\\');\\n        var label = this.select.querySelector(\".tsd-select-label\");\\n        if (selected && label) {\\n            selected.classList.add(\"selected\");\\n            label.textContent = selected.textContent;\\n        }\\n        document.documentElement.classList.remove(\"toggle-\" + oldValue);\\n        document.documentElement.classList.add(\"toggle-\" + newValue);\\n    };\\n    FilterItemSelect.prototype.fromLocalStorage = function (value) {\\n        return value;\\n    };\\n    FilterItemSelect.prototype.toLocalStorage = function (value) {\\n        return value;\\n    };\\n    return FilterItemSelect;\\n}(FilterItem));\\nvar Filter = /** @class */ (function (_super) {\\n    __extends(Filter, _super);\\n    function Filter(options) {\\n        var _this = _super.call(this, options) || this;\\n        _this.optionVisibility = new FilterItemSelect(\"visibility\", \"private\");\\n        _this.optionInherited = new FilterItemCheckbox(\"inherited\", true);\\n        _this.optionExternals = new FilterItemCheckbox(\"externals\", true);\\n        return _this;\\n    }\\n    Filter.isSupported = function () {\\n        try {\\n            return typeof window.localStorage != \"undefined\";\\n        }\\n        catch (e) {\\n            return false;\\n        }\\n    };\\n    return Filter;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Filter.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/components/MenuHighlight.ts':\n            /*!*******************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/MenuHighlight.ts ***!\n  \\*******************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"MenuHighlight\": () => /* binding */ MenuHighlight\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\\n/* harmony import */ var _services_Viewport__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../services/Viewport */ \"./default/assets/js/src/typedoc/services/Viewport.ts\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\n/**\\n * Manages the sticky state of the navigation and moves the highlight\\n * to the current navigation item.\\n */\\nvar MenuHighlight = /** @class */ (function (_super) {\\n    __extends(MenuHighlight, _super);\\n    /**\\n     * Create a new MenuHighlight instance.\\n     *\\n     * @param options  Backbone view constructor options.\\n     */\\n    function MenuHighlight(options) {\\n        var _this = _super.call(this, options) || this;\\n        /**\\n         * List of all discovered anchors.\\n         */\\n        _this.anchors = [];\\n        /**\\n         * Index of the currently highlighted anchor.\\n         */\\n        _this.index = -1;\\n        _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.addEventListener(\"resize\", function () { return _this.onResize(); });\\n        _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.addEventListener(\"scroll\", function (e) { return _this.onScroll(e); });\\n        _this.createAnchors();\\n        return _this;\\n    }\\n    /**\\n     * Find all anchors on the current page.\\n     */\\n    MenuHighlight.prototype.createAnchors = function () {\\n        var _this = this;\\n        var base = window.location.href;\\n        if (base.indexOf(\"#\") != -1) {\\n            base = base.substr(0, base.indexOf(\"#\"));\\n        }\\n        this.el.querySelectorAll(\"a\").forEach(function (el) {\\n            var href = el.href;\\n            if (href.indexOf(\"#\") == -1)\\n                return;\\n            if (href.substr(0, base.length) != base)\\n                return;\\n            var hash = href.substr(href.indexOf(\"#\") + 1);\\n            var anchor = document.querySelector(\"a.tsd-anchor[name=\" + hash + \"]\");\\n            var link = el.parentNode;\\n            if (!anchor || !link)\\n                return;\\n            _this.anchors.push({\\n                link: link,\\n                anchor: anchor,\\n                position: 0,\\n            });\\n        });\\n        this.onResize();\\n    };\\n    /**\\n     * Triggered after the viewport was resized.\\n     */\\n    MenuHighlight.prototype.onResize = function () {\\n        var anchor;\\n        for (var index = 0, count = this.anchors.length; index < count; index++) {\\n            anchor = this.anchors[index];\\n            var rect = anchor.anchor.getBoundingClientRect();\\n            anchor.position = rect.top + document.body.scrollTop;\\n        }\\n        this.anchors.sort(function (a, b) {\\n            return a.position - b.position;\\n        });\\n        var event = new CustomEvent(\"scroll\", {\\n            detail: {\\n                scrollTop: _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.scrollTop,\\n            },\\n        });\\n        this.onScroll(event);\\n    };\\n    /**\\n     * Triggered after the viewport was scrolled.\\n     *\\n     * @param event  The custom event with the current vertical scroll position.\\n     */\\n    MenuHighlight.prototype.onScroll = function (event) {\\n        var scrollTop = event.detail.scrollTop + 5;\\n        var anchors = this.anchors;\\n        var count = anchors.length - 1;\\n        var index = this.index;\\n        while (index > -1 && anchors[index].position > scrollTop) {\\n            index -= 1;\\n        }\\n        while (index < count && anchors[index + 1].position < scrollTop) {\\n            index += 1;\\n        }\\n        if (this.index != index) {\\n            if (this.index > -1)\\n                this.anchors[this.index].link.classList.remove(\"focus\");\\n            this.index = index;\\n            if (this.index > -1)\\n                this.anchors[this.index].link.classList.add(\"focus\");\\n        }\\n    };\\n    return MenuHighlight;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/MenuHighlight.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/components/Search.ts':\n            /*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Search.ts ***!\n  \\************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"initSearch\": () => /* binding */ initSearch\\n/* harmony export */ });\\n/* harmony import */ var _utils_debounce__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/debounce */ \"./default/assets/js/src/typedoc/utils/debounce.ts\");\\n/* harmony import */ var lunr__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! lunr */ \"../node_modules/lunr/lunr.js\");\\n/* harmony import */ var lunr__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(lunr__WEBPACK_IMPORTED_MODULE_1__);\\n\\n\\nfunction initSearch() {\\n    var searchEl = document.getElementById(\"tsd-search\");\\n    if (!searchEl)\\n        return;\\n    var searchScript = document.getElementById(\"search-script\");\\n    searchEl.classList.add(\"loading\");\\n    if (searchScript) {\\n        searchScript.addEventListener(\"error\", function () {\\n            searchEl.classList.remove(\"loading\");\\n            searchEl.classList.add(\"failure\");\\n        });\\n        searchScript.addEventListener(\"load\", function () {\\n            searchEl.classList.remove(\"loading\");\\n            searchEl.classList.add(\"ready\");\\n        });\\n        if (window.searchData) {\\n            searchEl.classList.remove(\"loading\");\\n        }\\n    }\\n    var field = document.querySelector(\"#tsd-search-field\");\\n    var results = document.querySelector(\".results\");\\n    if (!field || !results) {\\n        throw new Error(\"The input field or the result list wrapper was not found\");\\n    }\\n    var resultClicked = false;\\n    results.addEventListener(\"mousedown\", function () { return (resultClicked = true); });\\n    results.addEventListener(\"mouseup\", function () {\\n        resultClicked = false;\\n        searchEl.classList.remove(\"has-focus\");\\n    });\\n    field.addEventListener(\"focus\", function () { return searchEl.classList.add(\"has-focus\"); });\\n    field.addEventListener(\"blur\", function () {\\n        if (!resultClicked) {\\n            resultClicked = false;\\n            searchEl.classList.remove(\"has-focus\");\\n        }\\n    });\\n    var state = {\\n        base: searchEl.dataset.base + \"/\",\\n    };\\n    bindEvents(searchEl, results, field, state);\\n}\\nfunction bindEvents(searchEl, results, field, state) {\\n    field.addEventListener(\"input\", (0,_utils_debounce__WEBPACK_IMPORTED_MODULE_0__.debounce)(function () {\\n        updateResults(searchEl, results, field, state);\\n    }, 200));\\n    var preventPress = false;\\n    field.addEventListener(\"keydown\", function (e) {\\n        preventPress = true;\\n        if (e.key == \"Enter\") {\\n            gotoCurrentResult(results, field);\\n        }\\n        else if (e.key == \"Escape\") {\\n            field.blur();\\n        }\\n        else if (e.key == \"ArrowUp\") {\\n            setCurrentResult(results, -1);\\n        }\\n        else if (e.key === \"ArrowDown\") {\\n            setCurrentResult(results, 1);\\n        }\\n        else {\\n            preventPress = false;\\n        }\\n    });\\n    field.addEventListener(\"keypress\", function (e) {\\n        if (preventPress)\\n            e.preventDefault();\\n    });\\n    /**\\n     * Start searching by pressing slash.\\n     */\\n    document.body.addEventListener(\"keydown\", function (e) {\\n        if (e.altKey || e.ctrlKey || e.metaKey)\\n            return;\\n        if (!field.matches(\":focus\") && e.key === \"/\") {\\n            field.focus();\\n            e.preventDefault();\\n        }\\n    });\\n}\\nfunction checkIndex(state, searchEl) {\\n    if (state.index)\\n        return;\\n    if (window.searchData) {\\n        searchEl.classList.remove(\"loading\");\\n        searchEl.classList.add(\"ready\");\\n        state.data = window.searchData;\\n        state.index = lunr__WEBPACK_IMPORTED_MODULE_1__.Index.load(window.searchData.index);\\n    }\\n}\\nfunction updateResults(searchEl, results, query, state) {\\n    checkIndex(state, searchEl);\\n    // Don\\'t clear results if loading state is not ready,\\n    // because loading or error message can be removed.\\n    if (!state.index || !state.data)\\n        return;\\n    results.textContent = \"\";\\n    var searchText = query.value.trim();\\n    // Perform a wildcard search\\n    var res = state.index.search(\"*\" + searchText + \"*\");\\n    for (var i = 0, c = Math.min(10, res.length); i < c; i++) {\\n        var row = state.data.rows[Number(res[i].ref)];\\n        // Bold the matched part of the query in the search results\\n        var name_1 = boldMatches(row.name, searchText);\\n        if (row.parent) {\\n            name_1 = \"<span class=\\\\\"parent\\\\\">\" + boldMatches(row.parent, searchText) + \".</span>\" + name_1;\\n        }\\n        var item = document.createElement(\"li\");\\n        item.classList.value = row.classes;\\n        var anchor = document.createElement(\"a\");\\n        anchor.href = state.base + row.url;\\n        anchor.classList.add(\"tsd-kind-icon\");\\n        anchor.innerHTML = name_1;\\n        item.append(anchor);\\n        results.appendChild(item);\\n    }\\n}\\n/**\\n * Move the highlight within the result set.\\n */\\nfunction setCurrentResult(results, dir) {\\n    var current = results.querySelector(\".current\");\\n    if (!current) {\\n        current = results.querySelector(dir == 1 ? \"li:first-child\" : \"li:last-child\");\\n        if (current) {\\n            current.classList.add(\"current\");\\n        }\\n    }\\n    else {\\n        var rel = dir == 1\\n            ? current.nextElementSibling\\n            : current.previousElementSibling;\\n        if (rel) {\\n            current.classList.remove(\"current\");\\n            rel.classList.add(\"current\");\\n        }\\n    }\\n}\\n/**\\n * Navigate to the highlighted result.\\n */\\nfunction gotoCurrentResult(results, field) {\\n    var current = results.querySelector(\".current\");\\n    if (!current) {\\n        current = results.querySelector(\"li:first-child\");\\n    }\\n    if (current) {\\n        var link = current.querySelector(\"a\");\\n        if (link) {\\n            window.location.href = link.href;\\n        }\\n        field.blur();\\n    }\\n}\\nfunction boldMatches(text, search) {\\n    if (search === \"\") {\\n        return text;\\n    }\\n    var lowerText = text.toLocaleLowerCase();\\n    var lowerSearch = search.toLocaleLowerCase();\\n    var parts = [];\\n    var lastIndex = 0;\\n    var index = lowerText.indexOf(lowerSearch);\\n    while (index != -1) {\\n        parts.push(escapeHtml(text.substring(lastIndex, index)), \"<b>\" + escapeHtml(text.substring(index, index + lowerSearch.length)) + \"</b>\");\\n        lastIndex = index + lowerSearch.length;\\n        index = lowerText.indexOf(lowerSearch, lastIndex);\\n    }\\n    parts.push(escapeHtml(text.substring(lastIndex)));\\n    return parts.join(\"\");\\n}\\nvar SPECIAL_HTML = {\\n    \"&\": \"&amp;\",\\n    \"<\": \"&lt;\",\\n    \">\": \"&gt;\",\\n    \"\\'\": \"&#039;\",\\n    \\'\"\\': \"&quot;\",\\n};\\nfunction escapeHtml(text) {\\n    return text.replace(/[&<>\"\\'\"]/g, function (match) { return SPECIAL_HTML[match]; });\\n}\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Search.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/components/Signature.ts':\n            /*!***************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Signature.ts ***!\n  \\***************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"Signature\": () => /* binding */ Signature\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\\n/* harmony import */ var _services_Viewport__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../services/Viewport */ \"./default/assets/js/src/typedoc/services/Viewport.ts\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\n/**\\n * Holds a signature and its description.\\n */\\nvar SignatureGroup = /** @class */ (function () {\\n    /**\\n     * Create a new SignatureGroup instance.\\n     *\\n     * @param signature    The target signature.\\n     * @param description  The description for the signature.\\n     */\\n    function SignatureGroup(signature, description) {\\n        this.signature = signature;\\n        this.description = description;\\n    }\\n    /**\\n     * Add the given class to all elements of the group.\\n     *\\n     * @param className  The class name to add.\\n     */\\n    SignatureGroup.prototype.addClass = function (className) {\\n        this.signature.classList.add(className);\\n        this.description.classList.add(className);\\n        return this;\\n    };\\n    /**\\n     * Remove the given class from all elements of the group.\\n     *\\n     * @param className  The class name to remove.\\n     */\\n    SignatureGroup.prototype.removeClass = function (className) {\\n        this.signature.classList.remove(className);\\n        this.description.classList.remove(className);\\n        return this;\\n    };\\n    return SignatureGroup;\\n}());\\n/**\\n * Controls the tab like behaviour of methods and functions with multiple signatures.\\n */\\nvar Signature = /** @class */ (function (_super) {\\n    __extends(Signature, _super);\\n    /**\\n     * Create a new Signature instance.\\n     *\\n     * @param options  Backbone view constructor options.\\n     */\\n    function Signature(options) {\\n        var _this = _super.call(this, options) || this;\\n        /**\\n         * List of found signature groups.\\n         */\\n        _this.groups = [];\\n        /**\\n         * The index of the currently displayed signature.\\n         */\\n        _this.index = -1;\\n        _this.createGroups();\\n        if (_this.container) {\\n            _this.el.classList.add(\"active\");\\n            Array.from(_this.el.children).forEach(function (signature) {\\n                signature.addEventListener(\"touchstart\", function (event) {\\n                    return _this.onClick(event);\\n                });\\n                signature.addEventListener(\"click\", function (event) {\\n                    return _this.onClick(event);\\n                });\\n            });\\n            _this.container.classList.add(\"active\");\\n            _this.setIndex(0);\\n        }\\n        return _this;\\n    }\\n    /**\\n     * Set the index of the active signature.\\n     *\\n     * @param index  The index of the signature to activate.\\n     */\\n    Signature.prototype.setIndex = function (index) {\\n        if (index < 0)\\n            index = 0;\\n        if (index > this.groups.length - 1)\\n            index = this.groups.length - 1;\\n        if (this.index == index)\\n            return;\\n        var to = this.groups[index];\\n        if (this.index > -1) {\\n            var from_1 = this.groups[this.index];\\n            from_1.removeClass(\"current\").addClass(\"fade-out\");\\n            to.addClass(\"current\");\\n            to.addClass(\"fade-in\");\\n            _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.triggerResize();\\n            setTimeout(function () {\\n                from_1.removeClass(\"fade-out\");\\n                to.removeClass(\"fade-in\");\\n            }, 300);\\n        }\\n        else {\\n            to.addClass(\"current\");\\n            _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.triggerResize();\\n        }\\n        this.index = index;\\n    };\\n    /**\\n     * Find all signature/description groups.\\n     */\\n    Signature.prototype.createGroups = function () {\\n        var signatures = this.el.children;\\n        if (signatures.length < 2)\\n            return;\\n        this.container = this.el.nextElementSibling;\\n        var descriptions = this.container.children;\\n        this.groups = [];\\n        for (var index = 0; index < signatures.length; index++) {\\n            this.groups.push(new SignatureGroup(signatures[index], descriptions[index]));\\n        }\\n    };\\n    /**\\n     * Triggered when the user clicks onto a signature header.\\n     *\\n     * @param e  The related event object.\\n     */\\n    Signature.prototype.onClick = function (e) {\\n        var _this = this;\\n        this.groups.forEach(function (group, index) {\\n            if (group.signature === e.currentTarget) {\\n                _this.setIndex(index);\\n            }\\n        });\\n    };\\n    return Signature;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Signature.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/components/Toggle.ts':\n            /*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Toggle.ts ***!\n  \\************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"Toggle\": () => /* binding */ Toggle\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\\n/* harmony import */ var _utils_pointer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/pointer */ \"./default/assets/js/src/typedoc/utils/pointer.ts\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\nvar Toggle = /** @class */ (function (_super) {\\n    __extends(Toggle, _super);\\n    function Toggle(options) {\\n        var _this = _super.call(this, options) || this;\\n        _this.className = _this.el.dataset.toggle || \"\";\\n        _this.el.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, function (e) { return _this.onPointerUp(e); });\\n        _this.el.addEventListener(\"click\", function (e) { return e.preventDefault(); });\\n        document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, function (e) {\\n            return _this.onDocumentPointerDown(e);\\n        });\\n        document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, function (e) {\\n            return _this.onDocumentPointerUp(e);\\n        });\\n        return _this;\\n    }\\n    Toggle.prototype.setActive = function (value) {\\n        if (this.active == value)\\n            return;\\n        this.active = value;\\n        document.documentElement.classList.toggle(\"has-\" + this.className, value);\\n        this.el.classList.toggle(\"active\", value);\\n        var transition = (this.active ? \"to-has-\" : \"from-has-\") + this.className;\\n        document.documentElement.classList.add(transition);\\n        setTimeout(function () { return document.documentElement.classList.remove(transition); }, 500);\\n    };\\n    Toggle.prototype.onPointerUp = function (event) {\\n        if (_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.hasPointerMoved)\\n            return;\\n        this.setActive(true);\\n        event.preventDefault();\\n    };\\n    Toggle.prototype.onDocumentPointerDown = function (e) {\\n        if (this.active) {\\n            if (e.target.closest(\".col-menu, .tsd-filter-group\")) {\\n                return;\\n            }\\n            this.setActive(false);\\n        }\\n    };\\n    Toggle.prototype.onDocumentPointerUp = function (e) {\\n        var _this = this;\\n        if (_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.hasPointerMoved)\\n            return;\\n        if (this.active) {\\n            if (e.target.closest(\".col-menu\")) {\\n                var link = e.target.closest(\"a\");\\n                if (link) {\\n                    var href = window.location.href;\\n                    if (href.indexOf(\"#\") != -1) {\\n                        href = href.substr(0, href.indexOf(\"#\"));\\n                    }\\n                    if (link.href.substr(0, href.length) == href) {\\n                        setTimeout(function () { return _this.setActive(false); }, 250);\\n                    }\\n                }\\n            }\\n        }\\n    };\\n    return Toggle;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Toggle.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/services/Viewport.ts':\n            /*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/services/Viewport.ts ***!\n  \\************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"Viewport\": () => /* binding */ Viewport\\n/* harmony export */ });\\n/* harmony import */ var _EventTarget__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../EventTarget */ \"./default/assets/js/src/typedoc/EventTarget.ts\");\\n/* harmony import */ var _utils_trottle__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/trottle */ \"./default/assets/js/src/typedoc/utils/trottle.ts\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\n/**\\n * A global service that monitors the window size and scroll position.\\n */\\nvar Viewport = /** @class */ (function (_super) {\\n    __extends(Viewport, _super);\\n    /**\\n     * Create new Viewport instance.\\n     */\\n    function Viewport() {\\n        var _this = _super.call(this) || this;\\n        /**\\n         * The current scroll position.\\n         */\\n        _this.scrollTop = 0;\\n        /**\\n         * The previous scrollTop.\\n         */\\n        _this.lastY = 0;\\n        /**\\n         * The width of the window.\\n         */\\n        _this.width = 0;\\n        /**\\n         * The height of the window.\\n         */\\n        _this.height = 0;\\n        /**\\n         * Boolean indicating whether the toolbar is shown.\\n         */\\n        _this.showToolbar = true;\\n        _this.toolbar = (document.querySelector(\".tsd-page-toolbar\"));\\n        _this.secondaryNav = (document.querySelector(\".tsd-navigation.secondary\"));\\n        window.addEventListener(\"scroll\", (0,_utils_trottle__WEBPACK_IMPORTED_MODULE_1__.throttle)(function () { return _this.onScroll(); }, 10));\\n        window.addEventListener(\"resize\", (0,_utils_trottle__WEBPACK_IMPORTED_MODULE_1__.throttle)(function () { return _this.onResize(); }, 10));\\n        _this.onResize();\\n        _this.onScroll();\\n        return _this;\\n    }\\n    /**\\n     * Trigger a resize event.\\n     */\\n    Viewport.prototype.triggerResize = function () {\\n        var event = new CustomEvent(\"resize\", {\\n            detail: {\\n                width: this.width,\\n                height: this.height,\\n            },\\n        });\\n        this.dispatchEvent(event);\\n    };\\n    /**\\n     * Triggered when the size of the window has changed.\\n     */\\n    Viewport.prototype.onResize = function () {\\n        this.width = window.innerWidth || 0;\\n        this.height = window.innerHeight || 0;\\n        var event = new CustomEvent(\"resize\", {\\n            detail: {\\n                width: this.width,\\n                height: this.height,\\n            },\\n        });\\n        this.dispatchEvent(event);\\n    };\\n    /**\\n     * Triggered when the user scrolled the viewport.\\n     */\\n    Viewport.prototype.onScroll = function () {\\n        this.scrollTop = window.scrollY || 0;\\n        var event = new CustomEvent(\"scroll\", {\\n            detail: {\\n                scrollTop: this.scrollTop,\\n            },\\n        });\\n        this.dispatchEvent(event);\\n        this.hideShowToolbar();\\n    };\\n    /**\\n     * Handle hiding/showing of the toolbar.\\n     */\\n    Viewport.prototype.hideShowToolbar = function () {\\n        var isShown = this.showToolbar;\\n        this.showToolbar = this.lastY >= this.scrollTop || this.scrollTop <= 0;\\n        if (isShown !== this.showToolbar) {\\n            this.toolbar.classList.toggle(\"tsd-page-toolbar--hide\");\\n            this.secondaryNav.classList.toggle(\"tsd-navigation--toolbar-hide\");\\n        }\\n        this.lastY = this.scrollTop;\\n    };\\n    Viewport.instance = new Viewport();\\n    return Viewport;\\n}(_EventTarget__WEBPACK_IMPORTED_MODULE_0__.EventTarget));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/services/Viewport.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/utils/debounce.ts':\n            /*!*********************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/utils/debounce.ts ***!\n  \\*********************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"debounce\": () => /* binding */ debounce\\n/* harmony export */ });\\nvar debounce = function (fn, wait) {\\n    if (wait === void 0) { wait = 100; }\\n    var timeout;\\n    return function () {\\n        var args = [];\\n        for (var _i = 0; _i < arguments.length; _i++) {\\n            args[_i] = arguments[_i];\\n        }\\n        clearTimeout(timeout);\\n        timeout = setTimeout(function () { return fn(args); }, wait);\\n    };\\n};\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/debounce.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/utils/pointer.ts':\n            /*!********************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/utils/pointer.ts ***!\n  \\********************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"pointerDown\": () => /* binding */ pointerDown,\\n/* harmony export */   \"pointerMove\": () => /* binding */ pointerMove,\\n/* harmony export */   \"pointerUp\": () => /* binding */ pointerUp,\\n/* harmony export */   \"pointerDownPosition\": () => /* binding */ pointerDownPosition,\\n/* harmony export */   \"preventNextClick\": () => /* binding */ preventNextClick,\\n/* harmony export */   \"isPointerDown\": () => /* binding */ isPointerDown,\\n/* harmony export */   \"isPointerTouch\": () => /* binding */ isPointerTouch,\\n/* harmony export */   \"hasPointerMoved\": () => /* binding */ hasPointerMoved,\\n/* harmony export */   \"isMobile\": () => /* binding */ isMobile\\n/* harmony export */ });\\n/**\\n * Event name of the pointer down event.\\n */\\nvar pointerDown = \"mousedown\";\\n/**\\n * Event name of the pointer move event.\\n */\\nvar pointerMove = \"mousemove\";\\n/**\\n * Event name of the pointer up event.\\n */\\nvar pointerUp = \"mouseup\";\\n/**\\n * Position the pointer was pressed at.\\n */\\nvar pointerDownPosition = { x: 0, y: 0 };\\n/**\\n * Should the next click on the document be supressed?\\n */\\nvar preventNextClick = false;\\n/**\\n * Is the pointer down?\\n */\\nvar isPointerDown = false;\\n/**\\n * Is the pointer a touch point?\\n */\\nvar isPointerTouch = false;\\n/**\\n * Did the pointer move since the last down event?\\n */\\nvar hasPointerMoved = false;\\n/**\\n * Is the user agent a mobile agent?\\n */\\nvar isMobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);\\ndocument.documentElement.classList.add(isMobile ? \"is-mobile\" : \"not-mobile\");\\nif (isMobile && \"ontouchstart\" in document.documentElement) {\\n    isPointerTouch = true;\\n    pointerDown = \"touchstart\";\\n    pointerMove = \"touchmove\";\\n    pointerUp = \"touchend\";\\n}\\ndocument.addEventListener(pointerDown, function (e) {\\n    isPointerDown = true;\\n    hasPointerMoved = false;\\n    var t = pointerDown == \"touchstart\"\\n        ? e.targetTouches[0]\\n        : e;\\n    pointerDownPosition.y = t.pageY || 0;\\n    pointerDownPosition.x = t.pageX || 0;\\n});\\ndocument.addEventListener(pointerMove, function (e) {\\n    if (!isPointerDown)\\n        return;\\n    if (!hasPointerMoved) {\\n        var t = pointerDown == \"touchstart\"\\n            ? e.targetTouches[0]\\n            : e;\\n        var x = pointerDownPosition.x - (t.pageX || 0);\\n        var y = pointerDownPosition.y - (t.pageY || 0);\\n        hasPointerMoved = Math.sqrt(x * x + y * y) > 10;\\n    }\\n});\\ndocument.addEventListener(pointerUp, function () {\\n    isPointerDown = false;\\n});\\ndocument.addEventListener(\"click\", function (e) {\\n    if (preventNextClick) {\\n        e.preventDefault();\\n        e.stopImmediatePropagation();\\n        preventNextClick = false;\\n    }\\n});\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/pointer.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/utils/trottle.ts':\n            /*!********************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/utils/trottle.ts ***!\n  \\********************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"throttle\": () => /* binding */ throttle\\n/* harmony export */ });\\nvar throttle = function (fn, wait) {\\n    if (wait === void 0) { wait = 100; }\\n    var time = Date.now();\\n    return function () {\\n        var args = [];\\n        for (var _i = 0; _i < arguments.length; _i++) {\\n            args[_i] = arguments[_i];\\n        }\\n        if (time + wait - Date.now() < 0) {\\n            fn.apply(void 0, args);\\n            time = Date.now();\\n        }\\n    };\\n};\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/trottle.ts?'\n              )\n\n              /***/\n            },\n\n          /******/\n        }\n        /************************************************************************/\n        /******/ // The module cache\n        /******/ var __webpack_module_cache__ = {}\n        /******/\n        /******/ // The require function\n        /******/ function __webpack_require__(moduleId) {\n          /******/ // Check if module is in cache\n          /******/ if (__webpack_module_cache__[moduleId]) {\n            /******/ return __webpack_module_cache__[moduleId].exports\n            /******/\n          }\n          /******/ // Create a new module (and put it into the cache)\n          /******/ var module = (__webpack_module_cache__[moduleId] = {\n            /******/ // no module.id needed\n            /******/ // no module.loaded needed\n            /******/ exports: {},\n            /******/\n          })\n          /******/\n          /******/ // Execute the module function\n          /******/ __webpack_modules__[moduleId](\n            module,\n            module.exports,\n            __webpack_require__\n          )\n          /******/\n          /******/ // Return the exports of the module\n          /******/ return module.exports\n          /******/\n        }\n        /******/\n        /************************************************************************/\n        /******/ /* webpack/runtime/compat get default export */\n        /******/ ;(() => {\n          /******/ // getDefaultExport function for compatibility with non-harmony modules\n          /******/ __webpack_require__.n = module => {\n            /******/ var getter =\n              module && module.__esModule\n                ? /******/ () => module['default']\n                : /******/ () => module\n            /******/ __webpack_require__.d(getter, { a: getter })\n            /******/ return getter\n            /******/\n          }\n          /******/\n        })() /* webpack/runtime/define property getters */\n        /******/\n        /******/\n        /******/\n        ;(() => {\n          /******/ // define getter functions for harmony exports\n          /******/ __webpack_require__.d = (exports, definition) => {\n            /******/ for (var key in definition) {\n              /******/ if (\n                __webpack_require__.o(definition, key) &&\n                !__webpack_require__.o(exports, key)\n              ) {\n                /******/ Object.defineProperty(exports, key, {\n                  enumerable: true,\n                  get: definition[key],\n                })\n                /******/\n              }\n              /******/\n            }\n            /******/\n          }\n          /******/\n        })() /* webpack/runtime/hasOwnProperty shorthand */\n        /******/\n        /******/\n        /******/\n        ;(() => {\n          /******/ __webpack_require__.o = (obj, prop) =>\n            Object.prototype.hasOwnProperty.call(obj, prop)\n          /******/\n        })() /* webpack/runtime/make namespace object */\n        /******/\n        /******/\n        /******/\n        ;(() => {\n          /******/ // define __esModule on exports\n          /******/ __webpack_require__.r = exports => {\n            /******/ if (typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n              /******/ Object.defineProperty(exports, Symbol.toStringTag, {\n                value: 'Module',\n              })\n              /******/\n            }\n            /******/ Object.defineProperty(exports, '__esModule', {\n              value: true,\n            })\n            /******/\n          }\n          /******/\n        })()\n        /******/\n        /************************************************************************/\n        /******/ // startup\n        /******/ // Load entry module\n        /******/ __webpack_require__('./default/assets/js/src/bootstrap.ts')\n        /******/ // This entry module used 'exports' so it can't be inlined\n        /******/\n      })()\n    </script>\n  </body>\n</html>\n"
  },
  {
    "path": "typedocs/modules.html",
    "content": "<!DOCTYPE html>\n<html class=\"minimal no-js\">\n  <head>\n    <meta charset=\"utf-8\" />\n    <meta http-equiv=\"X-UA-Compatible\" content=\"IE=edge\" />\n    <title>react-charts | react-charts</title>\n    <meta name=\"description\" content=\"Documentation for react-charts\" />\n    <meta name=\"viewport\" content=\"width=device-width, initial-scale=1\" />\n    <style type=\"text/css\">\n      :root {\n        --color-background: #fdfdfd;\n        --color-text: #222;\n        --color-text-aside: #707070;\n        --color-link: #4da6ff;\n        --color-menu-divider: #eee;\n        --color-menu-divider-focus: #000;\n        --color-menu-label: #707070;\n        --color-panel: #fff;\n        --color-panel-divider: #eee;\n        --color-comment-tag: #707070;\n        --color-comment-tag-text: #fff;\n        --color-code-background: rgba(0, 0, 0, 0.04);\n        --color-ts: #9600ff;\n        --color-ts-interface: #647f1b;\n        --color-ts-enum: #937210;\n        --color-ts-class: #0672de;\n        --color-ts-private: #707070;\n        --color-toolbar: #fff;\n        --color-toolbar-text: #333;\n      }\n\n      /*! normalize.css v1.1.3 | MIT License | git.io/normalize */\n      /* ==========================================================================\n * * HTML5 display definitions\n * * ========================================================================== */\n      /**\n * * Correct `block` display not defined in IE 6/7/8/9 and Firefox 3. */\n      article,\n      aside,\n      details,\n      figcaption,\n      figure,\n      footer,\n      header,\n      hgroup,\n      main,\n      nav,\n      section,\n      summary {\n        display: block;\n      }\n\n      /**\n * * Correct `inline-block` display not defined in IE 6/7/8/9 and Firefox 3. */\n      audio,\n      canvas,\n      video {\n        display: inline-block;\n        *display: inline;\n        *zoom: 1;\n      }\n\n      /**\n * * Prevent modern browsers from displaying `audio` without controls.\n * * Remove excess height in iOS 5 devices. */\n      audio:not([controls]) {\n        display: none;\n        height: 0;\n      }\n\n      /**\n * * Address styling not present in IE 7/8/9, Firefox 3, and Safari 4.\n * * Known issue: no IE 6 support. */\n      [hidden] {\n        display: none;\n      }\n\n      /* ==========================================================================\n * * Base\n * * ========================================================================== */\n      /**\n * * 1. Correct text resizing oddly in IE 6/7 when body `font-size` is set using\n * *    `em` units.\n * * 2. Prevent iOS text size adjust after orientation change, without disabling\n * *    user zoom. */\n      html {\n        font-size: 100%;\n        /* 1 */\n        -ms-text-size-adjust: 100%;\n        /* 2 */\n        -webkit-text-size-adjust: 100%;\n        /* 2 */\n        font-family: sans-serif;\n      }\n\n      /**\n * * Address `font-family` inconsistency between `textarea` and other form\n * * elements. */\n      button,\n      input,\n      select,\n      textarea {\n        font-family: sans-serif;\n      }\n\n      /**\n * * Address margins handled incorrectly in IE 6/7. */\n      body {\n        margin: 0;\n      }\n\n      /* ==========================================================================\n * * Links\n * * ========================================================================== */\n      /**\n * * Address `outline` inconsistency between Chrome and other browsers. */\n      a:focus {\n        outline: thin dotted;\n      }\n      a:active,\n      a:hover {\n        outline: 0;\n      }\n\n      /**\n * * Improve readability when focused and also mouse hovered in all browsers. */\n      /* ==========================================================================\n * * Typography\n * * ========================================================================== */\n      /**\n * * Address font sizes and margins set differently in IE 6/7.\n * * Address font sizes within `section` and `article` in Firefox 4+, Safari 5,\n * * and Chrome. */\n      h1 {\n        font-size: 2em;\n        margin: 0.67em 0;\n      }\n\n      h2 {\n        font-size: 1.5em;\n        margin: 0.83em 0;\n      }\n\n      h3 {\n        font-size: 1.17em;\n        margin: 1em 0;\n      }\n\n      h4,\n      .tsd-index-panel h3 {\n        font-size: 1em;\n        margin: 1.33em 0;\n      }\n\n      h5 {\n        font-size: 0.83em;\n        margin: 1.67em 0;\n      }\n\n      h6 {\n        font-size: 0.67em;\n        margin: 2.33em 0;\n      }\n\n      /**\n * * Address styling not present in IE 7/8/9, Safari 5, and Chrome. */\n      abbr[title] {\n        border-bottom: 1px dotted;\n      }\n\n      /**\n * * Address style set to `bolder` in Firefox 3+, Safari 4/5, and Chrome. */\n      b,\n      strong {\n        font-weight: bold;\n      }\n\n      blockquote {\n        margin: 1em 40px;\n      }\n\n      /**\n * * Address styling not present in Safari 5 and Chrome. */\n      dfn {\n        font-style: italic;\n      }\n\n      /**\n * * Address differences between Firefox and other browsers.\n * * Known issue: no IE 6/7 normalization. */\n      hr {\n        -moz-box-sizing: content-box;\n        box-sizing: content-box;\n        height: 0;\n      }\n\n      /**\n * * Address styling not present in IE 6/7/8/9. */\n      mark {\n        background: #ff0;\n        color: #000;\n      }\n\n      /**\n * * Address margins set differently in IE 6/7. */\n      p,\n      pre {\n        margin: 1em 0;\n      }\n\n      /**\n * * Correct font family set oddly in IE 6, Safari 4/5, and Chrome. */\n      code,\n      kbd,\n      pre,\n      samp {\n        font-family: monospace, serif;\n        _font-family: 'courier new', monospace;\n        font-size: 1em;\n      }\n\n      /**\n * * Improve readability of pre-formatted text in all browsers. */\n      pre {\n        white-space: pre;\n        white-space: pre-wrap;\n        word-wrap: break-word;\n      }\n\n      /**\n * * Address CSS quotes not supported in IE 6/7. */\n      q {\n        quotes: none;\n      }\n      q:before,\n      q:after {\n        content: '';\n        content: none;\n      }\n\n      /**\n * * Address `quotes` property not supported in Safari 4. */\n      /**\n * * Address inconsistent and variable font size in all browsers. */\n      small {\n        font-size: 80%;\n      }\n\n      /**\n * * Prevent `sub` and `sup` affecting `line-height` in all browsers. */\n      sub {\n        font-size: 75%;\n        line-height: 0;\n        position: relative;\n        vertical-align: baseline;\n      }\n\n      sup {\n        font-size: 75%;\n        line-height: 0;\n        position: relative;\n        vertical-align: baseline;\n        top: -0.5em;\n      }\n\n      sub {\n        bottom: -0.25em;\n      }\n\n      /* ==========================================================================\n * * Lists\n * * ========================================================================== */\n      /**\n * * Address margins set differently in IE 6/7. */\n      dl,\n      menu,\n      ol,\n      ul {\n        margin: 1em 0;\n      }\n\n      dd {\n        margin: 0 0 0 40px;\n      }\n\n      /**\n * * Address paddings set differently in IE 6/7. */\n      menu,\n      ol,\n      ul {\n        padding: 0 0 0 40px;\n      }\n\n      /**\n * * Correct list images handled incorrectly in IE 7. */\n      nav ul,\n      nav ol {\n        list-style: none;\n        list-style-image: none;\n      }\n\n      /* ==========================================================================\n * * Embedded content\n * * ========================================================================== */\n      /**\n * * 1. Remove border when inside `a` element in IE 6/7/8/9 and Firefox 3.\n * * 2. Improve image quality when scaled in IE 7. */\n      img {\n        border: 0;\n        /* 1 */\n        -ms-interpolation-mode: bicubic;\n      }\n\n      /* 2 */\n      /**\n * * Correct overflow displayed oddly in IE 9. */\n      svg:not(:root) {\n        overflow: hidden;\n      }\n\n      /* ==========================================================================\n * * Figures\n * * ========================================================================== */\n      /**\n * * Address margin not present in IE 6/7/8/9, Safari 5, and Opera 11. */\n      figure,\n      form {\n        margin: 0;\n      }\n\n      /* ==========================================================================\n * * Forms\n * * ========================================================================== */\n      /**\n * * Correct margin displayed oddly in IE 6/7. */\n      /**\n * * Define consistent border, margin, and padding. */\n      fieldset {\n        border: 1px solid #c0c0c0;\n        margin: 0 2px;\n        padding: 0.35em 0.625em 0.75em;\n      }\n\n      /**\n * * 1. Correct color not being inherited in IE 6/7/8/9.\n * * 2. Correct text not wrapping in Firefox 3.\n * * 3. Correct alignment displayed oddly in IE 6/7. */\n      legend {\n        border: 0;\n        /* 1 */\n        padding: 0;\n        white-space: normal;\n        /* 2 */\n        *margin-left: -7px;\n      }\n\n      /* 3 */\n      /**\n * * 1. Correct font size not being inherited in all browsers.\n * * 2. Address margins set differently in IE 6/7, Firefox 3+, Safari 5,\n * *    and Chrome.\n * * 3. Improve appearance and consistency in all browsers. */\n      button,\n      input,\n      select,\n      textarea {\n        font-size: 100%;\n        /* 1 */\n        margin: 0;\n        /* 2 */\n        vertical-align: baseline;\n        /* 3 */\n        *vertical-align: middle;\n      }\n\n      /* 3 */\n      /**\n * * Address Firefox 3+ setting `line-height` on `input` using `!important` in\n * * the UA stylesheet. */\n      button,\n      input {\n        line-height: normal;\n      }\n\n      /**\n * * Address inconsistent `text-transform` inheritance for `button` and `select`.\n * * All other form control elements do not inherit `text-transform` values.\n * * Correct `button` style inheritance in Chrome, Safari 5+, and IE 6+.\n * * Correct `select` style inheritance in Firefox 4+ and Opera. */\n      button,\n      select {\n        text-transform: none;\n      }\n\n      /**\n * * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`\n * *    and `video` controls.\n * * 2. Correct inability to style clickable `input` types in iOS.\n * * 3. Improve usability and consistency of cursor style between image-type\n * *    `input` and others.\n * * 4. Remove inner spacing in IE 7 without affecting normal text inputs.\n * *    Known issue: inner spacing remains in IE 6. */\n      button,\n      html input[type='button'] {\n        -webkit-appearance: button;\n        /* 2 */\n        cursor: pointer;\n        /* 3 */\n        *overflow: visible;\n      }\n\n      /* 4 */\n      input[type='reset'],\n      input[type='submit'] {\n        -webkit-appearance: button;\n        /* 2 */\n        cursor: pointer;\n        /* 3 */\n        *overflow: visible;\n      }\n\n      /* 4 */\n      /**\n * * Re-set default cursor for disabled elements. */\n      button[disabled],\n      html input[disabled] {\n        cursor: default;\n      }\n\n      /**\n * * 1. Address box sizing set to content-box in IE 8/9.\n * * 2. Remove excess padding in IE 8/9.\n * * 3. Remove excess padding in IE 7.\n * *    Known issue: excess padding remains in IE 6. */\n      input {\n        /* 3 */\n      }\n      input[type='checkbox'],\n      input[type='radio'] {\n        box-sizing: border-box;\n        /* 1 */\n        padding: 0;\n        /* 2 */\n        *height: 13px;\n        /* 3 */\n        *width: 13px;\n      }\n      input[type='search'] {\n        -webkit-appearance: textfield;\n        /* 1 */\n        -moz-box-sizing: content-box;\n        -webkit-box-sizing: content-box;\n        /* 2 */\n        box-sizing: content-box;\n      }\n      input[type='search']::-webkit-search-cancel-button,\n      input[type='search']::-webkit-search-decoration {\n        -webkit-appearance: none;\n      }\n\n      /**\n * * 1. Address `appearance` set to `searchfield` in Safari 5 and Chrome.\n * * 2. Address `box-sizing` set to `border-box` in Safari 5 and Chrome\n * *    (include `-moz` to future-proof). */\n      /**\n * * Remove inner padding and search cancel button in Safari 5 and Chrome\n * * on OS X. */\n      /**\n * * Remove inner padding and border in Firefox 3+. */\n      button::-moz-focus-inner,\n      input::-moz-focus-inner {\n        border: 0;\n        padding: 0;\n      }\n\n      /**\n * * 1. Remove default vertical scrollbar in IE 6/7/8/9.\n * * 2. Improve readability and alignment in all browsers. */\n      textarea {\n        overflow: auto;\n        /* 1 */\n        vertical-align: top;\n      }\n\n      /* 2 */\n      /* ==========================================================================\n * * Tables\n * * ========================================================================== */\n      /**\n * * Remove most spacing between table cells. */\n      table {\n        border-collapse: collapse;\n        border-spacing: 0;\n      }\n\n      ul.tsd-descriptions > li > :first-child,\n      .tsd-panel > :first-child,\n      .col > :first-child,\n      .col-11 > :first-child,\n      .col-10 > :first-child,\n      .col-9 > :first-child,\n      .col-8 > :first-child,\n      .col-7 > :first-child,\n      .col-6 > :first-child,\n      .col-5 > :first-child,\n      .col-4 > :first-child,\n      .col-3 > :first-child,\n      .col-2 > :first-child,\n      .col-1 > :first-child,\n      ul.tsd-descriptions > li > :first-child > :first-child,\n      .tsd-panel > :first-child > :first-child,\n      .col > :first-child > :first-child,\n      .col-11 > :first-child > :first-child,\n      .col-10 > :first-child > :first-child,\n      .col-9 > :first-child > :first-child,\n      .col-8 > :first-child > :first-child,\n      .col-7 > :first-child > :first-child,\n      .col-6 > :first-child > :first-child,\n      .col-5 > :first-child > :first-child,\n      .col-4 > :first-child > :first-child,\n      .col-3 > :first-child > :first-child,\n      .col-2 > :first-child > :first-child,\n      .col-1 > :first-child > :first-child,\n      ul.tsd-descriptions > li > :first-child > :first-child > :first-child,\n      .tsd-panel > :first-child > :first-child > :first-child,\n      .col > :first-child > :first-child > :first-child,\n      .col-11 > :first-child > :first-child > :first-child,\n      .col-10 > :first-child > :first-child > :first-child,\n      .col-9 > :first-child > :first-child > :first-child,\n      .col-8 > :first-child > :first-child > :first-child,\n      .col-7 > :first-child > :first-child > :first-child,\n      .col-6 > :first-child > :first-child > :first-child,\n      .col-5 > :first-child > :first-child > :first-child,\n      .col-4 > :first-child > :first-child > :first-child,\n      .col-3 > :first-child > :first-child > :first-child,\n      .col-2 > :first-child > :first-child > :first-child,\n      .col-1 > :first-child > :first-child > :first-child {\n        margin-top: 0;\n      }\n      ul.tsd-descriptions > li > :last-child,\n      .tsd-panel > :last-child,\n      .col > :last-child,\n      .col-11 > :last-child,\n      .col-10 > :last-child,\n      .col-9 > :last-child,\n      .col-8 > :last-child,\n      .col-7 > :last-child,\n      .col-6 > :last-child,\n      .col-5 > :last-child,\n      .col-4 > :last-child,\n      .col-3 > :last-child,\n      .col-2 > :last-child,\n      .col-1 > :last-child,\n      ul.tsd-descriptions > li > :last-child > :last-child,\n      .tsd-panel > :last-child > :last-child,\n      .col > :last-child > :last-child,\n      .col-11 > :last-child > :last-child,\n      .col-10 > :last-child > :last-child,\n      .col-9 > :last-child > :last-child,\n      .col-8 > :last-child > :last-child,\n      .col-7 > :last-child > :last-child,\n      .col-6 > :last-child > :last-child,\n      .col-5 > :last-child > :last-child,\n      .col-4 > :last-child > :last-child,\n      .col-3 > :last-child > :last-child,\n      .col-2 > :last-child > :last-child,\n      .col-1 > :last-child > :last-child,\n      ul.tsd-descriptions > li > :last-child > :last-child > :last-child,\n      .tsd-panel > :last-child > :last-child > :last-child,\n      .col > :last-child > :last-child > :last-child,\n      .col-11 > :last-child > :last-child > :last-child,\n      .col-10 > :last-child > :last-child > :last-child,\n      .col-9 > :last-child > :last-child > :last-child,\n      .col-8 > :last-child > :last-child > :last-child,\n      .col-7 > :last-child > :last-child > :last-child,\n      .col-6 > :last-child > :last-child > :last-child,\n      .col-5 > :last-child > :last-child > :last-child,\n      .col-4 > :last-child > :last-child > :last-child,\n      .col-3 > :last-child > :last-child > :last-child,\n      .col-2 > :last-child > :last-child > :last-child,\n      .col-1 > :last-child > :last-child > :last-child {\n        margin-bottom: 0;\n      }\n\n      .container {\n        max-width: 1200px;\n        margin: 0 auto;\n        padding: 0 40px;\n      }\n      @media (max-width: 640px) {\n        .container {\n          padding: 0 20px;\n        }\n      }\n\n      .container-main {\n        padding-bottom: 200px;\n      }\n\n      .row {\n        display: flex;\n        position: relative;\n        margin: 0 -10px;\n      }\n      .row:after {\n        visibility: hidden;\n        display: block;\n        content: '';\n        clear: both;\n        height: 0;\n      }\n\n      .col,\n      .col-11,\n      .col-10,\n      .col-9,\n      .col-8,\n      .col-7,\n      .col-6,\n      .col-5,\n      .col-4,\n      .col-3,\n      .col-2,\n      .col-1 {\n        box-sizing: border-box;\n        float: left;\n        padding: 0 10px;\n      }\n\n      .col-1 {\n        width: 8.3333333333%;\n      }\n\n      .offset-1 {\n        margin-left: 8.3333333333%;\n      }\n\n      .col-2 {\n        width: 16.6666666667%;\n      }\n\n      .offset-2 {\n        margin-left: 16.6666666667%;\n      }\n\n      .col-3 {\n        width: 25%;\n      }\n\n      .offset-3 {\n        margin-left: 25%;\n      }\n\n      .col-4 {\n        width: 33.3333333333%;\n      }\n\n      .offset-4 {\n        margin-left: 33.3333333333%;\n      }\n\n      .col-5 {\n        width: 41.6666666667%;\n      }\n\n      .offset-5 {\n        margin-left: 41.6666666667%;\n      }\n\n      .col-6 {\n        width: 50%;\n      }\n\n      .offset-6 {\n        margin-left: 50%;\n      }\n\n      .col-7 {\n        width: 58.3333333333%;\n      }\n\n      .offset-7 {\n        margin-left: 58.3333333333%;\n      }\n\n      .col-8 {\n        width: 66.6666666667%;\n      }\n\n      .offset-8 {\n        margin-left: 66.6666666667%;\n      }\n\n      .col-9 {\n        width: 75%;\n      }\n\n      .offset-9 {\n        margin-left: 75%;\n      }\n\n      .col-10 {\n        width: 83.3333333333%;\n      }\n\n      .offset-10 {\n        margin-left: 83.3333333333%;\n      }\n\n      .col-11 {\n        width: 91.6666666667%;\n      }\n\n      .offset-11 {\n        margin-left: 91.6666666667%;\n      }\n\n      .tsd-kind-icon {\n        display: block;\n        position: relative;\n        padding-left: 20px;\n        text-indent: -20px;\n      }\n      .tsd-kind-icon:before {\n        content: '';\n        display: inline-block;\n        vertical-align: middle;\n        width: 17px;\n        height: 17px;\n        margin: 0 3px 2px 0;\n        background-image: url(data:image/png;base64,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);\n      }\n      @media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) {\n        .tsd-kind-icon:before {\n          background-image: url(data:image/png;base64,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);\n          background-size: 238px 204px;\n        }\n      }\n\n      .tsd-signature.tsd-kind-icon:before {\n        background-position: 0 -153px;\n      }\n\n      .tsd-kind-object-literal > .tsd-kind-icon:before {\n        background-position: 0px -17px;\n      }\n      .tsd-kind-object-literal.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -17px;\n      }\n      .tsd-kind-object-literal.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -17px;\n      }\n\n      .tsd-kind-class > .tsd-kind-icon:before {\n        background-position: 0px -34px;\n      }\n      .tsd-kind-class.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -34px;\n      }\n      .tsd-kind-class.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -34px;\n      }\n\n      .tsd-kind-class.tsd-has-type-parameter > .tsd-kind-icon:before {\n        background-position: 0px -51px;\n      }\n      .tsd-kind-class.tsd-has-type-parameter.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -17px -51px;\n      }\n      .tsd-kind-class.tsd-has-type-parameter.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -34px -51px;\n      }\n\n      .tsd-kind-interface > .tsd-kind-icon:before {\n        background-position: 0px -68px;\n      }\n      .tsd-kind-interface.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -68px;\n      }\n      .tsd-kind-interface.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -68px;\n      }\n\n      .tsd-kind-interface.tsd-has-type-parameter > .tsd-kind-icon:before {\n        background-position: 0px -85px;\n      }\n      .tsd-kind-interface.tsd-has-type-parameter.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -17px -85px;\n      }\n      .tsd-kind-interface.tsd-has-type-parameter.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -34px -85px;\n      }\n\n      .tsd-kind-namespace > .tsd-kind-icon:before {\n        background-position: 0px -102px;\n      }\n      .tsd-kind-namespace.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -102px;\n      }\n      .tsd-kind-namespace.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -102px;\n      }\n\n      .tsd-kind-module > .tsd-kind-icon:before {\n        background-position: 0px -102px;\n      }\n      .tsd-kind-module.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -102px;\n      }\n      .tsd-kind-module.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -102px;\n      }\n\n      .tsd-kind-enum > .tsd-kind-icon:before {\n        background-position: 0px -119px;\n      }\n      .tsd-kind-enum.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -119px;\n      }\n      .tsd-kind-enum.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -119px;\n      }\n\n      .tsd-kind-enum-member > .tsd-kind-icon:before {\n        background-position: 0px -136px;\n      }\n      .tsd-kind-enum-member.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -136px;\n      }\n      .tsd-kind-enum-member.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -136px;\n      }\n\n      .tsd-kind-signature > .tsd-kind-icon:before {\n        background-position: 0px -153px;\n      }\n      .tsd-kind-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -153px;\n      }\n      .tsd-kind-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -153px;\n      }\n\n      .tsd-kind-type-alias > .tsd-kind-icon:before {\n        background-position: 0px -170px;\n      }\n      .tsd-kind-type-alias.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -17px -170px;\n      }\n      .tsd-kind-type-alias.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -34px -170px;\n      }\n\n      .tsd-kind-type-alias.tsd-has-type-parameter > .tsd-kind-icon:before {\n        background-position: 0px -187px;\n      }\n      .tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -17px -187px;\n      }\n      .tsd-kind-type-alias.tsd-has-type-parameter.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -34px -187px;\n      }\n\n      .tsd-kind-variable > .tsd-kind-icon:before {\n        background-position: -136px -0px;\n      }\n      .tsd-kind-variable.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -0px;\n      }\n      .tsd-kind-variable.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -0px;\n      }\n      .tsd-kind-variable.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -0px;\n      }\n\n      .tsd-kind-property > .tsd-kind-icon:before {\n        background-position: -136px -0px;\n      }\n      .tsd-kind-property.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -0px;\n      }\n      .tsd-kind-property.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -0px;\n      }\n      .tsd-kind-property.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -0px;\n      }\n\n      .tsd-kind-get-signature > .tsd-kind-icon:before {\n        background-position: -136px -17px;\n      }\n      .tsd-kind-get-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -17px;\n      }\n      .tsd-kind-get-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -17px;\n      }\n      .tsd-kind-get-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -17px;\n      }\n\n      .tsd-kind-set-signature > .tsd-kind-icon:before {\n        background-position: -136px -34px;\n      }\n      .tsd-kind-set-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -34px;\n      }\n      .tsd-kind-set-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -34px;\n      }\n      .tsd-kind-set-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -34px;\n      }\n\n      .tsd-kind-accessor > .tsd-kind-icon:before {\n        background-position: -136px -51px;\n      }\n      .tsd-kind-accessor.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -51px;\n      }\n      .tsd-kind-accessor.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -51px;\n      }\n      .tsd-kind-accessor.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -51px;\n      }\n\n      .tsd-kind-function > .tsd-kind-icon:before {\n        background-position: -136px -68px;\n      }\n      .tsd-kind-function.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -68px;\n      }\n      .tsd-kind-function.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -68px;\n      }\n      .tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -68px;\n      }\n\n      .tsd-kind-method > .tsd-kind-icon:before {\n        background-position: -136px -68px;\n      }\n      .tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -68px;\n      }\n      .tsd-kind-method.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -68px;\n      }\n      .tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -68px;\n      }\n\n      .tsd-kind-call-signature > .tsd-kind-icon:before {\n        background-position: -136px -68px;\n      }\n      .tsd-kind-call-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -68px;\n      }\n      .tsd-kind-call-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -68px;\n      }\n      .tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -68px;\n      }\n\n      .tsd-kind-function.tsd-has-type-parameter > .tsd-kind-icon:before {\n        background-position: -136px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -153px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -85px;\n      }\n      .tsd-kind-function.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -85px;\n      }\n\n      .tsd-kind-method.tsd-has-type-parameter > .tsd-kind-icon:before {\n        background-position: -136px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -153px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -85px;\n      }\n      .tsd-kind-method.tsd-has-type-parameter.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -85px;\n      }\n\n      .tsd-kind-constructor > .tsd-kind-icon:before {\n        background-position: -136px -102px;\n      }\n      .tsd-kind-constructor.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -102px;\n      }\n      .tsd-kind-constructor.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -102px;\n      }\n      .tsd-kind-constructor.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -102px;\n      }\n\n      .tsd-kind-constructor-signature > .tsd-kind-icon:before {\n        background-position: -136px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -102px;\n      }\n      .tsd-kind-constructor-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -102px;\n      }\n\n      .tsd-kind-index-signature > .tsd-kind-icon:before {\n        background-position: -136px -119px;\n      }\n      .tsd-kind-index-signature.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -119px;\n      }\n      .tsd-kind-index-signature.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -119px;\n      }\n      .tsd-kind-index-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -119px;\n      }\n\n      .tsd-kind-event > .tsd-kind-icon:before {\n        background-position: -136px -136px;\n      }\n      .tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -136px;\n      }\n      .tsd-kind-event.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -136px;\n      }\n      .tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -136px;\n      }\n\n      .tsd-is-static > .tsd-kind-icon:before {\n        background-position: -136px -153px;\n      }\n      .tsd-is-static.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -153px;\n      }\n      .tsd-is-static.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-class > .tsd-kind-icon:before {\n        background-position: -51px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-enum > .tsd-kind-icon:before {\n        background-position: -170px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-interface > .tsd-kind-icon:before {\n        background-position: -204px -153px;\n      }\n      .tsd-is-static.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -153px;\n      }\n\n      .tsd-is-static.tsd-kind-function > .tsd-kind-icon:before {\n        background-position: -136px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -153px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -170px;\n      }\n      .tsd-is-static.tsd-kind-function.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -170px;\n      }\n\n      .tsd-is-static.tsd-kind-method > .tsd-kind-icon:before {\n        background-position: -136px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -170px;\n      }\n      .tsd-is-static.tsd-kind-method.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -170px;\n      }\n\n      .tsd-is-static.tsd-kind-call-signature > .tsd-kind-icon:before {\n        background-position: -136px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -153px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -170px;\n      }\n      .tsd-is-static.tsd-kind-call-signature.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -170px;\n      }\n\n      .tsd-is-static.tsd-kind-event > .tsd-kind-icon:before {\n        background-position: -136px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-is-protected > .tsd-kind-icon:before {\n        background-position: -153px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-is-private > .tsd-kind-icon:before {\n        background-position: -119px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-class\n        > .tsd-kind-icon:before {\n        background-position: -51px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -68px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -85px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-protected.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -102px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-class.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-enum\n        > .tsd-kind-icon:before {\n        background-position: -170px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-protected\n        > .tsd-kind-icon:before {\n        background-position: -187px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-enum.tsd-is-private\n        > .tsd-kind-icon:before {\n        background-position: -119px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-interface\n        > .tsd-kind-icon:before {\n        background-position: -204px -187px;\n      }\n      .tsd-is-static.tsd-kind-event.tsd-parent-kind-interface.tsd-is-inherited\n        > .tsd-kind-icon:before {\n        background-position: -221px -187px;\n      }\n\n      @keyframes fade-in {\n        from {\n          opacity: 0;\n        }\n        to {\n          opacity: 1;\n        }\n      }\n      @keyframes fade-out {\n        from {\n          opacity: 1;\n          visibility: visible;\n        }\n        to {\n          opacity: 0;\n        }\n      }\n      @keyframes fade-in-delayed {\n        0% {\n          opacity: 0;\n        }\n        33% {\n          opacity: 0;\n        }\n        100% {\n          opacity: 1;\n        }\n      }\n      @keyframes fade-out-delayed {\n        0% {\n          opacity: 1;\n          visibility: visible;\n        }\n        66% {\n          opacity: 0;\n        }\n        100% {\n          opacity: 0;\n        }\n      }\n      @keyframes shift-to-left {\n        from {\n          transform: translate(0, 0);\n        }\n        to {\n          transform: translate(-25%, 0);\n        }\n      }\n      @keyframes unshift-to-left {\n        from {\n          transform: translate(-25%, 0);\n        }\n        to {\n          transform: translate(0, 0);\n        }\n      }\n      @keyframes pop-in-from-right {\n        from {\n          transform: translate(100%, 0);\n        }\n        to {\n          transform: translate(0, 0);\n        }\n      }\n      @keyframes pop-out-to-right {\n        from {\n          transform: translate(0, 0);\n          visibility: visible;\n        }\n        to {\n          transform: translate(100%, 0);\n        }\n      }\n      body {\n        background: var(--color-background);\n        font-family: 'Segoe UI', sans-serif;\n        font-size: 16px;\n        color: var(--color-text);\n      }\n\n      a {\n        color: var(--color-link);\n        text-decoration: none;\n      }\n      a:hover {\n        text-decoration: underline;\n      }\n\n      code,\n      pre {\n        font-family: Menlo, Monaco, Consolas, 'Courier New', monospace;\n        padding: 0.2em;\n        margin: 0;\n        font-size: 14px;\n        background-color: var(--color-code-background);\n      }\n\n      pre {\n        padding: 10px;\n      }\n      pre code {\n        padding: 0;\n        font-size: 100%;\n        background-color: transparent;\n      }\n\n      blockquote {\n        margin: 1em 0;\n        padding-left: 1em;\n        border-left: 4px solid gray;\n      }\n\n      .tsd-typography {\n        line-height: 1.333em;\n      }\n      .tsd-typography ul {\n        list-style: square;\n        padding: 0 0 0 20px;\n        margin: 0;\n      }\n      .tsd-typography h4,\n      .tsd-typography .tsd-index-panel h3,\n      .tsd-index-panel .tsd-typography h3,\n      .tsd-typography h5,\n      .tsd-typography h6 {\n        font-size: 1em;\n        margin: 0;\n      }\n      .tsd-typography h5,\n      .tsd-typography h6 {\n        font-weight: normal;\n      }\n      .tsd-typography p,\n      .tsd-typography ul,\n      .tsd-typography ol {\n        margin: 1em 0;\n      }\n\n      @media (min-width: 901px) and (max-width: 1024px) {\n        html.default .col-content {\n          width: 72%;\n        }\n        html.default .col-menu {\n          width: 28%;\n        }\n        html.default .tsd-navigation {\n          padding-left: 10px;\n        }\n      }\n      @media (max-width: 900px) {\n        html.default .col-content {\n          float: none;\n          width: 100%;\n        }\n        html.default .col-menu {\n          position: fixed !important;\n          overflow: auto;\n          -webkit-overflow-scrolling: touch;\n          z-index: 1024;\n          top: 0 !important;\n          bottom: 0 !important;\n          left: auto !important;\n          right: 0 !important;\n          width: 100%;\n          padding: 20px 20px 0 0;\n          max-width: 450px;\n          visibility: hidden;\n          background-color: var(--color-panel);\n          transform: translate(100%, 0);\n        }\n        html.default .col-menu > *:last-child {\n          padding-bottom: 20px;\n        }\n        html.default .overlay {\n          content: '';\n          display: block;\n          position: fixed;\n          z-index: 1023;\n          top: 0;\n          left: 0;\n          right: 0;\n          bottom: 0;\n          background-color: rgba(0, 0, 0, 0.75);\n          visibility: hidden;\n        }\n        html.default.to-has-menu .overlay {\n          animation: fade-in 0.4s;\n        }\n        html.default.to-has-menu header,\n        html.default.to-has-menu footer,\n        html.default.to-has-menu .col-content {\n          animation: shift-to-left 0.4s;\n        }\n        html.default.to-has-menu .col-menu {\n          animation: pop-in-from-right 0.4s;\n        }\n        html.default.from-has-menu .overlay {\n          animation: fade-out 0.4s;\n        }\n        html.default.from-has-menu header,\n        html.default.from-has-menu footer,\n        html.default.from-has-menu .col-content {\n          animation: unshift-to-left 0.4s;\n        }\n        html.default.from-has-menu .col-menu {\n          animation: pop-out-to-right 0.4s;\n        }\n        html.default.has-menu body {\n          overflow: hidden;\n        }\n        html.default.has-menu .overlay {\n          visibility: visible;\n        }\n        html.default.has-menu header,\n        html.default.has-menu footer,\n        html.default.has-menu .col-content {\n          transform: translate(-25%, 0);\n        }\n        html.default.has-menu .col-menu {\n          visibility: visible;\n          transform: translate(0, 0);\n        }\n      }\n\n      .tsd-page-title {\n        padding: 70px 0 20px 0;\n        margin: 0 0 40px 0;\n        background: var(--color-panel);\n        box-shadow: 0 0 5px rgba(0, 0, 0, 0.35);\n      }\n      .tsd-page-title h1 {\n        margin: 0;\n      }\n\n      .tsd-breadcrumb {\n        margin: 0;\n        padding: 0;\n        color: var(--color-text-aside);\n      }\n      .tsd-breadcrumb a {\n        color: var(--color-text-aside);\n        text-decoration: none;\n      }\n      .tsd-breadcrumb a:hover {\n        text-decoration: underline;\n      }\n      .tsd-breadcrumb li {\n        display: inline;\n      }\n      .tsd-breadcrumb li:after {\n        content: ' / ';\n      }\n\n      html.minimal .container {\n        margin: 0;\n      }\n      html.minimal .container-main {\n        padding-top: 50px;\n        padding-bottom: 0;\n      }\n      html.minimal .content-wrap {\n        padding-left: 300px;\n      }\n      html.minimal .tsd-navigation {\n        position: fixed !important;\n        overflow: auto;\n        -webkit-overflow-scrolling: touch;\n        box-sizing: border-box;\n        z-index: 1;\n        left: 0;\n        top: 40px;\n        bottom: 0;\n        width: 300px;\n        padding: 20px;\n        margin: 0;\n      }\n      html.minimal .tsd-member .tsd-member {\n        margin-left: 0;\n      }\n      html.minimal .tsd-page-toolbar {\n        position: fixed;\n        z-index: 2;\n      }\n      html.minimal #tsd-filter .tsd-filter-group {\n        right: 0;\n        transform: none;\n      }\n      html.minimal footer {\n        background-color: transparent;\n      }\n      html.minimal footer .container {\n        padding: 0;\n      }\n      html.minimal .tsd-generator {\n        padding: 0;\n      }\n      @media (max-width: 900px) {\n        html.minimal .tsd-navigation {\n          display: none;\n        }\n        html.minimal .content-wrap {\n          padding-left: 0;\n        }\n      }\n\n      dl.tsd-comment-tags {\n        overflow: hidden;\n      }\n      dl.tsd-comment-tags dt {\n        float: left;\n        padding: 1px 5px;\n        margin: 0 10px 0 0;\n        border-radius: 4px;\n        border: 1px solid var(--color-comment-tag);\n        color: var(--color-comment-tag);\n        font-size: 0.8em;\n        font-weight: normal;\n      }\n      dl.tsd-comment-tags dd {\n        margin: 0 0 10px 0;\n      }\n      dl.tsd-comment-tags dd:before,\n      dl.tsd-comment-tags dd:after {\n        display: table;\n        content: ' ';\n      }\n      dl.tsd-comment-tags dd pre,\n      dl.tsd-comment-tags dd:after {\n        clear: both;\n      }\n      dl.tsd-comment-tags p {\n        margin: 0;\n      }\n\n      .tsd-panel.tsd-comment .lead {\n        font-size: 1.1em;\n        line-height: 1.333em;\n        margin-bottom: 2em;\n      }\n      .tsd-panel.tsd-comment .lead:last-child {\n        margin-bottom: 0;\n      }\n\n      .toggle-protected .tsd-is-private {\n        display: none;\n      }\n\n      .toggle-public .tsd-is-private,\n      .toggle-public .tsd-is-protected,\n      .toggle-public .tsd-is-private-protected {\n        display: none;\n      }\n\n      .toggle-inherited .tsd-is-inherited {\n        display: none;\n      }\n\n      .toggle-externals .tsd-is-external {\n        display: none;\n      }\n\n      #tsd-filter {\n        position: relative;\n        display: inline-block;\n        height: 40px;\n        vertical-align: bottom;\n      }\n      .no-filter #tsd-filter {\n        display: none;\n      }\n      #tsd-filter .tsd-filter-group {\n        display: inline-block;\n        height: 40px;\n        vertical-align: bottom;\n        white-space: nowrap;\n      }\n      #tsd-filter input {\n        display: none;\n      }\n      @media (max-width: 900px) {\n        #tsd-filter .tsd-filter-group {\n          display: block;\n          position: absolute;\n          top: 40px;\n          right: 20px;\n          height: auto;\n          background-color: var(--color-panel);\n          visibility: hidden;\n          transform: translate(50%, 0);\n          box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n        }\n        .has-options #tsd-filter .tsd-filter-group {\n          visibility: visible;\n        }\n        .to-has-options #tsd-filter .tsd-filter-group {\n          animation: fade-in 0.2s;\n        }\n        .from-has-options #tsd-filter .tsd-filter-group {\n          animation: fade-out 0.2s;\n        }\n        #tsd-filter label,\n        #tsd-filter .tsd-select {\n          display: block;\n          padding-right: 20px;\n        }\n      }\n\n      footer {\n        border-top: 1px solid var(--color-panel-divider);\n        background-color: var(--color-panel);\n      }\n      footer.with-border-bottom {\n        border-bottom: 1px solid var(--color-panel-divider);\n      }\n      footer .tsd-legend-group {\n        font-size: 0;\n      }\n      footer .tsd-legend {\n        display: inline-block;\n        width: 25%;\n        padding: 0;\n        font-size: 16px;\n        list-style: none;\n        line-height: 1.333em;\n        vertical-align: top;\n      }\n      @media (max-width: 900px) {\n        footer .tsd-legend {\n          width: 50%;\n        }\n      }\n\n      .tsd-hierarchy {\n        list-style: square;\n        padding: 0 0 0 20px;\n        margin: 0;\n      }\n      .tsd-hierarchy .target {\n        font-weight: bold;\n      }\n\n      .tsd-index-panel .tsd-index-content {\n        margin-bottom: -30px !important;\n      }\n      .tsd-index-panel .tsd-index-section {\n        margin-bottom: 30px !important;\n      }\n      .tsd-index-panel h3 {\n        margin: 0 -20px 10px -20px;\n        padding: 0 20px 10px 20px;\n        border-bottom: 1px solid var(--color-panel-divider);\n      }\n      .tsd-index-panel ul.tsd-index-list {\n        -webkit-column-count: 3;\n        -moz-column-count: 3;\n        -ms-column-count: 3;\n        -o-column-count: 3;\n        column-count: 3;\n        -webkit-column-gap: 20px;\n        -moz-column-gap: 20px;\n        -ms-column-gap: 20px;\n        -o-column-gap: 20px;\n        column-gap: 20px;\n        padding: 0;\n        list-style: none;\n        line-height: 1.333em;\n      }\n      @media (max-width: 900px) {\n        .tsd-index-panel ul.tsd-index-list {\n          -webkit-column-count: 1;\n          -moz-column-count: 1;\n          -ms-column-count: 1;\n          -o-column-count: 1;\n          column-count: 1;\n        }\n      }\n      @media (min-width: 901px) and (max-width: 1024px) {\n        .tsd-index-panel ul.tsd-index-list {\n          -webkit-column-count: 2;\n          -moz-column-count: 2;\n          -ms-column-count: 2;\n          -o-column-count: 2;\n          column-count: 2;\n        }\n      }\n      .tsd-index-panel ul.tsd-index-list li {\n        -webkit-page-break-inside: avoid;\n        -moz-page-break-inside: avoid;\n        -ms-page-break-inside: avoid;\n        -o-page-break-inside: avoid;\n        page-break-inside: avoid;\n      }\n      .tsd-index-panel a,\n      .tsd-index-panel .tsd-parent-kind-module a {\n        color: var(--color-ts);\n      }\n      .tsd-index-panel .tsd-parent-kind-interface a {\n        color: var(--color-ts-interface);\n      }\n      .tsd-index-panel .tsd-parent-kind-enum a {\n        color: var(--color-ts-enum);\n      }\n      .tsd-index-panel .tsd-parent-kind-class a {\n        color: var(--color-ts-class);\n      }\n      .tsd-index-panel .tsd-kind-module a {\n        color: var(--color-ts);\n      }\n      .tsd-index-panel .tsd-kind-interface a {\n        color: var(--color-ts-interface);\n      }\n      .tsd-index-panel .tsd-kind-enum a {\n        color: var(--color-ts-enum);\n      }\n      .tsd-index-panel .tsd-kind-class a {\n        color: var(--color-ts-class);\n      }\n      .tsd-index-panel .tsd-is-private a {\n        color: var(--color-ts-private);\n      }\n\n      .tsd-flag {\n        display: inline-block;\n        padding: 1px 5px;\n        border-radius: 4px;\n        color: var(--color-comment-tag-text);\n        background-color: var(--color-comment-tag);\n        text-indent: 0;\n        font-size: 14px;\n        font-weight: normal;\n      }\n\n      .tsd-anchor {\n        position: absolute;\n        top: -100px;\n      }\n\n      .tsd-member {\n        position: relative;\n      }\n      .tsd-member .tsd-anchor + h3 {\n        margin-top: 0;\n        margin-bottom: 0;\n        border-bottom: none;\n      }\n      .tsd-member a[data-tsd-kind] {\n        color: var(--color-ts);\n      }\n      .tsd-member a[data-tsd-kind='Interface'] {\n        color: var(--color-ts-interface);\n      }\n      .tsd-member a[data-tsd-kind='Enum'] {\n        color: var(--color-ts-enum);\n      }\n      .tsd-member a[data-tsd-kind='Class'] {\n        color: var(--color-ts-class);\n      }\n      .tsd-member a[data-tsd-kind='Private'] {\n        color: var(--color-ts-private);\n      }\n\n      .tsd-navigation {\n        margin: 0 0 0 40px;\n      }\n      .tsd-navigation a {\n        display: block;\n        padding-top: 2px;\n        padding-bottom: 2px;\n        border-left: 2px solid transparent;\n        color: var(--color-text);\n        text-decoration: none;\n        transition: border-left-color 0.1s;\n      }\n      .tsd-navigation a:hover {\n        text-decoration: underline;\n      }\n      .tsd-navigation ul {\n        margin: 0;\n        padding: 0;\n        list-style: none;\n      }\n      .tsd-navigation li {\n        padding: 0;\n      }\n\n      .tsd-navigation.primary {\n        padding-bottom: 40px;\n      }\n      .tsd-navigation.primary a {\n        display: block;\n        padding-top: 6px;\n        padding-bottom: 6px;\n      }\n      .tsd-navigation.primary ul li a {\n        padding-left: 5px;\n      }\n      .tsd-navigation.primary ul li li a {\n        padding-left: 25px;\n      }\n      .tsd-navigation.primary ul li li li a {\n        padding-left: 45px;\n      }\n      .tsd-navigation.primary ul li li li li a {\n        padding-left: 65px;\n      }\n      .tsd-navigation.primary ul li li li li li a {\n        padding-left: 85px;\n      }\n      .tsd-navigation.primary ul li li li li li li a {\n        padding-left: 105px;\n      }\n      .tsd-navigation.primary > ul {\n        border-bottom: 1px solid var(--color-panel-divider);\n      }\n      .tsd-navigation.primary li {\n        border-top: 1px solid var(--color-panel-divider);\n      }\n      .tsd-navigation.primary li.current > a {\n        font-weight: bold;\n      }\n      .tsd-navigation.primary li.label span {\n        display: block;\n        padding: 20px 0 6px 5px;\n        color: var(--color-menu-label);\n      }\n      .tsd-navigation.primary li.globals + li > span,\n      .tsd-navigation.primary li.globals + li > a {\n        padding-top: 20px;\n      }\n\n      .tsd-navigation.secondary {\n        max-height: calc(100vh - 1rem - 40px);\n        overflow: auto;\n        position: -webkit-sticky;\n        position: sticky;\n        top: calc(0.5rem + 40px);\n        transition: 0.3s;\n      }\n      .tsd-navigation.secondary.tsd-navigation--toolbar-hide {\n        max-height: calc(100vh - 1rem);\n        top: 0.5rem;\n      }\n      .tsd-navigation.secondary ul {\n        transition: opacity 0.2s;\n      }\n      .tsd-navigation.secondary ul li a {\n        padding-left: 25px;\n      }\n      .tsd-navigation.secondary ul li li a {\n        padding-left: 45px;\n      }\n      .tsd-navigation.secondary ul li li li a {\n        padding-left: 65px;\n      }\n      .tsd-navigation.secondary ul li li li li a {\n        padding-left: 85px;\n      }\n      .tsd-navigation.secondary ul li li li li li a {\n        padding-left: 105px;\n      }\n      .tsd-navigation.secondary ul li li li li li li a {\n        padding-left: 125px;\n      }\n      .tsd-navigation.secondary ul.current a {\n        border-left-color: var(--color-panel-divider);\n      }\n      .tsd-navigation.secondary li.focus > a,\n      .tsd-navigation.secondary ul.current li.focus > a {\n        border-left-color: var(--color-menu-divider-focus);\n      }\n      .tsd-navigation.secondary li.current {\n        margin-top: 20px;\n        margin-bottom: 20px;\n        border-left-color: var(--color-panel-divider);\n      }\n      .tsd-navigation.secondary li.current > a {\n        font-weight: bold;\n      }\n\n      @media (min-width: 901px) {\n        .menu-sticky-wrap {\n          position: static;\n        }\n      }\n\n      .tsd-panel {\n        margin: 20px 0;\n        padding: 20px;\n        background-color: var(--color-panel);\n        box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n      }\n      .tsd-panel:empty {\n        display: none;\n      }\n      .tsd-panel > h1,\n      .tsd-panel > h2,\n      .tsd-panel > h3 {\n        margin: 1.5em -20px 10px -20px;\n        padding: 0 20px 10px 20px;\n        border-bottom: 1px solid var(--color-panel-divider);\n      }\n      .tsd-panel > h1.tsd-before-signature,\n      .tsd-panel > h2.tsd-before-signature,\n      .tsd-panel > h3.tsd-before-signature {\n        margin-bottom: 0;\n        border-bottom: 0;\n      }\n      .tsd-panel table {\n        display: block;\n        width: 100%;\n        overflow: auto;\n        margin-top: 10px;\n        word-break: normal;\n        word-break: keep-all;\n      }\n      .tsd-panel table th {\n        font-weight: bold;\n      }\n      .tsd-panel table th,\n      .tsd-panel table td {\n        padding: 6px 13px;\n        border: 1px solid #ddd;\n      }\n      .tsd-panel table tr {\n        background-color: #fff;\n        border-top: 1px solid #ccc;\n      }\n      .tsd-panel table tr:nth-child(2n) {\n        background-color: #f8f8f8;\n      }\n\n      .tsd-panel-group {\n        margin: 60px 0;\n      }\n      .tsd-panel-group > h1,\n      .tsd-panel-group > h2,\n      .tsd-panel-group > h3 {\n        padding-left: 20px;\n        padding-right: 20px;\n      }\n\n      #tsd-search {\n        transition: background-color 0.2s;\n      }\n      #tsd-search .title {\n        position: relative;\n        z-index: 2;\n      }\n      #tsd-search .field {\n        position: absolute;\n        left: 0;\n        top: 0;\n        right: 40px;\n        height: 40px;\n      }\n      #tsd-search .field input {\n        box-sizing: border-box;\n        position: relative;\n        top: -50px;\n        z-index: 1;\n        width: 100%;\n        padding: 0 10px;\n        opacity: 0;\n        outline: 0;\n        border: 0;\n        background: transparent;\n        color: var(--color-text);\n      }\n      #tsd-search .field label {\n        position: absolute;\n        overflow: hidden;\n        right: -40px;\n      }\n      #tsd-search .field input,\n      #tsd-search .title {\n        transition: opacity 0.2s;\n      }\n      #tsd-search .results {\n        position: absolute;\n        visibility: hidden;\n        top: 40px;\n        width: 100%;\n        margin: 0;\n        padding: 0;\n        list-style: none;\n        box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n      }\n      #tsd-search .results li {\n        padding: 0 10px;\n        background-color: var(--color-background);\n      }\n      #tsd-search .results li:nth-child(even) {\n        background-color: var(--color-panel);\n      }\n      #tsd-search .results li.state {\n        display: none;\n      }\n      #tsd-search .results li.current,\n      #tsd-search .results li:hover {\n        background-color: var(--color-panel-divider);\n      }\n      #tsd-search .results a {\n        display: block;\n      }\n      #tsd-search .results a:before {\n        top: 10px;\n      }\n      #tsd-search .results span.parent {\n        color: var(--color-text-aside);\n        font-weight: normal;\n      }\n      #tsd-search.has-focus {\n        background-color: var(--color-panel-divider);\n      }\n      #tsd-search.has-focus .field input {\n        top: 0;\n        opacity: 1;\n      }\n      #tsd-search.has-focus .title {\n        z-index: 0;\n        opacity: 0;\n      }\n      #tsd-search.has-focus .results {\n        visibility: visible;\n      }\n      #tsd-search.loading .results li.state.loading {\n        display: block;\n      }\n      #tsd-search.failure .results li.state.failure {\n        display: block;\n      }\n\n      .tsd-signature {\n        margin: 0 0 1em 0;\n        padding: 10px;\n        border: 1px solid var(--color-panel-divider);\n        font-family: Menlo, Monaco, Consolas, 'Courier New', monospace;\n        font-size: 14px;\n        overflow-x: auto;\n      }\n      .tsd-signature.tsd-kind-icon {\n        padding-left: 30px;\n      }\n      .tsd-signature.tsd-kind-icon:before {\n        top: 10px;\n        left: 10px;\n      }\n      .tsd-panel > .tsd-signature {\n        margin-left: -20px;\n        margin-right: -20px;\n        border-width: 1px 0;\n      }\n      .tsd-panel > .tsd-signature.tsd-kind-icon {\n        padding-left: 40px;\n      }\n      .tsd-panel > .tsd-signature.tsd-kind-icon:before {\n        left: 20px;\n      }\n\n      .tsd-signature-symbol {\n        color: var(--color-text-aside);\n        font-weight: normal;\n      }\n\n      .tsd-signature-type {\n        font-style: italic;\n        font-weight: normal;\n      }\n\n      .tsd-signatures {\n        padding: 0;\n        margin: 0 0 1em 0;\n        border: 1px solid var(--color-panel-divider);\n      }\n      .tsd-signatures .tsd-signature {\n        margin: 0;\n        border-width: 1px 0 0 0;\n        transition: background-color 0.1s;\n      }\n      .tsd-signatures .tsd-signature:first-child {\n        border-top-width: 0;\n      }\n      .tsd-signatures .tsd-signature.current {\n        background-color: var(--color-panel-divider);\n      }\n      .tsd-signatures.active > .tsd-signature {\n        cursor: pointer;\n      }\n      .tsd-panel > .tsd-signatures {\n        margin-left: -20px;\n        margin-right: -20px;\n        border-width: 1px 0;\n      }\n      .tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon {\n        padding-left: 40px;\n      }\n      .tsd-panel > .tsd-signatures .tsd-signature.tsd-kind-icon:before {\n        left: 20px;\n      }\n      .tsd-panel > a.anchor + .tsd-signatures {\n        border-top-width: 0;\n        margin-top: -20px;\n      }\n\n      ul.tsd-descriptions {\n        position: relative;\n        overflow: hidden;\n        padding: 0;\n        list-style: none;\n      }\n      ul.tsd-descriptions.active > .tsd-description {\n        display: none;\n      }\n      ul.tsd-descriptions.active > .tsd-description.current {\n        display: block;\n      }\n      ul.tsd-descriptions.active > .tsd-description.fade-in {\n        animation: fade-in-delayed 0.3s;\n      }\n      ul.tsd-descriptions.active > .tsd-description.fade-out {\n        animation: fade-out-delayed 0.3s;\n        position: absolute;\n        display: block;\n        top: 0;\n        left: 0;\n        right: 0;\n        opacity: 0;\n        visibility: hidden;\n      }\n      ul.tsd-descriptions h4,\n      ul.tsd-descriptions .tsd-index-panel h3,\n      .tsd-index-panel ul.tsd-descriptions h3 {\n        font-size: 16px;\n        margin: 1em 0 0.5em 0;\n      }\n\n      ul.tsd-parameters,\n      ul.tsd-type-parameters {\n        list-style: square;\n        margin: 0;\n        padding-left: 20px;\n      }\n      ul.tsd-parameters > li.tsd-parameter-signature,\n      ul.tsd-type-parameters > li.tsd-parameter-signature {\n        list-style: none;\n        margin-left: -20px;\n      }\n      ul.tsd-parameters h5,\n      ul.tsd-type-parameters h5 {\n        font-size: 16px;\n        margin: 1em 0 0.5em 0;\n      }\n      ul.tsd-parameters .tsd-comment,\n      ul.tsd-type-parameters .tsd-comment {\n        margin-top: -0.5em;\n      }\n\n      .tsd-sources {\n        font-size: 14px;\n        color: var(--color-text-aside);\n        margin: 0 0 1em 0;\n      }\n      .tsd-sources a {\n        color: var(--color-text-aside);\n        text-decoration: underline;\n      }\n      .tsd-sources ul,\n      .tsd-sources p {\n        margin: 0 !important;\n      }\n      .tsd-sources ul {\n        list-style: none;\n        padding: 0;\n      }\n\n      .tsd-page-toolbar {\n        position: fixed;\n        z-index: 1;\n        top: 0;\n        left: 0;\n        width: 100%;\n        height: 40px;\n        color: var(--color-toolbar-text);\n        background: var(--color-toolbar);\n        border-bottom: 1px solid var(--color-panel-divider);\n        transition: transform 0.3s linear;\n      }\n      .tsd-page-toolbar a {\n        color: var(--color-toolbar-text);\n        text-decoration: none;\n      }\n      .tsd-page-toolbar a.title {\n        font-weight: bold;\n      }\n      .tsd-page-toolbar a.title:hover {\n        text-decoration: underline;\n      }\n      .tsd-page-toolbar .table-wrap {\n        display: table;\n        width: 100%;\n        height: 40px;\n      }\n      .tsd-page-toolbar .table-cell {\n        display: table-cell;\n        position: relative;\n        white-space: nowrap;\n        line-height: 40px;\n      }\n      .tsd-page-toolbar .table-cell:first-child {\n        width: 100%;\n      }\n\n      .tsd-page-toolbar--hide {\n        transform: translateY(-100%);\n      }\n\n      .tsd-select .tsd-select-list li:before,\n      .tsd-select .tsd-select-label:before,\n      .tsd-widget:before {\n        content: '';\n        display: inline-block;\n        width: 40px;\n        height: 40px;\n        margin: 0 -8px 0 0;\n        background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAUAAAAAoCAQAAAAlSeuiAAABp0lEQVR4Ae3aUa3jQAyF4QNhIBTCQiiEQlgIhRAGhTAQBkIgBEIgDITZZGXNjZTePiSWYqn/54dGfbAq+SiTutWXAgAAAAAAAAAAAAA8NCz1UFSD2lKDS5d3NVzZj/BVNasaLoRZRUmj2lLrVVHWMUntQ13Wj/i1pWa9lprX6xMRnH4dx6Rjsn26+v+12ms+EcB37P0r+qH+DNQGXgMFcHzbregQ78B8eQCTJk0e979ZW7PdA2O49ceDsYexKgUNoI3EKYDWL3D8miaPh/uXtl6BHqEHFQvgXau/FsCiIWAAbST2fpQRT0sl70j3z5ZiBdD7CG5WZX8kxwmgjbiP5GQA9/3O2XaxnnHi53AEE0AbRh+JQwC3/fzC4hcb6xPvS4i3QaMdwX+0utsRPEY6gm2wNhKHAG77eUi7SIcK4G4NY4GMIan2u2Cxqzncl5DUn7Q8ArjvZ8JFOsl/Ed0jyBom+BomQKSto+9PcblHMM4iuu4X0QQw5hrGQY/gUxFkjZuf4m4alXVU+1De/VhEn5CvDSB/RsBzqWgAAAAAAAAAAAAAAACAfyyYJ5nhVuwIAAAAAElFTkSuQmCC);\n        background-repeat: no-repeat;\n        text-indent: -1024px;\n        vertical-align: bottom;\n      }\n      @media (-webkit-min-device-pixel-ratio: 1.5), (min-resolution: 144dpi) {\n        .tsd-select .tsd-select-list li:before,\n        .tsd-select .tsd-select-label:before,\n        .tsd-widget:before {\n          background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAoAAAABQCAMAAAC+sjQXAAAAM1BMVEUAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACjBUbJAAAAEXRSTlMA3/+/UCBw7xCPYIBAMM+vn1qYQ7QAAALCSURBVHgB7MGBAAAAAICg/akXqQIAAAAAAAAAAAAAAAAAAJids9mdE4bhoDNZCITP93/aSmhV/9uwPWyi8jtkblws2IxsYpz9LwSAaJW8AreE16PxOsMYE6Q4DiYKF7X+8ZHXc/E608xv5snEyIuZrVwMZjbnujR6T3gsXmcLOIRNzD+Ig2UuVtt2+NbAiX/wVLzOlviD9L2BOfGBlL/3D1I+uDjGBJArBPxU3x+K15kCQFo2s21JAOHrKpz4SPrWv4IKA+uFaR6vMwMcb+emA2DWEfDglrkLqEBOKVslA8Dx14oPMiV4CtywWxdQgAwkq2QE0uTXUwJGk2G9s3mTFNBzAkC7HKPsX72AEVjMnAWIpsPCRRjXdQxcjCYpoOcEgHY5Rtk/slWSgM3M2aSeeVgjAOeVpKcdgGMdNAXMuIAqOcZzqF8L+WcAsi8wkTeheCWMegL6mgCorHHyEJ5TVfxrLWDrTUjZdhnhjYqAnlN8TaoELOLVC0gucmoz/3RKcPs2jAs4+J5ET8AEZF+TSgGLeC1V8YuGQQU2IV1Asq9JCwE9XitZVPxr34bpJRj8PqsFLOK108W9aVrWZRrR7Sm2HL4JCToCujHZ6gUs4jUz0P1TEvD+U5wMa363YeziBODIq1YbJrsv9QKW8Ry1nNp+GAHvuingRTfmYcjBf0QpAS37bdUL6PFKtHJq63EsZ5cxcKMkDVIClu1dAK1PcJ5TFQ0M9wZKDCPs3BD7MIJGTs3WfiTfDVQYx5q5ZekCauTU3P5Q0ukGCgh49oFURdobWBY9N/CxEuwGjpGLuPhTdwH1x7HqDDxNgRP2zQ8lraFyF/yJ9vH6QGqtgSbBOU8/j2VORz+Wqfle2d5Ae4R+ML0z7Y+W4P7XHN3AU+tzyK/24EAGAAAAYJC/9T2+CgAAAAAAAAAAAAAAAAAAAADgJpfzHyIKFFBKAAAAAElFTkSuQmCC);\n          background-size: 320px 40px;\n        }\n      }\n\n      .tsd-widget {\n        display: inline-block;\n        overflow: hidden;\n        opacity: 0.6;\n        height: 40px;\n        transition: opacity 0.1s, background-color 0.2s;\n        vertical-align: bottom;\n        cursor: pointer;\n      }\n      .tsd-widget:hover {\n        opacity: 0.8;\n      }\n      .tsd-widget.active {\n        opacity: 1;\n        background-color: var(--color-panel-divider);\n      }\n      .tsd-widget.no-caption {\n        width: 40px;\n      }\n      .tsd-widget.no-caption:before {\n        margin: 0;\n      }\n      .tsd-widget.search:before {\n        background-position: 0 0;\n      }\n      .tsd-widget.menu:before {\n        background-position: -40px 0;\n      }\n      .tsd-widget.options:before {\n        background-position: -80px 0;\n      }\n      .tsd-widget.options,\n      .tsd-widget.menu {\n        display: none;\n      }\n      @media (max-width: 900px) {\n        .tsd-widget.options,\n        .tsd-widget.menu {\n          display: inline-block;\n        }\n      }\n      input[type='checkbox'] + .tsd-widget:before {\n        background-position: -120px 0;\n      }\n      input[type='checkbox']:checked + .tsd-widget:before {\n        background-position: -160px 0;\n      }\n\n      .tsd-select {\n        position: relative;\n        display: inline-block;\n        height: 40px;\n        transition: opacity 0.1s, background-color 0.2s;\n        vertical-align: bottom;\n        cursor: pointer;\n      }\n      .tsd-select .tsd-select-label {\n        opacity: 0.6;\n        transition: opacity 0.2s;\n      }\n      .tsd-select .tsd-select-label:before {\n        background-position: -240px 0;\n      }\n      .tsd-select.active .tsd-select-label {\n        opacity: 0.8;\n      }\n      .tsd-select.active .tsd-select-list {\n        visibility: visible;\n        opacity: 1;\n        transition-delay: 0s;\n      }\n      .tsd-select .tsd-select-list {\n        position: absolute;\n        visibility: hidden;\n        top: 40px;\n        left: 0;\n        margin: 0;\n        padding: 0;\n        opacity: 0;\n        list-style: none;\n        box-shadow: 0 0 4px rgba(0, 0, 0, 0.25);\n        transition: visibility 0s 0.2s, opacity 0.2s;\n      }\n      .tsd-select .tsd-select-list li {\n        padding: 0 20px 0 0;\n        background-color: var(--color-background);\n      }\n      .tsd-select .tsd-select-list li:before {\n        background-position: 40px 0;\n      }\n      .tsd-select .tsd-select-list li:nth-child(even) {\n        background-color: var(--color-panel);\n      }\n      .tsd-select .tsd-select-list li:hover {\n        background-color: var(--color-panel-divider);\n      }\n      .tsd-select .tsd-select-list li.selected:before {\n        background-position: -200px 0;\n      }\n      @media (max-width: 900px) {\n        .tsd-select .tsd-select-list {\n          top: 0;\n          left: auto;\n          right: 100%;\n          margin-right: -5px;\n        }\n        .tsd-select .tsd-select-label:before {\n          background-position: -280px 0;\n        }\n      }\n\n      img {\n        max-width: 100%;\n      }\n    </style>\n  </head>\n  <body>\n    <header>\n      <div class=\"tsd-page-toolbar\">\n        <div class=\"container\">\n          <div class=\"table-wrap\">\n            <div class=\"table-cell\">\n              <strong><a href=\"index.html\">react-charts</a></strong>\n            </div>\n            <div class=\"table-cell\" id=\"tsd-widgets\">\n              <div id=\"tsd-filter\">\n                <a\n                  href=\"#\"\n                  class=\"tsd-widget options no-caption\"\n                  data-toggle=\"options\"\n                  >Options</a\n                >\n                <div class=\"tsd-filter-group\">\n                  <div class=\"tsd-select\" id=\"tsd-filter-visibility\">\n                    <span class=\"tsd-select-label\">All</span>\n                    <ul class=\"tsd-select-list\">\n                      <li data-value=\"public\">Public</li>\n                      <li data-value=\"protected\">Public/Protected</li>\n                      <li data-value=\"private\" class=\"selected\">All</li>\n                    </ul>\n                  </div>\n                  <input type=\"checkbox\" id=\"tsd-filter-inherited\" checked />\n                  <label class=\"tsd-widget\" for=\"tsd-filter-inherited\"\n                    >Inherited</label\n                  >\n                  <input type=\"checkbox\" id=\"tsd-filter-externals\" checked />\n                  <label class=\"tsd-widget\" for=\"tsd-filter-externals\"\n                    >Externals</label\n                  >\n                  <input type=\"checkbox\" id=\"tsd-filter-only-exported\" />\n                  <label class=\"tsd-widget\" for=\"tsd-filter-only-exported\"\n                    >Only exported</label\n                  >\n                </div>\n              </div>\n              <a href=\"#typedoc-main-index\" class=\"tsd-widget menu no-caption\"\n                >Menu</a\n              >\n            </div>\n          </div>\n        </div>\n      </div>\n    </header>\n    <nav class=\"tsd-navigation secondary\">\n      <ul>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#alignmode\" class=\"tsd-kind-icon\"\n            >Align<wbr />Mode</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#alignposition\" class=\"tsd-kind-icon\"\n            >Align<wbr />Position</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#anchormode\" class=\"tsd-kind-icon\"\n            >Anchor<wbr />Mode</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#axesinfo\" class=\"tsd-kind-icon\"\n            >Axes<wbr />Info</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axis\" class=\"tsd-kind-icon\">Axis</a>\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axisband\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Band</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axisbandoptions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Band<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axisbase\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Base</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#axisdimension\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Dimension</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#axisdimensions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Dimensions</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axislinear\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Linear</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axislinearoptions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Linear<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axisoptions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#axisoptionsbase\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Options<wbr />Base</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axisordinaloptions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Ordinal<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axistime\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Time</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#axistimeoptions\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Time<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#axistype\" class=\"tsd-kind-icon\"\n            >Axis<wbr />Type</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#chartcontextvalue\" class=\"tsd-kind-icon\"\n            >Chart<wbr />Context<wbr />Value</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#chartoffset\" class=\"tsd-kind-icon\"\n            >Chart<wbr />Offset</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#chartoptions\" class=\"tsd-kind-icon\"\n            >Chart<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#chartvalue\" class=\"tsd-kind-icon\"\n            >Chart<wbr />Value</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#cursoroptions\" class=\"tsd-kind-icon\"\n            >Cursor<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#datum\" class=\"tsd-kind-icon\">Datum</a>\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#datumfocusstatus\" class=\"tsd-kind-icon\"\n            >Datum<wbr />Focus<wbr />Status</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#datumstyles\" class=\"tsd-kind-icon\"\n            >Datum<wbr />Styles</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#griddimensions\" class=\"tsd-kind-icon\"\n            >Grid<wbr />Dimensions</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#groupingmode\" class=\"tsd-kind-icon\"\n            >Grouping<wbr />Mode</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#measurement\" class=\"tsd-kind-icon\"\n            >Measurement</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#pointer\" class=\"tsd-kind-icon\">Pointer</a>\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#pointerpressed\" class=\"tsd-kind-icon\"\n            >Pointer<wbr />Pressed</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#pointerunpressed\" class=\"tsd-kind-icon\"\n            >Pointer<wbr />Unpressed</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#position\" class=\"tsd-kind-icon\">Position</a>\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#requiredchartoptions\" class=\"tsd-kind-icon\"\n            >Required<wbr />Chart<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#resolvedaxisoptions\" class=\"tsd-kind-icon\"\n            >Resolved<wbr />Axis<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#resolvedtooltipoptions\" class=\"tsd-kind-icon\"\n            >Resolved<wbr />Tooltip<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#series\" class=\"tsd-kind-icon\">Series</a>\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#seriesfocusstatus\" class=\"tsd-kind-icon\"\n            >Series<wbr />Focus<wbr />Status</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#seriesstyles\" class=\"tsd-kind-icon\"\n            >Series<wbr />Styles</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias\">\n          <a href=\"modules.html#side\" class=\"tsd-kind-icon\">Side</a>\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#stackdatum\" class=\"tsd-kind-icon\"\n            >Stack<wbr />Datum</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#tooltipoptions\" class=\"tsd-kind-icon\"\n            >Tooltip<wbr />Options</a\n          >\n        </li>\n        <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n          <a href=\"modules.html#userserie\" class=\"tsd-kind-icon\"\n            >User<wbr />Serie</a\n          >\n        </li>\n        <li class=\"tsd-kind-function tsd-has-type-parameter\">\n          <a href=\"modules.html#chart\" class=\"tsd-kind-icon\">Chart</a>\n        </li>\n      </ul>\n    </nav>\n    <div class=\"container container-main\">\n      <div class=\"content-wrap\">\n        <div class=\"tsd-panel tsd-typography\">\n          <p>\n            <img\n              src=\"https://github.com/tannerlinsley/react-charts/raw/next/media/repo-dark.png\"\n              alt=\"React Charts Header\"\n            />\n          </p>\n          <p>Simple, immersive and interactive charts for React</p>\n          <a\n            href=\"https://twitter.com/intent/tweet?button_hashtag=TanStack\"\n            target=\"\\_parent\"\n          >\n            <img\n              alt=\"#TanStack\"\n              src=\"https://img.shields.io/twitter/url?color=%2308a0e9&label=%23TanStack&style=social&url=https%3A%2F%2Ftwitter.com%2Fintent%2Ftweet%3Fbutton_hashtag%3DTanStack\"\n            />\n          </a>\n          <a href=\"https://npmjs.com/package/react-charts\" target=\"\\_parent\">\n            <img alt=\"\" src=\"https://img.shields.io/npm/dm/react-charts.svg\" />\n          </a>\n          <a\n            href=\"https://bundlephobia.com/result?p=react-charts\"\n            target=\"\\_parent\"\n          >\n            <img\n              alt=\"\"\n              src=\"https://badgen.net/bundlephobia/minzip/react-charts\"\n            />\n          </a>\n          <a href=\"https://spectrum.chat/react-charts\">\n            <img\n              alt=\"Join the community on Spectrum\"\n              src=\"https://withspectrum.github.io/badge/badge.svg\"\n            />\n          </a>\n          <a\n            href=\"https://github.com/react-charts/react-charts\"\n            target=\"\\_parent\"\n          >\n            <img\n              alt=\"\"\n              src=\"https://img.shields.io/github/stars/react-charts/react-charts.svg?style=social&label=Star\"\n            />\n          </a>\n          <a href=\"https://twitter.com/tannerlinsley\" target=\"\\_parent\">\n            <img\n              alt=\"\"\n              src=\"https://img.shields.io/twitter/follow/tannerlinsley.svg?style=social&label=Follow\"\n            />\n          </a>\n          <br />\n          <br />\n          <p>\n            Enjoy this library? Try the entire\n            <a href=\"https://tanstack.com\">TanStack</a>!\n            <a href=\"https://github.com/tannerlinsley/react-table\"\n              >React Table</a\n            >,\n            <a href=\"https://github.com/tannerlinsley/react-query\"\n              >React Query</a\n            >,\n            <a href=\"https://github.com/tannerlinsley/react-form\">React Form</a>\n          </p>\n          <a\n            href=\"#visit-react-chartstanstackcom-for-docs-guides-api-and-more\"\n            id=\"visit-react-chartstanstackcom-for-docs-guides-api-and-more\"\n            style=\"color: inherit; text-decoration: none\"\n          >\n            <h2>\n              Visit\n              <a href=\"https://react-charts.tanstack.com\"\n                >react-charts.tanstack.com</a\n              >\n              for docs, guides, API and more!\n            </h2>\n          </a>\n          <a\n            href=\"#quick-features\"\n            id=\"quick-features\"\n            style=\"color: inherit; text-decoration: none\"\n          >\n            <h2>Quick Features</h2>\n          </a>\n          <ul>\n            <li>Line Charts</li>\n            <li>Bar Charts</li>\n            <li>Column Charts</li>\n            <li>Bubble Charts</li>\n            <li>Area Charts</li>\n            <li>Axis Stacking</li>\n            <li>Inverted Axes</li>\n            <li>Hyper Responsive</li>\n            <li>Invisibly Powered by D3</li>\n            <li>Declarative</li>\n            <li>Mutliple Axes</li>\n          </ul>\n          <a\n            href=\"#become-a-sponsor\"\n            id=\"become-a-sponsor\"\n            style=\"color: inherit; text-decoration: none\"\n          >\n            <h3>\n              <a href=\"https://github.com/sponsors/tannerlinsley/\"\n                >Become a Sponsor!</a\n              >\n            </h3>\n          </a>\n          <a\n            href=\"#contributors-✨\"\n            id=\"contributors-✨\"\n            style=\"color: inherit; text-decoration: none\"\n          >\n            <h1>Contributors ✨</h1>\n          </a>\n          <p>\n            Thanks goes to these wonderful people (<a\n              href=\"https://allcontributors.org/docs/en/emoji-key\"\n              >emoji key</a\n            >):\n          </p>\n          <!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->\n          <!-- prettier-ignore-start -->\n          <!-- markdownlint-disable -->\n          <table>\n            <tr>\n              <td align=\"center\">\n                <a href=\"https://tannerlinsley.com\"\n                  ><img\n                    src=\"https://avatars0.githubusercontent.com/u/5580297?v=4\"\n                    width=\"100px;\"\n                    alt=\"\"\n                  /><br /><sub><b>Tanner Linsley</b></sub></a\n                ><br /><a\n                  href=\"https://github.com/tannerlinsley/react-charts/commits?author=tannerlinsley\"\n                  title=\"Code\"\n                  >💻</a\n                >\n                <a\n                  href=\"#ideas-tannerlinsley\"\n                  title=\"Ideas, Planning, & Feedback\"\n                  >🤔</a\n                >\n                <a href=\"#example-tannerlinsley\" title=\"Examples\">💡</a>\n                <a href=\"#maintenance-tannerlinsley\" title=\"Maintenance\">🚧</a>\n                <a\n                  href=\"https://github.com/tannerlinsley/react-charts/pulls?q=is%3Apr+reviewed-by%3Atannerlinsley\"\n                  title=\"Reviewed Pull Requests\"\n                  >👀</a\n                >\n              </td>\n            </tr>\n          </table>\n          <!-- markdownlint-enable -->\n          <!-- prettier-ignore-end -->\n          <!-- ALL-CONTRIBUTORS-LIST:END -->\n          <p>\n            This project follows the\n            <a href=\"https://github.com/all-contributors/all-contributors\"\n              >all-contributors</a\n            >\n            specification. Contributions of any kind welcome!\n          </p>\n          <!-- Force 1 -->\n        </div>\n        <section class=\"tsd-panel-group tsd-index-group\">\n          <h2>Index</h2>\n          <section class=\"tsd-panel tsd-index-panel\">\n            <div class=\"tsd-index-content\">\n              <section class=\"tsd-index-section\">\n                <h3>Type aliases</h3>\n                <ul class=\"tsd-index-list\">\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#alignmode\" class=\"tsd-kind-icon\"\n                      >Align<wbr />Mode</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#alignposition\" class=\"tsd-kind-icon\"\n                      >Align<wbr />Position</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#anchormode\" class=\"tsd-kind-icon\"\n                      >Anchor<wbr />Mode</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#axesinfo\" class=\"tsd-kind-icon\"\n                      >Axes<wbr />Info</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axis\" class=\"tsd-kind-icon\">Axis</a>\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axisband\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Band</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axisbandoptions\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Band<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axisbase\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Base</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#axisdimension\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Dimension</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#axisdimensions\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Dimensions</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axislinear\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Linear</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#axislinearoptions\"\n                      class=\"tsd-kind-icon\"\n                      >Axis<wbr />Linear<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axisoptions\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#axisoptionsbase\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Options<wbr />Base</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#axisordinaloptions\"\n                      class=\"tsd-kind-icon\"\n                      >Axis<wbr />Ordinal<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axistime\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Time</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#axistimeoptions\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Time<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#axistype\" class=\"tsd-kind-icon\"\n                      >Axis<wbr />Type</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#chartcontextvalue\"\n                      class=\"tsd-kind-icon\"\n                      >Chart<wbr />Context<wbr />Value</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#chartoffset\" class=\"tsd-kind-icon\"\n                      >Chart<wbr />Offset</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#chartoptions\" class=\"tsd-kind-icon\"\n                      >Chart<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#chartvalue\" class=\"tsd-kind-icon\"\n                      >Chart<wbr />Value</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#cursoroptions\" class=\"tsd-kind-icon\"\n                      >Cursor<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#datum\" class=\"tsd-kind-icon\">Datum</a>\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a\n                      href=\"modules.html#datumfocusstatus\"\n                      class=\"tsd-kind-icon\"\n                      >Datum<wbr />Focus<wbr />Status</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#datumstyles\" class=\"tsd-kind-icon\"\n                      >Datum<wbr />Styles</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#griddimensions\" class=\"tsd-kind-icon\"\n                      >Grid<wbr />Dimensions</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#groupingmode\" class=\"tsd-kind-icon\"\n                      >Grouping<wbr />Mode</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#measurement\" class=\"tsd-kind-icon\"\n                      >Measurement</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#pointer\" class=\"tsd-kind-icon\"\n                      >Pointer</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#pointerpressed\" class=\"tsd-kind-icon\"\n                      >Pointer<wbr />Pressed</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a\n                      href=\"modules.html#pointerunpressed\"\n                      class=\"tsd-kind-icon\"\n                      >Pointer<wbr />Unpressed</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#position\" class=\"tsd-kind-icon\"\n                      >Position</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#requiredchartoptions\"\n                      class=\"tsd-kind-icon\"\n                      >Required<wbr />Chart<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#resolvedaxisoptions\"\n                      class=\"tsd-kind-icon\"\n                      >Resolved<wbr />Axis<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a\n                      href=\"modules.html#resolvedtooltipoptions\"\n                      class=\"tsd-kind-icon\"\n                      >Resolved<wbr />Tooltip<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#series\" class=\"tsd-kind-icon\"\n                      >Series</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a\n                      href=\"modules.html#seriesfocusstatus\"\n                      class=\"tsd-kind-icon\"\n                      >Series<wbr />Focus<wbr />Status</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#seriesstyles\" class=\"tsd-kind-icon\"\n                      >Series<wbr />Styles</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias\">\n                    <a href=\"modules.html#side\" class=\"tsd-kind-icon\">Side</a>\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#stackdatum\" class=\"tsd-kind-icon\"\n                      >Stack<wbr />Datum</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#tooltipoptions\" class=\"tsd-kind-icon\"\n                      >Tooltip<wbr />Options</a\n                    >\n                  </li>\n                  <li class=\"tsd-kind-type-alias tsd-has-type-parameter\">\n                    <a href=\"modules.html#userserie\" class=\"tsd-kind-icon\"\n                      >User<wbr />Serie</a\n                    >\n                  </li>\n                </ul>\n              </section>\n              <section class=\"tsd-index-section\">\n                <h3>Functions</h3>\n                <ul class=\"tsd-index-list\">\n                  <li class=\"tsd-kind-function tsd-has-type-parameter\">\n                    <a href=\"modules.html#chart\" class=\"tsd-kind-icon\">Chart</a>\n                  </li>\n                </ul>\n              </section>\n            </div>\n          </section>\n        </section>\n        <section class=\"tsd-panel-group tsd-member-group\">\n          <h2>Type aliases</h2>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"alignmode\" class=\"tsd-anchor\"></a>\n            <h3>Align<wbr />Mode</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Align<wbr />Mode<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;auto&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;right&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;topRight&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottomRight&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;left&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;topLeft&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottomLeft&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;top&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottom&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;center&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L132\"\n                    >types.ts:132</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"alignposition\" class=\"tsd-anchor\"></a>\n            <h3>Align<wbr />Position</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Align<wbr />Position<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;right&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;topRight&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottomRight&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;left&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;topLeft&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottomLeft&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;top&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottom&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L144\"\n                    >types.ts:144</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"anchormode\" class=\"tsd-anchor\"></a>\n            <h3>Anchor<wbr />Mode</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Anchor<wbr />Mode<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;pointer&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;closest&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;center&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;top&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottom&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;left&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;right&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;gridTop&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;gridBottom&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;gridLeft&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;gridRight&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;gridCenter&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L156\"\n                    >types.ts:156</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"axesinfo\" class=\"tsd-anchor\"></a>\n            <h3>Axes<wbr />Info</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axes<wbr />Info<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>xKey<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;primary&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;secondary&quot;</span\n              ><span class=\"tsd-signature-symbol\">; </span>yKey<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;primary&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;secondary&quot;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L415\"\n                    >types.ts:415</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    x<wbr />Key<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">&quot;primary&quot;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\"\n                      >&quot;secondary&quot;</span\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    y<wbr />Key<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">&quot;primary&quot;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\"\n                      >&quot;secondary&quot;</span\n                    >\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axis\" class=\"tsd-anchor\"></a>\n            <h3>Axis</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis&lt;TDatum&gt;<span class=\"tsd-signature-symbol\">:</span>\n              <a\n                href=\"modules.html#axistime\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisTime</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#axislinear\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisLinear</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#axisband\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBand</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L358\"\n                    >types.ts:358</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axisband\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Band</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Band&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">Omit</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axisbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBase</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><a\n                href=\"modules.html#resolvedaxisoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ResolvedAxisOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axisbandoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBandOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">&quot;format&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>axisFamily<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;band&quot;</span\n              ><span class=\"tsd-signature-symbol\">; </span>format<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span>value<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#chartvalue\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartValue</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>outerScale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleBand</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>scale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleBand</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L348\"\n                    >types.ts:348</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axisbandoptions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Band<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Band<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <a\n                href=\"modules.html#axisoptionsbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptionsBase</a\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>getValue<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#chartvalue\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartValue</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>minBandSize<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>scaleType<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;band&quot;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L261\"\n                    >types.ts:261</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axisbase\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Base</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Base&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>_<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">; </span>isVertical<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>range<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">[</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">]</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L302\"\n                    >types.ts:302</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    _<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">TDatum</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    is<wbr />Vertical<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    range<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-symbol\">[</span\n                    ><span class=\"tsd-signature-type\">number</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><span class=\"tsd-signature-type\">number</span\n                    ><span class=\"tsd-signature-symbol\">]</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"axisdimension\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Dimension</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Dimension<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>bottom<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>height<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>left<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>right<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>top<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>width<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L197\"\n                    >types.ts:197</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    bottom<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    height<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    left<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    right<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    top<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    width<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"axisdimensions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Dimensions</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Dimensions<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>bottom<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">Record</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><a\n                href=\"modules.html#axisdimension\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimension</a\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>left<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">Record</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><a\n                href=\"modules.html#axisdimension\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimension</a\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>right<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">Record</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><a\n                href=\"modules.html#axisdimension\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimension</a\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>top<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">Record</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><a\n                href=\"modules.html#axisdimension\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimension</a\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L206\"\n                    >types.ts:206</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    bottom<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">Record</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">string</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><a\n                      href=\"modules.html#axisdimension\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimension</a\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    left<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">Record</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">string</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><a\n                      href=\"modules.html#axisdimension\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimension</a\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    right<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">Record</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">string</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><a\n                      href=\"modules.html#axisdimension\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimension</a\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    top<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">Record</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">string</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><a\n                      href=\"modules.html#axisdimension\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimension</a\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axislinear\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Linear</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Linear&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">Omit</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axisbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBase</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><a\n                href=\"modules.html#resolvedaxisoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ResolvedAxisOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axislinearoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisLinearOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">&quot;format&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>axisFamily<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;linear&quot;</span\n              ><span class=\"tsd-signature-symbol\">; </span>bandScale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleBand</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>format<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ReturnType</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">ScaleLinear</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[</span\n              ><span class=\"tsd-signature-type\">&quot;tickFormat&quot;</span\n              ><span class=\"tsd-signature-symbol\">]</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>outerScale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleLinear</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>scale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleLinear</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L337\"\n                    >types.ts:337</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axislinearoptions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Linear<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Linear<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <a\n                href=\"modules.html#axisoptionsbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptionsBase</a\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>base<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>getValue<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#chartvalue\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartValue</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>hardMax<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>hardMin<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>max<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>min<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>scaleType<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;linear&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;log&quot;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L267\"\n                    >types.ts:267</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axisoptions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Options&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <a\n                href=\"modules.html#axistimeoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisTimeOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#axisordinaloptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOrdinalOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#axisbandoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBandOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#axislinearoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisLinearOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L277\"\n                    >types.ts:277</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"axisoptionsbase\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Options<wbr />Base</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Options<wbr />Base<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>curve<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CurveFactory</span\n              ><span class=\"tsd-signature-symbol\">; </span>elementType<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">&quot;line&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;area&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bar&quot;</span\n              ><span class=\"tsd-signature-symbol\">; </span>id<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>innerBandPadding<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>invert<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>isPrimary<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >minTickPaddingForRotation<span class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>outerBandPadding<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>position<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#position\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Position</a\n              ><span class=\"tsd-signature-symbol\">; </span>primaryAxisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>show<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >showDatumElements<span class=\"tsd-signature-symbol\">?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>showGrid<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >showOrphanDatumElements<span class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>stackOffset<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">typeof </span\n              ><span class=\"tsd-signature-type\">stackOffsetNone</span\n              ><span class=\"tsd-signature-symbol\">; </span>stacked<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>styles<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>line<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>tick<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >tickLabelRotationDeg<span class=\"tsd-signature-symbol\">?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L213\"\n                    >types.ts:213</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    curve<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">CurveFactory</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    element<wbr />Type<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">&quot;line&quot;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">&quot;area&quot;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">&quot;bar&quot;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    id<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    inner<wbr />Band<wbr />Padding<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    invert<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    is<wbr />Primary<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    min<wbr />Tick<wbr />Padding<wbr />For<wbr />Rotation<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    outer<wbr />Band<wbr />Padding<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    position<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#position\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Position</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    primary<wbr />Axis<wbr />Id<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Datum<wbr />Elements<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Grid<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Orphan<wbr />Datum<wbr />Elements<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    stack<wbr />Offset<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">typeof </span\n                    ><span class=\"tsd-signature-type\">stackOffsetNone</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    stacked<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    styles<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span\n                    ><span class=\"tsd-signature-symbol\"> &amp; </span\n                    ><span class=\"tsd-signature-symbol\">{ </span>line<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span\n                    ><span class=\"tsd-signature-symbol\">; </span>tick<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span\n                    ><span class=\"tsd-signature-symbol\"> }</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    tick<wbr />Label<wbr />Rotation<wbr />Deg<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axisordinaloptions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Ordinal<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Ordinal<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <a\n                href=\"modules.html#axisoptionsbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptionsBase</a\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>getValue<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#chartvalue\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartValue</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>scaleType<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;ordinal&quot;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L256\"\n                    >types.ts:256</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axistime\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Time</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Time&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">Omit</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axisbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisBase</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><a\n                href=\"modules.html#resolvedaxisoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ResolvedAxisOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axistimeoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisTimeOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">&quot;format&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>axisFamily<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;time&quot;</span\n              ><span class=\"tsd-signature-symbol\">; </span>bandScale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleBand</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>format<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ReturnType</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">ScaleTime</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[</span\n              ><span class=\"tsd-signature-type\">&quot;tickFormat&quot;</span\n              ><span class=\"tsd-signature-symbol\">]</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>outerScale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleTime</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>scale<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ScaleTime</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">never</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L326\"\n                    >types.ts:326</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"axistimeoptions\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Time<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Time<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <a\n                href=\"modules.html#axisoptionsbase\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptionsBase</a\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>base<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>getValue<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#chartvalue\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartValue</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">Date</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>hardMax<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>hardMin<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>max<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>min<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>scaleType<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">&quot;time&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;localTime&quot;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L246\"\n                    >types.ts:246</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"axistype\" class=\"tsd-anchor\"></a>\n            <h3>Axis<wbr />Type</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Axis<wbr />Type<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;ordinal&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;time&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;localTime&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;linear&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;log&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L154\"\n                    >types.ts:154</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"chartcontextvalue\" class=\"tsd-anchor\"></a>\n            <h3>Chart<wbr />Context<wbr />Value</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Chart<wbr />Context<wbr />Value&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>axesInfo<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#axesinfo\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxesInfo</a\n              ><span class=\"tsd-signature-symbol\">; </span\n              >getDatumStatusStyle<span class=\"tsd-signature-symbol\">: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>, focusedDatum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#datumstyles\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >DatumStyles</a\n              ><span class=\"tsd-signature-symbol\">; </span>getOptions<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">(</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#requiredchartoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >RequiredChartOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >getSeriesStatusStyle<span class=\"tsd-signature-symbol\">: </span\n              ><span class=\"tsd-signature-symbol\">(</span>series<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>, focusedDatum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#seriesstyles\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >SeriesStyles</a\n              ><span class=\"tsd-signature-symbol\">; </span>gridDimensions<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#griddimensions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >GridDimensions</a\n              ><span class=\"tsd-signature-symbol\">; </span\n              >datumsByInteractionGroup<span class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">Map</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">any</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>height<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>orderedSeries<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>primaryAxis<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#axis\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Axis</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryAxes<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#axis\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Axis</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>series<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>svgRect<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">ClientRect</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >useAxisDimensionsAtom<span class=\"tsd-signature-symbol\">: </span\n              ><span class=\"tsd-signature-symbol\">(</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-symbol\">[</span\n              ><a\n                href=\"modules.html#axisdimensions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimensions</a\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">SetAtom</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">SetStateAction</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#axisdimensions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisDimensions</a\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">]</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >useFocusedDatumAtom<span class=\"tsd-signature-symbol\">: </span\n              ><span class=\"tsd-signature-symbol\">(</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-symbol\">[</span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">SetAtom</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">SetStateAction</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">]</span\n              ><span class=\"tsd-signature-symbol\">; </span>width<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L61\"\n                    >types.ts:61</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    axes<wbr />Info<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#axesinfo\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxesInfo</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    get<wbr />Datum<wbr />Status<wbr />Style<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                    focusedDatum<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#datumstyles\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >DatumStyles</a\n                    >\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>datum<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                          focusedDatum<span class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#datumstyles\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >DatumStyles</a\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                datum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                            <li>\n                              <h5>\n                                focusedDatum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span\n                                ><span class=\"tsd-signature-symbol\"> | </span\n                                ><span class=\"tsd-signature-type\">null</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#datumstyles\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >DatumStyles</a\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    get<wbr />Options<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-symbol\">(</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#requiredchartoptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >RequiredChartOptions</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#requiredchartoptions\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >RequiredChartOptions</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#requiredchartoptions\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >RequiredChartOptions</a\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\">TDatum</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    get<wbr />Series<wbr />Status<wbr />Style<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>series<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                    focusedDatum<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#seriesstyles\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >SeriesStyles</a\n                    >\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>series<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#series\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Series</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                          focusedDatum<span class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#seriesstyles\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >SeriesStyles</a\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                series:\n                                <a\n                                  href=\"modules.html#series\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Series</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                            <li>\n                              <h5>\n                                focusedDatum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span\n                                ><span class=\"tsd-signature-symbol\"> | </span\n                                ><span class=\"tsd-signature-type\">null</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#seriesstyles\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >SeriesStyles</a\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    grid<wbr />Dimensions<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#griddimensions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >GridDimensions</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    grouped<wbr />Datums<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">Map</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">any</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    height<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    ordered<wbr />Series<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    primary<wbr />Axis<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#axis\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Axis</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    secondary<wbr />Axes<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#axis\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Axis</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    series<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    svg<wbr />Rect<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">ClientRect</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    use<wbr />Axis<wbr />Dimensions<wbr />Atom<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-symbol\">(</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-symbol\">[</span\n                    ><a\n                      href=\"modules.html#axisdimensions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimensions</a\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><span class=\"tsd-signature-type\">SetAtom</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">SetStateAction</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><a\n                      href=\"modules.html#axisdimensions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisDimensions</a\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">]</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-symbol\">[</span\n                          ><a\n                            href=\"modules.html#axisdimensions\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >AxisDimensions</a\n                          ><span class=\"tsd-signature-symbol\">, </span\n                          ><span class=\"tsd-signature-type\">SetAtom</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">SetStateAction</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><a\n                            href=\"modules.html#axisdimensions\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >AxisDimensions</a\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">]</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-returns-title\">\n                            Returns <span class=\"tsd-signature-symbol\">[</span\n                            ><a\n                              href=\"modules.html#axisdimensions\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >AxisDimensions</a\n                            ><span class=\"tsd-signature-symbol\">, </span\n                            ><span class=\"tsd-signature-type\">SetAtom</span\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\"\n                              >SetStateAction</span\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><a\n                              href=\"modules.html#axisdimensions\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >AxisDimensions</a\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\">]</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    use<wbr />Focused<wbr />Datum<wbr />Atom<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-symbol\">(</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-symbol\">[</span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><span class=\"tsd-signature-type\">SetAtom</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">SetStateAction</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">]</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-symbol\">[</span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span\n                          ><span class=\"tsd-signature-symbol\">, </span\n                          ><span class=\"tsd-signature-type\">SetAtom</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">SetStateAction</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">]</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-returns-title\">\n                            Returns <span class=\"tsd-signature-symbol\">[</span\n                            ><a\n                              href=\"modules.html#datum\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >Datum</a\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\">TDatum</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\"> | </span\n                            ><span class=\"tsd-signature-type\">null</span\n                            ><span class=\"tsd-signature-symbol\">, </span\n                            ><span class=\"tsd-signature-type\">SetAtom</span\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\"\n                              >SetStateAction</span\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><a\n                              href=\"modules.html#datum\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >Datum</a\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\">TDatum</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\"> | </span\n                            ><span class=\"tsd-signature-type\">null</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\">]</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    width<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"chartoffset\" class=\"tsd-anchor\"></a>\n            <h3>Chart<wbr />Offset</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Chart<wbr />Offset<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>height<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>left<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>top<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>width<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L190\"\n                    >types.ts:190</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    height<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    left<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    top<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    width<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"chartoptions\" class=\"tsd-anchor\"></a>\n            <h3>Chart<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Chart<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>brush<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">{ </span>onSelect<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>selection<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-symbol\">{ </span>end<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">unknown</span\n              ><span class=\"tsd-signature-symbol\">; </span>pointer<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#pointer\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Pointer</a\n              ><span class=\"tsd-signature-symbol\">; </span>start<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">unknown</span\n              ><span class=\"tsd-signature-symbol\"> }</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">void</span\n              ><span class=\"tsd-signature-symbol\">; </span>style<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span\n              ><span class=\"tsd-signature-symbol\">; </span>dark<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>data<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#userserie\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >UserSerie</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>defaultColors<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>getDatumStyle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>, status<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datumfocusstatus\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >DatumFocusStatus</a\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#datumstyles\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >DatumStyles</a\n              ><span class=\"tsd-signature-symbol\">; </span>getSeriesOrder<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>series<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>getSeriesStyle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>series<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#series\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Series</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>, status<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#seriesfocusstatus\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >SeriesFocusStatus</a\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><a\n                href=\"modules.html#seriesstyles\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >SeriesStyles</a\n              ><span class=\"tsd-signature-symbol\">; </span>interactionMode<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><a\n                href=\"modules.html#groupingmode\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >GroupingMode</a\n              ><span class=\"tsd-signature-symbol\">; </span>initialHeight<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>initialWidth<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>onClickDatum<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span>, event<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">React.MouseEvent</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">SVGSVGElement</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">MouseEvent</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">void</span\n              ><span class=\"tsd-signature-symbol\">; </span>onFocusDatum<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">void</span\n              ><span class=\"tsd-signature-symbol\">; </span>primaryAxis<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#axisoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>primaryCursor<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#cursoroptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >CursorOptions</a\n              ><span class=\"tsd-signature-symbol\">; </span>renderSVG<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">React.ReactNode</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryAxes<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#axisoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AxisOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryCursor<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#cursoroptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >CursorOptions</a\n              ><span class=\"tsd-signature-symbol\">; </span>showDebugAxes<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>showVoronoi<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>tooltip<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#tooltipoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >TooltipOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L10\"\n                    >types.ts:10</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    brush<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-symbol\">{ </span>onSelect<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>selection<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-symbol\">{ </span>end<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">unknown</span\n                    ><span class=\"tsd-signature-symbol\">; </span>pointer<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#pointer\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Pointer</a\n                    ><span class=\"tsd-signature-symbol\">; </span>start<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">unknown</span\n                    ><span class=\"tsd-signature-symbol\"> }</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">void</span\n                    ><span class=\"tsd-signature-symbol\">; </span>style<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span\n                    ><span class=\"tsd-signature-symbol\"> }</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter\">\n                      <h5>\n                        <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                        on<wbr />Select<span class=\"tsd-signature-symbol\"\n                          >?: </span\n                        ><span class=\"tsd-signature-symbol\">(</span\n                        >selection<span class=\"tsd-signature-symbol\">: </span\n                        ><span class=\"tsd-signature-symbol\">{ </span>end<span\n                          class=\"tsd-signature-symbol\"\n                          >: </span\n                        ><span class=\"tsd-signature-type\">unknown</span\n                        ><span class=\"tsd-signature-symbol\">; </span\n                        >pointer<span class=\"tsd-signature-symbol\">: </span\n                        ><a\n                          href=\"modules.html#pointer\"\n                          class=\"tsd-signature-type\"\n                          data-tsd-kind=\"Type alias\"\n                          >Pointer</a\n                        ><span class=\"tsd-signature-symbol\">; </span>start<span\n                          class=\"tsd-signature-symbol\"\n                          >: </span\n                        ><span class=\"tsd-signature-type\">unknown</span\n                        ><span class=\"tsd-signature-symbol\"> }</span\n                        ><span class=\"tsd-signature-symbol\">)</span\n                        ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                        ><span class=\"tsd-signature-type\">void</span>\n                      </h5>\n                      <ul class=\"tsd-parameters\">\n                        <li class=\"tsd-parameter-signature\">\n                          <ul\n                            class=\"\n                              tsd-signatures\n                              tsd-kind-type-literal\n                              tsd-parent-kind-type-literal\n                            \"\n                          >\n                            <li class=\"tsd-signature tsd-kind-icon\">\n                              <span class=\"tsd-signature-symbol\">(</span\n                              >selection<span class=\"tsd-signature-symbol\"\n                                >: </span\n                              ><span class=\"tsd-signature-symbol\">{ </span\n                              >end<span class=\"tsd-signature-symbol\">: </span\n                              ><span class=\"tsd-signature-type\">unknown</span\n                              ><span class=\"tsd-signature-symbol\">; </span\n                              >pointer<span class=\"tsd-signature-symbol\"\n                                >: </span\n                              ><a\n                                href=\"modules.html#pointer\"\n                                class=\"tsd-signature-type\"\n                                data-tsd-kind=\"Type alias\"\n                                >Pointer</a\n                              ><span class=\"tsd-signature-symbol\">; </span\n                              >start<span class=\"tsd-signature-symbol\">: </span\n                              ><span class=\"tsd-signature-type\">unknown</span\n                              ><span class=\"tsd-signature-symbol\"> }</span\n                              ><span class=\"tsd-signature-symbol\">)</span\n                              ><span class=\"tsd-signature-symbol\">: </span\n                              ><span class=\"tsd-signature-type\">void</span>\n                            </li>\n                          </ul>\n                          <ul class=\"tsd-descriptions\">\n                            <li class=\"tsd-description\">\n                              <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                              <ul class=\"tsd-parameters\">\n                                <li>\n                                  <h5>\n                                    selection:\n                                    <span class=\"tsd-signature-symbol\">{ </span\n                                    >end<span class=\"tsd-signature-symbol\"\n                                      >: </span\n                                    ><span class=\"tsd-signature-type\"\n                                      >unknown</span\n                                    ><span class=\"tsd-signature-symbol\">; </span\n                                    >pointer<span class=\"tsd-signature-symbol\"\n                                      >: </span\n                                    ><a\n                                      href=\"modules.html#pointer\"\n                                      class=\"tsd-signature-type\"\n                                      data-tsd-kind=\"Type alias\"\n                                      >Pointer</a\n                                    ><span class=\"tsd-signature-symbol\">; </span\n                                    >start<span class=\"tsd-signature-symbol\"\n                                      >: </span\n                                    ><span class=\"tsd-signature-type\"\n                                      >unknown</span\n                                    ><span class=\"tsd-signature-symbol\">\n                                      }</span\n                                    >\n                                  </h5>\n                                  <ul class=\"tsd-parameters\">\n                                    <li class=\"tsd-parameter\">\n                                      <h5>\n                                        end<span class=\"tsd-signature-symbol\"\n                                          >: </span\n                                        ><span class=\"tsd-signature-type\"\n                                          >unknown</span\n                                        >\n                                      </h5>\n                                    </li>\n                                    <li class=\"tsd-parameter\">\n                                      <h5>\n                                        pointer<span\n                                          class=\"tsd-signature-symbol\"\n                                          >: </span\n                                        ><a\n                                          href=\"modules.html#pointer\"\n                                          class=\"tsd-signature-type\"\n                                          data-tsd-kind=\"Type alias\"\n                                          >Pointer</a\n                                        >\n                                      </h5>\n                                    </li>\n                                    <li class=\"tsd-parameter\">\n                                      <h5>\n                                        start<span class=\"tsd-signature-symbol\"\n                                          >: </span\n                                        ><span class=\"tsd-signature-type\"\n                                          >unknown</span\n                                        >\n                                      </h5>\n                                    </li>\n                                  </ul>\n                                </li>\n                              </ul>\n                              <h4 class=\"tsd-returns-title\">\n                                Returns\n                                <span class=\"tsd-signature-type\">void</span>\n                              </h4>\n                            </li>\n                          </ul>\n                        </li>\n                      </ul>\n                    </li>\n                    <li class=\"tsd-parameter\">\n                      <h5>\n                        <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                        style<span class=\"tsd-signature-symbol\">?: </span\n                        ><span class=\"tsd-signature-type\">CSSProperties</span>\n                      </h5>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    dark<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    data<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#userserie\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >UserSerie</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    default<wbr />Colors<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    get<wbr />Datum<wbr />Style<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>, status<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#datumfocusstatus\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >DatumFocusStatus</a\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#datumstyles\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >DatumStyles</a\n                    >\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>datum<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                          status<span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#datumfocusstatus\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >DatumFocusStatus</a\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#datumstyles\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >DatumStyles</a\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                datum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                            <li>\n                              <h5>\n                                status:\n                                <a\n                                  href=\"modules.html#datumfocusstatus\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >DatumFocusStatus</a\n                                >\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#datumstyles\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >DatumStyles</a\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    get<wbr />Series<wbr />Order<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>series<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>series<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#series\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Series</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">[]</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#series\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Series</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">[]</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                series:\n                                <a\n                                  href=\"modules.html#series\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Series</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span\n                                ><span class=\"tsd-signature-symbol\">[]</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#series\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >Series</a\n                            ><span class=\"tsd-signature-symbol\">&lt;</span\n                            ><span class=\"tsd-signature-type\">TDatum</span\n                            ><span class=\"tsd-signature-symbol\">&gt;</span\n                            ><span class=\"tsd-signature-symbol\">[]</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    get<wbr />Series<wbr />Style<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>series<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#series\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Series</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>, status<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#seriesfocusstatus\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >SeriesFocusStatus</a\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><a\n                      href=\"modules.html#seriesstyles\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >SeriesStyles</a\n                    >\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>series<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#series\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Series</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span>,\n                          status<span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#seriesfocusstatus\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >SeriesFocusStatus</a\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><a\n                            href=\"modules.html#seriesstyles\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >SeriesStyles</a\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                series:\n                                <a\n                                  href=\"modules.html#series\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Series</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                            <li>\n                              <h5>\n                                status:\n                                <a\n                                  href=\"modules.html#seriesfocusstatus\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >SeriesFocusStatus</a\n                                >\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <a\n                              href=\"modules.html#seriesstyles\"\n                              class=\"tsd-signature-type\"\n                              data-tsd-kind=\"Type alias\"\n                              >SeriesStyles</a\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    grouping<wbr />Mode<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><a\n                      href=\"modules.html#groupingmode\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >GroupingMode</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    initial<wbr />Height<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    initial<wbr />Width<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    on<wbr />Click<wbr />Datum<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span>, event<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">React.MouseEvent</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">SVGSVGElement</span\n                    ><span class=\"tsd-signature-symbol\">, </span\n                    ><span class=\"tsd-signature-type\">MouseEvent</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">void</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>datum<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span>,\n                          event<span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\"\n                            >React.MouseEvent</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">SVGSVGElement</span\n                          ><span class=\"tsd-signature-symbol\">, </span\n                          ><span class=\"tsd-signature-type\">MouseEvent</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\">void</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                datum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span\n                                ><span class=\"tsd-signature-symbol\"> | </span\n                                ><span class=\"tsd-signature-type\">null</span>\n                              </h5>\n                            </li>\n                            <li>\n                              <h5>\n                                event:\n                                <span class=\"tsd-signature-type\"\n                                  >React.MouseEvent</span\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\"\n                                  >SVGSVGElement</span\n                                ><span class=\"tsd-signature-symbol\">, </span\n                                ><span class=\"tsd-signature-type\"\n                                  >MouseEvent</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns <span class=\"tsd-signature-type\">void</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    on<wbr />Focus<wbr />Datum<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>datum<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">void</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>datum<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><a\n                            href=\"modules.html#datum\"\n                            class=\"tsd-signature-type\"\n                            data-tsd-kind=\"Type alias\"\n                            >Datum</a\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\"> | </span\n                          ><span class=\"tsd-signature-type\">null</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\">void</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                datum:\n                                <a\n                                  href=\"modules.html#datum\"\n                                  class=\"tsd-signature-type\"\n                                  data-tsd-kind=\"Type alias\"\n                                  >Datum</a\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span\n                                ><span class=\"tsd-signature-symbol\"> | </span\n                                ><span class=\"tsd-signature-type\">null</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns <span class=\"tsd-signature-type\">void</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    primary<wbr />Axis<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#axisoptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisOptions</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    primary<wbr />Cursor<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><a\n                      href=\"modules.html#cursoroptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >CursorOptions</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    renderSVG<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">React.ReactNode</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\"\n                            >React.ReactNode</span\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <span class=\"tsd-signature-type\"\n                              >React.ReactNode</span\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    secondary<wbr />Axes<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#axisoptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AxisOptions</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    secondary<wbr />Cursor<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><a\n                      href=\"modules.html#cursoroptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >CursorOptions</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Debug<wbr />Axes<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Voronoi<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    tooltip<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><a\n                      href=\"modules.html#tooltipoptions\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >TooltipOptions</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"chartvalue\" class=\"tsd-anchor\"></a>\n            <h3>Chart<wbr />Value</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Chart<wbr />Value&lt;T&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">T</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">undefined</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L300\"\n                    >types.ts:300</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>T</h4>\n              </li>\n            </ul>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"cursoroptions\" class=\"tsd-anchor\"></a>\n            <h3>Cursor<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Cursor<wbr />Options<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>axisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>onChange<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">void</span\n              ><span class=\"tsd-signature-symbol\">; </span>show<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>showLabel<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>showLine<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>value<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">unknown</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L420\"\n                    >types.ts:420</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    axis<wbr />Id<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    on<wbr />Change<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">void</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\">void</span>\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-returns-title\">\n                            Returns <span class=\"tsd-signature-type\">void</span>\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Label<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    show<wbr />Line<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    value<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">unknown</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"datum\" class=\"tsd-anchor\"></a>\n            <h3>Datum</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Datum&lt;TDatum&gt;<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>element<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">Element</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">null</span\n              ><span class=\"tsd-signature-symbol\">; </span>group<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>index<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>originalDatum<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">; </span>originalSeries<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#userserie\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >UserSerie</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryAxisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>seriesId<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>seriesIndex<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>seriesLabel<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>stackData<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><a\n                href=\"modules.html#stackdatum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >StackDatum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>style<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L384\"\n                    >types.ts:384</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    element<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">Element</span\n                    ><span class=\"tsd-signature-symbol\"> | </span\n                    ><span class=\"tsd-signature-type\">null</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    group<span class=\"tsd-signature-symbol\">?: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    index<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    original<wbr />Datum<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">TDatum</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    original<wbr />Series<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#userserie\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >UserSerie</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    secondary<wbr />Axis<wbr />Id<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    series<wbr />Id<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    series<wbr />Index<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    series<wbr />Label<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    stack<wbr />Data<span class=\"tsd-signature-symbol\">?: </span\n                    ><a\n                      href=\"modules.html#stackdatum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >StackDatum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    style<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"datumfocusstatus\" class=\"tsd-anchor\"></a>\n            <h3>Datum<wbr />Focus<wbr />Status</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Datum<wbr />Focus<wbr />Status<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">&quot;none&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;focused&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;groupFocused&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L431\"\n                    >types.ts:431</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"datumstyles\" class=\"tsd-anchor\"></a>\n            <h3>Datum<wbr />Styles</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Datum<wbr />Styles<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>area<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>circle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>line<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>rectangle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L121\"\n                    >types.ts:121</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"griddimensions\" class=\"tsd-anchor\"></a>\n            <h3>Grid<wbr />Dimensions</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Grid<wbr />Dimensions<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>height<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>width<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>gridX<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>gridY<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L408\"\n                    >types.ts:408</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    grid<wbr />Height<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    grid<wbr />Width<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    gridX<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    gridY<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"groupingmode\" class=\"tsd-anchor\"></a>\n            <h3>Grouping<wbr />Mode</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Grouping<wbr />Mode<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;single&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;series&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;primary&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;secondary&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L130\"\n                    >types.ts:130</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"measurement\" class=\"tsd-anchor\"></a>\n            <h3>Measurement</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Measurement<span class=\"tsd-signature-symbol\">:</span>\n              <a\n                href=\"modules.html#side\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Side</a\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;width&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;height&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L406\"\n                    >types.ts:406</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"pointer\" class=\"tsd-anchor\"></a>\n            <h3>Pointer</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Pointer<span class=\"tsd-signature-symbol\">:</span>\n              <a\n                href=\"modules.html#pointerunpressed\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >PointerUnpressed</a\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><a\n                href=\"modules.html#pointerpressed\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >PointerPressed</a\n              >\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L188\"\n                    >types.ts:188</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"pointerpressed\" class=\"tsd-anchor\"></a>\n            <h3>Pointer<wbr />Pressed</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Pointer<wbr />Pressed<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">PointerBase</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>dragging<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">true</span\n              ><span class=\"tsd-signature-symbol\">; </span>startX<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>startY<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L182\"\n                    >types.ts:182</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"pointerunpressed\" class=\"tsd-anchor\"></a>\n            <h3>Pointer<wbr />Unpressed</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Pointer<wbr />Unpressed<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">PointerBase</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>dragging<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">false</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L178\"\n                    >types.ts:178</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"position\" class=\"tsd-anchor\"></a>\n            <h3>Position</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Position<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;top&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;right&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottom&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;left&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L128\"\n                    >types.ts:128</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"requiredchartoptions\" class=\"tsd-anchor\"></a>\n            <h3>Required<wbr />Chart<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Required<wbr />Chart<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">TSTB.Object.Required</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#chartoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >ChartOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">&quot;getSeriesStyle&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;getDatumStyle&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;getSeriesOrder&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;interactionMode&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;showVoronoi&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;defaultColors&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;initialWidth&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;initialHeight&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L49\"\n                    >types.ts:49</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"resolvedaxisoptions\" class=\"tsd-anchor\"></a>\n            <h3>Resolved<wbr />Axis<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Resolved<wbr />Axis<wbr />Options&lt;TAxisOptions&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">TSTB.Object.Required</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TAxisOptions</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{}</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;minTickPaddingForRotation&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;tickLabelRotationDeg&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;innerBandPadding&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;outerBandPadding&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;show&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;stacked&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L283\"\n                    >types.ts:283</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TAxisOptions</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"resolvedtooltipoptions\" class=\"tsd-anchor\"></a>\n            <h3>Resolved<wbr />Tooltip<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Resolved<wbr />Tooltip<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">TSTB.Object.Required</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><a\n                href=\"modules.html#tooltipoptions\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >TooltipOptions</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">, </span\n              ><span class=\"tsd-signature-type\">&quot;align&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;alignPriority&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;padding&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\"\n                >&quot;tooltipArrowPadding&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;anchor&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;render&quot;</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L104\"\n                    >types.ts:104</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"series\" class=\"tsd-anchor\"></a>\n            <h3>Series</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Series&lt;TDatum&gt;<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-symbol\">{ </span>datums<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>id<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>index<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>label<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>originalSeries<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#userserie\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >UserSerie</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryAxisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>style<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L374\"\n                    >types.ts:374</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    datums<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    id<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    index<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    label<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    original<wbr />Series<span class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><a\n                      href=\"modules.html#userserie\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >UserSerie</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    secondary<wbr />Axis<wbr />Id<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    style<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">CSSProperties</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"seriesfocusstatus\" class=\"tsd-anchor\"></a>\n            <h3>Series<wbr />Focus<wbr />Status</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Series<wbr />Focus<wbr />Status<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-type\">&quot;none&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;focused&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L429\"\n                    >types.ts:429</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"seriesstyles\" class=\"tsd-anchor\"></a>\n            <h3>Series<wbr />Styles</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Series<wbr />Styles<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> &amp; </span\n              ><span class=\"tsd-signature-symbol\">{ </span>area<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>circle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>line<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\">; </span>rectangle<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">CSSProperties</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L114\"\n                    >types.ts:114</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section class=\"tsd-panel tsd-member tsd-kind-type-alias\">\n            <a name=\"side\" class=\"tsd-anchor\"></a>\n            <h3>Side</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Side<span class=\"tsd-signature-symbol\">:</span>\n              <span class=\"tsd-signature-type\">&quot;left&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;right&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;top&quot;</span\n              ><span class=\"tsd-signature-symbol\"> | </span\n              ><span class=\"tsd-signature-type\">&quot;bottom&quot;</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L170\"\n                    >types.ts:170</a\n                  >\n                </li>\n              </ul>\n            </aside>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"stackdatum\" class=\"tsd-anchor\"></a>\n            <h3>Stack<wbr />Datum</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Stack<wbr />Datum&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>0<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>1<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>data<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><a\n                href=\"modules.html#datum\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >Datum</a\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L398\"\n                    >types.ts:398</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    0<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    1<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    data<span class=\"tsd-signature-symbol\">: </span\n                    ><a\n                      href=\"modules.html#datum\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >Datum</a\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"tooltipoptions\" class=\"tsd-anchor\"></a>\n            <h3>Tooltip<wbr />Options</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              Tooltip<wbr />Options&lt;TDatum&gt;<span\n                class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>align<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><a\n                href=\"modules.html#alignmode\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AlignMode</a\n              ><span class=\"tsd-signature-symbol\">; </span>alignPriority<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><a\n                href=\"modules.html#alignposition\"\n                class=\"tsd-signature-type\"\n                data-tsd-kind=\"Type alias\"\n                >AlignPosition</a\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>invert<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">boolean</span\n              ><span class=\"tsd-signature-symbol\">; </span>padding<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\">; </span>render<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-symbol\">(</span>props<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TooltipRendererProps</span\n              ><span class=\"tsd-signature-symbol\">&lt;</span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">&gt;</span\n              ><span class=\"tsd-signature-symbol\">)</span\n              ><span class=\"tsd-signature-symbol\"> =&gt; </span\n              ><span class=\"tsd-signature-type\">React.ReactNode</span\n              ><span class=\"tsd-signature-symbol\">; </span\n              >tooltipArrowPadding<span class=\"tsd-signature-symbol\">?: </span\n              ><span class=\"tsd-signature-type\">number</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L91\"\n                    >types.ts:91</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    align<span class=\"tsd-signature-symbol\">?: </span\n                    ><a\n                      href=\"modules.html#alignmode\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AlignMode</a\n                    >\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    align<wbr />Priority<span class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><a\n                      href=\"modules.html#alignposition\"\n                      class=\"tsd-signature-type\"\n                      data-tsd-kind=\"Type alias\"\n                      >AlignPosition</a\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    invert<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">boolean</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    padding<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    render<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-symbol\">(</span>props<span\n                      class=\"tsd-signature-symbol\"\n                      >: </span\n                    ><span class=\"tsd-signature-type\">TooltipRendererProps</span\n                    ><span class=\"tsd-signature-symbol\">&lt;</span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">&gt;</span\n                    ><span class=\"tsd-signature-symbol\">)</span\n                    ><span class=\"tsd-signature-symbol\"> =&gt; </span\n                    ><span class=\"tsd-signature-type\">React.ReactNode</span>\n                  </h5>\n                  <ul class=\"tsd-parameters\">\n                    <li class=\"tsd-parameter-signature\">\n                      <ul\n                        class=\"\n                          tsd-signatures\n                          tsd-kind-type-literal\n                          tsd-parent-kind-type-literal\n                        \"\n                      >\n                        <li class=\"tsd-signature tsd-kind-icon\">\n                          <span class=\"tsd-signature-symbol\">(</span>props<span\n                            class=\"tsd-signature-symbol\"\n                            >: </span\n                          ><span class=\"tsd-signature-type\"\n                            >TooltipRendererProps</span\n                          ><span class=\"tsd-signature-symbol\">&lt;</span\n                          ><span class=\"tsd-signature-type\">TDatum</span\n                          ><span class=\"tsd-signature-symbol\">&gt;</span\n                          ><span class=\"tsd-signature-symbol\">)</span\n                          ><span class=\"tsd-signature-symbol\">: </span\n                          ><span class=\"tsd-signature-type\"\n                            >React.ReactNode</span\n                          >\n                        </li>\n                      </ul>\n                      <ul class=\"tsd-descriptions\">\n                        <li class=\"tsd-description\">\n                          <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                          <ul class=\"tsd-parameters\">\n                            <li>\n                              <h5>\n                                props:\n                                <span class=\"tsd-signature-type\"\n                                  >TooltipRendererProps</span\n                                ><span class=\"tsd-signature-symbol\">&lt;</span\n                                ><span class=\"tsd-signature-type\">TDatum</span\n                                ><span class=\"tsd-signature-symbol\">&gt;</span>\n                              </h5>\n                            </li>\n                          </ul>\n                          <h4 class=\"tsd-returns-title\">\n                            Returns\n                            <span class=\"tsd-signature-type\"\n                              >React.ReactNode</span\n                            >\n                          </h4>\n                        </li>\n                      </ul>\n                    </li>\n                  </ul>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    tooltip<wbr />Arrow<wbr />Padding<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">number</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-type-alias tsd-has-type-parameter\n            \"\n          >\n            <a name=\"userserie\" class=\"tsd-anchor\"></a>\n            <h3>User<wbr />Serie</h3>\n            <div class=\"tsd-signature tsd-kind-icon\">\n              User<wbr />Serie&lt;TDatum&gt;<span class=\"tsd-signature-symbol\"\n                >:</span\n              >\n              <span class=\"tsd-signature-symbol\">{ </span>color<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>data<span\n                class=\"tsd-signature-symbol\"\n                >: </span\n              ><span class=\"tsd-signature-type\">TDatum</span\n              ><span class=\"tsd-signature-symbol\">[]</span\n              ><span class=\"tsd-signature-symbol\">; </span>id<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>label<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>primaryAxisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\">; </span>secondaryAxisId<span\n                class=\"tsd-signature-symbol\"\n                >?: </span\n              ><span class=\"tsd-signature-type\">string</span\n              ><span class=\"tsd-signature-symbol\"> }</span>\n            </div>\n            <aside class=\"tsd-sources\">\n              <ul>\n                <li>\n                  Defined in\n                  <a\n                    href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/types.ts#L363\"\n                    >types.ts:363</a\n                  >\n                </li>\n              </ul>\n            </aside>\n            <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n            <ul class=\"tsd-type-parameters\">\n              <li>\n                <h4>TDatum</h4>\n              </li>\n            </ul>\n            <div class=\"tsd-type-declaration\">\n              <h4>Type declaration</h4>\n              <ul class=\"tsd-parameters\">\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    color<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    data<span class=\"tsd-signature-symbol\">: </span\n                    ><span class=\"tsd-signature-type\">TDatum</span\n                    ><span class=\"tsd-signature-symbol\">[]</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    id<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    label<span class=\"tsd-signature-symbol\">?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    primary<wbr />Axis<wbr />Id<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n                <li class=\"tsd-parameter\">\n                  <h5>\n                    <span class=\"tsd-flag ts-flagOptional\">Optional</span>\n                    secondary<wbr />Axis<wbr />Id<span\n                      class=\"tsd-signature-symbol\"\n                      >?: </span\n                    ><span class=\"tsd-signature-type\">string</span>\n                  </h5>\n                </li>\n              </ul>\n            </div>\n          </section>\n        </section>\n        <section class=\"tsd-panel-group tsd-member-group\">\n          <h2>Functions</h2>\n          <section\n            class=\"\n              tsd-panel tsd-member tsd-kind-function tsd-has-type-parameter\n            \"\n          >\n            <a name=\"chart\" class=\"tsd-anchor\"></a>\n            <h3>Chart</h3>\n            <ul class=\"tsd-signatures tsd-kind-function tsd-has-type-parameter\">\n              <li class=\"tsd-signature tsd-kind-icon\">\n                Chart&lt;TDatum&gt;<span class=\"tsd-signature-symbol\">(</span\n                >__namedParameters<span class=\"tsd-signature-symbol\">: </span\n                ><span class=\"tsd-signature-type\">ComponentPropsWithoutRef</span\n                ><span class=\"tsd-signature-symbol\">&lt;</span\n                ><span class=\"tsd-signature-type\">&quot;div&quot;</span\n                ><span class=\"tsd-signature-symbol\">&gt;</span\n                ><span class=\"tsd-signature-symbol\"> &amp; </span\n                ><span class=\"tsd-signature-symbol\">{ </span>options<span\n                  class=\"tsd-signature-symbol\"\n                  >: </span\n                ><a\n                  href=\"modules.html#chartoptions\"\n                  class=\"tsd-signature-type\"\n                  data-tsd-kind=\"Type alias\"\n                  >ChartOptions</a\n                ><span class=\"tsd-signature-symbol\">&lt;</span\n                ><span class=\"tsd-signature-type\">TDatum</span\n                ><span class=\"tsd-signature-symbol\">&gt;</span\n                ><span class=\"tsd-signature-symbol\"> }</span\n                ><span class=\"tsd-signature-symbol\">)</span\n                ><span class=\"tsd-signature-symbol\">: </span\n                ><span class=\"tsd-signature-type\">Element</span>\n              </li>\n            </ul>\n            <ul class=\"tsd-descriptions\">\n              <li class=\"tsd-description\">\n                <aside class=\"tsd-sources\">\n                  <ul>\n                    <li>\n                      Defined in\n                      <a\n                        href=\"https://github.com/react-tools/react-charts/blob/7dc3286/src/components/Chart.tsx#L94\"\n                        >components/Chart.tsx:94</a\n                      >\n                    </li>\n                  </ul>\n                </aside>\n                <h4 class=\"tsd-type-parameters-title\">Type parameters</h4>\n                <ul class=\"tsd-type-parameters\">\n                  <li>\n                    <h4>TDatum</h4>\n                  </li>\n                </ul>\n                <h4 class=\"tsd-parameters-title\">Parameters</h4>\n                <ul class=\"tsd-parameters\">\n                  <li>\n                    <h5>\n                      __namedParameters:\n                      <span class=\"tsd-signature-type\"\n                        >ComponentPropsWithoutRef</span\n                      ><span class=\"tsd-signature-symbol\">&lt;</span\n                      ><span class=\"tsd-signature-type\">&quot;div&quot;</span\n                      ><span class=\"tsd-signature-symbol\">&gt;</span\n                      ><span class=\"tsd-signature-symbol\"> &amp; </span\n                      ><span class=\"tsd-signature-symbol\">{ </span>options<span\n                        class=\"tsd-signature-symbol\"\n                        >: </span\n                      ><a\n                        href=\"modules.html#chartoptions\"\n                        class=\"tsd-signature-type\"\n                        data-tsd-kind=\"Type alias\"\n                        >ChartOptions</a\n                      ><span class=\"tsd-signature-symbol\">&lt;</span\n                      ><span class=\"tsd-signature-type\">TDatum</span\n                      ><span class=\"tsd-signature-symbol\">&gt;</span\n                      ><span class=\"tsd-signature-symbol\"> }</span>\n                    </h5>\n                  </li>\n                </ul>\n                <h4 class=\"tsd-returns-title\">\n                  Returns <span class=\"tsd-signature-type\">Element</span>\n                </h4>\n              </li>\n            </ul>\n          </section>\n        </section>\n        <footer class=\"with-border-bottom\">\n          <div class=\"container\">\n            <h2>Legend</h2>\n            <div class=\"tsd-legend-group\"></div>\n          </div>\n        </footer>\n        <div class=\"container tsd-generator\">\n          <p>\n            Generated using\n            <a href=\"https://typedoc.org/\" target=\"_blank\">TypeDoc</a>\n          </p>\n        </div>\n      </div>\n    </div>\n    <script type=\"text/javascript\">\n      /*\n       * ATTENTION: The \"eval\" devtool has been used (maybe by default in mode: \"development\").\n       * This devtool is not neither made for production nor for readable output files.\n       * It uses \"eval()\" calls to create a separate source file in the browser devtools.\n       * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)\n       * or disable the default devtool with \"devtool: false\".\n       * If you are looking for production-ready output files, see mode: \"production\" (https://webpack.js.org/configuration/mode/).\n       */\n      /******/ ;(() => {\n        // webpackBootstrap\n        /******/ var __webpack_modules__ = {\n          /***/ '../node_modules/lunr/lunr.js':\n            /*!************************************!*\\\n  !*** ../node_modules/lunr/lunr.js ***!\n  \\************************************/\n            /***/ (module, exports, __webpack_require__) => {\n              eval(\n                \"var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;/**\\n * lunr - http://lunrjs.com - A bit like Solr, but much smaller and not as bright - 2.3.9\\n * Copyright (C) 2020 Oliver Nightingale\\n * @license MIT\\n */\\n\\n;(function(){\\n\\n/**\\n * A convenience function for configuring and constructing\\n * a new lunr Index.\\n *\\n * A lunr.Builder instance is created and the pipeline setup\\n * with a trimmer, stop word filter and stemmer.\\n *\\n * This builder object is yielded to the configuration function\\n * that is passed as a parameter, allowing the list of fields\\n * and other builder parameters to be customised.\\n *\\n * All documents _must_ be added within the passed config function.\\n *\\n * @example\\n * var idx = lunr(function () {\\n *   this.field('title')\\n *   this.field('body')\\n *   this.ref('id')\\n *\\n *   documents.forEach(function (doc) {\\n *     this.add(doc)\\n *   }, this)\\n * })\\n *\\n * @see {@link lunr.Builder}\\n * @see {@link lunr.Pipeline}\\n * @see {@link lunr.trimmer}\\n * @see {@link lunr.stopWordFilter}\\n * @see {@link lunr.stemmer}\\n * @namespace {function} lunr\\n */\\nvar lunr = function (config) {\\n  var builder = new lunr.Builder\\n\\n  builder.pipeline.add(\\n    lunr.trimmer,\\n    lunr.stopWordFilter,\\n    lunr.stemmer\\n  )\\n\\n  builder.searchPipeline.add(\\n    lunr.stemmer\\n  )\\n\\n  config.call(builder, builder)\\n  return builder.build()\\n}\\n\\nlunr.version = \\\"2.3.9\\\"\\n/*!\\n * lunr.utils\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A namespace containing utils for the rest of the lunr library\\n * @namespace lunr.utils\\n */\\nlunr.utils = {}\\n\\n/**\\n * Print a warning message to the console.\\n *\\n * @param {String} message The message to be printed.\\n * @memberOf lunr.utils\\n * @function\\n */\\nlunr.utils.warn = (function (global) {\\n  /* eslint-disable no-console */\\n  return function (message) {\\n    if (global.console && console.warn) {\\n      console.warn(message)\\n    }\\n  }\\n  /* eslint-enable no-console */\\n})(this)\\n\\n/**\\n * Convert an object to a string.\\n *\\n * In the case of `null` and `undefined` the function returns\\n * the empty string, in all other cases the result of calling\\n * `toString` on the passed object is returned.\\n *\\n * @param {Any} obj The object to convert to a string.\\n * @return {String} string representation of the passed object.\\n * @memberOf lunr.utils\\n */\\nlunr.utils.asString = function (obj) {\\n  if (obj === void 0 || obj === null) {\\n    return \\\"\\\"\\n  } else {\\n    return obj.toString()\\n  }\\n}\\n\\n/**\\n * Clones an object.\\n *\\n * Will create a copy of an existing object such that any mutations\\n * on the copy cannot affect the original.\\n *\\n * Only shallow objects are supported, passing a nested object to this\\n * function will cause a TypeError.\\n *\\n * Objects with primitives, and arrays of primitives are supported.\\n *\\n * @param {Object} obj The object to clone.\\n * @return {Object} a clone of the passed object.\\n * @throws {TypeError} when a nested object is passed.\\n * @memberOf Utils\\n */\\nlunr.utils.clone = function (obj) {\\n  if (obj === null || obj === undefined) {\\n    return obj\\n  }\\n\\n  var clone = Object.create(null),\\n      keys = Object.keys(obj)\\n\\n  for (var i = 0; i < keys.length; i++) {\\n    var key = keys[i],\\n        val = obj[key]\\n\\n    if (Array.isArray(val)) {\\n      clone[key] = val.slice()\\n      continue\\n    }\\n\\n    if (typeof val === 'string' ||\\n        typeof val === 'number' ||\\n        typeof val === 'boolean') {\\n      clone[key] = val\\n      continue\\n    }\\n\\n    throw new TypeError(\\\"clone is not deep and does not support nested objects\\\")\\n  }\\n\\n  return clone\\n}\\nlunr.FieldRef = function (docRef, fieldName, stringValue) {\\n  this.docRef = docRef\\n  this.fieldName = fieldName\\n  this._stringValue = stringValue\\n}\\n\\nlunr.FieldRef.joiner = \\\"/\\\"\\n\\nlunr.FieldRef.fromString = function (s) {\\n  var n = s.indexOf(lunr.FieldRef.joiner)\\n\\n  if (n === -1) {\\n    throw \\\"malformed field ref string\\\"\\n  }\\n\\n  var fieldRef = s.slice(0, n),\\n      docRef = s.slice(n + 1)\\n\\n  return new lunr.FieldRef (docRef, fieldRef, s)\\n}\\n\\nlunr.FieldRef.prototype.toString = function () {\\n  if (this._stringValue == undefined) {\\n    this._stringValue = this.fieldName + lunr.FieldRef.joiner + this.docRef\\n  }\\n\\n  return this._stringValue\\n}\\n/*!\\n * lunr.Set\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A lunr set.\\n *\\n * @constructor\\n */\\nlunr.Set = function (elements) {\\n  this.elements = Object.create(null)\\n\\n  if (elements) {\\n    this.length = elements.length\\n\\n    for (var i = 0; i < this.length; i++) {\\n      this.elements[elements[i]] = true\\n    }\\n  } else {\\n    this.length = 0\\n  }\\n}\\n\\n/**\\n * A complete set that contains all elements.\\n *\\n * @static\\n * @readonly\\n * @type {lunr.Set}\\n */\\nlunr.Set.complete = {\\n  intersect: function (other) {\\n    return other\\n  },\\n\\n  union: function () {\\n    return this\\n  },\\n\\n  contains: function () {\\n    return true\\n  }\\n}\\n\\n/**\\n * An empty set that contains no elements.\\n *\\n * @static\\n * @readonly\\n * @type {lunr.Set}\\n */\\nlunr.Set.empty = {\\n  intersect: function () {\\n    return this\\n  },\\n\\n  union: function (other) {\\n    return other\\n  },\\n\\n  contains: function () {\\n    return false\\n  }\\n}\\n\\n/**\\n * Returns true if this set contains the specified object.\\n *\\n * @param {object} object - Object whose presence in this set is to be tested.\\n * @returns {boolean} - True if this set contains the specified object.\\n */\\nlunr.Set.prototype.contains = function (object) {\\n  return !!this.elements[object]\\n}\\n\\n/**\\n * Returns a new set containing only the elements that are present in both\\n * this set and the specified set.\\n *\\n * @param {lunr.Set} other - set to intersect with this set.\\n * @returns {lunr.Set} a new set that is the intersection of this and the specified set.\\n */\\n\\nlunr.Set.prototype.intersect = function (other) {\\n  var a, b, elements, intersection = []\\n\\n  if (other === lunr.Set.complete) {\\n    return this\\n  }\\n\\n  if (other === lunr.Set.empty) {\\n    return other\\n  }\\n\\n  if (this.length < other.length) {\\n    a = this\\n    b = other\\n  } else {\\n    a = other\\n    b = this\\n  }\\n\\n  elements = Object.keys(a.elements)\\n\\n  for (var i = 0; i < elements.length; i++) {\\n    var element = elements[i]\\n    if (element in b.elements) {\\n      intersection.push(element)\\n    }\\n  }\\n\\n  return new lunr.Set (intersection)\\n}\\n\\n/**\\n * Returns a new set combining the elements of this and the specified set.\\n *\\n * @param {lunr.Set} other - set to union with this set.\\n * @return {lunr.Set} a new set that is the union of this and the specified set.\\n */\\n\\nlunr.Set.prototype.union = function (other) {\\n  if (other === lunr.Set.complete) {\\n    return lunr.Set.complete\\n  }\\n\\n  if (other === lunr.Set.empty) {\\n    return this\\n  }\\n\\n  return new lunr.Set(Object.keys(this.elements).concat(Object.keys(other.elements)))\\n}\\n/**\\n * A function to calculate the inverse document frequency for\\n * a posting. This is shared between the builder and the index\\n *\\n * @private\\n * @param {object} posting - The posting for a given term\\n * @param {number} documentCount - The total number of documents.\\n */\\nlunr.idf = function (posting, documentCount) {\\n  var documentsWithTerm = 0\\n\\n  for (var fieldName in posting) {\\n    if (fieldName == '_index') continue // Ignore the term index, its not a field\\n    documentsWithTerm += Object.keys(posting[fieldName]).length\\n  }\\n\\n  var x = (documentCount - documentsWithTerm + 0.5) / (documentsWithTerm + 0.5)\\n\\n  return Math.log(1 + Math.abs(x))\\n}\\n\\n/**\\n * A token wraps a string representation of a token\\n * as it is passed through the text processing pipeline.\\n *\\n * @constructor\\n * @param {string} [str=''] - The string token being wrapped.\\n * @param {object} [metadata={}] - Metadata associated with this token.\\n */\\nlunr.Token = function (str, metadata) {\\n  this.str = str || \\\"\\\"\\n  this.metadata = metadata || {}\\n}\\n\\n/**\\n * Returns the token string that is being wrapped by this object.\\n *\\n * @returns {string}\\n */\\nlunr.Token.prototype.toString = function () {\\n  return this.str\\n}\\n\\n/**\\n * A token update function is used when updating or optionally\\n * when cloning a token.\\n *\\n * @callback lunr.Token~updateFunction\\n * @param {string} str - The string representation of the token.\\n * @param {Object} metadata - All metadata associated with this token.\\n */\\n\\n/**\\n * Applies the given function to the wrapped string token.\\n *\\n * @example\\n * token.update(function (str, metadata) {\\n *   return str.toUpperCase()\\n * })\\n *\\n * @param {lunr.Token~updateFunction} fn - A function to apply to the token string.\\n * @returns {lunr.Token}\\n */\\nlunr.Token.prototype.update = function (fn) {\\n  this.str = fn(this.str, this.metadata)\\n  return this\\n}\\n\\n/**\\n * Creates a clone of this token. Optionally a function can be\\n * applied to the cloned token.\\n *\\n * @param {lunr.Token~updateFunction} [fn] - An optional function to apply to the cloned token.\\n * @returns {lunr.Token}\\n */\\nlunr.Token.prototype.clone = function (fn) {\\n  fn = fn || function (s) { return s }\\n  return new lunr.Token (fn(this.str, this.metadata), this.metadata)\\n}\\n/*!\\n * lunr.tokenizer\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A function for splitting a string into tokens ready to be inserted into\\n * the search index. Uses `lunr.tokenizer.separator` to split strings, change\\n * the value of this property to change how strings are split into tokens.\\n *\\n * This tokenizer will convert its parameter to a string by calling `toString` and\\n * then will split this string on the character in `lunr.tokenizer.separator`.\\n * Arrays will have their elements converted to strings and wrapped in a lunr.Token.\\n *\\n * Optional metadata can be passed to the tokenizer, this metadata will be cloned and\\n * added as metadata to every token that is created from the object to be tokenized.\\n *\\n * @static\\n * @param {?(string|object|object[])} obj - The object to convert into tokens\\n * @param {?object} metadata - Optional metadata to associate with every token\\n * @returns {lunr.Token[]}\\n * @see {@link lunr.Pipeline}\\n */\\nlunr.tokenizer = function (obj, metadata) {\\n  if (obj == null || obj == undefined) {\\n    return []\\n  }\\n\\n  if (Array.isArray(obj)) {\\n    return obj.map(function (t) {\\n      return new lunr.Token(\\n        lunr.utils.asString(t).toLowerCase(),\\n        lunr.utils.clone(metadata)\\n      )\\n    })\\n  }\\n\\n  var str = obj.toString().toLowerCase(),\\n      len = str.length,\\n      tokens = []\\n\\n  for (var sliceEnd = 0, sliceStart = 0; sliceEnd <= len; sliceEnd++) {\\n    var char = str.charAt(sliceEnd),\\n        sliceLength = sliceEnd - sliceStart\\n\\n    if ((char.match(lunr.tokenizer.separator) || sliceEnd == len)) {\\n\\n      if (sliceLength > 0) {\\n        var tokenMetadata = lunr.utils.clone(metadata) || {}\\n        tokenMetadata[\\\"position\\\"] = [sliceStart, sliceLength]\\n        tokenMetadata[\\\"index\\\"] = tokens.length\\n\\n        tokens.push(\\n          new lunr.Token (\\n            str.slice(sliceStart, sliceEnd),\\n            tokenMetadata\\n          )\\n        )\\n      }\\n\\n      sliceStart = sliceEnd + 1\\n    }\\n\\n  }\\n\\n  return tokens\\n}\\n\\n/**\\n * The separator used to split a string into tokens. Override this property to change the behaviour of\\n * `lunr.tokenizer` behaviour when tokenizing strings. By default this splits on whitespace and hyphens.\\n *\\n * @static\\n * @see lunr.tokenizer\\n */\\nlunr.tokenizer.separator = /[\\\\s\\\\-]+/\\n/*!\\n * lunr.Pipeline\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.Pipelines maintain an ordered list of functions to be applied to all\\n * tokens in documents entering the search index and queries being ran against\\n * the index.\\n *\\n * An instance of lunr.Index created with the lunr shortcut will contain a\\n * pipeline with a stop word filter and an English language stemmer. Extra\\n * functions can be added before or after either of these functions or these\\n * default functions can be removed.\\n *\\n * When run the pipeline will call each function in turn, passing a token, the\\n * index of that token in the original list of all tokens and finally a list of\\n * all the original tokens.\\n *\\n * The output of functions in the pipeline will be passed to the next function\\n * in the pipeline. To exclude a token from entering the index the function\\n * should return undefined, the rest of the pipeline will not be called with\\n * this token.\\n *\\n * For serialisation of pipelines to work, all functions used in an instance of\\n * a pipeline should be registered with lunr.Pipeline. Registered functions can\\n * then be loaded. If trying to load a serialised pipeline that uses functions\\n * that are not registered an error will be thrown.\\n *\\n * If not planning on serialising the pipeline then registering pipeline functions\\n * is not necessary.\\n *\\n * @constructor\\n */\\nlunr.Pipeline = function () {\\n  this._stack = []\\n}\\n\\nlunr.Pipeline.registeredFunctions = Object.create(null)\\n\\n/**\\n * A pipeline function maps lunr.Token to lunr.Token. A lunr.Token contains the token\\n * string as well as all known metadata. A pipeline function can mutate the token string\\n * or mutate (or add) metadata for a given token.\\n *\\n * A pipeline function can indicate that the passed token should be discarded by returning\\n * null, undefined or an empty string. This token will not be passed to any downstream pipeline\\n * functions and will not be added to the index.\\n *\\n * Multiple tokens can be returned by returning an array of tokens. Each token will be passed\\n * to any downstream pipeline functions and all will returned tokens will be added to the index.\\n *\\n * Any number of pipeline functions may be chained together using a lunr.Pipeline.\\n *\\n * @interface lunr.PipelineFunction\\n * @param {lunr.Token} token - A token from the document being processed.\\n * @param {number} i - The index of this token in the complete list of tokens for this document/field.\\n * @param {lunr.Token[]} tokens - All tokens for this document/field.\\n * @returns {(?lunr.Token|lunr.Token[])}\\n */\\n\\n/**\\n * Register a function with the pipeline.\\n *\\n * Functions that are used in the pipeline should be registered if the pipeline\\n * needs to be serialised, or a serialised pipeline needs to be loaded.\\n *\\n * Registering a function does not add it to a pipeline, functions must still be\\n * added to instances of the pipeline for them to be used when running a pipeline.\\n *\\n * @param {lunr.PipelineFunction} fn - The function to check for.\\n * @param {String} label - The label to register this function with\\n */\\nlunr.Pipeline.registerFunction = function (fn, label) {\\n  if (label in this.registeredFunctions) {\\n    lunr.utils.warn('Overwriting existing registered function: ' + label)\\n  }\\n\\n  fn.label = label\\n  lunr.Pipeline.registeredFunctions[fn.label] = fn\\n}\\n\\n/**\\n * Warns if the function is not registered as a Pipeline function.\\n *\\n * @param {lunr.PipelineFunction} fn - The function to check for.\\n * @private\\n */\\nlunr.Pipeline.warnIfFunctionNotRegistered = function (fn) {\\n  var isRegistered = fn.label && (fn.label in this.registeredFunctions)\\n\\n  if (!isRegistered) {\\n    lunr.utils.warn('Function is not registered with pipeline. This may cause problems when serialising the index.\\\\n', fn)\\n  }\\n}\\n\\n/**\\n * Loads a previously serialised pipeline.\\n *\\n * All functions to be loaded must already be registered with lunr.Pipeline.\\n * If any function from the serialised data has not been registered then an\\n * error will be thrown.\\n *\\n * @param {Object} serialised - The serialised pipeline to load.\\n * @returns {lunr.Pipeline}\\n */\\nlunr.Pipeline.load = function (serialised) {\\n  var pipeline = new lunr.Pipeline\\n\\n  serialised.forEach(function (fnName) {\\n    var fn = lunr.Pipeline.registeredFunctions[fnName]\\n\\n    if (fn) {\\n      pipeline.add(fn)\\n    } else {\\n      throw new Error('Cannot load unregistered function: ' + fnName)\\n    }\\n  })\\n\\n  return pipeline\\n}\\n\\n/**\\n * Adds new functions to the end of the pipeline.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @param {lunr.PipelineFunction[]} functions - Any number of functions to add to the pipeline.\\n */\\nlunr.Pipeline.prototype.add = function () {\\n  var fns = Array.prototype.slice.call(arguments)\\n\\n  fns.forEach(function (fn) {\\n    lunr.Pipeline.warnIfFunctionNotRegistered(fn)\\n    this._stack.push(fn)\\n  }, this)\\n}\\n\\n/**\\n * Adds a single function after a function that already exists in the\\n * pipeline.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @param {lunr.PipelineFunction} existingFn - A function that already exists in the pipeline.\\n * @param {lunr.PipelineFunction} newFn - The new function to add to the pipeline.\\n */\\nlunr.Pipeline.prototype.after = function (existingFn, newFn) {\\n  lunr.Pipeline.warnIfFunctionNotRegistered(newFn)\\n\\n  var pos = this._stack.indexOf(existingFn)\\n  if (pos == -1) {\\n    throw new Error('Cannot find existingFn')\\n  }\\n\\n  pos = pos + 1\\n  this._stack.splice(pos, 0, newFn)\\n}\\n\\n/**\\n * Adds a single function before a function that already exists in the\\n * pipeline.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @param {lunr.PipelineFunction} existingFn - A function that already exists in the pipeline.\\n * @param {lunr.PipelineFunction} newFn - The new function to add to the pipeline.\\n */\\nlunr.Pipeline.prototype.before = function (existingFn, newFn) {\\n  lunr.Pipeline.warnIfFunctionNotRegistered(newFn)\\n\\n  var pos = this._stack.indexOf(existingFn)\\n  if (pos == -1) {\\n    throw new Error('Cannot find existingFn')\\n  }\\n\\n  this._stack.splice(pos, 0, newFn)\\n}\\n\\n/**\\n * Removes a function from the pipeline.\\n *\\n * @param {lunr.PipelineFunction} fn The function to remove from the pipeline.\\n */\\nlunr.Pipeline.prototype.remove = function (fn) {\\n  var pos = this._stack.indexOf(fn)\\n  if (pos == -1) {\\n    return\\n  }\\n\\n  this._stack.splice(pos, 1)\\n}\\n\\n/**\\n * Runs the current list of functions that make up the pipeline against the\\n * passed tokens.\\n *\\n * @param {Array} tokens The tokens to run through the pipeline.\\n * @returns {Array}\\n */\\nlunr.Pipeline.prototype.run = function (tokens) {\\n  var stackLength = this._stack.length\\n\\n  for (var i = 0; i < stackLength; i++) {\\n    var fn = this._stack[i]\\n    var memo = []\\n\\n    for (var j = 0; j < tokens.length; j++) {\\n      var result = fn(tokens[j], j, tokens)\\n\\n      if (result === null || result === void 0 || result === '') continue\\n\\n      if (Array.isArray(result)) {\\n        for (var k = 0; k < result.length; k++) {\\n          memo.push(result[k])\\n        }\\n      } else {\\n        memo.push(result)\\n      }\\n    }\\n\\n    tokens = memo\\n  }\\n\\n  return tokens\\n}\\n\\n/**\\n * Convenience method for passing a string through a pipeline and getting\\n * strings out. This method takes care of wrapping the passed string in a\\n * token and mapping the resulting tokens back to strings.\\n *\\n * @param {string} str - The string to pass through the pipeline.\\n * @param {?object} metadata - Optional metadata to associate with the token\\n * passed to the pipeline.\\n * @returns {string[]}\\n */\\nlunr.Pipeline.prototype.runString = function (str, metadata) {\\n  var token = new lunr.Token (str, metadata)\\n\\n  return this.run([token]).map(function (t) {\\n    return t.toString()\\n  })\\n}\\n\\n/**\\n * Resets the pipeline by removing any existing processors.\\n *\\n */\\nlunr.Pipeline.prototype.reset = function () {\\n  this._stack = []\\n}\\n\\n/**\\n * Returns a representation of the pipeline ready for serialisation.\\n *\\n * Logs a warning if the function has not been registered.\\n *\\n * @returns {Array}\\n */\\nlunr.Pipeline.prototype.toJSON = function () {\\n  return this._stack.map(function (fn) {\\n    lunr.Pipeline.warnIfFunctionNotRegistered(fn)\\n\\n    return fn.label\\n  })\\n}\\n/*!\\n * lunr.Vector\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A vector is used to construct the vector space of documents and queries. These\\n * vectors support operations to determine the similarity between two documents or\\n * a document and a query.\\n *\\n * Normally no parameters are required for initializing a vector, but in the case of\\n * loading a previously dumped vector the raw elements can be provided to the constructor.\\n *\\n * For performance reasons vectors are implemented with a flat array, where an elements\\n * index is immediately followed by its value. E.g. [index, value, index, value]. This\\n * allows the underlying array to be as sparse as possible and still offer decent\\n * performance when being used for vector calculations.\\n *\\n * @constructor\\n * @param {Number[]} [elements] - The flat list of element index and element value pairs.\\n */\\nlunr.Vector = function (elements) {\\n  this._magnitude = 0\\n  this.elements = elements || []\\n}\\n\\n\\n/**\\n * Calculates the position within the vector to insert a given index.\\n *\\n * This is used internally by insert and upsert. If there are duplicate indexes then\\n * the position is returned as if the value for that index were to be updated, but it\\n * is the callers responsibility to check whether there is a duplicate at that index\\n *\\n * @param {Number} insertIdx - The index at which the element should be inserted.\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.positionForIndex = function (index) {\\n  // For an empty vector the tuple can be inserted at the beginning\\n  if (this.elements.length == 0) {\\n    return 0\\n  }\\n\\n  var start = 0,\\n      end = this.elements.length / 2,\\n      sliceLength = end - start,\\n      pivotPoint = Math.floor(sliceLength / 2),\\n      pivotIndex = this.elements[pivotPoint * 2]\\n\\n  while (sliceLength > 1) {\\n    if (pivotIndex < index) {\\n      start = pivotPoint\\n    }\\n\\n    if (pivotIndex > index) {\\n      end = pivotPoint\\n    }\\n\\n    if (pivotIndex == index) {\\n      break\\n    }\\n\\n    sliceLength = end - start\\n    pivotPoint = start + Math.floor(sliceLength / 2)\\n    pivotIndex = this.elements[pivotPoint * 2]\\n  }\\n\\n  if (pivotIndex == index) {\\n    return pivotPoint * 2\\n  }\\n\\n  if (pivotIndex > index) {\\n    return pivotPoint * 2\\n  }\\n\\n  if (pivotIndex < index) {\\n    return (pivotPoint + 1) * 2\\n  }\\n}\\n\\n/**\\n * Inserts an element at an index within the vector.\\n *\\n * Does not allow duplicates, will throw an error if there is already an entry\\n * for this index.\\n *\\n * @param {Number} insertIdx - The index at which the element should be inserted.\\n * @param {Number} val - The value to be inserted into the vector.\\n */\\nlunr.Vector.prototype.insert = function (insertIdx, val) {\\n  this.upsert(insertIdx, val, function () {\\n    throw \\\"duplicate index\\\"\\n  })\\n}\\n\\n/**\\n * Inserts or updates an existing index within the vector.\\n *\\n * @param {Number} insertIdx - The index at which the element should be inserted.\\n * @param {Number} val - The value to be inserted into the vector.\\n * @param {function} fn - A function that is called for updates, the existing value and the\\n * requested value are passed as arguments\\n */\\nlunr.Vector.prototype.upsert = function (insertIdx, val, fn) {\\n  this._magnitude = 0\\n  var position = this.positionForIndex(insertIdx)\\n\\n  if (this.elements[position] == insertIdx) {\\n    this.elements[position + 1] = fn(this.elements[position + 1], val)\\n  } else {\\n    this.elements.splice(position, 0, insertIdx, val)\\n  }\\n}\\n\\n/**\\n * Calculates the magnitude of this vector.\\n *\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.magnitude = function () {\\n  if (this._magnitude) return this._magnitude\\n\\n  var sumOfSquares = 0,\\n      elementsLength = this.elements.length\\n\\n  for (var i = 1; i < elementsLength; i += 2) {\\n    var val = this.elements[i]\\n    sumOfSquares += val * val\\n  }\\n\\n  return this._magnitude = Math.sqrt(sumOfSquares)\\n}\\n\\n/**\\n * Calculates the dot product of this vector and another vector.\\n *\\n * @param {lunr.Vector} otherVector - The vector to compute the dot product with.\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.dot = function (otherVector) {\\n  var dotProduct = 0,\\n      a = this.elements, b = otherVector.elements,\\n      aLen = a.length, bLen = b.length,\\n      aVal = 0, bVal = 0,\\n      i = 0, j = 0\\n\\n  while (i < aLen && j < bLen) {\\n    aVal = a[i], bVal = b[j]\\n    if (aVal < bVal) {\\n      i += 2\\n    } else if (aVal > bVal) {\\n      j += 2\\n    } else if (aVal == bVal) {\\n      dotProduct += a[i + 1] * b[j + 1]\\n      i += 2\\n      j += 2\\n    }\\n  }\\n\\n  return dotProduct\\n}\\n\\n/**\\n * Calculates the similarity between this vector and another vector.\\n *\\n * @param {lunr.Vector} otherVector - The other vector to calculate the\\n * similarity with.\\n * @returns {Number}\\n */\\nlunr.Vector.prototype.similarity = function (otherVector) {\\n  return this.dot(otherVector) / this.magnitude() || 0\\n}\\n\\n/**\\n * Converts the vector to an array of the elements within the vector.\\n *\\n * @returns {Number[]}\\n */\\nlunr.Vector.prototype.toArray = function () {\\n  var output = new Array (this.elements.length / 2)\\n\\n  for (var i = 1, j = 0; i < this.elements.length; i += 2, j++) {\\n    output[j] = this.elements[i]\\n  }\\n\\n  return output\\n}\\n\\n/**\\n * A JSON serializable representation of the vector.\\n *\\n * @returns {Number[]}\\n */\\nlunr.Vector.prototype.toJSON = function () {\\n  return this.elements\\n}\\n/* eslint-disable */\\n/*!\\n * lunr.stemmer\\n * Copyright (C) 2020 Oliver Nightingale\\n * Includes code from - http://tartarus.org/~martin/PorterStemmer/js.txt\\n */\\n\\n/**\\n * lunr.stemmer is an english language stemmer, this is a JavaScript\\n * implementation of the PorterStemmer taken from http://tartarus.org/~martin\\n *\\n * @static\\n * @implements {lunr.PipelineFunction}\\n * @param {lunr.Token} token - The string to stem\\n * @returns {lunr.Token}\\n * @see {@link lunr.Pipeline}\\n * @function\\n */\\nlunr.stemmer = (function(){\\n  var step2list = {\\n      \\\"ational\\\" : \\\"ate\\\",\\n      \\\"tional\\\" : \\\"tion\\\",\\n      \\\"enci\\\" : \\\"ence\\\",\\n      \\\"anci\\\" : \\\"ance\\\",\\n      \\\"izer\\\" : \\\"ize\\\",\\n      \\\"bli\\\" : \\\"ble\\\",\\n      \\\"alli\\\" : \\\"al\\\",\\n      \\\"entli\\\" : \\\"ent\\\",\\n      \\\"eli\\\" : \\\"e\\\",\\n      \\\"ousli\\\" : \\\"ous\\\",\\n      \\\"ization\\\" : \\\"ize\\\",\\n      \\\"ation\\\" : \\\"ate\\\",\\n      \\\"ator\\\" : \\\"ate\\\",\\n      \\\"alism\\\" : \\\"al\\\",\\n      \\\"iveness\\\" : \\\"ive\\\",\\n      \\\"fulness\\\" : \\\"ful\\\",\\n      \\\"ousness\\\" : \\\"ous\\\",\\n      \\\"aliti\\\" : \\\"al\\\",\\n      \\\"iviti\\\" : \\\"ive\\\",\\n      \\\"biliti\\\" : \\\"ble\\\",\\n      \\\"logi\\\" : \\\"log\\\"\\n    },\\n\\n    step3list = {\\n      \\\"icate\\\" : \\\"ic\\\",\\n      \\\"ative\\\" : \\\"\\\",\\n      \\\"alize\\\" : \\\"al\\\",\\n      \\\"iciti\\\" : \\\"ic\\\",\\n      \\\"ical\\\" : \\\"ic\\\",\\n      \\\"ful\\\" : \\\"\\\",\\n      \\\"ness\\\" : \\\"\\\"\\n    },\\n\\n    c = \\\"[^aeiou]\\\",          // consonant\\n    v = \\\"[aeiouy]\\\",          // vowel\\n    C = c + \\\"[^aeiouy]*\\\",    // consonant sequence\\n    V = v + \\\"[aeiou]*\\\",      // vowel sequence\\n\\n    mgr0 = \\\"^(\\\" + C + \\\")?\\\" + V + C,               // [C]VC... is m>0\\n    meq1 = \\\"^(\\\" + C + \\\")?\\\" + V + C + \\\"(\\\" + V + \\\")?$\\\",  // [C]VC[V] is m=1\\n    mgr1 = \\\"^(\\\" + C + \\\")?\\\" + V + C + V + C,       // [C]VCVC... is m>1\\n    s_v = \\\"^(\\\" + C + \\\")?\\\" + v;                   // vowel in stem\\n\\n  var re_mgr0 = new RegExp(mgr0);\\n  var re_mgr1 = new RegExp(mgr1);\\n  var re_meq1 = new RegExp(meq1);\\n  var re_s_v = new RegExp(s_v);\\n\\n  var re_1a = /^(.+?)(ss|i)es$/;\\n  var re2_1a = /^(.+?)([^s])s$/;\\n  var re_1b = /^(.+?)eed$/;\\n  var re2_1b = /^(.+?)(ed|ing)$/;\\n  var re_1b_2 = /.$/;\\n  var re2_1b_2 = /(at|bl|iz)$/;\\n  var re3_1b_2 = new RegExp(\\\"([^aeiouylsz])\\\\\\\\1$\\\");\\n  var re4_1b_2 = new RegExp(\\\"^\\\" + C + v + \\\"[^aeiouwxy]$\\\");\\n\\n  var re_1c = /^(.+?[^aeiou])y$/;\\n  var re_2 = /^(.+?)(ational|tional|enci|anci|izer|bli|alli|entli|eli|ousli|ization|ation|ator|alism|iveness|fulness|ousness|aliti|iviti|biliti|logi)$/;\\n\\n  var re_3 = /^(.+?)(icate|ative|alize|iciti|ical|ful|ness)$/;\\n\\n  var re_4 = /^(.+?)(al|ance|ence|er|ic|able|ible|ant|ement|ment|ent|ou|ism|ate|iti|ous|ive|ize)$/;\\n  var re2_4 = /^(.+?)(s|t)(ion)$/;\\n\\n  var re_5 = /^(.+?)e$/;\\n  var re_5_1 = /ll$/;\\n  var re3_5 = new RegExp(\\\"^\\\" + C + v + \\\"[^aeiouwxy]$\\\");\\n\\n  var porterStemmer = function porterStemmer(w) {\\n    var stem,\\n      suffix,\\n      firstch,\\n      re,\\n      re2,\\n      re3,\\n      re4;\\n\\n    if (w.length < 3) { return w; }\\n\\n    firstch = w.substr(0,1);\\n    if (firstch == \\\"y\\\") {\\n      w = firstch.toUpperCase() + w.substr(1);\\n    }\\n\\n    // Step 1a\\n    re = re_1a\\n    re2 = re2_1a;\\n\\n    if (re.test(w)) { w = w.replace(re,\\\"$1$2\\\"); }\\n    else if (re2.test(w)) { w = w.replace(re2,\\\"$1$2\\\"); }\\n\\n    // Step 1b\\n    re = re_1b;\\n    re2 = re2_1b;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      re = re_mgr0;\\n      if (re.test(fp[1])) {\\n        re = re_1b_2;\\n        w = w.replace(re,\\\"\\\");\\n      }\\n    } else if (re2.test(w)) {\\n      var fp = re2.exec(w);\\n      stem = fp[1];\\n      re2 = re_s_v;\\n      if (re2.test(stem)) {\\n        w = stem;\\n        re2 = re2_1b_2;\\n        re3 = re3_1b_2;\\n        re4 = re4_1b_2;\\n        if (re2.test(w)) { w = w + \\\"e\\\"; }\\n        else if (re3.test(w)) { re = re_1b_2; w = w.replace(re,\\\"\\\"); }\\n        else if (re4.test(w)) { w = w + \\\"e\\\"; }\\n      }\\n    }\\n\\n    // Step 1c - replace suffix y or Y by i if preceded by a non-vowel which is not the first letter of the word (so cry -> cri, by -> by, say -> say)\\n    re = re_1c;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      w = stem + \\\"i\\\";\\n    }\\n\\n    // Step 2\\n    re = re_2;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      suffix = fp[2];\\n      re = re_mgr0;\\n      if (re.test(stem)) {\\n        w = stem + step2list[suffix];\\n      }\\n    }\\n\\n    // Step 3\\n    re = re_3;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      suffix = fp[2];\\n      re = re_mgr0;\\n      if (re.test(stem)) {\\n        w = stem + step3list[suffix];\\n      }\\n    }\\n\\n    // Step 4\\n    re = re_4;\\n    re2 = re2_4;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      re = re_mgr1;\\n      if (re.test(stem)) {\\n        w = stem;\\n      }\\n    } else if (re2.test(w)) {\\n      var fp = re2.exec(w);\\n      stem = fp[1] + fp[2];\\n      re2 = re_mgr1;\\n      if (re2.test(stem)) {\\n        w = stem;\\n      }\\n    }\\n\\n    // Step 5\\n    re = re_5;\\n    if (re.test(w)) {\\n      var fp = re.exec(w);\\n      stem = fp[1];\\n      re = re_mgr1;\\n      re2 = re_meq1;\\n      re3 = re3_5;\\n      if (re.test(stem) || (re2.test(stem) && !(re3.test(stem)))) {\\n        w = stem;\\n      }\\n    }\\n\\n    re = re_5_1;\\n    re2 = re_mgr1;\\n    if (re.test(w) && re2.test(w)) {\\n      re = re_1b_2;\\n      w = w.replace(re,\\\"\\\");\\n    }\\n\\n    // and turn initial Y back to y\\n\\n    if (firstch == \\\"y\\\") {\\n      w = firstch.toLowerCase() + w.substr(1);\\n    }\\n\\n    return w;\\n  };\\n\\n  return function (token) {\\n    return token.update(porterStemmer);\\n  }\\n})();\\n\\nlunr.Pipeline.registerFunction(lunr.stemmer, 'stemmer')\\n/*!\\n * lunr.stopWordFilter\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.generateStopWordFilter builds a stopWordFilter function from the provided\\n * list of stop words.\\n *\\n * The built in lunr.stopWordFilter is built using this generator and can be used\\n * to generate custom stopWordFilters for applications or non English languages.\\n *\\n * @function\\n * @param {Array} token The token to pass through the filter\\n * @returns {lunr.PipelineFunction}\\n * @see lunr.Pipeline\\n * @see lunr.stopWordFilter\\n */\\nlunr.generateStopWordFilter = function (stopWords) {\\n  var words = stopWords.reduce(function (memo, stopWord) {\\n    memo[stopWord] = stopWord\\n    return memo\\n  }, {})\\n\\n  return function (token) {\\n    if (token && words[token.toString()] !== token.toString()) return token\\n  }\\n}\\n\\n/**\\n * lunr.stopWordFilter is an English language stop word list filter, any words\\n * contained in the list will not be passed through the filter.\\n *\\n * This is intended to be used in the Pipeline. If the token does not pass the\\n * filter then undefined will be returned.\\n *\\n * @function\\n * @implements {lunr.PipelineFunction}\\n * @params {lunr.Token} token - A token to check for being a stop word.\\n * @returns {lunr.Token}\\n * @see {@link lunr.Pipeline}\\n */\\nlunr.stopWordFilter = lunr.generateStopWordFilter([\\n  'a',\\n  'able',\\n  'about',\\n  'across',\\n  'after',\\n  'all',\\n  'almost',\\n  'also',\\n  'am',\\n  'among',\\n  'an',\\n  'and',\\n  'any',\\n  'are',\\n  'as',\\n  'at',\\n  'be',\\n  'because',\\n  'been',\\n  'but',\\n  'by',\\n  'can',\\n  'cannot',\\n  'could',\\n  'dear',\\n  'did',\\n  'do',\\n  'does',\\n  'either',\\n  'else',\\n  'ever',\\n  'every',\\n  'for',\\n  'from',\\n  'get',\\n  'got',\\n  'had',\\n  'has',\\n  'have',\\n  'he',\\n  'her',\\n  'hers',\\n  'him',\\n  'his',\\n  'how',\\n  'however',\\n  'i',\\n  'if',\\n  'in',\\n  'into',\\n  'is',\\n  'it',\\n  'its',\\n  'just',\\n  'least',\\n  'let',\\n  'like',\\n  'likely',\\n  'may',\\n  'me',\\n  'might',\\n  'most',\\n  'must',\\n  'my',\\n  'neither',\\n  'no',\\n  'nor',\\n  'not',\\n  'of',\\n  'off',\\n  'often',\\n  'on',\\n  'only',\\n  'or',\\n  'other',\\n  'our',\\n  'own',\\n  'rather',\\n  'said',\\n  'say',\\n  'says',\\n  'she',\\n  'should',\\n  'since',\\n  'so',\\n  'some',\\n  'than',\\n  'that',\\n  'the',\\n  'their',\\n  'them',\\n  'then',\\n  'there',\\n  'these',\\n  'they',\\n  'this',\\n  'tis',\\n  'to',\\n  'too',\\n  'twas',\\n  'us',\\n  'wants',\\n  'was',\\n  'we',\\n  'were',\\n  'what',\\n  'when',\\n  'where',\\n  'which',\\n  'while',\\n  'who',\\n  'whom',\\n  'why',\\n  'will',\\n  'with',\\n  'would',\\n  'yet',\\n  'you',\\n  'your'\\n])\\n\\nlunr.Pipeline.registerFunction(lunr.stopWordFilter, 'stopWordFilter')\\n/*!\\n * lunr.trimmer\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.trimmer is a pipeline function for trimming non word\\n * characters from the beginning and end of tokens before they\\n * enter the index.\\n *\\n * This implementation may not work correctly for non latin\\n * characters and should either be removed or adapted for use\\n * with languages with non-latin characters.\\n *\\n * @static\\n * @implements {lunr.PipelineFunction}\\n * @param {lunr.Token} token The token to pass through the filter\\n * @returns {lunr.Token}\\n * @see lunr.Pipeline\\n */\\nlunr.trimmer = function (token) {\\n  return token.update(function (s) {\\n    return s.replace(/^\\\\W+/, '').replace(/\\\\W+$/, '')\\n  })\\n}\\n\\nlunr.Pipeline.registerFunction(lunr.trimmer, 'trimmer')\\n/*!\\n * lunr.TokenSet\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * A token set is used to store the unique list of all tokens\\n * within an index. Token sets are also used to represent an\\n * incoming query to the index, this query token set and index\\n * token set are then intersected to find which tokens to look\\n * up in the inverted index.\\n *\\n * A token set can hold multiple tokens, as in the case of the\\n * index token set, or it can hold a single token as in the\\n * case of a simple query token set.\\n *\\n * Additionally token sets are used to perform wildcard matching.\\n * Leading, contained and trailing wildcards are supported, and\\n * from this edit distance matching can also be provided.\\n *\\n * Token sets are implemented as a minimal finite state automata,\\n * where both common prefixes and suffixes are shared between tokens.\\n * This helps to reduce the space used for storing the token set.\\n *\\n * @constructor\\n */\\nlunr.TokenSet = function () {\\n  this.final = false\\n  this.edges = {}\\n  this.id = lunr.TokenSet._nextId\\n  lunr.TokenSet._nextId += 1\\n}\\n\\n/**\\n * Keeps track of the next, auto increment, identifier to assign\\n * to a new tokenSet.\\n *\\n * TokenSets require a unique identifier to be correctly minimised.\\n *\\n * @private\\n */\\nlunr.TokenSet._nextId = 1\\n\\n/**\\n * Creates a TokenSet instance from the given sorted array of words.\\n *\\n * @param {String[]} arr - A sorted array of strings to create the set from.\\n * @returns {lunr.TokenSet}\\n * @throws Will throw an error if the input array is not sorted.\\n */\\nlunr.TokenSet.fromArray = function (arr) {\\n  var builder = new lunr.TokenSet.Builder\\n\\n  for (var i = 0, len = arr.length; i < len; i++) {\\n    builder.insert(arr[i])\\n  }\\n\\n  builder.finish()\\n  return builder.root\\n}\\n\\n/**\\n * Creates a token set from a query clause.\\n *\\n * @private\\n * @param {Object} clause - A single clause from lunr.Query.\\n * @param {string} clause.term - The query clause term.\\n * @param {number} [clause.editDistance] - The optional edit distance for the term.\\n * @returns {lunr.TokenSet}\\n */\\nlunr.TokenSet.fromClause = function (clause) {\\n  if ('editDistance' in clause) {\\n    return lunr.TokenSet.fromFuzzyString(clause.term, clause.editDistance)\\n  } else {\\n    return lunr.TokenSet.fromString(clause.term)\\n  }\\n}\\n\\n/**\\n * Creates a token set representing a single string with a specified\\n * edit distance.\\n *\\n * Insertions, deletions, substitutions and transpositions are each\\n * treated as an edit distance of 1.\\n *\\n * Increasing the allowed edit distance will have a dramatic impact\\n * on the performance of both creating and intersecting these TokenSets.\\n * It is advised to keep the edit distance less than 3.\\n *\\n * @param {string} str - The string to create the token set from.\\n * @param {number} editDistance - The allowed edit distance to match.\\n * @returns {lunr.Vector}\\n */\\nlunr.TokenSet.fromFuzzyString = function (str, editDistance) {\\n  var root = new lunr.TokenSet\\n\\n  var stack = [{\\n    node: root,\\n    editsRemaining: editDistance,\\n    str: str\\n  }]\\n\\n  while (stack.length) {\\n    var frame = stack.pop()\\n\\n    // no edit\\n    if (frame.str.length > 0) {\\n      var char = frame.str.charAt(0),\\n          noEditNode\\n\\n      if (char in frame.node.edges) {\\n        noEditNode = frame.node.edges[char]\\n      } else {\\n        noEditNode = new lunr.TokenSet\\n        frame.node.edges[char] = noEditNode\\n      }\\n\\n      if (frame.str.length == 1) {\\n        noEditNode.final = true\\n      }\\n\\n      stack.push({\\n        node: noEditNode,\\n        editsRemaining: frame.editsRemaining,\\n        str: frame.str.slice(1)\\n      })\\n    }\\n\\n    if (frame.editsRemaining == 0) {\\n      continue\\n    }\\n\\n    // insertion\\n    if (\\\"*\\\" in frame.node.edges) {\\n      var insertionNode = frame.node.edges[\\\"*\\\"]\\n    } else {\\n      var insertionNode = new lunr.TokenSet\\n      frame.node.edges[\\\"*\\\"] = insertionNode\\n    }\\n\\n    if (frame.str.length == 0) {\\n      insertionNode.final = true\\n    }\\n\\n    stack.push({\\n      node: insertionNode,\\n      editsRemaining: frame.editsRemaining - 1,\\n      str: frame.str\\n    })\\n\\n    // deletion\\n    // can only do a deletion if we have enough edits remaining\\n    // and if there are characters left to delete in the string\\n    if (frame.str.length > 1) {\\n      stack.push({\\n        node: frame.node,\\n        editsRemaining: frame.editsRemaining - 1,\\n        str: frame.str.slice(1)\\n      })\\n    }\\n\\n    // deletion\\n    // just removing the last character from the str\\n    if (frame.str.length == 1) {\\n      frame.node.final = true\\n    }\\n\\n    // substitution\\n    // can only do a substitution if we have enough edits remaining\\n    // and if there are characters left to substitute\\n    if (frame.str.length >= 1) {\\n      if (\\\"*\\\" in frame.node.edges) {\\n        var substitutionNode = frame.node.edges[\\\"*\\\"]\\n      } else {\\n        var substitutionNode = new lunr.TokenSet\\n        frame.node.edges[\\\"*\\\"] = substitutionNode\\n      }\\n\\n      if (frame.str.length == 1) {\\n        substitutionNode.final = true\\n      }\\n\\n      stack.push({\\n        node: substitutionNode,\\n        editsRemaining: frame.editsRemaining - 1,\\n        str: frame.str.slice(1)\\n      })\\n    }\\n\\n    // transposition\\n    // can only do a transposition if there are edits remaining\\n    // and there are enough characters to transpose\\n    if (frame.str.length > 1) {\\n      var charA = frame.str.charAt(0),\\n          charB = frame.str.charAt(1),\\n          transposeNode\\n\\n      if (charB in frame.node.edges) {\\n        transposeNode = frame.node.edges[charB]\\n      } else {\\n        transposeNode = new lunr.TokenSet\\n        frame.node.edges[charB] = transposeNode\\n      }\\n\\n      if (frame.str.length == 1) {\\n        transposeNode.final = true\\n      }\\n\\n      stack.push({\\n        node: transposeNode,\\n        editsRemaining: frame.editsRemaining - 1,\\n        str: charA + frame.str.slice(2)\\n      })\\n    }\\n  }\\n\\n  return root\\n}\\n\\n/**\\n * Creates a TokenSet from a string.\\n *\\n * The string may contain one or more wildcard characters (*)\\n * that will allow wildcard matching when intersecting with\\n * another TokenSet.\\n *\\n * @param {string} str - The string to create a TokenSet from.\\n * @returns {lunr.TokenSet}\\n */\\nlunr.TokenSet.fromString = function (str) {\\n  var node = new lunr.TokenSet,\\n      root = node\\n\\n  /*\\n   * Iterates through all characters within the passed string\\n   * appending a node for each character.\\n   *\\n   * When a wildcard character is found then a self\\n   * referencing edge is introduced to continually match\\n   * any number of any characters.\\n   */\\n  for (var i = 0, len = str.length; i < len; i++) {\\n    var char = str[i],\\n        final = (i == len - 1)\\n\\n    if (char == \\\"*\\\") {\\n      node.edges[char] = node\\n      node.final = final\\n\\n    } else {\\n      var next = new lunr.TokenSet\\n      next.final = final\\n\\n      node.edges[char] = next\\n      node = next\\n    }\\n  }\\n\\n  return root\\n}\\n\\n/**\\n * Converts this TokenSet into an array of strings\\n * contained within the TokenSet.\\n *\\n * This is not intended to be used on a TokenSet that\\n * contains wildcards, in these cases the results are\\n * undefined and are likely to cause an infinite loop.\\n *\\n * @returns {string[]}\\n */\\nlunr.TokenSet.prototype.toArray = function () {\\n  var words = []\\n\\n  var stack = [{\\n    prefix: \\\"\\\",\\n    node: this\\n  }]\\n\\n  while (stack.length) {\\n    var frame = stack.pop(),\\n        edges = Object.keys(frame.node.edges),\\n        len = edges.length\\n\\n    if (frame.node.final) {\\n      /* In Safari, at this point the prefix is sometimes corrupted, see:\\n       * https://github.com/olivernn/lunr.js/issues/279 Calling any\\n       * String.prototype method forces Safari to \\\"cast\\\" this string to what\\n       * it's supposed to be, fixing the bug. */\\n      frame.prefix.charAt(0)\\n      words.push(frame.prefix)\\n    }\\n\\n    for (var i = 0; i < len; i++) {\\n      var edge = edges[i]\\n\\n      stack.push({\\n        prefix: frame.prefix.concat(edge),\\n        node: frame.node.edges[edge]\\n      })\\n    }\\n  }\\n\\n  return words\\n}\\n\\n/**\\n * Generates a string representation of a TokenSet.\\n *\\n * This is intended to allow TokenSets to be used as keys\\n * in objects, largely to aid the construction and minimisation\\n * of a TokenSet. As such it is not designed to be a human\\n * friendly representation of the TokenSet.\\n *\\n * @returns {string}\\n */\\nlunr.TokenSet.prototype.toString = function () {\\n  // NOTE: Using Object.keys here as this.edges is very likely\\n  // to enter 'hash-mode' with many keys being added\\n  //\\n  // avoiding a for-in loop here as it leads to the function\\n  // being de-optimised (at least in V8). From some simple\\n  // benchmarks the performance is comparable, but allowing\\n  // V8 to optimize may mean easy performance wins in the future.\\n\\n  if (this._str) {\\n    return this._str\\n  }\\n\\n  var str = this.final ? '1' : '0',\\n      labels = Object.keys(this.edges).sort(),\\n      len = labels.length\\n\\n  for (var i = 0; i < len; i++) {\\n    var label = labels[i],\\n        node = this.edges[label]\\n\\n    str = str + label + node.id\\n  }\\n\\n  return str\\n}\\n\\n/**\\n * Returns a new TokenSet that is the intersection of\\n * this TokenSet and the passed TokenSet.\\n *\\n * This intersection will take into account any wildcards\\n * contained within the TokenSet.\\n *\\n * @param {lunr.TokenSet} b - An other TokenSet to intersect with.\\n * @returns {lunr.TokenSet}\\n */\\nlunr.TokenSet.prototype.intersect = function (b) {\\n  var output = new lunr.TokenSet,\\n      frame = undefined\\n\\n  var stack = [{\\n    qNode: b,\\n    output: output,\\n    node: this\\n  }]\\n\\n  while (stack.length) {\\n    frame = stack.pop()\\n\\n    // NOTE: As with the #toString method, we are using\\n    // Object.keys and a for loop instead of a for-in loop\\n    // as both of these objects enter 'hash' mode, causing\\n    // the function to be de-optimised in V8\\n    var qEdges = Object.keys(frame.qNode.edges),\\n        qLen = qEdges.length,\\n        nEdges = Object.keys(frame.node.edges),\\n        nLen = nEdges.length\\n\\n    for (var q = 0; q < qLen; q++) {\\n      var qEdge = qEdges[q]\\n\\n      for (var n = 0; n < nLen; n++) {\\n        var nEdge = nEdges[n]\\n\\n        if (nEdge == qEdge || qEdge == '*') {\\n          var node = frame.node.edges[nEdge],\\n              qNode = frame.qNode.edges[qEdge],\\n              final = node.final && qNode.final,\\n              next = undefined\\n\\n          if (nEdge in frame.output.edges) {\\n            // an edge already exists for this character\\n            // no need to create a new node, just set the finality\\n            // bit unless this node is already final\\n            next = frame.output.edges[nEdge]\\n            next.final = next.final || final\\n\\n          } else {\\n            // no edge exists yet, must create one\\n            // set the finality bit and insert it\\n            // into the output\\n            next = new lunr.TokenSet\\n            next.final = final\\n            frame.output.edges[nEdge] = next\\n          }\\n\\n          stack.push({\\n            qNode: qNode,\\n            output: next,\\n            node: node\\n          })\\n        }\\n      }\\n    }\\n  }\\n\\n  return output\\n}\\nlunr.TokenSet.Builder = function () {\\n  this.previousWord = \\\"\\\"\\n  this.root = new lunr.TokenSet\\n  this.uncheckedNodes = []\\n  this.minimizedNodes = {}\\n}\\n\\nlunr.TokenSet.Builder.prototype.insert = function (word) {\\n  var node,\\n      commonPrefix = 0\\n\\n  if (word < this.previousWord) {\\n    throw new Error (\\\"Out of order word insertion\\\")\\n  }\\n\\n  for (var i = 0; i < word.length && i < this.previousWord.length; i++) {\\n    if (word[i] != this.previousWord[i]) break\\n    commonPrefix++\\n  }\\n\\n  this.minimize(commonPrefix)\\n\\n  if (this.uncheckedNodes.length == 0) {\\n    node = this.root\\n  } else {\\n    node = this.uncheckedNodes[this.uncheckedNodes.length - 1].child\\n  }\\n\\n  for (var i = commonPrefix; i < word.length; i++) {\\n    var nextNode = new lunr.TokenSet,\\n        char = word[i]\\n\\n    node.edges[char] = nextNode\\n\\n    this.uncheckedNodes.push({\\n      parent: node,\\n      char: char,\\n      child: nextNode\\n    })\\n\\n    node = nextNode\\n  }\\n\\n  node.final = true\\n  this.previousWord = word\\n}\\n\\nlunr.TokenSet.Builder.prototype.finish = function () {\\n  this.minimize(0)\\n}\\n\\nlunr.TokenSet.Builder.prototype.minimize = function (downTo) {\\n  for (var i = this.uncheckedNodes.length - 1; i >= downTo; i--) {\\n    var node = this.uncheckedNodes[i],\\n        childKey = node.child.toString()\\n\\n    if (childKey in this.minimizedNodes) {\\n      node.parent.edges[node.char] = this.minimizedNodes[childKey]\\n    } else {\\n      // Cache the key for this node since\\n      // we know it can't change anymore\\n      node.child._str = childKey\\n\\n      this.minimizedNodes[childKey] = node.child\\n    }\\n\\n    this.uncheckedNodes.pop()\\n  }\\n}\\n/*!\\n * lunr.Index\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * An index contains the built index of all documents and provides a query interface\\n * to the index.\\n *\\n * Usually instances of lunr.Index will not be created using this constructor, instead\\n * lunr.Builder should be used to construct new indexes, or lunr.Index.load should be\\n * used to load previously built and serialized indexes.\\n *\\n * @constructor\\n * @param {Object} attrs - The attributes of the built search index.\\n * @param {Object} attrs.invertedIndex - An index of term/field to document reference.\\n * @param {Object<string, lunr.Vector>} attrs.fieldVectors - Field vectors\\n * @param {lunr.TokenSet} attrs.tokenSet - An set of all corpus tokens.\\n * @param {string[]} attrs.fields - The names of indexed document fields.\\n * @param {lunr.Pipeline} attrs.pipeline - The pipeline to use for search terms.\\n */\\nlunr.Index = function (attrs) {\\n  this.invertedIndex = attrs.invertedIndex\\n  this.fieldVectors = attrs.fieldVectors\\n  this.tokenSet = attrs.tokenSet\\n  this.fields = attrs.fields\\n  this.pipeline = attrs.pipeline\\n}\\n\\n/**\\n * A result contains details of a document matching a search query.\\n * @typedef {Object} lunr.Index~Result\\n * @property {string} ref - The reference of the document this result represents.\\n * @property {number} score - A number between 0 and 1 representing how similar this document is to the query.\\n * @property {lunr.MatchData} matchData - Contains metadata about this match including which term(s) caused the match.\\n */\\n\\n/**\\n * Although lunr provides the ability to create queries using lunr.Query, it also provides a simple\\n * query language which itself is parsed into an instance of lunr.Query.\\n *\\n * For programmatically building queries it is advised to directly use lunr.Query, the query language\\n * is best used for human entered text rather than program generated text.\\n *\\n * At its simplest queries can just be a single term, e.g. `hello`, multiple terms are also supported\\n * and will be combined with OR, e.g `hello world` will match documents that contain either 'hello'\\n * or 'world', though those that contain both will rank higher in the results.\\n *\\n * Wildcards can be included in terms to match one or more unspecified characters, these wildcards can\\n * be inserted anywhere within the term, and more than one wildcard can exist in a single term. Adding\\n * wildcards will increase the number of documents that will be found but can also have a negative\\n * impact on query performance, especially with wildcards at the beginning of a term.\\n *\\n * Terms can be restricted to specific fields, e.g. `title:hello`, only documents with the term\\n * hello in the title field will match this query. Using a field not present in the index will lead\\n * to an error being thrown.\\n *\\n * Modifiers can also be added to terms, lunr supports edit distance and boost modifiers on terms. A term\\n * boost will make documents matching that term score higher, e.g. `foo^5`. Edit distance is also supported\\n * to provide fuzzy matching, e.g. 'hello~2' will match documents with hello with an edit distance of 2.\\n * Avoid large values for edit distance to improve query performance.\\n *\\n * Each term also supports a presence modifier. By default a term's presence in document is optional, however\\n * this can be changed to either required or prohibited. For a term's presence to be required in a document the\\n * term should be prefixed with a '+', e.g. `+foo bar` is a search for documents that must contain 'foo' and\\n * optionally contain 'bar'. Conversely a leading '-' sets the terms presence to prohibited, i.e. it must not\\n * appear in a document, e.g. `-foo bar` is a search for documents that do not contain 'foo' but may contain 'bar'.\\n *\\n * To escape special characters the backslash character '\\\\' can be used, this allows searches to include\\n * characters that would normally be considered modifiers, e.g. `foo\\\\~2` will search for a term \\\"foo~2\\\" instead\\n * of attempting to apply a boost of 2 to the search term \\\"foo\\\".\\n *\\n * @typedef {string} lunr.Index~QueryString\\n * @example <caption>Simple single term query</caption>\\n * hello\\n * @example <caption>Multiple term query</caption>\\n * hello world\\n * @example <caption>term scoped to a field</caption>\\n * title:hello\\n * @example <caption>term with a boost of 10</caption>\\n * hello^10\\n * @example <caption>term with an edit distance of 2</caption>\\n * hello~2\\n * @example <caption>terms with presence modifiers</caption>\\n * -foo +bar baz\\n */\\n\\n/**\\n * Performs a search against the index using lunr query syntax.\\n *\\n * Results will be returned sorted by their score, the most relevant results\\n * will be returned first.  For details on how the score is calculated, please see\\n * the {@link https://lunrjs.com/guides/searching.html#scoring|guide}.\\n *\\n * For more programmatic querying use lunr.Index#query.\\n *\\n * @param {lunr.Index~QueryString} queryString - A string containing a lunr query.\\n * @throws {lunr.QueryParseError} If the passed query string cannot be parsed.\\n * @returns {lunr.Index~Result[]}\\n */\\nlunr.Index.prototype.search = function (queryString) {\\n  return this.query(function (query) {\\n    var parser = new lunr.QueryParser(queryString, query)\\n    parser.parse()\\n  })\\n}\\n\\n/**\\n * A query builder callback provides a query object to be used to express\\n * the query to perform on the index.\\n *\\n * @callback lunr.Index~queryBuilder\\n * @param {lunr.Query} query - The query object to build up.\\n * @this lunr.Query\\n */\\n\\n/**\\n * Performs a query against the index using the yielded lunr.Query object.\\n *\\n * If performing programmatic queries against the index, this method is preferred\\n * over lunr.Index#search so as to avoid the additional query parsing overhead.\\n *\\n * A query object is yielded to the supplied function which should be used to\\n * express the query to be run against the index.\\n *\\n * Note that although this function takes a callback parameter it is _not_ an\\n * asynchronous operation, the callback is just yielded a query object to be\\n * customized.\\n *\\n * @param {lunr.Index~queryBuilder} fn - A function that is used to build the query.\\n * @returns {lunr.Index~Result[]}\\n */\\nlunr.Index.prototype.query = function (fn) {\\n  // for each query clause\\n  // * process terms\\n  // * expand terms from token set\\n  // * find matching documents and metadata\\n  // * get document vectors\\n  // * score documents\\n\\n  var query = new lunr.Query(this.fields),\\n      matchingFields = Object.create(null),\\n      queryVectors = Object.create(null),\\n      termFieldCache = Object.create(null),\\n      requiredMatches = Object.create(null),\\n      prohibitedMatches = Object.create(null)\\n\\n  /*\\n   * To support field level boosts a query vector is created per\\n   * field. An empty vector is eagerly created to support negated\\n   * queries.\\n   */\\n  for (var i = 0; i < this.fields.length; i++) {\\n    queryVectors[this.fields[i]] = new lunr.Vector\\n  }\\n\\n  fn.call(query, query)\\n\\n  for (var i = 0; i < query.clauses.length; i++) {\\n    /*\\n     * Unless the pipeline has been disabled for this term, which is\\n     * the case for terms with wildcards, we need to pass the clause\\n     * term through the search pipeline. A pipeline returns an array\\n     * of processed terms. Pipeline functions may expand the passed\\n     * term, which means we may end up performing multiple index lookups\\n     * for a single query term.\\n     */\\n    var clause = query.clauses[i],\\n        terms = null,\\n        clauseMatches = lunr.Set.empty\\n\\n    if (clause.usePipeline) {\\n      terms = this.pipeline.runString(clause.term, {\\n        fields: clause.fields\\n      })\\n    } else {\\n      terms = [clause.term]\\n    }\\n\\n    for (var m = 0; m < terms.length; m++) {\\n      var term = terms[m]\\n\\n      /*\\n       * Each term returned from the pipeline needs to use the same query\\n       * clause object, e.g. the same boost and or edit distance. The\\n       * simplest way to do this is to re-use the clause object but mutate\\n       * its term property.\\n       */\\n      clause.term = term\\n\\n      /*\\n       * From the term in the clause we create a token set which will then\\n       * be used to intersect the indexes token set to get a list of terms\\n       * to lookup in the inverted index\\n       */\\n      var termTokenSet = lunr.TokenSet.fromClause(clause),\\n          expandedTerms = this.tokenSet.intersect(termTokenSet).toArray()\\n\\n      /*\\n       * If a term marked as required does not exist in the tokenSet it is\\n       * impossible for the search to return any matches. We set all the field\\n       * scoped required matches set to empty and stop examining any further\\n       * clauses.\\n       */\\n      if (expandedTerms.length === 0 && clause.presence === lunr.Query.presence.REQUIRED) {\\n        for (var k = 0; k < clause.fields.length; k++) {\\n          var field = clause.fields[k]\\n          requiredMatches[field] = lunr.Set.empty\\n        }\\n\\n        break\\n      }\\n\\n      for (var j = 0; j < expandedTerms.length; j++) {\\n        /*\\n         * For each term get the posting and termIndex, this is required for\\n         * building the query vector.\\n         */\\n        var expandedTerm = expandedTerms[j],\\n            posting = this.invertedIndex[expandedTerm],\\n            termIndex = posting._index\\n\\n        for (var k = 0; k < clause.fields.length; k++) {\\n          /*\\n           * For each field that this query term is scoped by (by default\\n           * all fields are in scope) we need to get all the document refs\\n           * that have this term in that field.\\n           *\\n           * The posting is the entry in the invertedIndex for the matching\\n           * term from above.\\n           */\\n          var field = clause.fields[k],\\n              fieldPosting = posting[field],\\n              matchingDocumentRefs = Object.keys(fieldPosting),\\n              termField = expandedTerm + \\\"/\\\" + field,\\n              matchingDocumentsSet = new lunr.Set(matchingDocumentRefs)\\n\\n          /*\\n           * if the presence of this term is required ensure that the matching\\n           * documents are added to the set of required matches for this clause.\\n           *\\n           */\\n          if (clause.presence == lunr.Query.presence.REQUIRED) {\\n            clauseMatches = clauseMatches.union(matchingDocumentsSet)\\n\\n            if (requiredMatches[field] === undefined) {\\n              requiredMatches[field] = lunr.Set.complete\\n            }\\n          }\\n\\n          /*\\n           * if the presence of this term is prohibited ensure that the matching\\n           * documents are added to the set of prohibited matches for this field,\\n           * creating that set if it does not yet exist.\\n           */\\n          if (clause.presence == lunr.Query.presence.PROHIBITED) {\\n            if (prohibitedMatches[field] === undefined) {\\n              prohibitedMatches[field] = lunr.Set.empty\\n            }\\n\\n            prohibitedMatches[field] = prohibitedMatches[field].union(matchingDocumentsSet)\\n\\n            /*\\n             * Prohibited matches should not be part of the query vector used for\\n             * similarity scoring and no metadata should be extracted so we continue\\n             * to the next field\\n             */\\n            continue\\n          }\\n\\n          /*\\n           * The query field vector is populated using the termIndex found for\\n           * the term and a unit value with the appropriate boost applied.\\n           * Using upsert because there could already be an entry in the vector\\n           * for the term we are working with. In that case we just add the scores\\n           * together.\\n           */\\n          queryVectors[field].upsert(termIndex, clause.boost, function (a, b) { return a + b })\\n\\n          /**\\n           * If we've already seen this term, field combo then we've already collected\\n           * the matching documents and metadata, no need to go through all that again\\n           */\\n          if (termFieldCache[termField]) {\\n            continue\\n          }\\n\\n          for (var l = 0; l < matchingDocumentRefs.length; l++) {\\n            /*\\n             * All metadata for this term/field/document triple\\n             * are then extracted and collected into an instance\\n             * of lunr.MatchData ready to be returned in the query\\n             * results\\n             */\\n            var matchingDocumentRef = matchingDocumentRefs[l],\\n                matchingFieldRef = new lunr.FieldRef (matchingDocumentRef, field),\\n                metadata = fieldPosting[matchingDocumentRef],\\n                fieldMatch\\n\\n            if ((fieldMatch = matchingFields[matchingFieldRef]) === undefined) {\\n              matchingFields[matchingFieldRef] = new lunr.MatchData (expandedTerm, field, metadata)\\n            } else {\\n              fieldMatch.add(expandedTerm, field, metadata)\\n            }\\n\\n          }\\n\\n          termFieldCache[termField] = true\\n        }\\n      }\\n    }\\n\\n    /**\\n     * If the presence was required we need to update the requiredMatches field sets.\\n     * We do this after all fields for the term have collected their matches because\\n     * the clause terms presence is required in _any_ of the fields not _all_ of the\\n     * fields.\\n     */\\n    if (clause.presence === lunr.Query.presence.REQUIRED) {\\n      for (var k = 0; k < clause.fields.length; k++) {\\n        var field = clause.fields[k]\\n        requiredMatches[field] = requiredMatches[field].intersect(clauseMatches)\\n      }\\n    }\\n  }\\n\\n  /**\\n   * Need to combine the field scoped required and prohibited\\n   * matching documents into a global set of required and prohibited\\n   * matches\\n   */\\n  var allRequiredMatches = lunr.Set.complete,\\n      allProhibitedMatches = lunr.Set.empty\\n\\n  for (var i = 0; i < this.fields.length; i++) {\\n    var field = this.fields[i]\\n\\n    if (requiredMatches[field]) {\\n      allRequiredMatches = allRequiredMatches.intersect(requiredMatches[field])\\n    }\\n\\n    if (prohibitedMatches[field]) {\\n      allProhibitedMatches = allProhibitedMatches.union(prohibitedMatches[field])\\n    }\\n  }\\n\\n  var matchingFieldRefs = Object.keys(matchingFields),\\n      results = [],\\n      matches = Object.create(null)\\n\\n  /*\\n   * If the query is negated (contains only prohibited terms)\\n   * we need to get _all_ fieldRefs currently existing in the\\n   * index. This is only done when we know that the query is\\n   * entirely prohibited terms to avoid any cost of getting all\\n   * fieldRefs unnecessarily.\\n   *\\n   * Additionally, blank MatchData must be created to correctly\\n   * populate the results.\\n   */\\n  if (query.isNegated()) {\\n    matchingFieldRefs = Object.keys(this.fieldVectors)\\n\\n    for (var i = 0; i < matchingFieldRefs.length; i++) {\\n      var matchingFieldRef = matchingFieldRefs[i]\\n      var fieldRef = lunr.FieldRef.fromString(matchingFieldRef)\\n      matchingFields[matchingFieldRef] = new lunr.MatchData\\n    }\\n  }\\n\\n  for (var i = 0; i < matchingFieldRefs.length; i++) {\\n    /*\\n     * Currently we have document fields that match the query, but we\\n     * need to return documents. The matchData and scores are combined\\n     * from multiple fields belonging to the same document.\\n     *\\n     * Scores are calculated by field, using the query vectors created\\n     * above, and combined into a final document score using addition.\\n     */\\n    var fieldRef = lunr.FieldRef.fromString(matchingFieldRefs[i]),\\n        docRef = fieldRef.docRef\\n\\n    if (!allRequiredMatches.contains(docRef)) {\\n      continue\\n    }\\n\\n    if (allProhibitedMatches.contains(docRef)) {\\n      continue\\n    }\\n\\n    var fieldVector = this.fieldVectors[fieldRef],\\n        score = queryVectors[fieldRef.fieldName].similarity(fieldVector),\\n        docMatch\\n\\n    if ((docMatch = matches[docRef]) !== undefined) {\\n      docMatch.score += score\\n      docMatch.matchData.combine(matchingFields[fieldRef])\\n    } else {\\n      var match = {\\n        ref: docRef,\\n        score: score,\\n        matchData: matchingFields[fieldRef]\\n      }\\n      matches[docRef] = match\\n      results.push(match)\\n    }\\n  }\\n\\n  /*\\n   * Sort the results objects by score, highest first.\\n   */\\n  return results.sort(function (a, b) {\\n    return b.score - a.score\\n  })\\n}\\n\\n/**\\n * Prepares the index for JSON serialization.\\n *\\n * The schema for this JSON blob will be described in a\\n * separate JSON schema file.\\n *\\n * @returns {Object}\\n */\\nlunr.Index.prototype.toJSON = function () {\\n  var invertedIndex = Object.keys(this.invertedIndex)\\n    .sort()\\n    .map(function (term) {\\n      return [term, this.invertedIndex[term]]\\n    }, this)\\n\\n  var fieldVectors = Object.keys(this.fieldVectors)\\n    .map(function (ref) {\\n      return [ref, this.fieldVectors[ref].toJSON()]\\n    }, this)\\n\\n  return {\\n    version: lunr.version,\\n    fields: this.fields,\\n    fieldVectors: fieldVectors,\\n    invertedIndex: invertedIndex,\\n    pipeline: this.pipeline.toJSON()\\n  }\\n}\\n\\n/**\\n * Loads a previously serialized lunr.Index\\n *\\n * @param {Object} serializedIndex - A previously serialized lunr.Index\\n * @returns {lunr.Index}\\n */\\nlunr.Index.load = function (serializedIndex) {\\n  var attrs = {},\\n      fieldVectors = {},\\n      serializedVectors = serializedIndex.fieldVectors,\\n      invertedIndex = Object.create(null),\\n      serializedInvertedIndex = serializedIndex.invertedIndex,\\n      tokenSetBuilder = new lunr.TokenSet.Builder,\\n      pipeline = lunr.Pipeline.load(serializedIndex.pipeline)\\n\\n  if (serializedIndex.version != lunr.version) {\\n    lunr.utils.warn(\\\"Version mismatch when loading serialised index. Current version of lunr '\\\" + lunr.version + \\\"' does not match serialized index '\\\" + serializedIndex.version + \\\"'\\\")\\n  }\\n\\n  for (var i = 0; i < serializedVectors.length; i++) {\\n    var tuple = serializedVectors[i],\\n        ref = tuple[0],\\n        elements = tuple[1]\\n\\n    fieldVectors[ref] = new lunr.Vector(elements)\\n  }\\n\\n  for (var i = 0; i < serializedInvertedIndex.length; i++) {\\n    var tuple = serializedInvertedIndex[i],\\n        term = tuple[0],\\n        posting = tuple[1]\\n\\n    tokenSetBuilder.insert(term)\\n    invertedIndex[term] = posting\\n  }\\n\\n  tokenSetBuilder.finish()\\n\\n  attrs.fields = serializedIndex.fields\\n\\n  attrs.fieldVectors = fieldVectors\\n  attrs.invertedIndex = invertedIndex\\n  attrs.tokenSet = tokenSetBuilder.root\\n  attrs.pipeline = pipeline\\n\\n  return new lunr.Index(attrs)\\n}\\n/*!\\n * lunr.Builder\\n * Copyright (C) 2020 Oliver Nightingale\\n */\\n\\n/**\\n * lunr.Builder performs indexing on a set of documents and\\n * returns instances of lunr.Index ready for querying.\\n *\\n * All configuration of the index is done via the builder, the\\n * fields to index, the document reference, the text processing\\n * pipeline and document scoring parameters are all set on the\\n * builder before indexing.\\n *\\n * @constructor\\n * @property {string} _ref - Internal reference to the document reference field.\\n * @property {string[]} _fields - Internal reference to the document fields to index.\\n * @property {object} invertedIndex - The inverted index maps terms to document fields.\\n * @property {object} documentTermFrequencies - Keeps track of document term frequencies.\\n * @property {object} documentLengths - Keeps track of the length of documents added to the index.\\n * @property {lunr.tokenizer} tokenizer - Function for splitting strings into tokens for indexing.\\n * @property {lunr.Pipeline} pipeline - The pipeline performs text processing on tokens before indexing.\\n * @property {lunr.Pipeline} searchPipeline - A pipeline for processing search terms before querying the index.\\n * @property {number} documentCount - Keeps track of the total number of documents indexed.\\n * @property {number} _b - A parameter to control field length normalization, setting this to 0 disabled normalization, 1 fully normalizes field lengths, the default value is 0.75.\\n * @property {number} _k1 - A parameter to control how quickly an increase in term frequency results in term frequency saturation, the default value is 1.2.\\n * @property {number} termIndex - A counter incremented for each unique term, used to identify a terms position in the vector space.\\n * @property {array} metadataWhitelist - A list of metadata keys that have been whitelisted for entry in the index.\\n */\\nlunr.Builder = function () {\\n  this._ref = \\\"id\\\"\\n  this._fields = Object.create(null)\\n  this._documents = Object.create(null)\\n  this.invertedIndex = Object.create(null)\\n  this.fieldTermFrequencies = {}\\n  this.fieldLengths = {}\\n  this.tokenizer = lunr.tokenizer\\n  this.pipeline = new lunr.Pipeline\\n  this.searchPipeline = new lunr.Pipeline\\n  this.documentCount = 0\\n  this._b = 0.75\\n  this._k1 = 1.2\\n  this.termIndex = 0\\n  this.metadataWhitelist = []\\n}\\n\\n/**\\n * Sets the document field used as the document reference. Every document must have this field.\\n * The type of this field in the document should be a string, if it is not a string it will be\\n * coerced into a string by calling toString.\\n *\\n * The default ref is 'id'.\\n *\\n * The ref should _not_ be changed during indexing, it should be set before any documents are\\n * added to the index. Changing it during indexing can lead to inconsistent results.\\n *\\n * @param {string} ref - The name of the reference field in the document.\\n */\\nlunr.Builder.prototype.ref = function (ref) {\\n  this._ref = ref\\n}\\n\\n/**\\n * A function that is used to extract a field from a document.\\n *\\n * Lunr expects a field to be at the top level of a document, if however the field\\n * is deeply nested within a document an extractor function can be used to extract\\n * the right field for indexing.\\n *\\n * @callback fieldExtractor\\n * @param {object} doc - The document being added to the index.\\n * @returns {?(string|object|object[])} obj - The object that will be indexed for this field.\\n * @example <caption>Extracting a nested field</caption>\\n * function (doc) { return doc.nested.field }\\n */\\n\\n/**\\n * Adds a field to the list of document fields that will be indexed. Every document being\\n * indexed should have this field. Null values for this field in indexed documents will\\n * not cause errors but will limit the chance of that document being retrieved by searches.\\n *\\n * All fields should be added before adding documents to the index. Adding fields after\\n * a document has been indexed will have no effect on already indexed documents.\\n *\\n * Fields can be boosted at build time. This allows terms within that field to have more\\n * importance when ranking search results. Use a field boost to specify that matches within\\n * one field are more important than other fields.\\n *\\n * @param {string} fieldName - The name of a field to index in all documents.\\n * @param {object} attributes - Optional attributes associated with this field.\\n * @param {number} [attributes.boost=1] - Boost applied to all terms within this field.\\n * @param {fieldExtractor} [attributes.extractor] - Function to extract a field from a document.\\n * @throws {RangeError} fieldName cannot contain unsupported characters '/'\\n */\\nlunr.Builder.prototype.field = function (fieldName, attributes) {\\n  if (/\\\\//.test(fieldName)) {\\n    throw new RangeError (\\\"Field '\\\" + fieldName + \\\"' contains illegal character '/'\\\")\\n  }\\n\\n  this._fields[fieldName] = attributes || {}\\n}\\n\\n/**\\n * A parameter to tune the amount of field length normalisation that is applied when\\n * calculating relevance scores. A value of 0 will completely disable any normalisation\\n * and a value of 1 will fully normalise field lengths. The default is 0.75. Values of b\\n * will be clamped to the range 0 - 1.\\n *\\n * @param {number} number - The value to set for this tuning parameter.\\n */\\nlunr.Builder.prototype.b = function (number) {\\n  if (number < 0) {\\n    this._b = 0\\n  } else if (number > 1) {\\n    this._b = 1\\n  } else {\\n    this._b = number\\n  }\\n}\\n\\n/**\\n * A parameter that controls the speed at which a rise in term frequency results in term\\n * frequency saturation. The default value is 1.2. Setting this to a higher value will give\\n * slower saturation levels, a lower value will result in quicker saturation.\\n *\\n * @param {number} number - The value to set for this tuning parameter.\\n */\\nlunr.Builder.prototype.k1 = function (number) {\\n  this._k1 = number\\n}\\n\\n/**\\n * Adds a document to the index.\\n *\\n * Before adding fields to the index the index should have been fully setup, with the document\\n * ref and all fields to index already having been specified.\\n *\\n * The document must have a field name as specified by the ref (by default this is 'id') and\\n * it should have all fields defined for indexing, though null or undefined values will not\\n * cause errors.\\n *\\n * Entire documents can be boosted at build time. Applying a boost to a document indicates that\\n * this document should rank higher in search results than other documents.\\n *\\n * @param {object} doc - The document to add to the index.\\n * @param {object} attributes - Optional attributes associated with this document.\\n * @param {number} [attributes.boost=1] - Boost applied to all terms within this document.\\n */\\nlunr.Builder.prototype.add = function (doc, attributes) {\\n  var docRef = doc[this._ref],\\n      fields = Object.keys(this._fields)\\n\\n  this._documents[docRef] = attributes || {}\\n  this.documentCount += 1\\n\\n  for (var i = 0; i < fields.length; i++) {\\n    var fieldName = fields[i],\\n        extractor = this._fields[fieldName].extractor,\\n        field = extractor ? extractor(doc) : doc[fieldName],\\n        tokens = this.tokenizer(field, {\\n          fields: [fieldName]\\n        }),\\n        terms = this.pipeline.run(tokens),\\n        fieldRef = new lunr.FieldRef (docRef, fieldName),\\n        fieldTerms = Object.create(null)\\n\\n    this.fieldTermFrequencies[fieldRef] = fieldTerms\\n    this.fieldLengths[fieldRef] = 0\\n\\n    // store the length of this field for this document\\n    this.fieldLengths[fieldRef] += terms.length\\n\\n    // calculate term frequencies for this field\\n    for (var j = 0; j < terms.length; j++) {\\n      var term = terms[j]\\n\\n      if (fieldTerms[term] == undefined) {\\n        fieldTerms[term] = 0\\n      }\\n\\n      fieldTerms[term] += 1\\n\\n      // add to inverted index\\n      // create an initial posting if one doesn't exist\\n      if (this.invertedIndex[term] == undefined) {\\n        var posting = Object.create(null)\\n        posting[\\\"_index\\\"] = this.termIndex\\n        this.termIndex += 1\\n\\n        for (var k = 0; k < fields.length; k++) {\\n          posting[fields[k]] = Object.create(null)\\n        }\\n\\n        this.invertedIndex[term] = posting\\n      }\\n\\n      // add an entry for this term/fieldName/docRef to the invertedIndex\\n      if (this.invertedIndex[term][fieldName][docRef] == undefined) {\\n        this.invertedIndex[term][fieldName][docRef] = Object.create(null)\\n      }\\n\\n      // store all whitelisted metadata about this token in the\\n      // inverted index\\n      for (var l = 0; l < this.metadataWhitelist.length; l++) {\\n        var metadataKey = this.metadataWhitelist[l],\\n            metadata = term.metadata[metadataKey]\\n\\n        if (this.invertedIndex[term][fieldName][docRef][metadataKey] == undefined) {\\n          this.invertedIndex[term][fieldName][docRef][metadataKey] = []\\n        }\\n\\n        this.invertedIndex[term][fieldName][docRef][metadataKey].push(metadata)\\n      }\\n    }\\n\\n  }\\n}\\n\\n/**\\n * Calculates the average document length for this index\\n *\\n * @private\\n */\\nlunr.Builder.prototype.calculateAverageFieldLengths = function () {\\n\\n  var fieldRefs = Object.keys(this.fieldLengths),\\n      numberOfFields = fieldRefs.length,\\n      accumulator = {},\\n      documentsWithField = {}\\n\\n  for (var i = 0; i < numberOfFields; i++) {\\n    var fieldRef = lunr.FieldRef.fromString(fieldRefs[i]),\\n        field = fieldRef.fieldName\\n\\n    documentsWithField[field] || (documentsWithField[field] = 0)\\n    documentsWithField[field] += 1\\n\\n    accumulator[field] || (accumulator[field] = 0)\\n    accumulator[field] += this.fieldLengths[fieldRef]\\n  }\\n\\n  var fields = Object.keys(this._fields)\\n\\n  for (var i = 0; i < fields.length; i++) {\\n    var fieldName = fields[i]\\n    accumulator[fieldName] = accumulator[fieldName] / documentsWithField[fieldName]\\n  }\\n\\n  this.averageFieldLength = accumulator\\n}\\n\\n/**\\n * Builds a vector space model of every document using lunr.Vector\\n *\\n * @private\\n */\\nlunr.Builder.prototype.createFieldVectors = function () {\\n  var fieldVectors = {},\\n      fieldRefs = Object.keys(this.fieldTermFrequencies),\\n      fieldRefsLength = fieldRefs.length,\\n      termIdfCache = Object.create(null)\\n\\n  for (var i = 0; i < fieldRefsLength; i++) {\\n    var fieldRef = lunr.FieldRef.fromString(fieldRefs[i]),\\n        fieldName = fieldRef.fieldName,\\n        fieldLength = this.fieldLengths[fieldRef],\\n        fieldVector = new lunr.Vector,\\n        termFrequencies = this.fieldTermFrequencies[fieldRef],\\n        terms = Object.keys(termFrequencies),\\n        termsLength = terms.length\\n\\n\\n    var fieldBoost = this._fields[fieldName].boost || 1,\\n        docBoost = this._documents[fieldRef.docRef].boost || 1\\n\\n    for (var j = 0; j < termsLength; j++) {\\n      var term = terms[j],\\n          tf = termFrequencies[term],\\n          termIndex = this.invertedIndex[term]._index,\\n          idf, score, scoreWithPrecision\\n\\n      if (termIdfCache[term] === undefined) {\\n        idf = lunr.idf(this.invertedIndex[term], this.documentCount)\\n        termIdfCache[term] = idf\\n      } else {\\n        idf = termIdfCache[term]\\n      }\\n\\n      score = idf * ((this._k1 + 1) * tf) / (this._k1 * (1 - this._b + this._b * (fieldLength / this.averageFieldLength[fieldName])) + tf)\\n      score *= fieldBoost\\n      score *= docBoost\\n      scoreWithPrecision = Math.round(score * 1000) / 1000\\n      // Converts 1.23456789 to 1.234.\\n      // Reducing the precision so that the vectors take up less\\n      // space when serialised. Doing it now so that they behave\\n      // the same before and after serialisation. Also, this is\\n      // the fastest approach to reducing a number's precision in\\n      // JavaScript.\\n\\n      fieldVector.insert(termIndex, scoreWithPrecision)\\n    }\\n\\n    fieldVectors[fieldRef] = fieldVector\\n  }\\n\\n  this.fieldVectors = fieldVectors\\n}\\n\\n/**\\n * Creates a token set of all tokens in the index using lunr.TokenSet\\n *\\n * @private\\n */\\nlunr.Builder.prototype.createTokenSet = function () {\\n  this.tokenSet = lunr.TokenSet.fromArray(\\n    Object.keys(this.invertedIndex).sort()\\n  )\\n}\\n\\n/**\\n * Builds the index, creating an instance of lunr.Index.\\n *\\n * This completes the indexing process and should only be called\\n * once all documents have been added to the index.\\n *\\n * @returns {lunr.Index}\\n */\\nlunr.Builder.prototype.build = function () {\\n  this.calculateAverageFieldLengths()\\n  this.createFieldVectors()\\n  this.createTokenSet()\\n\\n  return new lunr.Index({\\n    invertedIndex: this.invertedIndex,\\n    fieldVectors: this.fieldVectors,\\n    tokenSet: this.tokenSet,\\n    fields: Object.keys(this._fields),\\n    pipeline: this.searchPipeline\\n  })\\n}\\n\\n/**\\n * Applies a plugin to the index builder.\\n *\\n * A plugin is a function that is called with the index builder as its context.\\n * Plugins can be used to customise or extend the behaviour of the index\\n * in some way. A plugin is just a function, that encapsulated the custom\\n * behaviour that should be applied when building the index.\\n *\\n * The plugin function will be called with the index builder as its argument, additional\\n * arguments can also be passed when calling use. The function will be called\\n * with the index builder as its context.\\n *\\n * @param {Function} plugin The plugin to apply.\\n */\\nlunr.Builder.prototype.use = function (fn) {\\n  var args = Array.prototype.slice.call(arguments, 1)\\n  args.unshift(this)\\n  fn.apply(this, args)\\n}\\n/**\\n * Contains and collects metadata about a matching document.\\n * A single instance of lunr.MatchData is returned as part of every\\n * lunr.Index~Result.\\n *\\n * @constructor\\n * @param {string} term - The term this match data is associated with\\n * @param {string} field - The field in which the term was found\\n * @param {object} metadata - The metadata recorded about this term in this field\\n * @property {object} metadata - A cloned collection of metadata associated with this document.\\n * @see {@link lunr.Index~Result}\\n */\\nlunr.MatchData = function (term, field, metadata) {\\n  var clonedMetadata = Object.create(null),\\n      metadataKeys = Object.keys(metadata || {})\\n\\n  // Cloning the metadata to prevent the original\\n  // being mutated during match data combination.\\n  // Metadata is kept in an array within the inverted\\n  // index so cloning the data can be done with\\n  // Array#slice\\n  for (var i = 0; i < metadataKeys.length; i++) {\\n    var key = metadataKeys[i]\\n    clonedMetadata[key] = metadata[key].slice()\\n  }\\n\\n  this.metadata = Object.create(null)\\n\\n  if (term !== undefined) {\\n    this.metadata[term] = Object.create(null)\\n    this.metadata[term][field] = clonedMetadata\\n  }\\n}\\n\\n/**\\n * An instance of lunr.MatchData will be created for every term that matches a\\n * document. However only one instance is required in a lunr.Index~Result. This\\n * method combines metadata from another instance of lunr.MatchData with this\\n * objects metadata.\\n *\\n * @param {lunr.MatchData} otherMatchData - Another instance of match data to merge with this one.\\n * @see {@link lunr.Index~Result}\\n */\\nlunr.MatchData.prototype.combine = function (otherMatchData) {\\n  var terms = Object.keys(otherMatchData.metadata)\\n\\n  for (var i = 0; i < terms.length; i++) {\\n    var term = terms[i],\\n        fields = Object.keys(otherMatchData.metadata[term])\\n\\n    if (this.metadata[term] == undefined) {\\n      this.metadata[term] = Object.create(null)\\n    }\\n\\n    for (var j = 0; j < fields.length; j++) {\\n      var field = fields[j],\\n          keys = Object.keys(otherMatchData.metadata[term][field])\\n\\n      if (this.metadata[term][field] == undefined) {\\n        this.metadata[term][field] = Object.create(null)\\n      }\\n\\n      for (var k = 0; k < keys.length; k++) {\\n        var key = keys[k]\\n\\n        if (this.metadata[term][field][key] == undefined) {\\n          this.metadata[term][field][key] = otherMatchData.metadata[term][field][key]\\n        } else {\\n          this.metadata[term][field][key] = this.metadata[term][field][key].concat(otherMatchData.metadata[term][field][key])\\n        }\\n\\n      }\\n    }\\n  }\\n}\\n\\n/**\\n * Add metadata for a term/field pair to this instance of match data.\\n *\\n * @param {string} term - The term this match data is associated with\\n * @param {string} field - The field in which the term was found\\n * @param {object} metadata - The metadata recorded about this term in this field\\n */\\nlunr.MatchData.prototype.add = function (term, field, metadata) {\\n  if (!(term in this.metadata)) {\\n    this.metadata[term] = Object.create(null)\\n    this.metadata[term][field] = metadata\\n    return\\n  }\\n\\n  if (!(field in this.metadata[term])) {\\n    this.metadata[term][field] = metadata\\n    return\\n  }\\n\\n  var metadataKeys = Object.keys(metadata)\\n\\n  for (var i = 0; i < metadataKeys.length; i++) {\\n    var key = metadataKeys[i]\\n\\n    if (key in this.metadata[term][field]) {\\n      this.metadata[term][field][key] = this.metadata[term][field][key].concat(metadata[key])\\n    } else {\\n      this.metadata[term][field][key] = metadata[key]\\n    }\\n  }\\n}\\n/**\\n * A lunr.Query provides a programmatic way of defining queries to be performed\\n * against a {@link lunr.Index}.\\n *\\n * Prefer constructing a lunr.Query using the {@link lunr.Index#query} method\\n * so the query object is pre-initialized with the right index fields.\\n *\\n * @constructor\\n * @property {lunr.Query~Clause[]} clauses - An array of query clauses.\\n * @property {string[]} allFields - An array of all available fields in a lunr.Index.\\n */\\nlunr.Query = function (allFields) {\\n  this.clauses = []\\n  this.allFields = allFields\\n}\\n\\n/**\\n * Constants for indicating what kind of automatic wildcard insertion will be used when constructing a query clause.\\n *\\n * This allows wildcards to be added to the beginning and end of a term without having to manually do any string\\n * concatenation.\\n *\\n * The wildcard constants can be bitwise combined to select both leading and trailing wildcards.\\n *\\n * @constant\\n * @default\\n * @property {number} wildcard.NONE - The term will have no wildcards inserted, this is the default behaviour\\n * @property {number} wildcard.LEADING - Prepend the term with a wildcard, unless a leading wildcard already exists\\n * @property {number} wildcard.TRAILING - Append a wildcard to the term, unless a trailing wildcard already exists\\n * @see lunr.Query~Clause\\n * @see lunr.Query#clause\\n * @see lunr.Query#term\\n * @example <caption>query term with trailing wildcard</caption>\\n * query.term('foo', { wildcard: lunr.Query.wildcard.TRAILING })\\n * @example <caption>query term with leading and trailing wildcard</caption>\\n * query.term('foo', {\\n *   wildcard: lunr.Query.wildcard.LEADING | lunr.Query.wildcard.TRAILING\\n * })\\n */\\n\\nlunr.Query.wildcard = new String (\\\"*\\\")\\nlunr.Query.wildcard.NONE = 0\\nlunr.Query.wildcard.LEADING = 1\\nlunr.Query.wildcard.TRAILING = 2\\n\\n/**\\n * Constants for indicating what kind of presence a term must have in matching documents.\\n *\\n * @constant\\n * @enum {number}\\n * @see lunr.Query~Clause\\n * @see lunr.Query#clause\\n * @see lunr.Query#term\\n * @example <caption>query term with required presence</caption>\\n * query.term('foo', { presence: lunr.Query.presence.REQUIRED })\\n */\\nlunr.Query.presence = {\\n  /**\\n   * Term's presence in a document is optional, this is the default value.\\n   */\\n  OPTIONAL: 1,\\n\\n  /**\\n   * Term's presence in a document is required, documents that do not contain\\n   * this term will not be returned.\\n   */\\n  REQUIRED: 2,\\n\\n  /**\\n   * Term's presence in a document is prohibited, documents that do contain\\n   * this term will not be returned.\\n   */\\n  PROHIBITED: 3\\n}\\n\\n/**\\n * A single clause in a {@link lunr.Query} contains a term and details on how to\\n * match that term against a {@link lunr.Index}.\\n *\\n * @typedef {Object} lunr.Query~Clause\\n * @property {string[]} fields - The fields in an index this clause should be matched against.\\n * @property {number} [boost=1] - Any boost that should be applied when matching this clause.\\n * @property {number} [editDistance] - Whether the term should have fuzzy matching applied, and how fuzzy the match should be.\\n * @property {boolean} [usePipeline] - Whether the term should be passed through the search pipeline.\\n * @property {number} [wildcard=lunr.Query.wildcard.NONE] - Whether the term should have wildcards appended or prepended.\\n * @property {number} [presence=lunr.Query.presence.OPTIONAL] - The terms presence in any matching documents.\\n */\\n\\n/**\\n * Adds a {@link lunr.Query~Clause} to this query.\\n *\\n * Unless the clause contains the fields to be matched all fields will be matched. In addition\\n * a default boost of 1 is applied to the clause.\\n *\\n * @param {lunr.Query~Clause} clause - The clause to add to this query.\\n * @see lunr.Query~Clause\\n * @returns {lunr.Query}\\n */\\nlunr.Query.prototype.clause = function (clause) {\\n  if (!('fields' in clause)) {\\n    clause.fields = this.allFields\\n  }\\n\\n  if (!('boost' in clause)) {\\n    clause.boost = 1\\n  }\\n\\n  if (!('usePipeline' in clause)) {\\n    clause.usePipeline = true\\n  }\\n\\n  if (!('wildcard' in clause)) {\\n    clause.wildcard = lunr.Query.wildcard.NONE\\n  }\\n\\n  if ((clause.wildcard & lunr.Query.wildcard.LEADING) && (clause.term.charAt(0) != lunr.Query.wildcard)) {\\n    clause.term = \\\"*\\\" + clause.term\\n  }\\n\\n  if ((clause.wildcard & lunr.Query.wildcard.TRAILING) && (clause.term.slice(-1) != lunr.Query.wildcard)) {\\n    clause.term = \\\"\\\" + clause.term + \\\"*\\\"\\n  }\\n\\n  if (!('presence' in clause)) {\\n    clause.presence = lunr.Query.presence.OPTIONAL\\n  }\\n\\n  this.clauses.push(clause)\\n\\n  return this\\n}\\n\\n/**\\n * A negated query is one in which every clause has a presence of\\n * prohibited. These queries require some special processing to return\\n * the expected results.\\n *\\n * @returns boolean\\n */\\nlunr.Query.prototype.isNegated = function () {\\n  for (var i = 0; i < this.clauses.length; i++) {\\n    if (this.clauses[i].presence != lunr.Query.presence.PROHIBITED) {\\n      return false\\n    }\\n  }\\n\\n  return true\\n}\\n\\n/**\\n * Adds a term to the current query, under the covers this will create a {@link lunr.Query~Clause}\\n * to the list of clauses that make up this query.\\n *\\n * The term is used as is, i.e. no tokenization will be performed by this method. Instead conversion\\n * to a token or token-like string should be done before calling this method.\\n *\\n * The term will be converted to a string by calling `toString`. Multiple terms can be passed as an\\n * array, each term in the array will share the same options.\\n *\\n * @param {object|object[]} term - The term(s) to add to the query.\\n * @param {object} [options] - Any additional properties to add to the query clause.\\n * @returns {lunr.Query}\\n * @see lunr.Query#clause\\n * @see lunr.Query~Clause\\n * @example <caption>adding a single term to a query</caption>\\n * query.term(\\\"foo\\\")\\n * @example <caption>adding a single term to a query and specifying search fields, term boost and automatic trailing wildcard</caption>\\n * query.term(\\\"foo\\\", {\\n *   fields: [\\\"title\\\"],\\n *   boost: 10,\\n *   wildcard: lunr.Query.wildcard.TRAILING\\n * })\\n * @example <caption>using lunr.tokenizer to convert a string to tokens before using them as terms</caption>\\n * query.term(lunr.tokenizer(\\\"foo bar\\\"))\\n */\\nlunr.Query.prototype.term = function (term, options) {\\n  if (Array.isArray(term)) {\\n    term.forEach(function (t) { this.term(t, lunr.utils.clone(options)) }, this)\\n    return this\\n  }\\n\\n  var clause = options || {}\\n  clause.term = term.toString()\\n\\n  this.clause(clause)\\n\\n  return this\\n}\\nlunr.QueryParseError = function (message, start, end) {\\n  this.name = \\\"QueryParseError\\\"\\n  this.message = message\\n  this.start = start\\n  this.end = end\\n}\\n\\nlunr.QueryParseError.prototype = new Error\\nlunr.QueryLexer = function (str) {\\n  this.lexemes = []\\n  this.str = str\\n  this.length = str.length\\n  this.pos = 0\\n  this.start = 0\\n  this.escapeCharPositions = []\\n}\\n\\nlunr.QueryLexer.prototype.run = function () {\\n  var state = lunr.QueryLexer.lexText\\n\\n  while (state) {\\n    state = state(this)\\n  }\\n}\\n\\nlunr.QueryLexer.prototype.sliceString = function () {\\n  var subSlices = [],\\n      sliceStart = this.start,\\n      sliceEnd = this.pos\\n\\n  for (var i = 0; i < this.escapeCharPositions.length; i++) {\\n    sliceEnd = this.escapeCharPositions[i]\\n    subSlices.push(this.str.slice(sliceStart, sliceEnd))\\n    sliceStart = sliceEnd + 1\\n  }\\n\\n  subSlices.push(this.str.slice(sliceStart, this.pos))\\n  this.escapeCharPositions.length = 0\\n\\n  return subSlices.join('')\\n}\\n\\nlunr.QueryLexer.prototype.emit = function (type) {\\n  this.lexemes.push({\\n    type: type,\\n    str: this.sliceString(),\\n    start: this.start,\\n    end: this.pos\\n  })\\n\\n  this.start = this.pos\\n}\\n\\nlunr.QueryLexer.prototype.escapeCharacter = function () {\\n  this.escapeCharPositions.push(this.pos - 1)\\n  this.pos += 1\\n}\\n\\nlunr.QueryLexer.prototype.next = function () {\\n  if (this.pos >= this.length) {\\n    return lunr.QueryLexer.EOS\\n  }\\n\\n  var char = this.str.charAt(this.pos)\\n  this.pos += 1\\n  return char\\n}\\n\\nlunr.QueryLexer.prototype.width = function () {\\n  return this.pos - this.start\\n}\\n\\nlunr.QueryLexer.prototype.ignore = function () {\\n  if (this.start == this.pos) {\\n    this.pos += 1\\n  }\\n\\n  this.start = this.pos\\n}\\n\\nlunr.QueryLexer.prototype.backup = function () {\\n  this.pos -= 1\\n}\\n\\nlunr.QueryLexer.prototype.acceptDigitRun = function () {\\n  var char, charCode\\n\\n  do {\\n    char = this.next()\\n    charCode = char.charCodeAt(0)\\n  } while (charCode > 47 && charCode < 58)\\n\\n  if (char != lunr.QueryLexer.EOS) {\\n    this.backup()\\n  }\\n}\\n\\nlunr.QueryLexer.prototype.more = function () {\\n  return this.pos < this.length\\n}\\n\\nlunr.QueryLexer.EOS = 'EOS'\\nlunr.QueryLexer.FIELD = 'FIELD'\\nlunr.QueryLexer.TERM = 'TERM'\\nlunr.QueryLexer.EDIT_DISTANCE = 'EDIT_DISTANCE'\\nlunr.QueryLexer.BOOST = 'BOOST'\\nlunr.QueryLexer.PRESENCE = 'PRESENCE'\\n\\nlunr.QueryLexer.lexField = function (lexer) {\\n  lexer.backup()\\n  lexer.emit(lunr.QueryLexer.FIELD)\\n  lexer.ignore()\\n  return lunr.QueryLexer.lexText\\n}\\n\\nlunr.QueryLexer.lexTerm = function (lexer) {\\n  if (lexer.width() > 1) {\\n    lexer.backup()\\n    lexer.emit(lunr.QueryLexer.TERM)\\n  }\\n\\n  lexer.ignore()\\n\\n  if (lexer.more()) {\\n    return lunr.QueryLexer.lexText\\n  }\\n}\\n\\nlunr.QueryLexer.lexEditDistance = function (lexer) {\\n  lexer.ignore()\\n  lexer.acceptDigitRun()\\n  lexer.emit(lunr.QueryLexer.EDIT_DISTANCE)\\n  return lunr.QueryLexer.lexText\\n}\\n\\nlunr.QueryLexer.lexBoost = function (lexer) {\\n  lexer.ignore()\\n  lexer.acceptDigitRun()\\n  lexer.emit(lunr.QueryLexer.BOOST)\\n  return lunr.QueryLexer.lexText\\n}\\n\\nlunr.QueryLexer.lexEOS = function (lexer) {\\n  if (lexer.width() > 0) {\\n    lexer.emit(lunr.QueryLexer.TERM)\\n  }\\n}\\n\\n// This matches the separator used when tokenising fields\\n// within a document. These should match otherwise it is\\n// not possible to search for some tokens within a document.\\n//\\n// It is possible for the user to change the separator on the\\n// tokenizer so it _might_ clash with any other of the special\\n// characters already used within the search string, e.g. :.\\n//\\n// This means that it is possible to change the separator in\\n// such a way that makes some words unsearchable using a search\\n// string.\\nlunr.QueryLexer.termSeparator = lunr.tokenizer.separator\\n\\nlunr.QueryLexer.lexText = function (lexer) {\\n  while (true) {\\n    var char = lexer.next()\\n\\n    if (char == lunr.QueryLexer.EOS) {\\n      return lunr.QueryLexer.lexEOS\\n    }\\n\\n    // Escape character is '\\\\'\\n    if (char.charCodeAt(0) == 92) {\\n      lexer.escapeCharacter()\\n      continue\\n    }\\n\\n    if (char == \\\":\\\") {\\n      return lunr.QueryLexer.lexField\\n    }\\n\\n    if (char == \\\"~\\\") {\\n      lexer.backup()\\n      if (lexer.width() > 0) {\\n        lexer.emit(lunr.QueryLexer.TERM)\\n      }\\n      return lunr.QueryLexer.lexEditDistance\\n    }\\n\\n    if (char == \\\"^\\\") {\\n      lexer.backup()\\n      if (lexer.width() > 0) {\\n        lexer.emit(lunr.QueryLexer.TERM)\\n      }\\n      return lunr.QueryLexer.lexBoost\\n    }\\n\\n    // \\\"+\\\" indicates term presence is required\\n    // checking for length to ensure that only\\n    // leading \\\"+\\\" are considered\\n    if (char == \\\"+\\\" && lexer.width() === 1) {\\n      lexer.emit(lunr.QueryLexer.PRESENCE)\\n      return lunr.QueryLexer.lexText\\n    }\\n\\n    // \\\"-\\\" indicates term presence is prohibited\\n    // checking for length to ensure that only\\n    // leading \\\"-\\\" are considered\\n    if (char == \\\"-\\\" && lexer.width() === 1) {\\n      lexer.emit(lunr.QueryLexer.PRESENCE)\\n      return lunr.QueryLexer.lexText\\n    }\\n\\n    if (char.match(lunr.QueryLexer.termSeparator)) {\\n      return lunr.QueryLexer.lexTerm\\n    }\\n  }\\n}\\n\\nlunr.QueryParser = function (str, query) {\\n  this.lexer = new lunr.QueryLexer (str)\\n  this.query = query\\n  this.currentClause = {}\\n  this.lexemeIdx = 0\\n}\\n\\nlunr.QueryParser.prototype.parse = function () {\\n  this.lexer.run()\\n  this.lexemes = this.lexer.lexemes\\n\\n  var state = lunr.QueryParser.parseClause\\n\\n  while (state) {\\n    state = state(this)\\n  }\\n\\n  return this.query\\n}\\n\\nlunr.QueryParser.prototype.peekLexeme = function () {\\n  return this.lexemes[this.lexemeIdx]\\n}\\n\\nlunr.QueryParser.prototype.consumeLexeme = function () {\\n  var lexeme = this.peekLexeme()\\n  this.lexemeIdx += 1\\n  return lexeme\\n}\\n\\nlunr.QueryParser.prototype.nextClause = function () {\\n  var completedClause = this.currentClause\\n  this.query.clause(completedClause)\\n  this.currentClause = {}\\n}\\n\\nlunr.QueryParser.parseClause = function (parser) {\\n  var lexeme = parser.peekLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  switch (lexeme.type) {\\n    case lunr.QueryLexer.PRESENCE:\\n      return lunr.QueryParser.parsePresence\\n    case lunr.QueryLexer.FIELD:\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.TERM:\\n      return lunr.QueryParser.parseTerm\\n    default:\\n      var errorMessage = \\\"expected either a field or a term, found \\\" + lexeme.type\\n\\n      if (lexeme.str.length >= 1) {\\n        errorMessage += \\\" with value '\\\" + lexeme.str + \\\"'\\\"\\n      }\\n\\n      throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parsePresence = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  switch (lexeme.str) {\\n    case \\\"-\\\":\\n      parser.currentClause.presence = lunr.Query.presence.PROHIBITED\\n      break\\n    case \\\"+\\\":\\n      parser.currentClause.presence = lunr.Query.presence.REQUIRED\\n      break\\n    default:\\n      var errorMessage = \\\"unrecognised presence operator'\\\" + lexeme.str + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    var errorMessage = \\\"expecting term or field, found nothing\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.FIELD:\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.TERM:\\n      return lunr.QueryParser.parseTerm\\n    default:\\n      var errorMessage = \\\"expecting term or field, found '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseField = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  if (parser.query.allFields.indexOf(lexeme.str) == -1) {\\n    var possibleFields = parser.query.allFields.map(function (f) { return \\\"'\\\" + f + \\\"'\\\" }).join(', '),\\n        errorMessage = \\\"unrecognised field '\\\" + lexeme.str + \\\"', possible fields: \\\" + possibleFields\\n\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  parser.currentClause.fields = [lexeme.str]\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    var errorMessage = \\\"expecting term, found nothing\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      return lunr.QueryParser.parseTerm\\n    default:\\n      var errorMessage = \\\"expecting term, found '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseTerm = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  parser.currentClause.term = lexeme.str.toLowerCase()\\n\\n  if (lexeme.str.indexOf(\\\"*\\\") != -1) {\\n    parser.currentClause.usePipeline = false\\n  }\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    parser.nextClause()\\n    return\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseTerm\\n    case lunr.QueryLexer.FIELD:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.EDIT_DISTANCE:\\n      return lunr.QueryParser.parseEditDistance\\n    case lunr.QueryLexer.BOOST:\\n      return lunr.QueryParser.parseBoost\\n    case lunr.QueryLexer.PRESENCE:\\n      parser.nextClause()\\n      return lunr.QueryParser.parsePresence\\n    default:\\n      var errorMessage = \\\"Unexpected lexeme type '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseEditDistance = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  var editDistance = parseInt(lexeme.str, 10)\\n\\n  if (isNaN(editDistance)) {\\n    var errorMessage = \\\"edit distance must be numeric\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  parser.currentClause.editDistance = editDistance\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    parser.nextClause()\\n    return\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseTerm\\n    case lunr.QueryLexer.FIELD:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.EDIT_DISTANCE:\\n      return lunr.QueryParser.parseEditDistance\\n    case lunr.QueryLexer.BOOST:\\n      return lunr.QueryParser.parseBoost\\n    case lunr.QueryLexer.PRESENCE:\\n      parser.nextClause()\\n      return lunr.QueryParser.parsePresence\\n    default:\\n      var errorMessage = \\\"Unexpected lexeme type '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\nlunr.QueryParser.parseBoost = function (parser) {\\n  var lexeme = parser.consumeLexeme()\\n\\n  if (lexeme == undefined) {\\n    return\\n  }\\n\\n  var boost = parseInt(lexeme.str, 10)\\n\\n  if (isNaN(boost)) {\\n    var errorMessage = \\\"boost must be numeric\\\"\\n    throw new lunr.QueryParseError (errorMessage, lexeme.start, lexeme.end)\\n  }\\n\\n  parser.currentClause.boost = boost\\n\\n  var nextLexeme = parser.peekLexeme()\\n\\n  if (nextLexeme == undefined) {\\n    parser.nextClause()\\n    return\\n  }\\n\\n  switch (nextLexeme.type) {\\n    case lunr.QueryLexer.TERM:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseTerm\\n    case lunr.QueryLexer.FIELD:\\n      parser.nextClause()\\n      return lunr.QueryParser.parseField\\n    case lunr.QueryLexer.EDIT_DISTANCE:\\n      return lunr.QueryParser.parseEditDistance\\n    case lunr.QueryLexer.BOOST:\\n      return lunr.QueryParser.parseBoost\\n    case lunr.QueryLexer.PRESENCE:\\n      parser.nextClause()\\n      return lunr.QueryParser.parsePresence\\n    default:\\n      var errorMessage = \\\"Unexpected lexeme type '\\\" + nextLexeme.type + \\\"'\\\"\\n      throw new lunr.QueryParseError (errorMessage, nextLexeme.start, nextLexeme.end)\\n  }\\n}\\n\\n  /**\\n   * export the module via AMD, CommonJS or as a browser global\\n   * Export code from https://github.com/umdjs/umd/blob/master/returnExports.js\\n   */\\n  ;(function (root, factory) {\\n    if (true) {\\n      // AMD. Register as an anonymous module.\\n      !(__WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\\n\\t\\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\\n\\t\\t(__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :\\n\\t\\t__WEBPACK_AMD_DEFINE_FACTORY__),\\n\\t\\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__))\\n    } else {}\\n  }(this, function () {\\n    /**\\n     * Just return a value to define the module export.\\n     * This example returns an object, but the module\\n     * can return a function as the exported value.\\n     */\\n    return lunr\\n  }))\\n})();\\n\\n\\n//# sourceURL=webpack:///../node_modules/lunr/lunr.js?\"\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/css/main.sass':\n            /*!**************************************!*\\\n  !*** ./default/assets/css/main.sass ***!\n  \\**************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n// extracted by mini-css-extract-plugin\\n\\n\\n//# sourceURL=webpack:///./default/assets/css/main.sass?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/bootstrap.ts':\n            /*!********************************************!*\\\n  !*** ./default/assets/js/src/bootstrap.ts ***!\n  \\********************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony import */ var _typedoc_Application__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typedoc/Application */ \"./default/assets/js/src/typedoc/Application.ts\");\\n/* harmony import */ var _typedoc_components_MenuHighlight__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./typedoc/components/MenuHighlight */ \"./default/assets/js/src/typedoc/components/MenuHighlight.ts\");\\n/* harmony import */ var _typedoc_components_Search__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./typedoc/components/Search */ \"./default/assets/js/src/typedoc/components/Search.ts\");\\n/* harmony import */ var _typedoc_components_Signature__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./typedoc/components/Signature */ \"./default/assets/js/src/typedoc/components/Signature.ts\");\\n/* harmony import */ var _typedoc_components_Toggle__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./typedoc/components/Toggle */ \"./default/assets/js/src/typedoc/components/Toggle.ts\");\\n/* harmony import */ var _typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./typedoc/components/Filter */ \"./default/assets/js/src/typedoc/components/Filter.ts\");\\n/* harmony import */ var _css_main_sass__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../css/main.sass */ \"./default/assets/css/main.sass\");\\n\\n\\n\\n\\n\\n\\n\\n(0,_typedoc_components_Search__WEBPACK_IMPORTED_MODULE_2__.initSearch)();\\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_MenuHighlight__WEBPACK_IMPORTED_MODULE_1__.MenuHighlight, \".menu-highlight\");\\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_Signature__WEBPACK_IMPORTED_MODULE_3__.Signature, \".tsd-signatures\");\\n(0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_Toggle__WEBPACK_IMPORTED_MODULE_4__.Toggle, \"a[data-toggle]\");\\nif (_typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_5__.Filter.isSupported()) {\\n    (0,_typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.registerComponent)(_typedoc_components_Filter__WEBPACK_IMPORTED_MODULE_5__.Filter, \"#tsd-filter\");\\n}\\nelse {\\n    document.documentElement.classList.add(\"no-filter\");\\n}\\nvar app = new _typedoc_Application__WEBPACK_IMPORTED_MODULE_0__.Application();\\nObject.defineProperty(window, \"app\", { value: app });\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/bootstrap.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/Application.ts':\n            /*!******************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/Application.ts ***!\n  \\******************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"registerComponent\": () => /* binding */ registerComponent,\\n/* harmony export */   \"Application\": () => /* binding */ Application\\n/* harmony export */ });\\n/**\\n * List of all known components.\\n */\\nvar components = [];\\n/**\\n * Register a new component.\\n */\\nfunction registerComponent(constructor, selector) {\\n    components.push({\\n        selector: selector,\\n        constructor: constructor,\\n    });\\n}\\n/**\\n * TypeDoc application class.\\n */\\nvar Application = /** @class */ (function () {\\n    /**\\n     * Create a new Application instance.\\n     */\\n    function Application() {\\n        this.createComponents(document.body);\\n    }\\n    /**\\n     * Create all components beneath the given jQuery element.\\n     */\\n    Application.prototype.createComponents = function (context) {\\n        components.forEach(function (c) {\\n            context.querySelectorAll(c.selector).forEach(function (el) {\\n                if (!el.dataset.hasInstance) {\\n                    new c.constructor({ el: el });\\n                    el.dataset.hasInstance = String(true);\\n                }\\n            });\\n        });\\n    };\\n    return Application;\\n}());\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/Application.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/Component.ts':\n            /*!****************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/Component.ts ***!\n  \\****************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"Component\": () => /* binding */ Component\\n/* harmony export */ });\\n/**\\n * TypeDoc component class.\\n */\\nvar Component = /** @class */ (function () {\\n    function Component(options) {\\n        this.el = options.el;\\n    }\\n    return Component;\\n}());\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/Component.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/EventTarget.ts':\n            /*!******************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/EventTarget.ts ***!\n  \\******************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"EventTarget\": () => /* binding */ EventTarget\\n/* harmony export */ });\\n/**\\n * TypeDoc event target class.\\n */\\nvar EventTarget = /** @class */ (function () {\\n    function EventTarget() {\\n        this.listeners = {};\\n    }\\n    EventTarget.prototype.addEventListener = function (type, callback) {\\n        if (!(type in this.listeners)) {\\n            this.listeners[type] = [];\\n        }\\n        this.listeners[type].push(callback);\\n    };\\n    EventTarget.prototype.removeEventListener = function (type, callback) {\\n        if (!(type in this.listeners)) {\\n            return;\\n        }\\n        var stack = this.listeners[type];\\n        for (var i = 0, l = stack.length; i < l; i++) {\\n            if (stack[i] === callback) {\\n                stack.splice(i, 1);\\n                return;\\n            }\\n        }\\n    };\\n    EventTarget.prototype.dispatchEvent = function (event) {\\n        if (!(event.type in this.listeners)) {\\n            return true;\\n        }\\n        var stack = this.listeners[event.type].slice();\\n        for (var i = 0, l = stack.length; i < l; i++) {\\n            stack[i].call(this, event);\\n        }\\n        return !event.defaultPrevented;\\n    };\\n    return EventTarget;\\n}());\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/EventTarget.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/components/Filter.ts':\n            /*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Filter.ts ***!\n  \\************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"Filter\": () => /* binding */ Filter\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\\n/* harmony import */ var _utils_pointer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/pointer */ \"./default/assets/js/src/typedoc/utils/pointer.ts\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\nvar FilterItem = /** @class */ (function () {\\n    function FilterItem(key, value) {\\n        this.key = key;\\n        this.value = value;\\n        this.defaultValue = value;\\n        this.initialize();\\n        if (window.localStorage[this.key]) {\\n            this.setValue(this.fromLocalStorage(window.localStorage[this.key]));\\n        }\\n    }\\n    FilterItem.prototype.initialize = function () { };\\n    FilterItem.prototype.setValue = function (value) {\\n        if (this.value == value)\\n            return;\\n        var oldValue = this.value;\\n        this.value = value;\\n        window.localStorage[this.key] = this.toLocalStorage(value);\\n        this.handleValueChange(oldValue, value);\\n    };\\n    return FilterItem;\\n}());\\nvar FilterItemCheckbox = /** @class */ (function (_super) {\\n    __extends(FilterItemCheckbox, _super);\\n    function FilterItemCheckbox() {\\n        return _super !== null && _super.apply(this, arguments) || this;\\n    }\\n    FilterItemCheckbox.prototype.initialize = function () {\\n        var _this = this;\\n        var checkbox = document.querySelector(\"#tsd-filter-\" + this.key);\\n        if (!checkbox)\\n            return;\\n        this.checkbox = checkbox;\\n        this.checkbox.addEventListener(\"change\", function () {\\n            _this.setValue(_this.checkbox.checked);\\n        });\\n    };\\n    FilterItemCheckbox.prototype.handleValueChange = function (oldValue, newValue) {\\n        if (!this.checkbox)\\n            return;\\n        this.checkbox.checked = this.value;\\n        document.documentElement.classList.toggle(\"toggle-\" + this.key, this.value != this.defaultValue);\\n    };\\n    FilterItemCheckbox.prototype.fromLocalStorage = function (value) {\\n        return value == \"true\";\\n    };\\n    FilterItemCheckbox.prototype.toLocalStorage = function (value) {\\n        return value ? \"true\" : \"false\";\\n    };\\n    return FilterItemCheckbox;\\n}(FilterItem));\\nvar FilterItemSelect = /** @class */ (function (_super) {\\n    __extends(FilterItemSelect, _super);\\n    function FilterItemSelect() {\\n        return _super !== null && _super.apply(this, arguments) || this;\\n    }\\n    FilterItemSelect.prototype.initialize = function () {\\n        var _this = this;\\n        document.documentElement.classList.add(\"toggle-\" + this.key + this.value);\\n        var select = document.querySelector(\"#tsd-filter-\" + this.key);\\n        if (!select)\\n            return;\\n        this.select = select;\\n        var onActivate = function () {\\n            _this.select.classList.add(\"active\");\\n        };\\n        var onDeactivate = function () {\\n            _this.select.classList.remove(\"active\");\\n        };\\n        this.select.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, onActivate);\\n        this.select.addEventListener(\"mouseover\", onActivate);\\n        this.select.addEventListener(\"mouseleave\", onDeactivate);\\n        this.select.querySelectorAll(\"li\").forEach(function (el) {\\n            el.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, function (e) {\\n                select.classList.remove(\"active\");\\n                _this.setValue(e.target.dataset.value || \"\");\\n            });\\n        });\\n        document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, function (e) {\\n            if (_this.select.contains(e.target))\\n                return;\\n            _this.select.classList.remove(\"active\");\\n        });\\n    };\\n    FilterItemSelect.prototype.handleValueChange = function (oldValue, newValue) {\\n        this.select.querySelectorAll(\"li.selected\").forEach(function (el) {\\n            el.classList.remove(\"selected\");\\n        });\\n        var selected = this.select.querySelector(\\'li[data-value=\"\\' + newValue + \\'\"]\\');\\n        var label = this.select.querySelector(\".tsd-select-label\");\\n        if (selected && label) {\\n            selected.classList.add(\"selected\");\\n            label.textContent = selected.textContent;\\n        }\\n        document.documentElement.classList.remove(\"toggle-\" + oldValue);\\n        document.documentElement.classList.add(\"toggle-\" + newValue);\\n    };\\n    FilterItemSelect.prototype.fromLocalStorage = function (value) {\\n        return value;\\n    };\\n    FilterItemSelect.prototype.toLocalStorage = function (value) {\\n        return value;\\n    };\\n    return FilterItemSelect;\\n}(FilterItem));\\nvar Filter = /** @class */ (function (_super) {\\n    __extends(Filter, _super);\\n    function Filter(options) {\\n        var _this = _super.call(this, options) || this;\\n        _this.optionVisibility = new FilterItemSelect(\"visibility\", \"private\");\\n        _this.optionInherited = new FilterItemCheckbox(\"inherited\", true);\\n        _this.optionExternals = new FilterItemCheckbox(\"externals\", true);\\n        return _this;\\n    }\\n    Filter.isSupported = function () {\\n        try {\\n            return typeof window.localStorage != \"undefined\";\\n        }\\n        catch (e) {\\n            return false;\\n        }\\n    };\\n    return Filter;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Filter.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/components/MenuHighlight.ts':\n            /*!*******************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/MenuHighlight.ts ***!\n  \\*******************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"MenuHighlight\": () => /* binding */ MenuHighlight\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\\n/* harmony import */ var _services_Viewport__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../services/Viewport */ \"./default/assets/js/src/typedoc/services/Viewport.ts\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\n/**\\n * Manages the sticky state of the navigation and moves the highlight\\n * to the current navigation item.\\n */\\nvar MenuHighlight = /** @class */ (function (_super) {\\n    __extends(MenuHighlight, _super);\\n    /**\\n     * Create a new MenuHighlight instance.\\n     *\\n     * @param options  Backbone view constructor options.\\n     */\\n    function MenuHighlight(options) {\\n        var _this = _super.call(this, options) || this;\\n        /**\\n         * List of all discovered anchors.\\n         */\\n        _this.anchors = [];\\n        /**\\n         * Index of the currently highlighted anchor.\\n         */\\n        _this.index = -1;\\n        _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.addEventListener(\"resize\", function () { return _this.onResize(); });\\n        _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.addEventListener(\"scroll\", function (e) { return _this.onScroll(e); });\\n        _this.createAnchors();\\n        return _this;\\n    }\\n    /**\\n     * Find all anchors on the current page.\\n     */\\n    MenuHighlight.prototype.createAnchors = function () {\\n        var _this = this;\\n        var base = window.location.href;\\n        if (base.indexOf(\"#\") != -1) {\\n            base = base.substr(0, base.indexOf(\"#\"));\\n        }\\n        this.el.querySelectorAll(\"a\").forEach(function (el) {\\n            var href = el.href;\\n            if (href.indexOf(\"#\") == -1)\\n                return;\\n            if (href.substr(0, base.length) != base)\\n                return;\\n            var hash = href.substr(href.indexOf(\"#\") + 1);\\n            var anchor = document.querySelector(\"a.tsd-anchor[name=\" + hash + \"]\");\\n            var link = el.parentNode;\\n            if (!anchor || !link)\\n                return;\\n            _this.anchors.push({\\n                link: link,\\n                anchor: anchor,\\n                position: 0,\\n            });\\n        });\\n        this.onResize();\\n    };\\n    /**\\n     * Triggered after the viewport was resized.\\n     */\\n    MenuHighlight.prototype.onResize = function () {\\n        var anchor;\\n        for (var index = 0, count = this.anchors.length; index < count; index++) {\\n            anchor = this.anchors[index];\\n            var rect = anchor.anchor.getBoundingClientRect();\\n            anchor.position = rect.top + document.body.scrollTop;\\n        }\\n        this.anchors.sort(function (a, b) {\\n            return a.position - b.position;\\n        });\\n        var event = new CustomEvent(\"scroll\", {\\n            detail: {\\n                scrollTop: _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.scrollTop,\\n            },\\n        });\\n        this.onScroll(event);\\n    };\\n    /**\\n     * Triggered after the viewport was scrolled.\\n     *\\n     * @param event  The custom event with the current vertical scroll position.\\n     */\\n    MenuHighlight.prototype.onScroll = function (event) {\\n        var scrollTop = event.detail.scrollTop + 5;\\n        var anchors = this.anchors;\\n        var count = anchors.length - 1;\\n        var index = this.index;\\n        while (index > -1 && anchors[index].position > scrollTop) {\\n            index -= 1;\\n        }\\n        while (index < count && anchors[index + 1].position < scrollTop) {\\n            index += 1;\\n        }\\n        if (this.index != index) {\\n            if (this.index > -1)\\n                this.anchors[this.index].link.classList.remove(\"focus\");\\n            this.index = index;\\n            if (this.index > -1)\\n                this.anchors[this.index].link.classList.add(\"focus\");\\n        }\\n    };\\n    return MenuHighlight;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/MenuHighlight.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/components/Search.ts':\n            /*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Search.ts ***!\n  \\************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"initSearch\": () => /* binding */ initSearch\\n/* harmony export */ });\\n/* harmony import */ var _utils_debounce__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/debounce */ \"./default/assets/js/src/typedoc/utils/debounce.ts\");\\n/* harmony import */ var lunr__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! lunr */ \"../node_modules/lunr/lunr.js\");\\n/* harmony import */ var lunr__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(lunr__WEBPACK_IMPORTED_MODULE_1__);\\n\\n\\nfunction initSearch() {\\n    var searchEl = document.getElementById(\"tsd-search\");\\n    if (!searchEl)\\n        return;\\n    var searchScript = document.getElementById(\"search-script\");\\n    searchEl.classList.add(\"loading\");\\n    if (searchScript) {\\n        searchScript.addEventListener(\"error\", function () {\\n            searchEl.classList.remove(\"loading\");\\n            searchEl.classList.add(\"failure\");\\n        });\\n        searchScript.addEventListener(\"load\", function () {\\n            searchEl.classList.remove(\"loading\");\\n            searchEl.classList.add(\"ready\");\\n        });\\n        if (window.searchData) {\\n            searchEl.classList.remove(\"loading\");\\n        }\\n    }\\n    var field = document.querySelector(\"#tsd-search-field\");\\n    var results = document.querySelector(\".results\");\\n    if (!field || !results) {\\n        throw new Error(\"The input field or the result list wrapper was not found\");\\n    }\\n    var resultClicked = false;\\n    results.addEventListener(\"mousedown\", function () { return (resultClicked = true); });\\n    results.addEventListener(\"mouseup\", function () {\\n        resultClicked = false;\\n        searchEl.classList.remove(\"has-focus\");\\n    });\\n    field.addEventListener(\"focus\", function () { return searchEl.classList.add(\"has-focus\"); });\\n    field.addEventListener(\"blur\", function () {\\n        if (!resultClicked) {\\n            resultClicked = false;\\n            searchEl.classList.remove(\"has-focus\");\\n        }\\n    });\\n    var state = {\\n        base: searchEl.dataset.base + \"/\",\\n    };\\n    bindEvents(searchEl, results, field, state);\\n}\\nfunction bindEvents(searchEl, results, field, state) {\\n    field.addEventListener(\"input\", (0,_utils_debounce__WEBPACK_IMPORTED_MODULE_0__.debounce)(function () {\\n        updateResults(searchEl, results, field, state);\\n    }, 200));\\n    var preventPress = false;\\n    field.addEventListener(\"keydown\", function (e) {\\n        preventPress = true;\\n        if (e.key == \"Enter\") {\\n            gotoCurrentResult(results, field);\\n        }\\n        else if (e.key == \"Escape\") {\\n            field.blur();\\n        }\\n        else if (e.key == \"ArrowUp\") {\\n            setCurrentResult(results, -1);\\n        }\\n        else if (e.key === \"ArrowDown\") {\\n            setCurrentResult(results, 1);\\n        }\\n        else {\\n            preventPress = false;\\n        }\\n    });\\n    field.addEventListener(\"keypress\", function (e) {\\n        if (preventPress)\\n            e.preventDefault();\\n    });\\n    /**\\n     * Start searching by pressing slash.\\n     */\\n    document.body.addEventListener(\"keydown\", function (e) {\\n        if (e.altKey || e.ctrlKey || e.metaKey)\\n            return;\\n        if (!field.matches(\":focus\") && e.key === \"/\") {\\n            field.focus();\\n            e.preventDefault();\\n        }\\n    });\\n}\\nfunction checkIndex(state, searchEl) {\\n    if (state.index)\\n        return;\\n    if (window.searchData) {\\n        searchEl.classList.remove(\"loading\");\\n        searchEl.classList.add(\"ready\");\\n        state.data = window.searchData;\\n        state.index = lunr__WEBPACK_IMPORTED_MODULE_1__.Index.load(window.searchData.index);\\n    }\\n}\\nfunction updateResults(searchEl, results, query, state) {\\n    checkIndex(state, searchEl);\\n    // Don\\'t clear results if loading state is not ready,\\n    // because loading or error message can be removed.\\n    if (!state.index || !state.data)\\n        return;\\n    results.textContent = \"\";\\n    var searchText = query.value.trim();\\n    // Perform a wildcard search\\n    var res = state.index.search(\"*\" + searchText + \"*\");\\n    for (var i = 0, c = Math.min(10, res.length); i < c; i++) {\\n        var row = state.data.rows[Number(res[i].ref)];\\n        // Bold the matched part of the query in the search results\\n        var name_1 = boldMatches(row.name, searchText);\\n        if (row.parent) {\\n            name_1 = \"<span class=\\\\\"parent\\\\\">\" + boldMatches(row.parent, searchText) + \".</span>\" + name_1;\\n        }\\n        var item = document.createElement(\"li\");\\n        item.classList.value = row.classes;\\n        var anchor = document.createElement(\"a\");\\n        anchor.href = state.base + row.url;\\n        anchor.classList.add(\"tsd-kind-icon\");\\n        anchor.innerHTML = name_1;\\n        item.append(anchor);\\n        results.appendChild(item);\\n    }\\n}\\n/**\\n * Move the highlight within the result set.\\n */\\nfunction setCurrentResult(results, dir) {\\n    var current = results.querySelector(\".current\");\\n    if (!current) {\\n        current = results.querySelector(dir == 1 ? \"li:first-child\" : \"li:last-child\");\\n        if (current) {\\n            current.classList.add(\"current\");\\n        }\\n    }\\n    else {\\n        var rel = dir == 1\\n            ? current.nextElementSibling\\n            : current.previousElementSibling;\\n        if (rel) {\\n            current.classList.remove(\"current\");\\n            rel.classList.add(\"current\");\\n        }\\n    }\\n}\\n/**\\n * Navigate to the highlighted result.\\n */\\nfunction gotoCurrentResult(results, field) {\\n    var current = results.querySelector(\".current\");\\n    if (!current) {\\n        current = results.querySelector(\"li:first-child\");\\n    }\\n    if (current) {\\n        var link = current.querySelector(\"a\");\\n        if (link) {\\n            window.location.href = link.href;\\n        }\\n        field.blur();\\n    }\\n}\\nfunction boldMatches(text, search) {\\n    if (search === \"\") {\\n        return text;\\n    }\\n    var lowerText = text.toLocaleLowerCase();\\n    var lowerSearch = search.toLocaleLowerCase();\\n    var parts = [];\\n    var lastIndex = 0;\\n    var index = lowerText.indexOf(lowerSearch);\\n    while (index != -1) {\\n        parts.push(escapeHtml(text.substring(lastIndex, index)), \"<b>\" + escapeHtml(text.substring(index, index + lowerSearch.length)) + \"</b>\");\\n        lastIndex = index + lowerSearch.length;\\n        index = lowerText.indexOf(lowerSearch, lastIndex);\\n    }\\n    parts.push(escapeHtml(text.substring(lastIndex)));\\n    return parts.join(\"\");\\n}\\nvar SPECIAL_HTML = {\\n    \"&\": \"&amp;\",\\n    \"<\": \"&lt;\",\\n    \">\": \"&gt;\",\\n    \"\\'\": \"&#039;\",\\n    \\'\"\\': \"&quot;\",\\n};\\nfunction escapeHtml(text) {\\n    return text.replace(/[&<>\"\\'\"]/g, function (match) { return SPECIAL_HTML[match]; });\\n}\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Search.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/components/Signature.ts':\n            /*!***************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Signature.ts ***!\n  \\***************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"Signature\": () => /* binding */ Signature\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\\n/* harmony import */ var _services_Viewport__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../services/Viewport */ \"./default/assets/js/src/typedoc/services/Viewport.ts\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\n/**\\n * Holds a signature and its description.\\n */\\nvar SignatureGroup = /** @class */ (function () {\\n    /**\\n     * Create a new SignatureGroup instance.\\n     *\\n     * @param signature    The target signature.\\n     * @param description  The description for the signature.\\n     */\\n    function SignatureGroup(signature, description) {\\n        this.signature = signature;\\n        this.description = description;\\n    }\\n    /**\\n     * Add the given class to all elements of the group.\\n     *\\n     * @param className  The class name to add.\\n     */\\n    SignatureGroup.prototype.addClass = function (className) {\\n        this.signature.classList.add(className);\\n        this.description.classList.add(className);\\n        return this;\\n    };\\n    /**\\n     * Remove the given class from all elements of the group.\\n     *\\n     * @param className  The class name to remove.\\n     */\\n    SignatureGroup.prototype.removeClass = function (className) {\\n        this.signature.classList.remove(className);\\n        this.description.classList.remove(className);\\n        return this;\\n    };\\n    return SignatureGroup;\\n}());\\n/**\\n * Controls the tab like behaviour of methods and functions with multiple signatures.\\n */\\nvar Signature = /** @class */ (function (_super) {\\n    __extends(Signature, _super);\\n    /**\\n     * Create a new Signature instance.\\n     *\\n     * @param options  Backbone view constructor options.\\n     */\\n    function Signature(options) {\\n        var _this = _super.call(this, options) || this;\\n        /**\\n         * List of found signature groups.\\n         */\\n        _this.groups = [];\\n        /**\\n         * The index of the currently displayed signature.\\n         */\\n        _this.index = -1;\\n        _this.createGroups();\\n        if (_this.container) {\\n            _this.el.classList.add(\"active\");\\n            Array.from(_this.el.children).forEach(function (signature) {\\n                signature.addEventListener(\"touchstart\", function (event) {\\n                    return _this.onClick(event);\\n                });\\n                signature.addEventListener(\"click\", function (event) {\\n                    return _this.onClick(event);\\n                });\\n            });\\n            _this.container.classList.add(\"active\");\\n            _this.setIndex(0);\\n        }\\n        return _this;\\n    }\\n    /**\\n     * Set the index of the active signature.\\n     *\\n     * @param index  The index of the signature to activate.\\n     */\\n    Signature.prototype.setIndex = function (index) {\\n        if (index < 0)\\n            index = 0;\\n        if (index > this.groups.length - 1)\\n            index = this.groups.length - 1;\\n        if (this.index == index)\\n            return;\\n        var to = this.groups[index];\\n        if (this.index > -1) {\\n            var from_1 = this.groups[this.index];\\n            from_1.removeClass(\"current\").addClass(\"fade-out\");\\n            to.addClass(\"current\");\\n            to.addClass(\"fade-in\");\\n            _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.triggerResize();\\n            setTimeout(function () {\\n                from_1.removeClass(\"fade-out\");\\n                to.removeClass(\"fade-in\");\\n            }, 300);\\n        }\\n        else {\\n            to.addClass(\"current\");\\n            _services_Viewport__WEBPACK_IMPORTED_MODULE_1__.Viewport.instance.triggerResize();\\n        }\\n        this.index = index;\\n    };\\n    /**\\n     * Find all signature/description groups.\\n     */\\n    Signature.prototype.createGroups = function () {\\n        var signatures = this.el.children;\\n        if (signatures.length < 2)\\n            return;\\n        this.container = this.el.nextElementSibling;\\n        var descriptions = this.container.children;\\n        this.groups = [];\\n        for (var index = 0; index < signatures.length; index++) {\\n            this.groups.push(new SignatureGroup(signatures[index], descriptions[index]));\\n        }\\n    };\\n    /**\\n     * Triggered when the user clicks onto a signature header.\\n     *\\n     * @param e  The related event object.\\n     */\\n    Signature.prototype.onClick = function (e) {\\n        var _this = this;\\n        this.groups.forEach(function (group, index) {\\n            if (group.signature === e.currentTarget) {\\n                _this.setIndex(index);\\n            }\\n        });\\n    };\\n    return Signature;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Signature.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/components/Toggle.ts':\n            /*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/components/Toggle.ts ***!\n  \\************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"Toggle\": () => /* binding */ Toggle\\n/* harmony export */ });\\n/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Component */ \"./default/assets/js/src/typedoc/Component.ts\");\\n/* harmony import */ var _utils_pointer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/pointer */ \"./default/assets/js/src/typedoc/utils/pointer.ts\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\nvar Toggle = /** @class */ (function (_super) {\\n    __extends(Toggle, _super);\\n    function Toggle(options) {\\n        var _this = _super.call(this, options) || this;\\n        _this.className = _this.el.dataset.toggle || \"\";\\n        _this.el.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, function (e) { return _this.onPointerUp(e); });\\n        _this.el.addEventListener(\"click\", function (e) { return e.preventDefault(); });\\n        document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerDown, function (e) {\\n            return _this.onDocumentPointerDown(e);\\n        });\\n        document.addEventListener(_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.pointerUp, function (e) {\\n            return _this.onDocumentPointerUp(e);\\n        });\\n        return _this;\\n    }\\n    Toggle.prototype.setActive = function (value) {\\n        if (this.active == value)\\n            return;\\n        this.active = value;\\n        document.documentElement.classList.toggle(\"has-\" + this.className, value);\\n        this.el.classList.toggle(\"active\", value);\\n        var transition = (this.active ? \"to-has-\" : \"from-has-\") + this.className;\\n        document.documentElement.classList.add(transition);\\n        setTimeout(function () { return document.documentElement.classList.remove(transition); }, 500);\\n    };\\n    Toggle.prototype.onPointerUp = function (event) {\\n        if (_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.hasPointerMoved)\\n            return;\\n        this.setActive(true);\\n        event.preventDefault();\\n    };\\n    Toggle.prototype.onDocumentPointerDown = function (e) {\\n        if (this.active) {\\n            if (e.target.closest(\".col-menu, .tsd-filter-group\")) {\\n                return;\\n            }\\n            this.setActive(false);\\n        }\\n    };\\n    Toggle.prototype.onDocumentPointerUp = function (e) {\\n        var _this = this;\\n        if (_utils_pointer__WEBPACK_IMPORTED_MODULE_1__.hasPointerMoved)\\n            return;\\n        if (this.active) {\\n            if (e.target.closest(\".col-menu\")) {\\n                var link = e.target.closest(\"a\");\\n                if (link) {\\n                    var href = window.location.href;\\n                    if (href.indexOf(\"#\") != -1) {\\n                        href = href.substr(0, href.indexOf(\"#\"));\\n                    }\\n                    if (link.href.substr(0, href.length) == href) {\\n                        setTimeout(function () { return _this.setActive(false); }, 250);\\n                    }\\n                }\\n            }\\n        }\\n    };\\n    return Toggle;\\n}(_Component__WEBPACK_IMPORTED_MODULE_0__.Component));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/components/Toggle.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/services/Viewport.ts':\n            /*!************************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/services/Viewport.ts ***!\n  \\************************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"Viewport\": () => /* binding */ Viewport\\n/* harmony export */ });\\n/* harmony import */ var _EventTarget__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../EventTarget */ \"./default/assets/js/src/typedoc/EventTarget.ts\");\\n/* harmony import */ var _utils_trottle__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/trottle */ \"./default/assets/js/src/typedoc/utils/trottle.ts\");\\nvar __extends = (undefined && undefined.__extends) || (function () {\\n    var extendStatics = function (d, b) {\\n        extendStatics = Object.setPrototypeOf ||\\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\\n        return extendStatics(d, b);\\n    };\\n    return function (d, b) {\\n        extendStatics(d, b);\\n        function __() { this.constructor = d; }\\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\\n    };\\n})();\\n\\n\\n/**\\n * A global service that monitors the window size and scroll position.\\n */\\nvar Viewport = /** @class */ (function (_super) {\\n    __extends(Viewport, _super);\\n    /**\\n     * Create new Viewport instance.\\n     */\\n    function Viewport() {\\n        var _this = _super.call(this) || this;\\n        /**\\n         * The current scroll position.\\n         */\\n        _this.scrollTop = 0;\\n        /**\\n         * The previous scrollTop.\\n         */\\n        _this.lastY = 0;\\n        /**\\n         * The width of the window.\\n         */\\n        _this.width = 0;\\n        /**\\n         * The height of the window.\\n         */\\n        _this.height = 0;\\n        /**\\n         * Boolean indicating whether the toolbar is shown.\\n         */\\n        _this.showToolbar = true;\\n        _this.toolbar = (document.querySelector(\".tsd-page-toolbar\"));\\n        _this.secondaryNav = (document.querySelector(\".tsd-navigation.secondary\"));\\n        window.addEventListener(\"scroll\", (0,_utils_trottle__WEBPACK_IMPORTED_MODULE_1__.throttle)(function () { return _this.onScroll(); }, 10));\\n        window.addEventListener(\"resize\", (0,_utils_trottle__WEBPACK_IMPORTED_MODULE_1__.throttle)(function () { return _this.onResize(); }, 10));\\n        _this.onResize();\\n        _this.onScroll();\\n        return _this;\\n    }\\n    /**\\n     * Trigger a resize event.\\n     */\\n    Viewport.prototype.triggerResize = function () {\\n        var event = new CustomEvent(\"resize\", {\\n            detail: {\\n                width: this.width,\\n                height: this.height,\\n            },\\n        });\\n        this.dispatchEvent(event);\\n    };\\n    /**\\n     * Triggered when the size of the window has changed.\\n     */\\n    Viewport.prototype.onResize = function () {\\n        this.width = window.innerWidth || 0;\\n        this.height = window.innerHeight || 0;\\n        var event = new CustomEvent(\"resize\", {\\n            detail: {\\n                width: this.width,\\n                height: this.height,\\n            },\\n        });\\n        this.dispatchEvent(event);\\n    };\\n    /**\\n     * Triggered when the user scrolled the viewport.\\n     */\\n    Viewport.prototype.onScroll = function () {\\n        this.scrollTop = window.scrollY || 0;\\n        var event = new CustomEvent(\"scroll\", {\\n            detail: {\\n                scrollTop: this.scrollTop,\\n            },\\n        });\\n        this.dispatchEvent(event);\\n        this.hideShowToolbar();\\n    };\\n    /**\\n     * Handle hiding/showing of the toolbar.\\n     */\\n    Viewport.prototype.hideShowToolbar = function () {\\n        var isShown = this.showToolbar;\\n        this.showToolbar = this.lastY >= this.scrollTop || this.scrollTop <= 0;\\n        if (isShown !== this.showToolbar) {\\n            this.toolbar.classList.toggle(\"tsd-page-toolbar--hide\");\\n            this.secondaryNav.classList.toggle(\"tsd-navigation--toolbar-hide\");\\n        }\\n        this.lastY = this.scrollTop;\\n    };\\n    Viewport.instance = new Viewport();\\n    return Viewport;\\n}(_EventTarget__WEBPACK_IMPORTED_MODULE_0__.EventTarget));\\n\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/services/Viewport.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/utils/debounce.ts':\n            /*!*********************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/utils/debounce.ts ***!\n  \\*********************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"debounce\": () => /* binding */ debounce\\n/* harmony export */ });\\nvar debounce = function (fn, wait) {\\n    if (wait === void 0) { wait = 100; }\\n    var timeout;\\n    return function () {\\n        var args = [];\\n        for (var _i = 0; _i < arguments.length; _i++) {\\n            args[_i] = arguments[_i];\\n        }\\n        clearTimeout(timeout);\\n        timeout = setTimeout(function () { return fn(args); }, wait);\\n    };\\n};\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/debounce.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/utils/pointer.ts':\n            /*!********************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/utils/pointer.ts ***!\n  \\********************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"pointerDown\": () => /* binding */ pointerDown,\\n/* harmony export */   \"pointerMove\": () => /* binding */ pointerMove,\\n/* harmony export */   \"pointerUp\": () => /* binding */ pointerUp,\\n/* harmony export */   \"pointerDownPosition\": () => /* binding */ pointerDownPosition,\\n/* harmony export */   \"preventNextClick\": () => /* binding */ preventNextClick,\\n/* harmony export */   \"isPointerDown\": () => /* binding */ isPointerDown,\\n/* harmony export */   \"isPointerTouch\": () => /* binding */ isPointerTouch,\\n/* harmony export */   \"hasPointerMoved\": () => /* binding */ hasPointerMoved,\\n/* harmony export */   \"isMobile\": () => /* binding */ isMobile\\n/* harmony export */ });\\n/**\\n * Event name of the pointer down event.\\n */\\nvar pointerDown = \"mousedown\";\\n/**\\n * Event name of the pointer move event.\\n */\\nvar pointerMove = \"mousemove\";\\n/**\\n * Event name of the pointer up event.\\n */\\nvar pointerUp = \"mouseup\";\\n/**\\n * Position the pointer was pressed at.\\n */\\nvar pointerDownPosition = { x: 0, y: 0 };\\n/**\\n * Should the next click on the document be supressed?\\n */\\nvar preventNextClick = false;\\n/**\\n * Is the pointer down?\\n */\\nvar isPointerDown = false;\\n/**\\n * Is the pointer a touch point?\\n */\\nvar isPointerTouch = false;\\n/**\\n * Did the pointer move since the last down event?\\n */\\nvar hasPointerMoved = false;\\n/**\\n * Is the user agent a mobile agent?\\n */\\nvar isMobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);\\ndocument.documentElement.classList.add(isMobile ? \"is-mobile\" : \"not-mobile\");\\nif (isMobile && \"ontouchstart\" in document.documentElement) {\\n    isPointerTouch = true;\\n    pointerDown = \"touchstart\";\\n    pointerMove = \"touchmove\";\\n    pointerUp = \"touchend\";\\n}\\ndocument.addEventListener(pointerDown, function (e) {\\n    isPointerDown = true;\\n    hasPointerMoved = false;\\n    var t = pointerDown == \"touchstart\"\\n        ? e.targetTouches[0]\\n        : e;\\n    pointerDownPosition.y = t.pageY || 0;\\n    pointerDownPosition.x = t.pageX || 0;\\n});\\ndocument.addEventListener(pointerMove, function (e) {\\n    if (!isPointerDown)\\n        return;\\n    if (!hasPointerMoved) {\\n        var t = pointerDown == \"touchstart\"\\n            ? e.targetTouches[0]\\n            : e;\\n        var x = pointerDownPosition.x - (t.pageX || 0);\\n        var y = pointerDownPosition.y - (t.pageY || 0);\\n        hasPointerMoved = Math.sqrt(x * x + y * y) > 10;\\n    }\\n});\\ndocument.addEventListener(pointerUp, function () {\\n    isPointerDown = false;\\n});\\ndocument.addEventListener(\"click\", function (e) {\\n    if (preventNextClick) {\\n        e.preventDefault();\\n        e.stopImmediatePropagation();\\n        preventNextClick = false;\\n    }\\n});\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/pointer.ts?'\n              )\n\n              /***/\n            },\n\n          /***/ './default/assets/js/src/typedoc/utils/trottle.ts':\n            /*!********************************************************!*\\\n  !*** ./default/assets/js/src/typedoc/utils/trottle.ts ***!\n  \\********************************************************/\n            /***/ (\n              __unused_webpack_module,\n              __webpack_exports__,\n              __webpack_require__\n            ) => {\n              'use strict'\n              eval(\n                '__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */   \"throttle\": () => /* binding */ throttle\\n/* harmony export */ });\\nvar throttle = function (fn, wait) {\\n    if (wait === void 0) { wait = 100; }\\n    var time = Date.now();\\n    return function () {\\n        var args = [];\\n        for (var _i = 0; _i < arguments.length; _i++) {\\n            args[_i] = arguments[_i];\\n        }\\n        if (time + wait - Date.now() < 0) {\\n            fn.apply(void 0, args);\\n            time = Date.now();\\n        }\\n    };\\n};\\n\\n\\n//# sourceURL=webpack:///./default/assets/js/src/typedoc/utils/trottle.ts?'\n              )\n\n              /***/\n            },\n\n          /******/\n        }\n        /************************************************************************/\n        /******/ // The module cache\n        /******/ var __webpack_module_cache__ = {}\n        /******/\n        /******/ // The require function\n        /******/ function __webpack_require__(moduleId) {\n          /******/ // Check if module is in cache\n          /******/ if (__webpack_module_cache__[moduleId]) {\n            /******/ return __webpack_module_cache__[moduleId].exports\n            /******/\n          }\n          /******/ // Create a new module (and put it into the cache)\n          /******/ var module = (__webpack_module_cache__[moduleId] = {\n            /******/ // no module.id needed\n            /******/ // no module.loaded needed\n            /******/ exports: {},\n            /******/\n          })\n          /******/\n          /******/ // Execute the module function\n          /******/ __webpack_modules__[moduleId](\n            module,\n            module.exports,\n            __webpack_require__\n          )\n          /******/\n          /******/ // Return the exports of the module\n          /******/ return module.exports\n          /******/\n        }\n        /******/\n        /************************************************************************/\n        /******/ /* webpack/runtime/compat get default export */\n        /******/ ;(() => {\n          /******/ // getDefaultExport function for compatibility with non-harmony modules\n          /******/ __webpack_require__.n = module => {\n            /******/ var getter =\n              module && module.__esModule\n                ? /******/ () => module['default']\n                : /******/ () => module\n            /******/ __webpack_require__.d(getter, { a: getter })\n            /******/ return getter\n            /******/\n          }\n          /******/\n        })() /* webpack/runtime/define property getters */\n        /******/\n        /******/\n        /******/\n        ;(() => {\n          /******/ // define getter functions for harmony exports\n          /******/ __webpack_require__.d = (exports, definition) => {\n            /******/ for (var key in definition) {\n              /******/ if (\n                __webpack_require__.o(definition, key) &&\n                !__webpack_require__.o(exports, key)\n              ) {\n                /******/ Object.defineProperty(exports, key, {\n                  enumerable: true,\n                  get: definition[key],\n                })\n                /******/\n              }\n              /******/\n            }\n            /******/\n          }\n          /******/\n        })() /* webpack/runtime/hasOwnProperty shorthand */\n        /******/\n        /******/\n        /******/\n        ;(() => {\n          /******/ __webpack_require__.o = (obj, prop) =>\n            Object.prototype.hasOwnProperty.call(obj, prop)\n          /******/\n        })() /* webpack/runtime/make namespace object */\n        /******/\n        /******/\n        /******/\n        ;(() => {\n          /******/ // define __esModule on exports\n          /******/ __webpack_require__.r = exports => {\n            /******/ if (typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n              /******/ Object.defineProperty(exports, Symbol.toStringTag, {\n                value: 'Module',\n              })\n              /******/\n            }\n            /******/ Object.defineProperty(exports, '__esModule', {\n              value: true,\n            })\n            /******/\n          }\n          /******/\n        })()\n        /******/\n        /************************************************************************/\n        /******/ // startup\n        /******/ // Load entry module\n        /******/ __webpack_require__('./default/assets/js/src/bootstrap.ts')\n        /******/ // This entry module used 'exports' so it can't be inlined\n        /******/\n      })()\n    </script>\n  </body>\n</html>\n"
  }
]