[
  {
    "path": ".editorconfig",
    "content": "# editorconfig.org\n\nroot = true\n\n[*]\ncharset = utf-8\nend_of_line = lf\ninsert_final_newline = true\ntrim_trailing_whitespace = true\nindent_style = space\nindent_size = 2\n"
  },
  {
    "path": ".eslintrc.json",
    "content": "{\n  \"extends\": \"theme-next\",\n  \"root\": true\n}\n"
  },
  {
    "path": ".gitattributes",
    "content": "source/lib/* linguist-vendored\n"
  },
  {
    "path": ".github/CODE_OF_CONDUCT.md",
    "content": "<div align=\"right\">\n  Language:\n  :us:\n  <a title=\"Chinese\" href=\"../docs/zh-CN/CODE_OF_CONDUCT.md\">:cn:</a>\n  <a title=\"Russian\" href=\"../docs/ru/CODE_OF_CONDUCT.md\">:ru:</a>\n</div>\n\n# <div align=\"center\"><a title=\"Go to homepage\" href=\"https://theme-next.org\"><img align=\"center\" width=\"56\" height=\"56\" src=\"https://raw.githubusercontent.com/theme-next/hexo-theme-next/master/source/images/logo.svg?sanitize=true\"></a> e x T</div>\n\n[NexT](https://theme-next.org) is an elegant and powerful theme for [Hexo](https://hexo.io/). With it, you can build a static blog hosted on [GitHub Pages](https://pages.github.com/) to share your life and communicate with new friends.\n\nA CODE_OF_CONDUCT dictates how conversation during code updates, issue communication, and pull requests should happen within [NexT](https://github.com/theme-next/hexo-theme-next) repository.  We expect all users to show respect and courtesy to others through our repositories. Anyone violating these rules will not be reviewed and will be blocked and expelled from our repositories immediately upon discovery.\n\n## Table Of Contents\n\n- [Our Pledge](#our-pledge)\n- [Our Responsibilities](#our-responsibilities)\n- [Our Standards](#our-standards)\n- [Scope](#scope)\n- [Enforcement](#enforcement)\n- [Contacting Maintainers](#contacting-maintainers)\n- [Attribution](#attribution)\n\n## Our Pledge\n\nAs contributors and maintainers of this project, we pledge to respect all people who contribute through reporting issues, posting feature requests, updating documentation, submitting pull requests or patches, and other activities.\n\nIn the interest of fostering an open and welcoming environment, we are committed to making participation in our community a harassment-free experience for everyone, regardless of level of experience, gender, gender identity and expression, sexual identity and orientation, disability, personal appearance, body size, race, ethnicity, age, religion, or nationality.\n\n## Our Responsibilities\n\nProject maintainers have the right and responsibility to clarify the standards of acceptable behavior and are expected to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, or to block temporarily or permanently any contributor for other behaviors that they deem inappropriate, threatening, offensive, or harmful.\n\n## Our Standards\n\nAs a project on GitHub, this project is overed by the [GitHub Community Guidelines](https://help.github.com/articles/github-community-guidelines/). Additionally, as a project hosted on npm, it is covered by [npm Inc's Code of Conduct](https://www.npmjs.com/policies/conduct).\n\nExamples of behavior that contributes to creating a positive environment include:\n\n* Using welcoming and inclusive language.\n* Being respectful of differing viewpoints and experiences.\n* Gracefully accepting constructive feedback.\n* Focusing on what is best for the community.\n* Showing empathy and kindness towards other community members.\n\nExamples of unacceptable behavior by participants include:\n\n* The use of sexualized language or imagery and unwelcome sexual attention or advances\n* Trolling, insulting/derogatory comments, and personal or political attacks\n* Public or private harassment\n* Publishing others’ private information, such as a physical or electronic address, without explicit permission\n* Other conduct which could reasonably be considered inappropriate in a professional setting\n\n## Scope\n\nThis Code of Conduct applies both within project spaces and in public spaces when an individual is representing the project or its community.\n\nDepending on the violation, the maintainers may decide that violations of this code of conduct that have happened outside of the scope of the community may deem an individual unwelcome, and take appropriate action to maintain the comfort and safety of its members.\n\n## Enforcement\n\nIf you see a Code of Conduct violation, follow these steps:\n\n1. Let the person know that what they did is not appropriate and ask them to stop and/or edit their message(s) or commits. That person should immediately stop the behavior and correct the issue.\n2. If this doesn’t happen, or if you're uncomfortable speaking up, [contact the maintainers](#contacting-maintainers). When reporting, please include any relevant details, links, screenshots, context, or other information that may be used to better understand and resolve the situation.\n3. As soon as available, a maintainer will look into the issue, and take further action.\n\nOnce the maintainers get involved, they will follow a documented series of steps and do their best to preserve the well-being of project members.\n\nAll complaints will be reviewed and investigated and will result in a response that is deemed necessary and appropriate to the circumstances. The project team is obligated to maintain confidentiality with regard to the reporter of an incident. Further details of specific enforcement policies may be posted separately.\n\nThesehese are the steps maintainers will take for further enforcement, as needed:\n\n1. Repeat the request to stop.\n2. If the person doubles down, they will have offending messages removed or edited by a maintainers given an official warning. The PR or Issue may be locked.\n3. If the behavior continues or is repeated later, the person will be blocked from participating for 24 hours.\n4. If the behavior continues or is repeated after the temporary block, a long-term (6-12 months) ban will be used.\n\nOn top of this, maintainers may remove any offending messages, images, contributions, etc, as they deem necessary. Maintainers reserve full rights to skip any of these steps, at their discretion, if the violation is considered to be a serious and/or immediate threat to the well-being of members of the community. These include any threats, serious physical or verbal attacks, and other such behavior that would be completely unacceptable in any social setting that puts our members at risk.\n\nProject maintainers who do not follow or enforce the Code of Conduct in good faith may face temporary or permanent repercussions as determined by other members of the project's leadership.\n\n## Contacting Maintainers\n\nYou may get in touch with the maintainer team through any of the following methods:\n\n* Through Email:\n    * [support@theme-next.org](mailto:support@theme-next.org)\n\n* Through Chat:\n    * [Gitter](https://gitter.im/theme-next)\n    * [Riot](https://riot.im/app/#/room/#NexT:matrix.org)\n    * [Telegram](https://t.me/joinchat/GUNHXA-vZkgSMuimL1VmMw)\n\n## Attribution\n\nThis Code of Conduct is adapted from the [Contributor Covenant](https://www.contributor-covenant.org/) and [WeAllJS Code of Conduct](https://wealljs.org/code-of-conduct).\n"
  },
  {
    "path": ".github/CONTRIBUTING.md",
    "content": "<div align=\"right\">\n  Language:\n  :us:\n  <a title=\"Chinese\" href=\"../docs/zh-CN/CONTRIBUTING.md\">:cn:</a>\n  <a title=\"Russian\" href=\"../docs/ru/CONTRIBUTING.md\">:ru:</a>\n</div>\n\n# <div align=\"center\"><a title=\"Go to homepage\" href=\"https://theme-next.org\"><img align=\"center\" width=\"56\" height=\"56\" src=\"https://raw.githubusercontent.com/theme-next/hexo-theme-next/master/source/images/logo.svg?sanitize=true\"></a> e x T</div>\n\nFirst of all, thanks for taking your time to contribute and help make our project even better than it is today! The following is a set of guidelines for contributing to [Theme-Next](https://github.com/theme-next) and its libs submodules. These are mostly guidelines, not rules. Use your best judgment, and feel free to propose changes to this document in a pull request.\n\n## Table Of Contents\n\n[How Can I Contribute?](#how-can-i-contribute)\n\n  * [Before Submitting An Issue](#before-submitting-an-issue)\n    * [Read the docs](#read-the-docs)\n    * [Quick debug instructions](quick-debug-instructions)\n  * [Reporting Bugs](#reporting-bugs)\n    * [Reporting Security Bugs](#reporting-security-bugs)\n  * [Suggesting Enhancements](#suggesting-enhancements)\n  * [Submitting a Pull Request](#submitting-a-pull-request)\n  * [Creating Releases](#creating-releases)\n\n[Guides](#guides)\n\n  * [Coding Rules](#coding-rules)\n  * [Coding Standards](#coding-standards)\n  * [Labels Rules](#labels-rules)\n  * [Commit Messages Rules](#commit-messages-rules)\n\n## How Can I Contribute?\n\n### Before Submitting An Issue\n\n#### Read the docs\n\nIf you just have a question, you'll get faster results by checking the [FAQs for a list of common questions and problems](https://theme-next.org/docs/faqs) or the [troubleshooting part of «NexT» Documentation Site](https://theme-next.org/docs/troubleshooting).\n\nAlso, you can perform a [cursory search](https://github.com/theme-next/hexo-theme-next/search?q=&type=Issues&utf8=%E2%9C%93) to see if the problem has already been reported or solved. You don't want to duplicate effort. You might be able to find the cause of the problem and fix things yourself, or add comments to the existed issue.\n\n#### Quick debug instructions\n\nBefore submitting an Issue on GitHub, you can follow the steps below to debug:\n\n* Execute `hexo clean`, clear the browser cache and disable all CDN services (e.g. Cloudflare Rocket Loader)\n* Switch to another theme and check if the bug still exists (e.g. default theme landscape). In other words, prove that this is a NexT issue, not a issue from Hexo.\n* Upgrade theme NexT to the latest version.\n* Upgrade Hexo and Hexo plugins to the latest version.\n* Upgrade Node.js and `npm` to the latest version.\n* Uninstall all non-essential Hexo plugins, or reinstall all plugins using `npm install --save`.\n\nIf you get an error message from Hexo or your browser, please search in Google / Stackoverflow / GitHub Issues, or report it to us when submitting a new Issue.\n\nIf you find a bug in the source code, most importantly, please check carefully if you can reproduce the problem [in the latest release version of Next](https://github.com/theme-next/hexo-theme-next/releases/latest). Then, you can help us by [Reporting Bugs](#reporting-bugs) or [Suggesting Enhancements](#suggesting-enhancements) to our [Repository](https://github.com/theme-next/hexo-theme-next). Even better, you can [submit a Pull Request](#submitting-a-pull-request) with a fix.\n\n### Reporting Bugs\n\nBefore creating bug reports, please check [this list](#before-submitting-an-issue) as you might find out that you don't need to create one. After you've determined the repository your bug is related to, create an issue on that repository and provide the information as many details as possible by filling in [the required template](ISSUE_TEMPLATE.md).\n\nFollowing these guidelines helps maintainers and the community understand your report :pencil:, reproduce the behavior, and find related reports:\n\n* Use a clear and descriptive title for the issue to identify the problem.\n* Provide more context by answering these questions:\n    * Can you reproduce the problem? Can you reliably reproduce the issue? If not, provide details about how often the problem happens and under which conditions it normally happens.\n    * Did the problem start happening recently or was this always a problem?\n    * If the problem started happening recently, can you reproduce the problem in an older version of Next? What's the most recent version in which the problem doesn't happen? You can download older versions of Next from [the releases page](https://github.com/theme-next/hexo-theme-next/releases).\n    * Which version of Node, Hexo and Next are you using? You can get the exact version by running `node -v`, `hexo version` in your terminal, or copy the contents in site's`package.json`.\n    * Which packages do you have installed? You can get that list by copying the contents in site's`package.json`.\n* Describe the exact steps which reproduce the problem in as many details as possible. When listing steps, don't just say what you did, but explain how you did it, e.g. which command exactly you used. If you're providing snippets in the issue, use [Markdown code blocks](https://help.github.com/articles/creating-and-highlighting-code-blocks/) or [a permanent link to a code snippet](https://help.github.com/articles/creating-a-permanent-link-to-a-code-snippet/), or a [Gist link](https://gist.github.com/).\n* Provide specific examples to demonstrate the steps. Include links to files (screenshots or GIFs) or live demo.\n* Describe the behavior you observed after following the steps and point out what exactly is the problem with that behavior.\n* Explain which behavior you expected to see instead and why.\n\n#### Reporting Security Bugs\n\nIf you find a security issue, please act responsibly and report it not in the public issue tracker, but directly to us, so we can fix it before it can be exploited. Please send the related information to security@theme-next.com (desirable with using PGP for e-mail encryption).\n\nWe will gladly special thanks to anyone who reports a vulnerability so that we can fix it. If you want to remain anonymous or pseudonymous instead, please let us know that; we will gladly respect your wishes.\n\n### Suggesting Enhancements\n\nBefore creating enhancement suggestions, please check [this list](#before-submitting-an-issue) as you might find out that you don't need to create one. After you've determined the repository your enhancement suggestion is related to, create an issue on that repository and provide the information as many details as possible by filling in [the required template](ISSUE_TEMPLATE.md).\n\nFollowing these guidelines helps maintainers and the community understand your suggestion :pencil: and find related suggestions.\n\n* Use a clear and descriptive title for the issue to identify the suggestion.\n* Describe the current behavior and explain which behavior you expected to see instead and Explain why this enhancement would be useful to most users.\n* Provide specific examples to demonstrate the suggestion. Include links to files (screenshots or GIFs) or live demo.\n\n### Submitting a Pull Request\n\nBefore creating a Pull Request (PR), please check [this list](#before-submitting-an-issue) as you might find out that you don't need to create one. After you've determined the repository your pull request is related to, create a pull request on that repository. The detailed document of creating a pull request can be found [here](https://help.github.com/articles/creating-a-pull-request/).\n\nFollowing these guidelines helps maintainers and the community understand your pull request :pencil::\n\n* Follow our [Coding Rules](#coding-rules) and [commit message conventions](#commit-messages-rules).\n* Use a clear and descriptive title for the issue to identify the pull request. Do not include issue numbers in the PR title.\n* Fill in [the required template](PULL_REQUEST_TEMPLATE.md) as many details as possible.\n* All features or bug fixes must be tested in all schemes. And provide specific examples to demonstrate the pull request. Include links to files (screenshots or GIFs) or live demo.\n\n### Creating Releases\n\nReleases are a great way to ship projects on GitHub to your users.\n\n1. On GitHub, navigate to the main page of the repository. Under your repository name, click **Releases**. Click **Draft a new release**.\n2. Type a version number for your release. Versions are based on [Git tags](https://git-scm.com/book/en/Git-Basics-Tagging). We recommend naming tags that fit within [About Major and Minor NexT versions](https://github.com/theme-next/hexo-theme-next/issues/187).\n3. Select a branch that contains the project you want to release. Usually, you'll want to release against your `master` branch, unless you're releasing beta software.\n4. Type a title and description that describes your release.\n    - Use the version as the title.\n    - The types of changes include **Breaking Changes**, **Updates**, **Features**, and **Bug Fixes**. In the section of Breaking Changes, use multiple secondary headings, and use item list in other sections.\n    - Use the passive tense and subject-less sentences.\n    - All changes must be documented in release notes. If commits happen without pull request (minimal changes), just add this commit ID into release notes. If commits happen within pull request alreay, just add the related pull request ID including all possible commits.\n5. If you'd like to include binary files along with your release, such as compiled programs, drag and drop or select files manually in the binaries box.\n6. If the release is unstable, select **This is a pre-release** to notify users that it's not ready for production. If you're ready to publicize your release, click **Publish release**. Otherwise, click **Save draft** to work on it later.\n\n## Guides\n\n### Coding Rules\n\nThis project and everyone participating in it is governed by the [Code of Conduct](CODE_OF_CONDUCT.md) to keep open and inclusive. By participating, you are expected to uphold this code.\n\n### Coding Standards\n\nWe use ESLint and Stylint for identifying and reporting on patterns in JavaScript and Stylus, with the goal of making code more consistent and avoiding bugs. These specifications should be followed when coding.\n\n### Labels Rules\n\nWe use \"labels\" in the issue tracker to help classify Pull requests and Issues. Using labels enables maintainers and users to quickly find issues they should look into, either because they experience them, or because it meets their area of expertise.\n\nIf you are unsure what a label is about or which labels you should apply to a PR or issue, look no further!\n\nIssues related:\n\n- By types\n    - `Bug`: A detected bug that needs to be confirmed\n    - `Feature Request`: An issue that wants a new feature\n    - `Question`: An issue about questions\n    - `Meta`: Denoting a change of usage conditions\n    - `Support`: An issue labeled as support requests\n    - `Polls`: An issue that initiated a poll\n- By results\n    - `Duplicate`: An issue which had been mentioned\n    - `Irrelevant`: An irrelevant issue for Next\n    - `Invalid`: An issue that cannot be reproduced\n    - `Expected Behavior`: An issue that corresponds to expected behavior\n    - `Need More Info`: Need more information for solving the issue\n    - `Verified`: An issue that has been verified\n    - `Solved`: An issue that has been solved\n    - `Backlog`: An issue that is to be completed and later compensated\n    - `Stale`: This issue has been automatically marked as stale because lack of recent activity\n\nPull requests related:\n\n- `Breaking Change`: A pull request that makes breaking change\n- `Bug Fix`: A pull request that fixes the related bug\n- `New Feature`: A pull request that provides a new feature\n- `Feature`: A pull request that provides an option or addition to existing feature\n- `i18n`: A pull request that makes new languages translation\n- `Work in Progress`: A pull request that is still working in progress\n- `Skip Release`: A pull request that should be excluded from release note\n\nBoth:\n\n- `Roadmap`: An issue / pull request about future development\n- `Help Wanted`: An issue / pull request that needs help\n- `Discussion`: An issue / pull request that needs to be discussed\n- `Improvement`: An issue that needs improvement or a pull request that improves NexT\n- `Performance`: An issue / pull request that improves the performance\n- `Hexo`: An issue / pull request related to Hexo or Hexo plugins\n- `Template Engine`: An issue / pull request related to template engine\n- `CSS`: An issue / pull request related to CSS\n- `Fonts`: An issue / pull request related to fonts\n- `PJAX`: An issue / pull request related to PJAX\n- `3rd Party Plugin`: An issue / pull request related to 3rd party plugins & service\n- `Docs`: An issue / pull request related to instruction document\n- `Configurations`: An issue / pull request related to configurations\n\n### Commit Messages Rules\n\nWe have very precise rules over how our git commit messages can be formatted. Each commit message consists of a `type` and a `subject`. This leads to more\nreadable messages that are easy to follow when looking through the project history.\n\n- `type` describes the meaning of this commit including but not limited to the following items, and capitalize the first letter.\n    * `Build`: Changes that affect the build system or external dependencies\n    * `Ci`: Changes to our CI configuration files and scripts\n    * `Docs`: Documentation only changes\n    * `Feat`: A new feature\n    * `Fix`: A bug fix\n    * `Perf`: A code change that improves performance\n    * `Refactor`: A code change that neither fixes a bug nor adds a feature\n    * `Style`: Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)\n    * `Revert`: Revert some existing commits\n    * `Release`: Commit a release for a conventional changelog project\n- The `subject` contains a succinct description of the change, like `Update code highlighting in readme.md`.\n    * No dot (.) at the end.\n    * Use the imperative, present tense: \"change\" not \"changed\" nor \"changes\".\n"
  },
  {
    "path": ".github/ISSUE_TEMPLATE/bug-report.md",
    "content": "---\nname: Bug Report\nabout: Something isn't working as expected\ntitle: ''\nlabels: Bug\nassignees: ''\n\n---\n\nPlease follow this Issue template to provide relevant information, such as source code repositories, blog links, and screenshots, which will help us investigate.\n请按照此 Issue 模版提供相关信息，例如源码仓库、博客链接和屏幕截图，这将有助于我们进行调查。\n\n## Issue Checklist <!-- 我确认我已经查看了 -->\n<!-- Change [ ] to [x] to select (将 [ ] 换成 [x] 来选择) -->\n\n- [ ] I am using [the latest](https://github.com/theme-next/hexo-theme-next/releases/latest) version of NexT.\n- [ ] I have read the relevant documents of [Hexo](https://hexo.io/docs/) and [NexT](https://theme-next.org/docs/).\n- [ ] I have reviewed the latest Roadmap on GitHub and searched for current [issues](https://github.com/theme-next/hexo-theme-next/issues), which does not help me.\n\n***\n\n## Expected behavior <!-- 预期行为 -->\n\n\n## Actual behavior <!-- 实际行为 -->\n<!-- Please provide at least one of the following information (请至少提供以下的一项信息) -->\n\n- Links to demo site with this issue: N/A\n- Links to repository or source code of the blog: N/A\n\n\n## Steps to reproduce the behavior <!-- 重现步骤 -->\n1. N/A\n2. N/A\n3. N/A\n\n\n## Environment Information\n\n### Node.js and NPM Information\n<!-- Paste output from `node -v && npm -v` (粘贴 `node -v && npm -v` 输出的信息) -->\n```\n\n```\n\n### Package dependencies Information\n<!-- Paste output from `npm ls --depth 0` (粘贴 `npm ls --depth 0` 输出的信息) -->\n```\n\n```\n\n### Hexo Configuration\n<!-- Paste configuration from Hexo `_config.yml` (粘贴 Hexo `_config.yml` 中的内容) -->\n```yml\n\n```\n\n### NexT Configuration\n<!-- Paste ONLY CHANGED CONFIGURATION from NexT `_config.yml` (只粘贴 NexT 主题配置文件 `_config.yml` 中修改过的部分) -->\n```yml\n\n```\n\n## Other Information <!-- (Like Browser, System, Screenshots) -->\n"
  },
  {
    "path": ".github/ISSUE_TEMPLATE/feature-request.md",
    "content": "---\nname: Feature Request\nabout: Suggest an idea for this project\ntitle: ''\nlabels: Feature Request\nassignees: ''\n\n---\n\nPlease follow this Issue template to provide relevant information, such as source code repositories, blog links, and screenshots, which will help us investigate.\n请按照此 Issue 模版提供相关信息，例如源码仓库、博客链接和屏幕截图，这将有助于我们进行调查。\n\n## Issue Checklist <!-- 我确认我已经查看了 -->\n<!-- Change [ ] to [x] to select (将 [ ] 换成 [x] 来选择) -->\n\n- [ ] I am using [the latest](https://github.com/theme-next/hexo-theme-next/releases/latest) version of NexT.\n- [ ] I have read the relevant documents of [Hexo](https://hexo.io/docs/) and [NexT](https://theme-next.org/docs/).\n- [ ] I have reviewed the latest Roadmap on GitHub and searched for current [issues](https://github.com/theme-next/hexo-theme-next/issues), which does not help me.\n\n***\n\n## Expected behavior <!-- 预期行为 -->\n\n\n## Actual behavior <!-- 实际行为 -->\n<!-- Please provide at least one of the following information (请至少提供以下的一项信息) -->\n\n- Links to demo site with this feature: N/A\n- Links to repository or source code of the blog: N/A\n\n\n## Steps to reproduce the behavior <!-- 重现步骤 -->\n1. N/A\n2. N/A\n3. N/A\n\n## Other Information <!-- Like Browser, System, Screenshots -->\n"
  },
  {
    "path": ".github/ISSUE_TEMPLATE/other.md",
    "content": "---\nname: Other\nabout: Not a question, feature request or bug report\ntitle: ''\nlabels: ''\nassignees: ''\n\n---\n\nPlease follow this Issue template to provide relevant information, such as source code repositories, blog links, and screenshots, which will help us investigate.\n请按照此 Issue 模版提供相关信息，例如源码仓库、博客链接和屏幕截图，这将有助于我们进行调查。\n\n## Issue Checklist <!-- 我确认我已经查看了 -->\n<!-- Change [ ] to [x] to select (将 [ ] 换成 [x] 来选择) -->\n\n- [ ] I am using [the latest](https://github.com/theme-next/hexo-theme-next/releases/latest) version of NexT.\n- [ ] I have read the relevant documents of [Hexo](https://hexo.io/docs/) and [NexT](https://theme-next.org/docs/).\n- [ ] I have reviewed the latest Roadmap on GitHub and searched for current [issues](https://github.com/theme-next/hexo-theme-next/issues), which does not help me.\n\n***\n\n## Other Information <!-- Like Browser, System, Screenshots -->\n"
  },
  {
    "path": ".github/ISSUE_TEMPLATE/question.md",
    "content": "---\nname: Question\nabout: I have a question for NexT (e.g. Customize)\ntitle: ''\nlabels: Custom\nassignees: ''\n\n---\n\nPlease follow this Issue template to provide relevant information, such as source code repositories, blog links, and screenshots, which will help us investigate.\n请按照此 Issue 模版提供相关信息，例如源码仓库、博客链接和屏幕截图，这将有助于我们进行调查。\n\n## Issue Checklist <!-- 我确认我已经查看了 -->\n<!-- Change [ ] to [x] to select (将 [ ] 换成 [x] 来选择) -->\n\n- [ ] I am using [the latest](https://github.com/theme-next/hexo-theme-next/releases/latest) version of NexT.\n- [ ] I have read the relevant documents of [Hexo](https://hexo.io/docs/) and [NexT](https://theme-next.org/docs/).\n- [ ] I have reviewed the latest Roadmap on GitHub and searched for current [issues](https://github.com/theme-next/hexo-theme-next/issues), which does not help me.\n\n***\n\n## Expected behavior <!-- 预期行为 -->\n\n\n## Actual behavior <!-- 实际行为 -->\n<!-- Please provide at least one of the following information (请至少提供以下的一项信息) -->\n\n- Links to demo site with this issue: N/A\n- Links to repository or source code of the blog: N/A\n\n\n## Steps to reproduce the behavior <!-- 重现步骤 -->\n1. N/A\n2. N/A\n3. N/A\n\n\n## Environment Information\n\n### Node.js and NPM Information\n<!-- Paste output from `node -v && npm -v` (粘贴 `node -v && npm -v` 输出的信息) -->\n```\n\n```\n\n### Package dependencies Information\n<!-- Paste output from `npm ls --depth 0` (粘贴 `npm ls --depth 0` 输出的信息) -->\n```\n\n```\n\n### Hexo Configuration\n<!-- Paste configuration from Hexo `_config.yml` (粘贴 Hexo `_config.yml` 中的内容) -->\n```yml\n\n```\n\n### NexT Configuration\n<!-- Paste ONLY CHANGED CONFIGURATION from NexT `_config.yml` (只粘贴 NexT 主题配置文件 `_config.yml` 中修改过的部分) -->\n```yml\n\n```\n\n## Other Information <!-- Like Browser, System, Screenshots -->\n"
  },
  {
    "path": ".github/PULL_REQUEST_TEMPLATE.md",
    "content": "<!-- ATTENTION!\n1. Please write pull request readme in English, thanks!\n\n2. Always remember that NexT includes 4 schemes. And if on one of them works fine after the changes, on another scheme this changes can be broken. Muse and Mist have similar structure, but Pisces is very difference from them. Gemini is a mirror of Pisces with some styles and layouts remakes. So, please make the tests at least on two schemes (Muse or Mist and Pisces or Gemini).\n\n3. In addition, you need to confirm that the changes made by this PR are compatible with PJAX and Dark Mode.\n-->\n\n## PR Checklist <!-- 我确认我已经查看了 -->\n<!-- Change [ ] to [x] to select (将 [ ] 换成 [x] 来选择) -->\n\n- [ ] The commit message follows [guidelines for NexT](https://github.com/theme-next/hexo-theme-next/blob/master/.github/CONTRIBUTING.md).\n- [ ] Tests for the changes was maked (for bug fixes / features).\n   - [ ] Muse | Mist have been tested.\n   - [ ] Pisces | Gemini have been tested.\n- [ ] [Docs](https://github.com/theme-next/theme-next.org/tree/source/source/docs) in [NexT website](https://theme-next.org/docs/) have been added / updated (for features).\n<!-- For adding Docs edit needed file here: https://github.com/theme-next/theme-next.org/tree/source/source/docs and create PR with this changes here: https://github.com/theme-next/theme-next.org/pulls -->\n\n## PR Type\n<!-- What kind of change does this PR introduce? -->\n\n- [ ] Bugfix.\n- [ ] Feature.\n- [ ] Code style update (formatting, local variables).\n- [ ] Refactoring (no functional changes, no api changes).\n- [ ] Build & CI related changes.\n- [ ] Documentation.\n- [ ] Translation. <!-- We use Crowdin to manage translations https://i18n.theme-next.org -->\n- [ ] Other... Please describe:\n\n## What is the current behavior?\n<!-- Please describe the current behavior that you are modifying, or link to a relevant issue -->\n\nIssue resolved: N/A\n\n## What is the new behavior?\n<!-- Description about this pull, in several words -->\n\n- Screenshots with this changes: N/A\n- Link to demo site with this changes: N/A\n\n### How to use?\nIn NexT `_config.yml`:\n```yml\n\n```\n"
  },
  {
    "path": ".github/config.yml",
    "content": "# =============================================================================================== #\n# Configuration for welcome - https://github.com/behaviorbot/welcome\n\n# Comment to be posted to on first time issues\nnewIssueWelcomeComment: >\n  Thanks for opening this issue, maintainers will get back to you as soon as possible!\n\n# Comment to be posted to on PRs from first time contributors in your repository\nnewPRWelcomeComment: >\n  Thanks so much for opening your first PR here!\n\n# Comment to be posted to on pull requests merged by a first time user\nfirstPRMergeComment: >\n  Congrats on merging your first pull request here! :tada: How awesome!\n\n# =============================================================================================== #\n# Configuration for request-info - https://github.com/behaviorbot/request-info\n\n# *OPTIONAL* Label to be added to Issues and Pull Requests with insufficient information given\nrequestInfoLabelToAdd: Need More Info\n\n# *OPTIONAL* Add a list of people whose Issues/PRs will not be commented on\n# keys must be GitHub usernames\nrequestInfoUserstoExclude:\n  - 1v9\n  - Acris\n  - flashlab\n  - geekrainy\n  - iissnan\n  - ivan-nginx\n  - JiangTJ\n  - LEAFERx\n  - liolok\n  - maple3142\n  - Raincal\n  - sli1989\n  - stevenjoezhang\n  - tsanie\n  - wafer-li\n\n# =============================================================================================== #\nlockThreads:\n  toxicityThreshold: .7\n  numComments: 2\n  setTimeInHours: 72\n  replyComment: >\n    This thread is being locked due to exceeding the toxicity minimums. cc/ @theme-next/next\n"
  },
  {
    "path": ".github/issue-close-app.yml",
    "content": "# Comment that will be sent if an issue is judged to be closed.\ncomment: \"This issue has been closed because it does not meet our Issue template. Please read our [guidelines for contributing](https://github.com/theme-next/hexo-theme-next/blob/master/.github/CONTRIBUTING.md#how-can-i-contribute).\"\nissueConfigs:\n# There can be several configs for different kind of issues.\n- content:\n  - \"Issue Checklist\"\n# Optional configuration:\n#\n# whether the keywords are case-insensitive\n# default value is false, which means keywords are case-sensitive\ncaseInsensitive: true\n# the label that will be added when the bot close an issue\n# The bot will only add a label if this property is set.\nlabel: \"Invalid\"\n# The issue is judged to be legal if it includes all keywords from any of these two configs.\n# Or it will be closed by the app.\n"
  },
  {
    "path": ".github/issue_label_bot.yaml",
    "content": "label-alias:\n  bug: 'Bug'\n  feature_request: 'Feature Request'\n  question: 'Question'\n"
  },
  {
    "path": ".github/lock.yml",
    "content": "# Configuration for Lock Threads - https://github.com/dessant/lock-threads\n\n# Number of days of inactivity before a closed issue or pull request is locked\ndaysUntilLock: 365\n\n# Skip issues and pull requests created before a given timestamp. Timestamp must\n# follow ISO 8601 (`YYYY-MM-DD`). Set to `false` to disable\nskipCreatedBefore: false\n\n# Issues and pull requests with these labels will be ignored. Set to `[]` to disable\nexemptLabels: []\n\n# Label to add before locking, such as `outdated`. Set to `false` to disable\nlockLabel: false\n\n# Comment to post before locking. Set to `false` to disable\nlockComment: >\n  This thread has been automatically locked since there has not been\n  any recent activity after it was closed. It is possible issue was\n  solved or at least outdated. Feel free to open new for related bugs.\n\n# Assign `resolved` as the reason for locking. Set to `false` to disable\nsetLockReason: true\n\n# Limit to only `issues` or `pulls`\nonly: issues\n\n# Optionally, specify configuration settings just for `issues` or `pulls`\n# issues:\n#   exemptLabels:\n#     - help-wanted\n#   lockLabel: outdated\n\n# pulls:\n#   daysUntilLock: 30\n\n# Repository to extend settings from\n# _extends: repo\n"
  },
  {
    "path": ".github/mergeable.yml",
    "content": "# Configuration for Mergeable - https://github.com/jusx/mergeable\n\nversion: 2\nmergeable:\n  - when: pull_request.*\n    validate:\n      - do: description\n        no_empty:\n          enabled: false\n\n      - do: title\n        must_exclude:\n          regex: ^\\[WIP\\]\n\n      - do: label\n        must_include:\n          regex: 'change|feat|imp|fix|doc|i18n'\n        must_exclude:\n          regex: 'wip|work in progress'\n\n      #- do: project\n      #  no_empty:\n      #    enabled: true\n      #  must_include:\n      #    regex: 'change|feat|imp|fix|doc|loc'\n\n      - do: milestone\n        no_empty:\n          enabled: true\n"
  },
  {
    "path": ".github/release-drafter.yml",
    "content": "# Configuration for Release Drafter - https://github.com/toolmantim/release-drafter\n\nname-template: 'v$NEXT_MINOR_VERSION'\ntag-template: 'v$NEXT_MINOR_VERSION'\ncategories:\n  - title: '💥 Breaking Changes'\n    label: '💥 Breaking Change'\n\n  - title: '🌟 New Features'\n    label: '🌟 New Feature'\n\n  - title: '⭐ Features'\n    label: '⭐ Feature'\n\n  - title: '🐞 Bug Fixes'\n    label: '🐞 Bug Fix'\n\n  - title: '🛠 Improvements'\n    label: '🛠 Improvement'\n\n  - title: '🌀 External Changes'\n    label: '🔌 3rd Party Plugin'\n\n  - title: '📖 Documentation'\n    label: '📖 Docs'\n\n  - title: '🌍 Localization'\n    label: '🌍 i18n'\n\nchange-template: '- $TITLE (#$NUMBER)'\nno-changes-template: '- No changes'\ntemplate: |\n  $CHANGES\n\n  ***\n\n  For full changes, see the [comparison between $PREVIOUS_TAG and v$NEXT_MINOR_VERSION](https://github.com/theme-next/hexo-theme-next/compare/$PREVIOUS_TAG...v$NEXT_MINOR_VERSION)\n\nexclude-labels:\n  - 'Skip Release'\n"
  },
  {
    "path": ".github/stale.yml",
    "content": "# Configuration for probot-stale - https://github.com/probot/stale\n\n# Number of days of inactivity before an Issue or Pull Request becomes stale\ndaysUntilStale: 30\n# Number of days of inactivity before a stale Issue or Pull Request is closed\ndaysUntilClose: 7\n# Issues or Pull Requests with these labels will never be considered stale. Set to `[]` to disable\nexemptLabels:\n  - Bug\n  - Feature Request\n  - Discussion\n  - Help Wanted\n  - Question\n# Label to use when marking as stale\nstaleLabel: stale\n# Comment to post when marking as stale. Set to `false` to disable\nmarkComment: >\n  This issue has been automatically marked as stale because lack of\n  recent activity. It will be closed if no further activity occurs. Thank you\n  for your contributions. You can also use our [support channels](https://github.com/theme-next/hexo-theme-next#feedback) to get help with the project.\n# Comment to post when removing the stale label. Set to `false` to disable\nunmarkComment: false\n# Comment to post when closing a stale Issue or Pull Request. Set to `false` to disable\ncloseComment: false\n# Limit to only `issues` or `pulls`\nonly: issues\n"
  },
  {
    "path": ".github/support.yml",
    "content": "# Configuration for Support Requests - https://github.com/dessant/support-requests\n\n# Label used to mark issues as support requests\nsupportLabel: Support\n\n# Comment to post on issues marked as support requests, `{issue-author}` is an\n# optional placeholder. Set to `false` to disable\nsupportComment: >\n  :wave: @{issue-author}, we use the issue tracker exclusively for bug reports\n  and feature requests. However, this issue appears to be a support request.\n  Please use our [support channels](https://github.com/theme-next/hexo-theme-next/tree/master#feedback) to get help with the project.\n\n# Close issues marked as support requests\nclose: true\n\n# Lock issues marked as support requests\nlock: false\n\n# Assign `off-topic` as the reason for locking. Set to `false` to disable\nsetLockReason: true\n\n# Repository to extend settings from\n# _extends: repo\n"
  },
  {
    "path": ".gitignore",
    "content": ".DS_Store\n.idea/\n*.log\n*.iml\nyarn.lock\npackage-lock.json\nnode_modules/\n\n# Ignore optional external libraries\nsource/lib/*\n\n# Track internal libraries & Ignore unused verdors files\n!source/lib/font-awesome/\n!source/lib/anime.min.js\n!source/lib/velocity/\n"
  },
  {
    "path": ".stylintrc",
    "content": "{\n  \"blocks\": false,\n  \"brackets\": \"always\",\n  \"colons\": \"always\",\n  \"colors\": \"always\",\n  \"commaSpace\": \"always\",\n  \"commentSpace\": \"always\",\n  \"cssLiteral\": \"never\",\n  \"customProperties\": [],\n  \"depthLimit\": false,\n  \"duplicates\": true,\n  \"efficient\": \"always\",\n  \"exclude\": [],\n  \"extendPref\": false,\n  \"globalDupe\": false,\n  \"groupOutputByFile\": true,\n  \"indentPref\": false,\n  \"leadingZero\": \"never\",\n  \"maxErrors\": false,\n  \"maxWarnings\": false,\n  \"mixed\": false,\n  \"mixins\": [],\n  \"namingConvention\": \"lowercase-dash\",\n  \"namingConventionStrict\": false,\n  \"none\": \"never\",\n  \"noImportant\": true,\n  \"parenSpace\": false,\n  \"placeholders\": \"always\",\n  \"prefixVarsWithDollar\": \"always\",\n  \"quotePref\": false,\n  \"reporterOptions\": {\n    \"columns\": [\"lineData\", \"severity\", \"description\", \"rule\"],\n    \"columnSplitter\": \"  \",\n    \"showHeaders\": false,\n    \"truncate\": true\n  },\n  \"semicolons\": \"always\",\n  \"sortOrder\": \"alphabetical\",\n  \"stackedProperties\": false,\n  \"trailingWhitespace\": \"never\",\n  \"universal\": false,\n  \"valid\": true,\n  \"zeroUnits\": \"never\",\n  \"zIndexNormalize\": false\n}\n"
  },
  {
    "path": ".travis.yml",
    "content": "language: node_js\n\nnode_js: node\n\ncache:\n  npm: true\n\ninstall: npm install\n"
  },
  {
    "path": "LICENSE.md",
    "content": "# <div align=\"center\">«NexT» – Elegant and powerful theme for Hexo.</div>\n\n<p align=\"center\">Copyright © 2017 «<a href=\"https://github.com/theme-next/hexo-theme-next\">NexT</a>».</p>\n\n<p align=\"center\">Detail attribution information for «NexT»<br>\n              is contained in the '<a href=\"docs/AUTHORS.md\">docs/AUTHORS.md</a>' file.</p>\n\n  This program is free software; you can redistribute it and/or modify\nit under the terms of the [GNU Affero General Public License version 3][AGPL3]\nas published by the Free Software Foundation with the addition of the\nfollowing permission added to [Section 15][AGPL3-15] as permitted in [Section 7(a)][AGPL3-7]:\nFOR ANY PART OF THE COVERED WORK IN WHICH THE COPYRIGHT IS OWNED BY «NEXT»,\n«NEXT» DISCLAIMS THE WARRANTY OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.\n\n  This program is distributed in the hope that it will be useful, but\nWITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY\nor FITNESS FOR A PARTICULAR PURPOSE.\nSee the GNU Affero General Public License for more details.\nYou should have received a copy of the GNU Affero General Public License\nalong with this program; if not, see: https://www.gnu.org/licenses/agpl.txt\n\n  In accordance with [Section 7(b)][AGPL3-7] of the GNU Affero General Public License:\n\n* a) It is not necessary to specify copyright in each source file of\n     this program because GitHub fully save commits of all modified files\n     with their authors and provides to see for this changes publicly.\n\n* b) For any part of the covered work in which the copyright not specified,\n     except of third party libraries ('[source/lib/*](source/lib)') and '\\*custom.\\*' files,\n     will mean this part owned by «NexT» in accord with terms in this file.\n\n* c) A covered work must retain «NexT» official website link\n     (https://theme-next.org) in footer section of every website created,\n     modified or manipulated by using «NexT».\n     «NexT» theme configuration must be:\n     ```yml\n     footer:\n       theme:\n         enable: true\n     ```\n     Collaborators, best contributors and all authors specified in the\n     '[docs/AUTHORS.md][AUTHORS]' file of «NexT» repository under the\n     'https://github.com/theme-next' organization can ignore theme info link\n     requirements.\n\nAnyone can be released from the requirements of the license by purchasing\na commercial license. Buying such a license is mandatory as soon as you\ndevelop commercial activities involving the «NexT» software without\ndisclosing the source code of your own applications.\nThese activities include:\n  1. Access to private repository with various premium features.\n  2. Priority support for resolve all possible issues with «NexT».\n  3. Priority support for implement all possible features to «NexT».\n\n  For more information, please contact «NexT» Organization at this\naddress: support@theme-next.org\n\n<p align=\"center\">This license also available in <a href=\"docs/LICENSE.txt\">text format</a>.</p>\n\n[AUTHORS]: docs/AUTHORS.md\n[AGPL3]: docs/AGPL3.md\n[AGPL3-7]: docs/AGPL3.md/#7-additional-terms\n[AGPL3-15]: docs/AGPL3.md/#15-disclaimer-of-warranty\n"
  },
  {
    "path": "README.md",
    "content": "<div align=\"right\">\n  Language:\n  🇺🇸\n  <a title=\"Chinese\" href=\"docs/zh-CN/README.md\">🇨🇳</a>\n  <a title=\"Russian\" href=\"docs/ru/README.md\">🇷🇺</a>\n</div>\n\n# <div align=\"center\"><a title=\"NexT website repository\" href=\"https://github.com/theme-next/theme-next.org\"><img align=\"center\" width=\"56\" height=\"56\" src=\"https://raw.githubusercontent.com/theme-next/hexo-theme-next/master/source/images/logo.svg?sanitize=true\"></a> e x T</div>\n\n<p align=\"center\">\n  «NexT» is a high quality elegant <a href=\"https://hexo.io\">Hexo</a> theme. It is crafted from scratch with love.\n<br>\n<br>\n  <a href=\"https://www.npmjs.com/package/hexo-theme-next\"><img src=\"https://img.shields.io/github/package-json/v/theme-next/hexo-theme-next?style=flat-square\"></a>\n  <a href=\"https://nodejs.org\"><img src=\"https://img.shields.io/badge/node-%3E=10.9.0-green?style=flat-square\"></a>\n  <a href=\"https://hexo.io\"><img src=\"https://img.shields.io/badge/hexo-%3E=4.0.0-blue?style=flat-square&logo=hexo\"></a>\n  <a href=\"https://github.com/theme-next/hexo-theme-next/blob/master/LICENSE.md\"><img src=\"https://img.shields.io/badge/license-%20AGPL-orange?style=flat-square&logo=gnu\"></a>\n<br>\n  <a href=\"https://bestpractices.coreinfrastructure.org/projects/2625\"><img src=\"https://img.shields.io/cii/level/2625?style=flat-square\" title=\"Core Infrastructure Initiative Best Practices\"></a>\n  <a href=\"https://travis-ci.org/theme-next/hexo-theme-next?branch=master\"><img src=\"https://img.shields.io/travis/theme-next/hexo-theme-next/master?style=flat-square&logo=travis%20ci\" title=\"Travis CI [Linux]\"></a>\n  <a href=\"https://app.codacy.com/manual/theme-next/hexo-theme-next/dashboard\"><img src=\"https://img.shields.io/codacy/grade/72f7fe7609c2438a92069f448e5a341a/master?style=flat-square&logo=codacy\" title=\"Project Grade\"></a>\n  <img src=\"https://img.shields.io/snyk/vulnerabilities/github/theme-next/hexo-theme-next?style=flat-square\" title=\"Vulnerabilities\">\n<br>\n  <img src=\"https://user-images.githubusercontent.com/16272760/63487983-da41b080-c4df-11e9-951c-64883a8a5e9b.png\">\n</p>\n\n## Live Preview\n\n<p align=\"center\">\n  💟 <a href=\"https://muse.theme-next.org\">Muse</a> | 🔯 <a href=\"https://mist.theme-next.org\">Mist</a> | ♓️ <a href=\"https://pisces.theme-next.org\">Pisces</a> | ♊️ <a href=\"https://theme-next.org\">Gemini</a>\n<br>\n<br>\n  More «NexT» examples <a href=\"https://github.com/theme-next/awesome-next#live-preview\">here</a>.\n</p>\n\n## Installation\n\nThe simplest way to install is to clone the entire repository:\n\n```sh\n$ cd hexo\n$ git clone https://github.com/theme-next/hexo-theme-next themes/next\n```\n\nOr you can see [detailed installation instructions][docs-installation-url] if you want any other variant.\n\n## Plugins\n\nNexT supports a large number of third-party plugins, which can be easily configured.\n\nFor example, if you want to enable `pjax` on your site, just set `pjax` to `true` in NexT config file:\n\n```yml\n# Easily enable fast Ajax navigation on your website.\n# Dependencies: https://github.com/theme-next/theme-next-pjax\npjax: true\n```\n\nThen visit the «Dependencies» link to get the installation instructions of this module.\n\n### Configure CDN\n\nIf you want to specify a CDN link for any plugins, you need to set / update the CDN link.\n\nFor example, if you want to use `mediumzoom` and load the plugin via CDN, go to NexT config and see:\n\n```yml\nvendors:\n  # ...\n  # Some contents...\n  # ...\n  mediumzoom: # Set or update mediumzoom CDN URL.\n```\n\n## Update\n\nNexT releases new versions every month. You can update to latest master branch by the following command:\n\n```sh\n$ cd themes/next\n$ git pull\n```\n\nAnd if you see any error message during update (something like **«Commit your changes or stash them before you can merge»**), recommended to learn [Hexo data files][docs-data-files-url] feature.\\\nHowever, you can bypass update errors by using the `Commit`, `Stash` or `Reset` commands for local changes. See [here](https://stackoverflow.com/a/15745424/5861495) how to do it.\n\n**If you want to update from v5.1.x to the latest version, read [this][docs-update-5-1-x-url].**\n\n## Feedback\n\n* Visit the [Awesome NexT][awesome-next-url] list to share plugins and tutorials with other users.\n* Join our [Telegram][t-chat-url] / [Gitter][gitter-url] / [Riot][riot-url] chats.\n* [Add or improve translation][i18n-url] in few seconds.\n* Report a bug in [GitHub Issues][issues-bug-url].\n* Request a new feature on [GitHub][issues-feat-url].\n* Vote for [popular feature requests][feat-req-vote-url].\n\n## Contributing\n\nWe welcome you to join the development of NexT. Please see [contributing document][contributing-document-url]. 🤗\n\nAlso, we welcome Issue or PR to our [official-plugins][official-plugins-url].\n\n## Contributors\n\n[![][contributors-image]][contributors-url]\n\n## Thanks\n\n<p align=\"center\">\n  «NexT» send special thanks to these great services that sponsor our core infrastructure:\n<br>\n<br>\n  <a href=\"https://github.com\"><img align=\"center\" width=\"100\" src=\"https://github.githubassets.com/images/modules/logos_page/GitHub-Logo.png\"></a>\n  &nbsp;&nbsp;&nbsp;\n  <a href=\"https://www.netlify.com\"><img align=\"center\" width=\"150\" src=\"https://cdn.netlify.com/15ecf59b59c9d04b88097c6b5d2c7e8a7d1302d0/1b6d6/img/press/logos/full-logo-light.svg\"></a>\n<br>\n<br>\n  <sub>GitHub allows us to host the Git repository, Netlify allows us to distribute the documentation.</sub>\n<br>\n<br>\n  <a href=\"https://crowdin.com\"><img align=\"center\" width=\"180\" src=\"https://support.crowdin.com/assets/logos/crowdin-logo1-small.png\"></a>\n<br>\n<br>\n  <sub>Crowdin allows us to translate conveniently the documentation.</sub>\n<br>\n<br>\n  <a href=\"https://codacy.com\"><img align=\"center\" width=\"155\" src=\"https://user-images.githubusercontent.com/16944225/55026017-623f8f00-5002-11e9-88bf-0d6a5884c6c2.png\"></a>\n  &nbsp;&nbsp;&nbsp;\n  <a href=\"https://travis-ci.com\"><img align=\"center\" width=\"140\" src=\"https://raw.githubusercontent.com/travis-ci/travis-web/master/public/images/logos/TravisCI-Full-Color.png\"></a>\n<br>\n<br>\n  <sub>Codacy allows us to monitor code quality, Travis CI allows us to run the test suite.</sub>\n</p>\n\n[docs-installation-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/INSTALLATION.md\n[docs-data-files-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/DATA-FILES.md\n[docs-update-5-1-x-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/UPDATE-FROM-5.1.X.md\n\n[t-news-url]: https://t.me/theme_next_news\n[t-chat-url]: https://t.me/theme_next\n[gitter-url]: https://gitter.im/theme-next\n[riot-url]: https://riot.im/app/#/room/#theme-next:matrix.org\n[i18n-url]: https://i18n.theme-next.org\n\n[awesome-next-url]: https://github.com/theme-next/awesome-next\n[issues-bug-url]: https://github.com/theme-next/hexo-theme-next/issues/new?assignees=&labels=Bug&template=bug-report.md\n[issues-feat-url]: https://github.com/theme-next/hexo-theme-next/issues/new?assignees=&labels=Feature+Request&template=feature-request.md\n[feat-req-vote-url]: https://github.com/theme-next/hexo-theme-next/issues?q=is%3Aopen+is%3Aissue+label%3A%22Feature+Request%22\n\n[contributing-document-url]: https://github.com/theme-next/hexo-theme-next/blob/master/.github/CONTRIBUTING.md\n[official-plugins-url]: https://github.com/theme-next\n[contributors-image]: https://opencollective.com/theme-next/contributors.svg?width=890\n[contributors-url]: https://github.com/theme-next/hexo-theme-next/graphs/contributors\n"
  },
  {
    "path": "_config.yml",
    "content": "# ---------------------------------------------------------------\n# Theme Core Configuration Settings\n# See: https://theme-next.org/docs/theme-settings/\n# ---------------------------------------------------------------\n\n# If false, merge configs from `_data/next.yml` into default configuration (rewrite).\n# If true, will fully override default configuration by options from `_data/next.yml` (override). Only for NexT settings.\n# And if true, all config from default NexT `_config.yml` have to be copied into `next.yml`. Use if you know what you are doing.\n# Useful if you want to comment some options from NexT `_config.yml` by `next.yml` without editing default config.\noverride: false\n\n# Console reminder if new version released.\nreminder: false\n\n# Allow to cache content generation. Introduced in NexT v6.0.0.\ncache:\n  enable: true\n\n# Remove unnecessary files after hexo generate.\nminify: false\n\n# Define custom file paths.\n# Create your custom files in site directory `source/_data` and uncomment needed files below.\ncustom_file_path:\n  #head: source/_data/head.swig\n  #header: source/_data/header.swig\n  #sidebar: source/_data/sidebar.swig\n  #postMeta: source/_data/post-meta.swig\n  #postBodyEnd: source/_data/post-body-end.swig\n  #footer: source/_data/footer.swig\n  #bodyEnd: source/_data/body-end.swig\n  #variable: source/_data/variables.styl\n  #mixin: source/_data/mixins.styl\n  #style: source/_data/styles.styl\n\n\n# ---------------------------------------------------------------\n# Site Information Settings\n# See: https://theme-next.org/docs/getting-started/\n# ---------------------------------------------------------------\n\nfavicon:\n  small: /images/favicon-16x16-next.png\n  medium: /images/favicon-32x32-next.png\n  apple_touch_icon: /images/apple-touch-icon-next.png\n  safari_pinned_tab: /images/logo.svg\n  #android_manifest: /images/manifest.json\n  #ms_browserconfig: /images/browserconfig.xml\n\n# Show multilingual switcher in footer.\nlanguage_switcher: false\n\nfooter:\n  # Specify the date when the site was setup. If not defined, current year will be used.\n  #since: 2015\n\n  # Icon between year and copyright info.\n  icon:\n    # Icon name in Font Awesome. See: https://fontawesome.com/icons\n    name: fa fa-heart\n    # If you want to animate the icon, set it to true.\n    animated: false\n    # Change the color of icon, using Hex Code.\n    color: \"#ff0000\"\n\n  # If not defined, `author` from Hexo `_config.yml` will be used.\n  copyright:\n\n  # Powered by Hexo & NexT\n  powered: true\n\n  # Beian ICP and gongan information for Chinese users. See: https://beian.miit.gov.cn, http://www.beian.gov.cn\n  beian:\n    enable: false\n    icp:\n    # The digit in the num of gongan beian.\n    gongan_id:\n    # The full num of gongan beian.\n    gongan_num:\n    # The icon for gongan beian. See: http://www.beian.gov.cn/portal/download\n    gongan_icon_url:\n\n# Creative Commons 4.0 International License.\n# See: https://creativecommons.org/share-your-work/licensing-types-examples\n# Available values of license: by | by-nc | by-nc-nd | by-nc-sa | by-nd | by-sa | zero\n# You can set a language value if you prefer a translated version of CC license, e.g. deed.zh\n# CC licenses are available in 39 languages, you can find the specific and correct abbreviation you need on https://creativecommons.org\ncreative_commons:\n  license: by-nc-sa\n  sidebar: false\n  post: false\n  language:\n\n\n# ---------------------------------------------------------------\n# Scheme Settings\n# ---------------------------------------------------------------\n\n# Schemes\nscheme: Muse\n#scheme: Mist\n#scheme: Pisces\n#scheme: Gemini\n\n# Dark Mode\ndarkmode: false\n\n\n# ---------------------------------------------------------------\n# Menu Settings\n# ---------------------------------------------------------------\n\n# Usage: `Key: /link/ || icon`\n# Key is the name of menu item. If the translation for this item is available, the translated text will be loaded, otherwise the Key name will be used. Key is case-senstive.\n# Value before `||` delimiter is the target link, value after `||` delimiter is the name of Font Awesome icon.\n# When running the site in a subdirectory (e.g. yoursite.com/blog), remove the leading slash from link value (/archives -> archives).\n# External url should start with http:// or https://\nmenu:\n  home: / || fa fa-home\n  #about: /about/ || fa fa-user\n  #tags: /tags/ || fa fa-tags\n  #categories: /categories/ || fa fa-th\n  archives: /archives/ || fa fa-archive\n  #schedule: /schedule/ || fa fa-calendar\n  #sitemap: /sitemap.xml || fa fa-sitemap\n  #commonweal: /404/ || fa fa-heartbeat\n\n# Enable / Disable menu icons / item badges.\nmenu_settings:\n  icons: true\n  badges: false\n\n\n# ---------------------------------------------------------------\n# Sidebar Settings\n# See: https://theme-next.org/docs/theme-settings/sidebar\n# ---------------------------------------------------------------\n\nsidebar:\n  # Sidebar Position.\n  position: left\n  #position: right\n\n  # Manual define the sidebar width. If commented, will be default for:\n  # Muse | Mist: 320\n  # Pisces | Gemini: 240\n  #width: 300\n\n  # Sidebar Display (only for Muse | Mist), available values:\n  #  - post    expand on posts automatically. Default.\n  #  - always  expand for all pages automatically.\n  #  - hide    expand only when click on the sidebar toggle icon.\n  #  - remove  totally remove sidebar including sidebar toggle.\n  display: post\n\n  # Sidebar padding in pixels.\n  padding: 18\n  # Sidebar offset from top menubar in pixels (only for Pisces | Gemini).\n  offset: 12\n  # Enable sidebar on narrow view (only for Muse | Mist).\n  onmobile: false\n\n# Sidebar Avatar\navatar:\n  # Replace the default image and set the url here.\n  url: #/images/avatar.gif\n  # If true, the avatar will be dispalyed in circle.\n  rounded: false\n  # If true, the avatar will be rotated with the cursor.\n  rotated: false\n\n# Posts / Categories / Tags in sidebar.\nsite_state: true\n\n# Social Links\n# Usage: `Key: permalink || icon`\n# Key is the link label showing to end users.\n# Value before `||` delimiter is the target permalink, value after `||` delimiter is the name of Font Awesome icon.\nsocial:\n  #GitHub: https://github.com/yourname || fab fa-github\n  #E-Mail: mailto:yourname@gmail.com || fa fa-envelope\n  #Weibo: https://weibo.com/yourname || fab fa-weibo\n  #Google: https://plus.google.com/yourname || fab fa-google\n  #Twitter: https://twitter.com/yourname || fab fa-twitter\n  #FB Page: https://www.facebook.com/yourname || fab fa-facebook\n  #StackOverflow: https://stackoverflow.com/yourname || fab fa-stack-overflow\n  #YouTube: https://youtube.com/yourname || fab fa-youtube\n  #Instagram: https://instagram.com/yourname || fab fa-instagram\n  #Skype: skype:yourname?call|chat || fab fa-skype\n\nsocial_icons:\n  enable: true\n  icons_only: false\n  transition: false\n\n# Blog rolls\nlinks_settings:\n  icon: fa fa-link\n  title: Links\n  # Available values: block | inline\n  layout: block\n\nlinks:\n  #Title: http://yoursite.com\n\n# Table of Contents in the Sidebar\n# Front-matter variable (unsupport wrap expand_all).\ntoc:\n  enable: true\n  # Automatically add list number to toc.\n  number: true\n  # If true, all words will placed on next lines if header width longer then sidebar width.\n  wrap: false\n  # If true, all level of TOC in a post will be displayed, rather than the activated part of it.\n  expand_all: false\n  # Maximum heading depth of generated toc.\n  max_depth: 6\n\n# A button to open designated chat widget in sidebar.\n# Firstly, you need enable the chat service you want to activate its sidebar button.\nchat:\n  enable: false\n  #service: chatra\n  #service: tidio\n  icon: fa fa-comment # Icon name in Font Awesome, set false to disable icon.\n  text: Chat # Button text, change it as you wish.\n\n\n# ---------------------------------------------------------------\n# Post Settings\n# See: https://theme-next.org/docs/theme-settings/posts\n# ---------------------------------------------------------------\n\n# Automatically excerpt description in homepage as preamble text.\nexcerpt_description: true\n\n# Read more button\n# If true, the read more button will be displayed in excerpt section.\nread_more_btn: true\n\n# Post meta display settings\npost_meta:\n  item_text: true\n  created_at: true\n  updated_at:\n    enable: true\n    another_day: true\n  categories: true\n\n# Post wordcount display settings\n# Dependencies: https://github.com/theme-next/hexo-symbols-count-time\nsymbols_count_time:\n  separated_meta: true\n  item_text_post: true\n  item_text_total: false\n\n# Use icon instead of the symbol # to indicate the tag at the bottom of the post\ntag_icon: false\n\n# Reward (Donate)\n# Front-matter variable (unsupport animation).\nreward_settings:\n  # If true, reward will be displayed in every article by default.\n  enable: false\n  animation: false\n  #comment: Donate comment here.\n\nreward:\n  #wechatpay: /images/wechatpay.png\n  #alipay: /images/alipay.png\n  #paypal: /images/paypal.png\n  #bitcoin: /images/bitcoin.png\n\n# Subscribe through Telegram Channel, Twitter, etc.\n# Usage: `Key: permalink || icon` (Font Awesome)\nfollow_me:\n  #Twitter: https://twitter.com/username || fab fa-twitter\n  #Telegram: https://t.me/channel_name || fab fa-telegram\n  #WeChat: /images/wechat_channel.jpg || fab fa-weixin\n  #RSS: /atom.xml || fa fa-rss\n\n# Related popular posts\n# Dependencies: https://github.com/tea3/hexo-related-popular-posts\nrelated_posts:\n  enable: false\n  title: # Custom header, leave empty to use the default one\n  display_in_home: false\n  params:\n    maxCount: 5\n    #PPMixingRate: 0.0\n    #isDate: false\n    #isImage: false\n    #isExcerpt: false\n\n# Post edit\n# Dependencies: https://github.com/hexojs/hexo-deployer-git\npost_edit:\n  enable: false\n  url: https://github.com/user-name/repo-name/tree/branch-name/subdirectory-name # Link for view source\n  #url: https://github.com/user-name/repo-name/edit/branch-name/subdirectory-name # Link for fork & edit\n\n# Show previous post and next post in post footer if exists\n# Available values: left | right | false\npost_navigation: left\n\n\n# ---------------------------------------------------------------\n# Custom Page Settings\n# See: https://theme-next.org/docs/theme-settings/custom-pages\n# ---------------------------------------------------------------\n\n# TagCloud settings for tags page.\ntagcloud:\n  # All values below are same as default, change them by yourself.\n  min: 12 # Minimun font size in px\n  max: 30 # Maxium font size in px\n  start: \"#ccc\" # Start color (hex, rgba, hsla or color keywords)\n  end: \"#111\" # End color (hex, rgba, hsla or color keywords)\n  amount: 200 # Amount of tags, change it if you have more than 200 tags\n\n# Google Calendar\n# Share your recent schedule to others via calendar page.\ncalendar:\n  calendar_id: <required> # Your Google account E-Mail\n  api_key: <required>\n  orderBy: startTime\n  offsetMax: 24 # Time Range\n  offsetMin: 4 # Time Range\n  showDeleted: false\n  singleEvents: true\n  maxResults: 250\n\n\n# ---------------------------------------------------------------\n# Misc Theme Settings\n# ---------------------------------------------------------------\n\n# Set the text alignment in posts / pages.\ntext_align:\n  # Available values: start | end | left | right | center | justify | justify-all | match-parent\n  desktop: justify\n  mobile: justify\n\n# Reduce padding / margin indents on devices with narrow width.\nmobile_layout_economy: false\n\n# Android Chrome header panel color ($brand-bg / $headband-bg => $black-deep).\nandroid_chrome_color: \"#222\"\n\n# Custom Logo (Do not support scheme Mist)\ncustom_logo: #/uploads/custom-logo.jpg\n\ncodeblock:\n  # Code Highlight theme\n  # Available values: normal | night | night eighties | night blue | night bright | solarized | solarized dark | galactic\n  # See: https://github.com/chriskempson/tomorrow-theme\n  highlight_theme: normal\n  # Add copy button on codeblock\n  copy_button:\n    enable: false\n    # Show text copy result.\n    show_result: false\n    # Available values: default | flat | mac\n    style:\n\nback2top:\n  enable: true\n  # Back to top in sidebar.\n  sidebar: false\n  # Scroll percent label in b2t button.\n  scrollpercent: false\n\n# Reading progress bar\nreading_progress:\n  enable: false\n  # Available values: top | bottom\n  position: top\n  color: \"#37c6c0\"\n  height: 3px\n\n# Bookmark Support\nbookmark:\n  enable: false\n  # Customize the color of the bookmark.\n  color: \"#222\"\n  # If auto, save the reading progress when closing the page or clicking the bookmark-icon.\n  # If manual, only save it by clicking the bookmark-icon.\n  save: auto\n\n# `Follow me on GitHub` banner in the top-right corner.\ngithub_banner:\n  enable: false\n  permalink: https://github.com/yourname\n  title: Follow me on GitHub\n\n\n# ---------------------------------------------------------------\n# Font Settings\n# See: https://theme-next.org/docs/theme-settings/#Fonts-Customization\n# ---------------------------------------------------------------\n# Find fonts on Google Fonts (https://www.google.com/fonts)\n# All fonts set here will have the following styles:\n#   light | light italic | normal | normal italic | bold | bold italic\n# Be aware that setting too much fonts will cause site running slowly\n# ---------------------------------------------------------------\n# To avoid space between header and sidebar in scheme Pisces / Gemini, Web Safe fonts are recommended for `global` (and `title`):\n# Arial | Tahoma | Helvetica | Times New Roman | Courier New | Verdana | Georgia | Palatino | Garamond | Comic Sans MS | Trebuchet MS\n# ---------------------------------------------------------------\n\nfont:\n  enable: false\n\n  # Uri of fonts host, e.g. https://fonts.googleapis.com (Default).\n  host:\n\n  # Font options:\n  # `external: true` will load this font family from `host` above.\n  # `family: Times New Roman`. Without any quotes.\n  # `size: x.x`. Use `em` as unit. Default: 1 (16px)\n\n  # Global font settings used for all elements inside <body>.\n  global:\n    external: true\n    family: Lato\n    size:\n\n  # Font settings for site title (.site-title).\n  title:\n    external: true\n    family:\n    size:\n\n  # Font settings for headlines (<h1> to <h6>).\n  headings:\n    external: true\n    family:\n    size:\n\n  # Font settings for posts (.post-body).\n  posts:\n    external: true\n    family:\n\n  # Font settings for <code> and code blocks.\n  codes:\n    external: true\n    family:\n\n\n# ---------------------------------------------------------------\n# SEO Settings\n# ---------------------------------------------------------------\n\n# Disable Baidu transformation on mobile devices.\ndisable_baidu_transformation: false\n\n# If true, site-subtitle will be added to index page.\n# Remember to set up your site-subtitle in Hexo `_config.yml` (e.g. subtitle: Subtitle)\nindex_with_subtitle: false\n\n# Automatically add external URL with Base64 encrypt & decrypt.\nexturl: false\n\n# Google Webmaster tools verification.\n# See: https://www.google.com/webmasters\ngoogle_site_verification:\n\n# Bing Webmaster tools verification.\n# See: https://www.bing.com/webmaster\nbing_site_verification:\n\n# Yandex Webmaster tools verification.\n# See: https://webmaster.yandex.ru\nyandex_site_verification:\n\n# Baidu Webmaster tools verification.\n# See: https://ziyuan.baidu.com/site\nbaidu_site_verification:\n\n# Enable baidu push so that the blog will push the url to baidu automatically which is very helpful for SEO.\nbaidu_push: false\n\n\n# ---------------------------------------------------------------\n# Third Party Plugins & Services Settings\n# See: https://theme-next.org/docs/third-party-services/\n# More plugins: https://github.com/theme-next/awesome-next\n# You may need to install dependencies or set CDN URLs in `vendors`\n# There are two different CDN providers by default:\n#   - jsDelivr (cdn.jsdelivr.net), works everywhere even in China\n#   - CDNJS (cdnjs.cloudflare.com), provided by cloudflare\n# ---------------------------------------------------------------\n\n# Math Formulas Render Support\nmath:\n  # Default (true) will load mathjax / katex script on demand.\n  # That is it only render those page which has `mathjax: true` in Front-matter.\n  # If you set it to false, it will load mathjax / katex srcipt EVERY PAGE.\n  per_page: true\n\n  # hexo-renderer-pandoc (or hexo-renderer-kramed) required for full MathJax support.\n  mathjax:\n    enable: false\n    # See: https://mhchem.github.io/MathJax-mhchem/\n    mhchem: false\n\n  # hexo-renderer-markdown-it-plus (or hexo-renderer-markdown-it with markdown-it-katex plugin) required for full Katex support.\n  katex:\n    enable: false\n    # See: https://github.com/KaTeX/KaTeX/tree/master/contrib/copy-tex\n    copy_tex: false\n\n# Easily enable fast Ajax navigation on your website.\n# Dependencies: https://github.com/theme-next/theme-next-pjax\npjax: false\n\n# FancyBox is a tool that offers a nice and elegant way to add zooming functionality for images.\n# For more information: https://fancyapps.com/fancybox\nfancybox: false\n\n# A JavaScript library for zooming images like Medium.\n# Do not enable both `fancybox` and `mediumzoom`.\n# For more information: https://github.com/francoischalifour/medium-zoom\nmediumzoom: false\n\n# Vanilla JavaScript plugin for lazyloading images.\n# For more information: https://github.com/ApoorvSaxena/lozad.js\nlazyload: false\n\n# Pangu Support\n# For more information: https://github.com/vinta/pangu.js\npangu: false\n\n# Quicklink Support\n# Do not enable both `pjax` and `quicklink`.\n# For more information: https://github.com/GoogleChromeLabs/quicklink\n# Front-matter (unsupport home archive).\nquicklink:\n  enable: false\n\n  # Home page and archive page can be controlled through home and archive options below.\n  # This configuration item is independent of `enable`.\n  home: false\n  archive: false\n\n  # Default (true) will initialize quicklink after the load event fires.\n  delay: true\n  # Custom a time in milliseconds by which the browser must execute prefetching.\n  timeout: 3000\n  # Default (true) will enable fetch() or falls back to XHR.\n  priority: true\n\n  # For more flexibility you can add some patterns (RegExp, Function, or Array) to ignores.\n  # See: https://github.com/GoogleChromeLabs/quicklink#custom-ignore-patterns\n  ignores:\n\n\n# ---------------------------------------------------------------\n# Comments Settings\n# See: https://theme-next.org/docs/third-party-services/comments\n# ---------------------------------------------------------------\n\n# Multiple Comment System Support\ncomments:\n  # Available values: tabs | buttons\n  style: tabs\n  # Choose a comment system to be displayed by default.\n  # Available values: changyan | disqus | disqusjs | gitalk | livere | valine\n  active:\n  # Setting `true` means remembering the comment system selected by the visitor.\n  storage: true\n  # Lazyload all comment systems.\n  lazyload: false\n  # Modify texts or order for any navs, here are some examples.\n  nav:\n    #disqus:\n    #  text: Load Disqus\n    #  order: -1\n    #gitalk:\n    #  order: -2\n\n# Disqus\ndisqus:\n  enable: false\n  shortname:\n  count: true\n  #post_meta_order: 0\n\n# DisqusJS\n# Alternative Disqus - Render comment component using Disqus API.\n# Demo: https://suka.js.org/DisqusJS/\n# For more information: https://github.com/SukkaW/DisqusJS\ndisqusjs:\n  enable: false\n  # API Endpoint of Disqus API (https://disqus.com/api/).\n  # Leave api empty if you are able to connect to Disqus API. Otherwise you need a reverse proxy for it.\n  # For example:\n  # api: https://disqus.skk.moe/disqus/\n  api:\n  apikey: # Register new application from https://disqus.com/api/applications/\n  shortname: # See: https://disqus.com/admin/settings/general/\n\n# Changyan\nchangyan:\n  enable: false\n  appid:\n  appkey:\n  #post_meta_order: 0\n\n# Valine\n# For more information: https://valine.js.org, https://github.com/xCss/Valine\nvaline:\n  enable: false\n  appid: # Your leancloud application appid\n  appkey: # Your leancloud application appkey\n  notify: false # Mail notifier\n  verify: false # Verification code\n  placeholder: Just go go # Comment box placeholder\n  avatar: mm # Gravatar style\n  guest_info: nick,mail,link # Custom comment header\n  pageSize: 10 # Pagination size\n  language: # Language, available values: en, zh-cn\n  visitor: false # Article reading statistic\n  comment_count: true # If false, comment count will only be displayed in post page, not in home page\n  recordIP: false # Whether to record the commenter IP\n  serverURLs: # When the custom domain name is enabled, fill it in here (it will be detected automatically by default, no need to fill in)\n  #post_meta_order: 0\n\n# LiveRe comments system\n# You can get your uid from https://livere.com/insight/myCode (General web site)\nlivere_uid: # <your_uid>\n\n# Gitalk\n# For more information: https://gitalk.github.io, https://github.com/gitalk/gitalk\ngitalk:\n  enable: false\n  github_id: # GitHub repo owner\n  repo: # Repository name to store issues\n  client_id: # GitHub Application Client ID\n  client_secret: # GitHub Application Client Secret\n  admin_user: # GitHub repo owner and collaborators, only these guys can initialize gitHub issues\n  distraction_free_mode: true # Facebook-like distraction free mode\n  # Gitalk's display language depends on user's browser or system environment\n  # If you want everyone visiting your site to see a uniform language, you can set a force language value\n  # Available values: en | es-ES | fr | ru | zh-CN | zh-TW\n  language:\n\n\n# ---------------------------------------------------------------\n# Post Widgets & Content Sharing Services\n# See: https://theme-next.org/docs/third-party-services/post-widgets\n# ---------------------------------------------------------------\n\n# Star rating support to each article.\n# To get your ID visit https://widgetpack.com\nrating:\n  enable: false\n  id:     # <app_id>\n  color:  fc6423\n\n# AddThis Share. See: https://www.addthis.com\n# Go to https://www.addthis.com/dashboard to customize your tools.\nadd_this_id:\n\n\n# ---------------------------------------------------------------\n# Statistics and Analytics\n# See: https://theme-next.org/docs/third-party-services/statistics-and-analytics\n# ---------------------------------------------------------------\n\n# Google Analytics\ngoogle_analytics:\n  tracking_id: # <app_id>\n  # By default, NexT will load an external gtag.js script on your site.\n  # If you only need the pageview feature, set the following option to true to get a better performance.\n  only_pageview: false\n\n# Baidu Analytics\nbaidu_analytics: # <app_id>\n\n# Growingio Analytics\ngrowingio_analytics: # <project_id>\n\n# CNZZ count\ncnzz_siteid:\n\n# Show number of visitors of each article.\n# You can visit https://leancloud.cn to get AppID and AppKey.\n# AppID and AppKey are recommended to be the same as valine's for counter compatibility.\n# Do not enable both `valine.visitor` and `leancloud_visitors`.\nleancloud_visitors:\n  enable: false\n  app_id: # <your app id>\n  app_key: # <your app key>\n  # Required for apps from CN region\n  server_url: # <your server url>\n  # Dependencies: https://github.com/theme-next/hexo-leancloud-counter-security\n  # If you don't care about security in leancloud counter and just want to use it directly\n  # (without hexo-leancloud-counter-security plugin), set `security` to `false`.\n  security: true\n\n# Another tool to show number of visitors to each article.\n# Visit https://console.firebase.google.com/u/0/ to get apiKey and projectId.\n# Visit https://firebase.google.com/docs/firestore/ to get more information about firestore.\nfirestore:\n  enable: false\n  collection: articles # Required, a string collection name to access firestore database\n  apiKey: # Required\n  projectId: # Required\n\n# Show Views / Visitors of the website / page with busuanzi.\n# Get more information on http://ibruce.info/2015/04/04/busuanzi\nbusuanzi_count:\n  enable: false\n  total_visitors: true\n  total_visitors_icon: fa fa-user\n  total_views: true\n  total_views_icon: fa fa-eye\n  post_views: true\n  post_views_icon: fa fa-eye\n\n\n# ---------------------------------------------------------------\n# Search Services\n# See: https://theme-next.org/docs/third-party-services/search-services\n# ---------------------------------------------------------------\n\n# Algolia Search\n# For more information: https://www.algolia.com\nalgolia_search:\n  enable: false\n  hits:\n    per_page: 10\n  labels:\n    input_placeholder: Search for Posts\n    hits_empty: \"We didn't find any results for the search: ${query}\"\n    hits_stats: \"${hits} results found in ${time} ms\"\n\n# Local Search\n# Dependencies: https://github.com/theme-next/hexo-generator-searchdb\nlocal_search:\n  enable: false\n  # If auto, trigger search by changing input.\n  # If manual, trigger search by pressing enter key or search button.\n  trigger: auto\n  # Show top n results per article, show all results by setting to -1\n  top_n_per_article: 1\n  # Unescape html strings to the readable one.\n  unescape: false\n  # Preload the search data when the page loads.\n  preload: false\n\n# Swiftype Search API Key\nswiftype_key:\n\n\n# ---------------------------------------------------------------\n# Chat Services\n# See: https://theme-next.org/docs/third-party-services/chat-services\n# ---------------------------------------------------------------\n\n# Chatra Support\n# See: https://chatra.io\n# Dashboard: https://app.chatra.io/settings/general\nchatra:\n  enable: false\n  async: true\n  id: # Visit Dashboard to get your ChatraID\n  #embed: # Unfinished experimental feature for developers. See: https://chatra.io/help/api/#injectto\n\n# Tidio Support\n# See: https://www.tidiochat.com\n# Dashboard: https://www.tidiochat.com/panel/dashboard\ntidio:\n  enable: false\n  key: # Public Key, get it from dashboard. See: https://www.tidiochat.com/panel/settings/developer\n\n\n# ---------------------------------------------------------------\n# Tags Settings\n# See: https://theme-next.org/docs/tag-plugins/\n# ---------------------------------------------------------------\n\n# Note tag (bs-callout)\nnote:\n  # Note tag style values:\n  #  - simple    bs-callout old alert style. Default.\n  #  - modern    bs-callout new (v2-v3) alert style.\n  #  - flat      flat callout style with background, like on Mozilla or StackOverflow.\n  #  - disabled  disable all CSS styles import of note tag.\n  style: simple\n  icons: false\n  # Offset lighter of background in % for modern and flat styles (modern: -12 | 12; flat: -18 | 6).\n  # Offset also applied to label tag variables. This option can work with disabled note tag.\n  light_bg_offset: 0\n\n# Tabs tag\ntabs:\n  transition:\n    tabs: false\n    labels: true\n\n# PDF tag\n# NexT will try to load pdf files natively, if failed, pdf.js will be used.\n# So, you have to install the dependency of pdf.js if you want to use pdf tag and make it available to all browsers.\n# See: https://github.com/theme-next/theme-next-pdf\npdf:\n  enable: false\n  # Default height\n  height: 500px\n\n# Mermaid tag\nmermaid:\n  enable: false\n  # Available themes: default | dark | forest | neutral\n  theme: forest\n\n\n# ---------------------------------------------------------------\n# Animation Settings\n# ---------------------------------------------------------------\n\n# Use velocity to animate everything.\n# For more information: http://velocityjs.org\nmotion:\n  enable: true\n  async: false\n  transition:\n    # Transition variants:\n    # fadeIn | flipXIn | flipYIn | flipBounceXIn | flipBounceYIn\n    # swoopIn | whirlIn | shrinkIn | expandIn\n    # bounceIn | bounceUpIn | bounceDownIn | bounceLeftIn | bounceRightIn\n    # slideUpIn | slideDownIn | slideLeftIn | slideRightIn\n    # slideUpBigIn | slideDownBigIn | slideLeftBigIn | slideRightBigIn\n    # perspectiveUpIn | perspectiveDownIn | perspectiveLeftIn | perspectiveRightIn\n    post_block: fadeIn\n    post_header: slideDownIn\n    post_body: slideDownIn\n    coll_header: slideLeftIn\n    # Only for Pisces | Gemini.\n    sidebar: slideUpIn\n\n# Progress bar in the top during page loading.\n# Dependencies: https://github.com/theme-next/theme-next-pace\n# For more information: https://github.com/HubSpot/pace\npace:\n  enable: false\n  # Themes list:\n  # big-counter | bounce | barber-shop | center-atom | center-circle | center-radar | center-simple\n  # corner-indicator | fill-left | flat-top | flash | loading-bar | mac-osx | material | minimal\n  theme: minimal\n\n# JavaScript 3D library.\n# Dependencies: https://github.com/theme-next/theme-next-three\nthree:\n  enable: false\n  three_waves: false\n  canvas_lines: false\n  canvas_sphere: false\n\n# Canvas-ribbon\n# Dependencies: https://github.com/theme-next/theme-next-canvas-ribbon\n# For more information: https://github.com/zproo/canvas-ribbon\ncanvas_ribbon:\n  enable: false\n  size: 300 # The width of the ribbon\n  alpha: 0.6 # The transparency of the ribbon\n  zIndex: -1 # The display level of the ribbon\n\n\n#! ---------------------------------------------------------------\n#! DO NOT EDIT THE FOLLOWING SETTINGS\n#! UNLESS YOU KNOW WHAT YOU ARE DOING\n#! See: https://theme-next.org/docs/advanced-settings\n#! ---------------------------------------------------------------\n\n# Script Vendors. Set a CDN address for the vendor you want to customize.\n# Be aware that you would better use the same version as internal ones to avoid potential problems.\n# Remember to use the https protocol of CDN files when you enable https on your site.\nvendors:\n  # Internal path prefix.\n  _internal: lib\n\n  # Internal version: 3.1.0\n  # anime: //cdn.jsdelivr.net/npm/animejs@3.1.0/lib/anime.min.js\n  anime:\n\n  # Internal version: 5.13.0\n  # fontawesome: //cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free@5/css/all.min.css\n  # fontawesome: //cdnjs.cloudflare.com/ajax/libs/font-awesome/5.13.0/css/all.min.css\n  fontawesome:\n\n  # MathJax\n  # mathjax: //cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js\n  mathjax:\n\n  # KaTeX\n  # katex: //cdn.jsdelivr.net/npm/katex@0/dist/katex.min.css\n  # katex: //cdnjs.cloudflare.com/ajax/libs/KaTeX/0.11.1/katex.min.css\n  # copy_tex_js: //cdn.jsdelivr.net/npm/katex@0/dist/contrib/copy-tex.min.js\n  # copy_tex_css: //cdn.jsdelivr.net/npm/katex@0/dist/contrib/copy-tex.min.css\n  katex:\n  copy_tex_js:\n  copy_tex_css:\n\n  # Internal version: 0.2.8\n  # pjax: //cdn.jsdelivr.net/gh/theme-next/theme-next-pjax@0/pjax.min.js\n  pjax:\n\n  # FancyBox\n  # jquery: //cdn.jsdelivr.net/npm/jquery@3/dist/jquery.min.js\n  # fancybox: //cdn.jsdelivr.net/gh/fancyapps/fancybox@3/dist/jquery.fancybox.min.js\n  # fancybox_css: //cdn.jsdelivr.net/gh/fancyapps/fancybox@3/dist/jquery.fancybox.min.css\n  jquery:\n  fancybox:\n  fancybox_css:\n\n  # Medium-zoom\n  # mediumzoom: //cdn.jsdelivr.net/npm/medium-zoom@1/dist/medium-zoom.min.js\n  mediumzoom:\n\n  # Lazyload\n  # lazyload: //cdn.jsdelivr.net/npm/lozad@1/dist/lozad.min.js\n  # lazyload: //cdnjs.cloudflare.com/ajax/libs/lozad.js/1.14.0/lozad.min.js\n  lazyload:\n\n  # Pangu\n  # pangu: //cdn.jsdelivr.net/npm/pangu@4/dist/browser/pangu.min.js\n  # pangu: //cdnjs.cloudflare.com/ajax/libs/pangu/4.0.7/pangu.min.js\n  pangu:\n\n  # Quicklink\n  # quicklink: //cdn.jsdelivr.net/npm/quicklink@1/dist/quicklink.umd.js\n  quicklink:\n\n  # DisqusJS\n  # disqusjs_js: //cdn.jsdelivr.net/npm/disqusjs@1/dist/disqus.js\n  # disqusjs_css: //cdn.jsdelivr.net/npm/disqusjs@1/dist/disqusjs.css\n  disqusjs_js:\n  disqusjs_css:\n\n  # Valine\n  # valine: //cdn.jsdelivr.net/npm/valine@1/dist/Valine.min.js\n  # valine: //cdnjs.cloudflare.com/ajax/libs/valine/1.3.10/Valine.min.js\n  valine:\n\n  # Gitalk\n  # gitalk_js: //cdn.jsdelivr.net/npm/gitalk@1/dist/gitalk.min.js\n  # gitalk_css: //cdn.jsdelivr.net/npm/gitalk@1/dist/gitalk.min.css\n  gitalk_js:\n  gitalk_css:\n\n  # Algolia Search\n  # algolia_search: //cdn.jsdelivr.net/npm/algoliasearch@4/dist/algoliasearch-lite.umd.js\n  # instant_search: //cdn.jsdelivr.net/npm/instantsearch.js@4/dist/instantsearch.production.min.js\n  algolia_search:\n  instant_search:\n\n  # Mermaid\n  # mermaid: //cdn.jsdelivr.net/npm/mermaid@8/dist/mermaid.min.js\n  # mermaid: //cdnjs.cloudflare.com/ajax/libs/mermaid/8.4.8/mermaid.min.js\n  mermaid:\n\n  # Internal version: 1.2.1\n  # velocity: //cdn.jsdelivr.net/npm/velocity-animate@1/velocity.min.js\n  # velocity: //cdnjs.cloudflare.com/ajax/libs/velocity/1.2.1/velocity.min.js\n  # velocity_ui: //cdn.jsdelivr.net/npm/velocity-animate@1/velocity.ui.min.js\n  # velocity_ui: //cdnjs.cloudflare.com/ajax/libs/velocity/1.2.1/velocity.ui.min.js\n  velocity:\n  velocity_ui:\n\n  # Internal version: 1.0.2\n  # pace: //cdn.jsdelivr.net/npm/pace-js@1/pace.min.js\n  # pace: //cdnjs.cloudflare.com/ajax/libs/pace/1.0.2/pace.min.js\n  # pace_css: //cdn.jsdelivr.net/npm/pace-js@1/themes/blue/pace-theme-minimal.css\n  # pace_css: //cdnjs.cloudflare.com/ajax/libs/pace/1.0.2/themes/blue/pace-theme-minimal.min.css\n  pace:\n  pace_css:\n\n  # Internal version: 1.0.0\n  # three: //cdn.jsdelivr.net/gh/theme-next/theme-next-three@1/three.min.js\n  # three_waves: //cdn.jsdelivr.net/gh/theme-next/theme-next-three@1/three-waves.min.js\n  # canvas_lines: //cdn.jsdelivr.net/gh/theme-next/theme-next-three@1/canvas_lines.min.js\n  # canvas_sphere: //cdn.jsdelivr.net/gh/theme-next/theme-next-three@1/canvas_sphere.min.js\n  three:\n  three_waves:\n  canvas_lines:\n  canvas_sphere:\n\n  # Internal version: 1.0.0\n  # canvas_ribbon: //cdn.jsdelivr.net/gh/theme-next/theme-next-canvas-ribbon@1/canvas-ribbon.js\n  canvas_ribbon:\n\n# Assets\ncss: css\njs: js\nimages: images\n"
  },
  {
    "path": "crowdin.yml",
    "content": "files:\n  - source: /languages/en.yml\n    translation: /languages/%two_letters_code%.%file_extension%\n    languages_mapping:\n      two_letters_code:\n        zh-CN: zh-CN\n        zh-TW: zh-TW\n        zh-HK: zh-HK\n        pt-BR: pt-BR\n"
  },
  {
    "path": "docs/AGPL3.md",
    "content": "# <div align=\"center\">GNU Affero General Public License<div>\n\n<p align=\"center\">Version 3, 19 November 2007 Copyright © 2007 Free Software Foundation, Inc. &lt;http://fsf.org/&gt;</p>\n\n<p align=\"center\">Everyone is permitted to copy and distribute verbatim copies\nof this license document, but changing it is not allowed.</p>\n\n## <div align=\"center\">Preamble</div>\n\nThe GNU Affero General Public License is a free, copyleft license for\nsoftware and other kinds of works, specifically designed to ensure\ncooperation with the community in the case of network server software.\n\nThe licenses for most software and other practical works are designed\nto take away your freedom to share and change the works.  By contrast,\nour General Public Licenses are intended to guarantee your freedom to\nshare and change all versions of a program--to make sure it remains free\nsoftware for all its users.\n\nWhen we speak of free software, we are referring to freedom, not\nprice.  Our General Public Licenses are designed to make sure that you\nhave the freedom to distribute copies of free software (and charge for\nthem if you wish), that you receive source code or can get it if you\nwant it, that you can change the software or use pieces of it in new\nfree programs, and that you know you can do these things.\n\nDevelopers that use our General Public Licenses protect your rights\nwith two steps: **(1)** assert copyright on the software, and **(2)** offer\nyou this License which gives you legal permission to copy, distribute\nand/or modify the software.\n\nA secondary benefit of defending all users' freedom is that\nimprovements made in alternate versions of the program, if they\nreceive widespread use, become available for other developers to\nincorporate.  Many developers of free software are heartened and\nencouraged by the resulting cooperation.  However, in the case of\nsoftware used on network servers, this result may fail to come about.\nThe GNU General Public License permits making a modified version and\nletting the public access it on a server without ever releasing its\nsource code to the public.\n\nThe GNU Affero General Public License is designed specifically to\nensure that, in such cases, the modified source code becomes available\nto the community.  It requires the operator of a network server to\nprovide the source code of the modified version running there to the\nusers of that server.  Therefore, public use of a modified version, on\na publicly accessible server, gives the public access to the source\ncode of the modified version.\n\nAn older license, called the Affero General Public License and\npublished by Affero, was designed to accomplish similar goals.  This is\na different license, not a version of the Affero GPL, but Affero has\nreleased a new version of the Affero GPL which permits relicensing under\nthis license.\n\nThe precise terms and conditions for copying, distribution and\nmodification follow.\n\n## <div align=\"center\">TERMS AND CONDITIONS</div>\n\n### 0. Definitions\n\n“This License” refers to version 3 of the GNU Affero General Public License.\n\n“Copyright” also means copyright-like laws that apply to other kinds of\nworks, such as semiconductor masks.\n\n“The Program” refers to any copyrightable work licensed under this\nLicense.  Each licensee is addressed as “you”.  “Licensees” and\n“recipients” may be individuals or organizations.\n\nTo “modify” a work means to copy from or adapt all or part of the work\nin a fashion requiring copyright permission, other than the making of an\nexact copy.  The resulting work is called a “modified version” of the\nearlier work or a work “based on” the earlier work.\n\nA “covered work” means either the unmodified Program or a work based\non the Program.\n\nTo “propagate” a work means to do anything with it that, without\npermission, would make you directly or secondarily liable for\ninfringement under applicable copyright law, except executing it on a\ncomputer or modifying a private copy.  Propagation includes copying,\ndistribution (with or without modification), making available to the\npublic, and in some countries other activities as well.\n\nTo “convey” a work means any kind of propagation that enables other\nparties to make or receive copies.  Mere interaction with a user through\na computer network, with no transfer of a copy, is not conveying.\n\nAn interactive user interface displays “Appropriate Legal Notices”\nto the extent that it includes a convenient and prominently visible\nfeature that **(1)** displays an appropriate copyright notice, and **(2)**\ntells the user that there is no warranty for the work (except to the\nextent that warranties are provided), that licensees may convey the\nwork under this License, and how to view a copy of this License.  If\nthe interface presents a list of user commands or options, such as a\nmenu, a prominent item in the list meets this criterion.\n\n### 1. Source Code\n\nThe “source code” for a work means the preferred form of the work\nfor making modifications to it.  “Object code” means any non-source\nform of a work.\n\nA “Standard Interface” means an interface that either is an official\nstandard defined by a recognized standards body, or, in the case of\ninterfaces specified for a particular programming language, one that\nis widely used among developers working in that language.\n\nThe “System Libraries” of an executable work include anything, other\nthan the work as a whole, that **(a)** is included in the normal form of\npackaging a Major Component, but which is not part of that Major\nComponent, and **(b)** serves only to enable use of the work with that\nMajor Component, or to implement a Standard Interface for which an\nimplementation is available to the public in source code form.  A\n“Major Component”, in this context, means a major essential component\n(kernel, window system, and so on) of the specific operating system\n(if any) on which the executable work runs, or a compiler used to\nproduce the work, or an object code interpreter used to run it.\n\nThe “Corresponding Source” for a work in object code form means all\nthe source code needed to generate, install, and (for an executable\nwork) run the object code and to modify the work, including scripts to\ncontrol those activities.  However, it does not include the work's\nSystem Libraries, or general-purpose tools or generally available free\nprograms which are used unmodified in performing those activities but\nwhich are not part of the work.  For example, Corresponding Source\nincludes interface definition files associated with source files for\nthe work, and the source code for shared libraries and dynamically\nlinked subprograms that the work is specifically designed to require,\nsuch as by intimate data communication or control flow between those\nsubprograms and other parts of the work.\n\nThe Corresponding Source need not include anything that users\ncan regenerate automatically from other parts of the Corresponding\nSource.\n\nThe Corresponding Source for a work in source code form is that\nsame work.\n\n### 2. Basic Permissions\n\nAll rights granted under this License are granted for the term of\ncopyright on the Program, and are irrevocable provided the stated\nconditions are met.  This License explicitly affirms your unlimited\npermission to run the unmodified Program.  The output from running a\ncovered work is covered by this License only if the output, given its\ncontent, constitutes a covered work.  This License acknowledges your\nrights of fair use or other equivalent, as provided by copyright law.\n\nYou may make, run and propagate covered works that you do not\nconvey, without conditions so long as your license otherwise remains\nin force.  You may convey covered works to others for the sole purpose\nof having them make modifications exclusively for you, or provide you\nwith facilities for running those works, provided that you comply with\nthe terms of this License in conveying all material for which you do\nnot control copyright.  Those thus making or running the covered works\nfor you must do so exclusively on your behalf, under your direction\nand control, on terms that prohibit them from making any copies of\nyour copyrighted material outside their relationship with you.\n\nConveying under any other circumstances is permitted solely under\nthe conditions stated below.  Sublicensing is not allowed; section 10\nmakes it unnecessary.\n\n### 3. Protecting Users' Legal Rights From Anti-Circumvention Law\n\nNo covered work shall be deemed part of an effective technological\nmeasure under any applicable law fulfilling obligations under article\n11 of the WIPO copyright treaty adopted on 20 December 1996, or\nsimilar laws prohibiting or restricting circumvention of such\nmeasures.\n\nWhen you convey a covered work, you waive any legal power to forbid\ncircumvention of technological measures to the extent such circumvention\nis effected by exercising rights under this License with respect to\nthe covered work, and you disclaim any intention to limit operation or\nmodification of the work as a means of enforcing, against the work's\nusers, your or third parties' legal rights to forbid circumvention of\ntechnological measures.\n\n### 4. Conveying Verbatim Copies\n\nYou may convey verbatim copies of the Program's source code as you\nreceive it, in any medium, provided that you conspicuously and\nappropriately publish on each copy an appropriate copyright notice;\nkeep intact all notices stating that this License and any\nnon-permissive terms added in accord with section 7 apply to the code;\nkeep intact all notices of the absence of any warranty; and give all\nrecipients a copy of this License along with the Program.\n\nYou may charge any price or no price for each copy that you convey,\nand you may offer support or warranty protection for a fee.\n\n### 5. Conveying Modified Source Versions\n\nYou may convey a work based on the Program, or the modifications to\nproduce it from the Program, in the form of source code under the\nterms of section 4, provided that you also meet all of these conditions:\n\n* **a)** The work must carry prominent notices stating that you modified\nit, and giving a relevant date.\n* **b)** The work must carry prominent notices stating that it is\nreleased under this License and any conditions added under section 7.\nThis requirement modifies the requirement in section 4 to\n“keep intact all notices”.\n* **c)** You must license the entire work, as a whole, under this\nLicense to anyone who comes into possession of a copy.  This\nLicense will therefore apply, along with any applicable section 7\nadditional terms, to the whole of the work, and all its parts,\nregardless of how they are packaged.  This License gives no\npermission to license the work in any other way, but it does not\ninvalidate such permission if you have separately received it.\n* **d)** If the work has interactive user interfaces, each must display\nAppropriate Legal Notices; however, if the Program has interactive\ninterfaces that do not display Appropriate Legal Notices, your\nwork need not make them do so.\n\nA compilation of a covered work with other separate and independent\nworks, which are not by their nature extensions of the covered work,\nand which are not combined with it such as to form a larger program,\nin or on a volume of a storage or distribution medium, is called an\n“aggregate” if the compilation and its resulting copyright are not\nused to limit the access or legal rights of the compilation's users\nbeyond what the individual works permit.  Inclusion of a covered work\nin an aggregate does not cause this License to apply to the other\nparts of the aggregate.\n\n### 6. Conveying Non-Source Forms\n\nYou may convey a covered work in object code form under the terms\nof sections 4 and 5, provided that you also convey the\nmachine-readable Corresponding Source under the terms of this License,\nin one of these ways:\n\n* **a)** Convey the object code in, or embodied in, a physical product\n(including a physical distribution medium), accompanied by the\nCorresponding Source fixed on a durable physical medium\ncustomarily used for software interchange.\n* **b)** Convey the object code in, or embodied in, a physical product\n(including a physical distribution medium), accompanied by a\nwritten offer, valid for at least three years and valid for as\nlong as you offer spare parts or customer support for that product\nmodel, to give anyone who possesses the object code either **(1)** a\ncopy of the Corresponding Source for all the software in the\nproduct that is covered by this License, on a durable physical\nmedium customarily used for software interchange, for a price no\nmore than your reasonable cost of physically performing this\nconveying of source, or **(2)** access to copy the\nCorresponding Source from a network server at no charge.\n* **c)** Convey individual copies of the object code with a copy of the\nwritten offer to provide the Corresponding Source.  This\nalternative is allowed only occasionally and noncommercially, and\nonly if you received the object code with such an offer, in accord\nwith subsection 6b.\n* **d)** Convey the object code by offering access from a designated\nplace (gratis or for a charge), and offer equivalent access to the\nCorresponding Source in the same way through the same place at no\nfurther charge.  You need not require recipients to copy the\nCorresponding Source along with the object code.  If the place to\ncopy the object code is a network server, the Corresponding Source\nmay be on a different server (operated by you or a third party)\nthat supports equivalent copying facilities, provided you maintain\nclear directions next to the object code saying where to find the\nCorresponding Source.  Regardless of what server hosts the\nCorresponding Source, you remain obligated to ensure that it is\navailable for as long as needed to satisfy these requirements.\n* **e)** Convey the object code using peer-to-peer transmission, provided\nyou inform other peers where the object code and Corresponding\nSource of the work are being offered to the general public at no\ncharge under subsection 6d.\n\nA separable portion of the object code, whose source code is excluded\nfrom the Corresponding Source as a System Library, need not be\nincluded in conveying the object code work.\n\nA “User Product” is either **(1)** a “consumer product”, which means any\ntangible personal property which is normally used for personal, family,\nor household purposes, or **(2)** anything designed or sold for incorporation\ninto a dwelling.  In determining whether a product is a consumer product,\ndoubtful cases shall be resolved in favor of coverage.  For a particular\nproduct received by a particular user, “normally used” refers to a\ntypical or common use of that class of product, regardless of the status\nof the particular user or of the way in which the particular user\nactually uses, or expects or is expected to use, the product.  A product\nis a consumer product regardless of whether the product has substantial\ncommercial, industrial or non-consumer uses, unless such uses represent\nthe only significant mode of use of the product.\n\n“Installation Information” for a User Product means any methods,\nprocedures, authorization keys, or other information required to install\nand execute modified versions of a covered work in that User Product from\na modified version of its Corresponding Source.  The information must\nsuffice to ensure that the continued functioning of the modified object\ncode is in no case prevented or interfered with solely because\nmodification has been made.\n\nIf you convey an object code work under this section in, or with, or\nspecifically for use in, a User Product, and the conveying occurs as\npart of a transaction in which the right of possession and use of the\nUser Product is transferred to the recipient in perpetuity or for a\nfixed term (regardless of how the transaction is characterized), the\nCorresponding Source conveyed under this section must be accompanied\nby the Installation Information.  But this requirement does not apply\nif neither you nor any third party retains the ability to install\nmodified object code on the User Product (for example, the work has\nbeen installed in ROM).\n\nThe requirement to provide Installation Information does not include a\nrequirement to continue to provide support service, warranty, or updates\nfor a work that has been modified or installed by the recipient, or for\nthe User Product in which it has been modified or installed.  Access to a\nnetwork may be denied when the modification itself materially and\nadversely affects the operation of the network or violates the rules and\nprotocols for communication across the network.\n\nCorresponding Source conveyed, and Installation Information provided,\nin accord with this section must be in a format that is publicly\ndocumented (and with an implementation available to the public in\nsource code form), and must require no special password or key for\nunpacking, reading or copying.\n\n### 7. Additional Terms\n\n“Additional permissions” are terms that supplement the terms of this\nLicense by making exceptions from one or more of its conditions.\nAdditional permissions that are applicable to the entire Program shall\nbe treated as though they were included in this License, to the extent\nthat they are valid under applicable law.  If additional permissions\napply only to part of the Program, that part may be used separately\nunder those permissions, but the entire Program remains governed by\nthis License without regard to the additional permissions.\n\nWhen you convey a copy of a covered work, you may at your option\nremove any additional permissions from that copy, or from any part of\nit.  (Additional permissions may be written to require their own\nremoval in certain cases when you modify the work.)  You may place\nadditional permissions on material, added by you to a covered work,\nfor which you have or can give appropriate copyright permission.\n\nNotwithstanding any other provision of this License, for material you\nadd to a covered work, you may (if authorized by the copyright holders of\nthat material) supplement the terms of this License with terms:\n\n* **a)** Disclaiming warranty or limiting liability differently from the\nterms of sections 15 and 16 of this License; or\n* **b)** Requiring preservation of specified reasonable legal notices or\nauthor attributions in that material or in the Appropriate Legal\nNotices displayed by works containing it; or\n* **c)** Prohibiting misrepresentation of the origin of that material, or\nrequiring that modified versions of such material be marked in\nreasonable ways as different from the original version; or\n* **d)** Limiting the use for publicity purposes of names of licensors or\nauthors of the material; or\n* **e)** Declining to grant rights under trademark law for use of some\ntrade names, trademarks, or service marks; or\n* **f)** Requiring indemnification of licensors and authors of that\nmaterial by anyone who conveys the material (or modified versions of\nit) with contractual assumptions of liability to the recipient, for\nany liability that these contractual assumptions directly impose on\nthose licensors and authors.\n\nAll other non-permissive additional terms are considered “further\nrestrictions” within the meaning of section 10.  If the Program as you\nreceived it, or any part of it, contains a notice stating that it is\ngoverned by this License along with a term that is a further\nrestriction, you may remove that term.  If a license document contains\na further restriction but permits relicensing or conveying under this\nLicense, you may add to a covered work material governed by the terms\nof that license document, provided that the further restriction does\nnot survive such relicensing or conveying.\n\nIf you add terms to a covered work in accord with this section, you\nmust place, in the relevant source files, a statement of the\nadditional terms that apply to those files, or a notice indicating\nwhere to find the applicable terms.\n\nAdditional terms, permissive or non-permissive, may be stated in the\nform of a separately written license, or stated as exceptions;\nthe above requirements apply either way.\n\n### 8. Termination\n\nYou may not propagate or modify a covered work except as expressly\nprovided under this License.  Any attempt otherwise to propagate or\nmodify it is void, and will automatically terminate your rights under\nthis License (including any patent licenses granted under the third\nparagraph of section 11).\n\nHowever, if you cease all violation of this License, then your\nlicense from a particular copyright holder is reinstated **(a)**\nprovisionally, unless and until the copyright holder explicitly and\nfinally terminates your license, and **(b)** permanently, if the copyright\nholder fails to notify you of the violation by some reasonable means\nprior to 60 days after the cessation.\n\nMoreover, your license from a particular copyright holder is\nreinstated permanently if the copyright holder notifies you of the\nviolation by some reasonable means, this is the first time you have\nreceived notice of violation of this License (for any work) from that\ncopyright holder, and you cure the violation prior to 30 days after\nyour receipt of the notice.\n\nTermination of your rights under this section does not terminate the\nlicenses of parties who have received copies or rights from you under\nthis License.  If your rights have been terminated and not permanently\nreinstated, you do not qualify to receive new licenses for the same\nmaterial under section 10.\n\n### 9. Acceptance Not Required for Having Copies\n\nYou are not required to accept this License in order to receive or\nrun a copy of the Program.  Ancillary propagation of a covered work\noccurring solely as a consequence of using peer-to-peer transmission\nto receive a copy likewise does not require acceptance.  However,\nnothing other than this License grants you permission to propagate or\nmodify any covered work.  These actions infringe copyright if you do\nnot accept this License.  Therefore, by modifying or propagating a\ncovered work, you indicate your acceptance of this License to do so.\n\n### 10. Automatic Licensing of Downstream Recipients\n\nEach time you convey a covered work, the recipient automatically\nreceives a license from the original licensors, to run, modify and\npropagate that work, subject to this License.  You are not responsible\nfor enforcing compliance by third parties with this License.\n\nAn “entity transaction” is a transaction transferring control of an\norganization, or substantially all assets of one, or subdividing an\norganization, or merging organizations.  If propagation of a covered\nwork results from an entity transaction, each party to that\ntransaction who receives a copy of the work also receives whatever\nlicenses to the work the party's predecessor in interest had or could\ngive under the previous paragraph, plus a right to possession of the\nCorresponding Source of the work from the predecessor in interest, if\nthe predecessor has it or can get it with reasonable efforts.\n\nYou may not impose any further restrictions on the exercise of the\nrights granted or affirmed under this License.  For example, you may\nnot impose a license fee, royalty, or other charge for exercise of\nrights granted under this License, and you may not initiate litigation\n(including a cross-claim or counterclaim in a lawsuit) alleging that\nany patent claim is infringed by making, using, selling, offering for\nsale, or importing the Program or any portion of it.\n\n### 11. Patents\n\nA “contributor” is a copyright holder who authorizes use under this\nLicense of the Program or a work on which the Program is based.  The\nwork thus licensed is called the contributor's “contributor version”.\n\nA contributor's “essential patent claims” are all patent claims\nowned or controlled by the contributor, whether already acquired or\nhereafter acquired, that would be infringed by some manner, permitted\nby this License, of making, using, or selling its contributor version,\nbut do not include claims that would be infringed only as a\nconsequence of further modification of the contributor version.  For\npurposes of this definition, “control” includes the right to grant\npatent sublicenses in a manner consistent with the requirements of\nthis License.\n\nEach contributor grants you a non-exclusive, worldwide, royalty-free\npatent license under the contributor's essential patent claims, to\nmake, use, sell, offer for sale, import and otherwise run, modify and\npropagate the contents of its contributor version.\n\nIn the following three paragraphs, a “patent license” is any express\nagreement or commitment, however denominated, not to enforce a patent\n(such as an express permission to practice a patent or covenant not to\nsue for patent infringement).  To “grant” such a patent license to a\nparty means to make such an agreement or commitment not to enforce a\npatent against the party.\n\nIf you convey a covered work, knowingly relying on a patent license,\nand the Corresponding Source of the work is not available for anyone\nto copy, free of charge and under the terms of this License, through a\npublicly available network server or other readily accessible means,\nthen you must either **(1)** cause the Corresponding Source to be so\navailable, or **(2)** arrange to deprive yourself of the benefit of the\npatent license for this particular work, or **(3)** arrange, in a manner\nconsistent with the requirements of this License, to extend the patent\nlicense to downstream recipients.  “Knowingly relying” means you have\nactual knowledge that, but for the patent license, your conveying the\ncovered work in a country, or your recipient's use of the covered work\nin a country, would infringe one or more identifiable patents in that\ncountry that you have reason to believe are valid.\n\nIf, pursuant to or in connection with a single transaction or\narrangement, you convey, or propagate by procuring conveyance of, a\ncovered work, and grant a patent license to some of the parties\nreceiving the covered work authorizing them to use, propagate, modify\nor convey a specific copy of the covered work, then the patent license\nyou grant is automatically extended to all recipients of the covered\nwork and works based on it.\n\nA patent license is “discriminatory” if it does not include within\nthe scope of its coverage, prohibits the exercise of, or is\nconditioned on the non-exercise of one or more of the rights that are\nspecifically granted under this License.  You may not convey a covered\nwork if you are a party to an arrangement with a third party that is\nin the business of distributing software, under which you make payment\nto the third party based on the extent of your activity of conveying\nthe work, and under which the third party grants, to any of the\nparties who would receive the covered work from you, a discriminatory\npatent license **(a)** in connection with copies of the covered work\nconveyed by you (or copies made from those copies), or **(b)** primarily\nfor and in connection with specific products or compilations that\ncontain the covered work, unless you entered into that arrangement,\nor that patent license was granted, prior to 28 March 2007.\n\nNothing in this License shall be construed as excluding or limiting\nany implied license or other defenses to infringement that may\notherwise be available to you under applicable patent law.\n\n### 12. No Surrender of Others' Freedom\n\nIf conditions are imposed on you (whether by court order, agreement or\notherwise) that contradict the conditions of this License, they do not\nexcuse you from the conditions of this License.  If you cannot convey a\ncovered work so as to satisfy simultaneously your obligations under this\nLicense and any other pertinent obligations, then as a consequence you may\nnot convey it at all.  For example, if you agree to terms that obligate you\nto collect a royalty for further conveying from those to whom you convey\nthe Program, the only way you could satisfy both those terms and this\nLicense would be to refrain entirely from conveying the Program.\n\n### 13. Remote Network Interaction; Use with the GNU General Public License\n\nNotwithstanding any other provision of this License, if you modify the\nProgram, your modified version must prominently offer all users\ninteracting with it remotely through a computer network (if your version\nsupports such interaction) an opportunity to receive the Corresponding\nSource of your version by providing access to the Corresponding Source\nfrom a network server at no charge, through some standard or customary\nmeans of facilitating copying of software.  This Corresponding Source\nshall include the Corresponding Source for any work covered by version 3\nof the GNU General Public License that is incorporated pursuant to the\nfollowing paragraph.\n\nNotwithstanding any other provision of this License, you have\npermission to link or combine any covered work with a work licensed\nunder version 3 of the GNU General Public License into a single\ncombined work, and to convey the resulting work.  The terms of this\nLicense will continue to apply to the part which is the covered work,\nbut the work with which it is combined will remain governed by version\n3 of the GNU General Public License.\n\n### 14. Revised Versions of this License\n\nThe Free Software Foundation may publish revised and/or new versions of\nthe GNU Affero General Public License from time to time.  Such new versions\nwill be similar in spirit to the present version, but may differ in detail to\naddress new problems or concerns.\n\nEach version is given a distinguishing version number.  If the\nProgram specifies that a certain numbered version of the GNU Affero General\nPublic License “or any later version” applies to it, you have the\noption of following the terms and conditions either of that numbered\nversion or of any later version published by the Free Software\nFoundation.  If the Program does not specify a version number of the\nGNU Affero General Public License, you may choose any version ever published\nby the Free Software Foundation.\n\nIf the Program specifies that a proxy can decide which future\nversions of the GNU Affero General Public License can be used, that proxy's\npublic statement of acceptance of a version permanently authorizes you\nto choose that version for the Program.\n\nLater license versions may give you additional or different\npermissions.  However, no additional obligations are imposed on any\nauthor or copyright holder as a result of your choosing to follow a\nlater version.\n\n### 15. Disclaimer of Warranty\n\nTHERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY\nAPPLICABLE LAW.  EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT\nHOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM “AS IS” WITHOUT WARRANTY\nOF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,\nTHE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR\nPURPOSE.  THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM\nIS WITH YOU.  SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF\nALL NECESSARY SERVICING, REPAIR OR CORRECTION.\n\n### 16. Limitation of Liability\n\nIN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING\nWILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS\nTHE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY\nGENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE\nUSE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF\nDATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD\nPARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),\nEVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF\nSUCH DAMAGES.\n\n### 17. Interpretation of Sections 15 and 16\n\nIf the disclaimer of warranty and limitation of liability provided\nabove cannot be given local legal effect according to their terms,\nreviewing courts shall apply local law that most closely approximates\nan absolute waiver of all civil liability in connection with the\nProgram, unless a warranty or assumption of liability accompanies a\ncopy of the Program in return for a fee.\n\n## <div align=\"center\">END OF TERMS AND CONDITIONS</div>\n\n### <div align=\"center\">How to Apply These Terms to Your New Programs</div>\n\nIf you develop a new program, and you want it to be of the greatest\npossible use to the public, the best way to achieve this is to make it\nfree software which everyone can redistribute and change under these terms.\n\nTo do so, attach the following notices to the program.  It is safest\nto attach them to the start of each source file to most effectively\nstate the exclusion of warranty; and each file should have at least\nthe “copyright” line and a pointer to where the full notice is found.\n\n    <one line to give the program's name and a brief idea of what it does.>\n    Copyright (C) <year>  <name of author>\n\n    This program is free software: you can redistribute it and/or modify\n    it under the terms of the GNU Affero General Public License as published by\n    the Free Software Foundation, either version 3 of the License, or\n    (at your option) any later version.\n\n    This program is distributed in the hope that it will be useful,\n    but WITHOUT ANY WARRANTY; without even the implied warranty of\n    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\n    GNU Affero General Public License for more details.\n\n    You should have received a copy of the GNU Affero General Public License\n    along with this program.  If not, see <http://www.gnu.org/licenses/>.\n\nAlso add information on how to contact you by electronic and paper mail.\n\nIf your software can interact with users remotely through a computer\nnetwork, you should also make sure that it provides a way for users to\nget its source.  For example, if your program is a web application, its\ninterface could display a “Source” link that leads users to an archive\nof the code.  There are many ways you could offer source, and different\nsolutions will be better for different programs; see section 13 for the\nspecific requirements.\n\nYou should also get your employer (if you work as a programmer) or school,\nif any, to sign a “copyright disclaimer” for the program, if necessary.\nFor more information on this, and how to apply and follow the GNU AGPL, see\n&lt;<http://www.gnu.org/licenses/>&gt;."
  },
  {
    "path": "docs/ALGOLIA-SEARCH.md",
    "content": "<h1 align=\"center\">Algolia Search</h1>\n\nNexT provides Algolia search plugin for index your hexo website content. To use this feature, make sure that the version of NexT you are using is after the v5.1.0 release. What you should note here is that only turn on `enable` of `algolia_search` in `next/_config.yml` cannot let you use the algolia search correctly, you need to install corresponding [Hexo Algolia](https://github.com/oncletom/hexo-algolia) plugin to seach your website with Algolia. Follow the steps described below to complete the installation of Algolia search.\n\n1. Register at [Algolia](https://www.algolia.com/), you can log in directly using GitHub or Google Account. Upon Customer’s initial sign-up for an Account, Customer will have a free, fourteen (14) day evaluation period (the “Evaluation Period”) for the Algolia Services commencing on the Effective Date, subject to the limitations on Algolia’s website. After that, Algolia offers a free, branded version for up to 10k records and 100k operations per month.\n\n1. If a tutorial pops up, you can skip it. Go straight to create an `Index` which will be used later.\n\n    ![](https://user-images.githubusercontent.com/16272760/73673892-68a29b00-46ea-11ea-90c5-916b4b11fc7a.png)\n\n1. Go to the `API Keys` page and find your credentials. You will need the `Application ID` and the `Search-only API key` in the following sections. The `Admin API key` need to keep confidential. Never store your Admin API Key as apiKey in the` _config.yml` file: it would give full control of your Algolia index to others and you don't want to face the consequences.\n\n    ![](https://user-images.githubusercontent.com/16272760/73673895-693b3180-46ea-11ea-8f50-8bae850b50d0.png)\n\n1. In your site's `_config.yml`, add the following configuration and replace the `applicationID` & `apiKey` & `indexName` with corresponding fields obtained at Algolia.\n\n    ```yml\n    algolia:\n      applicationID: 'Application ID'\n      apiKey: 'Search-only API key'\n      indexName: 'indexName'\n      chunkSize: 5000\n    ```\n\n1. In the `API Keys` page, click the `All API Keys` button to switch to the corresponding tab. Then click the `New API Key` button to activate a pop-up box where you can setup authorizations and restrictions with a great level of precision. Enter `addObject`, `deleteObject`, `listIndexes`, `deleteIndex` features in ACL permissions that will be allowed for the given API key. And then click the `Create` button. Copy this newly created key to the clipboard, we call it a `High-privilege API key`.\n\n    ![](https://user-images.githubusercontent.com/16272760/73673902-6b04f500-46ea-11ea-9c80-4e5c5002e07b.png)\n    ![](https://user-images.githubusercontent.com/16272760/73673905-6b9d8b80-46ea-11ea-9e01-702ec2a8a297.png)\n\n1. Algolia requires users to upload their search index data either manually or via provided APIs. Install and configure [Hexo Algolia](https://github.com/oncletom/hexo-algolia) in your Hexo directory. This plugin will index your site and upload selected data to Algolia.\n\n    ```\n    $ cd hexo\n    $ npm install hexo-algolia\n    ```\n\n1. Run the following command to upload index data, keep a weather eye out the output of the command.\n\n    ```\n    $ export HEXO_ALGOLIA_INDEXING_KEY=High-privilege API key # Use Git Bash\n    # set HEXO_ALGOLIA_INDEXING_KEY=High-privilege API key # Use Windows command line\n    $ hexo clean\n    $ hexo algolia\n    ```\n\n    ![](http://theme-next.iissnan.com/uploads/algolia/algolia-step-4.png)\n\n1. In `next/_config.yml`, turn on `enable` of `algolia_search`. At the same time, you need to **turn off other search plugins** like Local Search. You can also adjust the text in `labels` according to your needs.\n\n    ```yml\n    # Algolia Search\n    algolia_search:\n      enable: true\n      hits:\n        per_page: 10\n      labels:\n        input_placeholder: Search for Posts\n        hits_empty: \"We didn't find any results for the search: ${query}\"\n        hits_stats: \"${hits} results found in ${time} ms\"\n    ```\n\n1. If you want to use a different version from CDN, please follow the instructions below.\n\n    You need to **set vendors** in NexT `_config.yml` file:\n    ```yml\n    vendors:\n      ...\n      # Algolia Search\n      # algolia_search: //cdn.jsdelivr.net/npm/algoliasearch@4/dist/algoliasearch-lite.umd.js\n      # instant_search: //cdn.jsdelivr.net/npm/instantsearch.js@4/dist/instantsearch.production.min.js\n      algolia_search: //cdn.jsdelivr.net/npm/algoliasearch@4/dist/algoliasearch-lite.umd.js\n      instant_search: //cdn.jsdelivr.net/npm/instantsearch.js@4/dist/instantsearch.production.min.js\n      ...\n    ```\n\n<h2 align=\"center\">Known Issues</h2>\n\n1. The latest version of the [Hexo-Algolia](https://github.com/oncletom/hexo-algolia) plugin removes the content indexing feature, given Algolia's free account limitation.\n\n1. The [Hexo-Algoliasearch](https://github.com/LouisBarranqueiro/hexo-algoliasearch) plugin provides content indexing functionality, but requires the replacement of keywords in the NEXT theme. The same problem exists with `Record Too Big` for Algolia's free account.\n    - Replace all `applicationID` in `source/js/algolia-search.js` with `appId`\n    - Replace all `applicationID` in `layout/_partials/head/head.swig` with `appId`\n"
  },
  {
    "path": "docs/AUTHORS.md",
    "content": "# <div align=\"center\">«NexT» Authors</div>\n\nNexT theme was initially developed by:\n\n- **IIssNaN**: [NexT](https://github.com/iissnan/hexo-theme-next) (2014 - 2017)\n\nWith collaborators from initially repository:\n\n- **Ivan.Nginx**: [DIFF highlight](https://github.com/iissnan/hexo-theme-next/pull/1079),\n                  [HyperComments](https://github.com/iissnan/hexo-theme-next/pull/1155),\n                  [`{% note %}` tag](https://github.com/iissnan/hexo-theme-next/pull/1160),\n                  [`seo` option](https://github.com/iissnan/hexo-theme-next/pull/1311),\n                  [`{% button %}` tag](https://github.com/iissnan/hexo-theme-next/pull/1328),\n                  [VK API](https://github.com/iissnan/hexo-theme-next/pull/1381),\n                  [WordCount plugin support](https://github.com/iissnan/hexo-theme-next/pull/1381),\n                  [Yandex verification option](https://github.com/iissnan/hexo-theme-next/pull/1381),\n                  [`{% exturl %}` tag](https://github.com/iissnan/hexo-theme-next/pull/1438),\n                  [`b2t` option](https://github.com/iissnan/hexo-theme-next/pull/1438),\n                  [`scrollpercent` option](https://github.com/iissnan/hexo-theme-next/pull/1438),\n                  [`save_scroll` option](https://github.com/iissnan/hexo-theme-next/pull/1574),\n                  [Star rating](https://github.com/iissnan/hexo-theme-next/pull/1649),\n                  [`mobile_layout_economy` option](https://github.com/iissnan/hexo-theme-next/pull/1697),\n                  [`{% tabs %}` tag](https://github.com/iissnan/hexo-theme-next/pull/1697),\n                  [`{% label %}` tag](https://github.com/iissnan/hexo-theme-next/pull/1697),\n                  [**`Gemini`** scheme](https://github.com/iissnan/hexo-theme-next/pull/1697),\n                  [Menu & Sidebar icons in 1 line](https://github.com/iissnan/hexo-theme-next/pull/1830),\n                  [Sidebar scrollable](https://github.com/iissnan/hexo-theme-next/pull/1898),\n                  [Responsive favicons](https://github.com/iissnan/hexo-theme-next/pull/1898)\n                  and many other [PR's with fixes and enhancements](https://github.com/iissnan/hexo-theme-next/pulls?utf8=%E2%9C%93&q=is%3Apr%20author%3Aivan-nginx)\n- **Acris**: [Many PR's with fixes and updates](https://github.com/iissnan/hexo-theme-next/pulls?utf8=%E2%9C%93&q=is%3Apr%20author%3AAcris)\n\nAnd best contributors from initially repository:\n\n- **Rainy**: [Gentie comments](https://github.com/iissnan/hexo-theme-next/pull/1301),\n             [Han](https://github.com/iissnan/hexo-theme-next/pull/1598)\n             and many [PR's with fixes and optimizations](https://github.com/iissnan/hexo-theme-next/pulls?utf8=%E2%9C%93&q=is%3Apr%20author%3Ageekrainy)\n- **Jeff**: [Local search](https://github.com/iissnan/hexo-theme-next/pull/694)\n            and many [PR's with fixes and improvements](https://github.com/iissnan/hexo-theme-next/pulls?utf8=%E2%9C%93&q=is%3Apr%20author%3Aflashlab)\n- **Haocen**: [Footer enhancements](https://github.com/iissnan/hexo-theme-next/pull/1886)\n              and some other [PR's with improvements](https://github.com/iissnan/hexo-theme-next/pulls?utf8=%E2%9C%93&q=is%3Apr%20author%3AHaocen)\n- **uchuhimo**: [Greatest enhancements for local search](https://github.com/iissnan/hexo-theme-next/pulls?utf8=%E2%9C%93&q=is%3Apr%20author%3Auchuhimo)\n- **Kei**: [Change static file setting to support subdirectory](https://github.com/iissnan/hexo-theme-next/pull/4)\n- **Jolyon**: [Swiftype](https://github.com/iissnan/hexo-theme-next/pull/84)\n- **xirong**: [404 page](https://github.com/iissnan/hexo-theme-next/pull/126)\n- **PinkyJie**: [Fix Swiftype](https://github.com/iissnan/hexo-theme-next/pull/132)\n- **Tim Kuijsten**: [Split javascript into separate files](https://github.com/iissnan/hexo-theme-next/pull/152)\n- **iamwent**: [Friendly links](https://github.com/iissnan/hexo-theme-next/pull/250)\n- **arao lin**: [Option to lazyload images](https://github.com/iissnan/hexo-theme-next/pull/269)\n- **Konstantin Pavlov**: [Microdata, opengraph and other semantic features](https://github.com/iissnan/hexo-theme-next/pull/276)\n- **Gary**: [FastClick](https://github.com/iissnan/hexo-theme-next/pull/324)\n- **Octavian**: [Baidu site vertification](https://github.com/iissnan/hexo-theme-next/pull/367)\n- **Henry Chang**: [Facebook SDK](https://github.com/iissnan/hexo-theme-next/pull/410)\n- **XiaMo**: [LeanCloud visitors](https://github.com/iissnan/hexo-theme-next/pull/439)\n- **iblogc**: [Fix UA in Duoshuo](https://github.com/iissnan/hexo-theme-next/pull/489)\n- **Vincent**: [Automatic headline ID's](https://github.com/iissnan/hexo-theme-next/pull/588)\n- **cissoid**: [Tencent analytics](https://github.com/iissnan/hexo-theme-next/pull/603)\n- **CosmoX**: [AddThis](https://github.com/iissnan/hexo-theme-next/pull/660)\n- **Jason Guo**: [Reward for post](https://github.com/iissnan/hexo-theme-next/pull/687)\n- **Jerry Bendy**: [CNZZ counter](https://github.com/iissnan/hexo-theme-next/pull/712)\n- **Hui Wang**: [Wechat subscriber](https://github.com/iissnan/hexo-theme-next/pull/788)\n- **PoonChiTim**: [Busuanzi counter](https://github.com/iissnan/hexo-theme-next/pull/809)\n- **hydai**: [Facebook comments](https://github.com/iissnan/hexo-theme-next/pull/925)\n- **OAwan**: [`canonical` option](https://github.com/iissnan/hexo-theme-next/pull/931)\n- **Jim Zenn**: [Google Calendar](https://github.com/iissnan/hexo-theme-next/pull/1167)\n- **Abner Chou**: [Disqus improvements](https://github.com/iissnan/hexo-theme-next/pull/1173)\n- **Igor Fesenko**: [Application Insights](https://github.com/iissnan/hexo-theme-next/pull/1257)\n- **jinfang**: [Youyan comments](https://github.com/iissnan/hexo-theme-next/pull/1324)\n- **AlynxZhou**: [`canvas_nest` option](https://github.com/iissnan/hexo-theme-next/pull/1327)\n- **aleon**: [Tencent MTA](https://github.com/iissnan/hexo-theme-next/pull/1408)\n- **asmoker**: [LiveRe comments](https://github.com/iissnan/hexo-theme-next/pull/1415)\n- **Jacksgong**: [Copyright on posts](https://github.com/iissnan/hexo-theme-next/pull/1497)\n- **zhaiqianfeng**: [Changyan comments](https://github.com/iissnan/hexo-theme-next/pull/1514)\n- **zproo**: [`canvas_ribbon` option](https://github.com/iissnan/hexo-theme-next/pull/1565)\n- **jjandxa**: [`three_waves`](https://github.com/iissnan/hexo-theme-next/pull/1534),\n               [`canvas_lines` and `canvas_sphere`](https://github.com/iissnan/hexo-theme-next/pull/1595) options\n- **shenzekun**: [Load bar at the top](https://github.com/iissnan/hexo-theme-next/pull/1689)\n- **elkan1788**: [Upgrade jiathis share](https://github.com/iissnan/hexo-theme-next/pull/1796)\n- **xCss**: [Valine comment system support](https://github.com/iissnan/hexo-theme-next/pull/1811)\n- **Julian Xhokaxhiu**: [`override` option](https://github.com/iissnan/hexo-theme-next/pull/1861)\n- **LEAFERx**: [NeedMoreShare2](https://github.com/iissnan/hexo-theme-next/pull/1913)\n- **aimingoo & LEAFERx**: [Gitment supported with Mint](https://github.com/iissnan/hexo-theme-next/pull/1919)\n- **LeviDing**: [Fix the bug of Gitment](https://github.com/iissnan/hexo-theme-next/pull/1944)\n- **maple3142**: [Firestore visitor counter](https://github.com/iissnan/hexo-theme-next/pull/1978)\n\nIt lives on as an open source project with many contributors, a self updating list is [here](https://github.com/theme-next/hexo-theme-next/graphs/contributors).\n\nP.S. If you did some useful pulls/commits in original repository and you are not in the list, let us know and you will be added here.\n"
  },
  {
    "path": "docs/DATA-FILES.md",
    "content": "<h1 align=\"center\">Data Files</h1>\n\nCurrently, it is not smooth to update NexT theme from pulling or downloading new releases. It is quite often running into conflict status when updating NexT theme via `git pull`, or need to merge configurations manually when upgrading to new releases.\n\nAt present, NexT encourages users to store some options in site's `/_config.yml` and other options in theme's `/themes/next/_config.yml`. This approach is applicable, but has some drawbacks:\n1. Configurations are splitted into two pieces\n2. Users may be confused which place should be for options\n\nIn order to resolve this issue, NexT provides the following two solutions.\n\n<h2 align=\"center\">Option 1: Hexo-Way</h2>\n\nWith this way, all your configurations locate in main Hexo config file (`/_config.yml`), you don't need to touch `/themes/next/_config.yml` or create any new files. But you must preserve double spaces indents within `theme_config` option.\n\nIf there are any new options in new releases, you just need to copy those options from `/themes/next/_config.yml`, paste into `/_config.yml` and set their values to whatever you want.\n\n### Usage\n\n1. Please confirm that the `/source/_data/next.yml` file does not exist (delete it if exists).\n2. Copy needed NexT theme options from theme's `/themes/next/_config.yml` into `/_config.yml`, then\\\n   2.1. Move all this settings to the right with two spaces (in Visual Studio Code: select all strings, <kbd>CTRL</kbd> + <kbd>]</kbd>).\\\n   2.2. Add `theme_config:` parameter above all this settings.\n\n### Useful links\n\n* [Hexo Configuration](https://hexo.io/docs/configuration.html)\n* [Hexo Pull #757](https://github.com/hexojs/hexo/pull/757)\n\n<h2 align=\"center\">Option 2: NexT-Way</h2>\n\nWith this way, you can put all your configurations into one place (`/source/_data/next.yml`), you don't need to touch `/themes/next/_config.yml`.\nBut option may not accurately procces all hexo external libraries with their additional options (for example, `hexo-server` module options may be readed only in default hexo config).\n\nIf there are any new options in new releases, you just need to copy those options from `/themes/next/_config.yml`, paste into `/source/_data/next.yml` and set their values to whatever you want.\n\nThis method relies on Hexo [Data files](https://hexo.io/docs/data-files.html). Because Data files is introduced in Hexo 3, so you need upgrade Hexo to 3.0 (or above) to use this feature.\n\n### Usage\n\n1. Please ensure you are using Hexo 3 (or above).\n2. Create an file named `next.yml` in site's `/source/_data` directory (create `_data` directory if it does not exist).\n\n<p align=\"center\">And after that steps there are <b>2 variants</b>, need to <b>choose only one</b> of them and <b>resume next steps</b>.</p>\n\n* **Variant 1: `override: false` (default)**:\n\n  1. Check your `override` option in default NexT config, it must set on `false`.\\\n     In `next.yml` it must not be defined or set on `false` too.\n  2. Copy needed options from both site's `/_config.yml` and theme's `/themes/next/_config.yml` into `/source/_data/next.yml`.\n\n* **Variant 2: `override: true`**:\n\n  1. In `next.yml` set `override` option on `true`.\n  2. Copy **all** NexT theme options from theme's `/themes/next/_config.yml` into `/source/_data/next.yml`.\n\n3. Then, in main site's `/_config.yml` need to define `theme: next` option (and if needed, `source_dir: source`).\n4. Use standard parameters to start server, generate or deploy (`hexo clean && hexo g -d && hexo s`).\n\n### Useful links\n\n* [NexT Issue #328](https://github.com/iissnan/hexo-theme-next/issues/328)\n"
  },
  {
    "path": "docs/INSTALLATION.md",
    "content": "<h1 align=\"center\">Installation</h1>\n\n<h2 align=\"center\">Step 1 &rarr; Go to Hexo dir</h2>\n\nChange dir to **Hexo root** directory. There must be `node_modules`, `source`, `themes` and other directories:\n\n```sh\n$ cd hexo\n$ ls\n_config.yml  node_modules  package.json  public  scaffolds  source  themes\n```\n\n<h2 align=\"center\">Step 2 &rarr; Get NexT</h2>\n\n<p align=\"center\">Download theme from GitHub.<br>\nThere are <b>3 options</b> to do it, need to <b>choose only one</b> of them.</p>\n\n### Option 1: Download [latest release version][releases-latest-url]\n\n   At most cases **stable**. Recommended for beginners.\n\n   * Install with [curl & tar & wget][curl-tar-wget-url]:\n\n     ```sh\n     $ mkdir themes/next\n     $ curl -s https://api.github.com/repos/theme-next/hexo-theme-next/releases/latest | grep tarball_url | cut -d '\"' -f 4 | wget -i - -O- | tar -zx -C themes/next --strip-components=1\n     ```\n     This variant will give to you **only latest release version** (without `.git` directory inside).\\\n     So, there is impossible to update this version with `git` later.\\\n     Instead you always can use separate configuration (e.g. [data-files][docs-data-files-url]) and download new version inside old directory (or create new directory and redefine `theme` in Hexo config), without losing your old configuration.\n\n### Option 2: Download [tagged release version][releases-url]\n\n   In rare cases useful, but not recommended.\\\n   You must define version. Replace `v6.0.0` with any version from [tags list][tags-url].\n\n   * Variant 1: Install with [curl & tar][curl-tar-url]:\n\n     ```sh\n     $ mkdir themes/next\n     $ curl -L https://api.github.com/repos/theme-next/hexo-theme-next/tarball/v6.0.0 | tar -zxv -C themes/next --strip-components=1\n     ```\n     Same as above under `curl & tar & wget` variant, but will download **only concrete version**.\n\n   * Variant 2: Install with [git][git-url]:\n\n     ```sh\n     $ git clone --branch v6.0.0 https://github.com/theme-next/hexo-theme-next themes/next\n     ```\n     This variant will give to you the **defined release version** (with `.git` directory inside).\\\n     And in any time you can switch to any tagged release, but with limit to defined version.\n\n### Option 3: Download [latest master branch][download-latest-url]\n\n   May be **unstable**, but includes latest features. Recommended for advanced users and for developers.\n\n   * Variant 1: Install with [curl & tar][curl-tar-url]:\n\n     ```sh\n     $ mkdir themes/next\n     $ curl -L https://api.github.com/repos/theme-next/hexo-theme-next/tarball | tar -zxv -C themes/next --strip-components=1\n     ```\n     Same as above under `curl & tar & wget` variant, but will download **only latest master branch version**.\\\n     At some cases useful for developers.\n\n   * Variant 2: Install with [git][git-url]:\n\n     ```sh\n     $ git clone https://github.com/theme-next/hexo-theme-next themes/next\n     ```\n\n     This variant will give to you the **whole repository** (with `.git` directory inside).\\\n     And in any time you can [update current version with git][update-with-git-url] and switch to any tagged release or on latest master or any other branch.\\\n     At most cases useful as for users and for developers.\n\n     Get tags list:\n\n     ```sh\n     $ cd themes/next\n     $ git tag -l\n     …\n     v6.0.0\n     v6.0.1\n     v6.0.2\n     ```\n\n     For example, you want to switch on `v6.0.1` [tagged release version][tags-url]. Input the following command:\n\n     ```sh\n     $ git checkout tags/v6.0.1\n     Note: checking out 'tags/v6.0.1'.\n     …\n     HEAD is now at da9cdd2... Release v6.0.1\n     ```\n\n     And if you want to switch back on [master branch][commits-url], input this command:\n\n     ```sh\n     $ git checkout master\n     ```\n\n<h2 align=\"center\">Step 3 &rarr; Set it up</h2>\n\nSet theme in main **Hexo root config** `_config.yml` file:\n\n```yml\ntheme: next\n```\n\n[download-latest-url]: https://github.com/theme-next/hexo-theme-next/archive/master.zip\n[releases-latest-url]: https://github.com/theme-next/hexo-theme-next/releases/latest\n[releases-url]: https://github.com/theme-next/hexo-theme-next/releases\n[tags-url]: https://github.com/theme-next/hexo-theme-next/tags\n[commits-url]: https://github.com/theme-next/hexo-theme-next/commits/master\n\n[git-url]: http://lmgtfy.com/?q=linux+git+install\n[curl-tar-url]: http://lmgtfy.com/?q=linux+curl+tar+install\n[curl-tar-wget-url]: http://lmgtfy.com/?q=linux+curl+tar+wget+install\n\n[update-with-git-url]: https://github.com/theme-next/hexo-theme-next/blob/master/README.md#update\n[docs-data-files-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/DATA-FILES.md\n"
  },
  {
    "path": "docs/LEANCLOUD-COUNTER-SECURITY.md",
    "content": "<h1 align=\"center\">Fix LeanCloud Counter Plugin Security Vulnerability</h1>\n\nBefore you make the config, please upgrade your NexT version to v6.0.6 or greater.\n\nPlease note the difference between **site config file** and **theme config file**\n\n---\n\n# Sign up to LeanCloud and create an app\n- Go to LeanCloud website [leancloud.app](https://leancloud.app) and sign up to LeanCloud. Then login.\n- Click `1` to enter the console:\n\n  ![1](https://lc-cqha0xyi.cn-n1.lcfile.com/fc0c048a1e25dc3d10aa.jpg)\n\n- Then click `1` to create an app:\n\n  ![2](https://lc-cqha0xyi.cn-n1.lcfile.com/33a56b754753a5d34b01.jpg)\n\n- Type your app name in `1` in the pop up window(eg. \"test\"), then choose `2`, which means developer's plan, and then click `3` to create the app:\n\n  ![3](https://lc-cqha0xyi.cn-n1.lcfile.com/649ccfc6f12015d1eefb.jpg)\n\n# Create Counter class and enable plugin in NexT\n- Click `1` (app name) to enter the app manage page:\n\n  ![4](https://lc-cqha0xyi.cn-n1.lcfile.com/d0889df29841661e0b9e.jpg)\n\n- then click `1` to create a class for counter:\n\n  ![5](https://lc-cqha0xyi.cn-n1.lcfile.com/b0fbc81bd6c19fa09a46.jpg)\n\n- Type `Counter` in the pop up window in `1`, check `2`, then click `3`:\n\n  ![6](https://lc-cqha0xyi.cn-n1.lcfile.com/ae6154d6a55f02f11ebf.jpg)\n\n- Click `1` to enter the app setting, then click `2`:\n\n  ![8](https://lc-cqha0xyi.cn-n1.lcfile.com/9501a6372918dd9a8a92.jpg)\n\n- Paste `App ID` and `App Key` to **theme config file** `_config.yml` like this:\n  ```yml\n  leancloud_visitors:\n    enable: true\n    app_id: # <your app id>\n    app_key: # <your app key>\n    # Required for apps from CN region\n    server_url: # <your server url>\n    # Dependencies: https://github.com/theme-next/hexo-leancloud-counter-security\n    security: true\n  ```\n\n- Set domain whitelist: Click `1`, then type your domain into `2` (**protocol, domain and port should be exactly the same**):\n\n ![9](https://lc-cqha0xyi.cn-n1.lcfile.com/0e537cc4bec2e185201d.jpg)\n\n# Deploy web engine to avoid your data being changed illegally\n- Click `1 -> 2 -> 3` by order\n\n  ![10](https://lc-cqha0xyi.cn-n1.lcfile.com/d7056dfeeef7c5d66318.jpg)\n\n- Click `1`:\n\n  ![11](https://lc-cqha0xyi.cn-n1.lcfile.com/2737841bbc2bdd572ae0.jpg)\n\n- In the pop up window, click `1` to choose type `Hook`, then choose`beforeUpdate` in `2`, choose `Counter` in `3`. Paste code below into `4`, then click `5` to save it:\n  ```javascript\n  var query = new AV.Query(\"Counter\");\n  if (request.object.updatedKeys.includes('time')) {\n      return query.get(request.object.id).then(function (obj) {\n          if (obj.get(\"time\") > request.object.get(\"time\")) {\n              throw new AV.Cloud.Error('Invalid update!');\n          }\n          return request.object.save();\n      });\n  }\n  ```\n\n  ![12](https://lc-cqha0xyi.cn-n1.lcfile.com/a8e13418ed1d9405315b.jpg)\n\n- Click `1` to deploy after the message in the red rect shows up:\n\n  ![13](https://lc-cqha0xyi.cn-n1.lcfile.com/ca56bf2e5fc2a1343565.jpg)\n\n- Click `1` in the pop up：\n\n  ![14](https://lc-cqha0xyi.cn-n1.lcfile.com/17548c13b3b23c71d845.jpg)\n\n- Click `1` to close the pop up window after the message in the red rect shows up:\n\n  ![15](https://lc-cqha0xyi.cn-n1.lcfile.com/d2f50de6cefea9fd0ed3.jpg)\n\n# Set access control for your database\n- Open **theme config file** `_config.yml`, set `leancloud_visitors: security` to `true`:\n  ```yml\n  leancloud_visitors:\n    enable: true\n    app_id: # <your app id>\n    app_key: # <your app key>\n    # Required for apps from CN region\n    server_url: # <your server url>\n    # Dependencies: https://github.com/theme-next/hexo-leancloud-counter-security\n    security: true\n  ```\n\n- Open cmd then switch to **root path of site**, type commands to install `hexo-leancloud-counter-security` plugin:\n  ```\n  npm install hexo-leancloud-counter-security\n  ```\n\n- Open **site config file** `_config.yml`, add those config:\n  ```yml\n  leancloud_counter_security:\n    enable_sync: true\n    app_id: <your app id>\n    app_key: <your app key>\n    username:\n    password:\n  ```\n\n- Type command:\n  ```\n  hexo lc-counter register <username> <password>\n  ```\n  or\n  ```\n  hexo lc-counter r <username> <password>\n  ```\n\n  Change `<username>` and `<password>` to your own username and password (no need to be the same as leancloud account). They will be used in the hexo deploying.\n\n  - Open **site config file** `_config.yml`, change `<username>` and `<password>`to those you set above:\n  ```yml\n  leancloud_counter_security:\n    enable_sync: true\n    app_id: <your app id>\n    app_key: <your app key>\n    username: <your username> # will be asked while deploying if be left blank\n    password: <your password> # recommend to leave it blank for security, will be asked while deploying if be left blank\n  ```\n\n- Add the deployer in the `deploy` of **site config file** `_config.yml`:\n  ```yml\n  deploy:\n    - type: git\n      repo: // your repo\n      ...\n    - type: leancloud_counter_security_sync\n  ```\n\n- Return to the LeanCloud console. Click `1 -> 2`, check if there is a record added in the `_User` (the img below is using username \"admin\" for example):\n\n  ![16](https://lc-cqha0xyi.cn-n1.lcfile.com/99faa5a0e7160e66d506.jpg)\n\n- Click `1 -> 2 -> 3` by order:\n\n  ![17](https://lc-cqha0xyi.cn-n1.lcfile.com/b72a9e64579f5b71749d.jpg)\n\n- <del>Click `1` (add_fields), then choose `2`:</del> Do as below \"create\" setting(choose the user you create):\n\n  ![18](https://lc-cqha0xyi.cn-n1.lcfile.com/14a8cb37062693d768ad.jpg)\n\n- click `1` (create), then choose `2`, type the username in `3`, then click `4 -> 5`:\n\n  ![19](https://lc-cqha0xyi.cn-n1.lcfile.com/d91714cfd703ef42b94c.jpg)\n\n  Now your page should be similar to this img after finishing the step.\n\n  ![20](https://lc-cqha0xyi.cn-n1.lcfile.com/c05e7ec9218820baf412.jpg)\n\n- Click `1` (delete), then choose `2`:\n\n ![21](https://lc-cqha0xyi.cn-n1.lcfile.com/c37b6e20726cfb1d3197.jpg)\n\nNow the bug is fixed.\n\n---\n\nSee detailed version here: https://leaferx.online/2018/03/16/lc-security-en/\n"
  },
  {
    "path": "docs/LICENSE.txt",
    "content": "             «NexT» – Elegant and powerful theme for Hexo.\n\n  Copyright © 2017 «NexT» (github.com/theme-next/hexo-theme-next).\n\n               Detail attribution information for «NexT»\n              is contained in the 'docs/AUTHORS.md' file.\n\n  This program is free software; you can redistribute it and/or modify\nit under the terms of the GNU Affero General Public License version 3\nas published by the Free Software Foundation with the addition of the\nfollowing permission added to Section 15 as permitted in Section 7(a):\nFOR ANY PART OF THE COVERED WORK IN WHICH THE COPYRIGHT IS OWNED BY «NEXT»,\n«NEXT» DISCLAIMS THE WARRANTY OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.\n\n  This program is distributed in the hope that it will be useful, but\nWITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY\nor FITNESS FOR A PARTICULAR PURPOSE.\nSee the GNU Affero General Public License for more details.\nYou should have received a copy of the GNU Affero General Public License\nalong with this program; if not, see: https://www.gnu.org/licenses/agpl.txt\n\n  In accordance with Section 7(b) of the GNU Affero General Public License:\n\n  a) It is not necessary to specify copyright in each source file of\n     this program because GitHub fully save commits of all modified files\n     with their authors and provides to see for this changes publicly.\n\n  b) For any part of the covered work in which the copyright not specified,\n     except of third party libraries ('source/lib/*') and '*custom.*' files,\n     will mean this part owned by «NexT» in accord with terms in this file.\n\n* c) A covered work must retain «NexT» official website link\n     (https://theme-next.org) in footer section of every website created,\n     modified or manipulated by using «NexT».\n     «NexT» theme configuration must be:\n     ```\n     footer:\n       theme:\n         enable: true\n     ```\n     Collaborators, best contributors and all authors specified in the\n     'docs/AUTHORS.md' file of «NexT» repository under the\n     'https://github.com/theme-next' organization can ignore theme info link\n     requirements.\n\n  Anyone can be released from the requirements of the license by purchasing\na commercial license. Buying such a license is mandatory as soon as you\ndevelop commercial activities involving the «NexT» software without\ndisclosing the source code of your own applications.\nThese activities include:\n  1. Access to private repository with various premium features.\n  2. Priority support for resolve all possible issues with «NexT».\n  3. Priority support for implement all possible features to «NexT».\n\n  For more information, please contact «NexT» Organization at this\naddress: support@theme-next.org\n"
  },
  {
    "path": "docs/MATH.md",
    "content": "<h1 align=\"center\">Math Equations</h1>\n\nNexT provides two render engines for displaying Math Equations.\n\nIf you choose to use this feature, you don't need to manually import any JS or CSS. You just need to choose a render engine and turn on `enable` for it (located in `next/_config.yml`).\n\nNotice: only turning on `enable` **cannot let you see the displayed equations correctly**, you need to install the **corresponding Hexo Renderer** to fully support the display of Math Equations. The corresponding Hexo Renderer per engine will be provided below.\n\n<h2 align=\"center\">Provided Render Engine</h2>\n\nFor now, NexT provides two Render Engines: [MathJax](https://www.mathjax.org/) and [Katex](https://khan.github.io/KaTeX/).\n\n### MathJax\n\nIf you use MathJax to render Math Equations, you need to use one of them: [hexo-renderer-pandoc](https://github.com/wzpan/hexo-renderer-pandoc) or [hexo-renderer-kramed](https://github.com/sun11/hexo-renderer-kramed) (Not recommended) as the renderer for Markdown.\n\nFirstly, you need to uninstall the original renderer `hexo-renderer-marked`, and install **one of the renderer above**:\n\n```sh\nnpm uninstall hexo-renderer-marked\nnpm install hexo-renderer-pandoc # or hexo-renderer-kramed\n```\n\nSecondly, in `next/_config.yml`, turn on `enable` of `mathjax`.\n\n```yml\nmath:\n  ...\n  mathjax:\n    enable: true\n```\n\nFinally, run standard Hexo generate, deploy process or start the server:\n\n```sh\nhexo clean && hexo g -d\n# or hexo clean && hexo s\n```\n\n#### Numbering and referring equations in MathJax\n\nIn the new version of NexT, we have added feature to automatically number equations and to refer to equations. We briefly describe how to use this feature below.\n\nIn general, to make the automatic equation numbering work, you have to wrap your LaTeX equations in `equation` environment. Using the plain old style (i.e., wrap an equation with two dollar signs in each side) will not work. How to refer to an equation? Just give a `\\label{}` tag and then in your later text, use `\\ref{}` or `\\eqref{}` to refer it. Using `\\eqref{}` is preferred since if you use `\\ref{}`, there are no parentheses around the equation number. Below are some of the common scenarios for equation numbering.\n\nFor simple equations, use the following form to give a tag,\n\n```latex\n$$\\begin{equation}\\label{eq1}\ne=mc^2\n\\end{equation}$$\n```\n\nThen, you can refer to this equation in your text easily by using something like\n\n```\nthe famous matter-energy equation $\\eqref{eq1}$ proposed by Einstein ...\n```\n\nFor multi-line equations, inside the `equation` environment, you can use the `aligned` environment to split it into multiple lines:\n\n```latex\n$$\\begin{equation}\\label{eq2}\n\\begin{aligned}\na &= b + c \\\\\n  &= d + e + f + g \\\\\n  &= h + i\n\\end{aligned}\n\\end{equation}$$\n```\n\nWe can use `align` environment to align multiple equations. Each of these equations will get its own numbers.\n\n```\n$$\\begin{align}\na &= b + c \\label{eq3} \\\\\nx &= yz \\label{eq4}\\\\\nl &= m - n \\label{eq5}\n\\end{align}$$\n```\n\nIn the `align` environment, if you do not want to number one or some equations, just [use `\\nonumber`](https://tex.stackexchange.com/questions/17528/show-equation-number-only-once-in-align-environment) right behind these equations. Like the following:\n\n```latex\n$$\\begin{align}\n-4 + 5x &= 2+y \\nonumber  \\\\\n w+2 &= -1+w \\\\\n ab &= cb\n\\end{align}$$\n```\n\nSometimes, you want to use more “exotic” style to refer your equation. You can use `\\tag{}` to achieve this. For example:\n\n```latex\n$$x+1\\over\\sqrt{1-x^2} \\tag{i}\\label{eq_tag}$$\n```\n\nFor more information, you can visit the [official MathJax documentation on equation numbering](https://docs.mathjax.org/en/latest/input/tex/eqnumbers.html). You can also visit this [post](https://theme-next.org/docs/third-party-services/math-equations) for more details.\n\n### Katex\n\nThe Katex engine is a **much faster** math render engine compared to MathJax. And it could survive without JavaScript.\n\nBut, what Katex supports is not as full as MathJax. You could check it from the Useful Links below.\n\nIf you use Katex to render Math Equations, you need to use **only one of those renderer**: [hexo-renderer-markdown-it-plus](https://github.com/CHENXCHEN/hexo-renderer-markdown-it-plus) or [hexo-renderer-markdown-it](https://github.com/hexojs/hexo-renderer-markdown-it).\n\nFirstly, you need to uninstall the original renderer `hexo-renderer-marked`, and **install one of selected above**.\n\n```sh\nnpm uninstall hexo-renderer-marked\nnpm install hexo-renderer-markdown-it-plus\n# or hexo-renderer-markdown-it\n```\n\nSecondly, in `next/_config.yml`, turn on `enable` option of `katex`.\n\n```yml\nmath:\n  ...\n  katex:\n    enable: true\n```\n\nFinally, run the standard Hexo generate, deploy process or start the server:\n\n```sh\nhexo clean && hexo g -d\n# or hexo clean && hexo s\n```\n\n#### If you use hexo-renderer-markdown-it\n\nIf you use `hexo-renderer-markdown-it`，you also need to add `markdown-it-katex` as its plugin：\n\n```\nnpm install markdown-it-katex\n```\n\nAnd then in `hexo/_config.yml` you need to add `markdown-it-katex` as a plugin for `hexo-renderer-markdown-it`:\n\n```yml\n# config of hexo-renderer-markdown-it\nmarkdown:\n  render:\n    html: true\n    xhtmlOut: false\n    breaks: true\n    linkify: true\n    typographer: true\n    quotes: '“”‘’'\n  plugins:\n    - markdown-it-katex\n```\n\n#### Known Bugs\n\n1. Firstly, please check [Common Issues](https://github.com/Khan/KaTeX#common-issues) of Katex.\n2. Displayed Math (i.e. `$$...$$`) needs to started with new clear line.\\\n   In other words: you must not have any characters (except of whitespaces) **before the opening `$$` and after the ending `$$`** ([comment #32](https://github.com/theme-next/hexo-theme-next/pull/32#issuecomment-357489509)).\n3. Don't support Unicode ([comment #32](https://github.com/theme-next/hexo-theme-next/pull/32#issuecomment-357489509)).\n4. Inline Math (..`$...$`) must not have white spaces **after the opening `$` and before the ending `$`** ([comment #32](https://github.com/theme-next/hexo-theme-next/pull/32#issuecomment-357489509)).\n5. If you use math in Heading (i.e. `## Heading`).\\\n   Then in corresponding TOC item it will show the related LaTex code 3 times ([comment #32](https://github.com/theme-next/hexo-theme-next/pull/32#issuecomment-359018694)).\n6. If you use math in your post's title, it will not be rendered ([comment #32](https://github.com/theme-next/hexo-theme-next/pull/32#issuecomment-359142879)).\n\nWe currently use Katex 0.11.1, some of those bugs might be caused by the outdated version of Katex we use.\n\nBut, as what is described in the beginning, the render of Math Equations relies on Hexo Renderer. Currently, Katex-related renderers only support Katex version until 0.11.1.\n\nWe will continuously monitor the updates of corresponding renderers, if there is a renderer which supports newer version of Katex, we will update the Katex we use.\n\n### Useful Links\n\n* [Speed test between Katex and MathJax](https://www.intmath.com/cg5/katex-mathjax-comparison.php)\n* [Function support by Katex](https://khan.github.io/KaTeX/function-support.html)\n\n<h2 align=\"center\">Configuration Specifications</h2>\n\nATTENTION! When you edit those configs, **don't change indentation!**\n\nCurrently, all NexT config use **2 spaces indents**.\n\nIf your content of config is put just directly after the config name, then a space is needed between the colon and the config content (i.e. `enable: true`)\n\n```yml\n# Math Formulas Render Support\nmath:\n  # Default (true) will load mathjax / katex script on demand.\n  # That is it only render those page which has `mathjax: true` in Front-matter.\n  # If you set it to false, it will load mathjax / katex srcipt EVERY PAGE.\n  per_page: true\n\n  # hexo-renderer-pandoc (or hexo-renderer-kramed) required for full MathJax support.\n  mathjax:\n    enable: true\n    # See: https://mhchem.github.io/MathJax-mhchem/\n    mhchem: false\n\n  # hexo-renderer-markdown-it-plus (or hexo-renderer-markdown-it with markdown-it-katex plugin) required for full Katex support.\n  katex:\n    enable: false\n    # See: https://github.com/KaTeX/KaTeX/tree/master/contrib/copy-tex\n    copy_tex: false\n```\n\n### `per_page`\n\n`true` or `false`, default is `true`.\n\nThis option is to control whether to render Math Equations every page.\n\nThe behavior of default (`true`) is to render Math Equations **on demand**.\n\nIt will only render those posts which have `mathjax: true` in their Front-matter.\n\nFor example:\n\n```md\n<!-- This post will render the Math Equations -->\n---\ntitle: 'Will Render Math'\nmathjax: true\n---\n....\n```\n\n```md\n<!-- This post will NOT render the Math Equations -->\n---\ntitle: 'Not Render Math'\nmathjax: false\n---\n....\n```\n\n```md\n<!-- This post will NOT render the Math Equations either -->\n---\ntitle: 'Not Render Math Either'\n---\n....\n```\n\nWhen you set it to `false`, the math will be rendered on **EVERY PAGE**.\n"
  },
  {
    "path": "docs/UPDATE-FROM-5.1.X.md",
    "content": "<h1 align=\"center\">Update from NexT v5.1.x</h1>\n\nNexT version 5 works fine with Hexo 3, but for frequent users, you maybe need to upgrade version 5 to 7 to get features and supports in new [Theme-Next](https://github.com/theme-next/hexo-theme-next) repository.\n\nThere are no hard breaking changes between 5.1.x and the latest version. It's change major version to 7 because:\n\n1. Main repo was rebased from [iissnan's](https://github.com/iissnan/hexo-theme-next) profile to [theme-next](https://github.com/theme-next) organization.\n2. Most libraries under the `next/source/lib` directory was moved out to [external repos under NexT organization](https://github.com/theme-next).\n3. 3rd-party plugin [`hexo-wordcount`](https://github.com/willin/hexo-wordcount) was replaced by [`hexo-symbols-count-time`](https://github.com/theme-next/hexo-symbols-count-time) because `hexo-symbols-count-time` no have any external Node.js dependencies, no have [language filter](https://github.com/willin/hexo-wordcount/issues/7) which causes better performance on speed at site generation.\n\nSo, we suggest to update from version 5 to version 7 in this way:\n\n1. You don't touch old `next` dir and just do some copies of NexT files:\\\n   1.1. `_config.yml` or `next.yml` (if you used [data-files](DATA-FILES.md)).\\\n   1.2. Custom CSS styles what placed in `next/source/css/_custom/*` and `next/source/css/_variables/*` directories.\\\n   1.3. Custom layout styles what placed in `next/layout/_custom/*`.\\\n   1.4. Any another possible custom additions which can be finded by compare tools between repos.\n2. Clone new repo to any another directory instead of `next`. For example, in `next-reloaded` directory: `git clone https://github.com/theme-next/hexo-theme-next themes/next-reloaded`. So, you don't touch your old NexT 5.1.x directory and can work with new `next-reloaded` dir.\n3. Go to Hexo main config and set theme parameter: `theme: next-reloaded`. So, your `next-reloaded` directory must loading with your generation. If you may see any bugs or you simply not like this version, you anytime can switch for 5.1.x version back.\n4. Update language configuration (For Chinese)\n\n    Since v6.0.3, `zh-Hans` has been renamed to `zh-CN`: https://github.com/theme-next/hexo-theme-next/releases/tag/v6.0.3\n\n    Users upgrading to v6.0.3 and later need to explicitly modify the `language` configuration in the Hexo main config file `_config.yml`, otherwise the language display is incorrect.\n5. Update Hexo and Hexo plugin\n\n    If after completing the above steps, an error occurs when executing `hexo s` or` hexo g`, it means that there may be a conflict between the old version of Hexo / Hexo plugin and the new version of the theme NexT. We recommend upgrading Hexo to versions 4.0 and higher and upgrading Hexo plugins to the latest version. You can run `npm outdated` to see all the upgradeable plugins.\n\nAnd how to enable 3rd-party libraries see [here](https://github.com/theme-next/hexo-theme-next/blob/master/docs/INSTALLATION.md#plugins).\n"
  },
  {
    "path": "docs/ru/DATA-FILES.md",
    "content": "<h1 align=\"center\">Дата Файлы</h1>\n\nОбновление темы NexT через пулы проходит не слишком гладко. Часто происходит конфликтная ситуация при обновлении по команде `git pull`, хотя её и можно обойти, если смерджить настройки в файле конфигурации вручную.\n\nНа данный момент, пользователи хранят одни настройки в корневом `_config.yml` (Hexo), а другие настройки в конфиге темы `_config.yml` (NexT). И всё вроде бы ничего, но имеются некоторые недостатки:\n1. Конфигурация разделяется на две части.\n2. Пользователи могут запутаться, в каком файле какие должны быть настройки.\n\nВо избежании проблемы, NexT предлагает два варианта.\n\n<h2 align=\"center\">Способ 1: Hexo-Путь</h2>\n\nИспользуя этот способ, вся конфигурация будет раположена в корневом конфиге hexo (`/_config.yml`), благодаря чему нет необходимости изменять оригинальный конфиг темы (`/themes/next/_config.yml`) или создавать какие-либо новые файлы. Но в этом случае необходимо сохранять двойные отступы внутри `theme_config` параметра.\n\nЕсли в новых версиях появятся какие-то новые настройки, нужно просто скопировать эти настройки из оригинального `next/_config.yml` в редактируемый `/_config.yml` и настроить по своему усмотрению.\n\n### Использование\n\n1. Проверяем на существование `/source/_data/next.yml` файл (удаляем, если существует).\n2. Копируем необходимые опции из конфига темы NexT `/themes/next/_config.yml` в `/_config.yml`, затем\\\n   2.1. Сдвигаем все опции вправо на 2 пробела (в Visual Studio Code: выделяем все строки, <kbd>CTRL</kbd> + <kbd>]</kbd>).\\\n   2.2. Добавляем `theme_config:` параметр перед всеми этими настройками.\n\n### Полезные ссылки\n\n* [Конфигурация Hexo](https://hexo.io/ru/docs/configuration.html)\n* [Hexo Pull #757](https://github.com/hexojs/hexo/pull/757)\n\n<h2 align=\"center\">Способ 2: NexT-Путь</h2>\n\nИспользуя этот способ, вся конфигурация будет храниться в одном файле (`/source/_data/next.yml`), благодаря чему нет необходимости изменять оригинальный конфиг темы (`/themes/next/_config.yml`).\nНо с этим способом могут не корректно обрабатываться все внешние библиотеки hexo при использовании их дополнительных опций (например, опции модуля `hexo-server` могут быть считаны только из стандартного конфига hexo).\n\nЕсли в новых версиях появятся какие-то новые настройки, нужно просто скопировать эти настройки из оригинального `/themes/next/_config.yml` во внешний `_data/next.yml` и настроить по своему усмотрению.\n\nЭтот метод опирается на Hexo [дата-файлов](https://hexo.io/docs/data-files.html). И т.к. дата-файлы были представлены в Hexo 3, необходимо обновиться до Hexo 3.0 (или выше) для использования этой возможности.\n\n### Использование\n\n1. Убеждаемся, что Hexo версии 3 (или выше).\n2. Создаём файл под именем `next.yml` в корневой директории сайта — `/source/_data` (создаём директорию `_data`, если отсутствует).\n\n<p align=\"center\">И после этих шагов есть <b>2 варианта</b>, нужно <b>выбрать только 1</b> из них и <b>продолжить следующие шаги</b>.</p>\n\n* **Вариант 1: `override: false` (по-умолчанию)**:\n\n  1. Проверяем опцию `override` в стандартном конфиге NexT'а, должно быть установлено в `false`.\\\n     В файле `next.yml` эта опция не должна быть вписана вовсе или вписана и установлена в `false`.\n  2. Копируем настройки из конфига темы NexT (`_config.yml`) и из корневого конфига сайта (`_config.yml`) в файл `/source/_data/next.yml`.\n\n* **Вариант 2: `override: true`**:\n\n  1. В файле `next.yml` ставим опцию `override` в `true`.\n  2. Копируем **все** опции из оригинального конфига NexT'а `/themes/next/_config.yml` в `/source/_data/next.yml`.\n\n3. Затем, в корневом конфиге сайта `/_config.yml` необходимо установить опцию `theme: next` (и если требуется, `source_dir: source`).\n4. Используем станадартные параметры для запускаь генерации или развёртывания (`hexo clean && hexo g -d && hexo s`).\n\n### Полезные ссылки\n\n* [NexT Issue #328](https://github.com/iissnan/hexo-theme-next/issues/328)\n"
  },
  {
    "path": "docs/ru/INSTALLATION.md",
    "content": "<h1 align=\"center\">Установка</h1>\n\n<h2 align=\"center\">Шаг 1 &rarr; Идём в директорию Hexo</h2>\n\nМеняем каталог на **корневой hexo**. Там должны находиться `node_modules`, `source`, `themes` и другие папки:\n\n```sh\n$ cd hexo\n$ ls\n_config.yml  node_modules  package.json  public  scaffolds  source  themes\n```\n\n<h2 align=\"center\">Шаг 2 &rarr; Скачиваем NexT</h2>\n\n<p align=\"center\">Скачиваем тему с GitHub.<br>\nИмеются <b>3 способа</b> как зделать это, нужно <b>выбрать только 1</b> из них.</p>\n\n### Способ 1: Скачиваем [последнюю версию релиза][releases-latest-url]\n\n   В большинстве случаев **стабильна**. Рекомендуется для начинающих пользователей.\n\n   * Установка с помощью [curl & tar & wget][curl-tar-wget-url]:\n\n     ```sh\n     $ mkdir themes/next\n     $ curl -s https://api.github.com/repos/theme-next/hexo-theme-next/releases/latest | grep tarball_url | cut -d '\"' -f 4 | wget -i - -O- | tar -zx -C themes/next --strip-components=1\n     ```\n     Этим способом Вы скачаете **только последнюю версию релиза** (без директории `.git` внутри).\\\n     Поэтому, в дальнейшем будет невозможно обновить эту версию через `git`.\\\n     Зато всегда можно использовать отдельную конфигурацию (т.е. [дата-файлы][docs-data-files-url]) и скачивать новую версию перезаписывая старую (или создать новый каталог и переопределить параметр `theme` в конфиге Hexo), без потери старой конфигурации.\n\n### Способ 2: Скачиваем [указанную версию релиза][releases-url]\n\n   В редких случаях полезно, но не рекомендуется.\\\n   Необходимо указать версию. Замените `v6.0.0` на любую версию из [списка тэгов][tags-url].\n\n   * Вариант 1: Установка с помощью [curl & tar][curl-tar-url]:\n\n     ```sh\n     $ mkdir themes/next\n     $ curl -L https://api.github.com/repos/theme-next/hexo-theme-next/tarball/v6.0.0 | tar -zxv -C themes/next --strip-components=1\n     ```\n     То же, что и описано выше в способе `curl & tar & wget`, но скачает **только конкретную версию**.\n\n   * Вариант 2: Установка с помощью [git][git-url]:\n\n     ```sh\n     $ git clone --branch v6.0.0 https://github.com/theme-next/hexo-theme-next themes/next\n     ```\n     Этот вариант скачает **указанную версию релиза** (включая директорию `.git` внутри).\\\n     И в любой момент Вы можете переключиться на любую весию тэга, но с лимитом до указанной версии.\n\n### Способ 3: Скачиваем [последнюю мастер-ветку][download-latest-url]\n\n   Иногда может быть **нестабильна**, но включает самые последние нововведения. Рекомендуется для продвинутых пользователей и для разработчиков.\n\n   * Вариант 1: Установка с помощью [curl & tar][curl-tar-url]:\n\n     ```sh\n     $ mkdir themes/next\n     $ curl -L https://api.github.com/repos/theme-next/hexo-theme-next/tarball | tar -zxv -C themes/next --strip-components=1\n     ```\n     То же, что и описано выше в варианте `curl & tar & wget`, но скачает **только последнюю мастер-ветку**.\\\n     В некоторых случаях полезно для разработчиков.\n\n   * Вариант 2: Установка с помощью [git][git-url]:\n\n     ```sh\n     $ git clone https://github.com/theme-next/hexo-theme-next themes/next\n     ```\n\n     Этот вариант скачает **весь репозиторий** (включая директорию `.git` внутри).\\\n     И в любой момент Вы можете [обновить текущую версию через git][update-with-git-url] и переключиться на любую версию тэга или на последнюю мастер или любую другую ветку.\\\n     В большинстве случаев полезно как для пользователей, так и для разработчиков.\n\n     Смотрим список тэгов:\n\n     ```sh\n     $ cd themes/next\n     $ git tag -l\n     …\n     v6.0.0\n     v6.0.1\n     v6.0.2\n     ```\n\n     Например, Вы хотите переключиться на [версию релиза][tags-url] `v6.0.1`. Вводим следующую команду:\n\n     ```sh\n     $ git checkout tags/v6.0.1\n     Note: checking out 'tags/v6.0.1'.\n     …\n     HEAD is now at da9cdd2... Release v6.0.1\n     ```\n\n     И если вы хотите переключиться обратно на [мастер-ветку][commits-url], вводим следующее:\n\n     ```sh\n     $ git checkout master\n     ```\n\n<h2 align=\"center\">Шаг 3 &rarr; Конфигурируем</h2>\n\nУстанавливаем параметр темы в конфиге `_config.yml` **корневой директории hexo**:\n\n```yml\ntheme: next\n```\n\n[download-latest-url]: https://github.com/theme-next/hexo-theme-next/archive/master.zip\n[releases-latest-url]: https://github.com/theme-next/hexo-theme-next/releases/latest\n[releases-url]: https://github.com/theme-next/hexo-theme-next/releases\n[tags-url]: https://github.com/theme-next/hexo-theme-next/tags\n[commits-url]: https://github.com/theme-next/hexo-theme-next/commits/master\n\n[git-url]: http://lmgtfy.com/?q=linux+git+install\n[curl-tar-url]: http://lmgtfy.com/?q=linux+curl+tar+install\n[curl-tar-wget-url]: http://lmgtfy.com/?q=linux+curl+tar+wget+install\n\n[update-with-git-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/ru/README.md#%D0%A3%D1%81%D1%82%D0%B0%D0%BD%D0%BE%D0%B2%D0%BA%D0%B0\n[docs-data-files-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/ru/DATA-FILES.md\n"
  },
  {
    "path": "docs/ru/README.md",
    "content": "<div align=\"right\">\n  Язык:\n  <a title=\"Английский\" href=\"../../README.md\">🇺🇸</a>\n  <a title=\"Китайский\" href=\"../zh-CN/README.md\">🇨🇳</a>\n  🇷🇺\n</div>\n\n# <div align=\"center\"><a title=\"Репозиторий сайта NexT\" href=\"https://github.com/theme-next/theme-next.org\"><img align=\"center\" width=\"56\" height=\"56\" src=\"https://raw.githubusercontent.com/theme-next/hexo-theme-next/master/source/images/logo.svg?sanitize=true\"></a> e x T</div>\n\n<p align=\"center\">\n  «NexT» — элегантная высококачественная тема под <a href=\"https://hexo.io\">Hexo</a>. Сделана с нуля, с любовью.\n<br>\n<br>\n  <a href=\"https://www.npmjs.com/package/hexo-theme-next\"><img src=\"https://img.shields.io/github/package-json/v/theme-next/hexo-theme-next?style=flat-square\"></a>\n  <a href=\"https://nodejs.org\"><img src=\"https://img.shields.io/badge/node-%3E=10.9.0-green?style=flat-square\"></a>\n  <a href=\"https://hexo.io\"><img src=\"https://img.shields.io/badge/hexo-%3E=4.0.0-blue?style=flat-square&logo=hexo\"></a>\n  <a href=\"https://github.com/theme-next/hexo-theme-next/blob/master/LICENSE.md\"><img src=\"https://img.shields.io/badge/license-%20AGPL-orange?style=flat-square&logo=gnu\"></a>\n<br>\n  <a href=\"https://bestpractices.coreinfrastructure.org/projects/2625\"><img src=\"https://img.shields.io/cii/level/2625?style=flat-square\" title=\"Инициатива базовой инфраструктуры: передовой опыт\"></a>\n  <a href=\"https://travis-ci.org/theme-next/hexo-theme-next?branch=master\"><img src=\"https://img.shields.io/travis/theme-next/hexo-theme-next/master?style=flat-square&logo=travis%20ci\" title=\"Travis CI [Linux]\"></a>\n  <a href=\"https://app.codacy.com/manual/theme-next/hexo-theme-next/dashboard\"><img src=\"https://img.shields.io/codacy/grade/72f7fe7609c2438a92069f448e5a341a/master?style=flat-square&logo=codacy\" title=\"Оценка проекта\"></a>\n  <img src=\"https://img.shields.io/snyk/vulnerabilities/github/theme-next/hexo-theme-next?style=flat-square\" title=\"Vulnerabilities\">\n<br>\n  <img src=\"https://user-images.githubusercontent.com/16272760/63487983-da41b080-c4df-11e9-951c-64883a8a5e9b.png\">\n</p>\n\n## Демо\n\n<p align=\"center\">\n  💟 <a href=\"https://muse.theme-next.org\">Muse</a> | 🔯 <a href=\"https://mist.theme-next.org\">Mist</a> | ♓️ <a href=\"https://pisces.theme-next.org\">Pisces</a> | ♊️ <a href=\"https://theme-next.org\">Gemini</a>\n<br>\n<br>\n  Больше примеров «NexT» <a href=\"https://github.com/theme-next/awesome-next#live-preview\">здесь</a>.\n</p>\n\n## Установка\n\nПростейший вариант установки — склонировать весь репозиторий:\n\n```sh\n$ cd hexo\n$ git clone https://github.com/theme-next/hexo-theme-next themes/next\n```\n\nИли предлагаю почитать [детальные инструкции по установке][docs-installation-url], если вариант выше не устраивает.\n\n## Плагины\n\nВ конфиге NexT'а теперь можно найти зависимости на каждый модуль, который был вынесен во внешние репозитории, которые могут быть найдены по [ссылке основной организации][official-plugins-url].\n\nНапример, Вы хотите использовать `pjax` для своего сайта. Открываем конфиг NexT'а и находим:\n\n```yml\n# Easily enable fast Ajax navigation on your website.\n# Dependencies: https://github.com/theme-next/theme-next-pjax\npjax: true\n```\n\nЗатем включаем параметр `pjax` и переходим по ссылке «Dependencies» с дальнейшеми инструкциями по установке этого модуля.\n\n## Обновление\n\nNexT выпускает новые версии каждый месяц. Можно обновить до последней мастер-ветки следующей командой:\n\n```sh\n$ cd themes/next\n$ git pull\n```\n\nА если всплывают ошибки во время обновления (что-то наподобии **«Commit your changes or stash them before you can merge»**), рекомендуется ознакомиться с особенностью хранения [дата-файлов в Hexo][docs-data-files-url].\\\nКак бы то ни было, можно обойти ошибки при обновлении если «Закомитить», «Стэшнуть» или «Откатить» локальные изменения. Смотрим  [здесь](https://stackoverflow.com/a/15745424/5861495) как это сделать.\n\n**Если нужно обновиться с версии v5.1.x на последней версиями, читаем [здесь][docs-update-5-1-x-url].**\n\n## Обратная связь\n\n* Посетите [Awesome NexT][awesome-next-url] список.\n* Вступить в наши [Telegram][t-chat-url] / [Gitter][gitter-url] / [Riot][riot-url] чаты.\n* [Добавить или улучшить перевод][i18n-url] за несколько секунд.\n* Сообщить об ошибке в разделе [GitHub Issues][issues-bug-url].\n* Запросить новую возможность на [GitHub][issues-feat-url].\n* Голосовать за [популярные запросы возможностей][feat-req-vote-url].\n\n## Содействие\n\n[![][contributors-image]][contributors-url]\n\nПриветсвуется любое содействие, не стесняйтесь сообщать «Баги», брать «Форки» и вливать «Пулы».\n\n## Благодарности\n\n<p align=\"center\">\n  «NexT» выражает особую благодарность этим замечательным сервисам, которые спонсируют нашу основную инфраструктуру:\n<br>\n<br>\n  <a href=\"https://github.com\"><img align=\"center\" width=\"100\" src=\"https://github.githubassets.com/images/modules/logos_page/GitHub-Logo.png\"></a>\n  &nbsp;&nbsp;&nbsp;\n  <a href=\"https://www.netlify.com\"><img align=\"center\" width=\"150\" src=\"https://cdn.netlify.com/15ecf59b59c9d04b88097c6b5d2c7e8a7d1302d0/1b6d6/img/press/logos/full-logo-light.svg\"></a>\n<br>\n  <sub>GitHub позволяет нам хостить Git-репозиторий, Netlify позволяет нам деплоить документацию.</sub>\n<br>\n<br>\n  <a href=\"https://crowdin.com\"><img align=\"center\" width=\"180\" src=\"https://support.crowdin.com/assets/logos/crowdin-logo1-small.png\"></a>\n<br>\n  <sub>Crowdin позволяет нам удобно переводить документацию.</sub>\n<br>\n<br>\n  <a href=\"https://codacy.com\"><img align=\"center\" width=\"155\" src=\"https://user-images.githubusercontent.com/16944225/55026017-623f8f00-5002-11e9-88bf-0d6a5884c6c2.png\"></a>\n  &nbsp;&nbsp;&nbsp;\n  <a href=\"https://travis-ci.com\"><img align=\"center\" width=\"140\" src=\"https://raw.githubusercontent.com/travis-ci/travis-web/master/public/images/logos/TravisCI-Full-Color.png\"></a>\n<br>\n  <sub>Codacy позволяет нам контролировать качество кода, Travis CI позволяет нам запускать набор тестов.</sub>\n</p>\n\n[docs-installation-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/ru/INSTALLATION.md\n[docs-data-files-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/ru/DATA-FILES.md\n[docs-update-5-1-x-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/ru/UPDATE-FROM-5.1.X.md\n\n[t-news-url]: https://t.me/theme_next_news\n[t-chat-url]: https://t.me/theme_next\n[gitter-url]: https://gitter.im/theme-next\n[riot-url]: https://riot.im/app/#/room/#theme-next:matrix.org\n[i18n-url]: https://i18n.theme-next.org\n\n[awesome-next-url]: https://github.com/theme-next/awesome-next\n[issues-bug-url]: https://github.com/theme-next/hexo-theme-next/issues/new?assignees=&labels=Bug&template=bug-report.md\n[issues-feat-url]: https://github.com/theme-next/hexo-theme-next/issues/new?assignees=&labels=Feature+Request&template=feature-request.md\n[feat-req-vote-url]: https://github.com/theme-next/hexo-theme-next/issues?q=is%3Aopen+is%3Aissue+label%3A%22Feature+Request%22\n\n[contributing-document-url]: https://github.com/theme-next/hexo-theme-next/blob/master/.github/CONTRIBUTING.md\n[official-plugins-url]: https://github.com/theme-next\n[contributors-image]: https://opencollective.com/theme-next/contributors.svg?width=890\n[contributors-url]: https://github.com/theme-next/hexo-theme-next/graphs/contributors\n"
  },
  {
    "path": "docs/ru/UPDATE-FROM-5.1.X.md",
    "content": "<h1 align=\"center\">Обновление из-под NexT v5.1.x</h1>\n\nМежду версией 5.1.x и последней версиями нет жёстких изменений. Версия сменилась на мажорную 7 по следующим причинам:\n1. Основной репозиторий перебазировался из профиля [iissnan'а](https://github.com/iissnan/hexo-theme-next) в [theme-next](https://github.com/theme-next) организацию.\n2. Большинство библиотек в `next/source/lib` директории были вынесены в [отдельные репозитории под организацией NexT](https://github.com/theme-next).\n3. 3rd-party плагин [`hexo-wordcount`](https://github.com/willin/hexo-wordcount) был заменён на [`hexo-symbols-count-time`](https://github.com/theme-next/hexo-symbols-count-time) т.к. `hexo-symbols-count-time` не имеет никаких сторонних Node.js зависимостей, не имеет [языкового фильтра](https://github.com/willin/hexo-wordcount/issues/7) что обеспечивает улучшенную производительность при генерации сайта.\n\nПоэтому, я предлагаю обновиться с версии 5 на версию 7 следующим способом:\n\n1. Вы не трогаете старую директорию `next`, а всего-лишь делаете резервные копии файлов NexT:\\\n   1.1. `config.yml` или `next.yml` (если Вы использовали [дата-файлы](DATA-FILES.md)).\\\n   1.2. Пользовательских CSS-стилей, которые расположены в `next/source/css/_custom/*` и `next/source/css/_variables/*` директориях.\\\n   1.3. Пользовательских layout-стилей, которые расположены в `next/layout/_custom/*`.\\\n   1.4. Любые другие всевозможные пользовательские изменения, которые могут быть найдены любым инструментом для сравнения файлов.\n2. Склонировать новый репозиторий в любую другую директорию, отличную от `next`. Например, в директорию `next-reloaded`: `git clone https://github.com/theme-next/hexo-theme-next themes/next-reloaded`. Итак, нет необходимости трогать старую NexT 5.1.x директорию и можно работать с новой `next-reloaded`.\n3. Открываем главную Hexo-конфигурацию и устанавливаем параметр темы: `theme: next-reloaded`. Так Ваша директория `next-reloaded` должна грузиться при генерации. Если Вы будете наблюдать какие-либо баги или Вам попросту не нравится эта новая версия, в любой момент Вы можете использовать старую 5.1.x.\n\nА как активировать 3rd-party библиотеки, смотрим здесь [здесь](https://github.com/theme-next/hexo-theme-next/blob/master/docs/ru/INSTALLATION.md#%D0%9F%D0%BB%D0%B0%D0%B3%D0%B8%D0%BD%D1%8B).\n"
  },
  {
    "path": "docs/zh-CN/ALGOLIA-SEARCH.md",
    "content": "<h1 align=\"center\">Algolia 搜索</h1>\n\nNexT 内部提供 Algolia 的搜索功能，要使用此功能请确保所使用的 NexT 版本在 `v5.1.0` 之后。需要注意的是，仅仅将 `next/_config.yml` 中 `algolia_search` 的 `enable` 打开**并不能让你使用 Algolia 搜索**，你还需要**使用对应的 Hexo-Algolia 插件** 才能真正在博客页面中使用 Algolia 搜索。按照下面介绍的步骤操作即可完成 Algolia 搜索的安装。\n\n1. 前往 [Algolia 注册页面](https://www.algolia.com/)，注册一个新账户。 可以使用 GitHub 或者 Google 账户直接登录，注册后的 14 天内拥有所有功能（包括收费类别的）。之后若未续费会自动降级为免费账户，免费账户 总共有 10,000 条记录，每月有 100,000 的可以操作数。注册完成后，创建一个新的 Index，这个 Index 将在后面使用。\n\n    ![](https://user-images.githubusercontent.com/16272760/73673892-68a29b00-46ea-11ea-90c5-916b4b11fc7a.png)\n\n1. 在 `API Keys` 页面找到需要使用的一些配置的值，包括 `Application ID` 和 `Search-Only API Key`。注意，`Admin API Key` 需要保密保存，不要外泄。\n\n    ![](https://user-images.githubusercontent.com/16272760/73673895-693b3180-46ea-11ea-8f50-8bae850b50d0.png)\n\n1. 编辑 `站点配置文件`，新增以下配置，除了 `chunkSize` 字段，替换成在 Algolia 获取到的值：\n\n    ```yml\n    algolia:\n      applicationID: 'Application ID'\n      apiKey: 'Search-Only API Key'\n      indexName: 'indexName'\n      chunkSize: 5000\n    ```\n\n1. 在 `API Keys` 页面，点击 `All API Keys` 切换到对应的页面中。接着点击 `New API Key` 按钮，来**编辑权限**。在弹出框中找到 ACL ，**输入 addObject、 deleteObject、listIndexes、deleteIndex 权限**，然后点击最下方的 `Create` 按钮。将这个新创建的 API Key 复制到剪贴板，我们称之为 `High-privilege API key`。\n\n    ![](https://user-images.githubusercontent.com/16272760/73673902-6b04f500-46ea-11ea-9c80-4e5c5002e07b.png)\n    ![](https://user-images.githubusercontent.com/16272760/73673905-6b9d8b80-46ea-11ea-9e01-702ec2a8a297.png)\n\n1. 在 Index 和 API Key 创建完成后，此时这个 Index 里未包含任何数据。接下来需要安装 [Hexo Algolia](https://github.com/oncletom/hexo-algolia) 扩展，这个扩展的功能是搜集站点的内容并通过 API 发送给 Algolia。前往站点根目录，执行命令安装：\n\n    ```\n    $ cd hexo\n    $ npm install hexo-algolia\n    ```\n\n1. 当配置完成，在站点根目录下执行以下命令来更新上传 Index。请注意观察命令的输出。\n\n    ```\n    $ export HEXO_ALGOLIA_INDEXING_KEY=High-privilege API key # 使用 Git Bash\n    # set HEXO_ALGOLIA_INDEXING_KEY=High-privilege API key # 使用 Windows CMD 命令行\n    $ hexo clean\n    $ hexo algolia\n    ```\n\n    ![](http://theme-next.iissnan.com/uploads/algolia/algolia-step-4.png)\n\n1. 更改`主题配置文件`，找到 Algolia Search 配置部分，将 `enable` 改为 `true`。同时你需要**关闭**其他搜索插件，如 Local Search 等。你也可以根据需要调整 `labels` 中的文本：\n\n    ```yml\n    # Algolia Search\n    algolia_search:\n      enable: true\n      hits:\n        per_page: 10\n      labels:\n        input_placeholder: Search for Posts\n        hits_empty: \"We didn't find any results for the search: ${query}\"\n        hits_stats: \"${hits} results found in ${time} ms\"\n    ```\n\n1. 如果你需要通过 CDN 使用其它版本的 algolia-instant-search ，请根据以下步骤操作。\n\n    你需要在`主题配置文件`中的 vendors 字段进行设置：\n\n    ```yml\n    vendors:\n      ...\n      # Algolia Search\n      # algolia_search: //cdn.jsdelivr.net/npm/algoliasearch@4/dist/algoliasearch-lite.umd.js\n      # instant_search: //cdn.jsdelivr.net/npm/instantsearch.js@4/dist/instantsearch.production.min.js\n      algolia_search: //cdn.jsdelivr.net/npm/algoliasearch@4/dist/algoliasearch-lite.umd.js\n      instant_search: //cdn.jsdelivr.net/npm/instantsearch.js@4/dist/instantsearch.production.min.js\n      ...\n    ```\n\n<h2 align=\"center\">已知的问题</h2>\n\n1. 考虑到 Algolia 免费账户的限制，目前 [Hexo-Algolia](https://github.com/oncletom/hexo-algolia) 插件最新版本去掉了正文索引功能。\n1. [Hexo-Algoliasearch](https://github.com/LouisBarranqueiro/hexo-algoliasearch) 插件提供了正文索引功能，不过需要替换 NEXT 主题中的关键字。对于免费账户，`Record Too Big` 的问题同样存在。\n    - 替换 `source/js/algolia-search.js` 中所有的 `applicationID` 为 `appId`\n    - 替换 `layout/_partials/head/head.swig` 中所有的 `applicationID` 为 `appId`\n"
  },
  {
    "path": "docs/zh-CN/CODE_OF_CONDUCT.md",
    "content": "<div align=\"right\">\n  语言：\n  <a title=\"英语\" href=\"../../.github/CODE_OF_CONDUCT.md\">:us:</a>\n  :cn:\n  <a title=\"俄语\" href=\"../ru/CODE_OF_CONDUCT.md\">:ru:</a>\n</div>\n\n# <div align=\"center\"><a title=\"Go to homepage\" href=\"https://theme-next.org\"><img align=\"center\" width=\"56\" height=\"56\" src=\"https://raw.githubusercontent.com/theme-next/hexo-theme-next/master/source/images/logo.svg?sanitize=true\"></a> e x T</div>\n\n[NexT](https://theme-next.org) 是一个优雅而强大的 [Hexo](https://hexo.io/)主题。在这里，您可以构建一个托管在 [GitHub Pages](https://pages.github.com/) 上的静态博客，分享您的生活，并与新朋友进行交流。\n\n参与者公约用来约束在 [NexT](https://github.com/theme-next/hexo-theme-next) 社区中代码更新、问题交流、请求合并等行为。我们期望所有用户相互尊重，礼貌待人。任何违反这些规则的人都将不会被审核，并会在发现后立即被阻止和驱逐。\n\n## 目录\n\n- [我们的保证](#我们的保证)\n- [我们的责任](#我们的责任)\n- [我们的标准](#我们的标准)\n- [使用范围](#使用范围)\n- [强制执行](#强制执行)\n- [联系项目维护者](#联系项目维护者)\n- [来源](#来源)\n\n## 我们的保证\n\n作为此项目的贡献者和维护者，我们承诺尊重所有做出贡献的用户，这些贡献包括了报告问题、发布功能请求、更新文档、提交合并请求以及其他活动。\n\n为了促进一个开放透明且友好的环境，我们作为贡献者和维护者保证：无论年龄、种族、民族、性别认同和表达（方式）、体型、身体健全与否、经验水平、国籍、个人表现、宗教或性别取向，参与者在我们项目和社区中都免于骚扰。\n\n## 我们的责任\n\n项目维护者有责任为「可接受的行为」标准做出诠释，有权利及责任去删除、编辑、拒绝与本行为标准有所违背的评论（comments）、提交（commits）、代码、wiki 编辑、问题（issues）和其他贡献，以及项目维护者可暂时或永久性的禁止任何他们认为有不适当、威胁、冒犯、有害行为的贡献者。\n\n## 我们的标准\n\n作为 GitHub 上的一个项目，本项目受到 [GitHub 社区准则](https://help.github.com/articles/github-community-guidelines/)的约束。 此外，作为 npm 托管的项目，[npm 公司的行为准则](https://www.npmjs.com/policies/conduct)也涵盖了本项目。\n\n有助于创造正面环境的行为包括但不限于：\n\n* 使用友好和包容性语言\n* 尊重不同的观点和经历\n* 耐心地接受建设性批评\n* 关注对社区最有利的事情\n* 友善对待其他社区成员\n\n身为参与者不能接受的行为包括但不限于：\n\n* 使用与性有关的言语或是图像，以及不受欢迎的性骚扰\n* 捣乱/煽动/造谣的行为或进行侮辱/贬损的评论，人身攻击及政治攻击\n* 公开或私下的骚扰\n* 未经许可地发布他人的个人资料，例如住址或是电子地址\n* 其他可以被合理地认定为不恰当或者违反职业操守的行为\n\n## 使用范围\n\n当一个人代表该项目或是其社区时，本行为标准适用于其项目社区和公共社区。\n\n根据某人在本社区范围以外发生的违规情况，项目维护者可以认为其不受欢迎，并采取适当措施来保证所有成员的安全性和舒适性。\n\n## 强制执行\n\n如果您看到违反行为准则的行为，请按以下步骤操作：\n\n1. 让这个人知道他所做的并不合适，并要求他停止或编辑他们的提交信息。该人应立即停止行为并纠正问题。\n2. 如果该人没有纠正其行为，或者您不方便与其沟通，请[联系项目维护者](#联系项目维护者)。上报时，请尽可能多的提供详细信息，链接，截图，上下文或可用于更好地理解和解决情况的其他信息。\n3. 收到上报信息后，项目维护者会查看问题，并采取进一步的措施。\n\n一旦项目维护者参与其中，他们将遵循以下一系列步骤，并尽力保护项目成员的利益。任何维护团队认为有必要且适合的所有投诉都将进行审查及调查，并做出相对应的回应。项目小组有对事件回报者有保密的义务。具体执行的方针近一步细节可能会单独公布。\n\n以下是项目维护者根据需要采取的进一步执法步骤：\n\n1. 再次要求停止违规行为。\n2. 如果违规者还是没有回应，将会受到正式的警告，并收到项目维护者的移除或修改消息。同时，相关的问题或合并请求将会被锁定。\n3. 如果警告后违规行为继续出现，违规者将会被禁言 24 小时。\n4. 如果禁言后违规行为继续出现，违规者将会被处罚长期（6-12个月）禁言。\n\n除此之外，项目维护者可以根据需要删除任何违规的消息，图片，贡献等。如果违规行为被认为是对社区成员的严重或直接威胁，包括任何置社区成员于风险的威胁、身体或言语攻击，项目维护者有充分权利自行决定跳过上述任何步骤。\n\n没有切实地遵守或是执行本行为标准的项目维护人员，可能会因项目领导人或是其他成员的决定，暂时或是永久地取消其参与资格。\n\n## 联系项目维护者\n\n您可以通过以下任何方法与维护人员联系\n\n* 电子邮件:\n    * [support@theme-next.org](mailto:support@theme-next.org)\n\n* 即时通信:\n    * [Gitter](https://gitter.im/theme-next)\n    * [Riot](https://riot.im/app/#/room/#NexT:matrix.org)\n    * [Telegram](https://t.me/joinchat/GUNHXA-vZkgSMuimL1VmMw)\n\n## 来源\n\n本行为标准改编自[Contributor Covenant](https://www.contributor-covenant.org/) 和 [WeAllJS Code of Conduct](https://wealljs.org/code-of-conduct)。\n"
  },
  {
    "path": "docs/zh-CN/CONTRIBUTING.md",
    "content": "<div align=\"right\">\n  语言：\n  <a title=\"英语\" href=\"../../.github/CONTRIBUTING.md\">:us:</a>\n  :cn:\n  <a title=\"俄语\" href=\"../ru/CONTRIBUTING.md\">:ru:</a>\n</div>\n\n# <div align=\"center\"><a title=\"Go to homepage\" href=\"https://theme-next.org\"><img align=\"center\" width=\"56\" height=\"56\" src=\"https://raw.githubusercontent.com/theme-next/hexo-theme-next/master/source/images/logo.svg?sanitize=true\"></a> e x T</div>\n\n首先，非常感谢大家抽出宝贵时间来让我们的 NexT 主题越变越好。在这里，我们介绍一下 [NexT 主题及其子模块](https://github.com/theme-next) 的开源贡献指南。不过，我们希望大家不要局限于此，更欢迎大家随时进行补充。\n\n## 目录\n\n[如何为 NexT 做贡献](#如何为-next-做贡献)\n\n  * [你需要了解的](#你需要了解的)\n    * [阅读文档](#阅读文档)\n    * [快速调试指南](#快速调试指南)\n  * [反馈 Bug](#反馈-bug)\n    * [提交漏洞](#提交漏洞)\n  * [提交功能需求](#提交功能需求)\n  * [提交合并请求](#提交合并请求)\n  * [发布版本](#发布版本)\n\n[规范](#规范)\n\n  * [行为规范](#行为规范)\n  * [编码规范](#编码规范)\n  * [标签规范](#标签规范)\n  * [提交信息规范](#提交信息规范)\n\n## 如何为 NexT 做贡献\n\n### 你需要了解的\n\n#### 阅读文档\n\n如果你在使用过程中遇到了问题，你可以查阅 [FAQs](https://theme-next.org/docs/faqs) 或者 [NexT 帮助文档](https://theme-next.org/docs/troubleshooting)。\n\n另外，你也可以通过 [这里](https://github.com/theme-next/hexo-theme-next/search?q=&type=Issues&utf8=%E2%9C%93) 进行大致检索，有些问题已经得到解答，你可以自行解决。对于没有解决的 Issue，你也可以继续提问。\n\n#### 快速调试指南\n\n在 GitHub 上提交 Issue 前，请先通过以下方法 debug：\n\n* 执行`hexo clean`，清除浏览器缓存，并禁用 CDN 服务（例如 Cloudflare Rocket Loader）；\n* 切换到其它主题并检查 bug 是否仍然存在（例如使用默认主题 landscape）。换言之，证明这是 NexT 主题而非来自 Hexo 的 bug；\n* 将 NexT 主题升级到最新版；\n* 将 Hexo 和 Hexo 插件升级到最新版；\n* 将 Node.js 和 `npm` 升级到最新版；\n* 卸载不必要的 Hexo 插件，或重新通过 `npm install --save` 安装插件。\n\n如果你得到了来自 Hexo 或浏览器控制台的报错信息，请在 Google / Stackoverflow / GitHub Issue 中搜寻，或在提交 Issue 时报告给我们。\n\n如果你在使用过程中发现了 Bug，请再次确认 Bug 在 [最新发布版本](https://github.com/theme-next/hexo-theme-next/releases/latest) 中是否重现。如果 Bug 重现，欢迎你到我们的 [主题仓库](https://github.com/theme-next/hexo-theme-next) 中 [反馈 Bug](#reporting-bugs) 或者 [提交功能需求](#提交功能需求)，也更期待您 [提交合并请求](#提交合并请求)。\n\n### 反馈 Bug\n\n反馈 Bug 前，请再次确认您已经查看了 [你需要了解的](#你需要了解的) 内容，避免提交重复的 Issue。确定相关仓库后，创建 Issue 并按照 [模板](../../.github/ISSUE_TEMPLATE.md) 尽可能的详细填写相关信息。\n\n请认真遵守如下指南，这样我们才能更好地理解问题，重现问题和解决问题。\n\n* 在标题中清晰准确地描述你的问题。\n* 参照如下问题尽可能多的提供信息：\n    * Bug 是否能够重现？是一直出现还是偶尔出现？\n    * Bug 是从什么时候开始发生的？\n    * 如果 Bug 突然发生，使用 [旧版本主题](https://github.com/theme-next/hexo-theme-next/releases) 是否能够重现 Bug？又是从哪个版本开始出现 Bug？\n    * 你所使用 Node，Hexo 以及 Next 的版本号多少？你可以运行 `node -v` 和 `hexo version` 获取版本号，或者查看文件 `package.json` 的内容。\n    * 你使用了哪些插件包？查看文件 `package.json` 的内容即可获取。\n* 一步步详细你是如何重现 Bug 的，做了什么，使用了哪些功能等等。如果你需要展示代码段，请使用 [Markdown 代码块](https://help.github.com/articles/creating-and-highlighting-code-blocks/) 或 [Github 预览链接](https://help.github.com/articles/creating-a-permanent-link-to-a-code-snippet/) 或 [Gist 链接](https://gist.github.com/)。\n* 提供 Bug 的样例，如图像文件、在线演示网址等等。\n* 详细描述通过上述重现过程出现的问题。\n* 详细描述你期待的结果。\n\n#### 提交漏洞\n\n如果你发现安全问题，请以负责任的方式行事，即不要在公共 Issue 中提交而是直接向我们反馈，这样我们就可以在漏洞被利用之前对其进行修复。请将相关信息发送到 security@theme-next.com（可接受 PGP 加密邮件）。\n\n我们很乐意对任何提交漏洞的人予以特别感谢以便我们修复它。如果你想保持匿名性或使用笔名替代，请告诉我们。我们将充分尊重你的意愿。\n\n### 提交功能需求\n\n提交功能需求前，请再次确认您已经查看了 [你需要了解的](#你需要了解的) 内容，避免提交重复的 Issue。确定相关仓库后，创建 Issue 并按照 [模板](../../.github/ISSUE_TEMPLATE.md) 尽可能的详细填写相关信息。\n\n请认真遵守如下指南，这样我们才能更好地理解和开发功能需求:pencil:：\n\n* 在标题中清晰准确地描述你的功能需求。\n* 详细描述目前所具有的功能和你所期待的功能，并解释为什么需要该功能。\n* 提供功能需求的样例，如图像文件、在线演示网址等等。\n\n### 提交合并请求\n\n提交合并请求前，请再次确认您已经查看了 [你需要了解的](#你需要了解的) 内容，避免提交重复的合并请求。确定相关仓库后，创建合并请求。更多详细操作过程可以查看 [帮助文档](https://help.github.com/articles/creating-a-pull-request/)。\n\n请认真遵守如下指南，这样我们才能更好地理解你的合并请求：\n\n* 创建合并请求时，请遵守 [编码规范](#编码规范) 和 [提交信息规范](#提交信息规范)。\n* 在标题中清晰准确地描述你的合并请求，不要加入 Issue 编号。\n* 按照 [模板](../../.github/PULL_REQUEST_TEMPLATE.md) 尽可能的详细填写相关信息。\n* 合并请求需要在所有主题样式中测试通过，并提供所表现功能的样例，如图像文件、在线演示网址等等。\n\n### 发布版本\n\n版本发布是将项目发布给用户的一种很好的方式。\n\n1. 进入 GitHub 项目主页，点击 **Releases** 和 **Draft a new release**。\n2. 输入你需要发布的版本号。版本控制是基于 [Git tags](https://git-scm.com/book/en/Git-Basics-Tagging) 工作的，建议按照 [About Major and Minor NexT versions](https://github.com/theme-next/hexo-theme-next/issues/187) 确定版本号。\n3. 确定你需要发布的分支。除非发布测试版本，通常情况下选择 `master` 分支。\n4. 输入发布版本的标题和说明。\n    - 标题为版本号。\n    - 所有内容更改的类型包括了 **Breaking Changes**, **Updates**, **Features** 和 **Bug Fixes**。在描述 Breaking Changes 时，使用二级标题分别陈述，描述其他类型时，使用项目列表陈述。\n    - 使用被动语态，省略主语。\n    - 所有的变化都需要记录在版本说明中。对于没有使用 PR 的更改，需要添加相应的 commit 编号。如果使用了 PR 进行合并修改，则直接添加相应的 PR 编号即可。\n5. 如果您希望随版本一起发布二进制文件（如编译的程序），请在上传二进制文件对话框中手动拖放或选择文件。\n6. 如果版本不稳定，请选择 **This is a pre-release**，以通知用户它尚未完全准备好。如果您准备公布您的版本，请点击 **Publish release**。否则，请单击 **Save draft** 以稍后处理。\n\n## 规范\n\n### 行为规范\n\n为了保证本项目的顺利运作，所有参与人都需要遵守 [行为规范](CODE_OF_CONDUCT.md)。\n\n### 编码规范\n\n我们使用 ESLint 和 Stylint 来识别和报告 JavaScript 和 Stylus 中的模式，目的是使代码更加一致并避免错误。编码时应遵循这些规范。\n\n### 标签规范\n\n为了方便维护人员和用户能够快速找到他们想要查看的问题，我们使用“标签”功能对 Pull requests 和 Issues 进行分类。\n\n如果您不确定某个标签的含义，或者不知道将哪些标签应用于 PR 或 issue，千万别错过这个。\n\nIssue 的标签：\n\n- 类型\n    - `Bug`: 检测到需要进行确认的 Bug\n    - `Feature Request`: 提出了新功能请求的 Issue\n    - `Question`: 提出疑问的 Issue\n    - `Meta`: 表明使用条款变更的 Issue\n    - `Support`: 被标记为支持请求的 Issue\n    - `Polls`: 发起投票的 Issue\n- 结果\n    - `Duplicate`: 重复提及的 Issue\n    - `Irrelevant`: 与 NexT 主题无关的 Issue\n    - `Invalid`: 无法复现的 Issue\n    - `Expected Behavior`: 与预期行为相符的 Issue\n    - `Need More Info`: 需要更多信息的 Issue\n    - `Verified`: 已经被确认的 Issue\n    - `Solved`: 已经解决的 Issue\n    - `Backlog`: 待解决的 Issue\n    - `Stale`: 由于长期无人回应被封存的 Issue\n\nPull Request 的标签：\n\n- `Breaking Change`: 产生重大变动的 Pull Request\n- `Bug Fix`: 修复相关 Bug 的 Pull Request\n- `New Feature`: 添加了新功能的 Pull Request\n- `Feature`: 为现有功能提供选项或加成的 Pull Request\n- `i18n`: 更新了翻译的 Pull Request\n- `Work in Progress`: 仍在进行改动和完善的 Pull Request\n- `Skip Release`: 无需在 Release Note 中展现的 Pull Request\n\n两者兼有：\n\n- `Roadmap`: 与 NexT 主题发展相关的 Issue 或者 Pull Request\n- `Help Wanted`: 需要帮助的 Issue 或者 Pull Request\n- `Discussion`: 需要进行讨论的 Issue 或者 Pull Request\n- `Improvement`: 需要改进的 Issue 或者改进了 NexT 主题的 Pull Request\n- `Performance`: 提出性能问题的 Issue 或者提高了 NexT 主题性能的 Pull Request\n- `Hexo`: 与 Hexo 和 Hexo 插件相关的 Issue 或者 Pull Request\n- `Template Engine`: 与模版引擎相关的 Issue 或者 Pull Request\n- `CSS`: 与 NexT 主题 CSS 文件相关的 Issue 或者 Pull Request\n- `Fonts`: 与 NexT 主题字体相关的 Issue 或者 Pull Request\n- `PJAX`: 与 PJAX 相关的 Issue 或者 Pull Request\n- `3rd Party Plugin`: 与第三方插件和服务相关的 Issue 或者 Pull Request\n- `Docs`: 与文档说明相关的 Issue 或者 Pull Request\n- `Configurations`: 与 NexT 主题设置相关的 Issue 或者 Pull Request\n\n### 提交信息规范\n\n我们对项目的 git 提交信息格式进行统一格式约定，每条提交信息由 `type`+`subject` 组成，这将提升项目日志的可读性。\n\n- `type` 用于表述此次提交信息的意义，首写字母大写，包括但不局限于如下类型：\n    * `Build`：基础构建系统或依赖库的变化\n    * `Ci`：CI 构建系统及其脚本变化\n    * `Docs`：文档内容变化\n    * `Feat`：新功能\n    * `Fix`：Bug 修复\n    * `Perf`：性能优化\n    * `Refactor`：重构（即不是新增功能，也不是修改 Bug 的代码变动）\n    * `Style`：格式（不影响代码运行的变动）\n    * `Revert`：代码回滚\n    * `Release`：版本发布\n- `subject` 用于简要描述修改变更的内容，如 `Update code highlighting in readme.md`。\n    * 句尾不要使用符号。\n    * 使用现在时、祈使句语气。\n"
  },
  {
    "path": "docs/zh-CN/DATA-FILES.md",
    "content": "<h1 align=\"center\">数据文件</h1>\n\n目前，通过 pull 或下载新的 release 版本来更新 NexT 主题的体验并不平滑。当用户使用 `git pull` 更新 NexT 主题时经常需要解决冲突问题，而在手动下载 release 版本时也经常需要手动合并配置。\n\n现在来说，NexT 推荐用户存储部分配置在 Hexo 站点配置文件（`/_config.yml`），而另一部分在主题配置文件（`/themes/next/_config.yml`）。这一方式固然可用，但也有一些缺点：\n1. 配置项被分裂为两部分；\n2. 用户难以弄清何处存放配置选项。\n\n为了解决这一问题，NexT 提供了以下两种方案。\n\n<h2 align=\"center\">选择 1：Hexo 方式</h2>\n\n使用这一方式，你的全部配置都将置于 Hexo 站点配置文件（`/_config.yml`），并且不需要修改 `/themes/next/_config.yml`，或者创建什么其他的文件。但是所有用到的主题选项必须放置在 `theme_config` 后，并全部增加两个空格的缩进。\n\n如果在新的 release 中新增了选项，那么你只需要从 `/themes/next/_config.yml` 中将他们复制到 `/_config.yml` 中并将它们的值设置为你想要的。\n\n### 用法\n\n1. 请确认不存在 `/source/_data/next.yml` 文件（如果已存在，请删除）\n2. 从主题的 `/themes/next/_config.yml` 文件中复制你需要的 NexT 配置项到 `/_config.yml` 中，然后\\\n   2.1. 所有这些配置项右移两个空格（在 Visual Studio Code 中：选中这些文字，<kbd>CTRL</kbd> + <kbd>]</kbd>）。\\\n   2.2. 在这些参数最上方添加一行 `theme_config:`。\n\n### 相关链接\n\n* [Hexo 配置](https://hexo.io/zh-cn/docs/configuration.html)\n* [Hexo Pull #757](https://github.com/hexojs/hexo/pull/757)\n\n<h2 align=\"center\">选择 2: NexT 方式</h2>\n\n使用这一方式，你现在可以将你的全部配置置于同一位置（`/source/_data/next.yml`），并且不需要修改 `/themes/next/_config.yml`。\n但是可能无法让所有 Hexo 外部库都准确处理它们的附加选项（举个例子，`hexo-server` 模块只会从 Hexo 默认配置文件中读取选项）。\n\n如果在新的 release 中出现了任何新的选项，那么你只需要从 `/themes/next/_config.yml` 中将他们复制到 `/source/_data/next.yml` 中并设置它们的值为你想要的选项。\n\n这一方法依赖于 Hexo 的[数据文件](https://hexo.io/docs/data-files.html)特性。因为数据文件是在 Hexo 3 中被引入，所以你需要更新至 Hexo 3.0 以后的版本来使用这一特性。\n\n### 用法\n\n1. 请确认你的 Hexo 版本为 3.0 或更高。\n2. 在你站点的 `/source/_data` 目录创建一个 `next.yml` 文件（如果 `_data` 目录不存在，请创建之）。\n\n<p align=\"center\">以上步骤之后有 <b>两种选择</b>，请<b>任选其一</b>然后<b>继续后面的步骤</b>。</p>\n\n* **选择 1：`override: false`（默认）**：\n\n  1. 检查默认 NexT 配置中的 `override` 选项，必须设置为 `false`。\\\n     在 `next.yml` 文件中，也要设置为 `false`，或者不定义此选项。\n  2. 从站点配置文件（`/_config.yml`）与主题配置文件（`/themes/next/_config.yml`）中复制你需要的选项到 `/source/_data/next.yml` 中。\n\n* **选择 2：`override: true`**：\n\n  1. 在 `next.yml` 中设置 `override` 选项为 `true`。\n  2. 从 `/themes/next/_config.yml` 配置文件中复制**所有**的 NexT 主题选项到 `/source/_data/next.yml` 中。\n\n3. 然后，在站点的 `/_config.yml` 中需要定义 `theme: next` 选项（如果需要的话，`source_dir: source`）。\n4. 使用标准参数来启动服务器，生成或部署（`hexo clean && hexo g -d && hexo s`）。\n\n### 相关链接\n\n* [NexT Issue #328](https://github.com/iissnan/hexo-theme-next/issues/328)\n"
  },
  {
    "path": "docs/zh-CN/INSTALLATION.md",
    "content": "<h1 align=\"center\">安装</h1>\n\n<h2 align=\"center\">步骤 1 &rarr; 进入 Hexo 目录</h2>\n\n进入 **Hexo 根**目录。这一目录中应当有 `node_modules`、`source`、`themes` 等若干子目录：\n\n```sh\n$ cd hexo\n$ ls\n_config.yml  node_modules  package.json  public  scaffolds  source  themes\n```\n\n<h2 align=\"center\">步骤 2 &rarr; 获取 NexT</h2>\n\n<p align=\"center\">从 GitHub 下载主题。<br>\n为了下载这一主题，共有 <b>3 种选项</b>可选。你需要选择其中<b>唯一一个方式</b>。</p>\n\n### 选项 1：下载[最新 release 版本][releases-latest-url]\n\n   通常情况下请选择 **stable** 版本。推荐不熟悉的用户按此方式进行。\n\n   * 使用 [curl、tar 和 wget][curl-tar-wget-url] 安装：\n\n     ```sh\n     $ mkdir themes/next\n     $ curl -s https://api.github.com/repos/theme-next/hexo-theme-next/releases/latest | grep tarball_url | cut -d '\"' -f 4 | wget -i - -O- | tar -zx -C themes/next --strip-components=1\n     ```\n     这种方式将**仅提供最新的 release 版本**（其中不附带 `.git` 目录）。\\\n     因此，将来你将不可能通过 `git` 更新这一方式安装的主题。\\\n     取而代之的，为了能不丢失你的自定义配置，你可以使用独立的配置文件（例如 [数据文件][docs-data-files-url]）并下载最新版本到旧版本的目录中（或者下载到新的主题目录中并修改 Hexo 配置中的主题名）。\n\n### 选项 2：下载 [tag 指向的 release 版本][releases-url]\n\n   在少数情况下将有所帮助，但这并非推荐方式。\\\n   你必须指定一个版本：使用 [tags 列表][tags-url]中的任意 tag 替换 `v6.0.0`。\n\n   * 方式 1：使用 [curl 和 tar][curl-tar-url] 安装：\n\n     ```sh\n     $ mkdir themes/next\n     $ curl -L https://api.github.com/repos/theme-next/hexo-theme-next/tarball/v6.0.0 | tar -zxv -C themes/next --strip-components=1\n     ```\n     和上述的 `curl、tar 和 wget` 方法相同，但只会下载**指定的 release 版本**。\n\n   * 方式 2：使用 [git][git-url] 安装：\n\n     ```sh\n     $ git clone --branch v6.0.0 https://github.com/theme-next/hexo-theme-next themes/next\n     ```\n     这一方式将为你下载**指定的 release 版本**（其中包含 `.git` 目录）。\\\n     并且，你可以随时切换到任何已定义的版本号所对应的 tag 的版本。\n\n### 选项 3：下载[最新 master 分支][download-latest-url]\n\n   可能**不稳定**，但包含最新的特性。推荐进阶用户和开发者按此方式进行。\n\n   * 方式 1：使用 [curl 和 tar][curl-tar-url] 安装：\n\n     ```sh\n     $ mkdir themes/next\n     $ curl -L https://api.github.com/repos/theme-next/hexo-theme-next/tarball | tar -zxv -C themes/next --strip-components=1\n     ```\n     和上述的 `curl、tar 和 wget` 方法相同，但只会下载**最新 master 分支版本**。\\\n     在有些情况对开发者有所帮助。\n\n   * 方式 2：使用 [git][git-url] 安装：\n\n     ```sh\n     $ git clone https://github.com/theme-next/hexo-theme-next themes/next\n     ```\n\n     这一方式将为你下载**完整仓库**（其中包含 `.git` 目录）。\\\n     你可以随时[使用 git 更新至最新版本][update-with-git-url]并切换至任何有 tag 标记的 release 版本、最新的 master 分支版本、甚至其他分支。\\\n     在绝大多数情况下对用户和开发者友好。\n\n     获取 tags 列表：\n\n     ```sh\n     $ cd themes/next\n     $ git tag -l\n     …\n     v6.0.0\n     v6.0.1\n     v6.0.2\n     ```\n\n     例如，假设你想要切换到 `v6.0.1` 这一 [tag 指向的 release 版本][tags-url]。输入如下指令：\n\n     ```sh\n     $ git checkout tags/v6.0.1\n     Note: checking out 'tags/v6.0.1'.\n     …\n     HEAD is now at da9cdd2... Release v6.0.1\n     ```\n\n     然后，假设你想要切换回 [master 分支][commits-url]，输入如下指令即可：\n\n     ```sh\n     $ git checkout master\n     ```\n\n<h2 align=\"center\">步骤 3 &rarr; 完成配置</h2>\n\n在 **Hexo 站点配置文件**（`/_config.yml`）中设置你的主题：\n\n```yml\ntheme: next\n```\n\n[download-latest-url]: https://github.com/theme-next/hexo-theme-next/archive/master.zip\n[releases-latest-url]: https://github.com/theme-next/hexo-theme-next/releases/latest\n[releases-url]: https://github.com/theme-next/hexo-theme-next/releases\n[tags-url]: https://github.com/theme-next/hexo-theme-next/tags\n[commits-url]: https://github.com/theme-next/hexo-theme-next/commits/master\n\n[git-url]: http://lmgtfy.com/?q=linux+git+install\n[curl-tar-url]: http://lmgtfy.com/?q=linux+curl+tar+install\n[curl-tar-wget-url]: http://lmgtfy.com/?q=linux+curl+tar+wget+install\n\n[update-with-git-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/zh-CN/README.md#update\n[docs-data-files-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/zh-CN/DATA-FILES.md\n"
  },
  {
    "path": "docs/zh-CN/LEANCLOUD-COUNTER-SECURITY.md",
    "content": "<h1 align=\"center\">修复 LeanCloud 统计插件安全漏洞</h1>\n\n在配置前，请升级 NexT 至 **v6.0.6** 以上。\n\n在配置过程中请注意**博客配置文件**和**主题配置文件**的区别。\n\n---\n\n# 注册 LeanCloud 并创建应用\n- 首先，前往 LeanCloud 官网 [leancloud.cn](https://leancloud.cn) 进行注册，并登录。\n\n  请注意，目前华东节点和华北节点创建应用需要先在账号设置完成实名认证，并且官方表明“[在国内市场将只服务于可验证的商业客户](https://leancloudblog.com/domain-incident/)”；美国节点暂无上述要求，并且账号系统与华东节点和华北节点是独立的，如需使用请前往 LeanCloud 国际版官网 [leancloud.app](https://leancloud.app) 注册登录。\n\n- 然后点击图示 `1` 处，进入控制台：\n\n  ![1](https://lc-cqha0xyi.cn-n1.lcfile.com/fc0c048a1e25dc3d10aa.jpg)\n\n- 接着，点击图示 `1` 处，创建应用：\n\n  ![2](https://lc-cqha0xyi.cn-n1.lcfile.com/33a56b754753a5d34b01.jpg)\n\n- 在弹出窗口 `1` 处输入应用名称（可随意输入，可更改，为演示方便取名为test），并选择 `2` 处“开发版”，然后点击 `3` 处创建：\n\n  ![3](https://lc-cqha0xyi.cn-n1.lcfile.com/649ccfc6f12015d1eefb.jpg)\n\n到这里应用创建完成。\n\n# 建立 Counter 类并在 NexT 中启用插件\n- 点击 `1` 处应用名称进入应用管理界面：\n\n  ![4](https://lc-cqha0xyi.cn-n1.lcfile.com/d0889df29841661e0b9e.jpg)\n\n- 如图，点击侧边栏 `1` 处创建 Class：\n\n  ![5](https://lc-cqha0xyi.cn-n1.lcfile.com/b0fbc81bd6c19fa09a46.jpg)\n\n- 在弹出窗口 `1` 处填入 `Counter`，勾选 `2` 处无限制，并点击 `3` 处创建 Class：\n\n  ![6](https://lc-cqha0xyi.cn-n1.lcfile.com/ae6154d6a55f02f11ebf.jpg)\n\n- 此时类已创建完成。接下来点击图示 `1` 处进入设置，然后点击 `2` 处进入应用 Key：\n\n  ![8](https://lc-cqha0xyi.cn-n1.lcfile.com/9501a6372918dd9a8a92.jpg)\n\n- 粘贴 `App ID` 和 `App Key` 到 **NexT主题配置文件** `_config.yml` 对应位置。此时配置文件应如下：\n  ```yml\n  leancloud_visitors:\n    enable: true\n    app_id: # <your app id>\n    app_key: # <your app key>\n    # Required for apps from CN region\n    server_url: # <your server url>\n    # Dependencies: https://github.com/theme-next/hexo-leancloud-counter-security\n    security: true\n  ```\n\n- 设置Web安全域名确保域名调用安全。点击 `1` 处进入安全中心，然后在 `2` 处填写自己博客对应的域名（**注意协议、域名和端口号需严格一致**）：\n\n ![9](https://lc-cqha0xyi.cn-n1.lcfile.com/0e537cc4bec2e185201d.jpg)\n\n到这里内容均与 Doublemine 的[为NexT主题添加文章阅读量统计功能](https://notes.wanghao.work/2015-10-21-%E4%B8%BANexT%E4%B8%BB%E9%A2%98%E6%B7%BB%E5%8A%A0%E6%96%87%E7%AB%A0%E9%98%85%E8%AF%BB%E9%87%8F%E7%BB%9F%E8%AE%A1%E5%8A%9F%E8%83%BD.html#%E9%85%8D%E7%BD%AELeanCloud)这篇文章相同，只不过截图为新版的Leancloud的界面。\n\n# 部署云引擎以保证访客数量不被随意篡改\n- 点击左侧 `1` 处云引擎，然后点击 `2` 处部署，再点击 `3` 处在线编辑：\n\n  ![10](https://lc-cqha0xyi.cn-n1.lcfile.com/d7056dfeeef7c5d66318.jpg)\n\n- 点击 `1` 处创建函数：\n\n  ![11](https://lc-cqha0xyi.cn-n1.lcfile.com/2737841bbc2bdd572ae0.jpg)\n\n- 在弹出窗口选择 `1` 处 `Hook` 类型，然后 `2` 处选择 `beforeUpdate`，`3` 处选择刚才建立的 `Counter` 类。在 `4` 中粘贴下方代码后，点 `5` 处保存。\n  ```javascript\n  var query = new AV.Query(\"Counter\");\n  if (request.object.updatedKeys.includes('time')) {\n      return query.get(request.object.id).then(function (obj) {\n          if (obj.get(\"time\") > request.object.get(\"time\")) {\n              throw new AV.Cloud.Error('Invalid update!');\n          }\n          return request.object.save();\n      });\n  }\n  ```\n\n  如图所示：\n\n  ![12](https://lc-cqha0xyi.cn-n1.lcfile.com/a8e13418ed1d9405315b.jpg)\n\n- 点击保存后应出现类似红框处函数。此时点击 `1` 处部署：\n\n  ![13](https://lc-cqha0xyi.cn-n1.lcfile.com/ca56bf2e5fc2a1343565.jpg)\n\n- 在弹出窗口点击 `1` 处部署：\n\n  ![14](https://lc-cqha0xyi.cn-n1.lcfile.com/17548c13b3b23c71d845.jpg)\n\n- 等待出现红框处的成功部署信息后，点击 `1` 处关闭：\n\n  ![15](https://lc-cqha0xyi.cn-n1.lcfile.com/d2f50de6cefea9fd0ed3.jpg)\n\n至此云引擎已成功部署，任何非法的访客数量更改请求都将失败。\n\n# 进一步设置权限\n- 打开**NexT主题配置文件** `_config.yml`，将 `leancloud_visitors` 下的 `security` 设置为 `true`（如没有则新增）：\n  ```yml\n  leancloud_visitors:\n    enable: true\n    app_id: # <your app id>\n    app_key: # <your app key>\n    # Required for apps from CN region\n    server_url: # <your server url>\n    # Dependencies: https://github.com/theme-next/hexo-leancloud-counter-security\n    security: true\n  ```\n\n- 打开 cmd 并切换至**博客根目录**，键入以下命令以安装 `hexo-leancloud-counter-security` 插件：\n  ```\n  npm install hexo-leancloud-counter-security\n  ```\n\n- 打开**博客配置文件** `_config.yml`，新增以下配置：\n  ```yml\n  leancloud_counter_security:\n    enable_sync: true\n    app_id: <your app id>\n    app_key: <your app key>\n    username:\n    password:\n  ```\n\n- 在相同目录键入以下命令：\n  ```\n  hexo lc-counter register <username> <password>\n  ```\n  或\n  ```\n  hexo lc-counter r <username> <password>\n  ```\n\n  将 `<username>` 和 `<password>` 替换为你自己的用户名和密码（不必与 LeanCloud 的账号相同）。此用户名和密码将在 Hexo 部署时使用。\n\n  - 打开**博客配置文件** `_config.yml`，将 `<username>` 和 `<password>` 替换为你刚刚设置的用户名和密码：\n  ```yml\n  leancloud_counter_security:\n    enable_sync: true\n    app_id: <your app id>\n    app_key: <your app key>\n    username: <your username> #如留空则将在部署时询问\n    password: <your password> #建议留空以保证安全性，如留空则将在部署时询问\n  ```\n\n- 在**博客配置文件** `_config.yml` 的 `deploy` 下添加项：\n  ```yml\n  deploy:\n    # other deployer\n    - type: leancloud_counter_security_sync\n  ```\n\n- 返回 LeanCloud 控制台的应用内。依次点击 `1` `2`，检查 `_User` 表中是否出现一条记录（图示以用户名为 `admin` 为例）：\n\n  ![16](https://lc-cqha0xyi.cn-n1.lcfile.com/99faa5a0e7160e66d506.jpg)\n\n- 点击 `1` 处进入 `Counter` 表，依次点击 `2` `3`，打开权限设置：\n\n  ![17](https://lc-cqha0xyi.cn-n1.lcfile.com/b72a9e64579f5b71749d.jpg)\n\n- <del>点击 `1` `add_field` 后选择 `2` 指定用户， 并将下两栏留空：</del> 此处应与下条 `create` 设置相同（选择你所创建的用户）：\n\n  ![18](https://lc-cqha0xyi.cn-n1.lcfile.com/14a8cb37062693d768ad.jpg)\n\n- 点击 `1` `create` 后选择 `2` 指定用户， 在 `3` 处键入用户名，点击 `4` 处后点击 `5` 处添加：\n\n  ![19](https://lc-cqha0xyi.cn-n1.lcfile.com/d91714cfd703ef42b94c.jpg)\n\n  完成此步操作后，界面应与图示类似：\n\n  ![20](https://lc-cqha0xyi.cn-n1.lcfile.com/c05e7ec9218820baf412.jpg)\n\n- 点击 `1` `delete` 后选择 `2` 指定用户， 并将下两栏留空：\n\n ![21](https://lc-cqha0xyi.cn-n1.lcfile.com/c37b6e20726cfb1d3197.jpg)\n\n至此权限已设置完成，数据库记录只能在本地增删。\n\n每次运行 `hexo d` 部署的时候，插件都会扫描本地 `source/_posts` 下的文章并与数据库对比，然后在数据库创建没有录入数据库的文章记录。\n\n如果在**博客配置文件**中留空 `username` 或 `password` ，则在部署过程中程序会要求输入。\n\n---\n\n原文链接：https://leaferx.online/2018/02/11/lc-security/\n"
  },
  {
    "path": "docs/zh-CN/MATH.md",
    "content": "<h1 align=\"center\">数学公式</h1>\n\nNexT 内部提供数学公式渲染的引擎，这样你就不需要自己手动在模板中引入 JS 或者 CSS；\n只需要选择对应的渲染引擎，并在 `next/_config.yml` 中将其 `enable` 选项改为 `true` 即可。\n\n需要注意的是，仅仅将 `enable` 打开**并不能让你看到数学公式**，你还需要**使用对应的 Hexo 渲染器(Renderer)** 才能真正在博客页面中显示出数学公式。引擎对应使用的 Hexo 渲染器会在引擎相关的部分介绍。\n\n<h2 align=\"center\">提供的渲染引擎</h2>\n\n目前，NexT 提供两种数学公式渲染引擎，分别为 [MathJax](https://www.mathjax.org/) 和 [Katex](https://khan.github.io/KaTeX/)。\n\n### MathJax\n\n如果你选择使用 MathJax 进行数学公式渲染，你需要使用 [hexo-renderer-pandoc](https://github.com/wzpan/hexo-renderer-pandoc) 或者 [hexo-renderer-kramed](https://github.com/sun11/hexo-renderer-kramed) （不推荐）作为 Hexo 的 Markdown 渲染器。\n\n首先，卸载原有的渲染器 `hexo-renderer-marked`，并安装这两种渲染器的**其中一个**：\n\n```sh\nnpm uninstall hexo-renderer-marked\nnpm install hexo-renderer-pandoc # 或者 hexo-renderer-kramed\n```\n\n然后在 `next/_config.yml` 中将 `mathjax` 的 `enable` 打开。\n\n```yml\nmath:\n  ...\n  mathjax:\n    enable: true\n```\n\n执行 Hexo 生成，部署，或者启动服务器：\n\n```sh\nhexo clean && hexo g -d\n# 或者 hexo clean && hexo s\n```\n\n#### 使用 MathJax 给公式编号并引用公式\n\n在新版本的 NexT 主题中，我们加入了公式自动编号和引用功能。下面简要介绍一下如何使用这项功能。\n\n为了使用这项功能，一般来说，你必须把所使用的 LaTeX 公式放在 `equation` 环境里面，采用旧的方法（也就是说，仅仅把公式的每一边用两个 $ 符号包含起来）是无效的。如何引用公式？你只需要在书写公式的时候给公式一个 `\\label{}` 标记（tag），然后在正文中，可以使用 `\\ref{}` 或者 `\\eqref{}` 命令来引用对应的公式。使用 `\\eqref{}` 是推荐的方式，因为如果你使用 `\\ref{}`，公式在文中的引用编号将没有圆括号包围。下面介绍几种常见的公式编号例子。\n\n对于简单的公式，使用下面的方式给公式一个标记，\n\n```latex\n$$\\begin{equation}\\label{eq1}\ne=mc^2\n\\end{equation}$$\n```\n\n然后，在正文中，你可以轻松引用上述公式，一个简单的例子如下：\n\n```\n著名的质能方程 $\\eqref{eq1}$ 由爱因斯坦提出 ...\n```\n\n对于多行公式，在 `equation` 环境中，你可以使用 `aligned` 环境把公式分成多行，\n\n```latex\n$$\\begin{equation}\\label{eq2}\n\\begin{aligned}\na &= b + c \\\\\n  &= d + e + f + g \\\\\n  &= h + i\n\\end{aligned}\n\\end{equation}$$\n```\n\n要对齐多个公式，我们需要使用 `align` 环境。align 环境中的每个公式都有自己的编号：\n\n```\n$$\\begin{align}\na &= b + c \\label{eq3} \\\\\nx &= yz \\label{eq4}\\\\\nl &= m - n \\label{eq5}\n\\end{align}$$\n```\n\n在 `align` 环境中，如果你不想给某个或某几个公式编号，那么在这些公式后面使用 [`\\nonumber`](https://tex.stackexchange.com/questions/17528/show-equation-number-only-once-in-align-environment) 命令即可。例如：\n\n```latex\n$$\\begin{align}\n-4 + 5x &= 2+y \\nonumber  \\\\\n w+2 &= -1+w \\\\\n ab &= cb\n\\end{align}$$\n```\n\n有时，你可能会希望采用更加奇特的方式来标记和引用你的公式，你可以通过使用 `\\tag{}` 命令来实现，例如：\n\n```latex\n$$x+1\\over\\sqrt{1-x^2} \\tag{i}\\label{eq_tag}$$\n```\n\n如果你想要了解更多信息，请访问 [MathJax 关于公式编号的官方文档](https://docs.mathjax.org/en/latest/input/tex/eqnumbers.html)。同时，你也可以阅读 [这篇文档](https://theme-next.org/docs/third-party-services/math-equations) 来获取更多细节信息。\n\n### Katex\n\nKatex 渲染引擎相对于 MathJax 来说**大大提高了速度**，而且在关掉 JavaScript 时也能渲染数学公式。\n\n但是 Katex 所支持的东西没有 MathJax 全面，你可以从下面的相关链接中获取更多的信息。\n\n如果你选择使用 Katex 进行数学公式渲染，你需要使用 [hexo-renderer-markdown-it-plus](https://github.com/CHENXCHEN/hexo-renderer-markdown-it-plus) 或者 [hexo-renderer-markdown-it](https://github.com/hexojs/hexo-renderer-markdown-it) 这两种渲染器的其中一个。\n\n首先，卸载原有的渲染器 `hexo-renderer-marked`，并安装这两种渲染器的**其中一个**：\n\n```sh\nnpm uninstall hexo-renderer-marked\nnpm install hexo-renderer-markdown-it-plus\n# 或者 hexo-renderer-markdown-it\n```\n\n然后在 `next/_config.yml` 中将 `katex` 的 `enable` 打开。\n\n```yml\nmath:\n  ...\n  katex:\n    enable: true\n```\n\n执行 Hexo 生成，部署，或者启动服务器：\n\n```sh\nhexo clean && hexo g -d\n# 或者 hexo clean && hexo s\n```\n\n#### 如果你使用 hexo-renderer-markdown-it\n\n如果你使用 `hexo-renderer-markdown-it`，你还需要为其加上 `markdown-it-katex` 作为插件：\n\n```\nnpm install markdown-it-katex\n```\n\n然后在 `hexo/_config.yml` 中将 `markdown-it-katex` 作为插件写入 `hexo-renderer-markdown-it` 的配置中：\n\n```yml\nmarkdown:\n  render:\n    html: true\n    xhtmlOut: false\n    breaks: true\n    linkify: true\n    typographer: true\n    quotes: '“”‘’'\n  plugins:\n    - markdown-it-katex\n```\n\n#### 已知的问题\n\n1. 首先请查阅 Katex 的 [Common Issue](https://github.com/Khan/KaTeX#common-issues)\n2. 块级公式(例如 `$$...$$`)必须位于空行。\\\n   即在开头的 `$$` 前和在结尾的 `$$` 后不能有除了空白字符以外的其他字符。([#32comment](https://github.com/theme-next/hexo-theme-next/pull/32#issuecomment-357489509))\n3. 不支持 Unicode。([#32comment](https://github.com/theme-next/hexo-theme-next/pull/32#issuecomment-357489509))\n4. 行内公式(例如 `$...$`)在开头的 `$` 后面和结尾的 `$` 前面**不能含有空格**。([#32comment](https://github.com/theme-next/hexo-theme-next/pull/32#issuecomment-357489509))\n5. 如果你在文章的各级标题中(例如 `## 标题`)使用公式。\\\n   那么文章目录中的这个标题会出现 3 次未渲染的公式代码([#32comment](https://github.com/theme-next/hexo-theme-next/pull/32#issuecomment-359018694))\n6. 如果你在文章 Title 中使用公式，那么公式将不会被渲染。([#32comment](https://github.com/theme-next/hexo-theme-next/pull/32#issuecomment-359142879))\n\n我们目前使用的 Katex 版本为 0.11.1，这里面可能有某些问题是因为 Katex 版本老旧导致的；\n\n但是，就像上面所说的，数学公式的渲染必须依靠渲染器来支持，目前的 Katex 相关的渲染器仅支持到 Katex 0.11.1；\n\n我们会持续关注相关渲染器的更新，如果有渲染器支持更高版本的 Katex，我们会及时更新我们的 Katex 版本。\n\n### 相关链接\n\n* [Katex 与 MathJax 渲染速度对比](https://www.intmath.com/cg5/katex-mathjax-comparison.php)\n* [Katex 支持的功能列表](https://khan.github.io/KaTeX/function-support.html)\n\n<h2 align=\"center\">相关配置说明</h2>\n\n注意，在修改配置选项时，**不要更改配置的缩进**；\n\n目前，NexT 的所有配置都采用**2 空格的缩进**；\n\n如果配置的内容接在冒号后面，那么内容和冒号之间必须有一个空格(例如`enable: true`)\n\n```yml\n# Math Formulas Render Support\nmath:\n  # Default (true) will load mathjax / katex script on demand.\n  # That is it only render those page which has `mathjax: true` in Front-matter.\n  # If you set it to false, it will load mathjax / katex srcipt EVERY PAGE.\n  per_page: true\n\n  # hexo-renderer-pandoc (or hexo-renderer-kramed) required for full MathJax support.\n  mathjax:\n    enable: true\n    # See: https://mhchem.github.io/MathJax-mhchem/\n    mhchem: false\n\n  # hexo-renderer-markdown-it-plus (or hexo-renderer-markdown-it with markdown-it-katex plugin) required for full Katex support.\n  katex:\n    enable: false\n    # See: https://github.com/KaTeX/KaTeX/tree/master/contrib/copy-tex\n    copy_tex: false\n```\n\n### `per_page`\n\n`true` 或者 `false`，默认为 `true`。\n\n这个选项是控制是否在每篇文章都渲染数学公式；\n\n默认(`true`) 的行为是**只对 Front-matter 中含有 `mathjax: true` 的文章进行数学公式渲染**。\n\n如果 Front-matter 中不含有 `mathjax: true`，或者 `mathjax: false`，那么 NexT 将不会对这些文章进行数学公式渲染。\n\n例如：\n\n```md\n<!-- 这篇文章会渲染数学公式 -->\n---\ntitle: 'Will Render Math'\nmathjax: true\n---\n....\n```\n\n```md\n<!-- 这篇文章不会渲染数学公式 -->\n---\ntitle: 'Not Render Math'\nmathjax: false\n---\n....\n```\n\n```md\n<!-- 这篇文章也不会渲染数学公式 -->\n---\ntitle: 'Not Render Math Either'\n---\n....\n```\n\n当你将它设置为 `false` 时，它就会在每个页面都加载 MathJax 或者 Katex 来进行数学公式渲染。\n"
  },
  {
    "path": "docs/zh-CN/README.md",
    "content": "<div align=\"right\">\n  语言:\n  <a title=\"英语\" href=\"../../README.md\">🇺🇸</a>\n  🇨🇳\n  <a title=\"俄语\" href=\"../ru/README.md\">🇷🇺</a>\n</div>\n\n# <div align=\"center\"><a title=\"NexT website repository\" href=\"https://github.com/theme-next/theme-next.org\"><img align=\"center\" width=\"56\" height=\"56\" src=\"https://raw.githubusercontent.com/theme-next/hexo-theme-next/master/source/images/logo.svg?sanitize=true\"></a> e x T</div>\n\n<p align=\"center\">\n  «NexT» 是一款风格优雅的高质量 <a href=\"https://hexo.io\">Hexo</a> 主题，自点点滴滴中用爱雕琢而成。\n<br>\n<br>\n  <a href=\"https://www.npmjs.com/package/hexo-theme-next\"><img src=\"https://img.shields.io/github/package-json/v/theme-next/hexo-theme-next?style=flat-square\"></a>\n  <a href=\"https://nodejs.org\"><img src=\"https://img.shields.io/badge/node-%3E=10.9.0-green?style=flat-square\"></a>\n  <a href=\"https://hexo.io\"><img src=\"https://img.shields.io/badge/hexo-%3E=4.0.0-blue?style=flat-square&logo=hexo\"></a>\n  <a href=\"https://github.com/theme-next/hexo-theme-next/blob/master/LICENSE.md\"><img src=\"https://img.shields.io/badge/license-%20AGPL-orange?style=flat-square&logo=gnu\"></a>\n<br>\n  <a href=\"https://bestpractices.coreinfrastructure.org/projects/2625\"><img src=\"https://img.shields.io/cii/level/2625?style=flat-square\" title=\"Core Infrastructure Initiative Best Practices\"></a>\n  <a href=\"https://travis-ci.org/theme-next/hexo-theme-next?branch=master\"><img src=\"https://img.shields.io/travis/theme-next/hexo-theme-next/master?style=flat-square&logo=travis%20ci\" title=\"Travis CI [Linux]\"></a>\n  <a href=\"https://app.codacy.com/manual/theme-next/hexo-theme-next/dashboard\"><img src=\"https://img.shields.io/codacy/grade/72f7fe7609c2438a92069f448e5a341a/master?style=flat-square&logo=codacy\" title=\"Project Grade\"></a>\n  <img src=\"https://img.shields.io/snyk/vulnerabilities/github/theme-next/hexo-theme-next?style=flat-square\" title=\"Vulnerabilities\">\n<br>\n  <img src=\"https://user-images.githubusercontent.com/16272760/63487983-da41b080-c4df-11e9-951c-64883a8a5e9b.png\">\n</p>\n\n## 即时预览\n\n<p align=\"center\">\n  💟 <a href=\"https://muse.theme-next.org\">Muse</a> | 🔯 <a href=\"https://mist.theme-next.org\">Mist</a> | ♓️ <a href=\"https://pisces.theme-next.org\">Pisces</a> | ♊️ <a href=\"https://theme-next.org\">Gemini</a>\n<br>\n<br>\n  更多 «NexT» 的例子参见<a href=\"https://github.com/theme-next/awesome-next#live-preview\">这里</a>。\n</p>\n\n## 安装\n\n最简单的安装方式是直接克隆整个仓库：\n\n```sh\n$ cd hexo\n$ git clone https://github.com/theme-next/hexo-theme-next themes/next\n```\n\n此外，如果你想要使用其他方式，你也可以参见[详细安装步骤][docs-installation-url]。\n\n## 插件\n\nNexT 支持大量的第三方插件，它们可以被轻松地配置。\n\n例如，你想要在你的站点中使用 `pjax` 插件，请进入 NexT 配置文件，启用 `pjax` 配置项：\n\n```yml\n# Easily enable fast Ajax navigation on your website.\n# Dependencies: https://github.com/theme-next/theme-next-pjax\npjax: true\n```\n\n然后，打开它上面的 «Dependencies» 链接以查看它的安装步骤。\n\n### 设置 CDN\n\n如果你想要通过 CDN 来加载插件脚本，那么需要设置相关的 CDN 链接。\n\n例如，你想要使用 `mediumzoom` 插件并通过 CDN 加载，进入 Next 配置文件并找到如下内容：\n\n```yml\nvendors:\n  # ...\n  # Some contents...\n  # ...\n  mediumzoom: # Set or update mediumzoom CDN URL.\n```\n\n## 更新\n\nNexT 每个月都会发布新版本。你可以通过如下命令更新到最新的 master 分支：\n\n```sh\n$ cd themes/next\n$ git pull\n```\n\n如果你在此过程中收到了任何错误报告 (例如 **«Commit your changes or stash them before you can merge»**)，我们推荐你使用 [Hexo 数据文件][docs-data-files-url]特性。\\\n然而你也可以通过提交（`Commit`）、贮藏（`Stash`）或忽视（`Discard`）本地更改以绕过这种更新错误。具体方法请参考[这里](https://stackoverflow.com/a/15745424/5861495)。\n\n**如果你想要从 v5.1.x 更新到最新版本，阅读[这篇文档][docs-update-5-1-x-url]。**\n\n## 反馈\n\n* 浏览 [Awesome NexT][awesome-next-url] 列表，与其它用户分享插件和教程。\n* 加入我们的 [Telegram][t-chat-url] / [Gitter][gitter-url] / [Riot][riot-url] 聊天。\n* 请花几秒钟来[添加或修正翻译][i18n-url]。\n* 在 [GitHub Issues][issues-bug-url] 报告Bug。\n* 在 [GitHub][issues-feat-url] 请求新的功能。\n* 为 [受欢迎的 Feature request][feat-req-vote-url] 投票。\n\n## 贡献你的代码\n\n我们欢迎你加入 NexT 的开发，贡献出你的一份力量。请看[开源贡献指南][contributing-document-url]。 🤗\n\n你也可以随时向我们的[官方插件][official-plugins-url]提交 Issue 或 Pull Request。\n\n## 贡献者\n\n[![][contributors-image]][contributors-url]\n\n## 鸣谢\n\n<p align=\"center\">\n  «NexT» 特别感谢这些支持我们核心基础设施的优质服务：\n<br>\n<br>\n  <a href=\"https://github.com\"><img align=\"center\" width=\"100\" src=\"https://github.githubassets.com/images/modules/logos_page/GitHub-Logo.png\"></a>\n  &nbsp;&nbsp;&nbsp;\n  <a href=\"https://www.netlify.com\"><img align=\"center\" width=\"150\" src=\"https://cdn.netlify.com/15ecf59b59c9d04b88097c6b5d2c7e8a7d1302d0/1b6d6/img/press/logos/full-logo-light.svg\"></a>\n<br>\n  <sub>GitHub 容许我们托管 Git 仓库，Netlify 容许我们分发文档。</sub>\n<br>\n<br>\n  <a href=\"https://crowdin.com\"><img align=\"center\" width=\"180\" src=\"https://support.crowdin.com/assets/logos/crowdin-logo1-small.png\"></a>\n<br>\n  <sub>Crowdin 容许我们方便地翻译文档。</sub>\n<br>\n<br>\n  <a href=\"https://codacy.com\"><img align=\"center\" width=\"155\" src=\"https://user-images.githubusercontent.com/16944225/55026017-623f8f00-5002-11e9-88bf-0d6a5884c6c2.png\"></a>\n  &nbsp;&nbsp;&nbsp;\n  <a href=\"https://travis-ci.com\"><img align=\"center\" width=\"140\" src=\"https://raw.githubusercontent.com/travis-ci/travis-web/master/public/images/logos/TravisCI-Full-Color.png\"></a>\n<br>\n  <sub>Codacy 容许我们监控代码质量，Travis CI 容许我们运行测试套件。</sub>\n</p>\n\n[docs-installation-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/zh-CN/INSTALLATION.md\n[docs-data-files-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/zh-CN/DATA-FILES.md\n[docs-update-5-1-x-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/zh-CN/UPDATE-FROM-5.1.X.md\n\n[t-news-url]: https://t.me/theme_next_news\n[t-chat-url]: https://t.me/theme_next_chinese\n[gitter-url]: https://gitter.im/theme-next\n[riot-url]: https://riot.im/app/#/room/#theme-next:matrix.org\n[i18n-url]: https://i18n.theme-next.org\n\n[awesome-next-url]: https://github.com/theme-next/awesome-next\n[issues-bug-url]: https://github.com/theme-next/hexo-theme-next/issues/new?assignees=&labels=Bug&template=bug-report.md\n[issues-feat-url]: https://github.com/theme-next/hexo-theme-next/issues/new?assignees=&labels=Feature+Request&template=feature-request.md\n[feat-req-vote-url]: https://github.com/theme-next/hexo-theme-next/issues?q=is%3Aopen+is%3Aissue+label%3A%22Feature+Request%22\n\n[contributing-document-url]: https://github.com/theme-next/hexo-theme-next/blob/master/docs/zh-CN/CONTRIBUTING.md\n[official-plugins-url]: https://github.com/theme-next\n[contributors-image]: https://opencollective.com/theme-next/contributors.svg?width=890\n[contributors-url]: https://github.com/theme-next/hexo-theme-next/graphs/contributors\n"
  },
  {
    "path": "docs/zh-CN/UPDATE-FROM-5.1.X.md",
    "content": "<h1 align=\"center\">从 NexT v5.1.x 更新</h1>\n\n在使用 Hexo 3 时，NexT V5 版本仍然能够正常运行，但是如果你想获得更多的功能和帮助，还是建议您升级到 NexT V7+ 版本，并移步 [Theme-Next](https://github.com/theme-next/hexo-theme-next) 仓库。\n\n在 5.1.x 版本和新版本之间没有很大的革命性改进。主版本号变更至 7 主要是因为：\n\n1. 主仓库已从 [iissnan 名下](https://github.com/iissnan/hexo-theme-next) 迁移至 [theme-next](https://github.com/theme-next) 组织。\n2. `next/source/lib` 目录下的绝大多数库被移出到了 [NexT 组织的外部仓库](https://github.com/theme-next)中。\n3. 第三方插件 [`hexo-wordcount`](https://github.com/willin/hexo-wordcount) 被 [`hexo-symbols-count-time`](https://github.com/theme-next/hexo-symbols-count-time) 所取代，因为 `hexo-symbols-count-time` 没有任何外部 Node.js 依赖、也没有会导致生成站点时的性能问题 [language filter](https://github.com/willin/hexo-wordcount/issues/7)。\n\n我们推荐通过如下步骤从 v5 升级到 v7：\n\n1. 并不修改原有的 `next` 目录，而只是复制部分 NexT 文件：\n    1. `_config.yml` 或 `next.yml`（如果你使用了[数据文件](DATA-FILES.md)）。\n    2. 自定义的 CSS 配置，它们应在 `next/source/css/_custom/*` 和 `next/source/css/_variables/*` 中。\n    3. 自定义的排布配置，它们应在 `next/layout/_custom/*` 中。\n    4. 任何其它可能的附加自定义内容；为了定位它们，你可以通过某些工具在仓库间比较。\n2. 克隆新的仓库到任一异于 `next` 的目录（如 `next-reloaded`）：\n    ```sh\n    $ git clone https://github.com/theme-next/hexo-theme-next themes/next-reloaded\n    ```\n    如此，你可以在不修改原有的 NexT v5.1.x 目录的同时使用 `next-reloaded` 目录中的新版本主题。\n3. 在 Hexo 的主配置文件中设置主题：\n    ```yml\n    ...\n    theme: next-reloaded\n    ...\n    ```\n    如此，你的 `next-reloaded` 主题将在生成站点时被加载。如果你遇到了任何错误、或只是不喜欢这一新版本，你可以随时切换回旧的 v5.1.x 版本。\n\n4. 更新语言配置\n\n    从 v6.0.3 版本起，`zh-Hans` 改名为 `zh-CN`：https://github.com/theme-next/hexo-theme-next/releases/tag/v6.0.3\n\n    升级到 v6.0.3 及以后版本的用户，需要显式修改 Hexo 主配置文件 `_config.yml` 里的 `language` 配置，否则语言显示不正确。\n5. 更新 Hexo 和 Hexo 插件\n\n    如果完成了以上步骤后，执行 `hexo s` 或 `hexo g` 出现错误，这意味着可能是旧版的 Hexo 和 Hexo 插件与新版的 NexT 主题产生了冲突。我们建议将 Hexo 升级至 4.0 以上的版本，将 Hexo 插件升级到最新版本。你可以执行 `npm outdated` 查看所有可以升级的插件。\n\n关于第三方库的启用，参见[这里](https://github.com/theme-next/hexo-theme-next/blob/master/docs/zh-CN/INSTALLATION.md#插件)。\n"
  },
  {
    "path": "gulpfile.js",
    "content": "const fs = require('fs');\nconst path = require('path');\nconst gulp = require('gulp');\nconst eslint = require('gulp-eslint');\nconst shell = require('gulp-shell');\nconst yaml = require('js-yaml');\n\ngulp.task('lint', () => gulp.src([\n  './source/js/**/*.js',\n  './scripts/**/*.js'\n]).pipe(eslint())\n  .pipe(eslint.format()));\n\ngulp.task('lint:stylus', shell.task([\n  'npx stylint ./source/css/'\n]));\n\ngulp.task('validate:config', cb => {\n  const themeConfig = fs.readFileSync(path.join(__dirname, '_config.yml'));\n\n  try {\n    yaml.safeLoad(themeConfig);\n    return cb();\n  } catch (error) {\n    return cb(new Error(error));\n  }\n});\n\ngulp.task('validate:languages', cb => {\n  const languagesPath = path.join(__dirname, 'languages');\n  const languages = fs.readdirSync(languagesPath);\n  const errors = [];\n\n  languages.forEach(lang => {\n    const languagePath = path.join(languagesPath, lang);\n    try {\n      yaml.safeLoad(fs.readFileSync(languagePath), {\n        filename: path.relative(__dirname, languagePath)\n      });\n    } catch (error) {\n      errors.push(error);\n    }\n  });\n\n  return errors.length === 0 ? cb() : cb(errors);\n});\n\ngulp.task('default', gulp.series('lint', 'validate:config', 'validate:languages'));\n"
  },
  {
    "path": "languages/ar.yml",
    "content": "---\nname: عربي\ntitle:\n  archive: الأرشيف\n  category: تصنيف\n  tag: وسم\n  schedule: التقويم\nmenu:\n  home: Home\n  archives: الأرشيفات\n  categories: التصنيفات\n  tags: الوسوم\n  about: معلومات\n  search: بحث\n  schedule: التقويم\n  sitemap: خريطة الموقع\n  commonweal: Commonweal 404\nsidebar:\n  overview: عام\n  toc: المحتويات\npost:\n  posted: نُشر في\n  edited: عُدل في\n  created: أُنشأ\n  modified: عُدل\n  edit: تحرير هذا المقال\n  in: في\n  read_more: تابع القراءة\n  untitled: بدون عنوان\n  sticky: مثبت\n  views: مشاهدات\n  related_posts: مقالات مشابهة\n  copyright:\n    author: مؤلف المقال\n    link: رابط المقال\n    license_title: حقوق الملكية\n    license_content: \"حميع المقالات في هذه المدوّنة منشورة تحت رخصة %s إلا عند التنويه بخلافه.\"\nfooter:\n  powered: \"تطبيق الموقع %s\"\n  total_views: إجمالي المشاهدات\n  total_visitors: إجمالي الزوار\ncounter:\n  tag_cloud:\n    zero: لا وسوم\n    one: وسمٌ واحدٌ\n    other: \"%d وسماً بالمُجمل\"\n  categories:\n    zero: لا تصنيفات\n    one: تصنيفٌ واحد\n    other: \"%d تصنيفات بالمُجمل\"\n  archive_posts:\n    zero: لا مقالات.\n    one: مقالٌ واحد.\n    other: \"%d مقالاً بالمُجمل.\"\nstate:\n  posts: المقالات\n  tags: الوسوم\n  categories: التصنيفات\nsearch:\n  placeholder: بحث...\ncheers:\n  um: هِم..\n  ok: حسناً\n  nice: جميل\n  good: جيد\n  great: عظيم\n  excellent: ممتاز\nkeep_on: واصل الكتابة.\nsymbol:\n  comma: \"، \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: تبرّع\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: مرحباً بك حيثُ أنشر أيضاً\naccessibility:\n  nav_toggle: تشغيل شريط التصفح\n  prev_page: الصفحة السابقة\n  next_page: الصفحة التالية\nsymbols_count_time:\n  count: عدد الحروف في المقال\n  count_total: مُجمل عدد الحروف\n  time: زمن القراءة\n  time_total: مُجمل زمن القراءة\n  time_minutes: دقائق.\n"
  },
  {
    "path": "languages/de.yml",
    "content": "---\nname: Deutsch\ntitle:\n  archive: Archiv\n  category: Kategorie\n  tag: Schlagwort\n  schedule: Zeitplan\nmenu:\n  home: Startseite\n  archives: Archiv\n  categories: Kategorien\n  tags: Schlagwörter\n  about: Über\n  search: Suche\n  schedule: Zeitplan\n  sitemap: Sitemap\n  commonweal: Commonweal 404\nsidebar:\n  overview: Übersicht\n  toc: Inhaltsverzeichnis\npost:\n  posted: Veröffentlicht am\n  edited: Bearbeitet am\n  created: Erstellt\n  modified: Geändert am\n  edit: Diesen Beitrag bearbeiten\n  in: in\n  read_more: Weiterlesen\n  untitled: Unbenannt\n  sticky: Angepinnt\n  views: Aufrufe\n  related_posts: Ähnliche Beiträge\n  copyright:\n    author: Beitragsautor\n    link: Beitragslink\n    license_title: Urheberrechtshinweis\n    license_content: \"Alle Artikel in diesem Blog sind unter %s lizenziert, außer es wird anders angegeben.\"\nfooter:\n  powered: \"Erstellt mit  %s\"\n  total_views: Alle Aufrufe\n  total_visitors: Alle Besucher\ncounter:\n  tag_cloud:\n    zero: Keine Schlagworte\n    one: Insgesamt ein Schlagwort\n    other: \"Insgesamt %d Schlagwörter\"\n  categories:\n    zero: Keine Kategorien\n    one: Insgesamt eine Kategorie\n    other: \"Insgesamt %d Kategorien\"\n  archive_posts:\n    zero: Keine Artikel vorhanden.\n    one: Ein Artikel.\n    other: \"Insgesamt %d Artikel.\"\nstate:\n  posts: Artikel\n  tags: schlagwörter\n  categories: Kategorien\nsearch:\n  placeholder: Suche...\ncheers:\n  um: Öhm..\n  ok: OK\n  nice: Schön\n  good: Gut\n  great: Wunderbar\n  excellent: Exzellent\nkeep_on: Bleib dran.\nsymbol:\n  comma: \". \"\n  period: \", \"\n  colon: \": \"\nreward:\n  donate: Spenden\n  wechatpay: WeChat Bezahlung\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: Navigationsleiste an/ausschalten\n  prev_page: Vorherige Seite\n  next_page: Nächste Seite\nsymbols_count_time:\n  count: Symbole im Artikel gezählt\n  count_total: Insgesamt gezählte Symbole\n  time: Lesezeit\n  time_total: Insgesamte Lesezeit\n  time_minutes: minuten.\n"
  },
  {
    "path": "languages/en.yml",
    "content": "name: English\n\ntitle:\n  archive: Archive\n  category: Category\n  tag: Tag\n  schedule: Schedule\n\nmenu:\n  home: Home\n  archives: Archives\n  categories: Categories\n  tags: Tags\n  about: About\n  search: Search\n  schedule: Schedule\n  sitemap: Sitemap\n  commonweal: Commonweal 404\n\nsidebar:\n  overview: Overview\n  toc: Table of Contents\n\npost:\n  posted: Posted on\n  edited: Edited on\n  created: Created\n  modified: Modified\n  edit: Edit this post\n  in: In\n  read_more: Read more\n  untitled: Untitled\n  sticky: Sticky\n  views: Views\n  related_posts: Related Posts\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: \"All articles in this blog are licensed under %s unless stating additionally.\"\n\nfooter:\n  powered: \"Powered by %s\"\n  total_views: Total Views\n  total_visitors: Total Visitors\n\ncounter:\n  tag_cloud:\n    zero: No tags\n    one: 1 tag in total\n    other: \"%d tags in total\"\n\n  categories:\n    zero: No categories\n    one: 1 category in total\n    other: \"%d categories in total\"\n\n  archive_posts:\n    zero: No posts.\n    one: 1 post.\n    other: \"%d posts in total.\"\n\nstate:\n  posts: posts\n  tags: tags\n  categories: categories\n\nsearch:\n  placeholder: Searching...\n\ncheers:\n  um: Um..\n  ok: OK\n  nice: Nice\n  good: Good\n  great: Great\n  excellent: Excellent\n\nkeep_on: Keep on posting.\n\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\n\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\n\nfollow_me:\n  welcome: Welcome to my other publishing channels\n\naccessibility:\n  nav_toggle: Toggle navigation bar\n  prev_page: Previous page\n  next_page: Next page\n\nsymbols_count_time:\n  count: Symbols count in article\n  count_total: Symbols count total\n  time: Reading time\n  time_total: Reading time total\n  time_minutes: mins.\n"
  },
  {
    "path": "languages/es.yml",
    "content": "---\nname: Español\ntitle:\n  archive: Archivo\n  category: Categoría\n  tag: Etiqueta\n  schedule: Calendario\nmenu:\n  home: Inicio\n  archives: Archivo\n  categories: Categorías\n  tags: Etiquetas\n  about: Sobre mi\n  search: Buscar\n  schedule: Calendario\n  sitemap: Mapa del sitio\n  commonweal: Commonweal 404\nsidebar:\n  overview: Inicio\n  toc: Tabla de contenidos\npost:\n  posted: Publicado el\n  edited: Editado el\n  created: Creado por\n  modified: Modificado por\n  edit: Editar esta entrada\n  in: En\n  read_more: Leer más\n  untitled: Sin título\n  sticky: Sticky\n  views: Visitas\n  related_posts: Entradas relacionadas\n  copyright:\n    author: Autor de la entrada\n    link: Enlace a la entrada\n    license_title: Copyright\n    license_content: \"Todos los artículos de este blog están licenciados bajo %s a no ser que se especifique una licencia adicional.\"\nfooter:\n  powered: \"Creado mediante %s\"\n  total_views: Visitas totales\n  total_visitors: Visitantes totales\ncounter:\n  tag_cloud:\n    zero: Sin etiquetas\n    one: 1 etiqueta en total\n    other: \"%d etiquetas en total\"\n  categories:\n    zero: Sin categorías\n    one: 1 categoría en total\n    other: \"%d categorías en total\"\n  archive_posts:\n    zero: Sin entradas.\n    one: 1 entrada.\n    other: \"%d entradas en total.\"\nstate:\n  posts: entradas\n  tags: tags\n  categories: categorías\nsearch:\n  placeholder: Buscando...\ncheers:\n  um: Um..\n  ok: Bueno\n  nice: Guai\n  good: Bien\n  great: Genial\n  excellent: Excelente\nkeep_on: Sigue posteando.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Donar\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: Cambiar a barra de navegación\n  prev_page: Página anterior\n  next_page: Página siguiente\nsymbols_count_time:\n  count: Cantidad de caracteres en el articulo\n  count_total: Cantidad total de caracteres\n  time: Tiempo de lectura\n  time_total: Tiempo total de lectura\n  time_minutes: minutos.\n"
  },
  {
    "path": "languages/fa.yml",
    "content": "---\nname: فارسی\ntitle:\n  archive: بایگانی\n  category: دسته بندی\n  tag: برچسب\n  schedule: زمان بندی\nmenu:\n  home: صفحه اصلی\n  archives: بایگانی\n  categories: دسته بندی ها\n  tags: برچسب ها\n  about: درباره\n  search: جستجو\n  schedule: زمان بندی\n  sitemap: نقشه سایت\n  commonweal: Commonweal 404\nsidebar:\n  overview: نمای کلی\n  toc: فهرست مطالب\npost:\n  posted: نوشته شده در\n  edited: ویرایش شده در\n  created: ایجاد شده\n  modified: تغییر یافته\n  edit: ویرایش این پست\n  in: در\n  read_more: ادامه مطلب\n  untitled: بدون عنوان\n  sticky: چسبنده\n  views: بازدیدها\n  related_posts: پست های مرتبط\n  copyright:\n    author: نویسنده پست\n    link: لینک پست\n    license_title: مقررات کپی رایت\n    license_content: \"همه مقالات در این وبلاگ تحت %s مجاز می باشند مگر اینکه به طور اضافی بیان شوند.\"\nfooter:\n  powered: \"قدرت گرفته از %s\"\n  total_views: مجموع بازدیدها\n  total_visitors: تعداد بازدید کنندگان\ncounter:\n  tag_cloud:\n    zero: بدون برچسب\n    one: 1 برچسب در مجموع\n    other: \"%d برچسب در مجموع\"\n  categories:\n    zero: بدون دسته بندی\n    one: 1 دسته بندی در مجموع\n    other: \"%d دسته بندی در مجموع\"\n  archive_posts:\n    zero: بدون پست.\n    one: 1 پست.\n    other: \"%d برچسب در مجموع.\"\nstate:\n  posts: پست ها\n  tags: برجسب ها\n  categories: دسته بندی ها\nsearch:\n  placeholder: جستجو...\ncheers:\n  um: ام...\n  ok: باشه\n  nice: زیبا\n  good: خوب\n  great: عالی\n  excellent: بسیار عالی\nkeep_on: به پست دادن ادامه دهید.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: کمک مالی\n  wechatpay: پرداخت WeChat\n  alipay: AliPay\n  paypal: PayPal\n  bitcoin: بیت کوین\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: تغییر ناوبری\n  prev_page: صفحه قبلی\n  next_page: صفحه بعدی\nsymbols_count_time:\n  count: تعداد نمادها در مقاله\n  count_total: تعداد کل نمادها\n  time: زمان خواندن\n  time_total: کل زمان خواندن\n  time_minutes: دقیقه.\n"
  },
  {
    "path": "languages/fr.yml",
    "content": "---\nname: Français\ntitle:\n  archive: Archive\n  category: Catégorie\n  tag: Mots clés\n  schedule: Plannifier\nmenu:\n  home: Accueil\n  archives: Archives\n  categories: Catégories\n  tags: Mots clés\n  about: À propos\n  search: Recherche\n  schedule: Plannifier\n  sitemap: Sitemap\n  commonweal: Commonweal 404\nsidebar:\n  overview: Aperçu\n  toc: Table Des Matières\npost:\n  posted: Posté le\n  edited: Édité le\n  created: Article créé le\n  modified: Mis à jour le\n  edit: Éditer cet article\n  in: dans\n  read_more: Lire la suite\n  untitled: Sans titre\n  sticky: Épingler\n  views: Vues\n  related_posts: Articles similaires\n  copyright:\n    author: Auteur de l'article\n    link: Lien de l'article\n    license_title: Droit d'auteur\n    license_content: \"Tous les articles de ce blog sont sous licence %s, sauf mention contraire.\"\nfooter:\n  powered: \"Propulsé par %s\"\n  total_views: Vues totales\n  total_visitors: Total visiteurs\ncounter:\n  tag_cloud:\n    zero: Aucun tag\n    one: 1 tag au total\n    other: \"%d tags au total\"\n  categories:\n    zero: Aucune categorie\n    one: 1 catégorie au total\n    other: \"%d catégories au total\"\n  archive_posts:\n    zero: Aucun article.\n    one: 1 article.\n    other: \"%d articles au total.\"\nstate:\n  posts: articles\n  tags: mots clé\n  categories: catégories\nsearch:\n  placeholder: Recherche...\ncheers:\n  um: Um..\n  ok: OK\n  nice: Jolie\n  good: Bien\n  great: Super\n  excellent: Excellent\nkeep_on: Continue comme ça.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Donner\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: Basculer la barre de navigation\n  prev_page: Page précédente\n  next_page: Page suivante\nsymbols_count_time:\n  count: Caractères dans l'article\n  count_total: Caractères total\n  time: Temps de lecture\n  time_total: Temps total de lecture\n  time_minutes: mins.\n"
  },
  {
    "path": "languages/hu.yml",
    "content": "---\nname: magyar\ntitle:\n  archive: Archive\n  category: Category\n  tag: Tag\n  schedule: Ütemterv\nmenu:\n  home: Home\n  archives: Archives\n  categories: Categories\n  tags: Tags\n  about: About\n  search: Search\n  schedule: Schedule\n  sitemap: Sitemap\n  commonweal: Commonweal 404\nsidebar:\n  overview: Overview\n  toc: Table of Contents\npost:\n  posted: Posted on\n  edited: Edited on\n  created: Created\n  modified: Modified\n  edit: Edit this post\n  in: In\n  read_more: Read more\n  untitled: Untitled\n  sticky: Sticky\n  views: Views\n  related_posts: Related Posts\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: \"All articles in this blog are licensed under %s unless stating additionally.\"\nfooter:\n  powered: \"Powered by %s\"\n  total_views: Total Views\n  total_visitors: Total Visitors\ncounter:\n  tag_cloud:\n    zero: No tags\n    one: 1 tag in total\n    other: \"%d tags in total\"\n  categories:\n    zero: No categories\n    one: 1 category in total\n    other: \"%d categories in total\"\n  archive_posts:\n    zero: No posts.\n    one: 1 post.\n    other: \"%d posts in total.\"\nstate:\n  posts: posts\n  tags: tags\n  categories: categories\nsearch:\n  placeholder: Searching...\ncheers:\n  um: Um..\n  ok: OK\n  nice: Nice\n  good: Good\n  great: Great\n  excellent: Excellent\nkeep_on: Keep on posting.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: Toggle navigation bar\n  prev_page: Previous page\n  next_page: Next page\nsymbols_count_time:\n  count: Symbols count in article\n  count_total: Symbols count total\n  time: Reading time\n  time_total: Reading time total\n  time_minutes: mins.\n"
  },
  {
    "path": "languages/id.yml",
    "content": "---\nname: Bahasa Indonesia\ntitle:\n  archive: Arsip\n  category: Kategori\n  tag: Tag\n  schedule: Schedule\nmenu:\n  home: Beranda\n  archives: Arsip\n  categories: Kategori\n  tags: Tags\n  about: Tentang\n  search: Pencarian\n  schedule: Schedule\n  sitemap: Sitemap\n  commonweal: Commonweal 404\nsidebar:\n  overview: Ikhtisar\n  toc: Daftar Isi\npost:\n  posted: Diposting di\n  edited: Edited on\n  created: Post created\n  modified: Updated at\n  edit: Edit this post\n  in: Di\n  read_more: Baca lebih\n  untitled: Tidak ada title\n  sticky: Sticky\n  views: Views\n  related_posts: Related Posts\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: \"All articles in this blog are licensed under %s unless stating additionally.\"\nfooter:\n  powered: \"Powered by %s\"\n  total_views: Total Views\n  total_visitors: Total Visitors\ncounter:\n  tag_cloud:\n    zero: Tidak ada tags\n    one: 1 total tag\n    other: \"%d total tags\"\n  categories:\n    zero: Tidak ada kategori\n    one: 1 total categori\n    other: \"%d total kategori\"\n  archive_posts:\n    zero: Tidak ada posting.\n    one: 1 posting.\n    other: \"%d total posting.\"\nstate:\n  posts: posting\n  tags: tags\n  categories: kategori\nsearch:\n  placeholder: Searching...\ncheers:\n  um: Um..\n  ok: OK\n  nice: Bagus\n  good: Bagus\n  great: Besar\n  excellent: Baik\nkeep_on: Terus Posting.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: Toggle navigation bar\n  prev_page: Halaman sebelumnya\n  next_page: Halaman selanjutnya\nsymbols_count_time:\n  count: Symbols count in article\n  count_total: Symbols count total\n  time: Reading time\n  time_total: Reading time total\n  time_minutes: mins.\n"
  },
  {
    "path": "languages/it.yml",
    "content": "---\nname: Italiano\ntitle:\n  archive: Archivio\n  category: Categoria\n  tag: Tag\n  schedule: Programma\nmenu:\n  home: Home\n  archives: Archivi\n  categories: Categorie\n  tags: Tags\n  about: Informazioni su\n  search: Cerca\n  schedule: Programma\n  sitemap: Sitemap\n  commonweal: Commonweal 404\nsidebar:\n  overview: Panoramica\n  toc: Indice\npost:\n  posted: Scritto il\n  edited: Edited on\n  created: Post creato\n  modified: Post modificato\n  edit: Edit this post\n  in: In\n  read_more: Leggi di più\n  untitled: Senza titolo\n  sticky: Sticky\n  views: Views\n  related_posts: Related Posts\n  copyright:\n    author: Autore\n    link: Link\n    license_title: Copyright\n    license_content: \"Tutti gli articoli in questo sito sono sotto licenza %s salvo disposizione contraria.\"\nfooter:\n  powered: \"Powered by %s\"\n  total_views: Total Views\n  total_visitors: Total Visitors\ncounter:\n  tag_cloud:\n    zero: Nessun tag\n    one: 1 tag in totale\n    other: \"%d tags in totale.\"\n  categories:\n    zero: Nessuna categoria\n    one: 1 categoria in totale\n    other: \"%d categorie in totale.\"\n  archive_posts:\n    zero: Nessun post.\n    one: 1 post.\n    other: \"%d posts in totale.\"\nstate:\n  posts: posts\n  tags: tags\n  categories: categorie\nsearch:\n  placeholder: Cerca...\ncheers:\n  um: Mh..\n  ok: OK\n  nice: Bello\n  good: Buono\n  great: Ottimo\n  excellent: Eccellente\nkeep_on: Continua così.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Dona\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: Toggle navigation bar\n  prev_page: Pagina precedente\n  next_page: Pagina successiva\nsymbols_count_time:\n  count: Symbols count in article\n  count_total: Symbols count total\n  time: Reading time\n  time_total: Reading time total\n  time_minutes: mins.\n"
  },
  {
    "path": "languages/ja.yml",
    "content": "---\nname: 日本語\ntitle:\n  archive: アーカイブ\n  category: カテゴリ\n  tag: タグ\n  schedule: スケジュール\nmenu:\n  home: ホーム\n  archives: アーカイブ\n  categories: カテゴリ\n  tags: タグ\n  about: プロフィール\n  search: 検索\n  schedule: スケジュール\n  sitemap: サイトマップ\n  commonweal: 公益 404\nsidebar:\n  overview: 概要\n  toc: 見出し\npost:\n  posted: 投稿日\n  edited: 編集日\n  created: 作成日\n  modified: 修正日\n  edit: この記事を編集する\n  in: カテゴリ\n  read_more: 続きを読む\n  untitled: 無題\n  sticky: 固定\n  views: 閲覧数\n  related_posts: 関連記事\n  copyright:\n    author: 著者\n    link: 記事へのリンク\n    license_title: 著作権表示\n    license_content: \"このブログ内のすべての記事は、特別な記載がない限り %s の下のライセンスで保護されています。\"\nfooter:\n  powered: \"Powered by %s\"\n  total_views: 閲覧合計数\n  total_visitors: 合計閲覧者数\ncounter:\n  tag_cloud:\n    zero: タグなし\n    one: 全 1 タグ\n    other: \"全 %d タグ\"\n  categories:\n    zero: カテゴリなし\n    one: 全 1 カテゴリ\n    other: \"全 %d カテゴリ\"\n  archive_posts:\n    zero: ポストなし\n    one: 全 1 ポスト\n    other: \"全 %d ポスト\"\nstate:\n  posts: ポスト\n  tags: タグ\n  categories: カテゴリ\nsearch:\n  placeholder: 検索…\ncheers:\n  um: うーん\n  ok: はい\n  nice: まあまあ\n  good: いいね\n  great: すごい\n  excellent: 最高\nkeep_on: もっと書こう！\nsymbol:\n  comma: \"、\"\n  period: \"。\"\n  colon: \"：\"\nreward:\n  donate: 寄付\n  wechatpay: WeChat 支払う\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: ビットコイン\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: ナビゲーションバーの切り替え\n  prev_page: 前のページ\n  next_page: 次のページ\nsymbols_count_time:\n  count: 単語数\n  count_total: 単語の総数\n  time: 読書の時間\n  time_total: 読書の合計時間\n  time_minutes: 分\n"
  },
  {
    "path": "languages/ko.yml",
    "content": "---\nname: 한국어\ntitle:\n  archive: 아카이브\n  category: 카테고리\n  tag: 태그\n  schedule: Schedule\nmenu:\n  home: 홈\n  archives: 아카이브\n  categories: 카테고리\n  tags: 태그\n  about: About\n  search: 검색\n  schedule: Schedule\n  sitemap: Sitemap\n  commonweal: Commonweal 404\nsidebar:\n  overview: 흝어보기\n  toc: 목차\npost:\n  posted: 작성일\n  edited: Edited on\n  created: Post created\n  modified: Updated at\n  edit: Edit this post\n  in: In\n  read_more: 더 읽어보기\n  untitled: 제목 없음\n  sticky: 고정\n  views: Views\n  related_posts: Related Posts\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: \"All articles in this blog are licensed under %s unless stating additionally.\"\nfooter:\n  powered: \"Powered by %s\"\n  total_views: Total Views\n  total_visitors: Total Visitors\ncounter:\n  tag_cloud:\n    zero: 태그 없음\n    one: 1개의 태그\n    other: \"총 %d개의 태그\"\n  categories:\n    zero: 카테고리 없음\n    one: 1개의 카테고리\n    other: \"총 %d개의 카테고리\"\n  archive_posts:\n    zero: 포스트 없음\n    one: 1개의 포스트\n    other: \"총 %d개의 포스트\"\nstate:\n  posts: 포스트\n  tags: 태그\n  categories: 카테고리\nsearch:\n  placeholder: Searching...\ncheers:\n  um: 음..\n  ok: OK\n  nice: 잘했어요\n  good: 좋아요\n  great: 훌륭해요\n  excellent: 완벽해요\nkeep_on: 포스트를 마저 작성하세요\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: Toggle navigation bar\n  prev_page: 이전 페이지\n  next_page: 다음 페이지\nsymbols_count_time:\n  count: Symbols count in article\n  count_total: Symbols count total\n  time: Reading time\n  time_total: Reading time total\n  time_minutes: mins.\n"
  },
  {
    "path": "languages/nl.yml",
    "content": "---\nname: Niederländisch\ntitle:\n  archive: Archief\n  category: Categorie\n  tag: Label\n  schedule: Rooster\nmenu:\n  home: Home\n  archives: Archieven\n  categories: Categorieën\n  tags: Labels\n  about: Over\n  search: Zoeken\n  schedule: Rooster\n  sitemap: Sitemap\n  commonweal: Gezond verstand 404\nsidebar:\n  overview: Overzicht\n  toc: Inhoudsopgave\npost:\n  posted: Geplaatst op\n  edited: Edited on\n  created: Post aangemaakt\n  modified: Post aangepast\n  edit: Edit this post\n  in: In\n  read_more: Lees meer\n  untitled: Naamloos\n  sticky: Sticky\n  views: Views\n  related_posts: Related Posts\n  copyright:\n    author: Post auteur\n    link: Post link\n    license_title: Copyright melding\n    license_content: \"Alle artikelen op deze blog zijn gelicenseerd onder %s, mits niet anders aangegeven.\"\nfooter:\n  powered: \"Mede mogelijk gemaakt door %s\"\n  total_views: Total Views\n  total_visitors: Total Visitors\ncounter:\n  tag_cloud:\n    zero: Geen labels\n    one: 1 label in totaal\n    other: \"%d labels in totaal\"\n  categories:\n    zero: Geen categorieën\n    one: 1 categorie in totaal\n    other: \"%d categorieën in totaal\"\n  archive_posts:\n    zero: Geen posts.\n    one: 1 post.\n    other: \"%d posts in totaal.\"\nstate:\n  posts: posts\n  tags: labels\n  categories: categorieën\nsearch:\n  placeholder: Zoeken...\ncheers:\n  um: Um..\n  ok: Oké\n  nice: Leuk\n  good: Goed\n  great: Geweldig\n  excellent: Uitstekend\nkeep_on: Blijf posten.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Doneer\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: Toggle navigation bar\n  prev_page: Vorige pagina\n  next_page: Volgende pagina\nsymbols_count_time:\n  count: Symbols count in article\n  count_total: Symbols count total\n  time: Reading time\n  time_total: Reading time total\n  time_minutes: mins.\n"
  },
  {
    "path": "languages/pt-BR.yml",
    "content": "---\nname: Português\ntitle:\n  archive: Arquivo\n  category: Categoria\n  tag: Tag\n  schedule: Schedule\nmenu:\n  home: Home\n  archives: Arquivos\n  categories: Categorias\n  tags: Tags\n  about: Sobre\n  search: Pesquisar\n  schedule: Schedule\n  sitemap: Sitemap\n  commonweal: Commonweal 404\nsidebar:\n  overview: Visão geral\n  toc: Tabela de conteúdo\npost:\n  posted: Postado em\n  edited: Edited on\n  created: Post created\n  modified: Updated at\n  edit: Edit this post\n  in: Em\n  read_more: Leia mais\n  untitled: Sem título\n  sticky: Sticky\n  views: Views\n  related_posts: Related Posts\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: \"All articles in this blog are licensed under %s unless stating additionally.\"\nfooter:\n  powered: \"Feito com %s\"\n  total_views: Total Views\n  total_visitors: Total Visitors\ncounter:\n  tag_cloud:\n    zero: Sem tags\n    one: 1 tag no total de\n    other: \"%d tags no total de\"\n  categories:\n    zero: Sem categoria\n    one: 1 categoria no total de\n    other: \"%d categoria no total de\"\n  archive_posts:\n    zero: Sem posts.\n    one: 1 post.\n    other: \"%d posts no total.\"\nstate:\n  posts: Posts\n  tags: Tags\n  categories: Categorias\nsearch:\n  placeholder: Searching...\ncheers:\n  um: Uhmmmm...\n  ok: OK\n  nice: Bom\n  good: Muito Bom\n  great: Ótimo\n  excellent: Excelente\nkeep_on: Continuar no post.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: Toggle navigation bar\n  prev_page: Página anterior\n  next_page: Próxima página\nsymbols_count_time:\n  count: Symbols count in article\n  count_total: Symbols count total\n  time: Reading time\n  time_total: Reading time total\n  time_minutes: mins.\n"
  },
  {
    "path": "languages/pt.yml",
    "content": "---\nname: Português\ntitle:\n  archive: Arquivo\n  category: Categoria\n  tag: Tag\n  schedule: Schedule\nmenu:\n  home: Home\n  archives: Arquivos\n  categories: Categorias\n  tags: Tags\n  about: Sobre\n  search: Pesquisa\n  schedule: Schedule\n  sitemap: Sitemap\n  commonweal: Commonweal 404\nsidebar:\n  overview: Visão Geral\n  toc: Tabela de Conteúdo\npost:\n  posted: Postado em\n  edited: Edited on\n  created: Post created\n  modified: Updated at\n  edit: Edit this post\n  in: Em\n  read_more: Ler mais\n  untitled: Sem título\n  sticky: Sticky\n  views: Views\n  related_posts: Related Posts\n  copyright:\n    author: Post author\n    link: Post link\n    license_title: Copyright Notice\n    license_content: \"All articles in this blog are licensed under %s unless stating additionally.\"\nfooter:\n  powered: \"Desenvolvido com amor com %s\"\n  total_views: Total Views\n  total_visitors: Total Visitors\ncounter:\n  tag_cloud:\n    zero: Sem tags\n    one: 1 tag no total\n    other: \"%d tags no total\"\n  categories:\n    zero: Sem categorias\n    one: 1 categoria no total\n    other: \"%d categorias no total\"\n  archive_posts:\n    zero: Sem publicações.\n    one: 1 post.\n    other: \"%d publicações no total.\"\nstate:\n  posts: publicações\n  tags: tags\n  categories: categorias\nsearch:\n  placeholder: Searching...\ncheers:\n  um: Um..\n  ok: OK\n  nice: Legal\n  good: Bom\n  great: Grandioso\n  excellent: Excelente\nkeep_on: Mantenha-se publicando!\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Donate\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: Toggle navigation bar\n  prev_page: Página anterior\n  next_page: Página seguinte\nsymbols_count_time:\n  count: Symbols count in article\n  count_total: Symbols count total\n  time: Reading time\n  time_total: Reading time total\n  time_minutes: mins.\n"
  },
  {
    "path": "languages/ru.yml",
    "content": "---\nname: Русский\ntitle:\n  archive: Архив\n  category: Категория\n  tag: Тэг\n  schedule: Календарь\nmenu:\n  home: Главная\n  archives: Архив\n  categories: Категории\n  tags: Тэги\n  about: О сайте\n  search: Поиск\n  schedule: Календарь\n  sitemap: Карта сайта\n  commonweal: Страница 404\nsidebar:\n  overview: Обзор\n  toc: Содержание\npost:\n  posted: Размещено\n  edited: Изменено\n  created: Создано\n  modified: Изменено\n  edit: Редактировать запись\n  in: в категории\n  read_more: Читать полностью\n  untitled: Без имени\n  sticky: Ссылка\n  views: Просмотров\n  related_posts: Похожие записи\n  copyright:\n    author: Автор записи\n    link: Ссылка на запись\n    license_title: Информация об авторских правах\n    license_content: \"Все записи на этом сайте защищены лицензией %s, если не указано дополнительно.\"\nfooter:\n  powered: \"Генератор — %s\"\n  total_views: Всего просмотров\n  total_visitors: Всего посетителей\ncounter:\n  tag_cloud:\n    zero: Нет тэгов.\n    one: 1 тэг.\n    other: \"%d тэгов всего.\"\n  categories:\n    zero: Нет категорий.\n    one: 1 категория.\n    other: \"%d категорий всего.\"\n  archive_posts:\n    zero: Нет записей.\n    one: 1 запись.\n    other: \"%d записей всего.\"\nstate:\n  posts: Архив\n  tags: Тэги\n  categories: Категории\nsearch:\n  placeholder: Поиск...\ncheers:\n  um: Эм..\n  ok: OK\n  nice: Неплохо\n  good: Хорошо\n  great: Замечательно\n  excellent: Великолепно\nkeep_on: Продолжаю писать.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Донат\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Добро пожаловать на другие мои издательские каналы\naccessibility:\n  nav_toggle: Показать/скрыть меню\n  prev_page: Предыдущая страница\n  next_page: Следующая страница\nsymbols_count_time:\n  count: Кол-во символов в статье\n  count_total: Общее кол-во символов\n  time: Время чтения\n  time_total: Общее время чтения\n  time_minutes: мин.\n"
  },
  {
    "path": "languages/tr.yml",
    "content": "---\nname: Türk\ntitle:\n  archive: Arşiv\n  category: Kategori\n  tag: Etiket\n  schedule: Program\nmenu:\n  home: Ana Sayfa\n  archives: Arşivler\n  categories: Kategoriler\n  tags: Etiketler\n  about: Hakkımda\n  search: Ara\n  schedule: Program\n  sitemap: Site Haritası\n  commonweal: Hata 404\nsidebar:\n  overview: Genel Bakış\n  toc: İçindekiler\npost:\n  posted: Yayınlandı\n  edited: Düzenlendi\n  created: Oluşturuldu\n  modified: Değiştirildi\n  edit: Bu gönderiyi düzenle\n  in: İçinde\n  read_more: Daha fazla oku\n  untitled: Başlıksız\n  sticky: Sabit\n  views: Görünümler\n  related_posts: İlgili Gönderiler\n  copyright:\n    author: Gönderiyi yazan\n    link: Gönderi bağlantısı\n    license_title: Telif Hakkı Bildirimi\n    license_content: \"Bu blogdaki tüm makaleler aksi belirtilmediği sürece %s altında lisanslıdır.\"\nfooter:\n  powered: \"%s tarafından desteklenmektedir\"\n  total_views: Toplam görüntülenme\n  total_visitors: Toplam Ziyaretçi\ncounter:\n  tag_cloud:\n    zero: Etiket yok\n    one: Toplam 1 etiket\n    other: \"Toplamda %d etiket\"\n  categories:\n    zero: Kategori yok\n    one: Toplamda 1 kategori\n    other: \"Toplamda %d kategori\"\n  archive_posts:\n    zero: Gönderi yok.\n    one: 1 gönderi.\n    other: \"Toplamda %d gönderi.\"\nstate:\n  posts: gönderiler\n  tags: etiketler\n  categories: kategoriler\nsearch:\n  placeholder: Aranıyor...\ncheers:\n  um: Um..\n  ok: Tamam\n  nice: Güzel\n  good: İyi\n  great: Müthiş\n  excellent: Mükemmel\nkeep_on: Gönderiye devam.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Bağış\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Welcome to my other publishing channels\naccessibility:\n  nav_toggle: Gezinti çubuğunu değiştir\n  prev_page: Önceki sayfa\n  next_page: Sonraki sayfa\nsymbols_count_time:\n  count: Makalede sayılan semboller\n  count_total: Sayılan toplam semboller\n  time: Okuma Süresi\n  time_total: Toplamda Okuma Süresi\n  time_minutes: dk.\n"
  },
  {
    "path": "languages/uk.yml",
    "content": "---\nname: Український\ntitle:\n  archive: Архів\n  category: Категорія\n  tag: Тег\n  schedule: Календар\nmenu:\n  home: Головна\n  archives: Архів\n  categories: Категорії\n  tags: Теги\n  about: Про сайт\n  search: Пошук\n  schedule: Календар\n  sitemap: Карта сайту\n  commonweal: Сторінка 404\nsidebar:\n  overview: Огляд\n  toc: Зміст\npost:\n  posted: Опубліковано\n  edited: Змінено\n  created: Створено\n  modified: Змінено\n  edit: Редагувати запис\n  in: в категорії\n  read_more: Читати повністю\n  untitled: Без імені\n  sticky: Посилання\n  views: Переглядів\n  related_posts: Схожі записи\n  copyright:\n    author: Автор запису\n    link: Посилання на запис\n    license_title: Інформація про авторські права\n    license_content: \"Всі записи на цьому сайті захищені ліцензією %s, якщо не вказано додатково.\"\nfooter:\n  powered: \"Генератор — %s\"\n  total_views: Всього переглядів\n  total_visitors: Всього відвідувачів\ncounter:\n  tag_cloud:\n    zero: Немає тегів.\n    one: 1 тег.\n    other: \"%d тегів всього.\"\n  categories:\n    zero: Немає категорій.\n    one: 1 категорія.\n    other: \"%d категорій всього.\"\n  archive_posts:\n    zero: Немає записів.\n    one: 1 запис.\n    other: \"%d записів всього.\"\nstate:\n  posts: Архів\n  tags: Теги\n  categories: Категорії\nsearch:\n  placeholder: Пошук...\ncheers:\n  um: Ем..\n  ok: ОК\n  nice: Не погано\n  good: Добре\n  great: Чудово\n  excellent: Прекрасно\nkeep_on: Продовжую писати.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Донат\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: PayPal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Мої інші видавничі канали\naccessibility:\n  nav_toggle: Показати/приховати меню\n  prev_page: Попередня сторінка\n  next_page: Наступна сторінка\nsymbols_count_time:\n  count: К-сть символів в статті\n  count_total: Загальна к-сть символів\n  time: Час читання\n  time_total: Загальний час читання\n  time_minutes: хв.\n"
  },
  {
    "path": "languages/vi.yml",
    "content": "---\nname: Tiếng Việt\ntitle:\n  archive: Lưu Trữ\n  category: Phân Loại\n  tag: Thẻ\n  schedule: Danh Mục\nmenu:\n  home: Trang Chủ\n  archives: Lưu Trữ\n  categories: Đầu Mục\n  tags: Thẻ\n  about: Giới Thiệu\n  search: Tìm Kiếm\n  schedule: Danh Mục\n  sitemap: Bản đồ trang\n  commonweal: Commonwealth Act No. 404\nsidebar:\n  overview: Tổng Quan\n  toc: Mục Lục\npost:\n  posted: Tạo lúc\n  edited: Chỉnh sửa vào\n  created: Được tạo\n  modified: Được thay đổi\n  edit: Chính sửa bài viết này\n  in: Trong\n  read_more: Đọc tiếp\n  untitled: Không có tiêu đề\n  sticky: Đính\n  views: Lượt xem\n  related_posts: Các bài viết liên quan\n  copyright:\n    author: Người viết\n    link: Liên kết bài viết\n    license_title: Chú ý bản quyền\n    license_content: \"Tất cả bài viết trong blog này được đăng ký bởi %s trừ khi có thông báo bổ sung.\"\nfooter:\n  powered: \"Cung cấp bởi %s\"\n  total_views: Tổng số người xem\n  total_visitors: Tổng số truy cập\ncounter:\n  tag_cloud:\n    zero: Không có thẻ nào\n    one: có 1 thẻ tất cả\n    other: \"có %d thẻ tất cả\"\n  categories:\n    zero: Không có trong mục nào\n    one: có 1 mục tất cả\n    other: \"có %d mục tất cả\"\n  archive_posts:\n    zero: Không có bài viết.\n    one: 1 bài viết.\n    other: \"tổng số %d bài viết.\"\nstate:\n  posts: bài viết\n  tags: thẻ\n  categories: mục\nsearch:\n  placeholder: Đang tìm...\ncheers:\n  um: Um..\n  ok: Đồng Ý\n  nice: Hay\n  good: Tốt\n  great: Tuyệt vời\n  excellent: Tuyệt cú mèo\nkeep_on: Giữ tiến độ nha.\nsymbol:\n  comma: \", \"\n  period: \". \"\n  colon: \": \"\nreward:\n  donate: Tài trợ\n  wechatpay: WeChat Pay\n  alipay: Alipay\n  paypal: Paypal\n  bitcoin: Bitcoin\nfollow_me:\n  welcome: Xin chào mừng đến với các kênh khác của tôi\naccessibility:\n  nav_toggle: Thanh điều hướng chuyển đổi\n  prev_page: Trang trước\n  next_page: Trang sau\nsymbols_count_time:\n  count: Số biểu tượng trong bài viết\n  count_total: Tổng số biểu tượng\n  time: Thời lượng đọc\n  time_total: Tổng thời lượng đọc\n  time_minutes: phút.\n"
  },
  {
    "path": "languages/zh-CN.yml",
    "content": "---\nname: 简体中文\ntitle:\n  archive: 归档\n  category: 分类\n  tag: 标签\n  schedule: 日程表\nmenu:\n  home: 首页\n  archives: 归档\n  categories: 分类\n  tags: 标签\n  about: 关于\n  search: 搜索\n  schedule: 日程表\n  sitemap: 站点地图\n  commonweal: 公益 404\nsidebar:\n  overview: 站点概览\n  toc: 文章目录\npost:\n  posted: 发表于\n  edited: 更新于\n  created: 创建时间\n  modified: 修改时间\n  edit: 编辑\n  in: 分类于\n  read_more: 阅读全文\n  untitled: 未命名\n  sticky: 置顶\n  views: 阅读次数\n  related_posts: 相关文章\n  copyright:\n    author: 本文作者\n    link: 本文链接\n    license_title: 版权声明\n    license_content: \"本博客所有文章除特别声明外，均采用 %s 许可协议。转载请注明出处！\"\nfooter:\n  powered: \"由 %s 强力驱动\"\n  total_views: 总访问量\n  total_visitors: 总访客量\ncounter:\n  tag_cloud:\n    zero: 暂无标签\n    one: 目前共计 1 个标签\n    other: \"目前共计 %d 个标签\"\n  categories:\n    zero: 暂无分类\n    one: 目前共计 1 个分类\n    other: \"目前共计 %d 个分类\"\n  archive_posts:\n    zero: 暂无日志。\n    one: 目前共计 1 篇日志。\n    other: \"目前共计 %d 篇日志。\"\nstate:\n  posts: 日志\n  tags: 标签\n  categories: 分类\nsearch:\n  placeholder: 搜索...\ncheers:\n  um: 嗯..\n  ok: 还行\n  nice: 不错\n  good: 很好\n  great: 非常好\n  excellent: 太棒了\nkeep_on: 继续努力。\nsymbol:\n  comma: \"，\"\n  period: \"。\"\n  colon: \"：\"\nreward:\n  donate: 打赏\n  wechatpay: 微信支付\n  alipay: 支付宝\n  paypal: 贝宝\n  bitcoin: 比特币\nfollow_me:\n  welcome: 欢迎关注我的其它发布渠道\naccessibility:\n  nav_toggle: 切换导航栏\n  prev_page: 上一页\n  next_page: 下一页\nsymbols_count_time:\n  count: 本文字数\n  count_total: 站点总字数\n  time: 阅读时长\n  time_total: 站点阅读时长\n  time_minutes: 分钟\n"
  },
  {
    "path": "languages/zh-HK.yml",
    "content": "---\nname: 繁體中文（香港）\ntitle:\n  archive: 歸檔\n  category: 分類\n  tag: 標籤\n  schedule: 日程表\nmenu:\n  home: 首頁\n  archives: 歸檔\n  categories: 分類\n  tags: 標籤\n  about: 關於\n  search: 檢索\n  schedule: 日程表\n  sitemap: 站點地圖\n  commonweal: 公益 404\nsidebar:\n  overview: 本站概覽\n  toc: 文章目錄\npost:\n  posted: 發表於\n  edited: 更新於\n  created: 創建時間\n  modified: 修改時間\n  edit: 編輯\n  in: 分類於\n  read_more: 閱讀全文\n  untitled: 未命名\n  sticky: 置頂\n  views: 閱讀次數\n  related_posts: 相關文章\n  copyright:\n    author: 博主\n    link: 文章連結\n    license_title: 版權聲明\n    license_content: \"本網誌所有文章除特別聲明外，均採用 %s 許可協議。轉載請註明出處！\"\nfooter:\n  powered: \"由 %s 強力驅動\"\n  total_views: 總瀏覽次數\n  total_visitors: 訪客總數\ncounter:\n  tag_cloud:\n    zero: 暫無標籤\n    one: 目前共有 1 個標籤\n    other: \"目前共有 %d 個標籤\"\n  categories:\n    zero: 暫無分類\n    one: 目前共有 1 個分類\n    other: \"目前共有 %d 個分類\"\n  archive_posts:\n    zero: 暫無文章。\n    one: 目前共有 1 篇文章。\n    other: \"目前共有 %d 篇文章。\"\nstate:\n  posts: 文章\n  tags: 標籤\n  categories: 分類\nsearch:\n  placeholder: 搜索...\ncheers:\n  um: 嗯..\n  ok: 還行\n  nice: 好\n  good: 很好\n  great: 非常好\n  excellent: 太棒了\nkeep_on: 繼續努力。\nsymbol:\n  comma: \"，\"\n  period: \"。\"\n  colon: \"：\"\nreward:\n  donate: 打賞\n  wechatpay: 微信支付\n  alipay: 支付寶\n  paypal: PayPal\n  bitcoin: 比特幣\nfollow_me:\n  welcome: 歡迎關注我的其它發布渠道\naccessibility:\n  nav_toggle: 切換導航欄\n  prev_page: 上一頁\n  next_page: 下一頁\nsymbols_count_time:\n  count: 本文字數\n  count_total: 站點總字數\n  time: 閱讀時長\n  time_total: 站點閱讀時長\n  time_minutes: 分鍾\n"
  },
  {
    "path": "languages/zh-TW.yml",
    "content": "---\nname: 繁體中文\ntitle:\n  archive: 歸檔\n  category: 分類\n  tag: 標籤\n  schedule: 時間表\nmenu:\n  home: 首頁\n  archives: 歸檔\n  categories: 分類\n  tags: 標籤\n  about: 關於\n  search: 搜尋\n  schedule: 時間表\n  sitemap: 網站地圖\n  commonweal: 公益 404\nsidebar:\n  overview: 本站概要\n  toc: 文章目錄\npost:\n  posted: 發表於\n  edited: 更新於\n  created: 創建時間\n  modified: 修改時間\n  edit: 編輯\n  in: 分類於\n  read_more: 閱讀全文\n  untitled: 未命名\n  sticky: 置頂\n  views: 閱讀次數\n  related_posts: 相關文章\n  copyright:\n    author: 作者\n    link: 文章連結\n    license_title: 版權聲明\n    license_content: \"本網誌所有文章除特別聲明外，均採用 %s 許可協議。轉載請註明出處！\"\nfooter:\n  powered: \"由 %s 強力驅動\"\n  total_views: 總瀏覽次數\n  total_visitors: 訪客總數\ncounter:\n  tag_cloud:\n    zero: 沒有標籤\n    one: 目前共有 1 個標籤\n    other: \"目前共有 %d 個標籤\"\n  categories:\n    zero: 沒有分類\n    one: 目前共有 1 個分類\n    other: \"目前共有 %d 個分類\"\n  archive_posts:\n    zero: 沒有文章。\n    one: 目前共有 1 篇文章。\n    other: \"目前共有 %d 篇文章。\"\nstate:\n  posts: 文章\n  tags: 標籤\n  categories: 分類\nsearch:\n  placeholder: 搜尋...\ncheers:\n  um: 嗯..\n  ok: 還行\n  nice: 好\n  good: 很好\n  great: 非常好\n  excellent: 太棒了\nkeep_on: 繼續努力。\nsymbol:\n  comma: \"，\"\n  period: \"。\"\n  colon: \"：\"\nreward:\n  donate: 捐贈\n  wechatpay: 微信支付\n  alipay: 支付寶\n  paypal: PayPal\n  bitcoin: 比特幣\nfollow_me:\n  welcome: 歡迎關注我的其它發布渠道\naccessibility:\n  nav_toggle: 切換導航欄\n  prev_page: 上一頁\n  next_page: 下一頁\nsymbols_count_time:\n  count: 文章字數\n  count_total: 總字數\n  time: 所需閱讀時間\n  time_total: 所需總閱讀時間\n  time_minutes: 分鐘\n"
  },
  {
    "path": "layout/_layout.swig",
    "content": "<!DOCTYPE html>\n<html lang=\"{{ config.language }}\">\n<head>\n  {{ partial('_partials/head/head.swig', {}, {cache: theme.cache.enable}) }}\n  {% include '_partials/head/head-unique.swig' %}\n  {{- next_inject('head') }}\n  <title>{% block title %}{% endblock %}</title>\n  {{ partial('_third-party/analytics/index.swig', {}, {cache: theme.cache.enable}) }}\n  {{ partial('_scripts/noscript.swig', {}, {cache: theme.cache.enable}) }}\n</head>\n\n<body itemscope itemtype=\"http://schema.org/WebPage\">\n  <div class=\"container{%- if theme.motion.enable %} use-motion{%- endif %}\">\n    <div class=\"headband\"></div>\n\n    <header class=\"header\" itemscope itemtype=\"http://schema.org/WPHeader\">\n      <div class=\"header-inner\">{% include '_partials/header/index.swig' %}</div>\n    </header>\n\n    {{ partial('_partials/widgets.swig', {}, {cache: theme.cache.enable}) }}\n\n    <main class=\"main\">\n      <div class=\"main-inner\">\n        <div class=\"content-wrap\">\n          {% include '_partials/header/sub-menu.swig' %}\n          <div class=\"content {% block class %}{% endblock %}\">\n            {% block content %}{% endblock %}\n          </div>\n          {% include '_partials/comments.swig' %}\n        </div>\n        {%- if theme.sidebar.display !== 'remove' %}\n          {% block sidebar %}{% endblock %}\n        {%- endif %}\n      </div>\n    </main>\n\n    <footer class=\"footer\">\n      <div class=\"footer-inner\">\n        {% include '_partials/languages.swig' %}\n        {{ partial('_partials/footer.swig', {}, {cache: theme.cache.enable}) }}\n        {{ partial('_third-party/statistics/index.swig', {}, {cache: theme.cache.enable}) }}\n      </div>\n    </footer>\n  </div>\n\n  {{ partial('_scripts/index.swig', {}, {cache: theme.cache.enable}) }}\n  {{ partial('_third-party/index.swig', {}, {cache: theme.cache.enable}) }}\n\n  {%- if theme.pjax %}\n    <div id=\"pjax\">\n  {%- endif %}\n  {% include '_third-party/math/index.swig' %}\n  {% include '_third-party/quicklink.swig' %}\n\n  {{- next_inject('bodyEnd') }}\n  {%- if theme.pjax %}\n    </div>\n  {%- endif %}\n</body>\n</html>\n"
  },
  {
    "path": "layout/_macro/post-collapse.swig",
    "content": "{% macro render(posts) %}\n{%- set current_year = '1970' %}\n{%- for post in posts.toArray() %}\n\n  {%- set year = date(post.date, 'YYYY') %}\n\n  {%- if year !== current_year %}\n    {%- set current_year = year %}\n    <div class=\"collection-year\">\n      <span class=\"collection-header\">{{ current_year }}</span>\n    </div>\n  {%- endif %}\n\n  <article itemscope itemtype=\"http://schema.org/Article\">\n    <header class=\"post-header\">\n\n      <div class=\"post-meta\">\n        <time itemprop=\"dateCreated\"\n              datetime=\"{{ moment(post.date).format() }}\"\n              content=\"{{ date(post.date, config.date_format) }}\">\n          {{ date(post.date, 'MM-DD') }}\n        </time>\n      </div>\n\n      <div class=\"post-title\">\n        {%- if post.link %}{# Link posts #}\n          {%- set postTitleIcon = '<i class=\"fa fa-external-link-alt\"></i>' %}\n          {%- set postText = post.title or post.link %}\n          {{ next_url(post.link, postText + postTitleIcon, {class: 'post-title-link post-title-link-external', itemprop: 'url'}) }}\n        {% else %}\n          <a class=\"post-title-link\" href=\"{{ url_for(post.path) }}\" itemprop=\"url\">\n            <span itemprop=\"name\">{{ post.title or __('post.untitled') }}</span>\n          </a>\n        {%- endif %}\n      </div>\n\n    </header>\n  </article>\n\n{%- endfor %}\n{% endmacro %}\n"
  },
  {
    "path": "layout/_macro/post.swig",
    "content": "  {##################}\n  {### POST BLOCK ###}\n  {##################}\n  <article itemscope itemtype=\"http://schema.org/Article\" class=\"post-block\" lang=\"{{ post.lang or config.language }}\">\n    <link itemprop=\"mainEntityOfPage\" href=\"{{ post.permalink }}\">\n\n    <span hidden itemprop=\"author\" itemscope itemtype=\"http://schema.org/Person\">\n      <meta itemprop=\"image\" content=\"{{ url_for(theme.avatar.url or theme.images + '/avatar.gif') }}\">\n      <meta itemprop=\"name\" content=\"{{ author }}\">\n      <meta itemprop=\"description\" content=\"{{ description }}\">\n    </span>\n\n    <span hidden itemprop=\"publisher\" itemscope itemtype=\"http://schema.org/Organization\">\n      <meta itemprop=\"name\" content=\"{{ title }}\">\n    </span>\n\n    {%- if post.header !== false %}\n      <header class=\"post-header\">\n        <{%- if is_index %}h2{% else %}h1{%- endif %} class=\"post-title{%- if post.direction and post.direction.toLowerCase() === 'rtl' %} rtl{%- endif %}\" itemprop=\"name headline\">\n          {# Link posts #}\n          {%- if post.link %}\n            {%- if post.sticky > 0 %}\n              <span class=\"post-sticky-flag\" title=\"{{ __('post.sticky') }}\">\n                <i class=\"fa fa-thumbtack\"></i>\n              </span>\n            {%- endif %}\n            {%- set postTitleIcon = '<i class=\"fa fa-external-link-alt\"></i>' %}\n            {%- set postText = post.title or post.link %}\n            {{ next_url(post.link, postText + postTitleIcon, {class: 'post-title-link post-title-link-external', itemprop: 'url'}) }}\n          {% elif is_index %}\n            {%- if post.sticky > 0 %}\n              <span class=\"post-sticky-flag\" title=\"{{ __('post.sticky') }}\">\n                <i class=\"fa fa-thumbtack\"></i>\n              </span>\n            {%- endif %}\n            {{ next_url(post.path, post.title or __('post.untitled'), {class: 'post-title-link', itemprop: 'url'}) }}\n          {%- else %}\n            {{- post.title }}\n            {{- post_edit(post.source) }}\n          {%- endif %}\n        </{%- if is_index %}h2{% else %}h1{%- endif %}>\n\n        <div class=\"post-meta\">\n\n          {%- set date_diff = date(post.date) != date(post.updated) %}\n          {%- set time_diff = time(post.date) != time(post.updated) %}\n          {%- set datetime_diff = date_diff or time_diff %}\n\n          {%- if theme.post_meta.created_at %}\n            <span class=\"post-meta-item\">\n              <span class=\"post-meta-item-icon\">\n                <i class=\"far fa-calendar\"></i>\n              </span>\n              <span class=\"post-meta-item-text\">{{ __('post.posted') }}</span>\n\n              {%- if not date_diff and time_diff and theme.post_meta.updated_at.enable and theme.post_meta.updated_at.another_day %}\n                {%- set create_title = __('post.created') + __('symbol.colon') + full_date(post.date) + ' / ' + __('post.modified') + __('symbol.colon') + time(post.updated) %}\n              {% else %}\n                {%- set create_title = __('post.created') + __('symbol.colon') + full_date(post.date) %}\n              {%- endif %}\n\n              <time title=\"{{ create_title }}\" itemprop=\"dateCreated datePublished\" datetime=\"{{ moment(post.date).format() }}\">{{ date(post.date) }}</time>\n            </span>\n          {%- endif %}\n\n          {%- if theme.post_meta.updated_at.enable and datetime_diff %}\n            {%- set display_updated = not theme.post_meta.updated_at.another_day or theme.post_meta.updated_at.another_day and date_diff %}\n\n            {%- if display_updated or not theme.post_meta.created_at %}\n              <span class=\"post-meta-item\">\n                <span class=\"post-meta-item-icon\">\n                  <i class=\"far fa-calendar-check\"></i>\n                </span>\n                <span class=\"post-meta-item-text\">{{ __('post.edited') }}</span>\n                <time title=\"{{ __('post.modified') + __('symbol.colon') + full_date(post.updated) }}\" itemprop=\"dateModified\" datetime=\"{{ moment(post.updated).format() }}\">{{ date(post.updated) }}</time>\n              </span>\n            {%- endif %}\n          {%- endif %}\n\n          {%- if post.categories and post.categories.length and theme.post_meta.categories %}\n            <span class=\"post-meta-item\">\n              <span class=\"post-meta-item-icon\">\n                <i class=\"far fa-folder\"></i>\n              </span>\n              <span class=\"post-meta-item-text\">{{ __('post.in') }}</span>\n              {%- for cat in post.categories.toArray() %}\n                <span itemprop=\"about\" itemscope itemtype=\"http://schema.org/Thing\">\n                  <a href=\"{{ url_for(cat.path) }}\" itemprop=\"url\" rel=\"index\"><span itemprop=\"name\">{{ cat.name }}</span></a>\n                </span>\n\n                {%- set cat_length = post.categories.length %}\n                {%- if cat_length > 1 and loop.index !== cat_length %}\n                  {{ __('symbol.comma') }}\n                {%- endif %}\n              {%- endfor %}\n            </span>\n          {%- endif %}\n\n          {# LeanCloud PageView #}\n          {%- if theme.leancloud_visitors.enable or (theme.valine.enable and theme.valine.appid and theme.valine.appkey and theme.valine.visitor) %}\n            <span id=\"{{ url_for(post.path) }}\" class=\"post-meta-item leancloud_visitors\" data-flag-title=\"{{ post.title }}\" title=\"{{ __('post.views') }}\">\n              <span class=\"post-meta-item-icon\">\n                <i class=\"fa fa-eye\"></i>\n              </span>\n              <span class=\"post-meta-item-text\">{{ __('post.views') + __('symbol.colon') }}</span>\n              <span class=\"leancloud-visitors-count\"></span>\n            </span>\n          {%- endif %}\n\n          {%- if theme.firestore.enable %}\n            <span class=\"post-meta-item\" title=\"{{ __('post.views') }}\">\n              <span class=\"post-meta-item-icon\">\n                <i class=\"fa fa-users\"></i>\n              </span>\n              <span class=\"post-meta-item-text\">{{ __('post.views') + __('symbol.colon') }}</span>\n              <span class=\"firestore-visitors-count\"></span>\n            </span>\n          {%- endif %}\n\n          {%- if not is_index and theme.busuanzi_count.enable and theme.busuanzi_count.post_views %}\n            <span class=\"post-meta-item\" title=\"{{ __('post.views') }}\" id=\"busuanzi_container_page_pv\" style=\"display: none;\">\n              <span class=\"post-meta-item-icon\">\n                <i class=\"{{ theme.busuanzi_count.post_views_icon }}\"></i>\n              </span>\n              <span class=\"post-meta-item-text\">{{ __('post.views') + __('symbol.colon') }}</span>\n              <span id=\"busuanzi_value_page_pv\"></span>\n            </span>\n          {%- endif %}\n\n          {{- next_inject('postMeta') }}\n\n          {%- if config.symbols_count_time.symbols %}\n          {%- if theme.symbols_count_time.separated_meta %}<br>{%- endif %}\n            <span class=\"post-meta-item\" title=\"{{ __('symbols_count_time.count') }}\">\n              <span class=\"post-meta-item-icon\">\n                <i class=\"far fa-file-word\"></i>\n              </span>\n              {%- if theme.symbols_count_time.item_text_post %}\n                <span class=\"post-meta-item-text\">{{ __('symbols_count_time.count') + __('symbol.colon') }}</span>\n              {%- endif %}\n              <span>{{ symbolsCount(post) }}</span>\n            </span>\n          {%- endif %}\n\n          {%- if config.symbols_count_time.time %}\n            <span class=\"post-meta-item\" title=\"{{ __('symbols_count_time.time') }}\">\n              <span class=\"post-meta-item-icon\">\n                <i class=\"far fa-clock\"></i>\n              </span>\n              {%- if theme.symbols_count_time.item_text_post %}\n                <span class=\"post-meta-item-text\">{{ __('symbols_count_time.time') }} &asymp;</span>\n              {%- endif %}\n              <span>{{ symbolsTime(post, config.symbols_count_time.awl, config.symbols_count_time.wpm, __('symbols_count_time.time_minutes')) }}</span>\n            </span>\n          {%- endif %}\n\n          {%- if post.description and (not theme.excerpt_description or not is_index) %}\n            <div class=\"post-description\">{{ post.description }}</div>\n          {%- endif %}\n\n        </div>\n      </header>\n    {%- endif %}\n\n    {#################}\n    {### POST BODY ###}\n    {#################}\n    <div class=\"post-body{%- if post.direction and post.direction.toLowerCase() === 'rtl' %} rtl{%- endif %}\" itemprop=\"articleBody\">\n\n      {# Gallery support #}\n      {%- if post.photos and post.photos.length %}\n        <div class=\"post-gallery\" itemscope itemtype=\"http://schema.org/ImageGallery\">\n          {%- for photo in post.photos %}\n            <img src=\"{{ url_for(photo) }}\" itemprop=\"contentUrl\">\n          {%- endfor %}\n        </div>\n      {%- endif %}\n\n      {%- if is_index %}\n        {%- if post.description and theme.excerpt_description %}\n          <p>{{ post.description }}</p>\n          <!--noindex-->\n          {%- if theme.read_more_btn %}\n            <div class=\"post-button\">\n              <a class=\"btn\" href=\"{{ url_for(post.path) }}\">\n                {{ __('post.read_more') }} &raquo;\n              </a>\n            </div>\n          {%- endif %}\n          <!--/noindex-->\n        {% elif post.excerpt %}\n          {{ post.excerpt }}\n          <!--noindex-->\n          {%- if theme.read_more_btn %}\n            <div class=\"post-button\">\n              <a class=\"btn\" href=\"{{ url_for(post.path) }}#more\" rel=\"contents\">\n                {{ __('post.read_more') }} &raquo;\n              </a>\n            </div>\n          {%- endif %}\n          <!--/noindex-->\n        {% else %}\n          {{ post.content }}\n        {%- endif %}\n      {% else %}\n        {{ post.content }}\n      {%- endif %}\n    </div>\n\n    {#####################}\n    {### END POST BODY ###}\n    {#####################}\n\n    {%- if theme.related_posts.enable and (theme.related_posts.display_in_home or not is_index) %}\n      {{ partial('_partials/post/post-related.swig') }}\n    {%- endif %}\n\n    {%- if not is_index %}\n      {{- next_inject('postBodyEnd') }}\n\n      {%- if post.reward_settings.enable %}\n        {{ partial('_partials/post/post-reward.swig') }}\n      {%- endif %}\n\n      {%- if theme.creative_commons.license and theme.creative_commons.post %}\n        {{ partial('_partials/post/post-copyright.swig') }}\n      {%- endif %}\n\n      {%- if theme.follow_me %}\n        {{ partial('_partials/post/post-followme.swig', {}, {cache: theme.cache.enable}) }}\n      {%- endif %}\n\n      <footer class=\"post-footer\">\n        {%- if post.tags and post.tags.length %}\n          {%- if theme.tag_icon %}\n            {%- set tag_indicate = '<i class=\"fa fa-tag\"></i>' %}\n          {% else %}\n            {%- set tag_indicate = '#' %}\n          {%- endif %}\n          <div class=\"post-tags\">\n            {%- for tag in post.tags.toArray() %}\n              <a href=\"{{ url_for(tag.path) }}\" rel=\"tag\">{{ tag_indicate }} {{ tag.name }}</a>\n            {%- endfor %}\n          </div>\n        {%- endif %}\n\n        {{ partial('_partials/post/post-footer.swig', {}, {cache: theme.cache.enable}) }}\n\n        {{ post_nav(post) }}\n      </footer>\n    {% else %}\n      <footer class=\"post-footer\">\n        <div class=\"post-eof\"></div>\n      </footer>\n    {%- endif %}\n  </article>\n  {######################}\n  {### END POST BLOCK ###}\n  {######################}\n"
  },
  {
    "path": "layout/_macro/sidebar.swig",
    "content": "{% macro render(display_toc) %}\n  <div class=\"toggle sidebar-toggle\">\n    <span class=\"toggle-line toggle-line-first\"></span>\n    <span class=\"toggle-line toggle-line-middle\"></span>\n    <span class=\"toggle-line toggle-line-last\"></span>\n  </div>\n\n  <aside class=\"sidebar\">\n    <div class=\"sidebar-inner\">\n\n      {%- set display_toc = page.toc.enable and display_toc %}\n      {%- if display_toc %}\n        {%- set toc = toc(page.content, { class: \"nav\", list_number: page.toc.number, max_depth: page.toc.max_depth }) %}\n        {%- set display_toc = toc.length > 1 and display_toc %}\n      {%- endif %}\n\n      <ul class=\"sidebar-nav motion-element\">\n        <li class=\"sidebar-nav-toc\">\n          {{ __('sidebar.toc') }}\n        </li>\n        <li class=\"sidebar-nav-overview\">\n          {{ __('sidebar.overview') }}\n        </li>\n      </ul>\n\n      <!--noindex-->\n      <div class=\"post-toc-wrap sidebar-panel\">\n        {%- if display_toc %}\n          <div class=\"post-toc motion-element\">{{ toc }}</div>\n        {%- endif %}\n      </div>\n      <!--/noindex-->\n\n      <div class=\"site-overview-wrap sidebar-panel\">\n        {{ partial('_partials/sidebar/site-overview.swig', {}, {cache: theme.cache.enable}) }}\n\n        {{- next_inject('sidebar') }}\n      </div>\n\n      {%- if theme.back2top.enable and theme.back2top.sidebar %}\n        <div class=\"back-to-top motion-element\">\n          <i class=\"fa fa-arrow-up\"></i>\n          <span>0%</span>\n        </div>\n      {%- endif %}\n\n    </div>\n  </aside>\n  <div id=\"sidebar-dimmer\"></div>\n{% endmacro %}\n"
  },
  {
    "path": "layout/_partials/comments.swig",
    "content": "{%- if page.comments %}\n  {%- if theme.injects.comment.length == 1 %}\n    {%- set inject_item = theme.injects.comment[0] %}\n    {{ partial(inject_item.layout, inject_item.locals, inject_item.options) }}\n  {%- elif theme.injects.comment.length > 1 %}\n    {%- if theme.comments.style == 'buttons' %}\n      <div class=\"comment-button-group\">\n        {%- for inject_item in theme.injects.comment %}\n          <a class=\"btn comment-button {{ inject_item.locals.class }}\">{{ inject_item.locals.button }}</a>\n        {%- endfor %}\n      </div>\n      {%- for inject_item in theme.injects.comment %}\n        <div class=\"comment-position {{ inject_item.locals.class }}\">\n          {{ partial(inject_item.layout, inject_item.locals, inject_item.options) }}\n        </div>\n      {%- endfor %}\n      <script{{ pjax }}>\n        (function() {\n          let commentButton = document.querySelectorAll('.comment-button');\n            commentButton.forEach(element => {\n            let commentClass = element.classList[2];\n            element.addEventListener('click', () => {\n              commentButton.forEach(rmActive => rmActive.classList.remove('active'));\n              element.classList.add('active');\n              document.querySelectorAll('.comment-position').forEach(rmActive => rmActive.classList.remove('active'));\n              document.querySelector(`.comment-position.${commentClass}`).classList.add('active');\n              if (CONFIG.comments.storage) {\n                localStorage.setItem('comments_active', commentClass);\n              }\n            });\n          });\n          let { activeClass } = CONFIG.comments;\n          if (CONFIG.comments.storage) {\n            activeClass = localStorage.getItem('comments_active') || activeClass;\n          }\n          if (activeClass) {\n            let activeButton = document.querySelector(`.comment-button.${activeClass}`);\n            if (activeButton) {\n              activeButton.click();\n            }\n          }\n        })();\n      </script>\n    {%- elif theme.comments.style == 'tabs' %}\n      <div class=\"tabs tabs-comment\">\n        <ul class=\"nav-tabs\">\n          {%- for inject_item in theme.injects.comment %}\n            <li class=\"tab\"><a href=\"#comment-{{ inject_item.locals.class }}\">{{ inject_item.locals.button }}</a></li>\n          {%- endfor %}\n        </ul>\n        <div class=\"tab-content\">\n          {%- for inject_item in theme.injects.comment %}\n            <div class=\"tab-pane {{ inject_item.locals.class }}\" id=\"comment-{{ inject_item.locals.class }}\">\n              {{ partial(inject_item.layout, inject_item.locals, inject_item.options) }}\n            </div>\n          {%- endfor %}\n        </div>\n      </div>\n    {%- endif %}\n  {%- endif %}\n{%- endif %}\n\n<script>\n  window.addEventListener('tabs:register', () => {\n    let { activeClass } = CONFIG.comments;\n    if (CONFIG.comments.storage) {\n      activeClass = localStorage.getItem('comments_active') || activeClass;\n    }\n    if (activeClass) {\n      let activeTab = document.querySelector(`a[href=\"#comment-${activeClass}\"]`);\n      if (activeTab) {\n        activeTab.click();\n      }\n    }\n  });\n  if (CONFIG.comments.storage) {\n    window.addEventListener('tabs:click', event => {\n      if (!event.target.matches('.tabs-comment .tab-content .tab-pane')) return;\n      let commentClass = event.target.classList[1];\n      localStorage.setItem('comments_active', commentClass);\n    });\n  }\n</script>\n"
  },
  {
    "path": "layout/_partials/footer.swig",
    "content": "{%- if theme.footer.beian.enable %}\n  <div class=\"beian\">\n    {{- next_url('https://beian.miit.gov.cn', theme.footer.beian.icp + ' ') }}\n    {%- if theme.footer.beian.gongan_icon_url %}\n      <img src=\"{{ url_for(theme.footer.beian.gongan_icon_url) }}\" style=\"display: inline-block;\">\n    {%- endif %}\n    {%- if theme.footer.beian.gongan_id and theme.footer.beian.gongan_num %}\n      {{- next_url('http://www.beian.gov.cn/portal/registerSystemInfo?recordcode=' + theme.footer.beian.gongan_id, theme.footer.beian.gongan_num + ' ') }}\n    {%- endif %}\n  </div>\n{%- endif %}\n\n<div class=\"copyright\">\n  {% set copyright_year = date(null, 'YYYY') %}\n  &copy; {% if theme.footer.since and theme.footer.since != copyright_year %}{{ theme.footer.since }} – {% endif %}\n  <span itemprop=\"copyrightYear\">{{ copyright_year }}</span>\n  <span class=\"with-love\">\n    <i class=\"{{ theme.footer.icon.name }}\"></i>\n  </span>\n  <span class=\"author\" itemprop=\"copyrightHolder\">{{ theme.footer.copyright or author }}</span>\n\n  {%- if config.symbols_count_time.total_symbols %}\n    <span class=\"post-meta-divider\">|</span>\n    <span class=\"post-meta-item-icon\">\n      <i class=\"fa fa-chart-area\"></i>\n    </span>\n    {%- if theme.symbols_count_time.item_text_total %}\n      <span class=\"post-meta-item-text\">{{ __('symbols_count_time.count_total') + __('symbol.colon') }}</span>\n    {%- endif %}\n    <span title=\"{{ __('symbols_count_time.count_total') }}\">{{ symbolsCountTotal(site) }}</span>\n  {%- endif %}\n\n  {%- if config.symbols_count_time.total_time %}\n    <span class=\"post-meta-divider\">|</span>\n    <span class=\"post-meta-item-icon\">\n      <i class=\"fa fa-coffee\"></i>\n    </span>\n    {%- if theme.symbols_count_time.item_text_total %}\n      <span class=\"post-meta-item-text\">{{ __('symbols_count_time.time_total') }} &asymp;</span>\n    {%- endif %}\n    <span title=\"{{ __('symbols_count_time.time_total') }}\">{{ symbolsTimeTotal(site, config.symbols_count_time.awl, config.symbols_count_time.wpm, __('symbols_count_time.time_minutes')) }}</span>\n  {%- endif %}\n</div>\n\n{%- if theme.footer.powered %}\n  <div class=\"powered-by\">\n    {%- set next_site = 'https://theme-next.org' %}\n    {%- if theme.scheme !== 'Gemini' %}\n      {%- set next_site = 'https://' + theme.scheme | lower + '.theme-next.org' %}\n    {%- endif %}\n    {{- __('footer.powered', next_url('https://hexo.io', 'Hexo', {class: 'theme-link'}) + ' & ' + next_url(next_site, 'NexT.' + theme.scheme, {class: 'theme-link'})) }}\n  </div>\n{%- endif %}\n\n{%- if theme.add_this_id %}\n  <div class=\"addthis_inline_share_toolbox\">\n    <script src=\"//s7.addthis.com/js/300/addthis_widget.js#pubid={{ theme.add_this_id }}\" async=\"async\"></script>\n  </div>\n{%- endif %}\n\n{{- next_inject('footer') }}\n"
  },
  {
    "path": "layout/_partials/head/head-unique.swig",
    "content": "{{ open_graph() }}\n\n{{ canonical() }}\n\n{# Exports some front-matter variables to Front-End #}\n<script id=\"page-configurations\">\n  // https://hexo.io/docs/variables.html\n  CONFIG.page = {\n    sidebar: {{ page.sidebar | json }},\n    isHome : {{ is_home() }},\n    isPost : {{ is_post() }},\n    lang   : '{{ page.lang }}'\n  };\n</script>\n"
  },
  {
    "path": "layout/_partials/head/head.swig",
    "content": "<meta charset=\"UTF-8\">\n<meta name=\"viewport\" content=\"width=device-width, initial-scale=1, maximum-scale=2\">\n<meta name=\"theme-color\" content=\"{{ theme.android_chrome_color }}\">\n<meta name=\"generator\" content=\"Hexo {{ hexo_version }}\">\n\n{%- if theme.favicon.apple_touch_icon %}\n  <link rel=\"apple-touch-icon\" sizes=\"180x180\" href=\"{{ url_for(theme.favicon.apple_touch_icon) }}\">\n{%- endif %}\n{%- if theme.favicon.medium %}\n  <link rel=\"icon\" type=\"image/png\" sizes=\"32x32\" href=\"{{ url_for(theme.favicon.medium) }}\">\n{%- endif %}\n{%- if theme.favicon.small %}\n  <link rel=\"icon\" type=\"image/png\" sizes=\"16x16\" href=\"{{ url_for(theme.favicon.small) }}\">\n{%- endif %}\n{%- if theme.favicon.safari_pinned_tab %}\n  <link rel=\"mask-icon\" href=\"{{ url_for(theme.favicon.safari_pinned_tab) }}\" color=\"{{ theme.android_chrome_color }}\">\n{%- endif %}\n{%- if theme.favicon.android_manifest %}\n  <link rel=\"manifest\" href=\"{{ url_for(theme.favicon.android_manifest) }}\">\n{%- endif %}\n{%- if theme.favicon.ms_browserconfig %}\n  <meta name=\"msapplication-config\" content=\"{{ url_for(theme.favicon.ms_browserconfig) }}\">\n{%- endif %}\n\n{%- if theme.disable_baidu_transformation %}\n  <meta http-equiv=\"Cache-Control\" content=\"no-transform\">\n  <meta http-equiv=\"Cache-Control\" content=\"no-siteapp\">\n{%- endif %}\n{%- if theme.google_site_verification %}\n  <meta name=\"google-site-verification\" content=\"{{ theme.google_site_verification }}\">\n{%- endif %}\n{%- if theme.bing_site_verification %}\n  <meta name=\"msvalidate.01\" content=\"{{ theme.bing_site_verification }}\">\n{%- endif %}\n{%- if theme.yandex_site_verification %}\n  <meta name=\"yandex-verification\" content=\"{{ theme.yandex_site_verification }}\">\n{%- endif %}\n{%- if theme.baidu_site_verification %}\n  <meta name=\"baidu-site-verification\" content=\"{{ theme.baidu_site_verification }}\">\n{%- endif %}\n\n<link rel=\"stylesheet\" href=\"{{ url_for(theme.css) }}/main.css\">\n\n{{ next_font() }}\n\n{%- set font_awesome_uri = theme.vendors.fontawesome or next_vendors('font-awesome/css/all.min.css') %}\n<link rel=\"stylesheet\" href=\"{{ font_awesome_uri }}\">\n\n{%- if theme.fancybox %}\n  {%- set fancybox_css_uri = theme.vendors.fancybox_css or next_vendors('//cdn.jsdelivr.net/gh/fancyapps/fancybox@3/dist/jquery.fancybox.min.css') %}\n  <link rel=\"stylesheet\" href=\"{{ fancybox_css_uri }}\">\n{%- endif %}\n\n{%- if theme.pace.enable %}\n  {%- set pace_css_uri = theme.vendors.pace_css or next_vendors('pace/pace-theme-' + theme.pace.theme + '.min.css') %}\n  {%- set pace_js_uri = theme.vendors.pace or next_vendors('pace/pace.min.js') %}\n  <link rel=\"stylesheet\" href=\"{{ pace_css_uri }}\">\n  <script src=\"{{ pace_js_uri }}\"></script>\n{%- endif %}\n\n{{ next_config() }}\n"
  },
  {
    "path": "layout/_partials/header/brand.swig",
    "content": "<div class=\"site-brand-container\">\n  <div class=\"site-nav-toggle\">\n    <div class=\"toggle\" aria-label=\"{{ __('accessibility.nav_toggle') }}\">\n      <span class=\"toggle-line toggle-line-first\"></span>\n      <span class=\"toggle-line toggle-line-middle\"></span>\n      <span class=\"toggle-line toggle-line-last\"></span>\n    </div>\n  </div>\n\n  <div class=\"site-meta{%- if theme.custom_logo %} custom-logo{%- endif %}\">\n    {%- if theme.custom_logo and theme.scheme === 'Muse' %}\n      <div class=\"site-meta-headline\">\n        <a>\n          <img class=\"custom-logo-image\" src=\"{{ theme.custom_logo }}\" alt=\"{{ title }}\">\n        </a>\n      </div>\n    {%- endif %}\n\n    <a href=\"{{ config.root }}\" class=\"brand\" rel=\"start\">\n      <span class=\"logo-line-before\"><i></i></span>\n      <h1 class=\"site-title\">{{ title }}</h1>\n      <span class=\"logo-line-after\"><i></i></span>\n    </a>\n    {%- if subtitle %}\n      <p class=\"site-subtitle\" itemprop=\"description\">{{ subtitle }}</p>\n    {%- endif %}\n    {%- if theme.custom_logo and (theme.scheme === 'Gemini' or theme.scheme === 'Pisces') %}\n      <a>\n        <img class=\"custom-logo-image\" src=\"{{ theme.custom_logo }}\" alt=\"{{ title }}\">\n      </a>\n    {%- endif %}\n  </div>\n\n  <div class=\"site-nav-right\">\n    <div class=\"toggle popup-trigger\">\n      {%- if theme.algolia_search.enable or theme.local_search.enable %}\n        <i class=\"fa fa-search fa-fw fa-lg\"></i>\n      {%- endif %}\n    </div>\n  </div>\n</div>\n"
  },
  {
    "path": "layout/_partials/header/index.swig",
    "content": "{{ partial('_partials/header/brand.swig', {}, {cache: theme.cache.enable}) }}\n\n{{ partial('_partials/header/menu.swig', {}, {cache: theme.cache.enable}) }}\n\n{{ partial('_partials/search/index.swig', {}, {cache: theme.cache.enable}) }}\n\n{{- next_inject('header') }}\n"
  },
  {
    "path": "layout/_partials/header/menu-item.swig",
    "content": "{% macro render(name, itemName, value) %}\n\n  {%- set itemURL = value.split('||')[0] | trim %}\n  {%- if not itemURL.startsWith('http') %}\n    {%- set itemURL = itemURL | replace('//', '/') %}\n  {%- endif %}\n  <li class=\"menu-item menu-item-{{ itemName | replace(' ', '-') }}\">\n\n    {%- set menuIcon = '' %}\n    {%- if theme.menu_settings.icons %}\n      {%- set menuIcon = '<i class=\"' + value.split('||')[1] | trim + ' fa-fw\"></i>' %}\n    {%- endif %}\n    {%- set menuText = __('menu.' + name) | replace('menu.', '') %}\n\n    {%- set menuBadge = '' %}\n    {%- if theme.menu_settings.badges %}\n      {%- set badges = {\n        archives  : site.posts.length,\n        categories: site.categories.length,\n        tags      : site.tags.length\n        }\n      %}\n      {%- for menu, count in badges %}\n        {%- if name == menu %}\n          {%- set menuBadge = '<span class=\"badge\">' + count + '</span>' %}\n        {%- endif %}\n      {%- endfor %}\n    {%- endif %}\n\n    {{ next_url(itemURL, menuIcon + menuText + menuBadge, {rel: 'section'}) }}\n\n  </li>\n\n{% endmacro %}\n"
  },
  {
    "path": "layout/_partials/header/menu.swig",
    "content": "{% import 'menu-item.swig' as menu_item with context %}\n\n<nav class=\"site-nav\">\n{%- if theme.menu %}\n  <ul id=\"menu\" class=\"main-menu menu\">\n    {%- for name, path in theme.menu %}\n      {%- set respath = path %}\n      {%- if path == '[object Object]' %}\n        {# Main Menu (default menu item for Submenu) #}\n        {%- for subname, subpath in path %}\n          {%- set itemName = subname | lower %}\n          {%- set respath = subpath %}\n          {%- if itemName == 'default' %}\n            {%- set itemName = name | lower %}\n            {{ menu_item.render(name, itemName, respath) }}\n          {%- endif %}\n        {%- endfor %}\n      {% else %}\n        {# Main Menu (standard menu items) #}\n        {%- set itemName = name | lower %}\n        {{- menu_item.render(name, itemName, respath) | trim }}\n      {%- endif %}\n    {%- endfor %}\n\n    {%- if theme.algolia_search.enable or theme.local_search.enable %}\n      <li class=\"menu-item menu-item-search\">\n        <a role=\"button\" class=\"popup-trigger\">\n          {%- if theme.menu_settings.icons %}<i class=\"fa fa-search fa-fw\"></i>{%- endif %}{{ __('menu.search') }}\n        </a>\n      </li>\n    {%- endif %}\n  </ul>\n{%- endif %}\n</nav>\n"
  },
  {
    "path": "layout/_partials/header/sub-menu.swig",
    "content": "{% import '_partials/header/menu-item.swig' as menu_item with context %}\n\n{%- if theme.menu and is_page() %}\n  {# Submenu & Submenu-2 #}\n  {%- for name, value in theme.menu %}\n    {%- set respath = value %}\n    {%- if value == '[object Object]' %}\n\n      {# If current URL is value of parent submenu 'default' path #}\n      {%- set currentParentUrl = page.path.split('/')[0] | trim %}\n      {%- if currentParentUrl == value.default.split('||')[0] | trim | replace('/', '') %}\n\n        {# Submenu items #}\n        <ul id=\"sub-menu\" class=\"sub-menu menu\">\n        {%- for subname, subvalue in value %}\n          {# For main submenu items #}\n          {%- if subvalue != '[object Object]' %}\n            {%- set itemName = subname | lower %}\n            {%- if itemName == 'default' %}\n              {%- set parentValue = subvalue.split('||')[0] | trim %}\n            {% else %}\n              {%- if subvalue.startsWith('http') %}\n                {%- set respath = subvalue %}\n              {% else %}\n                {%- set respath = parentValue + subvalue %}\n              {%- endif %}\n              {{ menu_item.render(subname, itemName, respath) }}\n            {%- endif %}\n          {% else %}\n            {# For 'default' submenu item in main submenu #}\n            {%- set itemName = subname | lower %}\n            {%- for subname2, subvalue2 in subvalue %}\n              {%- if subname2 == 'default' %}\n                {%- set respath = parentValue + subvalue2 %}\n                {{ menu_item.render(subname, itemName, respath) }}\n              {%- endif %}\n            {%- endfor %}\n          {%- endif %}\n        {%- endfor %}\n        </ul>\n        {# End Submenu items #}\n\n        {# Submenu-2 #}\n        {%- for name, value in theme.menu %}\n          {%- set respath = value %}\n          {%- if value == '[object Object]' %}\n\n            {%- for subname, subvalue in value %}\n              {%- set itemName = subname | lower %}\n              {%- if itemName == 'default' %}\n                {%- set parentValue = subvalue.split('||')[0] | trim %}\n              {%- endif %}\n              {%- if subvalue == '[object Object]' %}\n\n                {# If current URL is value of parent submenu 'default' path #}\n                {%- set paths = page.path.split('/') %}\n                {%- if paths.length > 2 %}\n                  {%- if paths[1] == subvalue.default.split('||')[0] | trim | replace('/', '') %}\n\n                    {# Submenu-2 items #}\n                    <ul id=\"sub-menu-2\" class=\"sub-menu menu\">\n                    {%- for subname2, subvalue2 in subvalue %}\n                      {%- set respath2 = subvalue %}\n                      {%- set itemName = subname2 | lower %}\n                      {%- if itemName == 'default' %}\n                        {%- set parentSubValue = subvalue2.split('||')[0] | trim %}\n                      {% else %}\n                        {%- if subvalue2.startsWith('http') %}\n                          {%- set respath2 = subvalue2 %}\n                        {% else %}\n                          {%- set respath2 = parentValue + parentSubValue + subvalue2 %}\n                        {%- endif %}\n                        {{ menu_item.render(subname2, itemName, respath2) }}\n                      {%- endif %}\n                    {%- endfor %}\n                    </ul>\n                    {# End Submenu-2 items #}\n\n                  {%- endif %}\n                {%- endif %}\n                {# End URL & path comparing #}\n\n              {%- endif %}\n            {%- endfor %}\n\n          {%- endif %}\n        {%- endfor %}\n        {# End Submenu-2 #}\n\n      {%- endif %}\n      {# End URL & path comparing #}\n\n    {%- endif %}\n  {%- endfor %}\n  {# End Submenu & Submenu-2 #}\n{%- endif %}\n"
  },
  {
    "path": "layout/_partials/languages.swig",
    "content": "{%- if theme.language_switcher and languages.length > 1 %}\n  <div class=\"languages\">\n    <label class=\"lang-select-label\">\n      <i class=\"fa fa-language\"></i>\n      <span>{{ language_name(page.lang) }}</span>\n      <i class=\"fa fa-angle-up\" aria-hidden=\"true\"></i>\n    </label>\n    <select class=\"lang-select\" data-canonical=\"\">\n      {% for language in languages %}\n        <option value=\"{{ language }}\" data-href=\"{{ i18n_path(language) }}\" selected=\"\">\n          {{ language_name(language) }}\n        </option>\n      {% endfor %}\n    </select>\n  </div>\n{%- endif %}\n"
  },
  {
    "path": "layout/_partials/page/breadcrumb.swig",
    "content": "{%- set paths = page.path.split('/') %}\n{%- set count = paths.length %}\n{%- if count > 2 %}\n  {%- set current = 0 %}\n  {%- set link = '' %}\n  <ul class=\"breadcrumb\">\n    {%- for path in paths %}\n      {%- set current = current + 1 %}\n      {%- if path != 'index.html' %}\n        {%- if current == count - 1 and paths[count - 1] == 'index.html' %}\n          <li>{{ path | upper }}</li>\n        {% else %}\n          {%- if link == '' %}\n            {%- set link = '/' + path %}\n          {% else %}\n            {%- set link = link + '/' + path %}\n          {%- endif %}\n          {%- if path.includes('.html') %}\n            <li>{{ path | replace('.html', '') | upper }}</li>\n          {% else %}\n            <li><a href=\"{{ url_for(link) }}/\">{{ path | upper }}</a></li>\n          {%- endif %}\n        {%- endif %}\n      {%- endif %}\n    {%- endfor %}\n  </ul>\n{%- endif %}\n"
  },
  {
    "path": "layout/_partials/page/page-header.swig",
    "content": "<header class=\"post-header\">\n\n<h1 class=\"post-title\" itemprop=\"name headline\">\n  {{- page.title }}\n  {{- post_edit(page.source) }}\n</h1>\n\n<div class=\"post-meta\">\n  {%- if page.description %}\n    <div class=\"post-description\">{{ page.description }}</div>\n  {%- endif %}\n  {% include '_partials/page/breadcrumb.swig' %}\n</div>\n\n</header>\n"
  },
  {
    "path": "layout/_partials/pagination.swig",
    "content": "{%- if page.prev or page.next %}\n  <nav class=\"pagination\">\n    {{\n      paginator({\n        prev_text: '<i class=\"fa fa-angle-left\" aria-label=\"' + __('accessibility.prev_page') + '\"></i>',\n        next_text: '<i class=\"fa fa-angle-right\" aria-label=\"' + __('accessibility.next_page') + '\"></i>',\n        mid_size : 1,\n        escape   : false\n      })\n    }}\n  </nav>\n{%- endif %}\n"
  },
  {
    "path": "layout/_partials/post/post-copyright.swig",
    "content": "{%- set ccIcon = '<i class=\"fab fa-fw fa-creative-commons\"></i>' %}\n{%- set ccText = theme.creative_commons.license | upper %}\n\n<div>\n<ul class=\"post-copyright\">\n  <li class=\"post-copyright-author\">\n    <strong>{{ __('post.copyright.author') + __('symbol.colon') }} </strong>\n    {{- page.author or author }}\n  </li>\n  <li class=\"post-copyright-link\">\n    <strong>{{ __('post.copyright.link') + __('symbol.colon') }}</strong>\n    {{ next_url(page.permalink, page.permalink, {title: page.title}) }}\n  </li>\n  <li class=\"post-copyright-license\">\n    <strong>{{ __('post.copyright.license_title') + __('symbol.colon') }} </strong>\n    {{- __('post.copyright.license_content', next_url(ccURL, ccIcon + ccText)) }}\n  </li>\n</ul>\n</div>\n"
  },
  {
    "path": "layout/_partials/post/post-followme.swig",
    "content": "{%- if theme.follow_me %}\n\n  <div class=\"followme\">\n    <p>{{ __('follow_me.welcome') }}</p>\n\n    <div class=\"social-list\">\n      {%- for name, value in theme.follow_me %}\n        {%- set link = value.split('||')[0] | trim %}\n        {%- set icon = value.split('||')[1] | trim %}\n\n        <div class=\"social-item\">\n          <a target=\"_blank\" class=\"social-link\" href=\"{{ link }}\">\n            <span class=\"icon\">\n              <i class=\"{{ icon }}\"></i>\n            </span>\n\n            <span class=\"label\">{{ name }}</span>\n          </a>\n        </div>\n      {%- endfor %}\n    </div>\n  </div>\n{%- endif %}\n"
  },
  {
    "path": "layout/_partials/post/post-footer.swig",
    "content": "{%- if theme.rating.enable %}\n  <div class=\"post-widgets\">\n    <div class=\"wp_rating\">\n      <div id=\"wpac-rating\"></div>\n    </div>\n  </div>\n{%- endif %}\n"
  },
  {
    "path": "layout/_partials/post/post-related.swig",
    "content": "{%- set popular_posts = popular_posts_json(theme.related_posts.params, page) %}\n{%- if popular_posts.json and popular_posts.json.length > 0 %}\n  <div class=\"popular-posts-header\">{{ theme.related_posts.title or __('post.related_posts') }}</div>\n  <ul class=\"popular-posts\">\n  {%- for popular_post in popular_posts.json %}\n    <li class=\"popular-posts-item\">\n      {%- if popular_post.date and popular_post.date != '' %}\n        <div class=\"popular-posts-date\">{{ popular_post.date }}</div>\n      {%- endif %}\n      {%- if popular_post.img and popular_post.img != '' %}\n        <div class=\"popular-posts-img\"><img src=\"{{ popular_post.img }}\"></div>\n      {%- endif %}\n      <div class=\"popular-posts-title\"><a href=\"{{ popular_post.path }}\" rel=\"bookmark\">{{ popular_post.title }}</a></div>\n      {%- if popular_post.excerpt and popular_post.excerpt != '' %}\n        <div class=\"popular-posts-excerpt\"><p>{{ popular_post.excerpt }}</p></div>\n      {%- endif %}\n    </li>\n  {%- endfor %}\n  </ul>\n{%- endif %}\n"
  },
  {
    "path": "layout/_partials/post/post-reward.swig",
    "content": "<div class=\"reward-container\">\n  <div>{{ page.reward_settings.comment }}</div>\n  <button onclick=\"var qr = document.getElementById('qr'); qr.style.display = (qr.style.display === 'none') ? 'block' : 'none';\">\n    {{ __('reward.donate') }}\n  </button>\n  <div id=\"qr\" style=\"display: none;\">\n\n    {%- for name, image in theme.reward %}\n      {%- set builtin = ['wechatpay', 'alipay', 'paypal', 'bitcoin'] %}\n      {%- if builtin.includes(name) %}\n        {%- set translation = __('reward.' + name) %}\n      {% else %}\n        {%- set translation = name %}\n      {%- endif %}\n      <div style=\"display: inline-block;\">\n        <img src=\"{{ url_for(image) }}\" alt=\"{{ author }} {{ translation }}\">\n        <p>{{ translation }}</p>\n      </div>\n    {%- endfor %}\n\n  </div>\n</div>\n"
  },
  {
    "path": "layout/_partials/search/algolia-search.swig",
    "content": "<div class=\"search-header\">\n  <span class=\"search-icon\">\n    <i class=\"fa fa-search\"></i>\n  </span>\n  <div class=\"search-input-container\"></div>\n  <span class=\"popup-btn-close\">\n    <i class=\"fa fa-times-circle\"></i>\n  </span>\n</div>\n<div class=\"algolia-results\">\n  <div id=\"algolia-stats\"></div>\n  <div id=\"algolia-hits\"></div>\n  <div id=\"algolia-pagination\" class=\"algolia-pagination\"></div>\n</div>\n"
  },
  {
    "path": "layout/_partials/search/index.swig",
    "content": "{%- if theme.algolia_search.enable or theme.local_search.enable %}\n  <div class=\"search-pop-overlay\">\n    <div class=\"popup search-popup\">\n      {%- if theme.algolia_search.enable %}\n        {% include 'algolia-search.swig' %}\n      {% elif theme.local_search.enable %}\n        {% include 'localsearch.swig' %}\n      {%- endif %}\n    </div>\n  </div>\n{%- endif %}\n"
  },
  {
    "path": "layout/_partials/search/localsearch.swig",
    "content": "<div class=\"search-header\">\n  <span class=\"search-icon\">\n    <i class=\"fa fa-search\"></i>\n  </span>\n  <div class=\"search-input-container\">\n    <input autocomplete=\"off\" autocapitalize=\"off\"\n           placeholder=\"{{ __('search.placeholder') }}\" spellcheck=\"false\"\n           type=\"search\" class=\"search-input\">\n  </div>\n  <span class=\"popup-btn-close\">\n    <i class=\"fa fa-times-circle\"></i>\n  </span>\n</div>\n<div id=\"search-result\">\n  <div id=\"no-result\">\n    <i class=\"fa fa-spinner fa-pulse fa-5x fa-fw\"></i>\n  </div>\n</div>\n"
  },
  {
    "path": "layout/_partials/sidebar/site-overview.swig",
    "content": "<div class=\"site-author motion-element\" itemprop=\"author\" itemscope itemtype=\"http://schema.org/Person\">\n  {%- if theme.avatar.url %}\n    <img class=\"site-author-image\" itemprop=\"image\" alt=\"{{ author }}\"\n      src=\"{{ url_for(theme.avatar.url) }}\">\n  {%- endif %}\n  <p class=\"site-author-name\" itemprop=\"name\">{{ author }}</p>\n  <div class=\"site-description\" itemprop=\"description\">{{ description }}</div>\n</div>\n\n{%- if theme.site_state %}\n<div class=\"site-state-wrap motion-element\">\n  <nav class=\"site-state\">\n    {%- if config.archive_dir != '/' and site.posts.length > 0 %}\n      <div class=\"site-state-item site-state-posts\">\n        {%- if theme.menu.archives %}\n          <a href=\"{{ url_for(theme.menu.archives.split('||')[0] | trim) }}\">\n        {% else %}\n          <a href=\"{{ url_for(config.archive_dir) }}\">\n        {%- endif %}\n          <span class=\"site-state-item-count\">{{ site.posts.length }}</span>\n          <span class=\"site-state-item-name\">{{ __('state.posts') }}</span>\n        </a>\n      </div>\n    {%- endif %}\n\n    {%- if site.categories.length > 0 %}\n      {%- set categoriesPageQuery = site.pages.find({type: 'categories'}, {lean: true}) %}\n      {%- set hasCategoriesPage = categoriesPageQuery.length > 0 %}\n      <div class=\"site-state-item site-state-categories\">\n        {%- if hasCategoriesPage %}\n          {%- if theme.menu.categories %}\n            <a href=\"{{ url_for(theme.menu.categories.split('||')[0] | trim) }}\">\n          {% else %}\n            <a href=\"{{ url_for(config.category_dir) + '/' }}\">\n          {%- endif %}\n        {%- endif %}\n        <span class=\"site-state-item-count\">{{ site.categories.length }}</span>\n        <span class=\"site-state-item-name\">{{ __('state.categories') }}</span>\n        {%- if hasCategoriesPage %}</a>{%- endif %}\n      </div>\n    {%- endif %}\n\n    {%- if site.tags.length > 0 %}\n      {%- set tagsPageQuery = site.pages.find({type: 'tags'}, {lean: true}) %}\n      {%- set hasTagsPage = tagsPageQuery.length > 0 %}\n      <div class=\"site-state-item site-state-tags\">\n        {%- if hasTagsPage %}\n          {%- if theme.menu.tags %}\n            <a href=\"{{ url_for(theme.menu.tags.split('||')[0] | trim) }}\">\n          {% else %}\n            <a href=\"{{ url_for(config.tag_dir) + '/' }}\">\n          {%- endif %}\n        {%- endif %}\n        <span class=\"site-state-item-count\">{{ site.tags.length }}</span>\n        <span class=\"site-state-item-name\">{{ __('state.tags') }}</span>\n        {%- if hasTagsPage %}</a>{%- endif %}\n      </div>\n    {%- endif %}\n  </nav>\n</div>\n{%- endif %}\n\n{%- if theme.chat.enable and theme.chat.service !== '' %}\n  <div class=\"sidebar-button motion-element\">\n  {%- if theme.chat.service == 'chatra' and theme.chatra.enable %}\n    <a onclick=\"Chatra('openChat', true);\">\n  {%- endif %}\n  {%- if theme.chat.service == 'tidio' and theme.tidio.enable %}\n    <a onclick=\"tidioChatApi.open();\">\n  {%- endif %}\n  {%- if theme.chat.icon %}<i class=\"{{ theme.chat.icon }}\"></i>{%- endif %}\n    {{ theme.chat.text }}\n  </a>\n  </div>\n{%- endif %}\n\n{%- if theme.social %}\n  <div class=\"links-of-author motion-element\">\n    {%- for name, link in theme.social %}\n      <span class=\"links-of-author-item\">\n      {%- set sidebarURL = link.split('||')[0] | trim %}\n      {%- if theme.social_icons.enable %}\n        {%- set sidebarIcon = '<i class=\"' + link.split('||')[1] | trim + ' fa-fw\"></i>' %}\n      {%- else %}\n        {%- set sidebarIcon = '' %}\n      {%- endif %}\n      {%- if theme.social_icons.enable and theme.social_icons.icons_only %}\n        {%- set sidebarText = '' %}\n      {%- else %}\n        {%- set sidebarText = name %}\n      {%- endif %}\n        {{ next_url(sidebarURL, sidebarIcon + sidebarText, {title: name + ' → ' + sidebarURL}) }}\n      </span>\n    {%- endfor %}\n  </div>\n{%- endif %}\n\n{%- if theme.creative_commons.license and theme.creative_commons.sidebar %}\n  <div class=\"cc-license motion-element\" itemprop=\"license\">\n  {%- set ccImage = '<img src=\"' + url_for(theme.images + '/cc-' + theme.creative_commons.license + '.svg') + '\" alt=\"Creative Commons\">' %}\n    {{ next_url(ccURL, ccImage, {class: 'cc-opacity'}) }}\n  </div>\n{%- endif %}\n\n{# Blogroll #}\n{%- if theme.links %}\n  <div class=\"links-of-blogroll motion-element\">\n    <div class=\"links-of-blogroll-title\">\n      {%- if theme.links_settings.icon %}<i class=\"{{ theme.links_settings.icon }} fa-fw\"></i>{%- endif %}\n      {{ theme.links_settings.title }}\n    </div>\n    <ul class=\"links-of-blogroll-list\">\n      {%- for blogrollText, blogrollURL in theme.links %}\n        <li class=\"links-of-blogroll-item\">\n          {{ next_url(blogrollURL, blogrollText, {title: blogrollURL}) }}\n        </li>\n      {%- endfor %}\n    </ul>\n  </div>\n{%- endif %}\n"
  },
  {
    "path": "layout/_partials/widgets.swig",
    "content": "{%- if theme.back2top.enable and not theme.back2top.sidebar %}\n  <div class=\"back-to-top\">\n    <i class=\"fa fa-arrow-up\"></i>\n    <span>0%</span>\n  </div>\n{%- endif %}\n{%- if theme.reading_progress.enable %}\n  <div class=\"reading-progress-bar\"></div>\n{%- endif %}\n{%- if theme.bookmark.enable %}\n  <a role=\"button\" class=\"book-mark-link book-mark-link-fixed\"></a>\n{%- endif %}\n{%- if theme.github_banner.enable %}\n  {%- set github_URL = theme.github_banner.permalink %}\n  {%- set github_title = theme.github_banner.title %}\n\n  {%- set github_image = '<svg width=\"80\" height=\"80\" viewBox=\"0 0 250 250\" aria-hidden=\"true\"><path d=\"M0,0 L115,115 L130,115 L142,142 L250,250 L250,0 Z\"></path><path d=\"M128.3,109.0 C113.8,99.7 119.0,89.6 119.0,89.6 C122.0,82.7 120.5,78.6 120.5,78.6 C119.2,72.0 123.4,76.3 123.4,76.3 C127.3,80.9 125.5,87.3 125.5,87.3 C122.9,97.6 130.6,101.9 134.4,103.2\" fill=\"currentColor\" style=\"transform-origin: 130px 106px;\" class=\"octo-arm\"></path><path d=\"M115.0,115.0 C114.9,115.1 118.7,116.5 119.8,115.4 L133.7,101.6 C136.9,99.2 139.9,98.4 142.2,98.6 C133.8,88.0 127.5,74.4 143.8,58.0 C148.5,53.4 154.0,51.2 159.7,51.0 C160.3,49.4 163.2,43.6 171.4,40.1 C171.4,40.1 176.1,42.5 178.8,56.2 C183.1,58.6 187.2,61.8 190.9,65.4 C194.5,69.0 197.7,73.2 200.1,77.6 C213.8,80.2 216.3,84.9 216.3,84.9 C212.7,93.1 206.9,96.0 205.4,96.6 C205.1,102.4 203.0,107.8 198.3,112.5 C181.9,128.9 168.3,122.5 157.7,114.1 C157.9,116.9 156.7,120.9 152.7,124.9 L141.0,136.5 C139.8,137.7 141.6,141.9 141.8,141.8 Z\" fill=\"currentColor\" class=\"octo-body\"></path></svg>' %}\n\n  {{ next_url(github_URL, github_image, {class: 'github-corner', title: github_title, \"aria-label\": github_title}) }}\n{%- endif %}\n"
  },
  {
    "path": "layout/_scripts/index.swig",
    "content": "{% include 'vendors.swig' %}\n\n{{- next_js('utils.js') }}\n{%- if theme.motion.enable %}\n  {{- next_js('motion.js') }}\n{%- endif %}\n\n{%- set scheme_script = 'schemes/' + theme.scheme | lower + '.swig' %}\n{% include scheme_script %}\n\n{{- next_js('next-boot.js') }}\n{%- if theme.bookmark.enable %}\n  {{- next_js('bookmark.js') }}\n{%- endif %}\n{%- if theme.pjax %}\n  {% include 'pjax.swig' %}\n{%- endif %}\n{% include 'three.swig' %}\n"
  },
  {
    "path": "layout/_scripts/noscript.swig",
    "content": "<noscript>\n  <style>\n  .use-motion .brand,\n  .use-motion .menu-item,\n  .sidebar-inner,\n  .use-motion .post-block,\n  .use-motion .pagination,\n  .use-motion .comments,\n  .use-motion .post-header,\n  .use-motion .post-body,\n  .use-motion .collection-header { opacity: initial; }\n\n  .use-motion .site-title,\n  .use-motion .site-subtitle {\n    opacity: initial;\n    top: initial;\n  }\n\n  .use-motion .logo-line-before i { left: initial; }\n  .use-motion .logo-line-after i { right: initial; }\n  </style>\n</noscript>\n"
  },
  {
    "path": "layout/_scripts/pages/schedule.swig",
    "content": "<script{{ pjax }}>\n(function() {\n  // Initialization\n  var calendar = {\n    orderBy     : 'startTime',\n    showLocation: false,\n    offsetMax   : 72,\n    offsetMin   : 4,\n    showDeleted : false,\n    singleEvents: true,\n    maxResults  : 250\n  };\n\n  // Read config form theme config file\n  Object.assign(calendar, {{ theme.calendar | json }});\n\n  var now = new Date();\n  var timeMax = new Date();\n  var timeMin = new Date();\n\n  timeMax.setHours(now.getHours() + calendar.offsetMax);\n  timeMin.setHours(now.getHours() - calendar.offsetMin);\n\n  // Build URL\n  const params = {\n    key         : calendar.api_key,\n    orderBy     : calendar.orderBy,\n    timeMax     : timeMax.toISOString(),\n    timeMin     : timeMin.toISOString(),\n    showDeleted : calendar.showDeleted,\n    singleEvents: calendar.singleEvents,\n    maxResults  : calendar.maxResults\n  };\n\n  var request_url = 'https://www.googleapis.com/calendar/v3/calendars/' + calendar.calendar_id + '/events?' + Object.entries(params).map(([key, value]) => `${key}=${encodeURIComponent(value)}`).join('&');\n\n  fetchData();\n  var fetchDataTimer = setInterval(fetchData, 60000);\n  window.addEventListener('pjax:send', () => {\n    clearInterval(fetchDataTimer);\n  });\n\n  function fetchData() {\n    var eventList = document.querySelector('.event-list');\n    if (!eventList) return;\n\n    fetch(request_url).then(response => {\n      return response.json();\n    }).then(data => {\n      if (data.items.length === 0) {\n        eventList.innerHTML = '<hr>';\n        return;\n      }\n      // Clean the event list\n      eventList.innerHTML = '';\n      var prevEnd = 0; // used to decide where to insert an <hr>\n\n      data.items.forEach(event => {\n        // Parse data\n        var utc   = new Date().getTimezoneOffset() * 60000;\n        var start = event.start.dateTime = new Date(event.start.dateTime || (new Date(event.start.date).getTime() + utc));\n        var end   = event.end.dateTime = new Date(event.end.dateTime || (new Date(event.end.date).getTime() + utc));\n\n        tense = judgeTense(now, start, end); // 0:now 1:future -1:past\n\n        if (tense === 1 && prevEnd < now) {\n          eventList.innerHTML += '<hr>';\n        }\n\n        eventDOM = buildEventDOM(tense, event);\n        eventList.innerHTML += eventDOM;\n\n        prevEnd = end;\n      });\n    });\n  }\n\n  function getRelativeTime(current, previous) {\n    var msPerMinute = 60 * 1000;\n    var msPerHour = msPerMinute * 60;\n    var msPerDay = msPerHour * 24;\n    var msPerMonth = msPerDay * 30;\n    var msPerYear = msPerDay * 365;\n\n    var elapsed = current - previous;\n    var tense = elapsed > 0 ? 'ago' : 'later';\n\n    elapsed = Math.abs(elapsed);\n\n    if      ( elapsed < msPerHour  ) {\n      return Math.round(elapsed / msPerMinute) + ' minutes ' + tense;\n    }\n    else if ( elapsed < msPerDay   ) {\n      return Math.round(elapsed / msPerHour) + ' hours ' + tense;\n    }\n    else if ( elapsed < msPerMonth ) {\n      return 'about ' + Math.round(elapsed / msPerDay) + ' days ' + tense;\n    }\n    else if ( elapsed < msPerYear  ) {\n      return 'about ' + Math.round(elapsed / msPerMonth) + ' months ' + tense;\n    }\n    else {\n      return 'about' + Math.round(elapsed / msPerYear) + ' years' + tense;\n    }\n  }\n\n  function judgeTense(now, eventStart, eventEnd) {\n    if      (eventEnd   < now) { return -1; }\n    else if (eventStart > now) { return  1; }\n    else                       { return  0; }\n  }\n\n  function buildEventDOM(tense, event) {\n    var tenseClass = '';\n    var start      = event.start.dateTime;\n    var end        = event.end.dateTime;\n    switch(tense) {\n      case 0 : // now\n        tenseClass = 'event-now';\n        break;\n      case 1 : // future\n        tenseClass = 'event-future';\n        break;\n      case -1: // past\n        tenseClass = 'event-past';\n        break;\n      default:\n        throw 'Time data error';\n    }\n    var durationFormat = {\n      weekday: 'short',\n      hour   : '2-digit',\n      minute : '2-digit'\n    };\n    var relativeTimeStr = (tense === 0) ? 'NOW' : getRelativeTime(now, start);\n    var durationStr = start.toLocaleTimeString([], durationFormat) + ' - ' + end.toLocaleTimeString([], durationFormat);\n\n    var locationDOM = '';\n    if (calendar.showLocation && event.location) {\n      locationDOM = '<span class=\"event-location event-details\">' + event.location + '</span>';\n    }\n\n    var eventContent = `<div class=\"event ${tenseClass}\">\n        <h2 class=\"event-summary\">\n          ${event.summary}\n          <span class=\"event-relative-time\">${relativeTimeStr}</span>\n        </h2>\n        ${locationDOM}\n        <span class=\"event-duration event-details\">${durationStr}</span>\n      </div>`;\n    return eventContent;\n  }\n})();\n</script>\n"
  },
  {
    "path": "layout/_scripts/pjax.swig",
    "content": "<script>\nvar pjax = new Pjax({\n  selectors: [\n    'head title',\n    '#page-configurations',\n    '.content-wrap',\n    '.post-toc-wrap',\n    '.languages',\n    '#pjax'\n  ],\n  switches: {\n    '.post-toc-wrap': Pjax.switches.innerHTML\n  },\n  analytics: false,\n  cacheBust: false,\n  scrollTo : !CONFIG.bookmark.enable\n});\n\nwindow.addEventListener('pjax:success', () => {\n  document.querySelectorAll('script[data-pjax], script#page-configurations, #pjax script').forEach(element => {\n    var code = element.text || element.textContent || element.innerHTML || '';\n    var parent = element.parentNode;\n    parent.removeChild(element);\n    var script = document.createElement('script');\n    if (element.id) {\n      script.id = element.id;\n    }\n    if (element.className) {\n      script.className = element.className;\n    }\n    if (element.type) {\n      script.type = element.type;\n    }\n    if (element.src) {\n      script.src = element.src;\n      // Force synchronous loading of peripheral JS.\n      script.async = false;\n    }\n    if (element.dataset.pjax !== undefined) {\n      script.dataset.pjax = '';\n    }\n    if (code !== '') {\n      script.appendChild(document.createTextNode(code));\n    }\n    parent.appendChild(script);\n  });\n  NexT.boot.refresh();\n  // Define Motion Sequence & Bootstrap Motion.\n  if (CONFIG.motion.enable) {\n    NexT.motion.integrator\n      .init()\n      .add(NexT.motion.middleWares.subMenu)\n      .add(NexT.motion.middleWares.postList)\n      .bootstrap();\n  }\n  NexT.utils.updateSidebarPosition();\n});\n</script>\n"
  },
  {
    "path": "layout/_scripts/schemes/gemini.swig",
    "content": "{{- next_js('schemes/pisces.js') }}\n"
  },
  {
    "path": "layout/_scripts/schemes/mist.swig",
    "content": "{{- next_js('schemes/muse.js') }}\n"
  },
  {
    "path": "layout/_scripts/schemes/muse.swig",
    "content": "{{- next_js('schemes/muse.js') }}\n"
  },
  {
    "path": "layout/_scripts/schemes/pisces.swig",
    "content": "{{- next_js('schemes/pisces.js') }}\n"
  },
  {
    "path": "layout/_scripts/three.swig",
    "content": "{%- if theme.three.enable %}\n  {%- set three_uri = theme.vendors.three or next_vendors('three/three.min.js') %}\n  <script defer src=\"{{ three_uri }}\"></script>\n  {%- if theme.three.three_waves %}\n    {%- set waves_uri = theme.vendors.three_waves or next_vendors('three/three-waves.min.js') %}\n    <script defer src=\"{{ waves_uri }}\"></script>\n  {%- endif %}\n  {%- if theme.three.canvas_lines %}\n    {%- set lines_uri = theme.vendors.canvas_lines or next_vendors('three/canvas_lines.min.js') %}\n    <script defer src=\"{{ lines_uri }}\"></script>\n  {%- endif %}\n  {%- if theme.three.canvas_sphere %}\n    {%- set sphere_uri = theme.vendors.canvas_sphere or next_vendors('three/canvas_sphere.min.js') %}\n    <script defer src=\"{{ sphere_uri }}\"></script>\n  {%- endif %}\n{%- endif %}\n"
  },
  {
    "path": "layout/_scripts/vendors.swig",
    "content": "{%- set js_vendors = {} %}\n{%- set js_vendors = js_vendors | attr('anime', 'anime.min.js') %}\n\n{%- if theme.pjax %}\n  {%- set js_vendors = js_vendors | attr('pjax', 'pjax/pjax.min.js') %}\n{%- endif %}\n\n{%- if theme.fancybox %}\n  {%- set js_vendors = js_vendors | attr('jquery', '//cdn.jsdelivr.net/npm/jquery@3/dist/jquery.min.js') %}\n  {%- set js_vendors = js_vendors | attr('fancybox', '//cdn.jsdelivr.net/gh/fancyapps/fancybox@3/dist/jquery.fancybox.min.js') %}\n{%- endif %}\n\n{%- if theme.mediumzoom %}\n  {%- set js_vendors = js_vendors | attr('mediumzoom', '//cdn.jsdelivr.net/npm/medium-zoom@1/dist/medium-zoom.min.js') %}\n{%- endif %}\n\n{%- if theme.lazyload %}\n  {%- set js_vendors = js_vendors | attr('lazyload', '//cdn.jsdelivr.net/npm/lozad@1/dist/lozad.min.js') %}\n{%- endif %}\n\n{%- if theme.pangu %}\n  {%- set js_vendors = js_vendors | attr('pangu', '//cdn.jsdelivr.net/npm/pangu@4/dist/browser/pangu.min.js') %}\n{%- endif %}\n\n{%- if theme.motion.enable %}\n  {%- set js_vendors = js_vendors | attr('velocity', 'velocity/velocity.min.js') %}\n  {%- set js_vendors = js_vendors | attr('velocity_ui', 'velocity/velocity.ui.min.js') %}\n{%- endif %}\n\n{%- if theme.canvas_nest.enable %}\n  {%- if theme.canvas_nest.onmobile %}\n    {%- set canvas_nest_uri = theme.vendors.canvas_nest or next_vendors('canvas-nest/canvas-nest.min.js') %}\n  {% else %}\n    {%- set canvas_nest_uri = theme.vendors.canvas_nest_nomobile or next_vendors('canvas-nest/canvas-nest-nomobile.min.js') %}\n  {%- endif %}\n  <script color='{{ theme.canvas_nest.color }}' opacity='{{ theme.canvas_nest.opacity }}' zIndex='{{ theme.canvas_nest.zIndex }}' count='{{ theme.canvas_nest.count }}' src=\"{{ canvas_nest_uri }}\"></script>\n{%- endif %}\n\n{%- if theme.canvas_ribbon.enable %}\n  {%- set canvas_ribbon_uri = theme.vendors.canvas_ribbon or next_vendors('canvas-ribbon/canvas-ribbon.js') %}\n  <script size=\"{{ theme.canvas_ribbon.size }}\" alpha=\"{{ theme.canvas_ribbon.alpha }}\" zIndex=\"{{ theme.canvas_ribbon.zIndex }}\" src=\"{{ canvas_ribbon_uri }}\"></script>\n{%- endif %}\n\n{%- for name, internal in js_vendors %}\n  {%- set internal_script = next_vendors(internal) %}\n  <script src=\"{{ theme.vendors[name] or internal_script }}\"></script>\n{%- endfor %}\n"
  },
  {
    "path": "layout/_third-party/analytics/baidu-analytics.swig",
    "content": "{%- if theme.baidu_analytics %}\n  <script{{ pjax }}>\n    var _hmt = _hmt || [];\n    (function() {\n      var hm = document.createElement(\"script\");\n      hm.src = \"https://hm.baidu.com/hm.js?{{ theme.baidu_analytics }}\";\n      var s = document.getElementsByTagName(\"script\")[0];\n      s.parentNode.insertBefore(hm, s);\n    })();\n  </script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/analytics/google-analytics.swig",
    "content": "{%- if theme.google_analytics.tracking_id %}\n  {%- if not theme.google_analytics.only_pageview %}\n    <script async src=\"https://www.googletagmanager.com/gtag/js?id={{ theme.google_analytics.tracking_id }}\"></script>\n    <script{{ pjax }}>\n      if (CONFIG.hostname === location.hostname) {\n        window.dataLayer = window.dataLayer || [];\n        function gtag(){dataLayer.push(arguments);}\n        gtag('js', new Date());\n        gtag('config', '{{ theme.google_analytics.tracking_id }}');\n      }\n    </script>\n  {%- endif %}\n  {%- if theme.google_analytics.only_pageview %}\n    <script>\n      function sendPageView() {\n        if (CONFIG.hostname !== location.hostname) return;\n        var uid = localStorage.getItem('uid') || (Math.random() + '.' + Math.random());\n        localStorage.setItem('uid', uid);\n        navigator.sendBeacon('https://www.google-analytics.com/collect', new URLSearchParams({\n          v  : 1,\n          tid: '{{ theme.google_analytics.tracking_id }}',\n          cid: uid,\n          t  : 'pageview',\n          dp : encodeURIComponent(location.pathname)\n        }));\n      }\n      document.addEventListener('pjax:complete', sendPageView);\n      sendPageView();\n    </script>\n  {%- endif %}\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/analytics/growingio.swig",
    "content": "{%- if theme.growingio_analytics %}\n  <script{{ pjax }}>\n    !function(e,t,n,g,i){e[i]=e[i]||function(){(e[i].q=e[i].q||[]).push(arguments)},n=t.createElement(\"script\"),tag=t.getElementsByTagName(\"script\")[0],n.async=1,n.src=('https:'==document.location.protocol?'https://':'http://')+g,tag.parentNode.insertBefore(n,tag)}(window,document,\"script\",\"assets.growingio.com/2.1/gio.js\",\"gio\");\n    gio('init', '{{ theme.growingio_analytics }}', {});\n    gio('send');\n  </script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/analytics/index.swig",
    "content": "{% include 'google-analytics.swig' %}\n{% include 'baidu-analytics.swig' %}\n{% include 'growingio.swig' %}\n"
  },
  {
    "path": "layout/_third-party/baidu-push.swig",
    "content": "{%- if theme.baidu_push %}\n  <script{{ pjax }}>\n    (function(){\n      var canonicalURL, curProtocol;\n      //Get the <link> tag\n      var x=document.getElementsByTagName(\"link\");\n\t\t//Find the last canonical URL\n\t\tif(x.length > 0){\n\t\t\tfor (i=0;i<x.length;i++){\n\t\t\t\tif(x[i].rel.toLowerCase() == 'canonical' && x[i].href){\n\t\t\t\t\tcanonicalURL=x[i].href;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n    //Get protocol\n\t    if (!canonicalURL){\n\t    \tcurProtocol = window.location.protocol.split(':')[0];\n\t    }\n\t    else{\n\t    \tcurProtocol = canonicalURL.split(':')[0];\n\t    }\n      //Get current URL if the canonical URL does not exist\n\t    if (!canonicalURL) canonicalURL = window.location.href;\n\t    //Assign script content. Replace current URL with the canonical URL\n      !function(){var e=/([http|https]:\\/\\/[a-zA-Z0-9\\_\\.]+\\.baidu\\.com)/gi,r=canonicalURL,t=document.referrer;if(!e.test(r)){var n=(String(curProtocol).toLowerCase() === 'https')?\"https://sp0.baidu.com/9_Q4simg2RQJ8t7jm9iCKT-xh_/s.gif\":\"//api.share.baidu.com/s.gif\";t?(n+=\"?r=\"+encodeURIComponent(document.referrer),r&&(n+=\"&l=\"+r)):r&&(n+=\"?l=\"+r);var i=new Image;i.src=n}}(window);})();\n  </script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/chat/chatra.swig",
    "content": "{%- if theme.chatra.enable %}\n  {%- if theme.chatra.embed %}\n  <script>\n    window.ChatraSetup = {\n      mode    : 'frame',\n      injectTo: '{{ theme.chatra.embed }}'\n    };\n  </script>\n  {%- endif %}\n  <script>\n    (function(d, w, c) {\n      w.ChatraID = '{{ theme.chatra.id }}';\n      var s = d.createElement('script');\n      w[c] = w[c] || function() {\n        (w[c].q = w[c].q || []).push(arguments);\n      };\n      s.async = {{ theme.chatra.async }};\n      s.src = 'https://call.chatra.io/chatra.js';\n      if (d.head) d.head.appendChild(s);\n    })(document, window, 'Chatra');\n  </script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/chat/tidio.swig",
    "content": "{%- if theme.tidio.enable %}\n  <script src=\"//code.tidio.co/{{ theme.tidio.key }}.js\"></script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/changyan.swig",
    "content": "{%- if is_home() %}\n  <script id=\"cy_cmt_num\" src=\"https://changyan.sohu.com/upload/plugins/plugins.list.count.js?clientId={{ theme.changyan.appid }}\"></script>\n{% elif page.comments %}\n  <script>\n  NexT.utils.loadComments(document.querySelector('#SOHUCS'), () => {\n    var appid = '{{ theme.changyan.appid }}';\n    var conf = '{{ theme.changyan.appkey }}';\n    var width = window.innerWidth || document.documentElement.clientWidth;\n    if (width < 960) {\n      window.document.write('<script id=\"changyan_mobile_js\" charset=\"utf-8\" type=\"text/javascript\" src=\"https://changyan.sohu.com/upload/mobile/wap-js/changyan_mobile.js?client_id=' + appid + '&conf=' + conf + '\"><\\/script>');\n    } else {\n      var loadJs=function(d,a){var c=document.getElementsByTagName(\"head\")[0]||document.head||document.documentElement;var b=document.createElement(\"script\");b.setAttribute(\"type\",\"text/javascript\");b.setAttribute(\"charset\",\"UTF-8\");b.setAttribute(\"src\",d);if(typeof a===\"function\"){if(window.attachEvent){b.onreadystatechange=function(){var e=b.readyState;if(e===\"loaded\"||e===\"complete\"){b.onreadystatechange=null;a()}}}else{b.onload=a}}c.appendChild(b)};loadJs(\"https://changyan.sohu.com/upload/changyan.js\",function(){window.changyan.api.config({appid:appid,conf:conf})});\n    }\n  });\n  </script>\n  <script src=\"https://assets.changyan.sohu.com/upload/plugins/plugins.count.js\"></script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/disqus.swig",
    "content": "{%- if theme.disqus.count %}\n<script>\n  function loadCount() {\n    var d = document, s = d.createElement('script');\n    s.src = 'https://{{ theme.disqus.shortname }}.disqus.com/count.js';\n    s.id = 'dsq-count-scr';\n    (d.head || d.body).appendChild(s);\n  }\n  // defer loading until the whole page loading is completed\n  window.addEventListener('load', loadCount, false);\n</script>\n{%- endif %}\n{%- if page.comments %}\n<script>\n  var disqus_config = function() {\n    this.page.url = {{ page.permalink | json }};\n    this.page.identifier = {{ page.path | json }};\n    this.page.title = {{ page.title | json }};\n    {% if __('disqus') !== 'disqus' -%}\n      this.language = '{{ __('disqus') }}';\n    {% endif -%}\n  };\n  NexT.utils.loadComments(document.querySelector('#disqus_thread'), () => {\n    if (window.DISQUS) {\n      DISQUS.reset({\n        reload: true,\n        config: disqus_config\n      });\n    } else {\n      var d = document, s = d.createElement('script');\n      s.src = 'https://{{ theme.disqus.shortname }}.disqus.com/embed.js';\n      s.setAttribute('data-timestamp', '' + +new Date());\n      (d.head || d.body).appendChild(s);\n    }\n  });\n</script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/disqusjs.swig",
    "content": "{%- if page.comments %}\n{%- set disqusjs_css_uri = theme.vendors.disqusjs_css or '//cdn.jsdelivr.net/npm/disqusjs@1/dist/disqusjs.css' %}\n<link rel=\"stylesheet\" href=\"{{ disqusjs_css_uri }}\">\n\n{%- set disqusjs_js_uri = theme.vendors.disqusjs_js or '//cdn.jsdelivr.net/npm/disqusjs@1/dist/disqus.js' %}\n\n<script>\nNexT.utils.loadComments(document.querySelector('#disqus_thread'), () => {\n  NexT.utils.getScript('{{ disqusjs_js_uri }}', () => {\n    window.dsqjs = new DisqusJS({\n      api       : '{{ theme.disqusjs.api }}' || 'https://disqus.com/api/',\n      apikey    : '{{ theme.disqusjs.apikey }}',\n      shortname : '{{ theme.disqusjs.shortname }}',\n      url       : {{ page.permalink | json }},\n      identifier: {{ page.path | json }},\n      title     : {{ page.title | json }},\n    });\n  }, window.DisqusJS);\n});\n</script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/gitalk.swig",
    "content": "{%- if page.comments %}\n{%- set gitalk_css_uri = theme.vendors.gitalk_css or '//cdn.jsdelivr.net/npm/gitalk@1/dist/gitalk.min.css' %}\n<link rel=\"stylesheet\" href=\"{{ gitalk_css_uri }}\">\n\n{%- set gitalk_js_uri = theme.vendors.gitalk_js or '//cdn.jsdelivr.net/npm/gitalk@1/dist/gitalk.min.js' %}\n\n<script>\nNexT.utils.loadComments(document.querySelector('#gitalk-container'), () => {\n  NexT.utils.getScript('{{ gitalk_js_uri }}', () => {\n    var gitalk = new Gitalk({\n      clientID    : '{{ theme.gitalk.client_id }}',\n      clientSecret: '{{ theme.gitalk.client_secret }}',\n      repo        : '{{ theme.gitalk.repo }}',\n      owner       : '{{ theme.gitalk.github_id }}',\n      admin       : ['{{ theme.gitalk.admin_user }}'],\n      id          : '{{ gitalk_md5(page.path) }}',\n      {%- if theme.gitalk.language == '' %}\n        language: window.navigator.language || window.navigator.userLanguage,\n      {% else %}\n        language: '{{ theme.gitalk.language }}',\n      {%- endif %}\n      distractionFreeMode: {{ theme.gitalk.distraction_free_mode }}\n    });\n    gitalk.render('gitalk-container');\n  }, window.Gitalk);\n});\n</script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/livere.swig",
    "content": "{%- if page.comments %}\n<script>\nNexT.utils.loadComments(document.querySelector('#lv-container'), () => {\n  window.livereOptions = {\n    refer: location.pathname.replace(CONFIG.root, '').replace('index.html', '')\n  };\n  (function(d, s) {\n    var j, e = d.getElementsByTagName(s)[0];\n    if (typeof LivereTower === 'function') { return; }\n    j = d.createElement(s);\n    j.src = 'https://cdn-city.livere.com/js/embed.dist.js';\n    j.async = true;\n    e.parentNode.insertBefore(j, e);\n  })(document, 'script');\n});\n</script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/comments/valine.swig",
    "content": "{%- set valine_uri = theme.vendors.valine or '//unpkg.com/valine/dist/Valine.min.js' %}\n\n<script>\nNexT.utils.loadComments(document.querySelector('#valine-comments'), () => {\n  NexT.utils.getScript('{{ valine_uri }}', () => {\n    var GUEST = ['nick', 'mail', 'link'];\n    var guest = '{{ theme.valine.guest_info }}';\n    guest = guest.split(',').filter(item => {\n      return GUEST.includes(item);\n    });\n    new Valine({\n      el         : '#valine-comments',\n      verify     : {{ theme.valine.verify }},\n      notify     : {{ theme.valine.notify }},\n      appId      : '{{ theme.valine.appid }}',\n      appKey     : '{{ theme.valine.appkey }}',\n      placeholder: {{ theme.valine.placeholder | json }},\n      avatar     : '{{ theme.valine.avatar }}',\n      meta       : guest,\n      pageSize   : '{{ theme.valine.pageSize }}' || 10,\n      visitor    : {{ theme.valine.visitor }},\n      lang       : '{{ theme.valine.language }}' || 'zh-cn',\n      path       : location.pathname,\n      recordIP   : {{ theme.valine.recordIP }},\n      serverURLs : '{{ theme.valine.serverURLs }}'\n    });\n  }, window.Valine);\n});\n</script>\n"
  },
  {
    "path": "layout/_third-party/index.swig",
    "content": "{% include 'baidu-push.swig' %}\n\n{% include 'rating.swig' %}\n\n{%- if theme.algolia_search.enable %}\n  {% include 'search/algolia-search.swig' %}\n{% elif theme.swiftype_key %}\n  {% include 'search/swiftype.swig' %}\n{% elif theme.local_search.enable %}\n  {% include 'search/localsearch.swig' %}\n{%- endif %}\n\n{% include 'chat/chatra.swig' %}\n{% include 'chat/tidio.swig' %}\n\n{% include 'tags/pdf.swig' %}\n{% include 'tags/mermaid.swig' %}\n"
  },
  {
    "path": "layout/_third-party/math/index.swig",
    "content": "{%- if theme.math.mathjax.enable or theme.math.katex.enable %}\n  {%- set is_index_has_math = false %}\n\n  {# At home, check if there has `mathjax: true` post #}\n  {%- if is_home() and theme.math.per_page %}\n    {%- for post in page.posts.toArray() %}\n      {%- if post.mathjax and not is_index_has_math %}\n        {%- set is_index_has_math = true %}\n      {%- endif %}\n    {%- endfor %}\n  {%- endif %}\n\n  {%- if not theme.math.per_page or is_index_has_math or page.mathjax %}\n    {%- if theme.math.mathjax.enable %}\n      {% include '_third-party/math/mathjax.swig' %}\n    {% elif theme.math.katex.enable %}\n      {% include '_third-party/math/katex.swig' %}\n    {%- endif %}\n  {%- endif %}\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/math/katex.swig",
    "content": "{%- set katex_uri = theme.vendors.katex or '//cdn.jsdelivr.net/npm/katex@0/dist/katex.min.css' %}\n<link rel=\"stylesheet\" href=\"{{ katex_uri }}\">\n{%- if theme.math.katex.copy_tex %}\n  {%- set copy_tex_js_uri = theme.vendors.copy_tex_js or '//cdn.jsdelivr.net/npm/katex@0/dist/contrib/copy-tex.min.js' %}\n  {%- set copy_tex_css_uri = theme.vendors.copy_tex_css or '//cdn.jsdelivr.net/npm/katex@0/dist/contrib/copy-tex.min.css' %}\n  <script src=\"{{ copy_tex_js_uri }}\"></script>\n  <link rel=\"stylesheet\" href=\"{{ copy_tex_css_uri }}\">\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/math/mathjax.swig",
    "content": "{%- set mathjax_uri = theme.vendors.mathjax or '//cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js' %}\n\n<script>\n  if (typeof MathJax === 'undefined') {\n    window.MathJax = {\n      loader: {\n        {%- if theme.math.mathjax.mhchem %}\n          load: ['[tex]/mhchem'],\n        {%- endif %}\n        source: {\n          '[tex]/amsCd': '[tex]/amscd',\n          '[tex]/AMScd': '[tex]/amscd'\n        }\n      },\n      tex: {\n        inlineMath: {'[+]': [['$', '$']]},\n        {%- if theme.math.mathjax.mhchem %}\n          packages: {'[+]': ['mhchem']},\n        {%- endif %}\n        tags: 'ams'\n      },\n      options: {\n        renderActions: {\n          findScript: [10, doc => {\n            document.querySelectorAll('script[type^=\"math/tex\"]').forEach(node => {\n              const display = !!node.type.match(/; *mode=display/);\n              const math = new doc.options.MathItem(node.textContent, doc.inputJax[0], display);\n              const text = document.createTextNode('');\n              node.parentNode.replaceChild(text, node);\n              math.start = {node: text, delim: '', n: 0};\n              math.end = {node: text, delim: '', n: 0};\n              doc.math.push(math);\n            });\n          }, '', false],\n          insertedScript: [200, () => {\n            document.querySelectorAll('mjx-container').forEach(node => {\n              let target = node.parentNode;\n              if (target.nodeName.toLowerCase() === 'li') {\n                target.parentNode.classList.add('has-jax');\n              }\n            });\n          }, '', false]\n        }\n      }\n    };\n    (function () {\n      var script = document.createElement('script');\n      script.src = '{{ mathjax_uri }}';\n      script.defer = true;\n      document.head.appendChild(script);\n    })();\n  } else {\n    MathJax.startup.document.state(0);\n    MathJax.texReset();\n    MathJax.typeset();\n  }\n</script>\n"
  },
  {
    "path": "layout/_third-party/quicklink.swig",
    "content": "{%- if page.quicklink.enable %}\n  {%- set quicklink_uri = theme.vendors.quicklink or next_vendors('//cdn.jsdelivr.net/npm/quicklink@1/dist/quicklink.umd.js') %}\n  <script src=\"{{ quicklink_uri }}\"></script>\n  <script>\n    {%- if page.quicklink.delay %}\n      window.addEventListener('load', () => {\n    {%- endif %}\n      quicklink({\n        timeout : {{ page.quicklink.timeout }},\n        priority: {{ page.quicklink.priority }},\n        ignores : [uri => uri.includes('#'),uri => uri === '{{ url | replace('index.html', '') }}',{{ page.quicklink.ignores }}]\n      });\n    {%- if page.quicklink.delay %}\n      });\n    {%- endif %}\n  </script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/rating.swig",
    "content": "{%- if theme.rating.enable %}\n  <script{{ pjax }}>\n  if (CONFIG.page.isPost) {\n    wpac_init = window.wpac_init || [];\n    wpac_init.push({\n      widget: 'Rating',\n      id    : {{ theme.rating.id }},\n      el    : 'wpac-rating',\n      color : '{{ theme.rating.color }}'\n    });\n    (function() {\n      if ('WIDGETPACK_LOADED' in window) return;\n      WIDGETPACK_LOADED = true;\n      var mc = document.createElement('script');\n      mc.type = 'text/javascript';\n      mc.async = true;\n      mc.src = '//embed.widgetpack.com/widget.js';\n      var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(mc, s.nextSibling);\n    })();\n  }\n  </script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/search/algolia-search.swig",
    "content": "{%- set algolia_search_uri = theme.vendors.algolia_search or next_vendors('//cdn.jsdelivr.net/npm/algoliasearch@4/dist/algoliasearch-lite.umd.js') %}\n{%- set instant_search_uri = theme.vendors.instant_search or next_vendors('//cdn.jsdelivr.net/npm/instantsearch.js@4/dist/instantsearch.production.min.js') %}\n<script src=\"{{ algolia_search_uri }}\"></script>\n<script src=\"{{ instant_search_uri }}\"></script>\n\n{{- next_js('algolia-search.js') }}\n"
  },
  {
    "path": "layout/_third-party/search/localsearch.swig",
    "content": "{{- next_js('local-search.js') }}\n"
  },
  {
    "path": "layout/_third-party/search/swiftype.swig",
    "content": "<script>\n  (function(w,d,t,u,n,s,e){w['SwiftypeObject']=n;w[n]=w[n]||function(){\n    (w[n].q=w[n].q||[]).push(arguments);};s=d.createElement(t);\n    e=d.getElementsByTagName(t)[0];s.async=1;s.src=u;e.parentNode.insertBefore(s,e);\n  })(window,document,'script','//s.swiftypecdn.com/install/v2/st.js','_st');\n\n  _st('install','{{ theme.swiftype_key }}','2.0.0');\n</script>\n"
  },
  {
    "path": "layout/_third-party/statistics/busuanzi-counter.swig",
    "content": "{%- if theme.busuanzi_count.enable %}\n<div class=\"busuanzi-count\">\n  <script{{ pjax }} async src=\"https://busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js\"></script>\n\n  {%- if theme.busuanzi_count.total_visitors %}\n    <span class=\"post-meta-item\" id=\"busuanzi_container_site_uv\" style=\"display: none;\">\n      <span class=\"post-meta-item-icon\">\n        <i class=\"{{ theme.busuanzi_count.total_visitors_icon }}\"></i>\n      </span>\n      <span class=\"site-uv\" title=\"{{ __('footer.total_visitors') }}\">\n        <span id=\"busuanzi_value_site_uv\"></span>\n      </span>\n    </span>\n  {%- endif %}\n\n  {%- if theme.busuanzi_count.total_visitors and theme.busuanzi_count.total_views %}\n    <span class=\"post-meta-divider\">|</span>\n  {%- endif %}\n\n  {%- if theme.busuanzi_count.total_views %}\n    <span class=\"post-meta-item\" id=\"busuanzi_container_site_pv\" style=\"display: none;\">\n      <span class=\"post-meta-item-icon\">\n        <i class=\"{{ theme.busuanzi_count.total_views_icon }}\"></i>\n      </span>\n      <span class=\"site-pv\" title=\"{{ __('footer.total_views') }}\">\n        <span id=\"busuanzi_value_site_pv\"></span>\n      </span>\n    </span>\n  {%- endif %}\n</div>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/statistics/cnzz-analytics.swig",
    "content": "{%- if theme.cnzz_siteid %}\n  <div style=\"display: none;\">\n    <script{{ pjax }} src=\"//s95.cnzz.com/z_stat.php?id={{ theme.cnzz_siteid }}&web_id={{ theme.cnzz_siteid }}\"></script>\n  </div>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/statistics/firestore.swig",
    "content": "{%- if theme.firestore.enable %}\n  <script src=\"https://www.gstatic.com/firebasejs/6.3.3/firebase-app.js\"></script>\n  <script src=\"https://www.gstatic.com/firebasejs/6.3.3/firebase-firestore.js\"></script>\n  <script>\n    firebase.initializeApp({\n      apiKey   : '{{ theme.firestore.apiKey }}',\n      projectId: '{{ theme.firestore.projectId }}'\n    });\n\n    function getCount(doc, increaseCount) {\n      // IncreaseCount will be false when not in article page\n      return doc.get().then(d => {\n        var count = 0;\n        if (!d.exists) { // Has no data, initialize count\n          if (increaseCount) {\n            doc.set({\n              count: 1\n            });\n            count = 1;\n          }\n        } else { // Has data\n          count = d.data().count;\n          if (increaseCount) {\n            // If first view this article\n            doc.set({ // Increase count\n              count: count + 1\n            });\n            count++;\n          }\n        }\n\n        return count;\n      });\n    }\n\n    function appendCountTo(el) {\n      return count => {\n        el.innerText = count;\n      }\n    }\n  </script>\n  <script{{ pjax }}>\n    (function() {\n      var db = firebase.firestore();\n      var articles = db.collection('{{ theme.firestore.collection }}');\n\n      if (CONFIG.page.isPost) { // Is article page\n        var title = document.querySelector('.post-title').innerText.trim();\n        var doc = articles.doc(title);\n        var increaseCount = CONFIG.hostname === location.hostname;\n        if (localStorage.getItem(title)) {\n          increaseCount = false;\n        } else {\n          // Mark as visited\n          localStorage.setItem(title, true);\n        }\n        getCount(doc, increaseCount).then(appendCountTo(document.querySelector('.firestore-visitors-count')));\n      } else if (CONFIG.page.isHome) { // Is index page\n        var promises = [...document.querySelectorAll('.post-title')].map(element => {\n          var title = element.innerText.trim();\n          var doc = articles.doc(title);\n          return getCount(doc);\n        });\n        Promise.all(promises).then(counts => {\n          var metas = document.querySelectorAll('.firestore-visitors-count');\n          counts.forEach((val, idx) => {\n            appendCountTo(metas[idx])(val);\n          });\n        });\n      }\n    })();\n  </script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/statistics/index.swig",
    "content": "{% include 'busuanzi-counter.swig' %}\n{% include 'cnzz-analytics.swig' %}\n{% include 'firestore.swig' %}\n{% include 'lean-analytics.swig' %}\n"
  },
  {
    "path": "layout/_third-party/statistics/lean-analytics.swig",
    "content": "{%- if theme.leancloud_visitors.enable and not theme.valine.visitor %}\n<script{{ pjax }}>\n  (function() {\n    function leancloudSelector(url) {\n      url = encodeURI(url);\n      return document.getElementById(url).querySelector('.leancloud-visitors-count');\n    }\n\n    function addCount(Counter) {\n      var visitors = document.querySelector('.leancloud_visitors');\n      var url = decodeURI(visitors.id);\n      var title = visitors.dataset.flagTitle;\n\n      Counter('get', '/classes/Counter?where=' + encodeURIComponent(JSON.stringify({ url })))\n        .then(response => response.json())\n        .then(({ results }) => {\n          if (results.length > 0) {\n            var counter = results[0];\n            leancloudSelector(url).innerText = counter.time + 1;\n            Counter('put', '/classes/Counter/' + counter.objectId, { time: { '__op': 'Increment', 'amount': 1 } })\n              .catch(error => {\n                console.error('Failed to save visitor count', error);\n              });\n          } else {\n            {%- if theme.leancloud_visitors.security %}\n              leancloudSelector(url).innerText = 'Counter not initialized! More info at console err msg.';\n              console.error('ATTENTION! LeanCloud counter has security bug, see how to solve it here: https://github.com/theme-next/hexo-leancloud-counter-security. \\n However, you can still use LeanCloud without security, by setting `security` option to `false`.');\n            {% else %}\n              Counter('post', '/classes/Counter', { title, url, time: 1 })\n                .then(response => response.json())\n                .then(() => {\n                  leancloudSelector(url).innerText = 1;\n                })\n                .catch(error => {\n                  console.error('Failed to create', error);\n                });\n            {%- endif %}\n          }\n        })\n        .catch(error => {\n          console.error('LeanCloud Counter Error', error);\n        });\n    }\n\n    function showTime(Counter) {\n      var visitors = document.querySelectorAll('.leancloud_visitors');\n      var entries = [...visitors].map(element => {\n        return decodeURI(element.id);\n      });\n\n      Counter('get', '/classes/Counter?where=' + encodeURIComponent(JSON.stringify({ url: { '$in': entries } })))\n        .then(response => response.json())\n        .then(({ results }) => {\n          for (let url of entries) {\n            let target = results.find(item => item.url === url);\n            leancloudSelector(url).innerText = target ? target.time : 0;\n          }\n        })\n        .catch(error => {\n          console.error('LeanCloud Counter Error', error);\n        });\n    }\n\n    let { app_id, app_key, server_url } = {{ theme.leancloud_visitors | json }};\n    function fetchData(api_server) {\n      var Counter = (method, url, data) => {\n        return fetch(`${api_server}/1.1${url}`, {\n          method,\n          headers: {\n            'X-LC-Id'     : app_id,\n            'X-LC-Key'    : app_key,\n            'Content-Type': 'application/json',\n          },\n          body: JSON.stringify(data)\n        });\n      };\n      if (CONFIG.page.isPost) {\n        if (CONFIG.hostname !== location.hostname) return;\n        addCount(Counter);\n      } else if (document.querySelectorAll('.post-title-link').length >= 1) {\n        showTime(Counter);\n      }\n    }\n\n    let api_server = app_id.slice(-9) !== '-MdYXbMMI' ? server_url : `https://${app_id.slice(0, 8).toLowerCase()}.api.lncldglobal.com`;\n\n    if (api_server) {\n      fetchData(api_server);\n    } else {\n      fetch('https://app-router.leancloud.cn/2/route?appId=' + app_id)\n        .then(response => response.json())\n        .then(({ api_server }) => {\n          fetchData('https://' + api_server);\n        });\n    }\n  })();\n</script>\n\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/tags/mermaid.swig",
    "content": "{%- if theme.mermaid.enable %}\n{%- set mermaid_uri = theme.vendors.mermaid or '//cdn.jsdelivr.net/npm/mermaid@8/dist/mermaid.min.js' %}\n<script{{ pjax }}>\nif (document.querySelectorAll('pre.mermaid').length) {\n  NexT.utils.getScript('{{ mermaid_uri }}', () => {\n    mermaid.initialize({\n      theme    : '{{ theme.mermaid.theme }}',\n      logLevel : 3,\n      flowchart: { curve     : 'linear' },\n      gantt    : { axisFormat: '%m/%d/%Y' },\n      sequence : { actorMargin: 50 }\n    });\n  }, window.mermaid);\n}\n</script>\n{%- endif %}\n"
  },
  {
    "path": "layout/_third-party/tags/pdf.swig",
    "content": "{%- if theme.pdf.enable %}\n{%- set pdf_uri = next_vendors('pdf/web/viewer.html') %}\n<script{{ pjax }}>\ndocument.querySelectorAll('.pdfobject-container').forEach(element => {\n  let url = element.dataset.target;\n  let pdfOpenParams = {\n    navpanes : 0,\n    toolbar  : 0,\n    statusbar: 0,\n    pagemode : 'thumbs',\n    view     : 'FitH'\n  };\n  let pdfOpenFragment = '#' + Object.entries(pdfOpenParams).map(([key, value]) => `${key}=${encodeURIComponent(value)}`).join('&');\n  let fullURL = `{{ pdf_uri }}?file=${encodeURIComponent(url)}${pdfOpenFragment}`;\n\n  if (NexT.utils.supportsPDFs()) {\n    element.innerHTML = `<embed class=\"pdfobject\" src=\"${url + pdfOpenFragment}\" type=\"application/pdf\" style=\"height: ${element.dataset.height};\">`;\n  } else {\n    element.innerHTML = `<iframe src=\"${fullURL}\" style=\"height: ${element.dataset.height};\" frameborder=\"0\"></iframe>`;\n  }\n});\n</script>\n{%- endif %}\n"
  },
  {
    "path": "layout/archive.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/post-collapse.swig' as post_template with context %}\n{% import '_macro/sidebar.swig' as sidebar_template with context %}\n\n{% block title %}{{ __('title.archive') }} | {{ title }}{% endblock %}\n\n{% block class %}archive{% endblock %}\n\n{% block content %}\n\n  {#####################}\n  {### ARCHIVE BLOCK ###}\n  {#####################}\n  <div class=\"post-block\">\n    <div class=\"posts-collapse\">\n      <div class=\"collection-title\">\n        {%- set posts_length = site.posts.length %}\n        {%- if posts_length > 210 %}\n          {%- set cheers = 'excellent' %}\n        {% elif posts_length > 130 %}\n          {%- set cheers = 'great' %}\n        {% elif posts_length > 80 %}\n          {%- set cheers = 'good' %}\n        {% elif posts_length > 50 %}\n          {%- set cheers = 'nice' %}\n        {% elif posts_length > 30 %}\n          {%- set cheers = 'ok' %}\n        {% else %}\n          {%- set cheers = 'um' %}\n        {%- endif %}\n        <span class=\"collection-header\">{{ __('cheers.' + cheers) }}! {{ _p('counter.archive_posts', site.posts.length) }} {{ __('keep_on') }}</span>\n      </div>\n\n      {{ post_template.render(page.posts) }}\n\n    </div>\n  </div>\n  {#########################}\n  {### END ARCHIVE BLOCK ###}\n  {#########################}\n\n  {% include '_partials/pagination.swig' %}\n\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(false) }}\n{% endblock %}\n"
  },
  {
    "path": "layout/category.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/post-collapse.swig' as post_template with context %}\n{% import '_macro/sidebar.swig' as sidebar_template with context %}\n\n{% block title %}{{ __('title.category') }}: {{ page.category }} | {{ title }}{% endblock %}\n\n{% block class %}category{% endblock %}\n\n{% block content %}\n\n  {######################}\n  {### CATEGORY BLOCK ###}\n  {######################}\n  <div class=\"post-block\">\n    <div class=\"posts-collapse\">\n      <div class=\"collection-title\">\n        <h2 class=\"collection-header\">\n          {{- page.category }}\n          <small>{{ __('title.category') }}</small>\n        </h2>\n      </div>\n\n      {{ post_template.render(page.posts) }}\n    </div>\n  </div>\n  {##########################}\n  {### END CATEGORY BLOCK ###}\n  {##########################}\n\n  {% include '_partials/pagination.swig' %}\n\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(false) }}\n{% endblock %}\n"
  },
  {
    "path": "layout/index.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/sidebar.swig' as sidebar_template with context %}\n\n{% block title %}{{ title }}{%- if theme.index_with_subtitle and subtitle %} - {{ subtitle }}{%- endif %}{% endblock %}\n\n{% block class %}index posts-expand{% endblock %}\n\n{% block content %}\n\n  {%- for post in page.posts.toArray() %}\n    {{ partial('_macro/post.swig', {post: post, is_index: true}) }}\n  {%- endfor %}\n\n  {% include '_partials/pagination.swig' %}\n\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(false) }}\n{% endblock %}\n"
  },
  {
    "path": "layout/page.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/sidebar.swig' as sidebar_template with context %}\n\n{% block title %}\n  {%- set page_title_suffix = ' | ' + title %}\n\n  {%- if page.type === 'categories' and not page.title %}\n    {{- __('title.category') + page_title_suffix }}\n  {%- elif page.type === 'tags' and not page.title %}\n    {{- __('title.tag') + page_title_suffix }}\n  {%- elif page.type === 'schedule' and not page.title %}\n    {{- __('title.schedule') + page_title_suffix }}\n  {%- else %}\n    {{- page.title + page_title_suffix }}\n  {%- endif %}\n{% endblock %}\n\n{% block class %}page posts-expand{% endblock %}\n\n{% block content %}\n\n    {##################}\n    {### PAGE BLOCK ###}\n    {##################}\n    <div class=\"post-block\" lang=\"{{ page.lang or config.language }}\">\n      {% include '_partials/page/page-header.swig' %}\n      {#################}\n      {### PAGE BODY ###}\n      {#################}\n      <div class=\"post-body{%- if page.direction and page.direction.toLowerCase() === 'rtl' %} rtl{%- endif %}\">\n        {%- if page.type === 'tags' %}\n          <div class=\"tag-cloud\">\n            <div class=\"tag-cloud-title\">\n              {{ _p('counter.tag_cloud', site.tags.length) }}\n            </div>\n            <div class=\"tag-cloud-tags\">\n              {{ tagcloud({\n                min_font   : theme.tagcloud.min,\n                max_font   : theme.tagcloud.max,\n                amount     : theme.tagcloud.amount,\n                color      : true,\n                start_color: theme.tagcloud.start,\n                end_color  : theme.tagcloud.end})\n              }}\n            </div>\n          </div>\n        {% elif page.type === 'categories' %}\n          <div class=\"category-all-page\">\n            <div class=\"category-all-title\">\n              {{ _p('counter.categories', site.categories.length) }}\n            </div>\n            <div class=\"category-all\">\n              {{ list_categories() }}\n            </div>\n          </div>\n        {% elif page.type === 'schedule' %}\n          <div class=\"event-list\">\n          </div>\n          {% include '_scripts/pages/schedule.swig' %}\n        {% else %}\n          {{ page.content }}\n        {%- endif %}\n      </div>\n      {#####################}\n      {### END PAGE BODY ###}\n      {#####################}\n    </div>\n    {% include '_partials/page/breadcrumb.swig' %}\n    {######################}\n    {### END PAGE BLOCK ###}\n    {######################}\n\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(true) }}\n{% endblock %}\n"
  },
  {
    "path": "layout/post.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/sidebar.swig' as sidebar_template with context %}\n\n{% block title %}{{ page.title }} | {{ title }}{% endblock %}\n\n{% block class %}post posts-expand{% endblock %}\n\n{% block content %}\n\n  {{ partial('_macro/post.swig', {post: page}) }}\n\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(true) }}\n{% endblock %}\n"
  },
  {
    "path": "layout/tag.swig",
    "content": "{% extends '_layout.swig' %}\n{% import '_macro/post-collapse.swig' as post_template with context %}\n{% import '_macro/sidebar.swig' as sidebar_template with context %}\n\n{% block title %}{{ __('title.tag') }}: {{ page.tag }} | {{ title }}{% endblock %}\n\n{% block class %}tag{% endblock %}\n\n{% block content %}\n\n  {#################}\n  {### TAG BLOCK ###}\n  {#################}\n  <div class=\"post-block\">\n    <div class=\"posts-collapse\">\n      <div class=\"collection-title\">\n        <h2 class=\"collection-header\">\n          {{- page.tag }}\n          <small>{{ __('title.tag') }}</small>\n        </h2>\n      </div>\n\n      {{ post_template.render(page.posts) }}\n    </div>\n  </div>\n  {#####################}\n  {### END TAG BLOCK ###}\n  {#####################}\n\n  {% include '_partials/pagination.swig' %}\n\n{% endblock %}\n\n{% block sidebar %}\n  {{ sidebar_template.render(false) }}\n{% endblock %}\n"
  },
  {
    "path": "package.json",
    "content": "{\n  \"name\": \"hexo-theme-next\",\n  \"version\": \"7.8.0\",\n  \"description\": \"Elegant and powerful theme for Hexo.\",\n  \"main\": \"gulpfile.js\",\n  \"scripts\": {\n    \"test\": \"gulp\"\n  },\n  \"repository\": {\n    \"type\": \"git\",\n    \"url\": \"git+https://github.com/theme-next/hexo-theme-next.git\"\n  },\n  \"keywords\": [\n    \"hexo\",\n    \"theme\",\n    \"next\"\n  ],\n  \"author\": \"NexT <support@theme-next.org> (https://theme-next.org)\",\n  \"license\": \"AGPL-3.0-or-later\",\n  \"bugs\": {\n    \"url\": \"https://github.com/theme-next/hexo-theme-next/issues\"\n  },\n  \"homepage\": \"https://theme-next.org\",\n  \"devDependencies\": {\n    \"eslint\": \"^6.8.0\",\n    \"eslint-config-theme-next\": \"^1.1.4\",\n    \"gulp\": \"^4.0.2\",\n    \"gulp-eslint\": \"^6.0.0\",\n    \"gulp-shell\": \"^0.8.0\",\n    \"js-yaml\": \"^3.13.1\",\n    \"stylint\": \"^2.0.0\"\n  },\n  \"engines\": {\n    \"node\": \">=10.9.0\"\n  }\n}\n"
  },
  {
    "path": "scripts/events/index.js",
    "content": "/* global hexo */\n\n'use strict';\n\nhexo.on('generateBefore', () => {\n  // Merge config.\n  require('./lib/config')(hexo);\n  // Add filter type `theme_inject`\n  require('./lib/injects')(hexo);\n});\n\nhexo.on('generateAfter', () => {\n  if (!hexo.theme.config.reminder) return;\n  const https = require('https');\n  const path = require('path');\n  const { version } = require(path.normalize('../../package.json'));\n  https.get('https://api.github.com/repos/theme-next/hexo-theme-next/releases/latest', {\n    headers: {\n      'User-Agent': 'Theme NexT Client'\n    }\n  }, res => {\n    let result = '';\n    res.on('data', data => {\n      result += data;\n    });\n    res.on('end', () => {\n      try {\n        let latest = JSON.parse(result).tag_name.replace('v', '').split('.');\n        let current = version.split('.');\n        let isOutdated = false;\n        for (let i = 0; i < Math.max(latest.length, current.length); i++) {\n          if (!current[i] || latest[i] > current[i]) {\n            isOutdated = true;\n            break;\n          }\n          if (latest[i] < current[i]) {\n            break;\n          }\n        }\n        if (isOutdated) {\n          hexo.log.warn(`Your theme NexT is outdated. Current version: v${current.join('.')}, latest version: v${latest.join('.')}`);\n          hexo.log.warn('Visit https://github.com/theme-next/hexo-theme-next/releases for more information.');\n        } else {\n          hexo.log.info('Congratulations! Your are using the latest version of theme NexT.');\n        }\n      } catch (err) {\n        hexo.log.error('Failed to detect version info. Error message:');\n        hexo.log.error(err);\n      }\n    });\n  }).on('error', err => {\n    hexo.log.error('Failed to detect version info. Error message:');\n    hexo.log.error(err);\n  });\n});\n"
  },
  {
    "path": "scripts/events/lib/config.js",
    "content": "'use strict';\n\nfunction isObject(item) {\n  return item && typeof item === 'object' && !Array.isArray(item);\n}\n\nfunction merge(target, source) {\n  for (const key in source) {\n    if (isObject(target[key]) && isObject(source[key])) {\n      merge(target[key], source[key]);\n    } else {\n      target[key] = source[key];\n    }\n  }\n  return target;\n}\n\nmodule.exports = hexo => {\n  let data = hexo.locals.get('data');\n\n  /**\n   * Merge configs from _data/next.yml into hexo.theme.config.\n   * If `override`, configs in next.yml will rewrite configs in hexo.theme.config.\n   * If next.yml not exists, merge all `theme_config.*` into hexo.theme.config.\n   */\n  if (data.next) {\n    if (data.next.override) {\n      hexo.theme.config = data.next;\n    } else {\n      merge(hexo.config, data.next);\n      merge(hexo.theme.config, data.next);\n    }\n  } else {\n    merge(hexo.theme.config, hexo.config.theme_config);\n  }\n\n  if (hexo.theme.config.cache && hexo.theme.config.cache.enable && hexo.config.relative_link) {\n    hexo.log.warn('Since caching is turned on, the `relative_link` option in Hexo `_config.yml` is set to `false` to avoid potential hazards.');\n    hexo.config.relative_link = false;\n  }\n  hexo.config.meta_generator = false;\n\n  // Custom languages support. Introduced in NexT v6.3.0.\n  if (data.languages) {\n    let { language } = hexo.config;\n    let { i18n } = hexo.theme;\n\n    const mergeLang = lang => {\n      i18n.set(lang, merge(i18n.get([lang]), data.languages[lang]));\n    };\n\n    if (Array.isArray(language)) {\n      for (let lang of language) {\n        mergeLang(lang);\n      }\n    } else {\n      mergeLang(language);\n    }\n  }\n};\n"
  },
  {
    "path": "scripts/events/lib/injects-point.js",
    "content": "'use strict';\n\nmodule.exports = {\n  views: [\n    'head',\n    'header',\n    'sidebar',\n    'postMeta',\n    'postBodyEnd',\n    'footer',\n    'bodyEnd',\n    'comment'\n  ],\n  styles: [\n    'variable',\n    'mixin',\n    'style'\n  ]\n};\n"
  },
  {
    "path": "scripts/events/lib/injects.js",
    "content": "'use strict';\n\nconst fs = require('fs');\nconst path = require('path');\nconst points = require('./injects-point');\nconst defaultExtname = '.swig';\n\n// Defining stylus types\nclass StylusInject {\n  constructor(base_dir) {\n    this.base_dir = base_dir;\n    this.files = [];\n  }\n  push(file) {\n    // Get absolute path base on hexo dir\n    this.files.push(path.resolve(this.base_dir, file));\n  }\n}\n\n// Defining view types\nclass ViewInject {\n  constructor(base_dir) {\n    this.base_dir = base_dir;\n    this.raws = [];\n  }\n  raw(name, raw, ...args) {\n    // Set default extname\n    if (path.extname(name) === '') {\n      name += defaultExtname;\n    }\n    this.raws.push({name, raw, args});\n  }\n  file(name, file, ...args) {\n    // Set default extname from file's extname\n    if (path.extname(name) === '') {\n      name += path.extname(file);\n    }\n    // Get absolute path base on hexo dir\n    this.raw(name, fs.readFileSync(path.resolve(this.base_dir, file), 'utf8'), ...args);\n  }\n}\n\n// Init injects\nfunction initInject(base_dir) {\n  let injects = {};\n  points.styles.forEach(item => {\n    injects[item] = new StylusInject(base_dir);\n  });\n  points.views.forEach(item => {\n    injects[item] = new ViewInject(base_dir);\n  });\n  return injects;\n}\n\nmodule.exports = hexo => {\n  // Exec theme_inject filter\n  let injects = initInject(hexo.base_dir);\n  hexo.execFilterSync('theme_inject', injects);\n  hexo.theme.config.injects = {};\n\n  // Inject stylus\n  points.styles.forEach(type => {\n    hexo.theme.config.injects[type] = injects[type].files;\n  });\n\n  // Inject views\n  points.views.forEach(type => {\n    let configs = Object.create(null);\n    hexo.theme.config.injects[type] = [];\n    // Add or override view.\n    injects[type].raws.forEach((injectObj, index) => {\n      let name = `inject/${type}/${injectObj.name}`;\n      hexo.theme.setView(name, injectObj.raw);\n      configs[name] = {\n        layout : name,\n        locals : injectObj.args[0],\n        options: injectObj.args[1],\n        order  : injectObj.args[2] || index\n      };\n    });\n    // Views sort.\n    hexo.theme.config.injects[type] = Object.values(configs)\n      .sort((x, y) => x.order - y.order);\n  });\n};\n"
  },
  {
    "path": "scripts/filters/comment/changyan.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst path = require('path');\nconst { iconText } = require('./common');\n\n// Add comment\nhexo.extend.filter.register('theme_inject', injects => {\n  let theme = hexo.theme.config;\n  if (!theme.changyan.enable || !theme.changyan.appid || !theme.changyan.appkey) return;\n\n  injects.comment.raw('changyan', `\n  <div class=\"comments\">\n    <div id=\"SOHUCS\"></div>\n  </div>\n  `, {}, {cache: true});\n\n  injects.bodyEnd.file('changyan', path.join(hexo.theme_dir, 'layout/_third-party/comments/changyan.swig'));\n\n});\n\n// Add post_meta\nhexo.extend.filter.register('theme_inject', injects => {\n  let theme = hexo.theme.config;\n  if (!theme.changyan.enable || !theme.changyan.appid || !theme.changyan.appkey) return;\n\n  injects.postMeta.raw('changyan', `\n  {% if post.comments %}\n  <span class=\"post-meta-item\">\n    ${iconText('far fa-comment', 'changyan')}\n    {% if is_post() %}\n      <a title=\"changyan\" href=\"{{ url_for(post.path) }}#SOHUCS\" itemprop=\"discussionUrl\">\n        <span id=\"changyan_count_unit\" class=\"post-comments-count hc-comment-count\" data-xid=\"{{ post.path }}\" itemprop=\"commentCount\"></span>\n      </a>\n    {% else %}\n      <a title=\"changyan\" href=\"{{ url_for(post.path) }}#SOHUCS\" itemprop=\"discussionUrl\">\n        <span id=\"url::{{ post.permalink }}\" class=\"cy_cmt_count\" data-xid=\"{{ post.path }}\" itemprop=\"commentCount\"></span>\n      </a>\n    {% endif %}\n  </span>\n  {% endif %}\n  `, {}, {}, theme.changyan.post_meta_order);\n\n});\n"
  },
  {
    "path": "scripts/filters/comment/common.js",
    "content": "'use strict';\n\nfunction capitalize(input) {\n  return input.toString().charAt(0).toUpperCase() + input.toString().substr(1);\n}\n\nmodule.exports = {\n  iconText(icon, key, defaultValue) {\n    if (!defaultValue) {\n      defaultValue = capitalize(key);\n    }\n    return `\n      <span class=\"post-meta-item-icon\">\n        <i class=\"${icon}\"></i>\n      </span>\n      {%- set post_meta_comment = __('post.comments.${key}') %}\n      {%- if post_meta_comment == 'post.comments.${key}' %}\n        {%- set post_meta_comment = '${defaultValue}' %}\n      {%- endif %}\n      <span class=\"post-meta-item-text\">{{ post_meta_comment + __('symbol.colon') }}</span>\n    `;\n  }\n};\n"
  },
  {
    "path": "scripts/filters/comment/default-config.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst path = require('path');\n\nhexo.extend.filter.register('theme_inject', injects => {\n  injects.comment.raws.forEach(element => {\n    // Set default button content\n    let injectName = path.basename(element.name, path.extname(element.name));\n    element.args[0] = Object.assign({\n      configKey: injectName,\n      class    : injectName,\n      button   : injectName\n    }, element.args[0]);\n    // Get locals and config\n    let locals = element.args[0];\n    let config = hexo.theme.config.comments;\n    // Set activeClass\n    if (config.active === locals.configKey) {\n      config.activeClass = locals.class;\n    }\n    // Set custom button content\n    if (config.nav) {\n      let nav = config.nav[locals.configKey] || {};\n      if (nav.order) {\n        element.args[2] = nav.order;\n      }\n      if (nav.text) {\n        locals.button = nav.text;\n      }\n    }\n  });\n}, 99999);\n"
  },
  {
    "path": "scripts/filters/comment/disqus.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst path = require('path');\nconst { iconText } = require('./common');\n\n// Add comment\nhexo.extend.filter.register('theme_inject', injects => {\n  let theme = hexo.theme.config;\n  if (!theme.disqus.enable || !theme.disqus.shortname) return;\n\n  injects.comment.raw('disqus', `\n  <div class=\"comments\">\n    <div id=\"disqus_thread\">\n      <noscript>Please enable JavaScript to view the comments powered by Disqus.</noscript>\n    </div>\n  </div>\n  `, {}, {cache: true});\n\n  injects.bodyEnd.file('disqus', path.join(hexo.theme_dir, 'layout/_third-party/comments/disqus.swig'));\n\n});\n\n// Add post_meta\nhexo.extend.filter.register('theme_inject', injects => {\n  let theme = hexo.theme.config;\n  if (!theme.disqus.enable || !theme.disqus.shortname || !theme.disqus.count) return;\n\n  injects.postMeta.raw('disqus', `\n  {% if post.comments %}\n  <span class=\"post-meta-item\">\n    ${iconText('far fa-comment', 'disqus')}\n    <a title=\"disqus\" href=\"{{ url_for(post.path) }}#disqus_thread\" itemprop=\"discussionUrl\">\n      <span class=\"post-comments-count disqus-comment-count\" data-disqus-identifier=\"{{ post.path }}\" itemprop=\"commentCount\"></span>\n    </a>\n  </span>\n  {% endif %}\n  `, {}, {}, theme.disqus.post_meta_order);\n\n});\n"
  },
  {
    "path": "scripts/filters/comment/disqusjs.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst path = require('path');\n\n// Add comment\nhexo.extend.filter.register('theme_inject', injects => {\n  let theme = hexo.theme.config;\n  if (!theme.disqusjs.enable || !theme.disqusjs.shortname || !theme.disqusjs.apikey) return;\n\n  injects.comment.raw('disqusjs', `\n  <div class=\"comments\">\n    <div id=\"disqus_thread\">\n      <noscript>Please enable JavaScript to view the comments powered by Disqus.</noscript>\n    </div>\n  </div>\n  `, {}, {cache: true});\n\n  injects.bodyEnd.file('disqusjs', path.join(hexo.theme_dir, 'layout/_third-party/comments/disqusjs.swig'));\n\n});\n"
  },
  {
    "path": "scripts/filters/comment/gitalk.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst path = require('path');\n\n// Add comment\nhexo.extend.filter.register('theme_inject', injects => {\n  let theme = hexo.theme.config;\n  if (!theme.gitalk.enable) return;\n\n  injects.comment.raw('gitalk', '<div class=\"comments\" id=\"gitalk-container\"></div>', {}, {cache: true});\n\n  injects.bodyEnd.file('gitalk', path.join(hexo.theme_dir, 'layout/_third-party/comments/gitalk.swig'));\n\n});\n"
  },
  {
    "path": "scripts/filters/comment/livere.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst path = require('path');\n\n// Add comment\nhexo.extend.filter.register('theme_inject', injects => {\n  let theme = hexo.theme.config;\n  if (!theme.livere_uid) return;\n\n  injects.comment.raw('livere', `\n  <div class=\"comments\">\n    <div id=\"lv-container\" data-id=\"city\" data-uid=\"{{ theme.livere_uid }}\"></div>\n  </div>\n  `, {}, {cache: true});\n\n  injects.bodyEnd.file('livere', path.join(hexo.theme_dir, 'layout/_third-party/comments/livere.swig'));\n\n});\n"
  },
  {
    "path": "scripts/filters/comment/valine.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst path = require('path');\nconst { iconText } = require('./common');\n\n// Add comment\nhexo.extend.filter.register('theme_inject', injects => {\n  let theme = hexo.theme.config;\n  if (!theme.valine.enable || !theme.valine.appid || !theme.valine.appkey) return;\n\n  injects.comment.raw('valine', '<div class=\"comments\" id=\"valine-comments\"></div>', {}, {cache: true});\n\n  injects.bodyEnd.file('valine', path.join(hexo.theme_dir, 'layout/_third-party/comments/valine.swig'));\n\n});\n\n// Add post_meta\nhexo.extend.filter.register('theme_inject', injects => {\n  let theme = hexo.theme.config;\n  if (!theme.valine.enable || !theme.valine.appid || !theme.valine.appkey) return;\n\n  injects.postMeta.raw('valine', `\n  {% if post.comments and (is_post() or theme.valine.comment_count) %}\n  <span class=\"post-meta-item\">\n    ${iconText('far fa-comment', 'valine')}\n    <a title=\"valine\" href=\"{{ url_for(post.path) }}#valine-comments\" itemprop=\"discussionUrl\">\n      <span class=\"post-comments-count valine-comment-count\" data-xid=\"{{ url_for(post.path) }}\" itemprop=\"commentCount\"></span>\n    </a>\n  </span>\n  {% endif %}\n  `, {}, {}, theme.valine.post_meta_order);\n\n});\n"
  },
  {
    "path": "scripts/filters/default-injects.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst points = require('../events/lib/injects-point');\n\nhexo.extend.filter.register('theme_inject', injects => {\n  let filePath = hexo.theme.config.custom_file_path;\n\n  if (!filePath) return;\n\n  points.views.forEach(key => {\n    if (filePath[key]) {\n      injects[key].file('custom', filePath[key]);\n    }\n  });\n\n  points.styles.forEach(key => {\n    if (filePath[key]) {\n      injects[key].push(filePath[key]);\n    }\n  });\n\n}, 99);\n"
  },
  {
    "path": "scripts/filters/front-matter.js",
    "content": "/**\n * Modify front-matter.\n *\n * Some keys are included by Hexo, please don't use them.\n * e.g. layout title date updated comments tags categories permalink keywords\n *\n * Some keys are generated by Hexo, don't use them either.\n * e.g. content excerpt more source full_source path permalink prev next raw photos link\n */\n\n/* global hexo */\n\n'use strict';\n\nconst keys = ['toc', 'reward_settings', 'quicklink'];\n\nfunction showWarnLog(source, variable) {\n  hexo.log.warn(`front-matter: '${variable}' has deprecated, source: ${source}`);\n  hexo.log.warn('see: https://github.com/theme-next/hexo-theme-next/pull/1211');\n}\n\nfunction compatibleBeforeAssign(page) {\n  if (page.quicklink === true) {\n    page.quicklink = {enable: true};\n    showWarnLog(page.source, 'quicklink:true');\n  }\n  if (page.quicklink === false) {\n    page.quicklink = {enable: false};\n    showWarnLog(page.source, 'quicklink:true');\n  }\n}\n\nfunction compatibleAfterAssign(page) {\n  if (page.reward !== undefined) {\n    page.reward_settings.enable = page.reward;\n    showWarnLog(page.source, 'reward');\n  }\n  if (page.toc_number !== undefined) {\n    page.toc.number = page.toc_number;\n    showWarnLog(page.source, 'toc_number');\n  }\n  if (page.toc_max_depth !== undefined) {\n    page.toc.max_depth = page.toc_max_depth;\n    showWarnLog(page.source, 'toc_max_depth');\n  }\n}\n\nhexo.extend.filter.register('template_locals', locals => {\n  const { page, theme } = locals;\n\n  compatibleBeforeAssign(page);\n\n  keys.forEach(key => {\n    page[key] = Object.assign({}, theme[key], page[key]);\n  });\n\n  compatibleAfterAssign(page);\n\n  // Set default value for toc.max_depth\n  if (!page.toc.max_depth) {\n    page.toc.max_depth = 6;\n  }\n\n  // Set home or archive quicklink\n  if (page.__index) {\n    page.quicklink.enable = theme.quicklink.home;\n  }\n  if (page.archive) {\n    page.quicklink.enable = theme.quicklink.archive;\n  }\n});\n"
  },
  {
    "path": "scripts/filters/locals.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst path = require('path');\n\nhexo.extend.filter.register('template_locals', locals => {\n  const { env, config } = hexo;\n  const { __, theme } = locals;\n  const { i18n } = hexo.theme;\n  // Hexo & NexT version\n  locals.hexo_version = env.version;\n  locals.next_version = require(path.normalize('../../package.json')).version;\n  // Language & Config\n  locals.title = __('title') !== 'title' ? __('title') : config.title;\n  locals.subtitle = __('subtitle') !== 'subtitle' ? __('subtitle') : config.subtitle;\n  locals.author = __('author') !== 'author' ? __('author') : config.author;\n  locals.description = __('description') !== 'description' ? __('description') : config.description;\n  locals.languages = [...i18n.languages];\n  locals.languages.splice(locals.languages.indexOf('default'), 1);\n  locals.page.lang = locals.page.lang || locals.page.language;\n  // Creative Commons\n  locals.ccURL = 'https://creativecommons.org/' + (theme.creative_commons.license === 'zero' ? 'publicdomain/zero/1.0/' : 'licenses/' + theme.creative_commons.license + '/4.0/') + (theme.creative_commons.language || '');\n  // PJAX\n  locals.pjax = theme.pjax ? ' data-pjax' : '';\n});\n"
  },
  {
    "path": "scripts/filters/minify.js",
    "content": "/* global hexo */\n\n'use strict';\n\nhexo.extend.filter.register('after_generate', () => {\n  const theme = hexo.theme.config;\n  if (!theme.minify) return;\n\n  const lists = hexo.route.list();\n  const velocity = lists.filter(list => list.includes('lib/velocity'));\n  const fontawesome = lists.filter(list => list.includes('lib/font-awesome'));\n\n  if (!theme.bookmark.enable) {\n    hexo.route.remove('js/bookmark.js');\n  }\n\n  if (!theme.motion.enable) {\n    hexo.route.remove('js/motion.js');\n    velocity.forEach(path => {\n      hexo.route.remove(path);\n    });\n  }\n\n  if (theme.motion.enable && theme.vendors.velocity && theme.vendors.velocity_ui) {\n    velocity.forEach(path => {\n      hexo.route.remove(path);\n    });\n  }\n\n  if (theme.vendors.fontawesome) {\n    fontawesome.forEach(path => {\n      hexo.route.remove(path);\n    });\n  }\n\n  if (theme.vendors.anime) {\n    hexo.route.remove('lib/anime.min.js');\n  }\n\n  if (!theme.algolia_search.enable) {\n    hexo.route.remove('js/algolia-search.js');\n  }\n\n  if (!theme.local_search.enable) {\n    hexo.route.remove('js/local-search.js');\n  }\n\n  if (theme.scheme === 'Muse' || theme.scheme === 'Mist') {\n    hexo.route.remove('js/schemes/pisces.js');\n  } else if (theme.scheme === 'Pisces' || theme.scheme === 'Gemini') {\n    hexo.route.remove('js/schemes/muse.js');\n  }\n});\n"
  },
  {
    "path": "scripts/filters/post.js",
    "content": "/* global hexo */\n\n'use strict';\n\nhexo.extend.filter.register('after_post_render', data => {\n  const { config } = hexo;\n  const theme = hexo.theme.config;\n  if (!theme.exturl && !theme.lazyload) return;\n  if (theme.lazyload) {\n    data.content = data.content.replace(/(<img[^>]*) src=/img, '$1 data-src=');\n  }\n  if (theme.exturl) {\n    const url = require('url');\n    const siteHost = url.parse(config.url).hostname || config.url;\n    data.content = data.content.replace(/<a[^>]* href=\"([^\"]+)\"[^>]*>([^<]+)<\\/a>/img, (match, href, html) => {\n      // Exit if the href attribute doesn't exists.\n      if (!href) return match;\n\n      // Exit if the url has same host with `config.url`, which means it's an internal link.\n      let link = url.parse(href);\n      if (!link.protocol || link.hostname === siteHost) return match;\n\n      return `<span class=\"exturl\" data-url=\"${Buffer.from(href).toString('base64')}\">${html}<i class=\"fa fa-external-link-alt\"></i></span>`;\n    });\n  }\n\n}, 0);\n"
  },
  {
    "path": "scripts/helpers/engine.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst crypto = require('crypto');\n\nhexo.extend.helper.register('next_inject', function(point) {\n  return hexo.theme.config.injects[point]\n    .map(item => this.partial(item.layout, item.locals, item.options))\n    .join('');\n});\n\nhexo.extend.helper.register('next_js', function(...urls) {\n  const { js } = hexo.theme.config;\n  return urls.map(url => this.js(`${js}/${url}`)).join('');\n});\n\nhexo.extend.helper.register('next_vendors', function(url) {\n  if (url.startsWith('//')) return url;\n  const internal = hexo.theme.config.vendors._internal;\n  return this.url_for(`${internal}/${url}`);\n});\n\nhexo.extend.helper.register('post_edit', function(src) {\n  const theme = hexo.theme.config;\n  if (!theme.post_edit.enable) return '';\n  return this.next_url(theme.post_edit.url + src, '<i class=\"fa fa-pencil-alt\"></i>', {\n    class: 'post-edit-link',\n    title: this.__('post.edit')\n  });\n});\n\nhexo.extend.helper.register('post_nav', function(post) {\n  const theme = hexo.theme.config;\n  if (theme.post_navigation === false || (!post.prev && !post.next)) return '';\n  const prev = theme.post_navigation === 'right' ? post.prev : post.next;\n  const next = theme.post_navigation === 'right' ? post.next : post.prev;\n  const left = prev ? `\n    <a href=\"${this.url_for(prev.path)}\" rel=\"prev\" title=\"${prev.title}\">\n      <i class=\"fa fa-chevron-left\"></i> ${prev.title}\n    </a>` : '';\n  const right = next ? `\n    <a href=\"${this.url_for(next.path)}\" rel=\"next\" title=\"${next.title}\">\n      ${next.title} <i class=\"fa fa-chevron-right\"></i>\n    </a>` : '';\n  return `\n    <div class=\"post-nav\">\n      <div class=\"post-nav-item\">${left}</div>\n      <div class=\"post-nav-item\">${right}</div>\n    </div>`;\n});\n\nhexo.extend.helper.register('gitalk_md5', function(path) {\n  let str = this.url_for(path);\n  str.replace('index.html', '');\n  return crypto.createHash('md5').update(str).digest('hex');\n});\n\nhexo.extend.helper.register('canonical', function() {\n  // https://support.google.com/webmasters/answer/139066\n  const { permalink } = hexo.config;\n  let url = this.url.replace(/index\\.html$/, '');\n  if (!permalink.endsWith('.html')) {\n    url = url.replace(/\\.html$/, '');\n  }\n  return `<link rel=\"canonical\" href=\"${url}\">`;\n});\n\n/**\n * Get page path given a certain language tag\n */\nhexo.extend.helper.register('i18n_path', function(language) {\n  const { path, lang } = this.page;\n  const base = path.startsWith(lang) ? path.slice(lang.length + 1) : path;\n  return this.url_for(`${this.languages.indexOf(language) === 0 ? '' : '/' + language}/${base}`);\n});\n\n/**\n * Get the language name\n */\nhexo.extend.helper.register('language_name', function(language) {\n  const name = hexo.theme.i18n.__(language)('name');\n  return name === 'name' ? language : name;\n});\n"
  },
  {
    "path": "scripts/helpers/font.js",
    "content": "/* global hexo */\n\n'use strict';\n\nhexo.extend.helper.register('next_font', () => {\n  const config = hexo.theme.config.font;\n\n  if (!config || !config.enable) return '';\n\n  const fontDisplay = '&display=swap';\n  const fontSubset = '&subset=latin,latin-ext';\n  const fontStyles = ':300,300italic,400,400italic,700,700italic';\n  const fontHost = config.host || '//fonts.googleapis.com';\n\n  //Get a font list from config\n  let fontFamilies = ['global', 'title', 'headings', 'posts', 'codes'].map(item => {\n    if (config[item] && config[item].family && config[item].external) {\n      return config[item].family + fontStyles;\n    }\n    return '';\n  });\n\n  fontFamilies = fontFamilies.filter(item => item !== '');\n  fontFamilies = [...new Set(fontFamilies)];\n  fontFamilies = fontFamilies.join('|');\n\n  // Merge extra parameters to the final processed font string\n  return fontFamilies ? `<link rel=\"stylesheet\" href=\"${fontHost}/css?family=${fontFamilies.concat(fontDisplay, fontSubset)}\">` : '';\n});\n"
  },
  {
    "path": "scripts/helpers/next-config.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst url = require('url');\n\n/**\n * Export theme config to js\n */\nhexo.extend.helper.register('next_config', function() {\n  let { config, theme, next_version } = this;\n  config.algolia = config.algolia || {};\n  let exportConfig = {\n    hostname  : url.parse(config.url).hostname || config.url,\n    root      : config.root,\n    scheme    : theme.scheme,\n    version   : next_version,\n    exturl    : theme.exturl,\n    sidebar   : theme.sidebar,\n    copycode  : theme.codeblock.copy_button,\n    back2top  : theme.back2top,\n    bookmark  : theme.bookmark,\n    fancybox  : theme.fancybox,\n    mediumzoom: theme.mediumzoom,\n    lazyload  : theme.lazyload,\n    pangu     : theme.pangu,\n    comments  : theme.comments,\n    algolia   : {\n      appID    : config.algolia.applicationID,\n      apiKey   : config.algolia.apiKey,\n      indexName: config.algolia.indexName,\n      hits     : theme.algolia_search.hits,\n      labels   : theme.algolia_search.labels\n    },\n    localsearch: theme.local_search,\n    motion     : theme.motion\n  };\n  if (config.search) {\n    exportConfig.path = config.search.path;\n  }\n  return `<script id=\"hexo-configurations\">\n    var NexT = window.NexT || {};\n    var CONFIG = ${JSON.stringify(exportConfig)};\n  </script>`;\n});\n"
  },
  {
    "path": "scripts/helpers/next-url.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst { htmlTag } = require('hexo-util');\nconst url = require('url');\n\nhexo.extend.helper.register('next_url', function(path, text, options = {}) {\n  const { config } = this;\n  const data = url.parse(path);\n  const siteHost = url.parse(config.url).hostname || config.url;\n\n  const theme = hexo.theme.config;\n  let exturl = '';\n  let tag = 'a';\n  let attrs = { href: this.url_for(path) };\n\n  // If `exturl` enabled, set spanned links only on external links.\n  if (theme.exturl && data.protocol && data.hostname !== siteHost) {\n    tag = 'span';\n    exturl = 'exturl';\n    const encoded = Buffer.from(path).toString('base64');\n    attrs = {\n      class     : exturl,\n      'data-url': encoded\n    };\n  }\n\n  for (let key in options) {\n\n    /**\n     * If option have `class` attribute, add it to\n     * 'exturl' class if `exturl` option enabled.\n     */\n    if (exturl !== '' && key === 'class') {\n      attrs[key] += ' ' + options[key];\n    } else {\n      attrs[key] = options[key];\n    }\n  }\n\n  if (attrs.class && Array.isArray(attrs.class)) {\n    attrs.class = attrs.class.join(' ');\n  }\n\n  // If it's external link, rewrite attributes.\n  if (data.protocol && data.hostname !== siteHost) {\n    attrs.external = null;\n\n    if (!theme.exturl) {\n      // Only for simple link need to rewrite/add attributes.\n      attrs.rel = 'noopener';\n      attrs.target = '_blank';\n    } else {\n      // Remove rel attributes for `exturl` in main menu.\n      attrs.rel = null;\n    }\n  }\n\n  return htmlTag(tag, attrs, decodeURI(text), false);\n});\n"
  },
  {
    "path": "scripts/renderer.js",
    "content": "/* global hexo */\n\n'use strict';\n\nconst nunjucks = require('nunjucks');\nconst path = require('path');\n\nfunction njkCompile(data) {\n  const templateDir = path.dirname(data.path);\n  const env = nunjucks.configure(templateDir, {\n    autoescape: false\n  });\n  env.addFilter('attr', (dictionary, key, value) => {\n    dictionary[key] = value;\n    return dictionary;\n  });\n  env.addFilter('json', dictionary => {\n    return JSON.stringify(dictionary || '');\n  });\n  return nunjucks.compile(data.text, env, data.path);\n}\n\nfunction njkRenderer(data, locals) {\n  return njkCompile(data).render(locals);\n}\n\n// Return a compiled renderer.\nnjkRenderer.compile = function(data) {\n  const compiledTemplate = njkCompile(data);\n  // Need a closure to keep the compiled template.\n  return function(locals) {\n    return compiledTemplate.render(locals);\n  };\n};\n\nhexo.extend.renderer.register('njk', 'html', njkRenderer);\nhexo.extend.renderer.register('swig', 'html', njkRenderer);\n"
  },
  {
    "path": "scripts/tags/button.js",
    "content": "/**\n * button.js | https://theme-next.org/docs/tag-plugins/button\n */\n\n/* global hexo */\n\n'use strict';\n\nfunction postButton(args) {\n  args = args.join(' ').split(',');\n  let url   = args[0];\n  let text  = args[1] || '';\n  let icon  = args[2] || '';\n  let title = args[3] || '';\n\n  if (!url) {\n    hexo.log.warn('URL can NOT be empty.');\n  }\n\n  text = text.trim();\n  icon = icon.trim();\n  icon = icon.startsWith('fa') ? icon : 'fa fa-' + icon;\n  title = title.trim();\n\n  return `<a class=\"btn\" href=\"${url}\"${title.length > 0 ? ` title=\"${title}\"` : ''}>\n            ${icon.length > 0 ? `<i class=\"${icon}\"></i>` : ''}${text}\n          </a>`;\n}\n\nhexo.extend.tag.register('button', postButton, {ends: false});\nhexo.extend.tag.register('btn', postButton, {ends: false});\n"
  },
  {
    "path": "scripts/tags/caniuse.js",
    "content": "/**\n * caniuse.js | https://theme-next.org/docs/tag-plugins/caniuse\n */\n\n/* global hexo */\n\n'use strict';\n\nfunction caniUse(args) {\n  args = args.join('').split('@');\n  var feature = args[0];\n  var periods = args[1] || 'current';\n\n  if (!feature) {\n    hexo.log.warn('Caniuse feature can NOT be empty.');\n    return '';\n  }\n\n  return `<iframe data-feature=\"${feature}\" src=\"https://caniuse.bitsofco.de/embed/index.html?feat=${feature}&periods=${periods}&accessible-colours=false\" frameborder=\"0\" width=\"100%\" height=\"400px\"></iframe>`;\n}\n\nhexo.extend.tag.register('caniuse', caniUse);\nhexo.extend.tag.register('can', caniUse);\n"
  },
  {
    "path": "scripts/tags/center-quote.js",
    "content": "/**\n * center-quote.js | https://theme-next.org/docs/tag-plugins/\n */\n\n/* global hexo */\n\n'use strict';\n\nfunction centerQuote(args, content) {\n  return `<blockquote class=\"blockquote-center\">\n            <i class=\"fa fa-quote-left\"></i>\n            ${hexo.render.renderSync({ text: content, engine: 'markdown' })}\n            <i class=\"fa fa-quote-right\"></i>\n          </blockquote>`;\n}\n\nhexo.extend.tag.register('centerquote', centerQuote, {ends: true});\nhexo.extend.tag.register('cq', centerQuote, {ends: true});\n"
  },
  {
    "path": "scripts/tags/group-pictures.js",
    "content": "/**\n * group-pictures.js | https://theme-next.org/docs/tag-plugins/group-pictures\n */\n\n/* global hexo */\n\n'use strict';\n\nvar LAYOUTS = {\n  2: {\n    1: [1, 1],\n    2: [2]\n  },\n  3: {\n    1: [3],\n    2: [1, 2],\n    3: [2, 1]\n  },\n  4: {\n    1: [1, 2, 1],\n    2: [1, 3],\n    3: [2, 2],\n    4: [3, 1]\n  },\n  5: {\n    1: [1, 2, 2],\n    2: [2, 1, 2],\n    3: [2, 3],\n    4: [3, 2]\n  },\n  6: {\n    1: [1, 2, 3],\n    2: [1, 3, 2],\n    3: [2, 1, 3],\n    4: [2, 2, 2],\n    5: [3, 3]\n  },\n  7: {\n    1: [1, 2, 2, 2],\n    2: [1, 3, 3],\n    3: [2, 2, 3],\n    4: [2, 3, 2],\n    5: [3, 2, 2]\n  },\n  8: {\n    1: [1, 2, 2, 3],\n    2: [1, 2, 3, 2],\n    3: [1, 3, 2, 2],\n    4: [2, 2, 2, 2],\n    5: [2, 3, 3],\n    6: [3, 2, 3],\n    7: [3, 3, 2]\n  },\n  9: {\n    1: [1, 2, 3, 3],\n    2: [1, 3, 2, 3],\n    3: [2, 2, 2, 3],\n    4: [2, 2, 3, 2],\n    5: [2, 3, 2, 2],\n    6: [3, 2, 2, 2],\n    7: [3, 3, 3]\n  },\n  10: {\n    1: [1, 3, 3, 3],\n    2: [2, 2, 3, 3],\n    3: [2, 3, 2, 3],\n    4: [2, 3, 3, 2],\n    5: [3, 2, 2, 3],\n    6: [3, 2, 3, 2],\n    7: [3, 3, 2, 2]\n  }\n};\n\nfunction groupBy(group, data) {\n  var r = [];\n  for (let count of group) {\n    r.push(data.slice(0, count));\n    data = data.slice(count);\n  }\n  return r;\n}\n\nvar templates = {\n\n  dispatch: function(pictures, group, layout) {\n    var rule = LAYOUTS[group] ? LAYOUTS[group][layout] : null;\n    return rule ? this.getHTML(groupBy(rule, pictures)) : templates.defaults(pictures);\n  },\n\n  /**\n   * Defaults Layout\n   *\n   * □ □ □\n   * □ □ □\n   * ...\n   *\n   * @param pictures\n   */\n  defaults: function(pictures) {\n    var ROW_SIZE = 3;\n    var rows = pictures.length / ROW_SIZE;\n    var pictureArr = [];\n\n    for (var i = 0; i < rows; i++) {\n      pictureArr.push(pictures.slice(i * ROW_SIZE, (i + 1) * ROW_SIZE));\n    }\n\n    return this.getHTML(pictureArr);\n  },\n\n  getHTML: function(rows) {\n    var rowHTML = rows.map(row => {\n      return `<div class=\"group-picture-row\">${this.getColumnHTML(row)}</div>`;\n    }).join('');\n\n    return `<div class=\"group-picture-container\">${rowHTML}</div>`;\n  },\n\n  getColumnHTML: function(pictures) {\n    var columnWidth = 100 / pictures.length;\n    var columnStyle = `style=\"width: ${columnWidth}%;\"`;\n    return pictures.map(picture => {\n      return `<div class=\"group-picture-column\" ${columnStyle}>${picture}</div>`;\n    }).join('');\n  }\n};\n\nfunction groupPicture(args, content) {\n  args = args[0].split('-');\n  var group = parseInt(args[0], 10);\n  var layout = parseInt(args[1], 10);\n\n  content = hexo.render.renderSync({text: content, engine: 'markdown'});\n\n  var pictures = content.match(/<img[\\s\\S]*?>/g);\n\n  return `<div class=\"group-picture\">${templates.dispatch(pictures, group, layout)}</div>`;\n}\n\nhexo.extend.tag.register('grouppicture', groupPicture, {ends: true});\nhexo.extend.tag.register('gp', groupPicture, {ends: true});\n"
  },
  {
    "path": "scripts/tags/label.js",
    "content": "/**\n * label.js | https://theme-next.org/docs/tag-plugins/label\n */\n\n/* global hexo */\n\n'use strict';\n\nfunction postLabel(args) {\n  args = args.join(' ').split('@');\n  var classes = args[0] || 'default';\n  var text    = args[1] || '';\n\n  !text && hexo.log.warn('Label text must be defined!');\n\n  return `<span class=\"label ${classes.trim()}\">${text}</span>`;\n}\n\nhexo.extend.tag.register('label', postLabel, {ends: false});\n"
  },
  {
    "path": "scripts/tags/mermaid.js",
    "content": "/**\n * mermaid.js | https://theme-next.org/docs/tag-plugins/mermaid\n */\n\n/* global hexo */\n\n'use strict';\n\nfunction mermaid(args, content) {\n  return `<pre class=\"mermaid\" style=\"text-align: center;\">\n            ${args.join(' ')}\n            ${content}\n          </pre>`;\n}\n\nhexo.extend.tag.register('mermaid', mermaid, {ends: true});\n"
  },
  {
    "path": "scripts/tags/note.js",
    "content": "/**\n * note.js | https://theme-next.org/docs/tag-plugins/note\n */\n\n/* global hexo */\n\n'use strict';\n\nfunction postNote(args, content) {\n  return `<div class=\"note ${args.join(' ')}\">\n            ${hexo.render.renderSync({text: content, engine: 'markdown'}).split('\\n').join('')}\n          </div>`;\n}\n\nhexo.extend.tag.register('note', postNote, {ends: true});\nhexo.extend.tag.register('subnote', postNote, {ends: true});\n"
  },
  {
    "path": "scripts/tags/pdf.js",
    "content": "/**\n * pdf.js | https://theme-next.org/docs/tag-plugins/pdf\n */\n\n/* global hexo */\n\n'use strict';\n\nfunction pdf(args) {\n  let theme = hexo.theme.config;\n  return `<div class=\"pdfobject-container\" data-target=\"${args[0]}\" data-height=\"${args[1] || theme.pdf.height}\"></div>`;\n}\n\nhexo.extend.tag.register('pdf', pdf, {ends: false});\n"
  },
  {
    "path": "scripts/tags/tabs.js",
    "content": "/**\n * tabs.js | https://theme-next.org/docs/tag-plugins/tabs\n */\n\n/* global hexo */\n\n'use strict';\n\nfunction postTabs(args, content) {\n  var tabBlock = /<!--\\s*tab (.*?)\\s*-->\\n([\\w\\W\\s\\S]*?)<!--\\s*endtab\\s*-->/g;\n\n  args = args.join(' ').split(',');\n  var tabName = args[0];\n  var tabActive = Number(args[1]) || 0;\n\n  var matches = [];\n  var match;\n  var tabId = 0;\n  var tabNav = '';\n  var tabContent = '';\n\n  !tabName && hexo.log.warn('Tabs block must have unique name!');\n\n  while ((match = tabBlock.exec(content)) !== null) {\n    matches.push(match[1]);\n    matches.push(match[2]);\n  }\n\n  for (var i = 0; i < matches.length; i += 2) {\n    var tabParameters = matches[i].split('@');\n    var postContent   = matches[i + 1];\n    var tabCaption    = tabParameters[0] || '';\n    var tabIcon       = tabParameters[1] || '';\n    var tabHref       = '';\n\n    postContent = hexo.render.renderSync({text: postContent, engine: 'markdown'}).trim();\n\n    tabId += 1;\n    tabHref = (tabName + ' ' + tabId).toLowerCase().split(' ').join('-');\n\n    ((tabCaption.length === 0) && (tabIcon.length === 0)) && (tabCaption = tabName + ' ' + tabId);\n\n    var isOnlyicon = tabIcon.length > 0 && tabCaption.length === 0 ? ' style=\"text-align: center;\"' : '';\n    let icon = tabIcon.trim();\n    icon = icon.startsWith('fa') ? icon : 'fa fa-' + icon;\n    tabIcon.length > 0 && (tabIcon = `<i class=\"${icon}\"${isOnlyicon}></i>`);\n\n    var isActive = (tabActive > 0 && tabActive === tabId) || (tabActive === 0 && tabId === 1) ? ' active' : '';\n    tabNav += `<li class=\"tab${isActive}\"><a href=\"#${tabHref}\">${tabIcon + tabCaption.trim()}</a></li>`;\n    tabContent += `<div class=\"tab-pane${isActive}\" id=\"${tabHref}\">${postContent}</div>`;\n  }\n\n  tabNav = `<ul class=\"nav-tabs\">${tabNav}</ul>`;\n  tabContent = `<div class=\"tab-content\">${tabContent}</div>`;\n\n  return `<div class=\"tabs\" id=\"${tabName.toLowerCase().split(' ').join('-')}\">${tabNav + tabContent}</div>`;\n}\n\nhexo.extend.tag.register('tabs', postTabs, {ends: true});\nhexo.extend.tag.register('subtabs', postTabs, {ends: true});\nhexo.extend.tag.register('subsubtabs', postTabs, {ends: true});\n"
  },
  {
    "path": "scripts/tags/video.js",
    "content": "/**\n * video.js | https://theme-next.org/docs/tag-plugins/video\n */\n\n/* global hexo */\n\n'use strict';\n\nfunction postVideo(args) {\n  return `<video src=\"${args}\" preload=\"metadata\" controls playsinline poster=\"\">Sorry, your browser does not support the video tag.</video>`;\n}\n\nhexo.extend.tag.register('video', postVideo, {ends: false});\n"
  },
  {
    "path": "source/css/_colors.styl",
    "content": ":root {\n  --body-bg-color: $body-bg-color;\n  --content-bg-color: $content-bg-color;\n  --card-bg-color: $card-bg-color;\n  --text-color: $text-color;\n  --blockquote-color: $blockquote-color;\n  --link-color: $link-color;\n  --link-hover-color: $link-hover-color;\n  --brand-color: $brand-color;\n  --brand-hover-color: $brand-hover-color;\n  --table-row-odd-bg-color: $table-row-odd-bg-color;\n  --table-row-hover-bg-color: $table-row-hover-bg-color;\n  --menu-item-bg-color: $menu-item-bg-color;\n  --btn-default-bg: $btn-default-bg;\n  --btn-default-color: $btn-default-color;\n  --btn-default-border-color: $btn-default-border-color;\n  --btn-default-hover-bg: $btn-default-hover-bg;\n  --btn-default-hover-color: $btn-default-hover-color;\n  --btn-default-hover-border-color: $btn-default-hover-border-color;\n}\n\nif (hexo-config('darkmode')) {\n  @media (prefers-color-scheme: dark) {\n    :root {\n      --body-bg-color: $body-bg-color-dark;\n      --content-bg-color: $content-bg-color-dark;\n      --card-bg-color: $card-bg-color-dark;\n      --text-color: $text-color-dark;\n      --blockquote-color: $blockquote-color-dark;\n      --link-color: $link-color-dark;\n      --link-hover-color: $link-hover-color-dark;\n      --brand-color: $brand-color-dark;\n      --brand-hover-color: $brand-hover-color-dark;\n      --table-row-odd-bg-color: $table-row-odd-bg-color-dark;\n      --table-row-hover-bg-color: $table-row-hover-bg-color-dark;\n      --menu-item-bg-color: $menu-item-bg-color-dark;\n      --btn-default-bg: $btn-default-bg-dark;\n      --btn-default-color: $btn-default-color-dark;\n      --btn-default-border-color: $btn-default-border-color-dark;\n      --btn-default-hover-bg: $btn-default-hover-bg-dark;\n      --btn-default-hover-color: $btn-default-hover-color-dark;\n      --btn-default-hover-border-color: $btn-default-hover-border-color-dark;\n    }\n\n    img {\n      opacity: .75;\n\n      &:hover {\n        opacity: .9;\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/back-to-top-sidebar.styl",
    "content": ".back-to-top {\n  background: transparent;\n  margin: 20px - $sidebar-offset -10px -20px;\n  opacity: 0;\n\n  if (!hexo-config('back2top.scrollpercent')) {\n    span {\n      display: none;\n    }\n  }\n\n  &.back-to-top-on {\n    cursor: pointer;\n    opacity: $b2t-opacity;\n\n    &:hover {\n      opacity: $b2t-opacity-hover;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/back-to-top.styl",
    "content": ".back-to-top {\n  background: $b2t-bg-color;\n  bottom: $b2t-position-bottom;\n  box-sizing: border-box;\n  color: $b2t-color;\n  cursor: pointer;\n  left: $b2t-position-right;\n  opacity: $b2t-opacity;\n  padding: 0 6px;\n  position: fixed;\n  transition-property: bottom;\n  z-index: $zindex-3;\n\n  if (hexo-config('back2top.scrollpercent')) {\n    width: initial;\n  } else {\n    width: 24px;\n\n    span {\n      display: none;\n    }\n  }\n\n  &:hover {\n    color: $sidebar-highlight;\n  }\n\n  &.back-to-top-on {\n    bottom: $b2t-position-bottom-on;\n  }\n\n  +tablet-mobile() {\n    left: $b2t-position-right-mobile;\n    opacity: $b2t-opacity-hover;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/components.styl",
    "content": "if (hexo-config('back2top.enable')) {\n  .back-to-top {\n    font-size: $b2t-font-size;\n    text-align: center;\n    the-transition();\n  }\n\n  @import (hexo-config('back2top.sidebar') ? 'back-to-top-sidebar' : 'back-to-top');\n}\n\n@import 'reading-progress' if (hexo-config('reading_progress.enable'));\n\n@import 'post';\n@import 'pages';\n@import 'third-party';\n"
  },
  {
    "path": "source/css/_common/components/pages/breadcrumb.styl",
    "content": "ul.breadcrumb {\n  font-size: $font-size-smallest;\n  list-style: none;\n  margin: 1em 0;\n  padding: 0 2em;\n  text-align: center;\n\n  li {\n    display: inline;\n  }\n\n  li + li::before {\n    content: '/\\00a0';\n    font-weight: normal;\n    padding: .5em;\n  }\n\n  li + li:last-child {\n    font-weight: bold;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/pages/categories.styl",
    "content": ".category-all-page {\n  .category-all-title {\n    text-align: center;\n  }\n\n  .category-all {\n    margin-top: 20px;\n  }\n\n  .category-list {\n    list-style: none;\n    margin: 0;\n    padding: 0;\n  }\n\n  .category-list-item {\n    margin: 5px 10px;\n  }\n\n  .category-list-count {\n    color: $grey;\n\n    &::before {\n      content: ' (';\n      display: inline;\n    }\n\n    &::after {\n      content: ') ';\n      display: inline;\n    }\n  }\n\n  .category-list-child {\n    padding-left: 10px;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/pages/pages.styl",
    "content": "// Page specific styles\n@import 'categories';\n@import 'schedule';\n@import 'breadcrumb';\n@import 'tag-cloud';\n"
  },
  {
    "path": "source/css/_common/components/pages/schedule.styl",
    "content": "@keyframes dot-flash {\n  from {\n    opacity: 1;\n    transform: scale(1);\n  }\n\n  to {\n    opacity: 0;\n    transform: scale(.8);\n  }\n}\n\n.event-list {\n  padding: 0;\n\n  hr {\n    background: $black-deep;\n    margin: 20px 0 45px 0;\n\n    &::after {\n      background: $black-deep;\n      color: white;\n      content: 'NOW';\n      display: inline-block;\n      font-weight: bold;\n      padding: 0 5px;\n      text-align: right;\n    }\n  }\n\n  .event {\n    background: $black-deep;\n    margin: 20px 0;\n    min-height: 40px;\n    padding: 15px 0 15px 10px;\n\n    .event-summary {\n      color: white;\n      margin: 0;\n      padding-bottom: 3px;\n\n      &::before {\n        animation: dot-flash 1s alternate infinite ease-in-out;\n        color: white;\n        content: '\\f111';\n        display: inline-block;\n        font-size: 10px;\n        margin-right: 25px;\n        vertical-align: middle;\n        font-family-icons();\n      }\n    }\n\n    .event-relative-time {\n      color: $grey;\n      display: inline-block;\n      font-size: 12px;\n      font-weight: normal;\n      padding-left: 12px;\n    }\n\n    .event-details {\n      color: white;\n      display: block;\n      line-height: 18px;\n      margin-left: 56px;\n      padding-bottom: 6px;\n      padding-top: 3px;\n      text-indent: -24px;\n\n      &::before {\n        color: white;\n        display: inline-block;\n        margin-right: 9px;\n        text-align: center;\n        text-indent: 0;\n        width: 14px;\n        font-family-icons();\n      }\n\n      &.event-location::before {\n        content: '\\f041';\n      }\n\n      &.event-duration::before {\n        content: '\\f017';\n      }\n    }\n  }\n\n  .event-past {\n    background: $whitesmoke;\n\n    .event-summary, .event-details {\n      color: $grey;\n      opacity: .9;\n\n      &::before {\n        animation: none;\n        color: $grey;\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/pages/tag-cloud.styl",
    "content": ".tag-cloud {\n  text-align: center;\n\n  a {\n    display: inline-block;\n    margin: 10px;\n\n    &:hover {\n      color: var(--link-hover-color) !important;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-collapse.styl",
    "content": ".posts-collapse {\n  margin-left: $posts-collapse-margin;\n  position: relative;\n\n  +mobile() {\n    margin-left: $posts-collapse-margin-mobile;\n    margin-right: $posts-collapse-margin-mobile;\n  }\n\n  .collection-title {\n    font-size: $font-size-large;\n    position: relative;\n\n    &::before {\n      background: $grey-dark;\n      border: 1px solid white;\n      border-radius: 50%;\n      content: ' ';\n      height: 10px;\n      left: 0;\n      margin-left: -6px;\n      margin-top: -4px;\n      position: absolute;\n      top: 50%;\n      width: 10px;\n    }\n  }\n\n  .collection-year {\n    font-size: $font-size-largest;\n    font-weight: bold;\n    margin: 60px 0;\n    position: relative;\n\n    &::before {\n      background: $grey;\n      border-radius: 50%;\n      content: ' ';\n      height: 8px;\n      left: 0;\n      margin-left: -4px;\n      margin-top: -4px;\n      position: absolute;\n      top: 50%;\n      width: 8px;\n    }\n  }\n\n  .collection-header {\n    display: block;\n    margin: 0 0 0 20px;\n\n    small {\n      color: $grey;\n      margin-left: 5px;\n    }\n  }\n\n  .post-header {\n    border-bottom: 1px dashed $grey-light;\n    margin: 30px 0;\n    padding-left: 15px;\n    position: relative;\n    transition-property: border;\n    the-transition();\n\n    &::before {\n      background: $grey;\n      border: 1px solid white;\n      border-radius: 50%;\n      content: ' ';\n      height: 6px;\n      left: 0;\n      margin-left: -4px;\n      position: absolute;\n      top: $font-size-smallest;\n      transition-property: background;\n      width: 6px;\n      the-transition();\n    }\n\n    &:hover {\n      border-bottom-color: $grey-dim;\n\n      &::before {\n        background: $black-deep;\n      }\n    }\n  }\n\n  .post-meta {\n    display: inline;\n    font-size: $font-size-smallest;\n    margin-right: 10px;\n  }\n\n  .post-title {\n    display: inline;\n\n    a, span.exturl {\n      border-bottom: none;\n      color: var(--link-color);\n    }\n\n    .fa-external-link-alt {\n      font-size: $font-size-small;\n      margin-left: 5px;\n    }\n  }\n\n  &::before {\n    background: $whitesmoke;\n    content: ' ';\n    height: 100%;\n    left: 0;\n    margin-left: -2px;\n    position: absolute;\n    top: 1.25em;\n    width: 4px;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-copyright.styl",
    "content": ".post-copyright {\n  background: var(--card-bg-color);\n  border-left: 3px solid $red;\n  list-style: none;\n  margin: 2em 0 0;\n  padding: .5em 1em;\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-eof.styl",
    "content": ".post-eof {\n  background: $grey-light;\n  height: 1px;\n  margin: $post-eof-margin-top auto $post-eof-margin-bottom;\n  text-align: center;\n  width: 8%;\n\n  .post-block:last-of-type & {\n    display: none;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-expand.styl",
    "content": ".content {\n  padding-top: 40px;\n}\n\n.post-body {\n  +desktop() {\n    text-align: unquote(hexo-config('text_align.desktop'));\n  }\n\n  +tablet-mobile() {\n    text-align: unquote(hexo-config('text_align.mobile'));\n  }\n\n  h1, h2, h3, h4, h5, h6 {\n    padding-top: 10px;\n\n    .header-anchor {\n      border-bottom-style: none;\n      color: $grey-light;\n      float: right;\n      margin-left: 10px;\n      visibility: hidden;\n\n      &:hover {\n        color: inherit;\n      }\n    }\n\n    &:hover .header-anchor {\n      visibility: visible;\n    }\n  }\n\n  iframe, img, video {\n    margin-bottom: 20px;\n  }\n\n  .video-container {\n    height: 0;\n    margin-bottom: 20px;\n    overflow: hidden;\n    padding-top: 75%;\n    position: relative;\n    width: 100%;\n\n    iframe, object, embed {\n      height: 100%;\n      left: 0;\n      margin: 0;\n      position: absolute;\n      top: 0;\n      width: 100%;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-followme.styl",
    "content": ".followme {\n  align-items: center;\n  background: var(--card-bg-color);\n  border-left: 3px solid $red;\n  color: $grey;\n  margin: 2em 0 1em 0;\n  padding: 1em 1.5em;\n  flex-column();\n\n  .social-list {\n    align-items: center;\n    display: flex;\n    flex-wrap: wrap;\n\n    .social-item {\n      margin: .5em 2em;\n    }\n    +tablet-mobile() {\n      .social-item {\n        margin: .5em .75em;\n      }\n    }\n\n    .social-link {\n      border: 0;\n      display:inline-block;\n      text-align: center;\n\n      .icon {\n        font-size: 1.75em;\n        height: 1.75em;\n        width: 1.75em;\n      }\n\n      .label {\n        display: block;\n        font-size: 14px;\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-gallery.styl",
    "content": ".post-gallery {\n  align-items: center;\n  display: grid;\n  grid-gap: 10px;\n  grid-template-columns: 1fr 1fr 1fr;\n  margin-bottom: 20px;\n\n  +mobile() {\n    grid-template-columns: 1fr 1fr;\n  }\n\n  a {\n    // For fancybox\n    border: 0;\n  }\n\n  img {\n    margin: 0;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-header.styl",
    "content": ".posts-expand .post-header {\n  font-size: $font-size-large;\n}\n\n.posts-expand .post-title {\n  font-size: $font-size-largest;\n  font-weight: normal;\n  margin: initial;\n  text-align: center;\n  word-wrap();\n\n  if (hexo-config('post_edit.enable')) {\n    .post-edit-link {\n      border-bottom: none;\n      color: $grey;\n      display: inline-block;\n      float: right;\n      font-size: $font-size-larger;\n      margin-left: -1.2em;\n      the-transition-ease-in();\n\n      +mobile-small() {\n        margin-left: initial;\n      }\n\n      &:hover {\n        color: $sidebar-highlight;\n      }\n    }\n  }\n}\n\n.posts-expand .post-title-link {\n  border-bottom: none;\n  color: var(--link-color);\n  display: inline-block;\n  position: relative;\n  vertical-align: top;\n\n  &::before {\n    background: var(--link-color);\n    bottom: 0;\n    content: '';\n    height: 2px;\n    left: 0;\n    position: absolute;\n    transform: scaleX(0);\n    visibility: hidden;\n    width: 100%;\n    the-transition();\n  }\n\n  &:hover::before {\n    transform: scaleX(1);\n    visibility: visible;\n  }\n\n  .fa-external-link-alt {\n    font-size: $font-size-small;\n    margin-left: 5px;\n  }\n}\n\n.posts-expand .post-meta {\n  color: $grey-dark;\n  font-family: $font-family-posts;\n  font-size: $font-size-smallest;\n  margin: 3px 0 60px 0;\n  text-align: center;\n\n  .post-description {\n    font-size: $font-size-small;\n    margin-top: 2px;\n  }\n\n  time {\n    border-bottom: 1px dashed $grey-dark;\n    cursor: pointer;\n  }\n}\n\n.post-meta .post-meta-item + .post-meta-item::before {\n  content: '|';\n  margin: 0 .5em;\n}\n\n.post-meta-divider {\n  margin: 0 .5em;\n}\n\n.post-meta-item-icon {\n  margin-right: 3px;\n\n  +tablet-mobile() {\n    display: inline-block;\n  }\n}\n\n.post-meta-item-text {\n  if (!hexo-config('post_meta.item_text')) {\n    display: none;\n  }\n\n  +tablet-mobile() {\n    display: none;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-nav.styl",
    "content": ".post-nav {\n  border-top: 1px solid $gainsboro;\n  display: flex;\n  justify-content: space-between;\n  margin-top: 15px;\n  padding: 10px 5px 0;\n}\n\n.post-nav-item {\n  flex: 1;\n\n  a {\n    border-bottom: none;\n    display: block;\n    font-size: $font-size-small;\n    line-height: 1.6;\n    position: relative;\n\n    &:active {\n      top: 2px;\n    }\n  }\n\n  .fa {\n    font-size: $font-size-smallest;\n  }\n\n  &:first-child {\n    margin-right: 15px;\n\n    .fa {\n      margin-right: 5px;\n    }\n  }\n\n  &:last-child {\n    margin-left: 15px;\n    text-align: right;\n\n    .fa {\n      margin-left: 5px;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-reward.styl",
    "content": ".reward-container {\n  margin: 20px auto;\n  padding: 10px 0;\n  text-align: center;\n  width: 90%;\n\n  button {\n    background: transparent;\n    border: 1px solid #fc6423;\n    border-radius: 0;\n    color: #fc6423;\n    cursor: pointer;\n    line-height: 2;\n    outline: 0;\n    padding: 0 15px;\n    vertical-align: text-top;\n\n    &:hover {\n      background: #fc6423;\n      border: 1px solid transparent;\n      color: #fa9366\n    }\n  }\n}\n\n#qr {\n  padding-top: 20px;\n\n  a {\n    border: 0;\n  }\n\n  img {\n    display: inline-block;\n    margin: .8em 2em 0 2em;\n    max-width: 100%;\n    width: 180px;\n  }\n\n  p {\n    text-align: center;\n  }\n\n  if (hexo-config('reward_settings.animation')) {\n    > div:hover p {\n      animation: roll .1s infinite linear;\n    }\n\n    @keyframes roll {\n      from {\n        transform: rotateZ(30deg);\n      }\n\n      to {\n        transform: rotateZ(-30deg);\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-rtl.styl",
    "content": ".rtl {\n  &.post-body {\n    p, a, h1, h2, h3, h4, h5, h6, li, ul, ol {\n      direction: rtl;\n      font-family: UKIJ Ekran;\n    }\n  }\n\n  &.post-title {\n    font-family: UKIJ Ekran;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-tags.styl",
    "content": ".post-tags {\n  margin-top: 40px;\n  text-align: center;\n\n  a {\n    display: inline-block;\n    font-size: $font-size-smaller;\n\n    &:not(:last-child) {\n      margin-right: 10px;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post-widgets.styl",
    "content": ".post-widgets {\n  border-top: 1px solid $gainsboro;\n  margin-top: 15px;\n  text-align: center;\n}\n\n.wp_rating {\n  height: 20px;\n  line-height: 20px;\n  margin-top: 10px;\n  padding-top: 6px;\n  text-align: center;\n}\n\n.social-like {\n  display: flex;\n  font-size: $font-size-small;\n  justify-content: center;\n  text-align: center;\n}\n"
  },
  {
    "path": "source/css/_common/components/post/post.styl",
    "content": ".post-body {\n  font-family: $font-family-posts;\n  word-wrap();\n\n  +desktop-large() {\n    font-size: $font-size-large;\n  }\n\n  .exturl .fa {\n    font-size: $font-size-small;\n    margin-left: 4px;\n  }\n\n  .image-caption, .figure .caption {\n    color: $grey-dark;\n    font-size: $font-size-small;\n    font-weight: bold;\n    line-height: 1;\n    margin: -20px auto 15px;\n    text-align: center;\n  }\n}\n\n.post-sticky-flag {\n  display: inline-block;\n  transform: rotate(30deg);\n}\n\n.post-button {\n  margin-top: 40px;\n  text-align: center;\n}\n\n.use-motion {\n  if (hexo-config('motion.transition.post_block')) {\n    .post-block, .pagination, .comments {\n      opacity: 0;\n    }\n  }\n\n  if (hexo-config('motion.transition.post_header')) {\n    .post-header {\n      opacity: 0;\n    }\n  }\n\n  if (hexo-config('motion.transition.post_body')) {\n    .post-body {\n      opacity: 0;\n    }\n  }\n\n  if (hexo-config('motion.transition.coll_header')) {\n    .collection-header {\n      opacity: 0;\n    }\n  }\n}\n\n@import 'post-collapse';\n@import 'post-eof';\n@import 'post-expand';\n@import 'post-gallery';\n@import 'post-header';\n@import 'post-nav';\n@import 'post-rtl';\n@import 'post-tags';\n@import 'post-widgets';\n@import 'post-reward';\n\n@import 'post-copyright' if (hexo-config('creative_commons.post'));\n\n@import 'post-followme' if (hexo-config('follow_me'));\n"
  },
  {
    "path": "source/css/_common/components/reading-progress.styl",
    "content": ".reading-progress-bar {\n  background: unquote(hexo-config('reading_progress.color'));\n  display: block;\n  height: unquote(hexo-config('reading_progress.height'));\n  left: 0;\n  position: fixed;\n  width: 0;\n  z-index: $zindex-5;\n\n  if (hexo-config('reading_progress.position') == 'bottom') {\n    bottom: 0;\n  } else {\n    top: 0;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/third-party/gitalk.styl",
    "content": ".gt-header a, .gt-comments a, .gt-popup a {\n  border-bottom: none;\n}\n\n.gt-container .gt-popup .gt-action.is--active::before {\n  top: .7em;\n}\n"
  },
  {
    "path": "source/css/_common/components/third-party/math.styl",
    "content": "mjx-container[jax=\"CHTML\"][display=\"true\"], .has-jax {\n  overflow: auto hidden;\n}\nmjx-container + br {\n  display: none;\n}\n"
  },
  {
    "path": "source/css/_common/components/third-party/related-posts.styl",
    "content": ".popular-posts-header {\n  border-bottom: 1px solid $gainsboro;\n  display: block;\n  font-size: $font-size-large;\n  margin-bottom: 10px;\n  margin-top: $post-eof-margin-bottom;\n}\n\n.popular-posts {\n  padding: 0;\n\n  .popular-posts-item {\n    // list-style: none;\n    margin-left: 2em;\n\n    .popular-posts-title {\n      font-size: $font-size-small;\n      font-weight: normal;\n      line-height: $line-height-base * 1.2;\n      margin: 0;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/third-party/search.styl",
    "content": ".search-pop-overlay {\n  background: rgba(0, 0, 0, 0);\n  height: 100%;\n  left: 0;\n  position: fixed;\n  top: 0;\n  transition: visibility 0s linear .2s, background .2s;\n  visibility: hidden;\n  width: 100%;\n  z-index: $zindex-4;\n\n  &.search-active {\n    background: rgba(0, 0, 0, .3);\n    transition: background .2s;\n    visibility: visible;\n  }\n}\n\n.search-popup {\n  background: var(--card-bg-color);\n  border-radius: 5px;\n  height: 80%;\n  left: calc(50% - 350px);\n  position: fixed;\n  top: 10%;\n  transform: scale(0);\n  transition: transform .2s;\n  width: 700px;\n  z-index: $zindex-5;\n\n  .search-active & {\n    transform: scale(1);\n  }\n\n  +mobile() {\n    border-radius: 0;\n    height: 100%;\n    left: 0;\n    margin: 0;\n    top: 0;\n    width: 100%;\n  }\n\n  .search-icon, .popup-btn-close {\n    color: $grey-dark;\n    font-size: 18px;\n    padding: 0 10px;\n  }\n\n  .popup-btn-close {\n    cursor: pointer;\n\n    &:hover .fa {\n      color: $black-deep;\n    }\n  }\n\n  .search-header {\n    background: $gainsboro;\n    border-top-left-radius: 5px;\n    border-top-right-radius: 5px;\n    display: flex;\n    padding: 5px;\n  }\n\n  input.search-input {\n    background: transparent;\n    border: 0;\n    outline: 0;\n    width: 100%;\n\n    &::-webkit-search-cancel-button {\n      display: none;\n    }\n  }\n}\n\nif (hexo-config('algolia_search.enable')) {\n  .search-input-container {\n    flex-grow: 1;\n\n    form {\n      padding: 2px;\n    }\n  }\n\n  .algolia-powered {\n    float: right;\n\n    img {\n      display: inline-block;\n      height: 18px;\n      vertical-align: middle;\n    }\n  }\n\n  .algolia-results {\n    height: calc(100% - 55px);\n    overflow: auto;\n    padding: 5px 30px;\n\n    hr {\n      margin: 10px 0;\n    }\n  }\n\n  .algolia-hit-item {\n    margin: 15px 0;\n  }\n\n  .algolia-hit-item-link {\n    border-bottom: 1px dashed $grey-light;\n    display: block;\n    the-transition();\n  }\n\n  .algolia-pagination {\n    .pagination {\n      border-top: none;\n      margin: 40px 0;\n      opacity: 1;\n      padding: 0;\n    }\n\n    .pagination-item {\n      display: inline-block;\n    }\n\n    .page-number {\n      border-top: 1px solid transparent;\n      the-transition();\n\n      &:hover {\n        border-top: 1px solid $black-deep;\n      }\n    }\n\n    .current .page-number {\n      @extend .pagination .page-number.current;\n      cursor: default;\n\n      &:hover {\n        border-top-color: $pagination-active-border;\n      }\n    }\n\n    .disabled-item {\n      visibility: hidden;\n    }\n  }\n}\n\nif (hexo-config('local_search.enable')) {\n  .search-popup {\n    .search-input-container {\n      flex-grow: 1;\n      padding: 2px;\n    }\n\n    ul.search-result-list {\n      margin: 0 5px;\n      padding: 0;\n      width: 100%;\n    }\n\n    p.search-result {\n      border-bottom: 1px dashed $grey-light;\n      padding: 5px 0;\n    }\n\n    a.search-result-title {\n      font-weight: bold;\n    }\n\n    .search-keyword {\n      border-bottom: 1px dashed $red;\n      color: $red;\n      font-weight: bold;\n    }\n\n    #search-result {\n      display: flex;\n      height: calc(100% - 55px);\n      overflow: auto;\n      padding: 5px 25px;\n    }\n\n    #no-result {\n      color: $grey-light;\n      margin: auto;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/components/third-party/third-party.styl",
    "content": "@import 'gitalk' if (hexo-config('gitalk.enable'));\n\n@import 'search' if (hexo-config('local_search.enable') || hexo-config('algolia_search.enable'));\n\n@import 'related-posts' if (hexo-config('related_posts.enable'));\n\n@import 'math' if (hexo-config('math.mathjax.enable'));\n"
  },
  {
    "path": "source/css/_common/outline/footer/footer.styl",
    "content": "// Footer Section\n// --------------------------------------------------\n.footer {\n  color: $grey-dark;\n  font-size: $font-size-small;\n  padding: 20px 0;\n\n  &.footer-fixed {\n    bottom: 0;\n    left: 0;\n    position: absolute;\n    right: 0;\n  }\n}\n\n.footer-inner {\n  box-sizing: border-box;\n  margin: 0 auto;\n  text-align: center;\n  width: $content-desktop;\n\n  +desktop-large() {\n    width: $content-desktop-large;\n  }\n\n  +desktop-largest() {\n    width: $content-desktop-largest;\n  }\n}\n\n@keyframes iconAnimate {\n  0%, 100% {\n    transform: scale(1);\n  }\n\n  10%, 30% {\n    transform: scale(.9);\n  }\n\n  20%, 40%, 60%, 80% {\n    transform: scale(1.1);\n  }\n\n  50%, 70% {\n    transform: scale(1.1);\n  }\n}\n\n.languages {\n  display: inline-block;\n  font-size: $font-size-large;\n  position: relative;\n\n  .lang-select-label span {\n    margin: 0 .5em;\n  }\n\n  .lang-select {\n    height: 100%;\n    left: 0;\n    opacity: 0;\n    position: absolute;\n    top: 0;\n    width: 100%;\n  }\n}\n\n.with-love {\n  color: unquote(hexo-config('footer.icon.color'));\n  display: inline-block;\n  margin: 0 5px;\n\n  if (hexo-config('footer.icon.animated')) {\n    animation: iconAnimate 1.33s ease-in-out infinite;\n  }\n}\n\n.powered-by, .theme-info {\n  display: inline-block;\n}\n"
  },
  {
    "path": "source/css/_common/outline/header/bookmark.styl",
    "content": ".book-mark-link {\n  border-bottom: none;\n  display: inline-block;\n  position: fixed;\n  right: $b2t-position-right;\n  top: -10px;\n  transition: .3s;\n\n  +tablet-mobile() {\n    display: none;\n  }\n\n  &::before {\n    color: unquote(hexo-config('bookmark.color'));\n    content: '\\f02e';\n    font-size: 32px;\n    line-height: 1;\n    font-family-icons();\n  }\n}\n\n.book-mark-link:hover, .book-mark-link-fixed {\n  top: -2px;\n}\n"
  },
  {
    "path": "source/css/_common/outline/header/github-banner.styl",
    "content": "@keyframes octocat-wave {\n  0%, 100% {\n    transform: rotate(0);\n  }\n\n  20%, 60% {\n    transform: rotate(-25deg);\n  }\n\n  40%, 80% {\n    transform: rotate(10deg);\n  }\n}\n\n.github-corner {\n  $bg-color = unquote(hexo-config('android_chrome_color'));\n\n  :hover .octo-arm {\n    animation: octocat-wave 560ms ease-in-out;\n  }\n\n  svg {\n    border: 0;\n    color: white;\n    fill: $bg-color;\n    position: absolute;\n    right: 0;\n    top: 0;\n    z-index: $zindex-0;\n  }\n\n  +tablet-mobile() {\n    if (hexo-config('local_search.enable') || hexo-config('algolia_search.enable')) {\n      display: none;\n    }\n\n    svg {\n      if (($scheme == 'Pisces') || ($scheme == 'Gemini')) {\n        color: $bg-color;\n        fill: white;\n      }\n    }\n\n    .github-corner:hover .octo-arm {\n      animation: none;\n    }\n\n    .github-corner .octo-arm {\n      animation: octocat-wave 560ms ease-in-out;\n    }\n  }\n\n  if ($scheme == 'Mist') {\n    +mobile() {\n      svg {\n        top: inherit;\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/outline/header/header.styl",
    "content": "// Header Section\n// --------------------------------------------------\n.header {\n  background: $head-bg;\n}\n\n.header-inner {\n  margin: 0 auto;\n  width: $content-desktop;\n\n  +desktop-large() {\n    width: $content-desktop-large;\n  }\n\n  +desktop-largest() {\n    width: $content-desktop-largest;\n  }\n}\n\n.site-brand-container {\n  display: flex;\n  flex-shrink: 0;\n  padding: 0 10px;\n}\n\n@import 'headerband';\n@import 'site-meta';\n@import 'site-nav';\n@import 'menu';\n\n@import 'bookmark' if (hexo-config('bookmark.enable'));\n\n@import 'github-banner' if (hexo-config('github_banner.enable'));\n"
  },
  {
    "path": "source/css/_common/outline/header/headerband.styl",
    "content": ".headband {\n  background: $headband-bg;\n  height: $headband-height;\n}\n"
  },
  {
    "path": "source/css/_common/outline/header/menu.styl",
    "content": "// Menu\n// --------------------------------------------------\n.menu {\n  margin-top: 20px;\n  padding-left: 0;\n  text-align: center;\n}\n\n.menu-item {\n  display: inline-block;\n  list-style: none;\n  margin: 0 10px;\n\n  +mobile() {\n    display: block;\n    margin-top: 10px;\n\n    &.menu-item-search {\n      display: none;\n    }\n  }\n\n  a, span.exturl {\n    border-bottom: 0;\n    display: block;\n    font-size: $font-size-smaller;\n    transition-property: border-color;\n    the-transition();\n\n    // To prevent hover on external links with touch devices after click.\n    @media (hover: none) {\n      &:hover {\n        border-bottom-color: transparent !important;\n      }\n    }\n  }\n\n  .fa, .fab, .far, .fas {\n    margin-right: 8px;\n  }\n\n  .badge {\n    display: inline-block;\n    font-weight: bold;\n    line-height: 1;\n    margin-left: .35em;\n    margin-top: .35em;\n    text-align: center;\n    white-space: nowrap;\n\n    +mobile() {\n      float: right;\n      margin-left: 0;\n    }\n  }\n}\n\n.menu-item-active a {\n  background: var(--menu-item-bg-color);\n}\n\n.use-motion .menu-item {\n  opacity: 0;\n}\n"
  },
  {
    "path": "source/css/_common/outline/header/site-meta.styl",
    "content": ".site-meta {\n  flex-grow: 1;\n  text-align: $site-meta-text-align;\n\n  +mobile() {\n    text-align: center;\n  }\n}\n\n.brand {\n  border-bottom: none;\n  color: var(--brand-color);\n  display: inline-block;\n  line-height: $font-size-title;\n  padding: 0 40px;\n  position: relative;\n\n  &:hover {\n    color: var(--brand-hover-color);\n  }\n}\n\n.site-title {\n  font-family: $font-family-logo;\n  font-size: $font-size-title;\n  font-weight: normal;\n  margin: 0;\n}\n\n.site-subtitle {\n  color: $subtitle-color;\n  font-size: $font-size-subtitle;\n  margin: 10px 0;\n}\n\n.use-motion {\n  .brand {\n    opacity: 0;\n  }\n\n  .site-title, .site-subtitle, .custom-logo-image {\n    opacity: 0;\n    position: relative;\n    top: -10px;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/outline/header/site-nav.styl",
    "content": ".site-nav-toggle, .site-nav-right {\n  display: none;\n\n  +mobile() {\n    flex-column();\n  }\n\n  .toggle {\n    color: var(--text-color);\n    padding: 10px;\n    width: 22px;\n\n    .toggle-line {\n      background: var(--text-color);\n      border-radius: 1px;\n    }\n  }\n}\n\n.site-nav {\n  display: block;\n\n  +mobile() {\n    clear: both;\n    display: none;\n  }\n\n  &.site-nav-on {\n    display: block;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/outline/mobile.styl",
    "content": "/*\n// < 767px\n+mobile() {\n\n}\n*/\n\n+mobile-small() {\n  // For Pisces & Gemini schemes only wider width (remove main blocks in Gemini).\n  .content-wrap {\n    padding: initial !important;\n  }\n\n  // For all schemes wider width.\n  .posts-expand {\n    .post-meta {\n      margin: 3px 0 10px 0 !important;\n    }\n  }\n\n  .post-block {\n    margin-top: initial !important;\n    // Inside posts blocks content padding (default 40px).\n    padding: $content-mobile-padding 18px $content-mobile-padding !important;\n  }\n\n  .posts-collapse {\n    margin-left: 0;\n    margin-right: 0;\n  }\n\n  .post-body {\n    // For headers narrow width.\n    h1, h2, h3, h4, h5, h6 {\n      margin: 10px 0 8px;\n    }\n\n    // Rewrite paddings & margins inside tags.\n    .note, .tabs .tab-content .tab-pane {\n      h1, h2, h3, h4, h5, h6 {\n        margin: 0 5px;\n      }\n    }\n\n    // For paragraphs narrow width.\n    > p {\n      margin: 0 0 10px 0;\n    }\n\n    // Rewrite paddings & margins inside tags.\n    .note > p, .tabs .tab-content .tab-pane > p {\n      padding: 0 5px;\n    }\n\n    img, video {\n      margin-bottom: 10px !important;\n    }\n\n    .note {\n      margin-bottom: 10px !important;\n      padding: 10px !important;\n\n      if (hexo-config('note.icons')) {\n        &:not(.no-icon) {\n          padding-left: 35px !important;\n        }\n      }\n    }\n\n    .tabs .tab-content .tab-pane {\n      padding: 10px 10px 0 10px !important;\n    }\n  }\n\n  .post-eof {\n    margin: 40px auto 20px !important;\n  }\n\n  .pagination {\n    margin-top: 40px;\n  }\n}\n\n/*\n// < 413px\n+mobile-smallest() {\n\n}\n*/\n"
  },
  {
    "path": "source/css/_common/outline/outline.styl",
    "content": ".container {\n  min-height: 100%;\n  position: relative;\n}\n\n.main-inner {\n  margin: 0 auto;\n  width: $content-desktop;\n\n  +desktop-large() {\n    width: $content-desktop-large;\n  }\n\n  +desktop-largest() {\n    width: $content-desktop-largest;\n  }\n}\n\n.content-wrap {\n  +mobile() {\n    padding: 0 20px;\n  }\n}\n\n@import 'header';\n@import 'sidebar';\n@import 'footer';\n\n@import 'mobile' if (hexo-config('mobile_layout_economy'));\n"
  },
  {
    "path": "source/css/_common/outline/sidebar/sidebar-author-links.styl",
    "content": ".links-of-author {\n  margin-top: 15px;\n\n  a, span.exturl {\n    border-bottom-color: $black-light;\n    display: inline-block;\n    font-size: $font-size-smaller;\n    margin-bottom: 10px;\n    margin-right: 10px;\n    vertical-align: middle;\n\n    if (hexo-config('social_icons.transition')) {\n      the-transition();\n    }\n\n    &::before {\n      background: rgb(random-color(0, 255) - 50%, random-color(0, 255) - 50%, random-color(0, 255) - 50%);\n      border-radius: 50%;\n      content: ' ';\n      display: inline-block;\n      height: 4px;\n      margin-right: 3px;\n      vertical-align: middle;\n      width: 4px;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/outline/sidebar/sidebar-author.styl",
    "content": ".site-author-image {\n  border: $site-author-image-border-width solid $site-author-image-border-color;\n  display: block;\n  margin: 0 auto;\n  max-width: $site-author-image-width;\n  padding: 2px;\n\n  if (hexo-config('avatar.rounded')) {\n    border-radius: 50%;\n  }\n}\n\nif (hexo-config('avatar.rotated')) {\n  .site-author-image {\n    transition: transform 1s ease-out;\n  }\n\n  .site-author-image:hover {\n    transform: rotateZ(360deg);\n  }\n}\n\n.site-author-name {\n  color: $site-author-name-color;\n  font-weight: $site-author-name-weight;\n  margin: $site-author-name-margin;\n  text-align: center;\n}\n\n.site-description {\n  color: $site-description-color;\n  font-size: $site-description-font-size;\n  margin-top: $site-description-margin-top;\n  text-align: center;\n}\n"
  },
  {
    "path": "source/css/_common/outline/sidebar/sidebar-blogroll.styl",
    "content": ".links-of-blogroll {\n  font-size: $font-size-smaller;\n  margin-top: 10px;\n}\n\n.links-of-blogroll-title {\n  font-size: $font-size-small;\n  font-weight: 600;\n  margin-top: 0;\n}\n\n.links-of-blogroll-list {\n  list-style: none;\n  margin: 0;\n  padding: 0;\n}\n"
  },
  {
    "path": "source/css/_common/outline/sidebar/sidebar-button.styl",
    "content": ".sidebar-button {\n  margin-top: 15px;\n\n  a {\n    border: 1px solid $orange;\n    border-radius: 4px;\n    color: $orange;\n    display: inline-block;\n    padding: 0 15px;\n\n    .fa, .fab, .far, .fas {\n      margin-right: 5px;\n    }\n\n    &:hover {\n      background: $orange;\n      border: 1px solid $orange;\n      color: white;\n\n      .fa, .fab, .far, .fas {\n        color: white;\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/outline/sidebar/sidebar-dimmer.styl",
    "content": "#sidebar-dimmer {\n  display: none;\n}\n\n+mobile() {\n  #sidebar-dimmer {\n    background: black;\n    display: block;\n    height: 100%;\n    left: 100%;\n    opacity: 0;\n    position: fixed;\n    top: 0;\n    width: 100%;\n    z-index: $zindex-1;\n  }\n\n  .sidebar-active + #sidebar-dimmer {\n    opacity: .7;\n    transform: translateX(-100%);\n    transition: opacity .5s;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/outline/sidebar/sidebar-nav.styl",
    "content": "// Sidebar Navigation\n.sidebar-nav {\n  margin: 0;\n  padding-bottom: 20px;\n  padding-left: 0;\n\n  li {\n    border-bottom: 1px solid transparent;\n    color: $sidebar-nav-color;\n    cursor: pointer;\n    display: inline-block;\n    font-size: $font-size-small;\n\n    &.sidebar-nav-overview {\n      margin-left: 10px;\n    }\n\n    &:hover {\n      color: $sidebar-nav-hover-color;\n    }\n  }\n\n  .sidebar-nav-active {\n    border-bottom-color: $sidebar-highlight;\n    color: $sidebar-highlight;\n\n    &:hover {\n      color: $sidebar-highlight;\n    }\n  }\n}\n\n.sidebar-panel {\n  display: none;\n  overflow-x: hidden;\n  overflow-y: auto;\n}\n\n.sidebar-panel-active {\n  display: block;\n}\n"
  },
  {
    "path": "source/css/_common/outline/sidebar/sidebar-toc.styl",
    "content": ".post-toc {\n  font-size: $font-size-small;\n\n  ol {\n    list-style: none;\n    margin: 0;\n    padding: 0 2px 5px 10px;\n    text-align: left;\n\n    > ol {\n      padding-left: 0;\n    }\n\n    a {\n      transition-property: all;\n      the-transition();\n    }\n  }\n\n  .nav-item {\n    line-height: 1.8;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    // text-align: justify;\n\n    if (!hexo-config('toc.wrap')) {\n      white-space: nowrap;\n    }\n  }\n\n  .nav {\n    .nav-child {\n      display: hexo-config('toc.expand_all') ? block : none;\n    }\n\n    .active > .nav-child {\n      display: block;\n    }\n\n    .active-current > .nav-child {\n      display: block;\n\n      > .nav-item {\n        display: block;\n      }\n    }\n\n    .active > a {\n      border-bottom-color: $sidebar-highlight;\n      color: $sidebar-highlight;\n    }\n\n    .active-current > a {\n      color: $sidebar-highlight;\n\n      &:hover {\n        color: $sidebar-highlight;\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/outline/sidebar/sidebar-toggle.styl",
    "content": ".sidebar-toggle {\n  background: $black-deep;\n  bottom: 45px;\n  cursor: pointer;\n  height: 14px;\n  left: $b2t-position-right;\n  padding: 5px;\n  position: fixed;\n  width: 14px;\n  z-index: $zindex-3;\n\n  +tablet-mobile() {\n    left: $b2t-position-right-mobile;\n    opacity: $b2t-opacity-hover;\n\n    if (!hexo-config('sidebar.onmobile')) {\n      display: none;\n    }\n  }\n}\n\n.sidebar-toggle:hover .toggle-line {\n  background: $sidebar-highlight;\n}\n"
  },
  {
    "path": "source/css/_common/outline/sidebar/sidebar.styl",
    "content": ".sidebar {\n  background: $black-deep;\n  bottom: 0;\n  if (!hexo-config('back2top.sidebar')){\n    box-shadow: inset 0 2px 6px black;\n  }\n  position: fixed;\n  top: 0;\n\n  +tablet-mobile() {\n    if (!hexo-config('sidebar.onmobile')) {\n      display: none;\n    }\n  }\n}\n\n.sidebar-inner {\n  color: $grey-dark;\n  padding: $sidebar-padding 10px;\n  text-align: center;\n}\n\n.cc-license {\n  margin-top: 10px;\n  text-align: center;\n\n  .cc-opacity {\n    border-bottom: none;\n    opacity: .7;\n\n    &:hover {\n      opacity: .9;\n    }\n  }\n\n  img {\n    display: inline-block;\n  }\n}\n\n@import 'sidebar-author';\n@import 'sidebar-author-links';\n@import 'sidebar-button';\n@import 'sidebar-blogroll';\n@import 'sidebar-dimmer';\n@import 'sidebar-nav';\n@import 'sidebar-toggle';\n\n@import 'sidebar-toc' if (hexo-config('toc.enable'));\n\n@import 'site-state' if (hexo-config('site_state'));\n"
  },
  {
    "path": "source/css/_common/outline/sidebar/site-state.styl",
    "content": ".site-state {\n  display: flex;\n  justify-content: center;\n  line-height: 1.4;\n  margin-top: 10px;\n  overflow: hidden;\n  text-align: center;\n  white-space: nowrap;\n}\n\n.site-state-item {\n  padding: 0 15px;\n\n  &:not(:first-child) {\n    border-left: 1px solid $site-state-item-border-color;\n  }\n\n  a {\n    border-bottom: none;\n  }\n}\n\n.site-state-item-count {\n  display: block;\n  font-size: $site-state-item-count-font-size;\n  font-weight: 600;\n  text-align: center;\n}\n\n.site-state-item-name {\n  color: $site-state-item-name-color;\n  font-size: $site-state-item-name-font-size;\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/base.styl",
    "content": "::selection {\n  background: $selection-bg;\n  color: $selection-color;\n}\n\nhtml, body {\n  height: 100%;\n}\n\nbody {\n  background: var(--body-bg-color);\n  color: var(--text-color);\n  font-family: $font-family-base;\n  font-size: $font-size-base;\n  line-height: $line-height-base;\n\n  +tablet-mobile() {\n    // Remove the padding of body when the sidebar is open.\n    padding-left: 0 !important;\n    padding-right: 0 !important;\n  }\n}\n\nh1, h2, h3, h4, h5, h6 {\n  font-family: $font-family-headings;\n  font-weight: bold;\n  line-height: 1.5;\n  margin: 20px 0 15px;\n}\n\nfor headline in (1 .. 6) {\n  h{headline} {\n    font-size: $font-size-headings-base - $font-size-headings-step * headline;\n  }\n}\n\np {\n  margin: 0 0 20px 0;\n}\n\na, span.exturl {\n  border-bottom: 1px solid $link-decoration-color;\n  color: var(--link-color);\n  outline: 0;\n  text-decoration: none;\n  word-wrap();\n\n  &:hover {\n    border-bottom-color: var(--link-hover-color);\n    color: var(--link-hover-color);\n  }\n\n  // For spanned external links.\n  cursor: pointer;\n}\n\niframe, img, video {\n  display: block;\n  margin-left: auto;\n  margin-right: auto;\n  max-width: 100%;\n}\n\nhr {\n  background-image: repeating-linear-gradient(-45deg, $grey-lighter, $grey-lighter 4px, transparent 4px, transparent 8px);\n  border: 0;\n  height: 3px;\n  margin: 40px 0;\n}\n\nblockquote {\n  border-left: 4px solid $grey-lighter;\n  color: var(--blockquote-color);\n  margin: 0;\n  padding: 0 15px;\n\n  cite::before {\n    content: '-';\n    padding: 0 5px;\n  }\n}\n\ndt {\n  font-weight: bold;\n}\n\ndd {\n  margin: 0;\n  padding: 0;\n}\n\nkbd {\n  background-color: $whitesmoke;\n  background-image: linear-gradient($gainsboro, white, $gainsboro);\n  border: 1px solid $grey-light;\n  border-radius: .2em;\n  box-shadow: .1em .1em .2em rgba(0, 0, 0, .1);\n  color: $code-foreground;\n  font-family: inherit;\n  padding: .1em .3em;\n  white-space: nowrap;\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/buttons.styl",
    "content": ".btn {\n  background: var(--btn-default-bg);\n  border: 2px solid var(--btn-default-border-color);\n  border-radius: $btn-default-radius;\n  color: var(--btn-default-color);\n  display: inline-block;\n  font-size: $font-size-small;\n  line-height: 2;\n  padding: 0 20px;\n  text-decoration: none;\n  transition-property: background-color;\n  the-transition();\n\n  &:hover {\n    background: var(--btn-default-hover-bg);\n    border-color: var(--btn-default-hover-border-color);\n    color: var(--btn-default-hover-color);\n  }\n\n  + .btn {\n    margin: 0 0 8px 8px;\n  }\n\n  .fa-fw {\n    text-align: left;\n    width: (18em / 14);\n  }\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/comments.styl",
    "content": ".comments {\n  margin-top: 60px;\n  overflow: hidden;\n}\n\n.comment-button-group {\n  display: flex;\n  flex-wrap: wrap-reverse;\n  justify-content: center;\n  margin: 1em 0;\n\n  .comment-button {\n    margin: .1em .2em;\n\n    &.active {\n      background: var(--btn-default-hover-bg);\n      border-color: var(--btn-default-hover-border-color);\n      color: var(--btn-default-hover-color);\n    }\n  }\n}\n\n.comment-position {\n  display: none;\n\n  &.active {\n    display: block;\n  }\n}\n\n.tabs-comment {\n  background: var(--content-bg-color);\n  margin-top: 4em;\n  padding-top: 0;\n\n  .comments {\n    border: 0;\n    box-shadow: none;\n    margin-top: 0;\n    padding-top: 0;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/highlight/copy-code.styl",
    "content": ".highlight-container {\n  position: relative;\n}\n\n.highlight-container:hover .copy-btn, .highlight-container .copy-btn:focus {\n  opacity: 1;\n}\n\n.copy-btn {\n  color: $black-dim;\n  cursor: pointer;\n  line-height: 1.6;\n  opacity: 0;\n  padding: 2px 6px;\n  position: absolute;\n  the-transition();\n\n  if (hexo-config('codeblock.copy_button.style') == 'flat') {\n    background: white;\n    border: 0;\n    font-size: $font-size-smaller;\n    right: 0;\n    top: 0;\n  } else if (hexo-config('codeblock.copy_button.style') == 'mac') {\n    color: white;\n    font-size: 14px;\n    right: 0;\n    top: 2px;\n  } else {\n    background-color: $gainsboro;\n    background-image: linear-gradient(#fcfcfc, $gainsboro);\n    border: 1px solid #d5d5d5;\n    border-radius: 3px;\n    font-size: $font-size-smaller;\n    right: 4px;\n    top: 8px;\n  }\n}\n\nif (hexo-config('codeblock.copy_button.style') == 'mac') {\n  .highlight-container {\n    background: #21252b;\n    border-radius: 5px;\n    box-shadow: 0 10px 30px 0 rgba(0, 0, 0, .4);\n    padding-top: 30px;\n\n    &::before {\n      background: #fc625d;\n      border-radius: 50%;\n      box-shadow: 20px 0 #fdbc40, 40px 0 #35cd4b;\n      content: ' ';\n      height: 12px;\n      left: 12px;\n      margin-top: -20px;\n      position: absolute;\n      width: 12px;\n    }\n\n    .highlight {\n      border-radius: 0 0 5px 5px;\n\n      .table-container {\n        border-radius: 0 0 5px 5px;\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/highlight/diff.styl",
    "content": "if ($highlight-theme == 'normal') {\n  $highlight-deletion = #fdd;\n  $highlight-addition = #dfd;\n} else {\n  $highlight-deletion = #800000;\n  $highlight-addition = #008000;\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/highlight/highlight.styl",
    "content": "// https://github.com/chriskempson/tomorrow-theme\n$highlight-theme = hexo-config('codeblock.highlight_theme');\n\n@import 'theme';\n@import 'diff';\n\n@import 'copy-code' if (hexo-config('codeblock.copy_button.enable'));\n\n// Placeholder: $code-block\n$code-block {\n  background: $highlight-background;\n  color: $highlight-foreground;\n  line-height: $line-height-code-block;\n  margin: 0 auto 20px;\n}\n\npre, code {\n  font-family: $code-font-family;\n}\n\ncode {\n  background: $code-background;\n  border-radius: 3px;\n  color: $code-foreground;\n  padding: 2px 4px;\n  word-wrap();\n}\n\n.highlight {\n  @extend $code-block;\n\n  *::selection {\n    background: $highlight-selection;\n  }\n\n  pre {\n    border: 0;\n    margin: 0;\n    padding: 10px 0;\n  }\n\n  table {\n    border: 0;\n    margin: 0;\n    width: auto;\n  }\n\n  td {\n    border: 0;\n    padding: 0;\n  }\n\n  figcaption {\n    background: $highlight-gutter.bg-color;\n    color: $highlight-foreground;\n    display: flex;\n    font-size: $table-font-size;\n    justify-content: space-between;\n    line-height: 1.2;\n    padding: .5em;\n\n    a {\n      color: $highlight-foreground;\n\n      &:hover {\n        border-bottom-color: $highlight-foreground;\n      }\n    }\n  }\n\n  .gutter {\n    disable-user-select();\n\n    pre {\n      background: $highlight-gutter.bg-color;\n      color: $highlight-gutter.color;\n      padding-left: 10px;\n      padding-right: 10px;\n      text-align: right;\n    }\n  }\n\n  .code pre {\n    background: $highlight-background;\n    padding-left: 10px;\n    width: 100%;\n  }\n}\n\n.gist table {\n  width: auto;\n\n  td {\n    border: 0;\n  }\n}\n\npre {\n  @extend $code-block;\n  overflow: auto;\n  padding: 10px;\n\n  code {\n    background: none;\n    color: $highlight-foreground;\n    font-size: $table-font-size;\n    padding: 0;\n    text-shadow: none;\n  }\n  // For diff highlight\n  .deletion {\n    background: $highlight-deletion;\n  }\n\n  .addition {\n    background: $highlight-addition;\n  }\n\n  .meta {\n    color: $highlight-yellow;\n    disable-user-select();\n  }\n\n  .comment {\n    color: $highlight-comment;\n  }\n\n  .variable, .attribute, .tag, .name, .regexp, .ruby .constant, .xml .tag .title, .xml .pi, .xml .doctype, .html .doctype, .css .id, .css .class, .css .pseudo {\n    color: $highlight-red;\n  }\n\n  .number, .preprocessor, .built_in, .builtin-name, .literal, .params, .constant, .command {\n    color: $highlight-orange;\n  }\n\n  .ruby .class .title, .css .rules .attribute, .string, .symbol, .value, .inheritance, .header, .ruby .symbol, .xml .cdata, .special, .formula {\n    color: $highlight-green;\n  }\n\n  .title, .css .hexcolor {\n    color: $highlight-aqua;\n  }\n\n  .function, .python .decorator, .python .title, .ruby .function .title, .ruby .title .keyword, .perl .sub, .javascript .title, .coffeescript .title {\n    color: $highlight-blue;\n  }\n\n  .keyword, .javascript .function {\n    color: $highlight-purple;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/highlight/theme.styl",
    "content": "if ($highlight-theme == 'night') {\n  $highlight-background   = #1d1f21;\n  $highlight-current-line = #282a2e;\n  $highlight-selection    = #373b41;\n  $highlight-foreground   = #c5c8c6;\n  $highlight-comment      = #969896;\n  $highlight-red          = #cc6666;\n  $highlight-orange       = #de935f;\n  $highlight-yellow       = #f0c674;\n  $highlight-green        = #b5bd68;\n  $highlight-aqua         = #8abeb7;\n  $highlight-blue         = #81a2be;\n  $highlight-purple       = #b294bb;\n  $highlight-gutter       = {\n    color: lighten($highlight-background, 50%),\n    bg-color: darken($highlight-background, 100%)\n  };\n} else if ($highlight-theme == 'night eighties') {\n  $highlight-background   = #2d2d2d;\n  $highlight-current-line = #393939;\n  $highlight-selection    = #515151;\n  $highlight-foreground   = #cccccc;\n  $highlight-comment      = #999999;\n  $highlight-red          = #f2777a;\n  $highlight-orange       = #f99157;\n  $highlight-yellow       = #ffcc66;\n  $highlight-green        = #99cc99;\n  $highlight-aqua         = #66cccc;\n  $highlight-blue         = #6699cc;\n  $highlight-purple       = #cc99cc;\n  $highlight-gutter       = {\n    color: $highlight-comment,\n    bg-color: darken($highlight-background, 40%)\n  };\n} else if ($highlight-theme == 'night blue') {\n  $highlight-background   = #002451;\n  $highlight-current-line = #00346e;\n  $highlight-selection    = #003f8e;\n  $highlight-foreground   = #ffffff;\n  $highlight-comment      = #7285b7;\n  $highlight-red          = #ff9da4;\n  $highlight-orange       = #ffc58f;\n  $highlight-yellow       = #ffeead;\n  $highlight-green        = #d1f1a9;\n  $highlight-aqua         = #99ffff;\n  $highlight-blue         = #bbdaff;\n  $highlight-purple       = #ebbbff;\n  $highlight-gutter       = {\n    color: $highlight-comment,\n    bg-color: darken($highlight-background, 60%)\n  };\n} else if ($highlight-theme == 'night bright') {\n  $highlight-background   = #000000;\n  $highlight-current-line = #2a2a2a;\n  $highlight-selection    = #424242;\n  $highlight-foreground   = #eaeaea;\n  $highlight-comment      = #969896;\n  $highlight-red          = #d54e53;\n  $highlight-orange       = #e78c45;\n  $highlight-yellow       = #e7c547;\n  $highlight-green        = #b9ca4a;\n  $highlight-aqua         = #70c0b1;\n  $highlight-blue         = #7aa6da;\n  $highlight-purple       = #c397d8;\n  $highlight-gutter       = {\n    color: lighten($highlight-background, 40%),\n    bg-color: lighten($highlight-background, 16%)\n  };\n} else if ($highlight-theme == 'solarized') {\n  $highlight-background   = #fdf6e3;\n  $highlight-current-line = #eee8d5;\n  $highlight-selection    = #eee8d5;\n  $highlight-foreground   = #586e75;\n  $highlight-comment      = #93a1a1;\n  $highlight-red          = #dc322f;\n  $highlight-orange       = #cb4b16;\n  $highlight-yellow       = #b58900;\n  $highlight-green        = #859900;\n  $highlight-aqua         = #2aa198;\n  $highlight-blue         = #268bd2;\n  $highlight-purple       = #6c71c4;\n  $highlight-gutter       = {\n    color: $highlight-comment,\n    bg-color: $highlight-background\n  };\n} else if ($highlight-theme == 'solarized dark') {\n  $highlight-background   = #002b36;\n  $highlight-current-line = #073642;\n  $highlight-selection    = #073642;\n  $highlight-foreground   = #93a1a1;\n  $highlight-comment      = #586e75;\n  $highlight-red          = #dc322f;\n  $highlight-orange       = #cb4b16;\n  $highlight-yellow       = #b58900;\n  $highlight-green        = #859900;\n  $highlight-aqua         = #2aa198;\n  $highlight-blue         = #268bd2;\n  $highlight-purple       = #6c71c4;\n  $highlight-gutter       = {\n    color: $highlight-comment,\n    bg-color: $highlight-background\n  };\n} else if ($highlight-theme == 'galactic') {\n  $highlight-background   = #262626;\n  $highlight-current-line = #303030;\n  $highlight-selection    = #303030;\n  $highlight-foreground   = #9e9e9e;\n  $highlight-comment      = #6a6a6a;\n  $highlight-red          = #ff511a;\n  $highlight-orange       = #dd7202;\n  $highlight-yellow       = #a68f01;\n  $highlight-green        = #4ca340;\n  $highlight-aqua         = #07a38f;\n  $highlight-blue         = #3294ff;\n  $highlight-purple       = #cc62fe;\n  $highlight-gutter       = {\n    color: $highlight-comment,\n    bg-color: $highlight-background\n  };\n} else {\n  $highlight-background   = #f7f7f7;\n  $highlight-current-line = #efefef;\n  $highlight-selection    = #d6d6d6;\n  $highlight-foreground   = #4d4d4c;\n  $highlight-comment      = #8e908c;\n  $highlight-red          = #c82829;\n  $highlight-orange       = #f5871f;\n  $highlight-yellow       = #eab700;\n  $highlight-green        = #718c00;\n  $highlight-aqua         = #3e999f;\n  $highlight-blue         = #4271ae;\n  $highlight-purple       = #8959a8;\n  $highlight-gutter       = {\n    color: #869194,\n    bg-color: #eff2f3\n  };\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/normalize.styl",
    "content": "/* normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */\n/* Document\n========================================================================== */\n/**\n * 1. Correct the line height in all browsers.\n * 2. Prevent adjustments of font size after orientation changes in iOS.\n */\nhtml {\n  line-height: 1.15; /* 1 */\n  -webkit-text-size-adjust: 100%; /* 2 */\n}\n\n/* Sections\n========================================================================== */\n/**\n * Remove the margin in all browsers.\n */\nbody {\n  margin: 0;\n}\n\n/**\n * Render the `main` element consistently in IE.\n */\nmain {\n  display: block;\n}\n\n/**\n * Correct the font size and margin on `h1` elements within `section` and\n * `article` contexts in Chrome, Firefox, and Safari.\n */\nh1 {\n  font-size: 2em;\n  margin: .67em 0;\n}\n\n/* Grouping content\n========================================================================== */\n/**\n * 1. Add the correct box sizing in Firefox.\n * 2. Show the overflow in Edge and IE.\n */\nhr {\n  box-sizing: content-box; /* 1 */\n  height: 0; /* 1 */\n  overflow: visible; /* 2 */\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\npre {\n  font-family: monospace, monospace; /* 1 */\n  font-size: 1em; /* 2 */\n}\n\n/* Text-level semantics\n========================================================================== */\n/**\n * Remove the gray background on active links in IE 10.\n */\na {\n  background: transparent;\n}\n\n/**\n * 1. Remove the bottom border in Chrome 57-\n * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n */\nabbr[title] {\n  border-bottom: none; /* 1 */\n  text-decoration: underline; /* 2 */\n  text-decoration: underline dotted; /* 2 */\n}\n\n/**\n * Add the correct font weight in Chrome, Edge, and Safari.\n */\nb, strong {\n  font-weight: bolder;\n}\n\n/**\n * 1. Correct the inheritance and scaling of font size in all browsers.\n * 2. Correct the odd `em` font sizing in all browsers.\n */\ncode, kbd, samp {\n  font-family: monospace, monospace; /* 1 */\n  font-size: 1em; /* 2 */\n}\n\n/**\n * Add the correct font size in all browsers.\n */\nsmall {\n  font-size: 80%;\n}\n\n/**\n * Prevent `sub` and `sup` elements from affecting the line height in\n * all browsers.\n */\nsub, sup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline;\n}\n\nsub {\n  bottom: -.25em;\n}\n\nsup {\n  top: -.5em;\n}\n\n/* Embedded content\n========================================================================== */\n/**\n * Remove the border on images inside links in IE 10.\n */\nimg {\n  border-style: none;\n}\n\n/* Forms\n========================================================================== */\n/**\n * 1. Change the font styles in all browsers.\n * 2. Remove the margin in Firefox and Safari.\n */\nbutton, input, optgroup, select, textarea {\n  font-family: inherit; /* 1 */\n  font-size: 100%; /* 1 */\n  line-height: 1.15; /* 1 */\n  margin: 0; /* 2 */\n}\n\n/**\n * Show the overflow in IE.\n * 1. Show the overflow in Edge.\n */\nbutton, input {\n  /* 1 */\n  overflow: visible;\n}\n\n/**\n * Remove the inheritance of text transform in Edge, Firefox, and IE.\n * 1. Remove the inheritance of text transform in Firefox.\n */\nbutton, select {\n  /* 1 */\n  text-transform: none;\n}\n\n/**\n * Correct the inability to style clickable types in iOS and Safari.\n */\nbutton, [type='button'], [type='reset'], [type='submit'] {\n  -webkit-appearance: button;\n}\n\n/**\n * Remove the inner border and padding in Firefox.\n */\nbutton::-moz-focus-inner, [type='button']::-moz-focus-inner, [type='reset']::-moz-focus-inner, [type='submit']::-moz-focus-inner {\n  border-style: none;\n  padding: 0;\n}\n\n/**\n * Restore the focus styles unset by the previous rule.\n */\nbutton:-moz-focusring, [type='button']:-moz-focusring, [type='reset']:-moz-focusring, [type='submit']:-moz-focusring {\n  outline: 1px dotted ButtonText;\n}\n\n/**\n * Correct the padding in Firefox.\n */\nfieldset {\n  padding: .35em .75em .625em;\n}\n\n/**\n * 1. Correct the text wrapping in Edge and IE.\n * 2. Correct the color inheritance from `fieldset` elements in IE.\n * 3. Remove the padding so developers are not caught out when they zero out\n *    `fieldset` elements in all browsers.\n */\nlegend {\n  box-sizing: border-box; /* 1 */\n  color: inherit; /* 2 */\n  display: table; /* 1 */\n  max-width: 100%; /* 1 */\n  padding: 0; /* 3 */\n  white-space: normal; /* 1 */\n}\n\n/**\n * Add the correct vertical alignment in Chrome, Firefox, and Opera.\n */\nprogress {\n  vertical-align: baseline;\n}\n\n/**\n * Remove the default vertical scrollbar in IE 10+.\n */\ntextarea {\n  overflow: auto;\n}\n\n/**\n * 1. Add the correct box sizing in IE 10.\n * 2. Remove the padding in IE 10.\n */\n[type='checkbox'], [type='radio'] {\n  box-sizing: border-box; /* 1 */\n  padding: 0; /* 2 */\n}\n\n/**\n * Correct the cursor style of increment and decrement buttons in Chrome.\n */\n[type='number']::-webkit-inner-spin-button, [type='number']::-webkit-outer-spin-button {\n  height: auto;\n}\n\n/**\n * 1. Correct the odd appearance in Chrome and Safari.\n * 2. Correct the outline style in Safari.\n */\n[type='search'] {\n  outline-offset: -2px; /* 2 */\n  -webkit-appearance: textfield; /* 1 */\n}\n\n/**\n * Remove the inner padding in Chrome and Safari on macOS.\n */\n[type='search']::-webkit-search-decoration {\n  -webkit-appearance: none;\n}\n\n/**\n * 1. Correct the inability to style clickable types in iOS and Safari.\n * 2. Change font properties to `inherit` in Safari.\n */\n::-webkit-file-upload-button {\n  font: inherit; /* 2 */\n  -webkit-appearance: button; /* 1 */\n}\n\n/* Interactive\n========================================================================== */\n/*\n * Add the correct display in Edge, IE 10+, and Firefox.\n */\ndetails {\n  display: block;\n}\n\n/*\n * Add the correct display in all browsers.\n */\nsummary {\n  display: list-item;\n}\n\n/* Misc\n========================================================================== */\n/**\n * Add the correct display in IE 10+.\n */\ntemplate {\n  display: none;\n}\n\n/**\n * Add the correct display in IE 10.\n */\n[hidden] {\n  display: none;\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/pagination.styl",
    "content": "$page-number-basic {\n  display: inline-block;\n  margin: 0 10px;\n  padding: 0 11px;\n  position: relative;\n  top: -1px;\n\n  +mobile() {\n    margin: 0 5px;\n  }\n}\n\n.pagination {\n  border-top: 1px solid $pagination-border;\n  margin: 120px 0 0;\n  text-align: center;\n\n  .prev, .next, .page-number {\n    @extend $page-number-basic;\n    border-bottom: 0;\n    border-top: 1px solid $pagination-link-border;\n    transition-property: border-color;\n    the-transition();\n\n    &:hover {\n      border-top-color: $pagination-link-hover-border;\n    }\n  }\n\n  .space {\n    @extend $page-number-basic;\n    margin: 0;\n    padding: 0;\n  }\n\n  .prev {\n    margin-left: 0;\n  }\n\n  .next {\n    margin-right: 0;\n  }\n\n  .page-number.current {\n    background: $pagination-active-bg;\n    border-top-color: $pagination-active-border;\n    color: $pagination-active-color;\n  }\n}\n\n+mobile() {\n  .pagination {\n    border-top: none;\n  }\n\n  .pagination {\n    .prev, .next, .page-number {\n      border-bottom: 1px solid $pagination-link-border;\n      border-top: 0;\n      margin-bottom: 10px;\n      padding: 0 10px;\n\n      &:hover {\n        border-bottom-color: $pagination-link-hover-border;\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/scaffolding.styl",
    "content": "//\n// Scaffolding\n// ==================================================\n@import 'normalize';\n@import 'base';\n@import 'tables';\n@import 'buttons';\n@import 'toggles';\n@import 'highlight';\n@import 'tags';\n@import 'pagination';\n@import 'comments';\n"
  },
  {
    "path": "source/css/_common/scaffolding/tables.styl",
    "content": ".table-container {\n  overflow: auto;\n}\n\ntable {\n  border-collapse: collapse;\n  border-spacing: 0;\n  font-size: $table-font-size;\n  margin: 0 0 20px 0;\n  width: 100%;\n}\n\ntbody tr {\n  &:nth-of-type(odd) {\n    background: var(--table-row-odd-bg-color);\n  }\n\n  &:hover {\n    background: var(--table-row-hover-bg-color);\n  }\n}\n\ncaption, th, td {\n  font-weight: normal;\n  padding: 8px;\n  vertical-align: middle;\n}\n\nth, td {\n  border: 1px solid $table-border-color;\n  border-bottom: 3px solid $table-cell-border-bottom-color;\n}\n\nth {\n  font-weight: 700;\n  padding-bottom: 10px;\n}\n\ntd {\n  border-bottom-width: 1px;\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/tags/blockquote-center.styl",
    "content": "// Blockquote with all children centered.\n.blockquote-center {\n  border-left: none;\n  margin: 40px 0;\n  padding: 0;\n  position: relative;\n  text-align: center;\n\n  .fa {\n    display: block;\n    opacity: .6;\n    position: absolute;\n    width: 100%;\n  }\n\n  .fa-quote-left {\n    border-top: 1px solid $grey-light;\n    text-align: left;\n    top: -20px;\n  }\n\n  .fa-quote-right {\n    border-bottom: 1px solid $grey-light;\n    text-align: right;\n    bottom: -20px;\n  }\n\n  p, div {\n    text-align: center;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/tags/group-pictures.styl",
    "content": ".post-body .group-picture img {\n  margin: 0 auto;\n  padding: 0 3px;\n}\n\n.group-picture-row {\n  margin-bottom: 6px;\n  overflow: hidden;\n}\n\n.group-picture-column {\n  float: left;\n  margin-bottom: 10px;\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/tags/label.styl",
    "content": ".post-body .label {\n  color: $text-color;\n  display: inline;\n  padding: 0 2px;\n\n  &.default {\n    background: $label-default;\n  }\n\n  &.primary {\n    background: $label-primary;\n  }\n\n  &.info {\n    background: $label-info;\n  }\n\n  &.success {\n    background: $label-success;\n  }\n\n  &.warning {\n    background: $label-warning;\n  }\n\n  &.danger {\n    background: $label-danger;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/tags/note.styl",
    "content": ".post-body .note {\n  $note-icons = hexo-config('note.icons');\n  $note-style = hexo-config('note.style');\n\n  border-radius: $note-border-radius;\n  margin-bottom: 20px;\n  padding: 1em;\n  position: relative;\n\n  if ($note-style == 'simple') {\n    border: 1px solid $gainsboro;\n    border-left-width: 5px;\n  }\n\n  if ($note-style == 'modern') {\n    background: $whitesmoke;\n    border: 1px solid transparent;\n  }\n\n  if ($note-style == 'flat') {\n    background: lighten($gainsboro, 65%);\n    border: initial;\n    border-left: 3px solid $gainsboro;\n  }\n\n  h2, h3, h4, h5, h6 {\n    if ($note-icons) {\n      margin-top: 3px;\n    } else {\n      margin-top: 0;\n    }\n\n    border-bottom: initial;\n    margin-bottom: 0;\n    padding-top: 0;\n  }\n\n  p, ul, ol, table, pre, blockquote, img {\n    &:first-child {\n      margin-top: 0;\n    }\n\n    &:last-child {\n      margin-bottom: 0;\n    }\n  }\n\n  if ($note-icons) {\n    &:not(.no-icon) {\n      padding-left: 2.5em;\n\n      &::before {\n        font-size: 1.5em;\n        left: .4em;\n        position: absolute;\n        top: calc(50% - 1em);\n        font-family-icons();\n      }\n    }\n  }\n\n  &.default {\n    if ($note-style == 'flat') {\n      background: $note-default-bg;\n    }\n\n    if ($note-style == 'modern') {\n      background: $note-modern-default-bg;\n      border-color: $note-modern-default-border;\n      color: $note-modern-default-text;\n\n      a, span.exturl {\n        &:not(.btn) {\n          border-bottom: 1px solid $note-modern-default-text;\n          color: $note-modern-default-text;\n\n          &:hover {\n            border-bottom: 1px solid $note-modern-default-hover;\n            color: $note-modern-default-hover;\n          }\n        }\n      }\n    }\n\n    if ($note-style != 'modern') {\n      border-left-color: $note-default-border;\n\n      h2, h3, h4, h5, h6 {\n        color: $note-default-text;\n      }\n    }\n\n    if ($note-icons) {\n      &:not(.no-icon)::before {\n        content: $note-default-icon;\n\n        if ($note-style != 'modern') {\n          color: $note-default-text;\n        }\n      }\n    }\n  }\n\n  &.primary {\n    if ($note-style == 'flat') {\n      background: $note-primary-bg;\n    }\n\n    if ($note-style == 'modern') {\n      background: $note-modern-primary-bg;\n      border-color: $note-modern-primary-border;\n      color: $note-modern-primary-text;\n\n      a, span.exturl {\n        &:not(.btn) {\n          border-bottom: 1px solid $note-modern-primary-text;\n          color: $note-modern-primary-text;\n\n          &:hover {\n            border-bottom: 1px solid $note-modern-primary-hover;\n            color: $note-modern-primary-hover;\n          }\n        }\n      }\n    }\n\n    if ($note-style != 'modern') {\n      border-left-color: $note-primary-border;\n\n      h2, h3, h4, h5, h6 {\n        color: $note-primary-text;\n      }\n    }\n\n    if ($note-icons) {\n      &:not(.no-icon)::before {\n        content: $note-primary-icon;\n\n        if ($note-style != 'modern') {\n          color: $note-primary-text;\n        }\n      }\n    }\n  }\n\n  &.info {\n    if ($note-style == 'flat') {\n      background: $note-info-bg;\n    }\n\n    if ($note-style == 'modern') {\n      background: $note-modern-info-bg;\n      border-color: $note-modern-info-border;\n      color: $note-modern-info-text;\n\n      a, span.exturl {\n        &:not(.btn) {\n          border-bottom: 1px solid $note-modern-info-text;\n          color: $note-modern-info-text;\n\n          &:hover {\n            border-bottom: 1px solid $note-modern-info-hover;\n            color: $note-modern-info-hover;\n          }\n        }\n      }\n    }\n\n    if ($note-style != 'modern') {\n      border-left-color: $note-info-border;\n\n      h2, h3, h4, h5, h6 {\n        color: $note-info-text;\n      }\n    }\n\n    if ($note-icons) {\n      &:not(.no-icon)::before {\n        content: $note-info-icon;\n\n        if ($note-style != 'modern') {\n          color: $note-info-text;\n        }\n      }\n    }\n  }\n\n  &.success {\n    if ($note-style == 'flat') {\n      background: $note-success-bg;\n    }\n\n    if ($note-style == 'modern') {\n      background: $note-modern-success-bg;\n      border-color: $note-modern-success-border;\n      color: $note-modern-success-text;\n\n      a, span.exturl {\n        &:not(.btn) {\n          border-bottom: 1px solid $note-modern-success-text;\n          color: $note-modern-success-text;\n\n          &:hover {\n            border-bottom: 1px solid $note-modern-success-hover;\n            color: $note-modern-success-hover;\n          }\n        }\n      }\n    }\n\n    if ($note-style != 'modern') {\n      border-left-color: $note-success-border;\n\n      h2, h3, h4, h5, h6 {\n        color: $note-success-text;\n      }\n    }\n\n    if ($note-icons) {\n      &:not(.no-icon)::before {\n        content: $note-success-icon;\n\n        if ($note-style != 'modern') {\n          color: $note-success-text;\n        }\n      }\n    }\n  }\n\n  &.warning {\n    if ($note-style == 'flat') {\n      background: $note-warning-bg;\n    }\n\n    if ($note-style == 'modern') {\n      background: $note-modern-warning-bg;\n      border-color: $note-modern-warning-border;\n      color: $note-modern-warning-text;\n\n      a, span.exturl {\n        &:not(.btn) {\n          border-bottom: 1px solid $note-modern-warning-text;\n          color: $note-modern-warning-text;\n\n          &:hover {\n            border-bottom: 1px solid $note-modern-warning-hover;\n            color: $note-modern-warning-hover;\n          }\n        }\n      }\n    }\n\n    if ($note-style != 'modern') {\n      border-left-color: $note-warning-border;\n\n      h2, h3, h4, h5, h6 {\n        color: $note-warning-text;\n      }\n    }\n\n    if ($note-icons) {\n      &:not(.no-icon)::before {\n        content: $note-warning-icon;\n\n        if ($note-style != 'modern') {\n          color: $note-warning-text;\n        }\n      }\n    }\n  }\n\n  &.danger {\n    if ($note-style == 'flat') {\n      background: $note-danger-bg;\n    }\n\n    if ($note-style == 'modern') {\n      background: $note-modern-danger-bg;\n      border-color: $note-modern-danger-border;\n      color: $note-modern-danger-text;\n\n      a, span.exturl {\n        &:not(.btn) {\n          border-bottom: 1px solid $note-modern-danger-text;\n          color: $note-modern-danger-text;\n\n          &:hover {\n            border-bottom: 1px solid $note-modern-danger-hover;\n            color: $note-modern-danger-hover;\n          }\n        }\n      }\n    }\n\n    if ($note-style != 'modern') {\n      border-left-color: $note-danger-border;\n\n      h2, h3, h4, h5, h6 {\n        color: $note-danger-text;\n      }\n    }\n\n    if ($note-icons) {\n      &:not(.no-icon)::before {\n        content: $note-danger-icon;\n\n        if ($note-style != 'modern') {\n          color: $note-danger-text;\n        }\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/tags/pdf.styl",
    "content": ".pdfobject-container {\n  iframe, embed {\n    height: unquote(hexo-config('pdf.height'));\n    width: 100%;\n  }\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/tags/tabs.styl",
    "content": ".post-body .tabs {\n  margin-bottom: 20px;\n}\n\n.post-body .tabs, .tabs-comment {\n  display: block;\n  padding-top: 10px;\n  position: relative;\n\n  ul.nav-tabs {\n    display: flex;\n    flex-wrap: wrap;\n    margin: 0;\n    margin-bottom: -1px;\n    padding: 0;\n\n    +mobile-smallest() {\n      display: block;\n      margin-bottom: 5px;\n    }\n\n    li.tab {\n      border-bottom: 1px solid $grey-lighter;\n      border-left: 1px solid transparent;\n      border-right: 1px solid transparent;\n      border-top: 3px solid transparent;\n      flex-grow: 1;\n      list-style-type: none;\n\n      +mobile-smallest() {\n        border-bottom: 1px solid transparent;\n        border-left: 3px solid transparent;\n        border-right: 1px solid transparent;\n        border-top: 1px solid transparent;\n      }\n\n      border-radius: $tbr $tbr 0 0;\n\n      +mobile-smallest() {\n        border-radius: $tbr;\n      }\n\n      if (hexo-config('tabs.transition.tabs')) {\n        the-transition-ease-out();\n      }\n\n      a {\n        border-bottom: initial;\n        display: block;\n        line-height: 1.8;\n        outline: 0;\n        padding: .25em .75em;\n        text-align: center;\n\n        i {\n          width: (18em / 14);\n        }\n\n        if (hexo-config('tabs.transition.labels')) {\n          the-transition-ease-out();\n        }\n      }\n\n      &.active {\n        border-bottom: 1px solid transparent;\n        border-left: 1px solid $table-border-color;\n        border-right: 1px solid $table-border-color;\n        border-top: 3px solid $orange;\n\n        +mobile-smallest() {\n          border-bottom: 1px solid $table-border-color;\n          border-left: 3px solid $orange;\n          border-right: 1px solid $table-border-color;\n          border-top: 1px solid $table-border-color;\n        }\n\n        a {\n          color: var(--link-color);\n          cursor: default;\n        }\n      }\n    }\n  }\n\n  .tab-content {\n    .tab-pane {\n      border: 1px solid $table-border-color;\n      border-top: 0;\n      padding: 20px 20px 0 20px;\n\n      border-radius: $tbr;\n\n      &:not(.active) {\n        display: none;\n      }\n\n      &.active {\n        display: block;\n\n        &:nth-of-type(1) {\n          border-radius: 0 $tbr $tbr $tbr;\n\n          +mobile-smallest() {\n            border-radius: $tbr;\n          }\n        }\n      }\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_common/scaffolding/tags/tags.styl",
    "content": "@import 'blockquote-center';\n@import 'group-pictures';\n@import 'label';\n@import 'tabs';\n\n@import 'note' if (hexo-config('note.style') != 'disabled');\n\n@import 'pdf' if (hexo-config('pdf.enable'));\n"
  },
  {
    "path": "source/css/_common/scaffolding/toggles.styl",
    "content": ".toggle {\n  line-height: 0;\n\n  .toggle-line {\n    background: white;\n    display: inline-block;\n    height: 2px;\n    left: 0;\n    position: relative;\n    top: 0;\n    transition: all .4s;\n    vertical-align: top;\n    width: 100%;\n\n    &:not(:first-child) {\n      margin-top: 3px;\n    }\n  }\n}\n\nif (hexo-config('sidebar.position') == 'right') {\n  .toggle.toggle-arrow {\n    .toggle-line-first {\n      top: 2px;\n      transform: rotate(-45deg);\n      width: 50%;\n    }\n\n    .toggle-line-middle {\n      width: 90%;\n    }\n\n    .toggle-line-last {\n      top: -2px;\n      transform: rotate(45deg);\n      width: 50%;\n    }\n  }\n\n  .toggle.toggle-close {\n    .toggle-line-first {\n      top: 5px;\n      transform: rotate(-45deg);\n    }\n\n    .toggle-line-middle {\n      opacity: 0;\n    }\n\n    .toggle-line-last {\n      top: -5px;\n      transform: rotate(45deg);\n    }\n  }\n} else {\n  .toggle.toggle-arrow {\n    .toggle-line-first {\n      left: 50%;\n      top: 2px;\n      transform: rotate(45deg);\n      width: 50%;\n    }\n\n    .toggle-line-middle {\n      left: 2px;\n      width: 90%;\n    }\n\n    .toggle-line-last {\n      left: 50%;\n      top: -2px;\n      transform: rotate(-45deg);\n      width: 50%;\n    }\n  }\n\n  .toggle.toggle-close {\n    .toggle-line-first {\n      transform: rotate(-45deg);\n      top: 5px;\n    }\n\n    .toggle-line-middle {\n      opacity: 0;\n    }\n\n    .toggle-line-last {\n      transform: rotate(45deg);\n      top: -5px;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_mixins.styl",
    "content": "the-transition() {\n  transition-delay: 0s;\n  transition-duration: .2s;\n  transition-timing-function: ease-in-out;\n}\n\nthe-transition-ease-in() {\n  transition-delay: 0s;\n  transition-duration: .2s;\n  transition-timing-function: ease-in;\n}\n\nthe-transition-ease-out() {\n  transition-delay: 0s;\n  transition-duration: .2s;\n  transition-timing-function: ease-out;\n}\n\nmobile-smallest() {\n  @media (max-width: 413px) {\n    {block};\n  }\n}\n\nmobile-small() {\n  @media (max-width: 567px) {\n    {block};\n  }\n}\n\nmobile() {\n  @media (max-width: 767px) {\n    {block};\n  }\n}\n\ntablet-mobile() {\n  @media (max-width: 991px) {\n    {block};\n  }\n}\n\ntablet-desktop() {\n  @media (min-width: 768px) {\n    {block};\n  }\n}\n\ntablet() {\n  @media (min-width: 768px) and (max-width: 991px) {\n    {block};\n  }\n}\n\ndesktop() {\n  @media (min-width: 992px) {\n    {block};\n  }\n}\n\ndesktop-large() {\n  @media (min-width: 1200px) {\n    {block};\n  }\n}\n\ndesktop-largest() {\n  @media (min-width: 1600px) {\n    {block};\n  }\n}\n\nrandom-color($min, $max) {\n  return floor(math(0, 'random') * ($max - $min + 1) + $min);\n}\n\nword-wrap() {\n  overflow-wrap: break-word;\n  word-wrap: break-word;\n}\n\ndisable-user-select() {\n  -moz-user-select: none;\n  -ms-user-select: none;\n  -webkit-user-select: none;\n  user-select: none;\n}\n\nsidebar-inline-links-item() {\n  margin: 5px 0 0;\n\n  a, span.exturl {\n    box-sizing: border-box;\n    display: inline-block;\n    margin-bottom: 0;\n    margin-right: 0;\n    max-width: 216px;\n    overflow: hidden;\n    padding: 0 5px;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n}\n\nflex-column() {\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n}\n\nfont-family-icons() {\n  font-family: 'Font Awesome 5 Free';\n  font-weight: 900;\n}\n"
  },
  {
    "path": "source/css/_schemes/Gemini/index.styl",
    "content": "@import '../Pisces/_layout';\n@import '../Pisces/_header';\n@import '../Pisces/_menu';\n@import '../Pisces/_sub-menu';\n@import '../Pisces/_sidebar';\n\n// ==================================================\n// Rewrite _layout.styl\n// ==================================================\n// Sidebar padding used as main desktop content padding for sidebar padding and post blocks padding too.\n\n// In `source/css/_variables/Pisces.styl` there are variable for main offset:\n// $sidebar-offset                   = 12px;\n// This value alse can be changed in main NexT config as `sidebar: offset: 12` option.\n\n// In `source/css/_variables/base.styl` there are variables for other resolutions:\n// $content-tablet-padding           = 10px;\n// $content-mobile-padding           = 8px;\n// P.S. If u want to change this paddings u may set this variables into `custom_file_path.variable` (in theme _config.yml).\n\n// So, it will 12px in Desktop, 10px in Tablets and 8px in Mobiles for all possible paddings.\n// ==================================================\n// Read values from NexT config and set they as local variables to use as string variables (in any CSS section).\n$use-seo = hexo-config('seo');\n\n// ==================================================\n// Desktop layout styles.\n// ==================================================\n// Post blocks.\n.content-wrap {\n  background: initial;\n  box-shadow: initial;\n  padding: initial;\n}\n\n// Post & Comments blocks.\n.post-block {\n  background: var(--content-bg-color);\n  border-radius: $border-radius-inner;\n  box-shadow: $box-shadow-inner;\n  padding: $content-desktop-padding;\n\n  // When blocks are siblings (homepage).\n  & + .post-block {\n    border-radius: $border-radius;\n    // Rewrite shadows & borders because all blocks have offsets.\n    box-shadow: $box-shadow;\n    margin-top: $sidebar-offset;\n  }\n}\n\n// Comments blocks.\n.comments {\n  background: var(--content-bg-color);\n  border-radius: $border-radius;\n  box-shadow: $box-shadow;\n  margin-top: $sidebar-offset;\n  padding: $content-desktop-padding;\n}\n\n.tabs-comment {\n  margin-top: 1em;\n}\n\n// Top main padding from header to posts (default 40px).\n.content {\n  padding-top: initial;\n}\n\n// Post delimiters.\n.post-eof {\n  display: none;\n}\n\n// Pagination.\n.pagination {\n  .prev, .next, .page-number {\n    margin-bottom: initial;\n    top: initial;\n  }\n\n  background: var(--content-bg-color);\n  border-radius: $border-radius;\n  border-top: initial;\n  box-shadow: $box-shadow;\n  margin: $sidebar-offset 0 0;\n  padding: 10px 0 10px;\n}\n\n// Footer alignment.\n.main {\n  padding-bottom: initial;\n}\n\n.footer {\n  bottom: auto;\n}\n\n// Sub-menu(s).\n.sub-menu {\n  border-bottom: initial;\n  box-shadow: $box-shadow-inner;\n\n  // Adapt submenu(s) with post-blocks.\n  + .content .post-block {\n    box-shadow: $box-shadow;\n    margin-top: $sidebar-offset;\n\n    +tablet() {\n      margin-top: $content-tablet-padding;\n    }\n\n    +mobile() {\n      margin-top: $content-mobile-padding;\n    }\n  }\n}\n\n// ==================================================\n// Headers.\n// ==================================================\n.post-body {\n  h1, h2 {\n    border-bottom: 1px solid $body-bg-color;\n  }\n\n  h3 {\n    if ($use-seo) {\n      border-bottom: 1px solid $body-bg-color;\n    } else {\n      border-bottom: 1px dotted $body-bg-color;\n    }\n  }\n\n  h4 {\n    if ($use-seo) {\n      border-bottom: 1px dotted $body-bg-color;\n    }\n  }\n}\n\n// ==================================================\n// > 768px & < 991px\n// ==================================================\n+tablet() {\n  // Posts in blocks.\n  .content-wrap {\n    padding: $content-tablet-padding;\n  }\n\n  .posts-expand {\n    // Components inside Posts.\n    .post-button {\n      margin-top: ($content-tablet-padding * 2);\n    }\n  }\n\n  .post-block {\n    border-radius: $border-radius;\n    // Rewrite shadows & borders because all blocks have offsets.\n    box-shadow: $box-shadow;\n    // Inside posts blocks content padding (default 40px).\n    padding: ($content-tablet-padding * 2);\n  }\n\n  // Only if blocks are siblings need bottom margin (homepage).\n  .post-block + .post-block {\n    margin-top: $content-tablet-padding;\n  }\n\n  .comments {\n    margin-top: $content-tablet-padding;\n    padding: $content-tablet-padding ($content-tablet-padding * 2);\n    // padding: initial;\n    // padding-top: $content-tablet-padding;\n  }\n\n  .pagination {\n    margin: $content-tablet-padding 0 0;\n  }\n}\n\n// ==================================================\n// < 767px\n// ==================================================\n+mobile() {\n  // Posts in blocks.\n  .content-wrap {\n    padding: $content-mobile-padding;\n  }\n\n  .posts-expand {\n    // Components inside Posts.\n    .post-button {\n      margin: $sidebar-offset 0;\n    }\n  }\n\n  .post-block {\n    border-radius: $border-radius;\n    // Rewrite shadows & borders because all blocks have offsets.\n    box-shadow: $box-shadow;\n    min-height: auto;\n    // Inside posts blocks content padding (default 40px).\n    padding: $sidebar-offset;\n  }\n\n  // Only if blocks are siblings need bottom margin (homepage).\n  .post-block + .post-block {\n    margin-top: $content-mobile-padding;\n  }\n\n  .comments {\n    margin-top: $content-mobile-padding;\n    padding: 10px $sidebar-offset;\n  }\n\n  .pagination {\n    margin: $content-mobile-padding 0 0;\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Mist/_header.styl",
    "content": "// Header\n// --------------------------------------------------\n.header {\n  background: var(--content-bg-color);\n}\n\n.header-inner {\n  align-items: center;\n  display: flex;\n  padding: 20px 0;\n\n  +mobile() {\n    display: block;\n    padding: 10px 0;\n    width: auto;\n  }\n}\n\n.site-meta {\n  line-height: normal;\n\n  .brand {\n    padding: 2px 1px;\n\n    +mobile() {\n      display: block;\n    }\n  }\n\n  .site-title {\n    font-weight: bolder;\n  }\n}\n\n.logo-line-before, .logo-line-after {\n  display: block;\n  margin: 0 auto;\n  overflow: hidden;\n  width: 75%;\n\n  +mobile() {\n    display: none;\n  }\n\n  i {\n    background: var(--brand-color);\n    display: block;\n    height: 2px;\n    position: relative;\n  }\n}\n\n.use-motion {\n  .logo-line-before i {\n    left: -100%;\n  }\n\n  .logo-line-after i {\n    right: -100%;\n  }\n}\n\n.site-subtitle {\n  display: none;\n}\n"
  },
  {
    "path": "source/css/_schemes/Mist/_layout.styl",
    "content": "// Tags\n// --------------------------------------------------\nhr {\n  height: 2px;\n  margin: 20px 0;\n}\n\n// Components\n// --------------------------------------------------\n.btn {\n  padding: 0 10px;\n}\n\n.headband {\n  display: none;\n}\n\n// Page - Container\n// --------------------------------------------------\n.main-inner {\n  padding-bottom: 80px;\n\n  +mobile() {\n    width: auto;\n  }\n}\n\n.content {\n  padding-top: 80px;\n\n  +mobile() {\n    padding-top: 60px;\n  }\n}\n\n// Pagination\n// --------------------------------------------------\n.pagination {\n  margin: 120px 0 0;\n  text-align: left;\n\n  +mobile() {\n    margin: 80px 10px 0;\n    text-align: center;\n  }\n}\n\n// Footer\n// --------------------------------------------------\n.footer {\n  background: var(--content-bg-color);\n  color: var(--text-color);\n  padding: 10px 0;\n}\n\n.footer-inner {\n  text-align: left;\n\n  +mobile() {\n    text-align: center;\n    width: auto;\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Mist/_menu.styl",
    "content": "// Menu\n// --------------------------------------------------\n.site-nav {\n  flex-grow: 1;\n\n  +mobile() {\n    padding: 10px 10px 0;\n  }\n}\n\n.menu {\n  margin: 0;\n\n  .menu-item {\n    margin: 0;\n\n    +mobile() {\n      margin-top: 5px;\n    }\n\n    a, span.exturl {\n      border-radius: 2px;\n      padding: 0 10px;\n      transition-property: background;\n\n      +mobile() {\n        text-align: left;\n      }\n\n      &:hover {\n        @extend .menu-item-active a;\n      }\n    }\n\n    .badge {\n      background: white;\n      border-radius: 10px;\n      color: $black-light;\n      padding: 1px 4px;\n      text-shadow: 1px 1px 0 rgba(0, 0, 0, .1);\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Mist/_posts-expand.styl",
    "content": "// Post Expand\n// --------------------------------------------------\n.posts-expand {\n  &.index {\n    .post-title, .post-meta {\n      text-align: $site-meta-text-align;\n\n      +mobile() {\n        text-align: center;\n      }\n    }\n\n    .post-meta {\n      margin: 5px 0 20px 0;\n    }\n  }\n\n  .post-eof {\n    display: none;\n  }\n\n  .post-block:not(:first-child) {\n    margin-top: 120px;\n  }\n\n  .post-title, .post-meta {\n    text-align: center;\n  }\n\n  .post-body img {\n    margin-left: 0;\n  }\n\n  .post-tags {\n    text-align: left;\n\n    a {\n      background: $whitesmoke;\n      border-bottom: none;\n      padding: 1px 5px;\n\n      &:hover {\n        background: $grey-light;\n      }\n    }\n  }\n\n  .post-nav {\n    margin-top: 40px;\n  }\n}\n\n.post-button {\n  margin-top: 20px;\n  text-align: left;\n\n  .btn {\n    // color: $grey-dim;\n    background: none;\n    border: 0;\n    border-bottom: 2px solid var(--btn-default-border-color);\n    padding: 0;\n    transition-property: border;\n\n    &:hover {\n      border-bottom-color: var(--btn-default-hover-border-color);\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Mist/index.styl",
    "content": "//\n// Mist scheme\n// ==================================================\n@import '_layout';\n@import '_header';\n@import '_menu';\n@import '_posts-expand';\n@import '../Muse/_sidebar';\n@import '../Muse/_sub-menu';\n"
  },
  {
    "path": "source/css/_schemes/Muse/_header.styl",
    "content": ".custom-logo {\n  .site-meta-headline {\n    text-align: center;\n  }\n\n  .site-title {\n    color: $black-deep;\n    margin: 10px auto 0;\n\n    a {\n      border: 0;\n    }\n  }\n}\n\n.custom-logo-image {\n  background: white;\n  margin: 0 auto;\n  max-width: 150px;\n  padding: 5px;\n}\n\n.brand {\n  background: var(--btn-default-bg);\n}\n"
  },
  {
    "path": "source/css/_schemes/Muse/_layout.styl",
    "content": ".header-inner, .main-inner, .footer-inner {\n  +mobile() {\n    width: auto;\n  }\n}\n\n.header-inner {\n  padding-top: 100px;\n\n  +mobile() {\n    padding-top: 50px;\n  }\n}\n\n.main-inner {\n  padding-bottom: 60px;\n}\n\n.content {\n  padding-top: 70px;\n\n  +mobile() {\n    padding-top: 35px;\n  }\n}\n\nembed {\n  display: block;\n  margin: 0 auto 25px auto;\n}\n"
  },
  {
    "path": "source/css/_schemes/Muse/_menu.styl",
    "content": ".site-nav {\n  +mobile() {\n    border-bottom: 1px solid $grey-lighter;\n    border-top: 1px solid $grey-lighter;\n    left: 0;\n    margin: 0;\n    padding: 0;\n    width: 100%;\n  }\n}\n\n.menu {\n  +mobile() {\n    text-align: left;\n  }\n}\n\n.menu-item-active a {\n  background: transparent;\n  border-bottom: 1px solid var(--link-hover-color) !important;\n\n  +mobile() {\n    border-bottom: 1px dotted $grey-lighter !important;\n  }\n}\n\n.menu .menu-item {\n  +mobile() {\n    margin: 0 10px;\n  }\n\n  a, span.exturl {\n    border-bottom: 1px solid transparent;\n\n    +mobile() {\n      padding: 5px 10px;\n    }\n\n    &:hover {\n      @extend .menu-item-active a;\n    }\n  }\n\n  .fa, .fab, .far, .fas {\n    +tablet-desktop() {\n      display: block;\n      line-height: 2;\n      margin-right: 0;\n      width: 100%;\n    }\n  }\n\n  .badge {\n    background: $gainsboro;\n    padding: 1px 4px;\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Muse/_sidebar.styl",
    "content": "if (hexo-config('sidebar.position') == 'right') {\n  .sidebar {\n    right: 0 - $sidebar-desktop;\n\n    &.sidebar-active {\n      right: 0;\n    }\n  }\n\n  .sidebar-toggle, .back-to-top {\n    left: auto;\n    right: $b2t-position-right;\n\n    +tablet-mobile() {\n      right: $b2t-position-right-mobile;\n    }\n  }\n\n  .book-mark-link {\n    left: $b2t-position-right;\n  }\n} else {\n  .sidebar {\n    left: 0 - $sidebar-desktop;\n\n    &.sidebar-active {\n      left: 0;\n    }\n  }\n}\n\n.sidebar {\n  width: $sidebar-desktop;\n  z-index: $zindex-2;\n  the-transition-ease-out();\n\n  a, span.exturl {\n    border-bottom-color: $black-light;\n    color: $grey-dark;\n\n    &:hover {\n      border-bottom-color: $gainsboro;\n      color: $gainsboro;\n    }\n  }\n}\n\n.links-of-blogroll-item {\n  if (hexo-config('links_settings.layout') == 'inline') {\n    display: inline-block;\n  }\n  padding: 2px 10px;\n\n  a, span.exturl {\n    box-sizing: border-box;\n    display: inline-block;\n    max-width: 280px;\n    overflow: hidden;\n    text-overflow: ellipsis;\n    white-space: nowrap;\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Muse/_sub-menu.styl",
    "content": ".sub-menu {\n  margin: 10px 0;\n\n  .menu-item {\n    display: inline-block;\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Muse/index.styl",
    "content": "@import '_layout';\n@import '_header';\n@import '_menu';\n@import '_sub-menu';\n@import '_sidebar';\n"
  },
  {
    "path": "source/css/_schemes/Pisces/_header.styl",
    "content": ".site-brand-container {\n  background: $black-deep;\n\n  +tablet-mobile() {\n    box-shadow: 0 0 16px rgba(0, 0, 0, .5);\n  }\n}\n\n.site-meta {\n  padding: 20px 0;\n}\n\n.brand {\n  padding: 0;\n}\n\n.site-subtitle {\n  margin: 10px 10px 0;\n}\n\n.custom-logo-image {\n  margin-top: 20px;\n\n  +tablet-mobile() {\n    display: none;\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Pisces/_layout.styl",
    "content": ".header {\n  margin: 0 auto;\n  position: relative;\n  width: $content-desktop;\n\n  +desktop-large() {\n    width: $content-desktop-large;\n  }\n\n  +desktop-largest() {\n    width: $content-desktop-largest;\n  }\n\n  +tablet-mobile() {\n    width: auto;\n  }\n}\n\n.header-inner {\n  background: var(--content-bg-color);\n  border-radius: $border-radius-inner;\n  box-shadow: $box-shadow-inner;\n  overflow: hidden;\n  padding: 0;\n  position: absolute;\n  top: 0;\n  width: $sidebar-desktop;\n\n  +desktop-large() {\n    width: $sidebar-desktop;\n  }\n\n  +tablet-mobile() {\n    border-radius: initial;\n    position: relative;\n    width: auto;\n  }\n}\n\n.main-inner {\n  align-items: flex-start;\n  display: flex;\n  justify-content: space-between;\n\n  if (hexo-config('sidebar.position') != 'right') {\n    flex-direction: row-reverse;\n  }\n  +tablet-mobile() {\n    width: auto;\n  }\n}\n\n.content-wrap {\n  background: var(--content-bg-color);\n  border-radius: $border-radius-inner;\n  box-shadow: $box-shadow-inner;\n  box-sizing: border-box;\n  padding: $content-desktop-padding;\n  width: $content-wrap;\n\n  +tablet-mobile() {\n    border-radius: initial;\n    padding: 20px;\n    width: 100%;\n  }\n}\n\nif (hexo-config('sidebar.position') == 'right') {\n  .header-inner {\n    right: 0;\n  }\n\n  .book-mark-link {\n    left: $b2t-position-right;\n  }\n\n  .footer-inner {\n    padding-right: 260px;\n  }\n} else {\n  .footer-inner {\n    padding-left: 260px;\n  }\n\n  .back-to-top {\n    left: auto;\n    right: $b2t-position-right;\n\n    +tablet-mobile() {\n      right: $b2t-position-right-mobile;\n    }\n  }\n}\n\n.footer-inner {\n\n  +tablet-mobile() {\n    padding-left: 0;\n    padding-right: 0;\n    width: auto;\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Pisces/_menu.styl",
    "content": ".site-nav-toggle, .site-nav-right {\n  +tablet() {\n    flex-column();\n  }\n\n  .toggle {\n    color: white;\n\n    .toggle-line {\n      background: white;\n    }\n  }\n}\n\n.site-nav {\n  +tablet() {\n    display: none;\n  }\n}\n\n.menu .menu-item {\n  display: block;\n  margin: 0;\n\n  a, span.exturl {\n    padding: 5px 20px;\n    position: relative;\n    text-align: left;\n    transition-property: background-color;\n\n    &:hover {\n      @extend .menu-item-active a;\n    }\n  }\n\n  +tablet-mobile() {\n    &.menu-item-search {\n      display: none;\n    }\n  }\n\n  .badge {\n    background: $grey-light;\n    border-radius: 10px;\n    color: white;\n    float: right;\n    padding: 2px 5px;\n    text-shadow: 1px 1px 0 rgba(0, 0, 0, .1);\n    vertical-align: middle;\n  }\n}\n\nif (!hexo-config('menu_settings.badges')) {\n  .main-menu .menu-item-active a::after {\n    background: $grey;\n    border-radius: 50%;\n    content: ' ';\n    height: 6px;\n    margin-top: -3px;\n    position: absolute;\n    right: 15px;\n    top: 50%;\n    width: 6px;\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Pisces/_sidebar.styl",
    "content": ".sidebar {\n  background: var(--body-bg-color);\n  box-shadow: none;\n  margin-top: 100%;\n  position: static;\n  width: $sidebar-desktop;\n\n  +tablet-mobile() {\n    display: none;\n  }\n}\n\n.sidebar-toggle {\n  display: none;\n}\n\n.sidebar-inner {\n  background: var(--content-bg-color);\n  border-radius: $border-radius;\n  box-shadow: $box-shadow;\n  box-sizing: border-box;\n  color: var(--text-color);\n  width: $sidebar-desktop;\n\n  if (hexo-config('motion.enable') && hexo-config('motion.transition.sidebar')) {\n    opacity: 0;\n  }\n\n  &.affix {\n    position: fixed;\n    top: $sidebar-offset;\n  }\n\n  &.affix-bottom {\n    position: absolute;\n  }\n}\n\n.site-state-item {\n  padding: 0 10px;\n}\n\n.sidebar-button {\n  border-bottom: 1px dotted $grey-light;\n  border-top: 1px dotted $grey-light;\n  margin-top: 10px;\n  text-align: center;\n\n  a {\n    border: 0;\n    color: $orange;\n    display: block;\n\n    &:hover {\n      background: none;\n      border: 0;\n      color: darken($orange, 20%);\n\n      .fa, .fab, .far, .fas {\n        color: darken($orange, 20%);\n      }\n    }\n  }\n}\n\n.links-of-author {\n  display: flex;\n  flex-wrap: wrap;\n  margin-top: 10px;\n  justify-content: center;\n}\n\n.links-of-author-item {\n  sidebar-inline-links-item();\n\n  if (!hexo-config('social_icons.icons_only')) {\n    width: 50%;\n  }\n\n  a, span.exturl {\n    border-bottom: none;\n    display: block;\n    text-decoration: none;\n\n    &::before {\n      display: none;\n    }\n\n    &:hover {\n      background: var(--body-bg-color);\n      border-radius: 4px;\n    }\n  }\n\n  .fa, .fab, .far, .fas {\n    margin-right: 2px;\n  }\n}\n\n.links-of-blogroll-item {\n  padding: 0;\n\n  if (hexo-config('links_settings.layout') == 'inline') {\n    display: inline-block;\n    sidebar-inline-links-item();\n\n    if (!hexo-config('social_icons.icons_only')) {\n      width: unset;\n    }\n  }\n}\n\nif (hexo-config('back2top.sidebar')) {\n  // Only when back2top.sidebar is true, apply the following styles\n  .back-to-top {\n    background: var(--body-bg-color);\n    margin: 8px - $sidebar-offset -10px -18px;\n\n    &.back-to-top-on {\n      margin-top: 16px;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Pisces/_sub-menu.styl",
    "content": ".sub-menu {\n  background: var(--content-bg-color);\n  border-bottom: 1px solid $table-border-color;\n  margin: 0;\n  padding: 6px 0;\n\n  .menu-item {\n    display: inline-block;\n\n    a, span.exturl {\n      background: transparent;\n      margin: 5px 10px;\n      padding: initial;\n\n      &:hover {\n        background: transparent;\n        color: $sidebar-highlight;\n      }\n    }\n  }\n\n  .menu-item-active a {\n    border-bottom-color: $sidebar-highlight;\n    color: $sidebar-highlight;\n\n    &:hover {\n      border-bottom-color: $sidebar-highlight;\n    }\n  }\n}\n"
  },
  {
    "path": "source/css/_schemes/Pisces/index.styl",
    "content": "@import '_layout';\n@import '_header';\n@import '_menu';\n@import '_sub-menu';\n@import '_sidebar';\n"
  },
  {
    "path": "source/css/_variables/Gemini.styl",
    "content": "// Variables of Gemini scheme\n// ==================================================\n\n@import \"Pisces.styl\";\n\n// Settings for some of the most global styles.\n// --------------------------------------------------\n$body-bg-color           = #eee;\n\n// Borders.\n// --------------------------------------------------\n$box-shadow-inner        = 0 2px 2px 0 rgba(0, 0, 0, .12), 0 3px 1px -2px rgba(0, 0, 0, .06), 0 1px 5px 0 rgba(0, 0, 0, .12);\n$box-shadow              = 0 2px 2px 0 rgba(0, 0, 0, .12), 0 3px 1px -2px rgba(0, 0, 0, .06), 0 1px 5px 0 rgba(0, 0, 0, .12), 0 -1px .5px 0 rgba(0, 0, 0, .09);\n\n$border-radius-inner     = initial;\n$border-radius           = initial;\n// $border-radius-inner     = 0 0 3px 3px;\n// $border-radius           = 3px;\n"
  },
  {
    "path": "source/css/_variables/Mist.styl",
    "content": "// Variables of Mist scheme\n// ==================================================\n\n@import \"Muse.styl\";\n\n$link-decoration-color   = $grey-light;\n$content-bg-color        = $whitesmoke;\n$menu-item-bg-color      = $grey-lighter;\n\n$brand-color             = $black-deep;\n$brand-hover-color       = $brand-color;\n\n$site-meta-text-align    = left;\n$posts-collapse-left     = 0;\n\n$btn-default-bg                 = transparent;\n$btn-default-color              = var(--link-color);\n$btn-default-hover-bg           = transparent;\n$btn-default-border-color       = var(--link-color);\n$btn-default-hover-color        = var(--link-hover-color);\n$btn-default-hover-border-color = var(--link-hover-color);\n"
  },
  {
    "path": "source/css/_variables/Muse.styl",
    "content": "// Variables of Muse scheme\n// ==================================================\n\n$sidebar-width           = hexo-config('sidebar.width') is a 'unit' ? hexo-config('sidebar.width') : 320;\n$sidebar-desktop         = unit($sidebar-width, 'px');\n"
  },
  {
    "path": "source/css/_variables/Pisces.styl",
    "content": "// Variables of Pisces scheme\n// ==================================================\n\n// Settings for some of the most global styles.\n// --------------------------------------------------\n$body-bg-color                = #f5f7f9;\n\n$sidebar-width                = hexo-config('sidebar.width') is a 'unit' ? hexo-config('sidebar.width') : 240;\n$sidebar-desktop              = unit($sidebar-width, 'px');\n$content-wrap                 = 'calc(100% - %s)' % unit($sidebar-width + $sidebar-offset, 'px');\n\n$content-desktop              = 'calc(100% - %s)' % unit($content-desktop-padding / 2, 'px');\n$content-desktop-large        = 1160px;\n$content-desktop-largest      = 73%;\n\n\n// Borders\n// --------------------------------------------------\n$box-shadow-inner                 = initial;\n$box-shadow                       = initial;\n\n$border-radius-inner              = initial;\n$border-radius                    = initial;\n\n\n// Header\n// --------------------------------------------------\n$subtitle-color                   = $grey-lighter;\n\n// Sidebar\n// --------------------------------------------------\n$sidebar-nav-color                = var(--text-color);\n$sidebar-nav-hover-color          = $orange;\n$sidebar-highlight                = $orange;\n\n$site-author-image-width          = 120px;\n$site-author-image-border-width   = 1px;\n$site-author-image-border-color   = $gainsboro;\n\n$site-author-name-margin          = 0;\n$site-author-name-color           = var(--text-color);\n$site-author-name-weight          = 600;\n\n$site-description-font-size       = $font-size-smaller;\n$site-description-color           = $grey-dark;\n$site-description-margin-top      = 0;\n\n$site-state-item-count-font-size  = $font-size-medium;\n$site-state-item-name-font-size   = $font-size-smaller;\n$site-state-item-name-color       = $grey-dark;\n$site-state-item-border-color     = $gainsboro;\n\n\n// Components\n// --------------------------------------------------\n\n// Button\n$btn-default-radius           = 2px;\n$btn-default-bg               = white;\n$btn-default-color            = $text-color;\n$btn-default-border-color     = $text-color;\n$btn-default-hover-bg         = $black-deep;\n$btn-default-hover-color      = white;\n\n// Back to top\n$b2t-opacity                  = .6;\n$b2t-position-bottom          = -100px;\n$b2t-position-bottom-on       = 30px;\n"
  },
  {
    "path": "source/css/_variables/base.styl",
    "content": "//\n// Variables\n// ==================================================\n\n\n// Colors\n// colors for use across theme.\n// --------------------------------------------------\n$whitesmoke   = #f5f5f5;\n$gainsboro    = #eee;\n$grey-lighter = #ddd;\n$grey-light   = #ccc;\n$grey         = #bbb;\n$grey-dark    = #999;\n$grey-dim     = #666;\n$black-light  = #555;\n$black-dim    = #333;\n$black-deep   = #222;\n$red          = #ff2a2a;\n$blue-bright  = #87daff;\n$blue         = #0684bd;\n$blue-deep    = #262a30;\n$orange       = #fc6423;\n\n\n// Scaffolding\n// Settings for some of the most global styles.\n// --------------------------------------------------\n// Global text color on <body>\n$text-color                   = $black-light;\n$text-color-dark              = $grey-light;\n\n// Global link color.\n$link-color                   = $black-light;\n$link-color-dark              = $grey-light;\n$link-hover-color             = $black-deep;\n$link-hover-color-dark        = $gainsboro;\n$link-decoration-color        = $grey-dark;\n\n$blockquote-color             = $grey-dim;\n$blockquote-color-dark        = $grey;\n\n// Global border color.\n$border-color                 = $grey-light;\n\n// Background color for <body>\n$body-bg-color                = white;\n$body-bg-color-dark           = #282828;\n$content-bg-color             = white;\n$content-bg-color-dark        = $black-dim;\n\n// Selection\n$selection-bg                 = $blue-deep;\n$selection-color              = $gainsboro;\n\n// Dark mode color\n$card-bg-color                = $whitesmoke;\n$card-bg-color-dark           = $black-light;\n\n$menu-item-bg-color           = $whitesmoke;\n$menu-item-bg-color-dark      = $black-light;\n\n// Typography\n// Font, line-height, and elements colors.\n// --------------------------------------------------\nget_font_family(config) {\n  $custom-family = hexo-config('font.' + config + '.family');\n  return $custom-family is a 'string' ? $custom-family : null;\n}\n\n// Font families.\n$font-family-chinese      = \"PingFang SC\", \"Microsoft YaHei\";\n\n$font-family-base         = $font-family-chinese, sans-serif;\n$font-family-base         = get_font_family('global'), $font-family-chinese, sans-serif if get_font_family('global');\n\n$font-family-logo         = $font-family-base;\n$font-family-logo         = get_font_family('title'), $font-family-base if get_font_family('title');\n\n$font-family-headings     = $font-family-base;\n$font-family-headings     = get_font_family('headings'), $font-family-base if get_font_family('headings');\n\n$font-family-posts        = $font-family-base;\n$font-family-posts        = get_font_family('posts'), $font-family-base if get_font_family('posts');\n\n$font-family-monospace    = consolas, Menlo, monospace, $font-family-chinese;\n$font-family-monospace    = get_font_family('codes'), consolas, Menlo, monospace, $font-family-chinese if get_font_family('codes');\n\n\n// Font size\n$font-size-base           = (hexo-config('font.enable') and hexo-config('font.global.size') is a 'unit') ? unit(hexo-config('font.global.size'), em) : 1em;\n$font-size-smallest       = .75em;\n$font-size-smaller        = .8125em;\n$font-size-small          = .875em;\n$font-size-medium         = 1em;\n$font-size-large          = 1.125em;\n$font-size-larger         = 1.25em;\n$font-size-largest        = 1.5em;\n\n\n// Headings font size\n$font-size-headings-step  = .125em;\n$font-size-headings-base  = (hexo-config('font.enable') and hexo-config('font.headings.size') is a 'unit') ? unit(hexo-config('font.headings.size'), em) : 1.625em;\n\n\n// Global line height\n$line-height-base         = 2;\n$line-height-code-block   = 1.6; // Can't be less than 1.3;\n\n\n// Z-index master list\n// --------------------------------------------------\n$zindex-0       = 1000;\n$zindex-1       = 1100;\n$zindex-2       = 1200;\n$zindex-3       = 1300;\n$zindex-4       = 1400;\n$zindex-5       = 1500;\n\n\n// Table\n// --------------------------------------------------\n$table-border-color             = $grey-lighter;\n$table-font-size                = $font-size-small;\n$table-cell-border-bottom-color = $grey-lighter;\n$table-row-odd-bg-color         = #f9f9f9;\n$table-row-odd-bg-color-dark    = #282828;\n$table-row-hover-bg-color       = $whitesmoke;\n$table-row-hover-bg-color-dark  = #363636;\n\n\n// Code & Code Blocks\n// --------------------------------------------------\n$code-font-family               = $font-family-monospace;\n$code-foreground                = $black-light;\n$code-background                = $gainsboro;\n\n\n// Buttons\n// --------------------------------------------------\n$btn-default-radius                    = 0;\n$btn-default-bg                        = $black-deep;\n$btn-default-bg-dark                   = $black-deep;\n$btn-default-color                     = white;\n$btn-default-color-dark                = $text-color-dark;\n$btn-default-border-color              = $black-deep;\n$btn-default-border-color-dark         = $black-light;\n$btn-default-hover-bg                  = white;\n$btn-default-hover-bg-dark             = $grey-dim;\n$btn-default-hover-color               = $black-deep;\n$btn-default-hover-color-dark          = $text-color-dark;\n$btn-default-hover-border-color        = $black-deep;\n$btn-default-hover-border-color-dark   = $grey-dim;\n\n\n// Pagination\n// --------------------------------------------------\n$pagination-border              = $gainsboro;\n\n$pagination-link-bg             = transparent;\n$pagination-link-color          = $link-color;\n$pagination-link-border         = $gainsboro;\n\n$pagination-link-hover-bg       = transparent;\n$pagination-link-hover-color    = $link-color;\n$pagination-link-hover-border   = $black-deep;\n\n$pagination-active-bg           = $grey-light;\n$pagination-active-color        = white;\n$pagination-active-border       = $grey-light;\n\n\n// Layout sizes\n// --------------------------------------------------\n$content-desktop                = 700px;\n$content-desktop-large          = 800px;\n$content-desktop-largest        = 900px;\n\n$content-desktop-padding        = 40px;\n$content-tablet-padding         = 10px;\n$content-mobile-padding         = 8px;\n\n\n// Headband\n// --------------------------------------------------\n$headband-height                = 3px;\n$headband-bg                    = $black-deep;\n\n\n// Section Header\n// Variables for header section elements.\n// --------------------------------------------------\n$head-bg                        = transparent;\n\n// Site Meta\n$site-meta-text-align           = center;\n$brand-color                    = white;\n$brand-hover-color              = white;\n$brand-color-dark               = $grey-lighter;\n$brand-hover-color-dark         = $grey-lighter;\n\n$font-size-title                = (hexo-config('font.enable') and hexo-config('font.title.size') is a 'unit') ? unit(hexo-config('font.title.size'), em) : 1.375em;\n$font-size-subtitle             = $font-size-smaller;\n$subtitle-color                 = $grey-dark;\n$site-subtitle-color            = $grey-dark;\n\n\n// Posts Collpase\n// --------------------------------------------------\n$posts-collapse-margin          = 35px;\n$posts-collapse-margin-mobile   = 0px;\n\n\n// Sidebar\n// Variables for sidebar section elements.\n// --------------------------------------------------\n\n$sidebar-padding                      = hexo-config('sidebar.padding') is a 'unit' ? unit(hexo-config('sidebar.padding'), px) : 18px;\n$sidebar-offset                       = hexo-config('sidebar.offset') is a 'unit' ? unit(hexo-config('sidebar.offset'), px) : 12px;\n$sidebar-nav-color                    = $grey-dim;\n$sidebar-nav-hover-color              = $whitesmoke;\n$sidebar-highlight                    = $blue-bright;\n\n$site-author-image-width              = 96px;\n$site-author-image-border-width       = 2px;\n$site-author-image-border-color       = $black-dim;\n\n$site-author-name-margin              = 5px 0 0;\n$site-author-name-color               = $whitesmoke;\n$site-author-name-weight              = normal;\n\n$site-description-font-size           = $font-size-medium;\n$site-description-color               = $grey-dark;\n$site-description-margin-top          = 5px;\n\n$site-state-item-count-font-size      = $font-size-larger;\n$site-state-item-name-font-size       = $font-size-small;\n$site-state-item-name-color           = inherit;\n$site-state-item-border-color         = $black-dim;\n\n\n// Components\n// --------------------------------------------------\n// Back to top\n$b2t-opacity                  = 1;\n$b2t-opacity-hover            = .8;\n$b2t-position-bottom          = -100px;\n$b2t-position-bottom-on       = 19px;\n$b2t-position-right           = 30px;\n$b2t-position-right-mobile    = 20px;\n$b2t-font-size                = 12px;\n$b2t-color                    = white;\n$b2t-bg-color                 = $black-deep;\n\n//  .post-expand .post-eof\n//  In Muse scheme, margin above and below the post separator\n$post-eof-margin-top          = 80px; //  or 160px for more white space;\n$post-eof-margin-bottom       = 60px; //  or 120px for less white space;\n\n\n// Iconography\n// Icons SVG Base64\n// --------------------------------------------------\n// blockquote-center icon\n$center-quote-left            = '../images/quote-l.svg';\n$center-quote-right           = '../images/quote-r.svg';\n\n\n// Note colors\n// --------------------------------------------------\n// Read note light_bg_offset from NexT config and set in \"$lbg%\" to use it as string variable.\n$lbg = hexo-config('note.light_bg_offset') is a 'unit' ? unit(hexo-config('note.light_bg_offset'), \"%\") : 0;\n\n// Default\n$note-border-radius         = 3px;\n\n$note-default-border        = #777;\n$note-default-bg            = lighten(spin($note-default-border, 0), 94% + $lbg);\n$note-default-text          = $note-default-border;\n$note-default-icon          = \"\\f0a9\";\n\n$note-modern-default-border = #e1e1e1;\n$note-modern-default-bg     = lighten(spin($note-modern-default-border, 10), 60% + ($lbg * 4));\n$note-modern-default-text   = $grey-dim;\n$note-modern-default-hover  = darken(spin($note-modern-default-text, -10), 32%);\n\n// Primary\n$note-primary-border        = #6f42c1;\n$note-primary-bg            = lighten(spin($note-primary-border, 10), 92% + $lbg);\n$note-primary-text          = $note-primary-border;\n$note-primary-icon          = \"\\f055\";\n\n$note-modern-primary-border = #e1c2ff;\n$note-modern-primary-bg     = lighten(spin($note-modern-primary-border, 10), 40% + ($lbg * 4));\n$note-modern-primary-text   = #6f42c1;\n$note-modern-primary-hover  = darken(spin($note-modern-primary-text, -10), 22%);\n\n// Info\n$note-info-border           = #428bca;\n$note-info-bg               = lighten(spin($note-info-border, -10), 91% + $lbg);\n$note-info-text             = $note-info-border;\n$note-info-icon             = \"\\f05a\";\n\n$note-modern-info-border    = #b3e5ef;\n$note-modern-info-bg        = lighten(spin($note-modern-info-border, 10), 50% + ($lbg * 4));\n$note-modern-info-text      = #31708f;\n$note-modern-info-hover     = darken(spin($note-modern-info-text, -10), 32%);\n\n// Success\n$note-success-border        = #5cb85c;\n$note-success-bg            = lighten(spin($note-success-border, 10), 90% + $lbg);\n$note-success-text          = $note-success-border;\n$note-success-icon          = \"\\f058\";\n\n$note-modern-success-border = #d0e6be;\n$note-modern-success-bg     = lighten(spin($note-modern-success-border, 10), 40% + ($lbg * 4));\n$note-modern-success-text   = #3c763d;\n$note-modern-success-hover  = darken(spin($note-modern-success-text, -10), 27%);\n\n// Warning\n$note-warning-border        = #f0ad4e;\n$note-warning-bg            = lighten(spin($note-warning-border, 10), 88% + $lbg);\n$note-warning-text          = $note-warning-border;\n$note-warning-icon          = \"\\f06a\";\n\n$note-modern-warning-border = #fae4cd;\n$note-modern-warning-bg     = lighten(spin($note-modern-warning-border, 10), 43% + ($lbg * 4));\n$note-modern-warning-text   = #8a6d3b;\n$note-modern-warning-hover  = darken(spin($note-modern-warning-text, -10), 18%);\n\n// Danger\n$note-danger-border         = #d9534f;\n$note-danger-bg             = lighten(spin($note-danger-border, -10), 92% + $lbg);\n$note-danger-text           = $note-danger-border;\n$note-danger-icon           = \"\\f056\";\n\n$note-modern-danger-border  = #ebcdd2;\n$note-modern-danger-bg      = lighten(spin($note-modern-danger-border, 10), 35% + ($lbg * 4));\n$note-modern-danger-text    = #a94442;\n$note-modern-danger-hover   = darken(spin($note-modern-danger-text, -10), 22%);\n\n// Tabs border radius\n// --------------------------------------------------\n$tbr                        = 0;\n\n// Label colors\n// --------------------------------------------------\n$label-default              = lighten(spin($note-default-border, 0), 89% + $lbg);\n$label-primary              = lighten(spin($note-primary-border, 10), 87% + $lbg);\n$label-info                 = lighten(spin($note-info-border, -10), 86% + $lbg);\n$label-success              = lighten(spin($note-success-border, 10), 85% + $lbg);\n$label-warning              = lighten(spin($note-warning-border, 10), 83% + $lbg);\n$label-danger               = lighten(spin($note-danger-border, -10), 87% + $lbg);\n"
  },
  {
    "path": "source/css/main.styl",
    "content": "// CSS Style Guide: http://codeguide.co/#css\n\n\n$scheme    = hexo-config('scheme') ? hexo-config('scheme') : 'Muse';\n\n$variables = base $scheme;\n\n\n// Variables Layer\n// --------------------------------------------------\nfor $variable in $variables\n  @import \"_variables/\" + $variable;\nfor $inject_variable in hexo-config('injects.variable')\n  @import $inject_variable;\n\n// Mixins Layer\n// --------------------------------------------------\n@import \"_mixins.styl\";\nfor $inject_mixin in hexo-config('injects.mixin')\n  @import $inject_mixin;\n\n// Dark mode colors\n// --------------------------------------------------\n@import \"_colors.styl\";\n\n// Common Layer\n// --------------------------------------------------\n\n// Scaffolding\n@import \"_common/scaffolding\";\n\n// Layout\n@import \"_common/outline\";\n\n// Components\n@import \"_common/components\";\n\n\n// Schemes Layer\n// --------------------------------------------------\n@import \"_schemes/\" + $scheme;\n\n\n// Custom Layer\n// --------------------------------------------------\nfor $inject_style in hexo-config('injects.style')\n  @import $inject_style;\n"
  },
  {
    "path": "source/js/algolia-search.js",
    "content": "/* global instantsearch, algoliasearch, CONFIG */\n\ndocument.addEventListener('DOMContentLoaded', () => {\n  const algoliaSettings = CONFIG.algolia;\n  const { indexName, appID, apiKey } = algoliaSettings;\n\n  let search = instantsearch({\n    indexName,\n    searchClient  : algoliasearch(appID, apiKey),\n    searchFunction: helper => {\n      let searchInput = document.querySelector('.search-input');\n      if (searchInput.value) {\n        helper.search();\n      }\n    }\n  });\n\n  window.pjax && search.on('render', () => {\n    window.pjax.refresh(document.getElementById('algolia-hits'));\n  });\n\n  // Registering Widgets\n  search.addWidgets([\n    instantsearch.widgets.configure({\n      hitsPerPage: algoliaSettings.hits.per_page || 10\n    }),\n\n    instantsearch.widgets.searchBox({\n      container           : '.search-input-container',\n      placeholder         : algoliaSettings.labels.input_placeholder,\n      // Hide default icons of algolia search\n      showReset           : false,\n      showSubmit          : false,\n      showLoadingIndicator: false,\n      cssClasses          : {\n        input: 'search-input'\n      }\n    }),\n\n    instantsearch.widgets.stats({\n      container: '#algolia-stats',\n      templates: {\n        text: data => {\n          let stats = algoliaSettings.labels.hits_stats\n            .replace(/\\$\\{hits}/, data.nbHits)\n            .replace(/\\$\\{time}/, data.processingTimeMS);\n          return `${stats}\n            <span class=\"algolia-powered\">\n              <img src=\"${CONFIG.root}images/algolia_logo.svg\" alt=\"Algolia\">\n            </span>\n            <hr>`;\n        }\n      }\n    }),\n\n    instantsearch.widgets.hits({\n      container: '#algolia-hits',\n      templates: {\n        item: data => {\n          let link = data.permalink ? data.permalink : CONFIG.root + data.path;\n          return `<a href=\"${link}\" class=\"algolia-hit-item-link\">${data._highlightResult.title.value}</a>`;\n        },\n        empty: data => {\n          return `<div id=\"algolia-hits-empty\">\n              ${algoliaSettings.labels.hits_empty.replace(/\\$\\{query}/, data.query)}\n            </div>`;\n        }\n      },\n      cssClasses: {\n        item: 'algolia-hit-item'\n      }\n    }),\n\n    instantsearch.widgets.pagination({\n      container: '#algolia-pagination',\n      scrollTo : false,\n      showFirst: false,\n      showLast : false,\n      templates: {\n        first   : '<i class=\"fa fa-angle-double-left\"></i>',\n        last    : '<i class=\"fa fa-angle-double-right\"></i>',\n        previous: '<i class=\"fa fa-angle-left\"></i>',\n        next    : '<i class=\"fa fa-angle-right\"></i>'\n      },\n      cssClasses: {\n        root        : 'pagination',\n        item        : 'pagination-item',\n        link        : 'page-number',\n        selectedItem: 'current',\n        disabledItem: 'disabled-item'\n      }\n    })\n  ]);\n\n  search.start();\n\n  // Handle and trigger popup window\n  document.querySelectorAll('.popup-trigger').forEach(element => {\n    element.addEventListener('click', () => {\n      document.body.style.overflow = 'hidden';\n      document.querySelector('.search-pop-overlay').classList.add('search-active');\n      document.querySelector('.search-input').focus();\n    });\n  });\n\n  // Monitor main search box\n  const onPopupClose = () => {\n    document.body.style.overflow = '';\n    document.querySelector('.search-pop-overlay').classList.remove('search-active');\n  };\n\n  document.querySelector('.search-pop-overlay').addEventListener('click', event => {\n    if (event.target === document.querySelector('.search-pop-overlay')) {\n      onPopupClose();\n    }\n  });\n  document.querySelector('.popup-btn-close').addEventListener('click', onPopupClose);\n  window.addEventListener('pjax:success', onPopupClose);\n  window.addEventListener('keyup', event => {\n    if (event.key === 'Escape') {\n      onPopupClose();\n    }\n  });\n});\n"
  },
  {
    "path": "source/js/bookmark.js",
    "content": "/* global CONFIG */\n\ndocument.addEventListener('DOMContentLoaded', () => {\n  'use strict';\n\n  var doSaveScroll = () => {\n    localStorage.setItem('bookmark' + location.pathname, window.scrollY);\n  };\n\n  var scrollToMark = () => {\n    var top = localStorage.getItem('bookmark' + location.pathname);\n    top = parseInt(top, 10);\n    // If the page opens with a specific hash, just jump out\n    if (!isNaN(top) && location.hash === '') {\n      // Auto scroll to the position\n      window.anime({\n        targets  : document.scrollingElement,\n        duration : 200,\n        easing   : 'linear',\n        scrollTop: top\n      });\n    }\n  };\n  // Register everything\n  var init = function(trigger) {\n    // Create a link element\n    var link = document.querySelector('.book-mark-link');\n    // Scroll event\n    window.addEventListener('scroll', () => link.classList.toggle('book-mark-link-fixed', window.scrollY === 0));\n    // Register beforeunload event when the trigger is auto\n    if (trigger === 'auto') {\n      // Register beforeunload event\n      window.addEventListener('beforeunload', doSaveScroll);\n      window.addEventListener('pjax:send', doSaveScroll);\n    }\n    // Save the position by clicking the icon\n    link.addEventListener('click', () => {\n      doSaveScroll();\n      window.anime({\n        targets : link,\n        duration: 200,\n        easing  : 'linear',\n        top     : -30,\n        complete: () => {\n          setTimeout(() => {\n            link.style.top = '';\n          }, 400);\n        }\n      });\n    });\n    scrollToMark();\n    window.addEventListener('pjax:success', scrollToMark);\n  };\n\n  init(CONFIG.bookmark.save);\n});\n"
  },
  {
    "path": "source/js/local-search.js",
    "content": "/* global CONFIG */\n\ndocument.addEventListener('DOMContentLoaded', () => {\n  // Popup Window\n  let isfetched = false;\n  let datas;\n  let isXml = true;\n  // Search DB path\n  let searchPath = CONFIG.path;\n  if (searchPath.length === 0) {\n    searchPath = 'search.xml';\n  } else if (searchPath.endsWith('json')) {\n    isXml = false;\n  }\n  const input = document.querySelector('.search-input');\n  const resultContent = document.getElementById('search-result');\n\n  const getIndexByWord = (word, text, caseSensitive) => {\n    if (CONFIG.localsearch.unescape) {\n      let div = document.createElement('div');\n      div.innerText = word;\n      word = div.innerHTML;\n    }\n    let wordLen = word.length;\n    if (wordLen === 0) return [];\n    let startPosition = 0;\n    let position = [];\n    let index = [];\n    if (!caseSensitive) {\n      text = text.toLowerCase();\n      word = word.toLowerCase();\n    }\n    while ((position = text.indexOf(word, startPosition)) > -1) {\n      index.push({ position, word });\n      startPosition = position + wordLen;\n    }\n    return index;\n  };\n\n  // Merge hits into slices\n  const mergeIntoSlice = (start, end, index, searchText) => {\n    let item = index[index.length - 1];\n    let { position, word } = item;\n    let hits = [];\n    let searchTextCountInSlice = 0;\n    while (position + word.length <= end && index.length !== 0) {\n      if (word === searchText) {\n        searchTextCountInSlice++;\n      }\n      hits.push({\n        position,\n        length: word.length\n      });\n      let wordEnd = position + word.length;\n\n      // Move to next position of hit\n      index.pop();\n      while (index.length !== 0) {\n        item = index[index.length - 1];\n        position = item.position;\n        word = item.word;\n        if (wordEnd > position) {\n          index.pop();\n        } else {\n          break;\n        }\n      }\n    }\n    return {\n      hits,\n      start,\n      end,\n      searchTextCount: searchTextCountInSlice\n    };\n  };\n\n  // Highlight title and content\n  const highlightKeyword = (text, slice) => {\n    let result = '';\n    let prevEnd = slice.start;\n    slice.hits.forEach(hit => {\n      result += text.substring(prevEnd, hit.position);\n      let end = hit.position + hit.length;\n      result += `<b class=\"search-keyword\">${text.substring(hit.position, end)}</b>`;\n      prevEnd = end;\n    });\n    result += text.substring(prevEnd, slice.end);\n    return result;\n  };\n\n  const inputEventFunction = () => {\n    if (!isfetched) return;\n    let searchText = input.value.trim().toLowerCase();\n    let keywords = searchText.split(/[-\\s]+/);\n    if (keywords.length > 1) {\n      keywords.push(searchText);\n    }\n    let resultItems = [];\n    if (searchText.length > 0) {\n      // Perform local searching\n      datas.forEach(({ title, content, url }) => {\n        let titleInLowerCase = title.toLowerCase();\n        let contentInLowerCase = content.toLowerCase();\n        let indexOfTitle = [];\n        let indexOfContent = [];\n        let searchTextCount = 0;\n        keywords.forEach(keyword => {\n          indexOfTitle = indexOfTitle.concat(getIndexByWord(keyword, titleInLowerCase, false));\n          indexOfContent = indexOfContent.concat(getIndexByWord(keyword, contentInLowerCase, false));\n        });\n\n        // Show search results\n        if (indexOfTitle.length > 0 || indexOfContent.length > 0) {\n          let hitCount = indexOfTitle.length + indexOfContent.length;\n          // Sort index by position of keyword\n          [indexOfTitle, indexOfContent].forEach(index => {\n            index.sort((itemLeft, itemRight) => {\n              if (itemRight.position !== itemLeft.position) {\n                return itemRight.position - itemLeft.position;\n              }\n              return itemLeft.word.length - itemRight.word.length;\n            });\n          });\n\n          let slicesOfTitle = [];\n          if (indexOfTitle.length !== 0) {\n            let tmp = mergeIntoSlice(0, title.length, indexOfTitle, searchText);\n            searchTextCount += tmp.searchTextCountInSlice;\n            slicesOfTitle.push(tmp);\n          }\n\n          let slicesOfContent = [];\n          while (indexOfContent.length !== 0) {\n            let item = indexOfContent[indexOfContent.length - 1];\n            let { position, word } = item;\n            // Cut out 100 characters\n            let start = position - 20;\n            let end = position + 80;\n            if (start < 0) {\n              start = 0;\n            }\n            if (end < position + word.length) {\n              end = position + word.length;\n            }\n            if (end > content.length) {\n              end = content.length;\n            }\n            let tmp = mergeIntoSlice(start, end, indexOfContent, searchText);\n            searchTextCount += tmp.searchTextCountInSlice;\n            slicesOfContent.push(tmp);\n          }\n\n          // Sort slices in content by search text's count and hits' count\n          slicesOfContent.sort((sliceLeft, sliceRight) => {\n            if (sliceLeft.searchTextCount !== sliceRight.searchTextCount) {\n              return sliceRight.searchTextCount - sliceLeft.searchTextCount;\n            } else if (sliceLeft.hits.length !== sliceRight.hits.length) {\n              return sliceRight.hits.length - sliceLeft.hits.length;\n            }\n            return sliceLeft.start - sliceRight.start;\n          });\n\n          // Select top N slices in content\n          let upperBound = parseInt(CONFIG.localsearch.top_n_per_article, 10);\n          if (upperBound >= 0) {\n            slicesOfContent = slicesOfContent.slice(0, upperBound);\n          }\n\n          let resultItem = '';\n\n          if (slicesOfTitle.length !== 0) {\n            resultItem += `<li><a href=\"${url}\" class=\"search-result-title\">${highlightKeyword(title, slicesOfTitle[0])}</a>`;\n          } else {\n            resultItem += `<li><a href=\"${url}\" class=\"search-result-title\">${title}</a>`;\n          }\n\n          slicesOfContent.forEach(slice => {\n            resultItem += `<a href=\"${url}\"><p class=\"search-result\">${highlightKeyword(content, slice)}...</p></a>`;\n          });\n\n          resultItem += '</li>';\n          resultItems.push({\n            item: resultItem,\n            id  : resultItems.length,\n            hitCount,\n            searchTextCount\n          });\n        }\n      });\n    }\n    if (keywords.length === 1 && keywords[0] === '') {\n      resultContent.innerHTML = '<div id=\"no-result\"><i class=\"fa fa-search fa-5x\"></i></div>';\n    } else if (resultItems.length === 0) {\n      resultContent.innerHTML = '<div id=\"no-result\"><i class=\"far fa-frown fa-5x\"></i></div>';\n    } else {\n      resultItems.sort((resultLeft, resultRight) => {\n        if (resultLeft.searchTextCount !== resultRight.searchTextCount) {\n          return resultRight.searchTextCount - resultLeft.searchTextCount;\n        } else if (resultLeft.hitCount !== resultRight.hitCount) {\n          return resultRight.hitCount - resultLeft.hitCount;\n        }\n        return resultRight.id - resultLeft.id;\n      });\n      resultContent.innerHTML = `<ul class=\"search-result-list\">${resultItems.map(result => result.item).join('')}</ul>`;\n      window.pjax && window.pjax.refresh(resultContent);\n    }\n  };\n\n  const fetchData = () => {\n    fetch(CONFIG.root + searchPath)\n      .then(response => response.text())\n      .then(res => {\n        // Get the contents from search data\n        isfetched = true;\n        datas = isXml ? [...new DOMParser().parseFromString(res, 'text/xml').querySelectorAll('entry')].map(element => {\n          return {\n            title  : element.querySelector('title').textContent,\n            content: element.querySelector('content').textContent,\n            url    : element.querySelector('url').textContent\n          };\n        }) : JSON.parse(res);\n        // Only match articles with not empty titles\n        datas = datas.filter(data => data.title).map(data => {\n          data.title = data.title.trim();\n          data.content = data.content ? data.content.trim().replace(/<[^>]+>/g, '') : '';\n          data.url = decodeURIComponent(data.url).replace(/\\/{2,}/g, '/');\n          return data;\n        });\n        // Remove loading animation\n        document.getElementById('no-result').innerHTML = '<i class=\"fa fa-search fa-5x\"></i>';\n        inputEventFunction();\n      });\n  };\n\n  if (CONFIG.localsearch.preload) {\n    fetchData();\n  }\n\n  if (CONFIG.localsearch.trigger === 'auto') {\n    input.addEventListener('input', inputEventFunction);\n  } else {\n    document.querySelector('.search-icon').addEventListener('click', inputEventFunction);\n    input.addEventListener('keypress', event => {\n      if (event.key === 'Enter') {\n        inputEventFunction();\n      }\n    });\n  }\n\n  // Handle and trigger popup window\n  document.querySelectorAll('.popup-trigger').forEach(element => {\n    element.addEventListener('click', () => {\n      document.body.style.overflow = 'hidden';\n      document.querySelector('.search-pop-overlay').classList.add('search-active');\n      input.focus();\n      if (!isfetched) fetchData();\n    });\n  });\n\n  // Monitor main search box\n  const onPopupClose = () => {\n    document.body.style.overflow = '';\n    document.querySelector('.search-pop-overlay').classList.remove('search-active');\n  };\n\n  document.querySelector('.search-pop-overlay').addEventListener('click', event => {\n    if (event.target === document.querySelector('.search-pop-overlay')) {\n      onPopupClose();\n    }\n  });\n  document.querySelector('.popup-btn-close').addEventListener('click', onPopupClose);\n  window.addEventListener('pjax:success', onPopupClose);\n  window.addEventListener('keyup', event => {\n    if (event.key === 'Escape') {\n      onPopupClose();\n    }\n  });\n});\n"
  },
  {
    "path": "source/js/motion.js",
    "content": "/* global NexT, CONFIG, Velocity */\n\nif (window.$ && window.$.Velocity) window.Velocity = window.$.Velocity;\n\nNexT.motion = {};\n\nNexT.motion.integrator = {\n  queue : [],\n  cursor: -1,\n  init  : function() {\n    this.queue = [];\n    this.cursor = -1;\n    return this;\n  },\n  add: function(fn) {\n    this.queue.push(fn);\n    return this;\n  },\n  next: function() {\n    this.cursor++;\n    var fn = this.queue[this.cursor];\n    typeof fn === 'function' && fn(NexT.motion.integrator);\n  },\n  bootstrap: function() {\n    this.next();\n  }\n};\n\nNexT.motion.middleWares = {\n  logo: function(integrator) {\n    var sequence = [];\n    var brand = document.querySelector('.brand');\n    var image = document.querySelector('.custom-logo-image');\n    var title = document.querySelector('.site-title');\n    var subtitle = document.querySelector('.site-subtitle');\n    var logoLineTop = document.querySelector('.logo-line-before i');\n    var logoLineBottom = document.querySelector('.logo-line-after i');\n\n    brand && sequence.push({\n      e: brand,\n      p: {opacity: 1},\n      o: {duration: 200}\n    });\n\n    function getMistLineSettings(element, translateX) {\n      return {\n        e: element,\n        p: {translateX},\n        o: {\n          duration     : 500,\n          sequenceQueue: false\n        }\n      };\n    }\n\n    function pushImageToSequence() {\n      sequence.push({\n        e: image,\n        p: {opacity: 1, top: 0},\n        o: {duration: 200}\n      });\n    }\n\n    CONFIG.scheme === 'Mist' && logoLineTop && logoLineBottom\n    && sequence.push(\n      getMistLineSettings(logoLineTop, '100%'),\n      getMistLineSettings(logoLineBottom, '-100%')\n    );\n\n    CONFIG.scheme === 'Muse' && image && pushImageToSequence();\n\n    title && sequence.push({\n      e: title,\n      p: {opacity: 1, top: 0},\n      o: {duration: 200}\n    });\n\n    subtitle && sequence.push({\n      e: subtitle,\n      p: {opacity: 1, top: 0},\n      o: {duration: 200}\n    });\n\n    (CONFIG.scheme === 'Pisces' || CONFIG.scheme === 'Gemini') && image && pushImageToSequence();\n\n    if (sequence.length > 0) {\n      sequence[sequence.length - 1].o.complete = function() {\n        integrator.next();\n      };\n      Velocity.RunSequence(sequence);\n    } else {\n      integrator.next();\n    }\n\n    if (CONFIG.motion.async) {\n      integrator.next();\n    }\n  },\n\n  menu: function(integrator) {\n    Velocity(document.querySelectorAll('.menu-item'), 'transition.slideDownIn', {\n      display : null,\n      duration: 200,\n      complete: function() {\n        integrator.next();\n      }\n    });\n\n    if (CONFIG.motion.async) {\n      integrator.next();\n    }\n  },\n\n  subMenu: function(integrator) {\n    var subMenuItem = document.querySelectorAll('.sub-menu .menu-item');\n    if (subMenuItem.length > 0) {\n      subMenuItem.forEach(element => {\n        element.style.opacity = 1;\n      });\n    }\n    integrator.next();\n  },\n\n  postList: function(integrator) {\n    var postBlock = document.querySelectorAll('.post-block, .pagination, .comments');\n    var postBlockTransition = CONFIG.motion.transition.post_block;\n    var postHeader = document.querySelectorAll('.post-header');\n    var postHeaderTransition = CONFIG.motion.transition.post_header;\n    var postBody = document.querySelectorAll('.post-body');\n    var postBodyTransition = CONFIG.motion.transition.post_body;\n    var collHeader = document.querySelectorAll('.collection-header');\n    var collHeaderTransition = CONFIG.motion.transition.coll_header;\n\n    if (postBlock.length > 0) {\n      var postMotionOptions = window.postMotionOptions || {\n        stagger : 100,\n        drag    : true,\n        complete: function() {\n          integrator.next();\n        }\n      };\n\n      if (CONFIG.motion.transition.post_block) {\n        Velocity(postBlock, 'transition.' + postBlockTransition, postMotionOptions);\n      }\n      if (CONFIG.motion.transition.post_header) {\n        Velocity(postHeader, 'transition.' + postHeaderTransition, postMotionOptions);\n      }\n      if (CONFIG.motion.transition.post_body) {\n        Velocity(postBody, 'transition.' + postBodyTransition, postMotionOptions);\n      }\n      if (CONFIG.motion.transition.coll_header) {\n        Velocity(collHeader, 'transition.' + collHeaderTransition, postMotionOptions);\n      }\n    }\n    if (CONFIG.scheme === 'Pisces' || CONFIG.scheme === 'Gemini') {\n      integrator.next();\n    }\n  },\n\n  sidebar: function(integrator) {\n    var sidebarAffix = document.querySelector('.sidebar-inner');\n    var sidebarAffixTransition = CONFIG.motion.transition.sidebar;\n    // Only for Pisces | Gemini.\n    if (sidebarAffixTransition && (CONFIG.scheme === 'Pisces' || CONFIG.scheme === 'Gemini')) {\n      Velocity(sidebarAffix, 'transition.' + sidebarAffixTransition, {\n        display : null,\n        duration: 200,\n        complete: function() {\n          // After motion complete need to remove transform from sidebar to let affix work on Pisces | Gemini.\n          sidebarAffix.style.transform = 'initial';\n        }\n      });\n    }\n    integrator.next();\n  }\n};\n"
  },
  {
    "path": "source/js/next-boot.js",
    "content": "/* global NexT, CONFIG, Velocity */\n\nNexT.boot = {};\n\nNexT.boot.registerEvents = function() {\n\n  NexT.utils.registerScrollPercent();\n  NexT.utils.registerCanIUseTag();\n\n  // Mobile top menu bar.\n  document.querySelector('.site-nav-toggle .toggle').addEventListener('click', () => {\n    event.currentTarget.classList.toggle('toggle-close');\n    var siteNav = document.querySelector('.site-nav');\n    var animateAction = siteNav.classList.contains('site-nav-on') ? 'slideUp' : 'slideDown';\n\n    if (typeof Velocity === 'function') {\n      Velocity(siteNav, animateAction, {\n        duration: 200,\n        complete: function() {\n          siteNav.classList.toggle('site-nav-on');\n        }\n      });\n    } else {\n      siteNav.classList.toggle('site-nav-on');\n    }\n  });\n\n  var TAB_ANIMATE_DURATION = 200;\n  document.querySelectorAll('.sidebar-nav li').forEach((element, index) => {\n    element.addEventListener('click', event => {\n      var item = event.currentTarget;\n      var activeTabClassName = 'sidebar-nav-active';\n      var activePanelClassName = 'sidebar-panel-active';\n      if (item.classList.contains(activeTabClassName)) return;\n\n      var targets = document.querySelectorAll('.sidebar-panel');\n      var target = targets[index];\n      var currentTarget = targets[1 - index];\n      window.anime({\n        targets : currentTarget,\n        duration: TAB_ANIMATE_DURATION,\n        easing  : 'linear',\n        opacity : 0,\n        complete: () => {\n          // Prevent adding TOC to Overview if Overview was selected when close & open sidebar.\n          currentTarget.classList.remove(activePanelClassName);\n          target.style.opacity = 0;\n          target.classList.add(activePanelClassName);\n          window.anime({\n            targets : target,\n            duration: TAB_ANIMATE_DURATION,\n            easing  : 'linear',\n            opacity : 1\n          });\n        }\n      });\n\n      [...item.parentNode.children].forEach(element => {\n        element.classList.remove(activeTabClassName);\n      });\n      item.classList.add(activeTabClassName);\n    });\n  });\n\n  window.addEventListener('resize', NexT.utils.initSidebarDimension);\n\n  window.addEventListener('hashchange', () => {\n    var tHash = location.hash;\n    if (tHash !== '' && !tHash.match(/%\\S{2}/)) {\n      var target = document.querySelector(`.tabs ul.nav-tabs li a[href=\"${tHash}\"]`);\n      target && target.click();\n    }\n  });\n};\n\nNexT.boot.refresh = function() {\n\n  /**\n   * Register JS handlers by condition option.\n   * Need to add config option in Front-End at 'layout/_partials/head.swig' file.\n   */\n  CONFIG.fancybox && NexT.utils.wrapImageWithFancyBox();\n  CONFIG.mediumzoom && window.mediumZoom('.post-body :not(a) > img, .post-body > img');\n  CONFIG.lazyload && window.lozad('.post-body img').observe();\n  CONFIG.pangu && window.pangu.spacingPage();\n\n  CONFIG.exturl && NexT.utils.registerExtURL();\n  CONFIG.copycode.enable && NexT.utils.registerCopyCode();\n  NexT.utils.registerTabsTag();\n  NexT.utils.registerActiveMenuItem();\n  NexT.utils.registerLangSelect();\n  NexT.utils.registerSidebarTOC();\n  NexT.utils.wrapTableWithBox();\n  NexT.utils.registerVideoIframe();\n};\n\nNexT.boot.motion = function() {\n  // Define Motion Sequence & Bootstrap Motion.\n  if (CONFIG.motion.enable) {\n    NexT.motion.integrator\n      .add(NexT.motion.middleWares.logo)\n      .add(NexT.motion.middleWares.menu)\n      .add(NexT.motion.middleWares.postList)\n      .add(NexT.motion.middleWares.sidebar)\n      .bootstrap();\n  }\n  NexT.utils.updateSidebarPosition();\n};\n\ndocument.addEventListener('DOMContentLoaded', () => {\n  NexT.boot.registerEvents();\n  NexT.boot.refresh();\n  NexT.boot.motion();\n});\n"
  },
  {
    "path": "source/js/schemes/muse.js",
    "content": "/* global NexT, CONFIG, Velocity */\n\ndocument.addEventListener('DOMContentLoaded', () => {\n\n  var isRight = CONFIG.sidebar.position === 'right';\n  var SIDEBAR_WIDTH = CONFIG.sidebar.width || 320;\n  var SIDEBAR_DISPLAY_DURATION = 200;\n  var mousePos = {};\n\n  var sidebarToggleLines = {\n    lines: document.querySelector('.sidebar-toggle'),\n    init : function() {\n      this.lines.classList.remove('toggle-arrow', 'toggle-close');\n    },\n    arrow: function() {\n      this.lines.classList.remove('toggle-close');\n      this.lines.classList.add('toggle-arrow');\n    },\n    close: function() {\n      this.lines.classList.remove('toggle-arrow');\n      this.lines.classList.add('toggle-close');\n    }\n  };\n\n  var sidebarToggleMotion = {\n    sidebarEl       : document.querySelector('.sidebar'),\n    isSidebarVisible: false,\n    init            : function() {\n      sidebarToggleLines.init();\n\n      window.addEventListener('mousedown', this.mousedownHandler.bind(this));\n      window.addEventListener('mouseup', this.mouseupHandler.bind(this));\n      document.querySelector('#sidebar-dimmer').addEventListener('click', this.clickHandler.bind(this));\n      document.querySelector('.sidebar-toggle').addEventListener('click', this.clickHandler.bind(this));\n      document.querySelector('.sidebar-toggle').addEventListener('mouseenter', this.mouseEnterHandler.bind(this));\n      document.querySelector('.sidebar-toggle').addEventListener('mouseleave', this.mouseLeaveHandler.bind(this));\n      window.addEventListener('sidebar:show', this.showSidebar.bind(this));\n      window.addEventListener('sidebar:hide', this.hideSidebar.bind(this));\n    },\n    mousedownHandler: function(event) {\n      mousePos.X = event.pageX;\n      mousePos.Y = event.pageY;\n    },\n    mouseupHandler: function(event) {\n      var deltaX = event.pageX - mousePos.X;\n      var deltaY = event.pageY - mousePos.Y;\n      var clickingBlankPart = Math.sqrt((deltaX * deltaX) + (deltaY * deltaY)) < 20 && event.target.matches('.main');\n      if (this.isSidebarVisible && (clickingBlankPart || event.target.matches('img.medium-zoom-image, .fancybox img'))) {\n        this.hideSidebar();\n      }\n    },\n    clickHandler: function() {\n      this.isSidebarVisible ? this.hideSidebar() : this.showSidebar();\n    },\n    mouseEnterHandler: function() {\n      if (!this.isSidebarVisible) {\n        sidebarToggleLines.arrow();\n      }\n    },\n    mouseLeaveHandler: function() {\n      if (!this.isSidebarVisible) {\n        sidebarToggleLines.init();\n      }\n    },\n    showSidebar: function() {\n      this.isSidebarVisible = true;\n      this.sidebarEl.classList.add('sidebar-active');\n      if (typeof Velocity === 'function') {\n        Velocity(document.querySelectorAll('.sidebar .motion-element'), isRight ? 'transition.slideRightIn' : 'transition.slideLeftIn', {\n          stagger: 50,\n          drag   : true\n        });\n      }\n\n      sidebarToggleLines.close();\n      NexT.utils.isDesktop() && window.anime(Object.assign({\n        targets : document.body,\n        duration: SIDEBAR_DISPLAY_DURATION,\n        easing  : 'linear'\n      }, isRight ? {\n        'padding-right': SIDEBAR_WIDTH\n      } : {\n        'padding-left': SIDEBAR_WIDTH\n      }));\n    },\n    hideSidebar: function() {\n      this.isSidebarVisible = false;\n      this.sidebarEl.classList.remove('sidebar-active');\n\n      sidebarToggleLines.init();\n      NexT.utils.isDesktop() && window.anime(Object.assign({\n        targets : document.body,\n        duration: SIDEBAR_DISPLAY_DURATION,\n        easing  : 'linear'\n      }, isRight ? {\n        'padding-right': 0\n      } : {\n        'padding-left': 0\n      }));\n    }\n  };\n  sidebarToggleMotion.init();\n\n  function updateFooterPosition() {\n    var footer = document.querySelector('.footer');\n    var containerHeight = document.querySelector('.header').offsetHeight + document.querySelector('.main').offsetHeight + footer.offsetHeight;\n    footer.classList.toggle('footer-fixed', containerHeight <= window.innerHeight);\n  }\n\n  updateFooterPosition();\n  window.addEventListener('resize', updateFooterPosition);\n  window.addEventListener('scroll', updateFooterPosition);\n});\n"
  },
  {
    "path": "source/js/schemes/pisces.js",
    "content": "/* global NexT, CONFIG */\n\nvar Affix = {\n  init: function(element, options) {\n    this.element = element;\n    this.offset = options || 0;\n    this.affixed = null;\n    this.unpin = null;\n    this.pinnedOffset = null;\n    this.checkPosition();\n    window.addEventListener('scroll', this.checkPosition.bind(this));\n    window.addEventListener('click', this.checkPositionWithEventLoop.bind(this));\n    window.matchMedia('(min-width: 992px)').addListener(event => {\n      if (event.matches) {\n        this.offset = NexT.utils.getAffixParam();\n        this.checkPosition();\n      }\n    });\n  },\n  getState: function(scrollHeight, height, offsetTop, offsetBottom) {\n    let scrollTop = window.scrollY;\n    let targetHeight = window.innerHeight;\n    if (offsetTop != null && this.affixed === 'top') {\n      if (document.querySelector('.content-wrap').offsetHeight < offsetTop) return 'top';\n      return scrollTop < offsetTop ? 'top' : false;\n    }\n    if (this.affixed === 'bottom') {\n      if (offsetTop != null) return this.unpin <= this.element.getBoundingClientRect().top ? false : 'bottom';\n      return scrollTop + targetHeight <= scrollHeight - offsetBottom ? false : 'bottom';\n    }\n    let initializing = this.affixed === null;\n    let colliderTop = initializing ? scrollTop : this.element.getBoundingClientRect().top + scrollTop;\n    let colliderHeight = initializing ? targetHeight : height;\n    if (offsetTop != null && scrollTop <= offsetTop) return 'top';\n    if (offsetBottom != null && (colliderTop + colliderHeight >= scrollHeight - offsetBottom)) return 'bottom';\n    return false;\n  },\n  getPinnedOffset: function() {\n    if (this.pinnedOffset) return this.pinnedOffset;\n    this.element.classList.remove('affix-top', 'affix-bottom');\n    this.element.classList.add('affix');\n    return (this.pinnedOffset = this.element.getBoundingClientRect().top);\n  },\n  checkPositionWithEventLoop() {\n    setTimeout(this.checkPosition.bind(this), 1);\n  },\n  checkPosition: function() {\n    if (window.getComputedStyle(this.element).display === 'none') return;\n    let height = this.element.offsetHeight;\n    let { offset } = this;\n    let offsetTop = offset.top;\n    let offsetBottom = offset.bottom;\n    let { scrollHeight } = document.body;\n    let affix = this.getState(scrollHeight, height, offsetTop, offsetBottom);\n    if (this.affixed !== affix) {\n      if (this.unpin != null) this.element.style.top = '';\n      let affixType = 'affix' + (affix ? '-' + affix : '');\n      this.affixed = affix;\n      this.unpin = affix === 'bottom' ? this.getPinnedOffset() : null;\n      this.element.classList.remove('affix', 'affix-top', 'affix-bottom');\n      this.element.classList.add(affixType);\n    }\n    if (affix === 'bottom') {\n      this.element.style.top = scrollHeight - height - offsetBottom + 'px';\n    }\n  }\n};\n\nNexT.utils.getAffixParam = function() {\n  const sidebarOffset = CONFIG.sidebar.offset || 12;\n\n  let headerOffset = document.querySelector('.header-inner').offsetHeight;\n  let footerOffset = document.querySelector('.footer').offsetHeight;\n\n  document.querySelector('.sidebar').style.marginTop = headerOffset + sidebarOffset + 'px';\n\n  return {\n    top   : headerOffset,\n    bottom: footerOffset\n  };\n};\n\ndocument.addEventListener('DOMContentLoaded', () => {\n\n  Affix.init(document.querySelector('.sidebar-inner'), NexT.utils.getAffixParam());\n});\n"
  },
  {
    "path": "source/js/utils.js",
    "content": "/* global NexT, CONFIG */\n\nHTMLElement.prototype.wrap = function(wrapper) {\n  this.parentNode.insertBefore(wrapper, this);\n  this.parentNode.removeChild(this);\n  wrapper.appendChild(this);\n};\n\nNexT.utils = {\n\n  /**\n   * Wrap images with fancybox.\n   */\n  wrapImageWithFancyBox: function() {\n    document.querySelectorAll('.post-body :not(a) > img, .post-body > img').forEach(element => {\n      var $image = $(element);\n      var imageLink = $image.attr('data-src') || $image.attr('src');\n      var $imageWrapLink = $image.wrap(`<a class=\"fancybox fancybox.image\" href=\"${imageLink}\" itemscope itemtype=\"http://schema.org/ImageObject\" itemprop=\"url\"></a>`).parent('a');\n      if ($image.is('.post-gallery img')) {\n        $imageWrapLink.attr('data-fancybox', 'gallery').attr('rel', 'gallery');\n      } else if ($image.is('.group-picture img')) {\n        $imageWrapLink.attr('data-fancybox', 'group').attr('rel', 'group');\n      } else {\n        $imageWrapLink.attr('data-fancybox', 'default').attr('rel', 'default');\n      }\n\n      var imageTitle = $image.attr('title') || $image.attr('alt');\n      if (imageTitle) {\n        $imageWrapLink.append(`<p class=\"image-caption\">${imageTitle}</p>`);\n        // Make sure img title tag will show correctly in fancybox\n        $imageWrapLink.attr('title', imageTitle).attr('data-caption', imageTitle);\n      }\n    });\n\n    $.fancybox.defaults.hash = false;\n    $('.fancybox').fancybox({\n      loop   : true,\n      helpers: {\n        overlay: {\n          locked: false\n        }\n      }\n    });\n  },\n\n  registerExtURL: function() {\n    document.querySelectorAll('span.exturl').forEach(element => {\n      let link = document.createElement('a');\n      // https://stackoverflow.com/questions/30106476/using-javascripts-atob-to-decode-base64-doesnt-properly-decode-utf-8-strings\n      link.href = decodeURIComponent(atob(element.dataset.url).split('').map(c => {\n        return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2);\n      }).join(''));\n      link.rel = 'noopener external nofollow noreferrer';\n      link.target = '_blank';\n      link.className = element.className;\n      link.title = element.title;\n      link.innerHTML = element.innerHTML;\n      element.parentNode.replaceChild(link, element);\n    });\n  },\n\n  /**\n   * One-click copy code support.\n   */\n  registerCopyCode: function() {\n    document.querySelectorAll('figure.highlight').forEach(element => {\n      const box = document.createElement('div');\n      element.wrap(box);\n      box.classList.add('highlight-container');\n      box.insertAdjacentHTML('beforeend', '<div class=\"copy-btn\"><i class=\"fa fa-clipboard fa-fw\"></i></div>');\n      var button = element.parentNode.querySelector('.copy-btn');\n      button.addEventListener('click', event => {\n        var target = event.currentTarget;\n        var code = [...target.parentNode.querySelectorAll('.code .line')].map(line => line.innerText).join('\\n');\n        var ta = document.createElement('textarea');\n        ta.style.top = window.scrollY + 'px'; // Prevent page scrolling\n        ta.style.position = 'absolute';\n        ta.style.opacity = '0';\n        ta.readOnly = true;\n        ta.value = code;\n        document.body.append(ta);\n        const selection = document.getSelection();\n        const selected = selection.rangeCount > 0 ? selection.getRangeAt(0) : false;\n        ta.select();\n        ta.setSelectionRange(0, code.length);\n        ta.readOnly = false;\n        var result = document.execCommand('copy');\n        if (CONFIG.copycode.show_result) {\n          target.querySelector('i').className = result ? 'fa fa-check fa-fw' : 'fa fa-times fa-fw';\n        }\n        ta.blur(); // For iOS\n        target.blur();\n        if (selected) {\n          selection.removeAllRanges();\n          selection.addRange(selected);\n        }\n        document.body.removeChild(ta);\n      });\n      button.addEventListener('mouseleave', event => {\n        setTimeout(() => {\n          event.target.querySelector('i').className = 'fa fa-clipboard fa-fw';\n        }, 300);\n      });\n    });\n  },\n\n  wrapTableWithBox: function() {\n    document.querySelectorAll('table').forEach(element => {\n      const box = document.createElement('div');\n      box.className = 'table-container';\n      element.wrap(box);\n    });\n  },\n\n  registerVideoIframe: function() {\n    document.querySelectorAll('iframe').forEach(element => {\n      const supported = [\n        'www.youtube.com',\n        'player.vimeo.com',\n        'player.youku.com',\n        'player.bilibili.com',\n        'www.tudou.com'\n      ].some(host => element.src.includes(host));\n      if (supported && !element.parentNode.matches('.video-container')) {\n        const box = document.createElement('div');\n        box.className = 'video-container';\n        element.wrap(box);\n        let width = Number(element.width);\n        let height = Number(element.height);\n        if (width && height) {\n          element.parentNode.style.paddingTop = (height / width * 100) + '%';\n        }\n      }\n    });\n  },\n\n  registerScrollPercent: function() {\n    var THRESHOLD = 50;\n    var backToTop = document.querySelector('.back-to-top');\n    var readingProgressBar = document.querySelector('.reading-progress-bar');\n    // For init back to top in sidebar if page was scrolled after page refresh.\n    window.addEventListener('scroll', () => {\n      if (backToTop || readingProgressBar) {\n        var docHeight = document.querySelector('.container').offsetHeight;\n        var winHeight = window.innerHeight;\n        var contentVisibilityHeight = docHeight > winHeight ? docHeight - winHeight : document.body.scrollHeight - winHeight;\n        var scrollPercent = Math.min(100 * window.scrollY / contentVisibilityHeight, 100);\n        if (backToTop) {\n          backToTop.classList.toggle('back-to-top-on', window.scrollY > THRESHOLD);\n          backToTop.querySelector('span').innerText = Math.round(scrollPercent) + '%';\n        }\n        if (readingProgressBar) {\n          readingProgressBar.style.width = scrollPercent.toFixed(2) + '%';\n        }\n      }\n    });\n\n    backToTop && backToTop.addEventListener('click', () => {\n      window.anime({\n        targets  : document.scrollingElement,\n        duration : 500,\n        easing   : 'linear',\n        scrollTop: 0\n      });\n    });\n  },\n\n  /**\n   * Tabs tag listener (without twitter bootstrap).\n   */\n  registerTabsTag: function() {\n    // Binding `nav-tabs` & `tab-content` by real time permalink changing.\n    document.querySelectorAll('.tabs ul.nav-tabs .tab').forEach(element => {\n      element.addEventListener('click', event => {\n        event.preventDefault();\n        var target = event.currentTarget;\n        // Prevent selected tab to select again.\n        if (!target.classList.contains('active')) {\n          // Add & Remove active class on `nav-tabs` & `tab-content`.\n          [...target.parentNode.children].forEach(element => {\n            element.classList.remove('active');\n          });\n          target.classList.add('active');\n          var tActive = document.getElementById(target.querySelector('a').getAttribute('href').replace('#', ''));\n          [...tActive.parentNode.children].forEach(element => {\n            element.classList.remove('active');\n          });\n          tActive.classList.add('active');\n          // Trigger event\n          tActive.dispatchEvent(new Event('tabs:click', {\n            bubbles: true\n          }));\n        }\n      });\n    });\n\n    window.dispatchEvent(new Event('tabs:register'));\n  },\n\n  registerCanIUseTag: function() {\n    // Get responsive height passed from iframe.\n    window.addEventListener('message', ({ data }) => {\n      if ((typeof data === 'string') && data.includes('ciu_embed')) {\n        var featureID = data.split(':')[1];\n        var height = data.split(':')[2];\n        document.querySelector(`iframe[data-feature=${featureID}]`).style.height = parseInt(height, 10) + 5 + 'px';\n      }\n    }, false);\n  },\n\n  registerActiveMenuItem: function() {\n    document.querySelectorAll('.menu-item').forEach(element => {\n      var target = element.querySelector('a[href]');\n      if (!target) return;\n      var isSamePath = target.pathname === location.pathname || target.pathname === location.pathname.replace('index.html', '');\n      var isSubPath = !CONFIG.root.startsWith(target.pathname) && location.pathname.startsWith(target.pathname);\n      element.classList.toggle('menu-item-active', target.hostname === location.hostname && (isSamePath || isSubPath));\n    });\n  },\n\n  registerLangSelect: function() {\n    let selects = document.querySelectorAll('.lang-select');\n    selects.forEach(sel => {\n      sel.value = CONFIG.page.lang;\n      sel.addEventListener('change', () => {\n        let target = sel.options[sel.selectedIndex];\n        document.querySelectorAll('.lang-select-label span').forEach(span => span.innerText = target.text);\n        let url = target.dataset.href;\n        window.pjax ? window.pjax.loadUrl(url) : window.location.href = url;\n      });\n    });\n  },\n\n  registerSidebarTOC: function() {\n    const navItems = document.querySelectorAll('.post-toc li');\n    const sections = [...navItems].map(element => {\n      var link = element.querySelector('a.nav-link');\n      var target = document.getElementById(decodeURI(link.getAttribute('href')).replace('#', ''));\n      // TOC item animation navigate.\n      link.addEventListener('click', event => {\n        event.preventDefault();\n        var offset = target.getBoundingClientRect().top + window.scrollY;\n        window.anime({\n          targets  : document.scrollingElement,\n          duration : 500,\n          easing   : 'linear',\n          scrollTop: offset + 10\n        });\n      });\n      return target;\n    });\n\n    var tocElement = document.querySelector('.post-toc-wrap');\n    function activateNavByIndex(target) {\n      if (target.classList.contains('active-current')) return;\n\n      document.querySelectorAll('.post-toc .active').forEach(element => {\n        element.classList.remove('active', 'active-current');\n      });\n      target.classList.add('active', 'active-current');\n      var parent = target.parentNode;\n      while (!parent.matches('.post-toc')) {\n        if (parent.matches('li')) parent.classList.add('active');\n        parent = parent.parentNode;\n      }\n      // Scrolling to center active TOC element if TOC content is taller then viewport.\n      window.anime({\n        targets  : tocElement,\n        duration : 200,\n        easing   : 'linear',\n        scrollTop: tocElement.scrollTop - (tocElement.offsetHeight / 2) + target.getBoundingClientRect().top - tocElement.getBoundingClientRect().top\n      });\n    }\n\n    function findIndex(entries) {\n      let index = 0;\n      let entry = entries[index];\n      if (entry.boundingClientRect.top > 0) {\n        index = sections.indexOf(entry.target);\n        return index === 0 ? 0 : index - 1;\n      }\n      for (; index < entries.length; index++) {\n        if (entries[index].boundingClientRect.top <= 0) {\n          entry = entries[index];\n        } else {\n          return sections.indexOf(entry.target);\n        }\n      }\n      return sections.indexOf(entry.target);\n    }\n\n    function createIntersectionObserver(marginTop) {\n      marginTop = Math.floor(marginTop + 10000);\n      let intersectionObserver = new IntersectionObserver((entries, observe) => {\n        let scrollHeight = document.documentElement.scrollHeight + 100;\n        if (scrollHeight > marginTop) {\n          observe.disconnect();\n          createIntersectionObserver(scrollHeight);\n          return;\n        }\n        let index = findIndex(entries);\n        activateNavByIndex(navItems[index]);\n      }, {\n        rootMargin: marginTop + 'px 0px -100% 0px',\n        threshold : 0\n      });\n      sections.forEach(element => {\n        element && intersectionObserver.observe(element);\n      });\n    }\n    createIntersectionObserver(document.documentElement.scrollHeight);\n  },\n\n  hasMobileUA: function() {\n    let ua = navigator.userAgent;\n    let pa = /iPad|iPhone|Android|Opera Mini|BlackBerry|webOS|UCWEB|Blazer|PSP|IEMobile|Symbian/g;\n    return pa.test(ua);\n  },\n\n  isTablet: function() {\n    return window.screen.width < 992 && window.screen.width > 767 && this.hasMobileUA();\n  },\n\n  isMobile: function() {\n    return window.screen.width < 767 && this.hasMobileUA();\n  },\n\n  isDesktop: function() {\n    return !this.isTablet() && !this.isMobile();\n  },\n\n  supportsPDFs: function() {\n    let ua = navigator.userAgent;\n    let isFirefoxWithPDFJS = ua.includes('irefox') && parseInt(ua.split('rv:')[1].split('.')[0], 10) > 18;\n    let supportsPdfMimeType = typeof navigator.mimeTypes['application/pdf'] !== 'undefined';\n    let isIOS = /iphone|ipad|ipod/i.test(ua.toLowerCase());\n    return isFirefoxWithPDFJS || (supportsPdfMimeType && !isIOS);\n  },\n\n  /**\n   * Init Sidebar & TOC inner dimensions on all pages and for all schemes.\n   * Need for Sidebar/TOC inner scrolling if content taller then viewport.\n   */\n  initSidebarDimension: function() {\n    var sidebarNav = document.querySelector('.sidebar-nav');\n    var sidebarNavHeight = sidebarNav.style.display !== 'none' ? sidebarNav.offsetHeight : 0;\n    var sidebarOffset = CONFIG.sidebar.offset || 12;\n    var sidebarb2tHeight = CONFIG.back2top.enable && CONFIG.back2top.sidebar ? document.querySelector('.back-to-top').offsetHeight : 0;\n    var sidebarSchemePadding = (CONFIG.sidebar.padding * 2) + sidebarNavHeight + sidebarb2tHeight;\n    // Margin of sidebar b2t: -4px -10px -18px, brings a different of 22px.\n    if (CONFIG.scheme === 'Pisces' || CONFIG.scheme === 'Gemini') sidebarSchemePadding += (sidebarOffset * 2) - 22;\n    // Initialize Sidebar & TOC Height.\n    var sidebarWrapperHeight = document.body.offsetHeight - sidebarSchemePadding + 'px';\n    document.querySelector('.site-overview-wrap').style.maxHeight = sidebarWrapperHeight;\n    document.querySelector('.post-toc-wrap').style.maxHeight = sidebarWrapperHeight;\n  },\n\n  updateSidebarPosition: function() {\n    var sidebarNav = document.querySelector('.sidebar-nav');\n    var hasTOC = document.querySelector('.post-toc');\n    if (hasTOC) {\n      sidebarNav.style.display = '';\n      sidebarNav.classList.add('motion-element');\n      document.querySelector('.sidebar-nav-toc').click();\n    } else {\n      sidebarNav.style.display = 'none';\n      sidebarNav.classList.remove('motion-element');\n      document.querySelector('.sidebar-nav-overview').click();\n    }\n    NexT.utils.initSidebarDimension();\n    if (!this.isDesktop() || CONFIG.scheme === 'Pisces' || CONFIG.scheme === 'Gemini') return;\n    // Expand sidebar on post detail page by default, when post has a toc.\n    var display = CONFIG.page.sidebar;\n    if (typeof display !== 'boolean') {\n      // There's no definition sidebar in the page front-matter.\n      display = CONFIG.sidebar.display === 'always' || (CONFIG.sidebar.display === 'post' && hasTOC);\n    }\n    if (display) {\n      window.dispatchEvent(new Event('sidebar:show'));\n    }\n  },\n\n  getScript: function(url, callback, condition) {\n    if (condition) {\n      callback();\n    } else {\n      var script = document.createElement('script');\n      script.onload = script.onreadystatechange = function(_, isAbort) {\n        if (isAbort || !script.readyState || /loaded|complete/.test(script.readyState)) {\n          script.onload = script.onreadystatechange = null;\n          script = undefined;\n          if (!isAbort && callback) setTimeout(callback, 0);\n        }\n      };\n      script.src = url;\n      document.head.appendChild(script);\n    }\n  },\n\n  loadComments: function(element, callback) {\n    if (!CONFIG.comments.lazyload || !element) {\n      callback();\n      return;\n    }\n    let intersectionObserver = new IntersectionObserver((entries, observer) => {\n      let entry = entries[0];\n      if (entry.isIntersecting) {\n        callback();\n        observer.disconnect();\n      }\n    });\n    intersectionObserver.observe(element);\n    return intersectionObserver;\n  }\n};\n"
  },
  {
    "path": "source/lib/anime.min.js",
    "content": "/*\n * anime.js v3.1.0\n * (c) 2019 Julian Garnier\n * Released under the MIT license\n * animejs.com\n */\n\n!function(n,e){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=e():\"function\"==typeof define&&define.amd?define(e):n.anime=e()}(this,function(){\"use strict\";var n={update:null,begin:null,loopBegin:null,changeBegin:null,change:null,changeComplete:null,loopComplete:null,complete:null,loop:1,direction:\"normal\",autoplay:!0,timelineOffset:0},e={duration:1e3,delay:0,endDelay:0,easing:\"easeOutElastic(1, .5)\",round:0},r=[\"translateX\",\"translateY\",\"translateZ\",\"rotate\",\"rotateX\",\"rotateY\",\"rotateZ\",\"scale\",\"scaleX\",\"scaleY\",\"scaleZ\",\"skew\",\"skewX\",\"skewY\",\"perspective\"],t={CSS:{},springs:{}};function a(n,e,r){return Math.min(Math.max(n,e),r)}function o(n,e){return n.indexOf(e)>-1}function u(n,e){return n.apply(null,e)}var i={arr:function(n){return Array.isArray(n)},obj:function(n){return o(Object.prototype.toString.call(n),\"Object\")},pth:function(n){return i.obj(n)&&n.hasOwnProperty(\"totalLength\")},svg:function(n){return n instanceof SVGElement},inp:function(n){return n instanceof HTMLInputElement},dom:function(n){return n.nodeType||i.svg(n)},str:function(n){return\"string\"==typeof n},fnc:function(n){return\"function\"==typeof n},und:function(n){return void 0===n},hex:function(n){return/(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(n)},rgb:function(n){return/^rgb/.test(n)},hsl:function(n){return/^hsl/.test(n)},col:function(n){return i.hex(n)||i.rgb(n)||i.hsl(n)},key:function(r){return!n.hasOwnProperty(r)&&!e.hasOwnProperty(r)&&\"targets\"!==r&&\"keyframes\"!==r}};function c(n){var e=/\\(([^)]+)\\)/.exec(n);return e?e[1].split(\",\").map(function(n){return parseFloat(n)}):[]}function s(n,e){var r=c(n),o=a(i.und(r[0])?1:r[0],.1,100),u=a(i.und(r[1])?100:r[1],.1,100),s=a(i.und(r[2])?10:r[2],.1,100),f=a(i.und(r[3])?0:r[3],.1,100),l=Math.sqrt(u/o),d=s/(2*Math.sqrt(u*o)),p=d<1?l*Math.sqrt(1-d*d):0,h=1,v=d<1?(d*l-f)/p:-f+l;function g(n){var r=e?e*n/1e3:n;return r=d<1?Math.exp(-r*d*l)*(h*Math.cos(p*r)+v*Math.sin(p*r)):(h+v*r)*Math.exp(-r*l),0===n||1===n?n:1-r}return e?g:function(){var e=t.springs[n];if(e)return e;for(var r=0,a=0;;)if(1===g(r+=1/6)){if(++a>=16)break}else a=0;var o=r*(1/6)*1e3;return t.springs[n]=o,o}}function f(n){return void 0===n&&(n=10),function(e){return Math.round(e*n)*(1/n)}}var l,d,p=function(){var n=11,e=1/(n-1);function r(n,e){return 1-3*e+3*n}function t(n,e){return 3*e-6*n}function a(n){return 3*n}function o(n,e,o){return((r(e,o)*n+t(e,o))*n+a(e))*n}function u(n,e,o){return 3*r(e,o)*n*n+2*t(e,o)*n+a(e)}return function(r,t,a,i){if(0<=r&&r<=1&&0<=a&&a<=1){var c=new Float32Array(n);if(r!==t||a!==i)for(var s=0;s<n;++s)c[s]=o(s*e,r,a);return function(n){return r===t&&a===i?n:0===n||1===n?n:o(f(n),t,i)}}function f(t){for(var i=0,s=1,f=n-1;s!==f&&c[s]<=t;++s)i+=e;var l=i+(t-c[--s])/(c[s+1]-c[s])*e,d=u(l,r,a);return d>=.001?function(n,e,r,t){for(var a=0;a<4;++a){var i=u(e,r,t);if(0===i)return e;e-=(o(e,r,t)-n)/i}return e}(t,l,r,a):0===d?l:function(n,e,r,t,a){for(var u,i,c=0;(u=o(i=e+(r-e)/2,t,a)-n)>0?r=i:e=i,Math.abs(u)>1e-7&&++c<10;);return i}(t,i,i+e,r,a)}}}(),h=(l={linear:function(){return function(n){return n}}},d={Sine:function(){return function(n){return 1-Math.cos(n*Math.PI/2)}},Circ:function(){return function(n){return 1-Math.sqrt(1-n*n)}},Back:function(){return function(n){return n*n*(3*n-2)}},Bounce:function(){return function(n){for(var e,r=4;n<((e=Math.pow(2,--r))-1)/11;);return 1/Math.pow(4,3-r)-7.5625*Math.pow((3*e-2)/22-n,2)}},Elastic:function(n,e){void 0===n&&(n=1),void 0===e&&(e=.5);var r=a(n,1,10),t=a(e,.1,2);return function(n){return 0===n||1===n?n:-r*Math.pow(2,10*(n-1))*Math.sin((n-1-t/(2*Math.PI)*Math.asin(1/r))*(2*Math.PI)/t)}}},[\"Quad\",\"Cubic\",\"Quart\",\"Quint\",\"Expo\"].forEach(function(n,e){d[n]=function(){return function(n){return Math.pow(n,e+2)}}}),Object.keys(d).forEach(function(n){var e=d[n];l[\"easeIn\"+n]=e,l[\"easeOut\"+n]=function(n,r){return function(t){return 1-e(n,r)(1-t)}},l[\"easeInOut\"+n]=function(n,r){return function(t){return t<.5?e(n,r)(2*t)/2:1-e(n,r)(-2*t+2)/2}}}),l);function v(n,e){if(i.fnc(n))return n;var r=n.split(\"(\")[0],t=h[r],a=c(n);switch(r){case\"spring\":return s(n,e);case\"cubicBezier\":return u(p,a);case\"steps\":return u(f,a);default:return u(t,a)}}function g(n){try{return document.querySelectorAll(n)}catch(n){return}}function m(n,e){for(var r=n.length,t=arguments.length>=2?arguments[1]:void 0,a=[],o=0;o<r;o++)if(o in n){var u=n[o];e.call(t,u,o,n)&&a.push(u)}return a}function y(n){return n.reduce(function(n,e){return n.concat(i.arr(e)?y(e):e)},[])}function b(n){return i.arr(n)?n:(i.str(n)&&(n=g(n)||n),n instanceof NodeList||n instanceof HTMLCollection?[].slice.call(n):[n])}function M(n,e){return n.some(function(n){return n===e})}function x(n){var e={};for(var r in n)e[r]=n[r];return e}function w(n,e){var r=x(n);for(var t in n)r[t]=e.hasOwnProperty(t)?e[t]:n[t];return r}function k(n,e){var r=x(n);for(var t in e)r[t]=i.und(n[t])?e[t]:n[t];return r}function O(n){return i.rgb(n)?(r=/rgb\\((\\d+,\\s*[\\d]+,\\s*[\\d]+)\\)/g.exec(e=n))?\"rgba(\"+r[1]+\",1)\":e:i.hex(n)?(t=n.replace(/^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i,function(n,e,r,t){return e+e+r+r+t+t}),a=/^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(t),\"rgba(\"+parseInt(a[1],16)+\",\"+parseInt(a[2],16)+\",\"+parseInt(a[3],16)+\",1)\"):i.hsl(n)?function(n){var e,r,t,a=/hsl\\((\\d+),\\s*([\\d.]+)%,\\s*([\\d.]+)%\\)/g.exec(n)||/hsla\\((\\d+),\\s*([\\d.]+)%,\\s*([\\d.]+)%,\\s*([\\d.]+)\\)/g.exec(n),o=parseInt(a[1],10)/360,u=parseInt(a[2],10)/100,i=parseInt(a[3],10)/100,c=a[4]||1;function s(n,e,r){return r<0&&(r+=1),r>1&&(r-=1),r<1/6?n+6*(e-n)*r:r<.5?e:r<2/3?n+(e-n)*(2/3-r)*6:n}if(0==u)e=r=t=i;else{var f=i<.5?i*(1+u):i+u-i*u,l=2*i-f;e=s(l,f,o+1/3),r=s(l,f,o),t=s(l,f,o-1/3)}return\"rgba(\"+255*e+\",\"+255*r+\",\"+255*t+\",\"+c+\")\"}(n):void 0;var e,r,t,a}function C(n){var e=/[+-]?\\d*\\.?\\d+(?:\\.\\d+)?(?:[eE][+-]?\\d+)?(%|px|pt|em|rem|in|cm|mm|ex|ch|pc|vw|vh|vmin|vmax|deg|rad|turn)?$/.exec(n);if(e)return e[1]}function B(n,e){return i.fnc(n)?n(e.target,e.id,e.total):n}function P(n,e){return n.getAttribute(e)}function I(n,e,r){if(M([r,\"deg\",\"rad\",\"turn\"],C(e)))return e;var a=t.CSS[e+r];if(!i.und(a))return a;var o=document.createElement(n.tagName),u=n.parentNode&&n.parentNode!==document?n.parentNode:document.body;u.appendChild(o),o.style.position=\"absolute\",o.style.width=100+r;var c=100/o.offsetWidth;u.removeChild(o);var s=c*parseFloat(e);return t.CSS[e+r]=s,s}function T(n,e,r){if(e in n.style){var t=e.replace(/([a-z])([A-Z])/g,\"$1-$2\").toLowerCase(),a=n.style[e]||getComputedStyle(n).getPropertyValue(t)||\"0\";return r?I(n,a,r):a}}function D(n,e){return i.dom(n)&&!i.inp(n)&&(P(n,e)||i.svg(n)&&n[e])?\"attribute\":i.dom(n)&&M(r,e)?\"transform\":i.dom(n)&&\"transform\"!==e&&T(n,e)?\"css\":null!=n[e]?\"object\":void 0}function E(n){if(i.dom(n)){for(var e,r=n.style.transform||\"\",t=/(\\w+)\\(([^)]*)\\)/g,a=new Map;e=t.exec(r);)a.set(e[1],e[2]);return a}}function F(n,e,r,t){var a,u=o(e,\"scale\")?1:0+(o(a=e,\"translate\")||\"perspective\"===a?\"px\":o(a,\"rotate\")||o(a,\"skew\")?\"deg\":void 0),i=E(n).get(e)||u;return r&&(r.transforms.list.set(e,i),r.transforms.last=e),t?I(n,i,t):i}function N(n,e,r,t){switch(D(n,e)){case\"transform\":return F(n,e,t,r);case\"css\":return T(n,e,r);case\"attribute\":return P(n,e);default:return n[e]||0}}function A(n,e){var r=/^(\\*=|\\+=|-=)/.exec(n);if(!r)return n;var t=C(n)||0,a=parseFloat(e),o=parseFloat(n.replace(r[0],\"\"));switch(r[0][0]){case\"+\":return a+o+t;case\"-\":return a-o+t;case\"*\":return a*o+t}}function L(n,e){if(i.col(n))return O(n);if(/\\s/g.test(n))return n;var r=C(n),t=r?n.substr(0,n.length-r.length):n;return e?t+e:t}function j(n,e){return Math.sqrt(Math.pow(e.x-n.x,2)+Math.pow(e.y-n.y,2))}function S(n){for(var e,r=n.points,t=0,a=0;a<r.numberOfItems;a++){var o=r.getItem(a);a>0&&(t+=j(e,o)),e=o}return t}function q(n){if(n.getTotalLength)return n.getTotalLength();switch(n.tagName.toLowerCase()){case\"circle\":return o=n,2*Math.PI*P(o,\"r\");case\"rect\":return 2*P(a=n,\"width\")+2*P(a,\"height\");case\"line\":return j({x:P(t=n,\"x1\"),y:P(t,\"y1\")},{x:P(t,\"x2\"),y:P(t,\"y2\")});case\"polyline\":return S(n);case\"polygon\":return r=(e=n).points,S(e)+j(r.getItem(r.numberOfItems-1),r.getItem(0))}var e,r,t,a,o}function $(n,e){var r=e||{},t=r.el||function(n){for(var e=n.parentNode;i.svg(e)&&i.svg(e.parentNode);)e=e.parentNode;return e}(n),a=t.getBoundingClientRect(),o=P(t,\"viewBox\"),u=a.width,c=a.height,s=r.viewBox||(o?o.split(\" \"):[0,0,u,c]);return{el:t,viewBox:s,x:s[0]/1,y:s[1]/1,w:u/s[2],h:c/s[3]}}function X(n,e){function r(r){void 0===r&&(r=0);var t=e+r>=1?e+r:0;return n.el.getPointAtLength(t)}var t=$(n.el,n.svg),a=r(),o=r(-1),u=r(1);switch(n.property){case\"x\":return(a.x-t.x)*t.w;case\"y\":return(a.y-t.y)*t.h;case\"angle\":return 180*Math.atan2(u.y-o.y,u.x-o.x)/Math.PI}}function Y(n,e){var r=/[+-]?\\d*\\.?\\d+(?:\\.\\d+)?(?:[eE][+-]?\\d+)?/g,t=L(i.pth(n)?n.totalLength:n,e)+\"\";return{original:t,numbers:t.match(r)?t.match(r).map(Number):[0],strings:i.str(n)||e?t.split(r):[]}}function Z(n){return m(n?y(i.arr(n)?n.map(b):b(n)):[],function(n,e,r){return r.indexOf(n)===e})}function Q(n){var e=Z(n);return e.map(function(n,r){return{target:n,id:r,total:e.length,transforms:{list:E(n)}}})}function V(n,e){var r=x(e);if(/^spring/.test(r.easing)&&(r.duration=s(r.easing)),i.arr(n)){var t=n.length;2===t&&!i.obj(n[0])?n={value:n}:i.fnc(e.duration)||(r.duration=e.duration/t)}var a=i.arr(n)?n:[n];return a.map(function(n,r){var t=i.obj(n)&&!i.pth(n)?n:{value:n};return i.und(t.delay)&&(t.delay=r?0:e.delay),i.und(t.endDelay)&&(t.endDelay=r===a.length-1?e.endDelay:0),t}).map(function(n){return k(n,r)})}function z(n,e){var r=[],t=e.keyframes;for(var a in t&&(e=k(function(n){for(var e=m(y(n.map(function(n){return Object.keys(n)})),function(n){return i.key(n)}).reduce(function(n,e){return n.indexOf(e)<0&&n.push(e),n},[]),r={},t=function(t){var a=e[t];r[a]=n.map(function(n){var e={};for(var r in n)i.key(r)?r==a&&(e.value=n[r]):e[r]=n[r];return e})},a=0;a<e.length;a++)t(a);return r}(t),e)),e)i.key(a)&&r.push({name:a,tweens:V(e[a],n)});return r}function H(n,e){var r;return n.tweens.map(function(t){var a=function(n,e){var r={};for(var t in n){var a=B(n[t],e);i.arr(a)&&1===(a=a.map(function(n){return B(n,e)})).length&&(a=a[0]),r[t]=a}return r.duration=parseFloat(r.duration),r.delay=parseFloat(r.delay),r}(t,e),o=a.value,u=i.arr(o)?o[1]:o,c=C(u),s=N(e.target,n.name,c,e),f=r?r.to.original:s,l=i.arr(o)?o[0]:f,d=C(l)||C(s),p=c||d;return i.und(u)&&(u=f),a.from=Y(l,p),a.to=Y(A(u,l),p),a.start=r?r.end:0,a.end=a.start+a.delay+a.duration+a.endDelay,a.easing=v(a.easing,a.duration),a.isPath=i.pth(o),a.isColor=i.col(a.from.original),a.isColor&&(a.round=1),r=a,a})}var G={css:function(n,e,r){return n.style[e]=r},attribute:function(n,e,r){return n.setAttribute(e,r)},object:function(n,e,r){return n[e]=r},transform:function(n,e,r,t,a){if(t.list.set(e,r),e===t.last||a){var o=\"\";t.list.forEach(function(n,e){o+=e+\"(\"+n+\") \"}),n.style.transform=o}}};function R(n,e){Q(n).forEach(function(n){for(var r in e){var t=B(e[r],n),a=n.target,o=C(t),u=N(a,r,o,n),i=A(L(t,o||C(u)),u),c=D(a,r);G[c](a,r,i,n.transforms,!0)}})}function W(n,e){return m(y(n.map(function(n){return e.map(function(e){return function(n,e){var r=D(n.target,e.name);if(r){var t=H(e,n),a=t[t.length-1];return{type:r,property:e.name,animatable:n,tweens:t,duration:a.end,delay:t[0].delay,endDelay:a.endDelay}}}(n,e)})})),function(n){return!i.und(n)})}function J(n,e){var r=n.length,t=function(n){return n.timelineOffset?n.timelineOffset:0},a={};return a.duration=r?Math.max.apply(Math,n.map(function(n){return t(n)+n.duration})):e.duration,a.delay=r?Math.min.apply(Math,n.map(function(n){return t(n)+n.delay})):e.delay,a.endDelay=r?a.duration-Math.max.apply(Math,n.map(function(n){return t(n)+n.duration-n.endDelay})):e.endDelay,a}var K=0;var U,_=[],nn=[],en=function(){function n(){U=requestAnimationFrame(e)}function e(e){var r=_.length;if(r){for(var t=0;t<r;){var a=_[t];if(a.paused){var o=_.indexOf(a);o>-1&&(_.splice(o,1),r=_.length)}else a.tick(e);t++}n()}else U=cancelAnimationFrame(U)}return n}();function rn(r){void 0===r&&(r={});var t,o=0,u=0,i=0,c=0,s=null;function f(n){var e=window.Promise&&new Promise(function(n){return s=n});return n.finished=e,e}var l,d,p,h,v,g,y,b,M=(d=w(n,l=r),p=w(e,l),h=z(p,l),v=Q(l.targets),g=W(v,h),y=J(g,p),b=K,K++,k(d,{id:b,children:[],animatables:v,animations:g,duration:y.duration,delay:y.delay,endDelay:y.endDelay}));f(M);function x(){var n=M.direction;\"alternate\"!==n&&(M.direction=\"normal\"!==n?\"normal\":\"reverse\"),M.reversed=!M.reversed,t.forEach(function(n){return n.reversed=M.reversed})}function O(n){return M.reversed?M.duration-n:n}function C(){o=0,u=O(M.currentTime)*(1/rn.speed)}function B(n,e){e&&e.seek(n-e.timelineOffset)}function P(n){for(var e=0,r=M.animations,t=r.length;e<t;){var o=r[e],u=o.animatable,i=o.tweens,c=i.length-1,s=i[c];c&&(s=m(i,function(e){return n<e.end})[0]||s);for(var f=a(n-s.start-s.delay,0,s.duration)/s.duration,l=isNaN(f)?1:s.easing(f),d=s.to.strings,p=s.round,h=[],v=s.to.numbers.length,g=void 0,y=0;y<v;y++){var b=void 0,x=s.to.numbers[y],w=s.from.numbers[y]||0;b=s.isPath?X(s.value,l*x):w+l*(x-w),p&&(s.isColor&&y>2||(b=Math.round(b*p)/p)),h.push(b)}var k=d.length;if(k){g=d[0];for(var O=0;O<k;O++){d[O];var C=d[O+1],B=h[O];isNaN(B)||(g+=C?B+C:B+\" \")}}else g=h[0];G[o.type](u.target,o.property,g,u.transforms),o.currentValue=g,e++}}function I(n){M[n]&&!M.passThrough&&M[n](M)}function T(n){var e=M.duration,r=M.delay,l=e-M.endDelay,d=O(n);M.progress=a(d/e*100,0,100),M.reversePlayback=d<M.currentTime,t&&function(n){if(M.reversePlayback)for(var e=c;e--;)B(n,t[e]);else for(var r=0;r<c;r++)B(n,t[r])}(d),!M.began&&M.currentTime>0&&(M.began=!0,I(\"begin\")),!M.loopBegan&&M.currentTime>0&&(M.loopBegan=!0,I(\"loopBegin\")),d<=r&&0!==M.currentTime&&P(0),(d>=l&&M.currentTime!==e||!e)&&P(e),d>r&&d<l?(M.changeBegan||(M.changeBegan=!0,M.changeCompleted=!1,I(\"changeBegin\")),I(\"change\"),P(d)):M.changeBegan&&(M.changeCompleted=!0,M.changeBegan=!1,I(\"changeComplete\")),M.currentTime=a(d,0,e),M.began&&I(\"update\"),n>=e&&(u=0,M.remaining&&!0!==M.remaining&&M.remaining--,M.remaining?(o=i,I(\"loopComplete\"),M.loopBegan=!1,\"alternate\"===M.direction&&x()):(M.paused=!0,M.completed||(M.completed=!0,I(\"loopComplete\"),I(\"complete\"),!M.passThrough&&\"Promise\"in window&&(s(),f(M)))))}return M.reset=function(){var n=M.direction;M.passThrough=!1,M.currentTime=0,M.progress=0,M.paused=!0,M.began=!1,M.loopBegan=!1,M.changeBegan=!1,M.completed=!1,M.changeCompleted=!1,M.reversePlayback=!1,M.reversed=\"reverse\"===n,M.remaining=M.loop,t=M.children;for(var e=c=t.length;e--;)M.children[e].reset();(M.reversed&&!0!==M.loop||\"alternate\"===n&&1===M.loop)&&M.remaining++,P(M.reversed?M.duration:0)},M.set=function(n,e){return R(n,e),M},M.tick=function(n){i=n,o||(o=i),T((i+(u-o))*rn.speed)},M.seek=function(n){T(O(n))},M.pause=function(){M.paused=!0,C()},M.play=function(){M.paused&&(M.completed&&M.reset(),M.paused=!1,_.push(M),C(),U||en())},M.reverse=function(){x(),C()},M.restart=function(){M.reset(),M.play()},M.reset(),M.autoplay&&M.play(),M}function tn(n,e){for(var r=e.length;r--;)M(n,e[r].animatable.target)&&e.splice(r,1)}return\"undefined\"!=typeof document&&document.addEventListener(\"visibilitychange\",function(){document.hidden?(_.forEach(function(n){return n.pause()}),nn=_.slice(0),rn.running=_=[]):nn.forEach(function(n){return n.play()})}),rn.version=\"3.1.0\",rn.speed=1,rn.running=_,rn.remove=function(n){for(var e=Z(n),r=_.length;r--;){var t=_[r],a=t.animations,o=t.children;tn(e,a);for(var u=o.length;u--;){var i=o[u],c=i.animations;tn(e,c),c.length||i.children.length||o.splice(u,1)}a.length||o.length||t.pause()}},rn.get=N,rn.set=R,rn.convertPx=I,rn.path=function(n,e){var r=i.str(n)?g(n)[0]:n,t=e||100;return function(n){return{property:n,el:r,svg:$(r),totalLength:q(r)*(t/100)}}},rn.setDashoffset=function(n){var e=q(n);return n.setAttribute(\"stroke-dasharray\",e),e},rn.stagger=function(n,e){void 0===e&&(e={});var r=e.direction||\"normal\",t=e.easing?v(e.easing):null,a=e.grid,o=e.axis,u=e.from||0,c=\"first\"===u,s=\"center\"===u,f=\"last\"===u,l=i.arr(n),d=l?parseFloat(n[0]):parseFloat(n),p=l?parseFloat(n[1]):0,h=C(l?n[1]:n)||0,g=e.start||0+(l?d:0),m=[],y=0;return function(n,e,i){if(c&&(u=0),s&&(u=(i-1)/2),f&&(u=i-1),!m.length){for(var v=0;v<i;v++){if(a){var b=s?(a[0]-1)/2:u%a[0],M=s?(a[1]-1)/2:Math.floor(u/a[0]),x=b-v%a[0],w=M-Math.floor(v/a[0]),k=Math.sqrt(x*x+w*w);\"x\"===o&&(k=-x),\"y\"===o&&(k=-w),m.push(k)}else m.push(Math.abs(u-v));y=Math.max.apply(Math,m)}t&&(m=m.map(function(n){return t(n/y)*y})),\"reverse\"===r&&(m=m.map(function(n){return o?n<0?-1*n:-n:Math.abs(y-n)}))}return g+(l?(p-d)/y:d)*(Math.round(100*m[e])/100)+h}},rn.timeline=function(n){void 0===n&&(n={});var r=rn(n);return r.duration=0,r.add=function(t,a){var o=_.indexOf(r),u=r.children;function c(n){n.passThrough=!0}o>-1&&_.splice(o,1);for(var s=0;s<u.length;s++)c(u[s]);var f=k(t,w(e,n));f.targets=f.targets||n.targets;var l=r.duration;f.autoplay=!1,f.direction=r.direction,f.timelineOffset=i.und(a)?l:A(a,l),c(r),r.seek(f.timelineOffset);var d=rn(f);c(d),u.push(d);var p=J(u,n);return r.delay=p.delay,r.endDelay=p.endDelay,r.duration=p.duration,r.seek(0),r.reset(),r.autoplay&&r.play(),r},r},rn.easing=v,rn.penner=h,rn.random=function(n,e){return Math.floor(Math.random()*(e-n+1))+n},rn});"
  }
]