Greasy Fork is available in English.

简悦( SimpRead ) · 轻阅版

简悦 - 让你瞬间进入沉浸式阅读的 User Script 扩展

(function () {
  'use strict';

  var _extends = Object.assign || function (target) {
    for (var i = 1; i < arguments.length; i++) {
      var source = arguments[i];

      for (var key in source) {
        if (Object.prototype.hasOwnProperty.call(source, key)) {
          target[key] = source[key];
        }
      }
    }

    return target;
  };

  var toConsumableArray = function (arr) {
    if (Array.isArray(arr)) {
      for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) arr2[i] = arr[i];

      return arr2;
    } else {
      return Array.from(arr);
    }
  };

  // ==UserScript==
  // @name         简悦( SimpRead ) · 轻阅版
  // @namespace    http://ksria.com/simpread/
  // @version      1.1.2.5016
  // @description  简悦 - 让你瞬间进入沉浸式阅读的 User Script 扩展
  // @author       Kenshin <kenshin@ksria.com>
  // @icon         
  // @include      http://*/*
  // @include      https://*/*
  // @require      https://cdnjs.cloudflare.com/ajax/libs/jquery/3.4.1/jquery.min.js
  // @require      https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.15.6/highlight.min.js
  // @require      https://greasyfork.org/scripts/40244-mduikit/code/MDUIKit.js?version=697886
  // @require      https://greasyfork.org/scripts/40236-notify/code/Notify.js?version=697887
  // @require      https://greasyfork.org/scripts/40172-mousetrap/code/Mousetrap.js?version=262594
  // @require      https://greasyfork.org/scripts/383025-bloomingmenu/code/BloomingMenu.js?version=698175
  // @require      https://greasyfork.org/scripts/39995-pureread/code/PureRead.js?version=697882
  // @require      https://greasyfork.org/scripts/39997-puplugin/code/PuPlugin.js?version=697883
  // @resource     global_sites http://sr.ksria.cn/website_list_v4.json?data=1.1.2.5016
  // @resource     notify_style http://sr.ksria.cn/puread/notify.css?version=1.1.2.5016
  // @resource     main_style   http://sr.ksria.cn/puread/simpread.css?version=1.1.2.5016
  // @resource     mntips_style http://sr.ksria.cn/puread/mintooltip.css?version=1.1.2.5016
  // @resource     option_style http://sr.ksria.cn/puread/option.css?version=1.1.2.5016
  // @resource     user_style   https://gist.github.com/Kenshin/365a91c61bad550b5900247539113f06/raw/3e666bee279f249e5b59140d8a777192ecb121cd/simpread_user.css
  // @resource     theme_common http://sr.ksria.cn/puread/theme_common.css?version=1.1.2.5016
  // @resource     theme_dark   http://sr.ksria.cn/puread/theme_dark.css?version=1.1.2.5016
  // @resource     theme_github http://sr.ksria.cn/puread/theme_github.css?version=1.1.2.5016
  // @resource     theme_gothic http://sr.ksria.cn/puread/theme_gothic.css?version=1.1.2.5016
  // @resource     theme_night  http://sr.ksria.cn/puread/theme_night.css?version=1.1.2.5016
  // @resource     theme_pixyii http://sr.ksria.cn/puread/theme_pixyii.css?version=1.1.2.5016
  // @resource     theme_engwrite  http://sr.ksria.cn/puread/theme_engwrite.css?version=1.1.2.5016
  // @resource     theme_monospace http://sr.ksria.cn/puread/theme_monospace.css?version=1.1.2.5016
  // @resource     theme_newsprint http://sr.ksria.cn/puread/theme_newsprint.css?version=1.1.2.5016
  // @resource     theme_octopress http://sr.ksria.cn/puread/theme_octopress.css?version=1.1.2.5016
  // @grant        GM_getResourceText
  // @grant        GM_addStyle
  // @grant        GM_getValue
  // @grant        GM_setValue
  // @grant        GM_deleteValue
  // @grant        GM_info
  // @run-at       document-end
  // @noframes
  // ==/UserScript==

  var pr = new PureRead(),
      style = puplugin.Plugin("style"),
      global_sites = GM_getResourceText("global_sites"),
      notify_style = GM_getResourceText("notify_style"),
      main_style = GM_getResourceText("main_style"),
      mntips_style = GM_getResourceText("mntips_style"),
      option_style = GM_getResourceText("option_style"),
      user_style = GM_getResourceText("user_style"),
      theme_common = GM_getResourceText("theme_common"),
      theme_dark = GM_getResourceText("theme_dark"),
      theme_github = GM_getResourceText("theme_github"),
      theme_gothic = GM_getResourceText("theme_gothic"),
      theme_night = GM_getResourceText("theme_night"),
      theme_pixyii = GM_getResourceText("theme_pixyii"),
      theme_engwrite = GM_getResourceText("theme_engwrite"),
      theme_monospace = GM_getResourceText("theme_monospace"),
      theme_newsprint = GM_getResourceText("theme_newsprint"),
      theme_octopress = GM_getResourceText("theme_octopress"),
      theme = { theme_github: theme_github, theme_newsprint: theme_newsprint, theme_gothic: theme_gothic, theme_engwrite: theme_engwrite, theme_octopress: theme_octopress, theme_pixyii: theme_pixyii, theme_monospace: theme_monospace, theme_night: theme_night, theme_dark: theme_dark },
      focus = {
      version: "2016-12-29",
      bgcolor: "rgba( 235, 235, 235, 0.9 )",
      mask: true,
      highlight: true, // not-write, only read
      opacity: 90,
      shortcuts: "A S"
  },
      read = {
      version: "2017-03-16",
      cleanup: true,
      pure: true,
      auto: false,
      controlbar: true,
      highlight: true,
      shortcuts: "A A",
      theme: "github",
      fontfamily: "default",
      whitelist: [],
      exclusion: ["v2ex.com", "issue.github.com", "readme.github.com", "question.zhihu.com", "douban.com", "nationalgeographic.com.cn", "tech.163.com", "docs.microsoft.com", "msdn.microsoft.com", "baijia.baidu.com", "code.oschina.net", "http://www.ifanr.com", "http://www.ifanr.com/news", "http://www.ifanr.com/app", "http://www.ifanr.com/minapp", "http://www.ifanr.com/dasheng", "http://www.ifanr.com/data", "https://www.ifanr.com/app", "http://www.ifanr.com/weizhizao", "http://www.thepaper.cn", "http://www.pingwest.com", "http://tech2ipo.com", "https://www.waerfa.com/social"],
      fontsize: "62.5%",
      layout: "20%",
      toc: true,
      toc_hide: true
  },
      option = {
      version: "2017-04-03",
      esc: true,
      trigger: "read", // include: 'focus' 'read', only by userscript
      origins: [],
      trigger_hiden: true,
      blacklist: ["google.com", "https://www.baidu.com/?vit=1"]
  },
      opt_value = "\n                # \u662F\u5426\u542F\u7528 ESC \u9000\u51FA\u65B9\u5F0F\uFF1F\n                # \u9ED8\u8BA4\u4E3A true\uFF0C\u53D6\u503C\u8303\u56F4 true | false\n                set_esc: true\n\n                # \u53F3\u4E0B\u89D2\u89E6\u53D1\u5668\u70B9\u51FB\u540E\u8FDB\u5165\u7684\u6A21\u5F0F\n                # \u9ED8\u8BA4\u4E3A read\uFF0C\u53D6\u503C\u8303\u56F4 focus | read\n                set_trigger: read\n\n                # \u5F53\u5728\u975E\u9002\u914D\u7684\u9875\u9762\u662F\u5426\u9690\u85CF\u89E6\u53D1\u5668\n                # \u9ED8\u8BA4\u4E3A true \uFF08\u9690\u85CF\uFF09\uFF0C\u53D6\u503C\u8303\u56F4 true | false\n                # \u5F53\u9009\u62E9\u4E86 true \u4E14\u5728\u975E\u9002\u914D\u9875\u9762\u65F6\uFF0C\u53EF\u4EE5\u901A\u8FC7\u5FEB\u6377\u952E\u4F7F\u7528\u4E34\u65F6\u9605\u8BFB\u6A21\u5F0F\n                set_trigger_hiden: true\n\n                # \u9ED1\u540D\u5355\uFF0C\u52A0\u5165\u5176\u4E2D\u540E\uFF0C\u4E0D\u518D\u542F\u52A8\u7B80\u60A6\n                # \u6709\u522B\u4E8E\u767D\u540D\u5355\u548C\u6392\u9664\u5217\u8868\uFF0C\u524D\u4E24\u79CD\u5F53\u524D\u9875\u9762\u8FD8\u662F\u52A0\u8F7D\u7B80\u60A6\uFF0C\u4F46\u9ED1\u540D\u5355\u5219\u5F7B\u5E95\u52A0\u8F7D\u8F7B\u9605\u7684\u4EE3\u7801\n                # \u652F\u6301 \u57DF\u540D \u548C URL\uFF0C\n                # \u4F8B\u5982\uFF1A \n                # https://www.baidu.com/?vit=1 \u5219\u5728\u6B64\u9875\u9762\u7981\u7528\n                # google.com \u5219\u51E1\u662F\u542B\u6709 google.com \u7684\u57DF\u540D\u90FD\u7981\u7528\uFF0C\u5305\u62EC\uFF1A mail.google.com doc.google.com \u7B49\n                # mail.google.com \u4EC5\u5728 mail.google.com \u4E0B\u65E0\u6CD5\u4F7F\u7528\uFF0C\u4F46 doc.google.com \u5219\u6CA1\u95EE\u9898\n                # \u6BCF\u4E2A\u540D\u5355\u7531\u5C0F\u5199 , \u5206\u9694\n                set_blacklist: \n    ",
      focus_value = "\n                # \u662F\u5426\u542F\u7528\u70B9\u51FB\u7A7A\u767D\uFF08\u906E\u7F69\uFF09\u9000\u51FA\u529F\u80FD\uFF1F\n                # \u9ED8\u8BA4\u4E3A true\uFF0C\u53D6\u503C\u8303\u56F4 true | false\n                set_mask: true\n\n                # \u906E\u7F69\u7684\u80CC\u666F\u8272\uFF0C\u4EC5\u652F\u6301 rgba \u683C\u5F0F\n                # \u9ED8\u8BA4\u4E3A rgba( 235, 235, 235, 1 )\n                set_bgcolor: rgba( 235, 235, 235, 0.9 )\n\n                # \u906E\u7F69\u7684\u900F\u660E\u5EA6\n                # \u9ED8\u8BA4\u4E3A 90\uFF0C\u53D6\u503C\u8303\u56F4 0 ~ 100\n                set_opacity: 90\n\n                # \u542F\u52A8\u805A\u7126\u6A21\u5F0F\u7684\u5FEB\u6377\u952E\n                # \u9ED8\u8BA4\u4E3A A S\n                # \u5FC5\u987B\u6709\u4E24\u4E2A\u503C\uFF0C\u4EC5\u652F\u6301 shift, \u5B57\u6BCD\u548C\u6570\u5B57\uFF0C\u4E2D\u95F4\u5FC5\u987B\u6709\u7A7A\u683C\n                set_shortcuts: A S\n\n                # \u5F53\u672A\u9002\u914D\u805A\u7126\u6A21\u5F0F\u65F6\uFF0C\u662F\u5426\u542F\u7528\u624B\u52A8\u805A\u7126\u6A21\u5F0F\uFF1F\n                # \u9ED8\u8BA4\u4E3A\u542F\u7528\uFF0C\u53D6\u503C\u8303\u56F4 true | false\n                set_highlight: true\n    ",
      read_value = "\n                # \u4E3B\u9898\u6837\u5F0F\n                # \u53D6\u503C\u8303\u56F4 \u767D\u7EC3 \u2192 github, \u767D\u78C1 \u2192 newsprint, \u536F\u4E4B\u82B1\u8272 \u2192 gothic, \u4E01\u5B50\u8272 \u2192 engwrite\n                # \u53D6\u503C\u8303\u56F4 \u5A1F\u9F20 \u2192 octopress, \u6708\u767D \u2192 pixyii, \u767E\u5408 \u2192 monospace, \u7D3A\u9F20 \u2192 night, \u9ED2\u9E22 \u2192 dark\n                # \u8BF7\u4F7F\u7528\u5173\u952E\u5B57\uFF0C\u800C\u975E\u540D\u79F0\uFF0C\u5982\uFF1Apixyii\n                set_theme: github\n\n                # \u5B57\u4F53\u6837\u5F0F\uFF0C\u652F\u6301 css font-family \u503C\n                # \u9ED8\u8BA4\u4E3A default\uFF0C\u5373\u6D4F\u89C8\u5668\u9ED8\u8BA4\u503C\n                set_fontfamily: default\n\n                # \u5B57\u4F53\u5927\u5C0F\uFF0C\u652F\u6301 css font-size \u503C\n                # \u9ED8\u8BA4\u4E3A 62.5%\n                set_fontsize: 62.5%\n\n                # \u5E03\u5C40\u5BBD\u5EA6\uFF0C\u652F\u6301 css margin \u503C\uFF0C\u4F8B\u5982\uFF1A 20px, 80% \u7B49\n                # \u9ED8\u8BA4\u4E3A 20% \u5BBD\u5EA6\n                set_layout: 20%\n\n                # \u662F\u5426\u4E00\u76F4\u663E\u793A\u53F3\u4E0B\u89D2\u7684\u63A7\u5236\u680F\uFF1F\n                # \u9ED8\u8BA4\u4E3A\u4E0D\u663E\u793A\uFF0C\u53D6\u503C\u8303\u56F4 true | false\n                set_controlbar: false\n\n                # \u5F53\u672A\u9002\u914D\u9605\u8BFB\u6A21\u5F0F\u65F6\uFF0C\u662F\u5426\u542F\u7528\u4E34\u65F6\u9605\u8BFB\u6A21\u5F0F\uFF1F\n                # \u9ED8\u8BA4\u4E3A\u542F\u7528\uFF0C\u53D6\u503C\u8303\u56F4 true | false\n                set_highlight: true\n\n                # \u542F\u52A8\u9605\u8BFB\u6A21\u5F0F\u7684\u5FEB\u6377\u952E\n                # \u9ED8\u8BA4\u4E3A A A\n                # \u5FC5\u987B\u6709\u4E24\u4E2A\u503C\uFF0C\u4EC5\u652F\u6301 shift, \u5B57\u6BCD\u548C\u6570\u5B57\uFF0C\u4E2D\u95F4\u5FC5\u987B\u6709\u7A7A\u683C\n                set_shortcuts: A A\n\n                # \u5982\u679C\u5F53\u524D\u9875\u9762\u9002\u914D\u9605\u8BFB\u6A21\u5F0F\uFF0C\u662F\u5426\u81EA\u52A8\u8FDB\u5165\u9605\u8BFB\u6A21\u5F0F\uFF1F\n                # \u9ED8\u8BA4\u4E3A false\uFF0C\u53D6\u503C\u8303\u56F4 true | false\n                set_auto: false\n\n                # \u9ED1\u540D\u5355\uFF0C\u52A0\u5165\u5176\u4E2D\u540E\uFF0C\u4E0D\u4F1A\u81EA\u52A8\u8FDB\u5165\u9605\u8BFB\u6A21\u5F0F\n                # \u6B64\u529F\u80FD\u5728 auto = true \u65F6\u624D\u4F1A\u751F\u6548\n                # \u652F\u6301 minimatch\uFF0C\u57DF\u540D \u548C name\uFF0C\u4F8B\u5982\uFF1A \"v2ex.com\", \"http://www.ifanr.com/**/*\"\n                # \u6BCF\u4E2A\u540D\u5355\u7531\u5C0F\u5199 , \u5206\u9694\n                set_exclusion: \n\n                # \u767D\u540D\u5355\uFF0C\u52A0\u5165\u5176\u4E2D\u540E\uFF0C\u81EA\u52A8\u8FDB\u5165\u9605\u8BFB\u6A21\u5F0F\n                # \u6B64\u529F\u80FD\u5728 auto = true \u65F6\u624D\u4F1A\u751F\u6548\uFF0C\u5E76\u4E0E\u9ED1\u540D\u5355\u4E92\u65A5\n                # \u652F\u6301 minimatch\uFF0C\u57DF\u540D \u548C name\uFF0C\u4F8B\u5982\uFF1A \"v2ex.com\", \"http://www.ifanr.com/**/*\"\n                # \u9ED8\u8BA4\u4E3A\u7A7A\uFF0C\u6BCF\u4E2A\u540D\u5355\u7531\u5C0F\u5199 , \u5206\u9694\n                set_whitelist: \n\n                # \u662F\u5426\u542F\u7528\u589E\u5F3A\u89E3\u6790\u6A21\u5F0F\uFF1F\n                # \u589E\u5F3A\u89E3\u6790\u6A21\u5F0F\u4F1A\u5BF9\u7248\u9762\u91CD\u65B0\u8BBE\u8BA1\uFF0C\u5305\u62EC\uFF1A\u53BB\u9664\u591A\u4F59\u7A7A\u683C\u3001\u4F18\u5316\u7248\u9762\u7ED3\u6784\u7B49\uFF0C\u6B64\u529F\u80FD\u4E3A\u6D4B\u8BD5\u7248\uFF0C\u9047\u5230\u89E3\u6790\u5931\u8D25\u65F6\uFF0C\u8BF7\u5173\u95ED\u6B64\u529F\u80FD\u3002\n                # \u9ED8\u8BA4\u4E3A true\uFF0C\u53D6\u503C\u8303\u56F4 true | false\n                set_cleanup: true\n\n                # \u662F\u5426\u542F\u7528\u7EAF\u7CB9\u6A21\u5F0F\uFF1F\n                # \u6BD4\u3010\u589E\u5F3A\u89E3\u6790\u6A21\u5F0F\u3011\u8FD8\u8981\u5F7B\u5E95\u4F18\u5316\u7248\u672C\uFF0C\u5305\u62EC\uFF1A\u5B57\u5F62\u3001\u989C\u8272\u3001\u5B57\u53F7\u3001\u4EE3\u7801\u6BB5\u7B49\uFF0C\u4E13\u6CBB\u9875\u9762\u53CA\u4E0D\u89C4\u8303\uFF0C\u5982\uFF1A\u5FAE\u4FE1\u8BA2\u9605\u53F7\uFF0CCSDN \u7B49\u3002\n                # \u6B64\u529F\u80FD\u5728 cleanup = true \u65F6\u624D\u4F1A\u751F\u6548\n                # \u9ED8\u8BA4\u4E3A true\uFF0C\u53D6\u503C\u8303\u56F4 true | false\n                set_pure: true\n\n                # \u662F\u5426\u81EA\u52A8\u751F\u6210\u5927\u7EB2\uFF08\u76EE\u5F55\uFF09\uFF1F\n                # \u53EA\u6574\u7406 h1, h2, h3, h4 \u7684\u5185\u5BB9\u4E3A\u5927\u7EB2\n                # \u9ED8\u8BA4\u4E3A true\uFF0C\u53D6\u503C\u8303\u56F4 true | false\n                set_toc: true\n\n                # \u5927\u7EB2\uFF08\u76EE\u5F55\uFF09\u662F\u5426\u5F00\u542F\u300C\u9F20\u6807\u79FB\u52A8\u5230\u5DE6\u4E0A\u89D2\u300D\u81EA\u52A8\u663E\u793A\uFF1F\n                # \u5173\u95ED\u610F\u5473\u7740\u300C\u4E00\u76F4\u663E\u793A\u300D\n                # \u6B64\u529F\u80FD\u5728 toc = true \u65F6\u624D\u4F1A\u751F\u6548\n                # \u9ED8\u8BA4\u4E3A true\uFF0C\u53D6\u503C\u8303\u56F4 true | false\n                set_toc_hide: true\n    ";
  var current_state = "",
      // include: focus, read, option
  simpread = { version: "1.1.2", focus: focus, read: read, option: option },
      org_simp = _extends({}, simpread);

  /****************************
   * Entry
   ****************************/

  // initialize
  version();

  // common mobile
  commonMobile();

  // blacklist
  if (!blacklist()) {
      // add simpread style
      GM_addStyle(notify_style);
      GM_addStyle(main_style);
      GM_addStyle(mntips_style);
      GM_addStyle(option_style);
      GM_addStyle(user_style);
      GM_addStyle(theme_common);

      // add websites and current can'b read mode
      if (GM_getValue("simpread_db")) {
          pr.sites = GM_getValue("simpread_db");
      } else {
          pr.Addsites(JSON.parse(global_sites));
          GM_setValue("simpread_db", pr.sites);
      }
      pr.cleanup = simpread.read.cleanup;
      pr.pure = simpread.read.pure;
      pr.AddPlugin(puplugin.Plugin());
      pr.Getsites();

      // global
      bindShortcuts();
      controlbar();
      autoOpen();

  }

  /****************************
   * Style
   ****************************/

  /**
   * Common Mobile style
   */
  function commonMobile() {
      var css = "\n\n    sr-rd-content {\n        text-align: justify;\n    }\n    \n    sr-rd-content p {\n        -webkit-hyphens: auto;\n        -moz-hyphens: auto;\n        -ms-hyphens: auto;\n        hyphens: auto;\n    }\n\n    /**\n     * iPad pro 12 and below\n     */\n     @media only screen and (max-device-width: 1024px) {\n\n        sr-rd-content img {\n            margin: 0!important;\n            width: 100%!important;\n            background-color: transparent!important;\n            border: 0!important;\n            box-shadow: none!important;\n        }\n\n        fab {\n            opacity: 1!important;\n        }\n    }\n\n    /**\n    * iPhone XS Max and below\n    */\n    @media only screen and (max-device-width: 414px) {\n\n        sr-rd-crlbar.controlbar {\n            z-index: 2147483646!important;\n        }\n\n        dialog-gp {\n            transform: scale(.7);\n            z-index: 2147483647!important;\n        }\n\n        dialog-content .about {\n            width: 100%!important;\n        }\n    }\n    \n    /**\n    * iPhone SE and below\n    */\n    @media only screen and (max-device-width: 320px) {\n    }\n    ";
      $("head").append("<style id=\"sr-common-mobile\">" + css + "</style>");
  }

  /**
   * read Mode Mobile style
   */
  function readModeMobile() {
      var css = "\n\n    /**\n    * iPhone XS Max and below\n    */\n    @media only screen and (max-device-width: 414px) {\n        sr-read {\n            margin: 10px 10%;\n            width: 100%;\n            min-width: initial!important;\n            min-height: initial!important;\n        }\n\n        sr-rd-desc {\n            padding: 15px !important;\n            line-height: 2;\n            border: none;\n        }\n\n        sr-rd-content a, sr-rd-content a:link {\n            font-size: inherit;\n        }\n\n        sr-rd-content li code, sr-rd-content p code {\n            font-size: inherit;\n        }\n\n        sr-rd-footer {\n            margin-top: 20px;\n        }\n\n        sr-blockquote, sr-blockquote * {\n            margin: 5px !important;\n            padding: 5px !important;\n        }\n\n        sr-rd-title, sr-rd-content h1, sr-rd-content h2, sr-rd-content h3, sr-rd-content h4, sr-rd-content h5, sr-rd-content h6 {\n            font-family: PingFang SC, Verdana, Helvetica Neue, Microsoft Yahei, Hiragino Sans GB, Microsoft Sans Serif, WenQuanYi Micro Hei, sans-serif;\n            color: #000;\n            font-weight: 100;\n            line-height: 1.35;\n        }\n\n        sr-rd-content h1, sr-rd-content h2, sr-rd-content h3, sr-rd-content h4, sr-rd-content h5, sr-rd-content h6,\n        sr-rd-content h1 *, sr-rd-content h2 *, sr-rd-content h3 *, sr-rd-content h4 *, sr-rd-content h5 *, sr-rd-content h6 * {\n            margin-top: 1.2em;\n            margin-bottom: 0.6em;\n            font-weight: 100;\n            line-height: 1.35;\n        }\n\n        sr-rd-content ul, sr-rd-content-ul {\n            margin-left: 1.3em!important;\n            list-style: disc;\n        }\n\n        sr-rd-content ol, sr-rd-content-ol {\n            list-style: decimal;\n            margin-left: 1.9em!important;\n        }\n\n        sr-rd-content li ul, sr-rd-content li ol, sr-rd-content-ul ul, sr-rd-content-ul ol, sr-rd-content-ol ul, sr-rd-content-ol ol {\n            margin-bottom: 0.8em;\n            margin-left: 2em!important;;\n        }\n    }\n    ";
      setTimeout(function () {
          return $("head").append("<style id=\"sr-rd-mobile\">" + css + "</style>");
      }, 1000);
  }

  /****************************
   * Method
   ****************************/

  /**
   * Version
   */
  function version() {
      // get and set simpread
      if (GM_getValue("simpread")) {
          simpread = GM_getValue("simpread");
      } else {
          GM_setValue("simpread", simpread);
          GM_setValue("simpread_subver", GM_info.script.version);
          new Notify().Render("简悦 · 轻阅版 版本提示", "\u5B89\u88C5\u5230\u6700\u65B0\u7248 " + GM_info.script.version + "\uFF0C\u8BF7\u770B <a href='https://github.com/Kenshin/simpread-little' target='_blank' >\u8BE6\u7EC6\u8BF4\u660E</a> \u3002");
      }
      // compare
      if (GM_getValue("simpread_subver") != GM_info.script.version) {
          GM_setValue("simpread_subver", GM_info.script.version);
          if (simpread.version != org_simp.version) {
              if (simpread.version == undefined) {
                  simpread = _extends({}, org_simp);
              } else {
                  Object.keys(org_simp).forEach(function (key) {
                      key != "version" && Object.keys(org_simp[key]).forEach(function (value) {
                          if (!simpread[key][value]) {
                              simpread[key][value] = org_simp[key][value];
                          }
                      });
                  });
                  simpread.version = org_simp.version;
              }
              GM_setValue("simpread", simpread);
          }
          new Notify().Render("简悦 · 轻阅版 版本提示", "\u5347\u7EA7\u5230\u6B63\u5F0F\u7248 " + GM_info.script.version + "\uFF0C\u8BF7\u770B <a href='http://ksria.com/simpread/changelog.html#us_" + GM_info.script.version + "' target='_blank' >\u66F4\u65B0\u8BF4\u660E</a> \u3002");
      }
  }

  /**
   * Black list
   */
  function blacklist() {
      var is_blacklist = false;
      var _iteratorNormalCompletion = true;
      var _didIteratorError = false;
      var _iteratorError = undefined;

      try {
          for (var _iterator = simpread.option.blacklist[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
              var item = _step.value;

              if (!item.startsWith("http")) {
                  if (location.hostname.includes(item)) {
                      is_blacklist = true;
                      break;
                  }
              } else {
                  if (location.href == item) {
                      is_blacklist = true;
                      break;
                  }
              }
          }
      } catch (err) {
          _didIteratorError = true;
          _iteratorError = err;
      } finally {
          try {
              if (!_iteratorNormalCompletion && _iterator.return) {
                  _iterator.return();
              }
          } finally {
              if (_didIteratorError) {
                  throw _iteratorError;
              }
          }
      }

      return is_blacklist;
  }

  /**
   * Keyboard event handler
   */
  function bindShortcuts() {
      Mousetrap.bind([simpread.focus.shortcuts.toLowerCase()], function () {
          return entryMode("focus");
      });
      Mousetrap.bind([simpread.read.shortcuts.toLowerCase()], function () {
          return entryMode("read");
      });
      Mousetrap.bind("esc", function (event, combo) {
          if (combo == "esc" && simpread.option.esc) {
              if ($(".simpread-read-root").length > 0) $(".simpread-read-root sr-rd-crlbar fab")[1].click();
              if ($(".simpread-focus-root").length > 0) $("sr-rd-crlbar fab.crlbar-close")[0].click();
          }
      });
  }

  /**
   * Auto open read mode
   */
  function autoOpen() {
      var exclusion = function exclusion(minimatch, data) {
          var url = window.location.origin + window.location.pathname;
          return data.findIndex(function (item) {
              item = item.trim();
              return item.startsWith("http") ? minimatch(url, item) : item == pr.current.site.name;
          }) == -1 ? true : false;
      },
          whitelist = function whitelist(minimatch, data) {
          var url = window.location.origin + window.location.pathname;
          return data.findIndex(function (item) {
              item = item.trim();
              return item.startsWith("http") ? minimatch(url, item) : item == pr.current.site.name;
          }) != -1 ? true : false;
      };
      if (window.location.href.includes("simpread_mode=read") || simpread.read.auto && exclusion(puplugin.Plugin("minimatch"), simpread.read.exclusion) || !simpread.read.auto && whitelist(puplugin.Plugin("minimatch"), simpread.read.whitelist)) {
          switch (pr.current.site.name) {
              case "my.oschina.net":
              case "36kr.com":
              case "chiphell.com":
              case "question.zhihu.com":
                  $(function () {
                      return readMode();
                  });
                  break;
              case "post.juejin.im":
              case "entry.juejin.im":
                  setTimeout(function () {
                      return readMode();
                  }, 2500);
                  break;
              case "kancloud.cn":
              case "sspai.com":
                  setTimeout(function () {
                      return readMode();
                  }, 1000);
                  break;
              default:
                  if (pr.state == "adapter") readMode();
                  break;
          }
      }
  }

  /**
   * Control bar
   */
  function controlbar() {
      $("body").append('<sr-rd-crlbar class="controlbar"><fab class="about"></fab><fab class="setting"></fab><fab style="font-size:12px!important;">简 悦</fab></sr-rd-crlbar>');
      $("sr-rd-crlbar").css("opacity", 1);
      if (pr.state == "none") $("sr-rd-crlbar fab:not(.setting,.about)").addClass("not-adapter");
      setTimeout(function () {
          $("sr-rd-crlbar").removeAttr("style");
          if (pr.state == "none" && simpread.option.trigger_hiden == true) $("sr-rd-crlbar").css({ display: "none" });
      }, 1000 * 2);
      $("sr-rd-crlbar fab:not(.setting,.about)").click(function (event) {
          if ($(event.target).hasClass("crlbar-close")) {
              $(".simpread-focus-root").trigger("click", "okay");
              $(event.target).removeClass("crlbar-close").text("简 悦");
          } else entryMode(simpread.option.trigger);
          event.preventDefault();
          return false;
      });
      $("sr-rd-crlbar fab:not(.setting,.about)").mouseover(function () {
          if ($(".simpread-focus-root").length == 0) {
              $("sr-rd-crlbar fab.setting").addClass("show");
              $("sr-rd-crlbar fab.about").addClass("show");
          }
          $("sr-rd-crlbar").one("mouseleave", function () {
              $("sr-rd-crlbar fab.setting").removeClass("show");
              $("sr-rd-crlbar fab.about").removeClass("show");
          });
      });
      $("sr-rd-crlbar fab.setting").click(function () {
          optionMode();
      });
      $("sr-rd-crlbar fab.about").click(function () {
          aboutMode();
      });
  }
  /**
   * Enter Mode
   * 
   * @param {string} include: focus, read
   */
  function entryMode(type) {
      try {
          type = type == "focus" ? "focus" : "read";
          if (["none"].includes(pr.state)) {
              if (simpread[type].highlight == true) tempMode(type);else new Notify().Render("\u5F53\u524D\u672A\u542F\u7528 <a href='http://ksria.com/simpread/docs/#/%E4%B8%B4%E6%97%B6%E9%98%85%E8%AF%BB%E6%A8%A1%E5%BC%8F' target='_blank' >\u4E34\u65F6\u9605\u8BFB\u6A21\u5F0F</a>\uFF0C\u5E76\u5F53\u524D\u7AD9\u70B9\u4E5F\u672A\u9002\u914D\uFF0C\u5982\u9700\u8981\u9002\u914D\u8BF7\u63D0\u4EA4\u5230 <a href=\"https://github.com/Kenshin/simpread/issues/new\" target=\"_blank\">\u6B64\u9875\u9762</a>");
          } else type == "focus" ? focusMode() : readMode();
      } catch (err) {
          new Notify().Render(2, "当前页面无法使用阅读模式。");
      }
  }

  /**
   * Focus mode
   * 
   * @param {dom} html element
   */
  function focusMode() {
      var element = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : undefined;

      var $focus = element ? $(element) : pr.Include(),
          tag = void 0,
          $parent = void 0;
      var focuscls = "simpread-focus-highlight",
          focusstyle = "z-index: 2147483646; overflow: visible; position: relative;",
          maskcls = "simpread-focus-mask",
          maskstyle = "z-index: auto; opacity: 1; overflow: visible; transform: none; animation: none; position: relative;",
          bgcls = "simpread-focus-root",
          bgtmpl = "<div class=" + bgcls + "></div>",
          bgclsjq = "." + bgcls,
          includeStyle = function includeStyle($target, style, cls, type) {
          $target.each(function (idx, ele) {
              var bakstyle = void 0,
                  selector = $(ele);
              if (type === "add") {
                  bakstyle = selector.attr("style") == undefined ? "" : selector.attr("style");
                  selector.attr("style", bakstyle + style).addClass(cls);
              } else if (type === "delete") {
                  bakstyle = selector.attr("style");
                  bakstyle = bakstyle.replace(style, "");
                  selector.attr("style", bakstyle).removeClass(cls);
              }
          });
      },
          excludeStyle = function excludeStyle($target, type) {
          var tags = pr.Exclude($target);
          if (type == "delete") $target.find(tags).hide();else if (type == "add") $target.find(tags).show();
      };

      if (current_state == "focus") {
          new Notify().Render("请误重复进入。");
          return;
      } else if (current_state != "") {
          new Notify().Render("请先退出当前模式。");
          return;
      } else current_state = "focus";

      // set include style
      includeStyle($focus, focusstyle, focuscls, "add");

      // set exclude style
      excludeStyle($focus, "delete");

      // add simpread-focus-mask
      $parent = $focus.parent();
      tag = $parent[0].tagName;
      while (tag.toLowerCase() != "body") {
          includeStyle($parent, maskstyle, maskcls, "add");
          $parent = $parent.parent();
          tag = $parent[0].tagName;
      }

      // add background
      $("body").append(bgtmpl);

      // add background color
      $(bgclsjq).css({ "background-color": style.BgColor(simpread.focus.bgcolor, simpread.focus.opacity) }).animate({ opacity: 1 });

      // click mask remove it
      $(bgclsjq).on("click", function (event, data) {
          if (!simpread.focus.mask && !data) return;
          $(bgclsjq).animate({ opacity: 0 }, {
              complete: function complete() {
                  current_state = "";
                  includeStyle($focus, focusstyle, focuscls, "delete");
                  excludeStyle($focus, "add");
                  $(bgclsjq).remove();
                  $(bgclsjq).off("click");
                  $("sr-rd-crlbar fab:not(.setting,.about)").removeClass("crlbar-close").text("简 悦");
              }
          });

          // remove simpread-focus-mask style
          $parent = $focus.parent();
          tag = $parent[0].tagName;
          while (tag && tag.toLowerCase() != "body") {
              includeStyle($parent, maskstyle, maskcls, "delete");
              $parent = $parent.parent();
              tag = $parent[0].tagName;
          }
      });

      // set focus controlbar
      $("sr-rd-crlbar fab:not(.setting,.about)").addClass("crlbar-close").text("");
  }

  /**
   * Read mode
   */
  function readMode() {
      var $root = $("html"),
          bgtmpl = "<div class=\"simpread-read-root\">\n                        <sr-read>\n                            <sr-rd-title></sr-rd-title>\n                            <sr-rd-desc></sr-rd-desc>\n                            <sr-rd-content></sr-rd-content>\n                            <sr-page></sr-page>\n                            <sr-rd-footer>\n                                <sr-rd-footer-group>\n                                    <sr-rd-footer-line></sr-rd-footer-line>\n                                    <sr-rd-footer-text>\u5168\u6587\u5B8C</sr-rd-footer-text>\n                                    <sr-rd-footer-line></sr-rd-footer-line>\n                                </sr-rd-footer-group>\n                                <sr-rd-footer-copywrite>\n                                    <div>\u672C\u6587\u7531 <a href=\"http://ksria.com/simpread\" target=\"_blank\">\u7B80\u60A6 SimpRead</a> \u4F18\u5316\uFF0C\u7528\u4EE5\u63D0\u5347\u9605\u8BFB\u4F53\u9A8C</div>\n                                    <div class=\"second\">\u4F7F\u7528\u4E86 <abbr>\u5168\u65B0\u7684\u7B80\u60A6\u8BCD\u6CD5\u5206\u6790\u5F15\u64CE<sup>beta</sup></abbr>\uFF0C<a target=\"_blank\" href=\"http://ksria.com/simpread/docs/#/\u8BCD\u6CD5\u5206\u6790\u5F15\u64CE\">\u70B9\u51FB\u67E5\u770B</a>\u8BE6\u7EC6\u8BF4\u660E</div>\n                                    <div class=\"third\">\n                                        <a class=\"sr-icon good sr-top\" data-sr-mini-tooltip=\"\u89C9\u5F97\u4E0D\u9519\uFF1F\u8BF7\u5E2E\u5FD9\u6295\u7968 \uD83D\uDE04\" data-position=\"up\" target=\"_blank\" href=\"https://chrome.google.com/webstore/detail/%E7%AE%80%E6%82%A6-simpread/ijllcpnolfcooahcekpamkbidhejabll/reviews\">\n                                            <svg t=\"1556354786433\" viewBox=\"0 0 1024 1024\" version=\"1.1\" width=\"33\" height=\"33\"><defs><style type=\"text/css\"></style></defs><path d=\"M859.8 191.2c-80.8-84.2-212-84.2-292.8 0L512 248.2l-55-57.2c-81-84.2-212-84.2-292.8 0-91 94.6-91 248.2 0 342.8L512 896l347.8-362C950.8 439.4 950.8 285.8 859.8 191.2z\" p-id=\"6225\" fill=\"#8C8C8C\"></path></svg>\n                                        </a>\n                                        <a class=\"sr-icon bad sr-top\" data-sr-mini-tooltip=\"\u6709\u5F85\u6539\u8FDB\uFF0C\u8BF7\u5E2E\u5FD9\u5410\u69FD \uD83D\uDE04\" data-position=\"up\" target=\"_blank\" href=\"https://wj.qq.com/s2/3611463/7260/\">\n                                            <svg t=\"1556354650943\" viewBox=\"0 0 1024 1024\" version=\"1.1\" p-id=\"5899\" width=\"33\" height=\"33\"><defs><style type=\"text/css\"></style></defs><path d=\"M458 576c2-36 0-76 16-110 4-10 2-20 2-30-8-42-28-80-30-120 0-2.78 2.008-9.542 2.01-12.314-6.432 4.468-15.214 8.048-22.01 10.314-40 12-35.02 5.146-69.02 27.146l-23.866 14.456c32.686-35.878 77.056-49.562 113.05-77.428 0.388-30.876 1.716-61.354 6.274-91.68C371.22 106.992 243.57 108.536 164.246 191.14c-90.994 94.688-90.994 248.202 0 342.89l305.698 318.192c-0.17-21.312-0.886-42.352-3.944-62.222C454 718 458 648 458 576z\" p-id=\"5900\" fill=\"#8C8C8C\"></path><path d=\"M644 602c-22-52-66-88-126-100-1.7 0-3.758-1.086-5.872-2.638-0.046 0.214-0.082 0.426-0.128 0.638-22 96-46 188-42 284 0 24.454 7.966 50.234 7.666 76.262L512 896l208-216.5C690.306 658.542 660.856 637.242 644 602z\" p-id=\"5901\" fill=\"#8C8C8C\"></path><path d=\"M859.748 191.14c-80.852-84.188-211.978-84.188-292.816 0L528 230.806c0.15 26.35 0.426 52.404-6 77.194-4 20-38 38-32 62 6.006 26.426 16.332 51.41 21.464 77.118C542.028 464.168 569.542 485.792 594 512c45.602 53.532 75.494 114.918 130.566 162.742l135.182-140.71C950.75 439.342 950.75 285.828 859.748 191.14z\" p-id=\"5902\" fill=\"#8C8C8C\"></path></svg>\n                                        </a>\n                                    </div>\n                                </sr-rd-footer-copywrite>\n                            </sr-rd-footer>\n                            <sr-rd-crlbar style=\"position:fixed;bottom:0;right:0;width:100px;height:200px;\" class=" + (simpread.read.controlbar == true ? "" : "controlbar") + ">\n                                <fab class=\"setting\"></fab>\n                                <fab class=\"crlbar-close\"></fab>\n                            </sr-rd-crlbar>\n                        </sr-read>\n                    </div>",
          multiple = function multiple(include, avatar) {
          var contents = [],
              names = avatar[0].name,
              urls = avatar[1].url;
          include.each(function (idx, item) {
              var art = {};
              art.name = $(names[idx]).text();
              art.url = $(urls[idx]).attr("src");
              art.content = $(item).html();
              !art.url && (art.url = default_src);
              contents.push(art);
          });
          var child = contents.map(function (item) {
              return "<sr-rd-mult>\n                            <sr-rd-mult-avatar>\n                                <div class=\"sr-rd-content-nobeautify\"><img src=" + item.url + " /></div>\n                                <span>" + item.name + "</span>\n                            </sr-rd-mult-avatar>\n                            <sr-rd-mult-content>" + item.content + "</sr-rd-mult-content>\n                    </sr-rd-mult>";
          });
          $("sr-rd-content").html(child);
      },
          paging = function paging(page) {
          var prev = page[0].prev,
              next = page[1].next,
              btn_next = mduikit.Button("btn-next", "后一页 →", { href: next == undefined ? "javascript:;" : next, disable: next == undefined ? true : false, color: "#fff", bgColor: "#1976D2" }),
              btn_prev = mduikit.Button("btn-prev", "← 前一页", { href: prev == undefined ? "javascript:;" : prev, disable: prev == undefined ? true : false, color: "#fff", bgColor: "#1976D2" });
          if (!prev && !next) $("sr-page").remove();else $("sr-page").html(btn_prev + btn_next);
      },
          special = function special() {
          if (pr.current.site.name == "qdaily.com") {
              new Notify().Render("简悦 · 轻阅版 并不支持此站的适配,如需请使用完整版。");
              return true;
          }
          if (pr.html.include.includes && pr.html.include.includes("sr-rd-content-error")) {
              //new Notify().Render( `当前页面结构改变导致不匹配阅读模式,请报告 <a href="https://github.com/Kenshin/simpread/issues/new" target="_blank">此页面</a>` );
              //simpread.read.highlight  == true && tempMode( "read"  );
              //return true;
              console.warn('=== Adapter failed call Readability View ===');
              pr.Readability();
              pr.ReadMode();
              return false;
          }
      };

      if (pr.isMathJax() && pr.state == "temp") {
          console.warn('=== MathJax Mode ===');
          var dom = pr.MathJaxMode();
          if (typeof dom == "undefined") {
              new Notify().Render("智能感知失败,请移动鼠标框选。");
              highlight().done(function (dom) {
                  storage.pr.TempMode("read", dom);
                  Render(false);
              });
          } else if (typeof dom == "string") {
              var html = pr.GetDom(dom, "html");
              pr.Newsite("read", html);
          } else {
              pr.TempMode("read", dom[0]);
          }
      }
      pr.ReadMode();

      if (special()) return;

      if (current_state == "read") {
          new Notify().Render("请误重复进入。");
          return;
      } else if (current_state != "") {
          new Notify().Render("请先退出当前模式。");
          return;
      } else current_state = "read";

      $("body").addClass("simpread-hidden");
      $root.addClass("simpread-font").addClass("simpread-theme-root").append(bgtmpl);

      $(".simpread-read-root").addClass("simpread-theme-root").animate({ opacity: 1 }, { delay: 100 }).addClass("simpread-read-root-show");

      $("sr-rd-title").html(pr.html.title);
      if (pr.html.desc != "") $("sr-rd-desc").html(pr.html.desc);else $("sr-rd-desc").remove();
      if (pr.html.avatar) multiple(pr.html.include, pr.html.avatar);else $("sr-rd-content").html(pr.html.include);
      if (pr.html.paging) paging(pr.html.paging);else $("sr-page").remove();

      $("sr-rd-content").find(pr.Exclude($("sr-rd-content"))).remove();
      pr.Beautify($("sr-rd-content"));
      pr.Format("simpread-read-root");

      GM_addStyle(theme["theme_" + simpread.read.theme]);
      style.FontFamily(simpread.read.fontfamily);
      style.FontSize(simpread.read.fontsize);
      style.Layout(simpread.read.layout);

      pr.pure && codehighlight();
      simpread.read.toc && toc();

      // add mobile adpater
      readModeMobile();

      // exit
      $(".simpread-read-root sr-rd-crlbar fab:not(.setting)").one("click", function (event) {
          $(".simpread-read-root").animate({ opacity: 0 }, {
              delay: 100,
              complete: function complete() {
                  current_state = "";
                  $root.removeClass("simpread-theme-root").removeClass("simpread-font");
                  if ($root.attr("style")) $root.attr("style", $root.attr("style").replace("font-size: 62.5%!important", ""));
                  $("body").removeClass("simpread-hidden");
                  $(".simpread-read-root").remove();
                  $("head #sr-rd-mobile").remove();
              }
          }).addClass("simpread-read-root-hide");
      });
      $(".simpread-read-root sr-rd-crlbar fab:not(.setting)").mouseover(function () {
          $(".simpread-read-root sr-rd-crlbar fab.setting").addClass("show");
      });
      $(".simpread-read-root sr-rd-crlbar").mouseleave(function () {
          $("sr-rd-crlbar fab.setting").removeClass("show");
      });
      $(".simpread-read-root sr-rd-crlbar fab.setting").click(function () {
          wheelmenu();
      });
  }
  /**
   * Temp Read mode
   * 
   * @param {string} include: focus, read
   */
  function tempMode() {
      var mode = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : "read";

      new Notify().Render("当前并未适配阅读模式,请移动鼠标手动生成 <a href='http://ksria.com/simpread/docs/#/%E4%B8%B4%E6%97%B6%E9%98%85%E8%AF%BB%E6%A8%A1%E5%BC%8F' target='_blank' >临时阅读模式</a>。");
      highlight().done(function (dom) {
          if (mode == "read") {
              pr.TempMode(mode, dom.outerHTML);
              readMode();
          } else focusMode(dom);
      });
  }

  /**
   * Highlight
   * 
   * @return {promise} promise
   */
  function highlight() {
      var highlight_class = "simpread-highlight-selector";
      var $prev = void 0;
      var dtd = $.Deferred(),
          mousemoveEvent = function mousemoveEvent(event) {
          if (!$prev) {
              $(event.target).addClass(highlight_class);
          } else {
              $prev.removeClass(highlight_class);
              $(event.target).addClass(highlight_class);
          }
          $prev = $(event.target);
      };
      $("body").one("click", function (event) {
          if (!$prev) return;
          $(event.target).removeClass(highlight_class);
          $("body").off("mousemove", mousemoveEvent);
          $prev = undefined;
          dtd.resolve(event.target);
      });
      $("body").one("keydown", function (event) {
          if (event.keyCode == 27 && $prev) {
              $(event.target).find("." + highlight_class).removeClass(highlight_class);
              $("body").off("mousemove", mousemoveEvent);
              $prev = undefined;
          }
      });
      $("body").on("mousemove", mousemoveEvent);
      return dtd;
  }

  /**
   * Code highlight
   */
  function codehighlight() {
      $("head").append('<link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/highlight.js/9.15.6/styles/default.min.css">');
      $("head").append('<style>.hljs{background:transparent!important;}</style>');
      $("sr-rd-content").find('pre').map(function (idx, item) {
          hljs.highlightBlock(item);
      });
  }

  /**
   * Wheel menu buttons
   */
  function wheelmenu() {
      if ($(".sr-rd-trigger").length > 0) return;
      var menu = new BloomingMenu({
          startAngle: -180,
          endAngle: 0,
          radius: 120,
          itemsNum: 7,
          itemAnimationDelay: 0,
          isAutoClose: false
      });
      menu.render();
      menu.open();
      menu.props.elements.items.forEach(function (item, index) {
          item.addEventListener('click', function () {
              switch (index) {
                  case 0:
                  case 1:
                      var size = parseFloat(simpread.read.fontsize) + (index == 0 ? 3 : -3);
                      simpread.read.fontsize = size + "%";
                      style.FontSize(simpread.read.fontsize);
                      GM_setValue("simpread", simpread);
                      break;
                  case 2:
                  case 3:
                      var layout = parseFloat(simpread.read.layout) + (index == 3 ? 3 : -3);
                      simpread.read.layout = layout + "%";
                      style.Layout(simpread.read.layout);
                      GM_setValue("simpread", simpread);
                      break;
                  case 4:
                  case 5:
                      var arr = Object.keys(theme),
                          len = arr.length;
                      var idx = arr.indexOf("theme_" + simpread.read.theme) + +(index == 4 ? 1 : -1);
                      if (idx == len) {
                          idx = 0;
                      } else if (idx == -1) {
                          idx = len - 1;
                      }
                      // remove old theme
                      $("head").find("style").map(function (index, item) {
                          var $target = $(item),
                              css = $target.text();
                          if (css.startsWith("sr-rd-theme-" + simpread.read.theme)) {
                              $target.remove();
                          }
                      });
                      // add new theme
                      simpread.read.theme = arr[idx].replace("theme_", "");
                      GM_setValue("simpread", simpread);
                      GM_addStyle(theme["theme_" + simpread.read.theme]);
                      break;
                  case 6:
                      menu.remove();
                      $(".sr-rd-trigger").remove();
                      $("head #blooming-menu__root").remove();
                      break;
              }
          });
      });
      var css = "\n        .sr-rd-trigger {\n            position: fixed;\n            right: 50%;\n            bottom: 35px;\n        }\n        .blooming-menu__container {\n            transition: all 1s cubic-bezier(.23,1,.32,1) .1s!important;\n        }\n        .blooming-menu__main {\n            background-color: rgba(244, 67, 54, 1);\n        }\n        .blooming-menu__item-btn-wrapper {\n            background-color: #03a9f4!important;\n            transition: all 1000ms cubic-bezier(0.23, 1, 0.32, 1) 0ms;\n        }\n        .blooming-menu__item-btn-wrapper:active {\n            background-color: #0D47A1!important;\n        }\n        .blooming-menu__main.is-active {\n            transform: rotate(0);\n            -webkit-transform: rotate(0);\n        }\n        .blooming-menu__item:nth-of-type(3) button,\n        .blooming-menu__item:nth-of-type(4) button {\n            transform: rotate(90deg);\n        }\n        .blooming-menu__item:nth-of-type(6) button {\n            transform: rotate(180deg);\n        }\n    ";
      $("head").append("<style id=\"blooming-menu__root\">" + css + "</style>");
      setTimeout(function () {
          $(".simpread-read-root").append("<div class=\"sr-rd-trigger\"></div>");
          $(".sr-rd-trigger").append($(".blooming-menu__container"));
          $(".simpread-read-root .blooming-menu__main-content").html("<svg t=\"1557891708974\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"5907\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\"><defs><style type=\"text/css\"></style></defs><path d=\"M152.365633 555.145394a154.587346 154.587346 0 0 0 39.497121 66.761107C221.21131 651.245914 260.251289 667.428762 301.759838 667.428762c41.508549 0 80.548528-16.164563 109.897084-45.531404A154.660489 154.660489 0 0 0 450.40433 557.714536H978.330904c25.206844 0 45.714261-20.470846 45.714262-45.714262 0-25.197701-20.470846-45.714261-45.714262-45.714261H450.395187a154.669631 154.669631 0 0 0-38.729122-64.182823A154.413632 154.413632 0 0 0 301.759838 356.571786c-41.508549 0-80.548528 16.164563-109.897084 45.531404a154.587346 154.587346 0 0 0-39.497121 66.761107A45.48569 45.48569 0 0 0 137.234212 466.286013H45.714261a45.723404 45.723404 0 0 0 0 91.428523h91.519951c5.302854 0 10.395423-0.905142 15.131421-2.569142z m719.359614 270.280998a154.596489 154.596489 0 0 0-39.497121-66.761107A154.413632 154.413632 0 0 0 722.331042 713.143024c-41.508549 0-80.548528 16.164563-109.897084 45.531404A154.660489 154.660489 0 0 0 573.68655 822.857251H45.759976c-25.206844 0-45.714261 20.470846-45.714262 45.714261 0 25.197701 20.470846 45.714261 45.714262 45.714261h527.935717a154.660489 154.660489 0 0 0 38.729122 64.182823C641.782513 1007.84458 680.822492 1024 722.331042 1024c41.508549 0 80.548528-16.164563 109.897084-45.531404a154.587346 154.587346 0 0 0 39.497121-66.761107 45.48569 45.48569 0 0 0 15.131421 2.578284h91.519951a45.723404 45.723404 0 0 0 0-91.428522h-91.519951c-5.302854 0-10.395423 0.905142-15.131421 2.569141z m0-713.142475a154.596489 154.596489 0 0 0-39.497121-66.761107A154.413632 154.413632 0 0 0 722.331042 0.000549c-41.508549 0-80.548528 16.164563-109.897084 45.531404A154.660489 154.660489 0 0 0 573.68655 109.714776H45.759976c-25.206844 0-45.714261 20.470846-45.714262 45.714261 0 25.197701 20.470846 45.714261 45.714262 45.714261h527.935717a154.660489 154.660489 0 0 0 38.729122 64.182823C641.782513 294.702105 680.822492 310.857525 722.331042 310.857525c41.508549 0 80.548528-16.164563 109.897084-45.531404a154.587346 154.587346 0 0 0 39.497121-66.761107 45.48569 45.48569 0 0 0 15.131421 2.578284h91.519951a45.723404 45.723404 0 0 0 0-91.428522h-91.519951c-5.302854 0-10.395423 0.905142-15.131421 2.569141zM347.016957 557.257393A63.579395 63.579395 0 0 1 301.759838 576.00024a63.579395 63.579395 0 0 1-45.257118-18.742847A63.579395 63.579395 0 0 1 237.759873 512.000274c0-17.097134 6.655996-33.170268 18.742847-45.257118A63.579395 63.579395 0 0 1 301.759838 448.000309c17.097134 0 33.170268 6.655996 45.257119 18.742847A63.579395 63.579395 0 0 1 365.759804 512.000274c0 17.097134-6.655996 33.170268-18.742847 45.257119z m420.571203 356.571237A63.579395 63.579395 0 0 1 722.331042 932.571478a63.579395 63.579395 0 0 1-45.257119-18.742848A63.579395 63.579395 0 0 1 658.331076 868.571512c0-17.097134 6.655996-33.170268 18.742847-45.257119A63.579395 63.579395 0 0 1 722.331042 804.571546c17.097134 0 33.170268 6.655996 45.257118 18.742847A63.579395 63.579395 0 0 1 786.331007 868.571512c0 17.097134-6.655996 33.170268-18.742847 45.257118z m0-713.142475A63.579395 63.579395 0 0 1 722.331042 219.429002a63.579395 63.579395 0 0 1-45.257119-18.742847A63.579395 63.579395 0 0 1 658.331076 155.429037c0-17.097134 6.655996-33.170268 18.742847-45.257119A63.579395 63.579395 0 0 1 722.331042 91.429071c17.097134 0 33.170268 6.655996 45.257118 18.742847A63.579395 63.579395 0 0 1 786.331007 155.429037c0 17.097134-6.655996 33.170268-18.742847 45.257118z\" fill=\"#ffffff\" p-id=\"5908\"></path></svg>");
          $($(".simpread-read-root .blooming-menu__item-btn")[0]).html("<svg t=\"1557891878314\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"7413\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\"><defs><style type=\"text/css\"></style></defs><path d=\"M661.333333 938.666667a21.333333 21.333333 0 0 1-19.886666-13.606667L547.186667 682.666667H178.146667l-94.266667 242.4a21.333333 21.333333 0 1 1-39.76-15.466667l298.666667-768a21.333333 21.333333 0 0 1 39.76 0l298.666666 768A21.333333 21.333333 0 0 1 661.333333 938.666667zM194.74 640h335.853333L362.666667 208.193333zM832 384a21.333333 21.333333 0 0 1-21.333333-21.333333V256h-106.666667a21.333333 21.333333 0 0 1 0-42.666667h106.666667V106.666667a21.333333 21.333333 0 0 1 42.666666 0v106.666666h106.666667a21.333333 21.333333 0 0 1 0 42.666667h-106.666667v106.666667a21.333333 21.333333 0 0 1-21.333333 21.333333z\" fill=\"#ffffff\" p-id=\"7414\"></path></svg>");
          $($(".simpread-read-root .blooming-menu__item-btn")[1]).html("<svg t=\"1557891916958\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"7691\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\"><defs><style type=\"text/css\"></style></defs><path d=\"M661.333333 938.666667a21.333333 21.333333 0 0 1-19.886666-13.606667L547.186667 682.666667H178.146667l-94.266667 242.4a21.333333 21.333333 0 1 1-39.76-15.466667l298.666667-768a21.333333 21.333333 0 0 1 39.76 0l298.666666 768A21.333333 21.333333 0 0 1 661.333333 938.666667zM194.74 640h335.853333L362.666667 208.193333zM960 256h-256a21.333333 21.333333 0 0 1 0-42.666667h256a21.333333 21.333333 0 0 1 0 42.666667z\" fill=\"#ffffff\" p-id=\"7692\"></path></svg>");
          $($(".simpread-read-root .blooming-menu__item-btn")[2]).html("<svg t=\"1557892103159\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"825\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\"><defs><style type=\"text/css\"></style></defs><path d=\"M128 128h768v85.333333H128V128z m213.333333 341.333333v426.666667H256V469.333333H128l170.666667-170.666666 170.666666 170.666666H341.333333z m426.666667 0v426.666667h-85.333333V469.333333h-128l170.666666-170.666666 170.666667 170.666666h-128z\" p-id=\"826\" fill=\"#ffffff\"></path></svg>");
          $($(".simpread-read-root .blooming-menu__item-btn")[3]).html("<svg t=\"1557892186358\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"10987\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\"><defs><style type=\"text/css\"></style></defs><path d=\"M128 810.666667h768v85.333333H128v-85.333333z m213.333333-256h128l-170.666666 170.666666-170.666667-170.666666h128V128h85.333333v426.666667z m426.666667 0h128l-170.666667 170.666666-170.666666-170.666666h128V128h85.333333v426.666667z\" p-id=\"10988\" fill=\"#ffffff\"></path></svg>");
          $($(".simpread-read-root .blooming-menu__item-btn")[4]).html("<svg t=\"1557893778057\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"12269\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\"><defs><style type=\"text/css\"></style></defs><path d=\"M249.984 841.984l0-269.994667 148.010667 356.010667-61.994667 0q-34.005333 0-59.989333-25.984t-25.984-59.989333zM336 374.016q18.005333 0 29.994667-13.013333t11.989333-31.018667-11.989333-29.994667-29.994667-11.989333-29.994667 11.989333-11.989333 29.994667 11.989333 31.018667 29.994667 13.013333zM939.989333 680.021333q13.994667 32 0 64.981333t-45.994667 47.018667l-313.984 130.005333q-16 6.016-34.005333 6.016-56.021333 0-77.994667-52.010667l-212.010667-512q-6.016-18.005333-6.016-34.005333 0-54.016 52.010667-75.989333l315.989333-130.005333q18.005333-6.016 34.005333-6.016 54.016 0 75.989333 52.010667zM107.989333 838.016q-32-13.994667-45.994667-45.994667t0-64l104.021333-249.984 0 384z\" p-id=\"12270\" fill=\"#ffffff\"></path></svg>");
          $($(".simpread-read-root .blooming-menu__item-btn")[5]).html("<svg t=\"1557893778057\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"12269\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\"><defs><style type=\"text/css\"></style></defs><path d=\"M249.984 841.984l0-269.994667 148.010667 356.010667-61.994667 0q-34.005333 0-59.989333-25.984t-25.984-59.989333zM336 374.016q18.005333 0 29.994667-13.013333t11.989333-31.018667-11.989333-29.994667-29.994667-11.989333-29.994667 11.989333-11.989333 29.994667 11.989333 31.018667 29.994667 13.013333zM939.989333 680.021333q13.994667 32 0 64.981333t-45.994667 47.018667l-313.984 130.005333q-16 6.016-34.005333 6.016-56.021333 0-77.994667-52.010667l-212.010667-512q-6.016-18.005333-6.016-34.005333 0-54.016 52.010667-75.989333l315.989333-130.005333q18.005333-6.016 34.005333-6.016 54.016 0 75.989333 52.010667zM107.989333 838.016q-32-13.994667-45.994667-45.994667t0-64l104.021333-249.984 0 384z\" p-id=\"12270\" fill=\"#ffffff\"></path></svg>");
          $($(".simpread-read-root .blooming-menu__item-btn")[6]).html("<svg t=\"1557893821906\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"13152\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"20\" height=\"20\"><defs><style type=\"text/css\"></style></defs><path d=\"M851.428571 755.428571q0 22.857143-16 38.857143l-77.714285 77.714286q-16 16-38.857143 16t-38.857143-16l-168-168-168 168q-16 16-38.857143 16t-38.857143-16l-77.714285-77.714286q-16-16-16-38.857143t16-38.857142l168-168-168-168q-16-16-16-38.857143t16-38.857143l77.714285-77.714286q16-16 38.857143-16t38.857143 16l168 168 168-168q16-16 38.857143-16t38.857143 16l77.714285 77.714286q16 16 16 38.857143t-16 38.857143l-168 168 168 168q16 16 16 38.857142z\" p-id=\"13153\" fill=\"#ffffff\"></path></svg>");
          $("body").find(".blooming-menu__container").remove();
      }, 1000);

      var preScroll = 0;
      $(document).scroll(function () {
          if ($(document).scrollTop() > preScroll) {
              $(".blooming-menu__container").css({ transform: 'translate(-50%, 20%)', opacity: 0.5 });
              menu.close();
          } else {
              $(".blooming-menu__container").css({ transform: 'translate(-50%, -50%)', opacity: 1 });
          }
          preScroll = $(document).scrollTop();
      });
  }

  /**
   * toc
   */
  function toc() {
      var table = [],
          cls = simpread.read.toc_hide ? "toc-bg-hidden" : "";
      $("sr-read").find("h1, h2, h3, h4").map(function (idx, item) {
          var $item = $(item),
              tag = $item[0].tagName.toLowerCase(),
              value = $item.text();
          var id = $item.attr("id");
          id = id == undefined ? "sr-toc-" + idx : id + "-" + idx;
          $item.attr("id", id);
          value && table.push({
              level: "toc-level-" + tag,
              id: id,
              value: value
          });
      });
      var tmpl = "";
      table.forEach(function (item, idx) {
          tmpl += "<outline className=" + item.level + ">\n                    <active></active>\n                    <a class=" + ("toc-outline-theme-" + simpread.read.theme) + " href=" + ("#" + item.id) + " >" + item.value + "</a>\n                </outline>";
      });
      $("sr-read").append("<toc-bg class=" + cls + "><toc class=\"simpread-font simpread-theme-root\">" + tmpl + "</toc></tocbg>");
      var is_click = false;
      $("sr-read toc outline a").on("click", function (event) {
          is_click = true;
          var $target = $(event.target).parent();
          $target.parent().find("active").removeClass("toc-outline-active");
          $target.find("active").addClass("toc-outline-active");

          var href = $(event.target).attr("href"),
              offsetTop = href === "#" ? 0 : $(href).offset().top - 5;
          $("html").stop().animate({
              scrollTop: offsetTop
          }, 300, function () {
              setTimeout(function () {
                  return is_click = false;
              }, 500);
          });
          event.preventDefault();
      });
      simpread.read.toc_hide && $('head').append("<style>toc-bg{width:50px!important;height:200px!important}.toc-bg-hidden{transition:opacity .2s ease}.toc-bg-hidden:hover toc{width:180px}toc{width:0;transition:width .5s!important}</style>");
  }

  /**
   * Option Mode
   */
  function optionMode() {
      var close = function close(event) {
          mduikit.Destory();
          $(".simpread-option-root").animate({ opacity: 0 }, { complete: function complete() {
                  current_state = "";
                  $(".simpread-option-root").remove();
              } });
      },
          save = function save(event) {
          setter($("#txt-option").val(), "option");
          setter($("#txt-focus ").val(), "focus");
          setter($("#txt-read ").val(), "read");
          GM_setValue("simpread", simpread);
          new Notify().Render("保存成功,请刷新当前页面,以便新配置文件生效。");
      },
          imports = function imports(event) {
          var input = document.createElement("input"),
              $input = $(input),
              onload = function onload(event) {
              if (event && event.target && event.target.result) {
                  try {
                      var json = JSON.parse(event.target.result);
                      if (json.version && json.version.replace(/\./g, "") < simpread.version.replace(/\./g, "")) {
                          new Notify().Render(2, "上传的版本太低,已转换为最新版版本!");
                      }
                      Object.keys(simpread.focus).forEach(function (key) {
                          json.focus[key] != undefined && (simpread.focus[key] = json.focus[key]);
                      });
                      Object.keys(simpread.read).forEach(function (key) {
                          json.read[key] != undefined && (simpread.read[key] = json.read[key]);
                      });
                      Object.keys(simpread.option).forEach(function (key) {
                          json.option[key] != undefined && (simpread.option[key] = json.option[key]);
                      });
                      GM_setValue("simpread", simpread);
                      if (json.websites) {
                          pr.sites.custom = [].concat(toConsumableArray(json.websites.custom));
                          pr.sites.local = [].concat(toConsumableArray(json.websites.local));
                          GM_setValue("simpread_db", pr.sites);
                          new Notify().Render("\u5DF2\u5BFC\u5165\u672C\u5730\u9002\u914D\u6E90\uFF1A" + pr.sites.local.length + " \u6761\uFF1B\u5B98\u65B9\u6B21\u9002\u914D\u6E90\uFF1A" + pr.sites.custom.length + " \u6761\u3002");
                      }
                      new Notify().Render("导入成功,请刷新当前页面,以便新配置文件生效。");
                  } catch (error) {
                      new Notify().Render(2, "上传失败,配置文件解析失败,请重新确认。");
                  }
              }
          };
          $input.attr({ type: "file", multiple: "false" }).one("change", function (event) {
              var reader = new FileReader();
              reader.onload = onload;
              reader.readAsText(event.target.files[0]);
          });
          $input.trigger("click");
      },
          exports = function exports(event) {
          var data = "data:text/json;charset=utf-8," + encodeURIComponent(JSON.stringify(simpread));
          var $a = $("<a style=\"display:none\" href=" + data + " download=\"simpread-little-config.json\"></a>").appendTo("body");
          $a[0].click();
          $a.remove();
      },
          remote = function remote(event) {
          if (location.protocol == "https:") {
              new Notify().Render("\u8BF7\u52FF\u5728 https \u4E0B\u9762\u4F7F\u7528\u6B64\u529F\u80FD\uFF0C\u8BF7\u524D\u5F80 http \u7684\u9875\u9762\uFF0C\u5982\uFF1A <a href='http://kenshin.wang/blog/' target='_blank' >\u70B9\u51FB\u8FD9\u91CC</a>");
              return;
          }
          $.getJSON("http://sr.ksria.cn/website_list_v4.json" + "?_=" + Math.round(+new Date()), function (result) {
              var count = pr.Addsites(result);
              count == 0 ? new Notify().Render("适配列表已同步至最新版本。") : new Notify().Render(0, "\u9002\u914D\u5217\u8868\u5DF2\u540C\u6B65\u6210\u529F\uFF0C\u672C\u6B21\u65B0\u589E " + count + " \u4E2A\u7AD9\u70B9\u3002");
          });
      },
          clean = function clean(event) {
          new Notify().Render("是否清除掉本地配置文件?", "同意 ", function () {
              simpread = _extends({}, org_simp);
              GM_setValue("simpread", simpread);
              pr.sites = { global: [], custom: [], local: [] };
              GM_deleteValue("simpread_db");
              new Notify().Render("清除成功,请刷新本页!");
          });
      },
          getter = function getter(value, type) {
          try {
              var arr = value.split("\n").map(function (str) {
                  str = str.trim();
                  if (str.startsWith("set_")) {
                      str = str.replace("set_", "");
                      var key = str.split(":")[0];
                      var _value = str.split(":")[1];
                      if (simpread[type][key] != undefined) {
                          _value = simpread[type][key];
                          !["whitelist", "exclusion", "blacklist"].includes(key) && _value === "" && (_value = org_simp[type][key]);
                          return "set_" + key + ": " + _value;
                      }
                  } else return str;
              });
              return arr.join("\n");
          } catch (error) {
              new Notify().Render(2, "设置出现了问题,请重新打开设置。");
          }
      },
          setter = function setter(value, type) {
          try {
              var arr = value.split("\n").forEach(function (str) {
                  str = str.trim();
                  if (str.startsWith("set_")) {
                      str = str.replace("set_", "");
                      var key = str.split(":")[0];
                      if (["exclusion", "whitelist", "blacklist"].includes(key)) {
                          var _value2 = str.replace(key + ":", "").trim();
                          simpread[type][key] = _value2.split(",");
                      } else if (simpread[type][key] != undefined) {
                          var _value3 = str.split(":")[1].trim();
                          if (typeof simpread[type][key] == "boolean") {
                              simpread[type][key] = _value3 == "true" ? true : false;
                          } else simpread[type][key] = _value3.trim();
                      }
                  }
              });
          } catch (error) {
              new Notify().Render(2, "设置出现了问题,请重新打开设置。");
          }
      },
          btn_cancel = mduikit.Button("opt-cancel", "关 闭", { color: "rgb(33, 150, 243)", type: "flat", onclick: close, mode: "secondary" }),
          btn_save = mduikit.Button("opt-save", "保 存", { color: "rgb(33, 150, 243)", type: "flat", onclick: save }),
          btn_import = mduikit.Button("opt-import", "从本地导入配置文件", { color: "#fff", bgColor: "#FF5252", type: "flat", width: "100%", onclick: imports }),
          btn_export = mduikit.Button("opt-export", "导出配置文件到本地", { color: "#fff", bgColor: "#2196F3", type: "flat", width: "100%", onclick: exports }),
          btn_remote = mduikit.Button("opt-remote", "手动同步适配列表", { color: "#fff", bgColor: "#2196F3", type: "flat", width: "100%", onclick: remote }),
          btn_clean = mduikit.Button("opt-clean", "清除数据", { color: "#fff", bgColor: "#757575", type: "flat", width: "100%", onclick: clean }),
          txt_option = mduikit.Textarea("txt-option", getter(opt_value, "option"), { color: "rgba(51, 51, 51, 0.6)", state_color: "rgb(33, 150, 243)", size: "11px", height: "130px" }),
          txt_focus = mduikit.Textarea("txt-focus", getter(focus_value, "focus"), { color: "rgba(51, 51, 51, 0.6)", state_color: "rgb(33, 150, 243)", size: "11px" }),
          txt_read = mduikit.Textarea("txt-read", getter(read_value, "read"), { color: "rgba(51, 51, 51, 0.6)", state_color: "rgb(33, 150, 243)", size: "11px" }),
          optmpl = "<div class=\"simpread-option-root\">\n                        <dialog-gp>\n                            <dialog-head>\u9009\u9879\u9875</dialog-head>\n                            <dialog-content>\n                                <sr-opt-gp>\n                                    <sr-opt-label>\u5BFC\u5165\u548C\u5BFC\u51FA</sr-opt-label>\n                                    <sr-opt-item>" + (btn_import + btn_export) + "</sr-opt-item>\n                                </sr-opt-gp>\n                                <sr-opt-gp>\n                                    <sr-opt-label>\u540C\u6B65\u4E0E\u6E05\u9664</sr-opt-label>\n                                    <sr-opt-item>" + (btn_remote + btn_clean) + "</sr-opt-item>\n                                </sr-opt-gp>\n                                <sr-opt-gp>\n                                    <sr-opt-label>\u5168\u5C40</sr-opt-label>\n                                    <sr-opt-item>" + txt_option + "</sr-opt-item>\n                                </sr-opt-gp>\n                                <sr-opt-gp>\n                                    <sr-opt-label>\u805A\u7126\u6A21\u5F0F</sr-opt-label>\n                                    <sr-opt-item>" + txt_focus + "</sr-opt-item>\n                                </sr-opt-gp>\n                                <sr-opt-gp>\n                                    <sr-opt-label>\u9605\u8BFB\u6A21\u5F0F</sr-opt-label>\n                                    <sr-opt-item>" + txt_read + "</sr-opt-item>\n                                </sr-opt-gp>\n                            </dialog-content>\n                            <dialog-footer>\n                                " + (btn_cancel + btn_save) + "\n                            </dialog-footer>\n                        </dialog-gp>\n                    </div>";
      if (current_state == "option") {
          new Notify().Render("请误重复进入。");
          return;
      } else if (current_state != "") {
          new Notify().Render("请先退出当前模式。");
          return;
      } else current_state = "option";
      $("html").append(optmpl);
      $(".simpread-option-root").animate({ opacity: 1 });
      var _ref = [$("dialog-gp").height(), $(".simpread-option-root").height()],
          h1 = _ref[0],
          h2 = _ref[1];

      if (h2 <= h1) {
          $("dialog-gp").height(h2 - 80);
      }
  }

  /**
   * About Mode
   */
  function aboutMode() {
      var close = function close(event, cb) {
          mduikit.Destory();
          $(".simpread-option-root").animate({ opacity: 0 }, { complete: function complete() {
                  current_state = "";
                  $(".simpread-option-root").remove();
                  cb && cb();
              } });
      },
          option = function option(event) {
          close(event, function () {
              return optionMode();
          });
      },
          btn_cancel = mduikit.Button("opt-cancel", "关 闭", { color: "rgb(33, 150, 243)", type: "flat", onclick: close }),
          btn_open = mduikit.Button("opt-open", "设 定", { color: "rgb(33, 150, 243)", type: "flat", onclick: option, mode: "secondary" }),
          optmpl = "<div class=\"simpread-option-root\">\n                        <dialog-gp>\n                            <dialog-head>\u5173\u4E8E</dialog-head>\n                            <dialog-content>\n                                <p align=\"center\"><img src=\"http://sr.ksria.cn/logo@128.png\"></p>\n                                <div style=\"display:flex;flex-direction:row;justify-content:center;\">\n                                    <a href=\"https://github.com/Kenshin/simpread/releases\" target=\"_blank\" data-reactid=\".2.1.5.0.0.2.0\">\n                                        <svg style=\"margin: 5px;\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"90\" height=\"20\"><linearGradient id=\"b\" x2=\"0\" y2=\"100%\"><stop offset=\"0\" stop-color=\"#bbb\" stop-opacity=\".1\"/><stop offset=\"1\" stop-opacity=\".1\"/></linearGradient><clipPath id=\"a\"><rect width=\"90\" height=\"20\" rx=\"3\" fill=\"#fff\"/></clipPath><g clip-path=\"url(#a)\"><path fill=\"#555\" d=\"M0 0h51v20H0z\"/><path fill=\"#007ec6\" d=\"M51 0h39v20H51z\"/><path fill=\"url(#b)\" d=\"M0 0h90v20H0z\"/></g><g fill=\"#fff\" text-anchor=\"middle\" font-family=\"DejaVu Sans,Verdana,Geneva,sans-serif\" font-size=\"110\"> <text x=\"265\" y=\"150\" fill=\"#010101\" fill-opacity=\".3\" transform=\"scale(.1)\" textLength=\"410\">version</text><text x=\"265\" y=\"140\" transform=\"scale(.1)\" textLength=\"410\">version</text><text x=\"695\" y=\"150\" fill=\"#010101\" fill-opacity=\".3\" transform=\"scale(.1)\" textLength=\"290\">1.1.2</text><text x=\"695\" y=\"140\" transform=\"scale(.1)\" textLength=\"290\">1.1.2</text></g> </svg>\n                                    </a>\n                                    <a href=\"http://ksria.com/simpread#lite\" target=\"_blank\" data-reactid=\".2.1.5.0.0.2.1\"><img style=\"padding:5px;\" src=\"\" data-reactid=\".2.1.5.0.0.2.1.0\"></a><a href=\"https://github.com/Kenshin/simpread\" target=\"_blank\" data-reactid=\".2.1.5.0.0.2.2\"><img style=\"padding:5px;\" src=\"\" data-reactid=\".2.1.5.0.0.2.2.0\"></a></div>\n                                <div style=\"display:flex;flex-direction:row;justify-content:center;\" data-reactid=\".2.1.5.0.0.3\"><a href=\"http://ksria.com/simpread/changelog.html#us_" + GM_info.script.version + "\" target=\"_blank\" data-reactid=\".2.1.5.0.0.3.0\"><img style=\"padding:5px;\" src=\"\" data-reactid=\".2.1.5.0.0.3.0.0\"></a><a href=\"https://github.com/kenshin/simpread/issues\" target=\"_blank\" data-reactid=\".2.1.5.0.0.3.1\"><img style=\"padding:5px;\" src=\"\" data-reactid=\".2.1.5.0.0.3.1.0\"></a><a href=\"https://github.com/kenshin/simpread/issues\" target=\"_blank\" data-reactid=\".2.1.5.0.0.3.2\"><img style=\"padding:5px;\" src=\"\" data-reactid=\".2.1.5.0.0.3.2.0\"></a></div>\n                                <div class=\"about\">\n                                    \u4F60\u597D\uFF0C\u6211\u662F <a target=\"_blank\" href=\"https://github.com/Kenshin/simpread-little\">\u7B80\u60A6 \xB7 \u8F7B\u9605\u7248</a> \u7684\u5F00\u53D1\u8005 <a target=\"_blank\" href=\"http://kenshin.wang\">Kenshin</a>\uFF0C\u5F88\u9AD8\u5174\u770B\u5230\u4F60\u80FD\u4F7F\u7528\u5B83\u3002<br>\n                                    \u5B83\u662F\u4E00\u4E2A\u9605\u8BFB\u6A21\u5F0F\u7C7B\u7684\u6CB9\u7334\u811A\u672C\uFF0C\u4E5F\u662F <a href=\"http://ksria.com/simpread\">\u7B80\u60A6</a> \u7684\u8F7B\u91CF\u7EA7\u7248\u672C\u3002</br>\n                                    \u62E5\u6709 <a target=\"_blank\" href=\"http://ksria.com/simpread/#feature\">\u7B80\u60A6\u7684\u4E00\u5207\u7279\u6027</a>\uFF0C\u66F4\u5177\u6709\u300C\u52A0\u8F7D\u901F\u5EA6\u5FEB \xB7 \u53EA\u5173\u6CE8\u9605\u8BFB\u6A21\u5F0F\u5448\u73B0\u300D\u7B49 <a target=\"_blank\" href=\"https://github.com/Kenshin/simpread-little/blob/master/README.md#\u7279\u70B9\">\u7279\u70B9</a>\u3002</br>\n                                    \u7B80\u60A6\u7684\u521D\u8877\uFF1A\u8FD8\u539F\u4E00\u4E2A\u5E72\u51C0\u7684\u9605\u8BFB\u7A7A\u95F4\uFF0C\u63D0\u5347\u4F60\u7684\u9605\u8BFB\u4F53\u9A8C\u3002</br>\n                                    \u622A\u81F3\u5230\u76EE\u524D\u4E3A\u6B62\uFF0C\u7B80\u60A6\u5DF2\u7ECF\u7CBE\u51C6\u9002\u914D\u4E86 <spn style=\"color:#ff3f80;font-weight:600;\">" + pr.sites.global.length + "\u4E2A</spn> \u7F51\u5740\uFF0C\u8BE6\u7EC6\u8BF7\u770B <a href=\"http://ksria.com/simpread/docs/#/%E9%80%82%E9%85%8D%E7%AB%99%E7%82%B9%E5%88%97%E8%A1%A8\" target=\"_blank\">\u8FD9\u91CC</a>\u3002<br>\n                                    \u7B80\u60A6\u662F\u4E00\u4E2A\u514D\u8D39\u4E14\u5F00\u6E90\u7684\u9879\u76EE\uFF0C\u5360\u7528\u4E86\u6211\u7EDD\u5927\u591A\u6570\u7684\u4E1A\u4F59\u65F6\u95F4\u3002</br>\n                                    \u5982\u679C\u89C9\u5F97\u5B83\u8FD8\u4E0D\u9519\uFF0C\u5E0C\u671B\u53EF\u4EE5\u7ED9\u6211 <a href=\"https://greasyfork.org/zh-CN/forum/post/discussion?script=39998&locale=zh-CN\" target=\"_blank\">\u6295\u7968</a> \u6216 <a href=\"https://github.com/kenshin/simpread#\u8BF7\u676F\u5496\u5561\" target=\"_blank\">\u8BF7\u6211\u559D\u676F\u5496\u5561</a>\uFF0C\u8FD9\u662F\u5BF9\u7B80\u60A6\u7684\u6700\u5927\u9F13\u52B1\u3002<br>\n                                    \u73B0\u5728\u5C31\u52A0\u5165 <a href=\"https://t.me/simpread\">Telegram</a> \u7FA4\uFF0C\u83B7\u53D6\u7B80\u60A6\u7684\u7B2C\u4E00\u624B\u8D44\u6599\u3002</br>\n                                </div>\n                            </dialog-content>\n                            <dialog-footer>\n                                " + (btn_open + btn_cancel) + "\n                            </dialog-footer>\n                        </dialog-gp>\n                    </div>";
      if (current_state == "option") {
          new Notify().Render("请误重复进入。");
          return;
      } else if (current_state != "") {
          new Notify().Render("请先退出当前模式。");
          return;
      } else current_state = "option";
      $("html").append(optmpl);
      $(".simpread-option-root").animate({ opacity: 1 }, { complete: function complete() {
              var _ref2 = [$("dialog-gp").height(), $(".simpread-option-root").height()],
                  h1 = _ref2[0],
                  h2 = _ref2[1];

              if (h2 <= h1) {
                  $("dialog-gp").animate({ height: h2 - 80 });
              }
          } });
  }

}());