百度搜索 - 优化

1、屏蔽百度推广 2、居中单列(可选) 3、居中双列(可选) 4.自动下一页(可选)

Instali tiun ĉi skripton?
Author's suggested script

You may also like 谷歌搜索 - 优化.

Instali tiun ĉi skripton
// ==UserScript==
// @name         百度搜索 - 优化
// @namespace    http://tampermonkey.net/
// @home-url     https://greasyfork.org/zh-CN/scripts/31642
// @description  1、屏蔽百度推广 2、居中单列(可选) 3、居中双列(可选) 4.自动下一页(可选)
// @version      5.1.1
// @author       浮生未歇
// @run-at       document-start
// @match         *://ipv6.baidu.com/*
// @match         *://www.baidu.com/
// @match         *://www.baidu.com/?*
// @match         *://www.baidu.com/s?*
// @match         *://www.baidu.com/#*
// @match         *://www.baidu.com/baidu?*
// @exclude      ^https://www.baidu.com/home*
// @exclude      ^https://www.baidu.com/sf*
// @exclude      ^https://www.baidu.com/search*
// @exclude      ^https://www.baidu.com/link*
// @exclude      ^https://www.baidu.com/s*tn=news*
// @require      https://lib.baomitu.com/jquery/3.5.0/jquery.min.js
// @connect      self
// @connect      baidu.com
// @connect      bing.com
// @grant        GM_addStyle
// @grant        GM_getResourceText
// @grant        GM_getResourceURL
// @grant        GM_setValue
// @grant        GM_getValue
// @grant        GM_deleteValue
// @grant        GM_xmlhttpRequest
// ==/UserScript==


(function () {
    const UserConfig = {
        BG_IMAGE_URL: "",
    };
    const SYSTEM_CONFIGS = {
        IS_DEBUG: false,
        PAGE_SELECT_NAME: "BD_PAGE_SELECT",
        PAGE_AUTO_NEXT_PAGE_NAME: "IS_AUTO_NEXT_PAGE",
        DEFAULT_PAGE_SELECT_VALUE: 1,
        DEFAULT_AUTO_NEXT_PAGE_SWITCH: false,
        BAIDU_STYLES: {
            INDEX: "baiduIndexStyle",
            BASE: "baiduBaseStyle",
            MENU: "baiduMenu",
            ONE_PAGE: "baiduOne",
            TWO_PAGE: "baiduTwo",
            THREE_PAGE: "baiduThree"
        },
    };
    const SIDEBAR_TOOLBAR_ITEMS = {
        "百度识图": "https://graph.baidu.com/pcpage/index?tpl_from=pc",
        "百度资讯": "https://www.baidu.com/s?rtt=1&bsst=1&cl=2&tn=news&ie=utf-8&word=%s",
        "百度文库": "https://wenku.baidu.com/search?lm=0&od=0&ie=utf-8&word=%s",
        "百度知道": "https://zhidao.baidu.com/search?ct=17&pn=0&tn=ikaslist&rn=10&fr=wenku&word=%s",
        "百度贴吧": "https://tieba.baidu.com/f?kw=%s&t=4",
        "百度图片": "https://image.baidu.com/search/index?tn=baiduimage&ct=201326592&lm=-1&cl=2&word=%s&t=3",
        "百度地图": "https://map.baidu.com/",
        "Google": "https://www.google.com/search?&num=20&newwindow=1&q=%s",
        "Bing": "https://www.bing.com/search?q=%s",
        "淘宝": "https://s.taobao.com/search?q=%s",
        "京东": "https://search.jd.com/Search?keyword=%s&enc=utf-8"
    };
    let LAYOUT_TYPE;
    (function (LAYOUT_TYPE) {
        LAYOUT_TYPE[LAYOUT_TYPE["General"] = 0] = "General";
        LAYOUT_TYPE[LAYOUT_TYPE["OneCenter"] = 1] = "OneCenter";
        LAYOUT_TYPE[LAYOUT_TYPE["TwoCenter"] = 2] = "TwoCenter";
        LAYOUT_TYPE[LAYOUT_TYPE["ThreeCenter"] = 3] = "ThreeCenter";
    })(LAYOUT_TYPE || (LAYOUT_TYPE = {}));
    ;
    let SILTER_BAR_MODE;
    (function (SILTER_BAR_MODE) {
        SILTER_BAR_MODE[SILTER_BAR_MODE["auto"] = 0] = "auto";
        SILTER_BAR_MODE[SILTER_BAR_MODE["show"] = 1] = "show";
        SILTER_BAR_MODE[SILTER_BAR_MODE["hidden"] = 2] = "hidden";
    })(SILTER_BAR_MODE || (SILTER_BAR_MODE = {}));
    let ADDITION_FUNCTION;
    (function (ADDITION_FUNCTION) {
        ADDITION_FUNCTION[ADDITION_FUNCTION["AutoNextPage"] = 0] = "AutoNextPage";
        ADDITION_FUNCTION[ADDITION_FUNCTION["SideToolBar"] = 1] = "SideToolBar";
    })(ADDITION_FUNCTION || (ADDITION_FUNCTION = {}));
    const LAYOUT_CONFIG = {
        saveName: "PAGE_LAYOUT",
        defaultValue: LAYOUT_TYPE.General
    };
    const SILDER_BAR_CONFIG = {
        saveName: "silder_bar",
        defaultValue: SILTER_BAR_MODE.hidden
    };
    const ADDITION_FUNCTION_CONFIGS = {
        AutoNextPage: {
            saveName: "funciton_auto_next_page",
            defaultSwitch: false,
            functionName: ADDITION_FUNCTION.AutoNextPage
        },
        SideToolBar: {
            saveName: "funciton_side_tool_bar",
            defaultSwitch: false,
            functionName: ADDITION_FUNCTION.SideToolBar
        }
    };
    const INLINE_STYLE_BASE = `#content_left .c-container[data-lp],#content_left>.c-container[tpl=short_video_pc],#content_left>div>.c-container[tpl=short_video_pc],#content_left>table,#content_right,#demo,#ent_sug,#foot,#head .headBlock,#imsg,#page .fk,#result_logo img,#rs_new,#rs_top_new,#searchTag,#top-ad,#u>a .c-icon,.c-recommend,.hint_common_restop,.hit_top_new,.leftBlock,.rrecom-btn-parent,body>.res_top_banner,iframe{display:none!important}#content_left>div:not([id]),#content_left>div[style*='display:block !important;'],body>div[style*='position: absolute;'],body>div[style*='position: fixed;']{display:none!important;position:absolute!important;top:-1px!important;clip:rect(0 0 0 0)!important;z-index:-1!important}.bd-none{display:none!important}#form{display:none!important}#baidu_content_left{margin-left:200px}.c-container{display:inline-block;margin:20px auto}#container{position:relative!important;padding-top:60px!important}body{background:#f1f2f3!important}html{overflow-y:scroll}:root{overflow-y:auto;overflow-x:hidden}:root body{position:absolute}body{width:100vw;overflow:hidden}#form{position:absolute!important;z-index:-1;-webkit-transform:scaleX(0);transform:scaleX(0)}.bd-container-search{position:absolute;top:8px;left:150px}.bd-docker{position:absolute;top:0;left:0}.bd-barbox-ul{position:absolute;display:flow-root;width:640px;height:40px;font-size:18px;line-height:1.2;text-align:center;z-index:2}.bd-barbox-li{float:left;position:relative}.bd-barbox-li:first-of-type:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;z-index:-1}.bd-barbox-button,.bd-barbox-input{border:none!important;outline:0!important}.bd-barbox-input{position:relative;width:540px;height:40px;color:#000;font-size:inherit;border-radius:3px 0 0 3px;background:#e3e3e3!important;padding-left:15px;padding-right:10px;-webkit-transition:width .3s;transition:width .3s;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden}.bd-barbox-input:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;z-index:-1;background:#fff}.bd-barbox-button{position:relative;-webkit-box-sizing:border-box;box-sizing:border-box;width:100px;height:40px;line-height:1;font-size:inherit;background:linear-gradient(40deg,#18c0fe,#1677ff);border-radius:0 3px 3px 0;color:#fff;-webkit-transition:background .3s;transition:background .3s}.bd-barbox-button:hover{cursor:pointer;background:linear-gradient(40deg,#2070e5,#1890ff);-webkit-transition:background .3s;transition:background .3s}.bd-associate-ul{position:absolute;width:650px;top:50px;background:0 0;border-radius:.5em;text-align:left}.bd-associate-ul:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;z-index:-1;background:#fdfdfd;-webkit-box-shadow:0 0 5px 1px rgba(0,0,0,.2);box-shadow:0 0 5px 1px rgba(0,0,0,.2)}.bd-associate-li{font-size:16px;padding:10px 20px;list-style-type:none!important}.bd-associate-li>span{font-weight:700}.bd-associate-li:hover{cursor:pointer}.bd-associate-li:first-of-type{border-radius:.5em .5em 0 0}.bd-associate-li:last-of-type{border-radius:0 0 .5em .5em}.bd-associate-li:only-of-type{border-radius:.5em!important}.bd-associate-selected{position:relative;color:#2196f3;background:#f3f3f3!important}.bd-associate-selected:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;-webkit-box-shadow:0 0 3px hsla(0,0%,13%,.1);box-shadow:0 0 3px hsla(0,0%,13%,.1)}#head{background-color:#f1f2f3!important;border-bottom:1px solid!important;border-color:#e4e5e7!important;-webkit-box-shadow:none!important;box-shadow:none!important}#head .s_form{height:58px!important}#u .s-top-img-wrapper,.set-result-tts{display:none!important}#u{font-size:15px!important;margin-top:8px!important;padding-right:10px!important}#u a,#u a:hover{text-decoration:none}#u>a{-webkit-box-sizing:border-box!important;box-sizing:border-box!important;font-family:"Microsoft YaHei"!important;font-size:inherit!important;margin:0 8px!important;padding:8px 8px!important;position:relative;background:0 0!important;color:hsla(216,25%,24%,.8)!important;border-radius:3px}#u>a .s-top-username{font-size:15px!important;line-height:24px!important;margin:0!important;padding:0!important}#u>a[name=tj_login]{height:auto!important}#u>a:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;border-radius:3px;background-color:#e4e5e7!important;z-index:-1}#u>a:hover:after{background-color:#fff!important}#user{max-width:250px!important;text-overflow:ellipsis!important;height:auto!important}@media screen and (max-width:1024px){#u .toindex{display:none!important}}.bdpfmenu,.usermenu{width:auto!important;border:1px solid #e4e5e7!important;-webkit-box-shadow:none!important;box-shadow:none!important;padding:0!important;border-radius:0!important}.bdpfmenu{position:fixed!important;top:50px!important;width:100px!important;margin-top:3px!important;margin-right:10px!important}.usermenu{top:35px!important;width:100px!important;margin-top:10px!important;margin-right:0!important;z-index:1}.usermenu a{margin:0!important}.bdpfmenu>a,.usermenu>a{border-radius:0!important;display:block!important;width:auto!important;height:auto!important;margin:0!important;padding:5px 10px!important;font-size:14px!important;line-height:1.8!important;text-align:center!important;background:#fff!important;color:#222!important}.bdpfmenu>a>span,.usermenu>a>span{margin:0!important}.bdpfmenu>a:hover,.usermenu>a:hover{background:#f1f3fd!important;color:#315efb!important}#s_tab{display:none!important}#content_left{display:none!important}#head{width:100%!important}.s_form{padding:0!important}#container{padding-left:0!important}@media screen and (min-width:1921px){.head_wrapper{width:100%;margin:0 auto;position:relative;-webkit-transform:translate3d(-52px,0,1px);transform:translate3d(-52px,0,1px)}}.options_2Vntk{width:auto!important}.result-molecule{width:640px!important}.bd_search_result_container .bd_list{width:640px;float:left}.bd_search_result_container .bd_list:not(:first-of-type){margin-left:10px}.bd_search_result_container .c-container{margin:5px auto!important}.bd_search_result_container .c-container .c-container{width:100%!important}.bd_search_result_container #rs,.bd_search_result_container #rs_new,.bd_search_result_container .bd_list>.c-container[id][tpl]{width:640px!important;margin-top:5px!important;padding:0 20px 10px!important;margin-bottom:5px!important;background:#fff!important;-webkit-box-sizing:border-box!important;box-sizing:border-box!important;border:none!important;border-radius:3px}.bd_search_result_container #rs,.bd_search_result_container .bd_list>.c-container[id]{position:relative!important}.bd_search_result_container #rs:after,.bd_search_result_container .bd_list>.c-container[id]:after{content:"";z-index:-1;position:absolute;top:0;bottom:0;left:0;right:0;-webkit-box-shadow:0 0 30px 1px rgba(0,0,0,.1);box-shadow:0 0 30px 1px rgba(0,0,0,.1)}.bd_search_result_container .c-result-content>.c-container[id]{border:none!important;margin-left:-20px!important}.bd_search_result_container .bd_list>.c-container[tpl*=ty_lasar]{padding:0}.bd_search_result_container .bd_list>.c-container[tpl=soft] .op-soft-title,.bd_search_result_container .bd_list>.c-container[tpl] h3{background:hsla(0,0%,90%,.05)!important;margin:0 -20px 5px!important;padding:8px 20px 6px!important;border-bottom:1px solid hsla(0,2%,10%,.05)!important}.bd_search_result_container .bd_list>.c-container[tpl=jy_rota_wenshu_pc] .c-container{padding-top:0!important}.bd_search_result_container .bd_list>.c-container[tpl=jy_rota_wenshu_pc] header.c-gap-bottom-small{padding-bottom:10px!important}.bd_search_result_container .bd_list>.c-container h3 [class*=OP_LOG_LINK]{color:#fff!important}.bd_search_result_container .bd_list>.c-container h3 a,.bd_search_result_container .bd_list>.c-container h3 a em,.bd_search_result_container .bd_list>.c-container[tpl=soft] .op-soft-title a,.bd_search_result_container .bd_list>.c-container[tpl=soft] .op-soft-title a em{color:#014aa5!important;text-decoration:none!important}.bd_search_result_container .bd_list>.c-container h3 a em,.bd_search_result_container .bd_list>.c-container[tpl=soft] .op-soft-title a em{color:#e45465!important}.bd_search_result_container .bd_list>.c-container h3 a,.bd_search_result_container .op-soft-title a{position:relative;display:inline-block}.bd_search_result_container .bd_list>.c-container h3 a:after,.bd_search_result_container .op-soft-title a:after{position:absolute;z-index:1;content:"";border-bottom:1px solid;bottom:2px;left:100%;width:0;-webkit-transition:width 350ms,left 350ms;-moze-transition:width 350ms,left 350ms;transition:width 350ms,left 350ms}.bd_search_result_container .bd_list>.c-container h3 a:hover:after,.bd_search_result_container .op-soft-title a:hover:after{left:0;width:100%;-webkit-transition:width 350ms;transition:width 350ms}.bd_search_result_container .bd_list>.c-container h3 a:visited,.bd_search_result_container .op-soft-title a:visited{color:#7c32a1!important}.bd_search_result_container .bd_list>.c-container h3 a:visited:after,.bd_search_result_container .op-soft-title a:visited:after{left:100%;width:0;-webkit-transition:width 350ms,left 350ms;-moze-transition:width 350ms,left 350ms;transition:width 350ms,left 350ms}.bd_search_result_container .bd_list>.c-container h3 a:visited:hover:after,.bd_search_result_container .op-soft-title a:visited:hover:after{left:0;width:100%;-webkit-transition:width 350ms;transition:width 350ms}.bd_search_result_container .bd_list>.c-container .c-abstract,.bd_search_result_container .bd_list>.c-container .c-span18,.bd_search_result_container ol li{color:#636363!important;color:#333!important;line-height:1.8}.bd_search_result_container table em{text-decoration:none!important}.bd_search_result_container .c-gap-right-small,.bd_search_result_container .c-gray a,.bd_search_result_container .c-offset>div a,.bd_search_result_container .c-span18 a,.bd_search_result_container .c-span6 a,.bd_search_result_container .c-tabs-content a,.bd_search_result_container .f13 a,.bd_search_result_container .f13 em,.bd_search_result_container .op-b2b-find-all-text,.bd_search_result_container .op-b2b-product-item-title a,.bd_search_result_container .op-generaltable-morelink a,.bd_search_result_container .op-img-address-link-menu a,.bd_search_result_container .op-se-listen-recommend,.bd_search_result_container .op-short-video-pc-more a,.bd_search_result_container .op-short-video-pc-poster a,.bd_search_result_container .op-tieba-general-mainpl a,.bd_search_result_container .op-tieba-general-right,.bd_search_result_container .op-tieba-novel-lookmore a,.bd_search_result_container .op-tieba-novel-trone a,.bd_search_result_container .op-tieba-novel-trtwo a,.bd_search_result_container .op-tieba-offical-lookmore a,.bd_search_result_container .op-tieba_offical-lianjie,.bd_search_result_container .op_dq01_morelink a,.bd_search_result_container .op_dq01_table a,.bd_search_result_container .op_dq01_title,.bd_search_result_container .op_generalqa_answer_title a,.bd_search_result_container .op_jingyan_list p.c-gap-top-small,.bd_search_result_container .op_offical_weibo_content a,.bd_search_result_container .op_offical_weibo_pz a,.bd_search_result_container .op_tieba2_tablinks_container a,.bd_search_result_container .subLink_factory a,.bd_search_result_container tbody a{text-decoration:none!important;color:#014aa5!important}.bd_search_result_container .c-gap-right-small:hover,.bd_search_result_container .c-gray:hover a,.bd_search_result_container .c-offset>div a:hover,.bd_search_result_container .c-span6 a:hover,.bd_search_result_container .c-tabs-content a:hover,.bd_search_result_container .f13 a:hover,.bd_search_result_container .f13 em:hover,.bd_search_result_container .op-b2b-product-item-title a:hover,.bd_search_result_container .op-generaltable-morelink a:hover,.bd_search_result_container .op-img-address-link-menu a:hover,.bd_search_result_container .op-se-listen-recommend:hover,.bd_search_result_container .op-short-video-pc-more a:hover,.bd_search_result_container .op-short-video-pc-poster a:hover,.bd_search_result_container .op-tieba-general-mainpl a:hover,.bd_search_result_container .op-tieba-general-right:hover,.bd_search_result_container .op-tieba-offical-lookmore a:hover,.bd_search_result_container .op-tieba_offical-lianjie:hover,.bd_search_result_container .op_dq01_morelink a:hover,.bd_search_result_container .op_dq01_table a:hover,.bd_search_result_container .op_dq01_title:hover,.bd_search_result_container .op_generalqa_answer_title:hover,.bd_search_result_container .op_jingyan_list p:hover,.bd_search_result_container .op_tieba2_tablinks_container a:hover,.bd_search_result_container .subLink_factory a:hover,.bd_search_result_container tbody a:hover{text-decoration:underline!important}.bd_search_result_container .f13 a{color:green!important}.bd_search_result_container em{color:#e45465}.bd_search_result_container .c-img6{opacity:.9}.bd_search_result_container .c-span18{width:455px!important}.bd_search_result_container .c-span24{width:100%!important;line-height:1.8!important}.bd_search_result_container .c-border{width:auto!important;border:none!important;border-bottom-color:transparent;border-right-color:transparent;-webkit-box-shadow:none!important;box-shadow:none!important}.bd_search_result_container .bd_list>.c-container .op-img-address-link-type,.bd_search_result_container .op_jingyan_list,.bd_search_result_container .se_com_irregular_gallery ul li{display:inline-block}.bd_search_result_container::after{content:"";display:table;clear:both}#page{display:none!important}#bd_page_number{width:640px;text-align:center;margin-top:20px;margin-bottom:100px}#bd_page_number .bd_page_item{border:none;border-radius:6px;background-color:#fff;color:#3951b3;margin-right:10px;display:inline-block;vertical-align:text-bottom;text-align:center;text-decoration:none;overflow:hidden}#bd_page_number .bd_page_item span{display:inline-block;cursor:pointer;width:100%;height:100%;line-height:36px}#bd_page_number .bd_page_item :hover{border:none;background:#4e6ef2;color:#fff}#bd_page_number .bd_page_number{width:36px;height:36px}#bd_page_number .bd_page_next_page,#bd_page_number .bd_page_pre_page{width:80px;height:36px}#bd_page_number .bd_page_next_page{margin-right:0}#bd_page_number .bd_page_number_selected{pointer-events:none;background-color:#4e6ef2;color:#fff} `;
    const INLINE_STYLE_INDEX = `#bds-message-wrapper,#bottom_container,#bottom_layer,#ftCon,#s-hotsearch-wrapper,#s_lm_wrap,#s_main,#s_side_wrapper,#s_top_wrap.s-down .s-center-box,.guide-info,.qrcodeCon,.s-set-homepage-tts,.s-top-wrap.s-isindex-wrap.s-down,.show-feed{display:none!important}body{position:relative;overflow-y:hidden!important;background:0 0!important}body::after{position:absolute;content:"";top:0;bottom:0;left:0;right:0;z-index:-100;background-color:#f1f2f3}#s_top_wrap{border:none!important}#head_wrapper{z-index:1!important}#s_main{background:hsla(0,0%,100%,.6)!important}#head_wrapper .s_form{width:900px}.s-top-wrap{background:0 0!important}.s-isindex-wrap .c-color-t:after{content:"";position:absolute;top:0;bottom:-2px;left:50%;right:50%;z-index:-2;border-bottom:2px solid}.s-isindex-wrap .c-color-t:hover{color:#2196f3!important;position:relative}.s-isindex-wrap .c-color-t:hover:after{left:0;right:0;-webkit-transition:left .3s ease,right .3s ease;transition:left .3s ease,right .3s ease}.s-top-more-content .c-color-t{color:#555!important;text-shadow:none!important}.s-top-more-content .c-color-t:hover{color:#4682b4!important}.s-isindex-wrap .c-color-red.c-color-red{color:#fff}.s-isindex-wrap .c-color-red.c-color-red:hover{color:#2196f3}#form{display:none!important}.bd-container-search{position:relative}.bd-barbox-ul{position:absolute;display:flow-root;top:200px;bottom:-50px;width:100%;height:48px;font-size:20px;line-height:1.2;text-align:center;z-index:2}.bd-barbox-center{display:inline-block;margin:0 auto;border-radius:30px;-webkit-box-shadow:0 0 8px 3px rgba(0,0,0,.1);box-shadow:0 0 8px 3px rgba(0,0,0,.1);text-align:center}.bd-barbox-li{float:left;position:relative}.bd-barbox-li:first-of-type:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;border-radius:20px 20px 0 0;background:hsla(0,0%,100%,.2)!important;-webkit-filter:blur(5px);filter:blur(5px);z-index:-1}.bd-barbox-button,.bd-barbox-input{border:none!important}.bd-barbox-input{position:relative;width:450px;height:40px;color:#000;text-shadow:0 0 1px 1px #000;border-radius:20px 0 0 20px;background:hsla(0,0%,100%,.3);padding-left:25px;padding-right:10px;-webkit-transition:width .3s;transition:width .3s;-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden}.bd-barbox-input:focus{width:500px;background:hsla(0,0%,100%,.6);-webkit-transition:width .3s ease,background .5s ease-out;transition:width .3s ease,background .5s ease-out}.bd-barbox-input:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;z-index:-1;background:#fff;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.bd-barbox-button{position:relative;height:40px;padding:0 20px;line-height:1;background:hsla(216,80%,55%,.7);border-radius:0 20px 20px 0;color:#fff;-webkit-transition:background .3s;transition:background .3s}.bd-barbox-button:hover{background:#3079e8;-webkit-transition:background .3s;transition:background .3s}.bd-associate-ul{position:absolute;width:620px;top:250px;left:0;margin-left:140px;background:0 0;border-radius:.5em;text-align:left;-webkit-box-shadow:0 0 10px 5px rgba(0,0,0,.1);box-shadow:0 0 10px 5px rgba(0,0,0,.1);overflow:hidden}.bd-associate-ul:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;z-index:-1;background:hsla(0,0%,100%,.6);-webkit-filter:blur(1px);filter:blur(1px);margin:-30px}.bd-associate-li{font-size:16px;padding:10px 20px;list-style-type:none!important}.bd-associate-li>span{font-weight:700}.bd-associate-li:hover{cursor:pointer}.bd-associate-li:first-of-type{border-radius:.5em .5em 0 0}.bd-associate-li:last-of-type{border-radius:0 0 .5em .5em}.bd-associate-li:only-of-type{border-radius:.5em!important}.bd-associate-selected{position:relative;color:#2196f3;background:rgba(255,255,255,.3)!important}.bd-associate-selected:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;-webkit-box-shadow:0 0 10px hsla(0,0%,13%,.1);box-shadow:0 0 10px hsla(0,0%,13%,.1)}#head_wrapper .s-p-top{height:181px}#lg>img{display:none!important}#lg{position:relative;width:900px}#lg:after{content:"";position:absolute;top:0;left:0;margin-left:35px;z-index:100}#lg:after{width:100%;height:230px;-webkit-transform:scale(.35);transform:scale(.35);background-image:url()!important;background-repeat:no-repeat}.bd-display{display:none}.bd-bg-ul{position:fixed;top:0;bottom:0;left:0;right:0;z-index:-1}.bd-bg-ul:after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;z-index:2;-webkit-filter:blur(20px);filter:blur(20px);background-color:rgba(29,23,36,.2)}.bd-bg-li{position:absolute;top:0;bottom:0;left:0;right:0;z-index:-1;color:transparent}.bd-bg-li{background-size:100% 100%;background-repeat:no-repeat;background-attachment:fixed}.bd-opacity{opacity:0}#bd-search-association{background:red;width:575px;height:500px;position:absolute;margin-top:45px;border-radius:5px}.bd-head-more{background:red;position:fixed;top:50px;right:10px} `;
    const INLINE_STYLE_MENU = `#u>#bd-menu-btn:hover{-webkit-transition:background .3s;transition:background .3s}#bd-menu-detilas{position:absolute;top:-3px;left:-10px;margin-top:50px;border:1px solid #e4e5e7;background-color:#fff;-webkit-box-shadow:0 0 15px 1px rgba(0,0,0,.2);box-shadow:0 0 15px 1px rgba(0,0,0,.2)}#bd-menu-detilas .bt-menu-piece{display:flow-root;float:left;width:100px}#bd-menu-detilas ol{text-align:center;-webkit-box-shadow:none!important;box-shadow:none!important;border-bottom:1px dashed #e4e5e7!important}#bd-menu-detilas ol li{text-align:left;list-style:none!important;margin-left:-5px;padding:0 5px;color:#222;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}#bd-menu-detilas ol li input{-webkit-appearance:auto!important;-moz-appearance:auto!important;appearance:auto!important}#bd-menu-detilas ol:last-child{border-bottom:none!important}#bd-menu-detilas #bd_menu_save{display:block;width:100%;height:25px;margin-top:3px;border:1px solid #9e9e9e;cursor:pointer} `;
    const INLINE_STYLE_ONE_CENTER = `#container.sam_newgrid{margin:0!important;width:100%!important}.bd-container-search{position:relative!important;left:0!important;margin:auto;width:640px;left:4px!important}.result-molecule{width:640px!important;margin:auto!important}#container.sam_newgrid{margin:0!important;width:100%!important}.bd_serach_result_dock{width:640px;margin:auto}@media screen and (min-width:1921px){#wrapper_wrapper{margin-left:0!important}}#bd_page_number{margin:20px auto 100px!important} `;
    const INLINE_SIDEBAE = `#bd_sidebar{position:fixed;display:block;width:110px;height:100%;top:60px;z-index:100;background-color:transparent;color:#fff1c1;text-align:center;font-size:14px;left:-100px;opacity:0;opacity:1}#bd_sidebar:hover{opacity:1;left:0;background-color:#2b333e;overflow:hidden;-webkit-transition:left .2s;transition:left .2s}#bd_sidebar li{position:relative;width:100%;height:40px;line-height:40px;background:0 0!important;cursor:pointer}#bd_sidebar li:hover{padding-left:5px!important;-webkit-transition:padding-left .2s;transition:padding-left .2s;border-bottom-color:transparent}#bd_sidebar li:hover::after{content:"";position:absolute;top:0;bottom:0;left:0;right:0;z-index:-2;background:linear-gradient(to right,#00a8ff 3px,#3d5a83 0)!important} `;
    const INLINE_STYLE_THREE_CENTER = `#container.sam_newgrid{margin:0!important;width:100%!important}.bd-container-search{position:relative!important;left:0!important;margin:auto;width:640px;left:4px!important}.result-molecule{width:1940px!important;margin:auto!important}#container.sam_newgrid{margin:0!important;width:100%!important}.bd_serach_result_dock{width:1940px;margin:auto}@media screen and (min-width:1921px){#wrapper_wrapper{margin-left:0!important}}#bd_page_number{margin:20px auto 100px!important} `;
    const INLINE_STYLE_TWO_CENTER = `#container.sam_newgrid{margin:0!important;width:100%!important}.bd-container-search{position:relative!important;left:0!important;margin:auto;width:640px;left:4px!important}.result-molecule{width:1290px!important;margin:auto!important}#container.sam_newgrid{margin:0!important;width:100%!important}.bd_serach_result_dock{width:1290px;margin:auto}@media screen and (min-width:1921px){#wrapper_wrapper{margin-left:0!important}}#bd_page_number{margin:20px auto 100px!important} `;
    class GM {
        static getValue(key, defaultValue) {
            try {
                return GM_getValue(key, defaultValue);
            }
            catch (error) {
                console.debug(error);
            }
        }
        static setValue(key, value) {
            try {
                GM_setValue(key, value);
            }
            catch (error) {
                console.debug(error);
            }
        }
        static addStyle(content) {
            Promise.resolve().then(() => {
                try {
                    GM_addStyle(content);
                }
                catch (error) {
                    console.debug(error);
                }
            });
        }
        static xmlhttpRequest(config) {
            try {
                GM_xmlhttpRequest(config);
            }
            catch (error) {
                console.debug(error);
            }
        }
        static getResourceText(name) {
            try {
                return GM_getResourceText(name);
            }
            catch (error) {
                console.debug(error);
            }
        }
    }
    class OptionControl {
        constructor(name, defaultValue) {
            this.GM = GM;
            this.name = name;
            this.defalutValue = defaultValue;
        }
        getDefaultValue() {
            return this.defalutValue;
        }
        setOption(value) {
            this.GM.setValue(this.getOptionName(), value);
        }
        getOptionName() {
            return this.name;
        }
        getOptionValue() {
            return this.GM.getValue(this.getOptionName(), this.getDefaultValue());
        }
    }
    class Debug {
        static execute(callback) {
            if (Config.isDebug()) {
                callback();
            }
        }
        static log(msg) {
            this.execute(() => {
                console.log(msg);
            });
        }
        static info(msg) {
            this.execute(() => {
                console.info(msg);
            });
        }
        static count(msg) {
            this.execute(() => {
                console.count(msg);
            });
        }
        static debug(msg) {
            this.execute(() => {
                console.debug(msg);
            });
        }
    }
    class Config {
        static isDebug() {
            return SYSTEM_CONFIGS.IS_DEBUG;
        }
    }
    class Assoicate {
        constructor() {
            this.templateUrlAssociate = "https://www.baidu.com/sugrec?pre=1&p=3&ie=utf-8&json=1&prod=pc&from=pc_web&req=2&csor=10&wd=%s";
        }
        getURL(templateURL, keyWord) {
            const isEmptyKeyWord = keyWord.trim().length <= 0;
            if (isEmptyKeyWord) {
                return "";
            }
            else {
                return templateURL.replace(/\%s/i, encodeURIComponent(keyWord));
            }
        }
        decodeString(content) {
            return unescape(content.replace(/\\\u/g, "%u"));
        }
        stringToObject(content) {
            let result = `{"s":${content.match(/\[\".+\"\]/i)}}`;
            return JSON.parse(result);
        }
        processData(content, name) {
            let strContent = this.decodeString(content);
            let objContent = this.stringToObject(strContent);
            return name ? objContent[name] : objContent;
        }
        getItems(responseText) {
            let response = JSON.parse(responseText);
            let searchResults = response["g"];
            let items = [];
            for (const key in searchResults) {
                let item = searchResults[key]["q"];
                items.push(item);
            }
            return items;
        }
        getAssociateURL(keyWord) {
            return this.getURL(this.templateUrlAssociate, keyWord);
        }
    }
    class AssociateManager extends Assoicate {
        constructor(o) {
            super();
            this.o = o;
        }
        deal(responseText) {
            let items = super.getItems(responseText);
            this.update(items);
        }
        update(items) {
            this.o.update(items);
        }
        getAssoicateURL(keyWord) {
            return super.getAssociateURL(keyWord);
        }
        request(keyword) {
            let that = this;
            let url = this.getAssociateURL(keyword);
            GM.xmlhttpRequest({
                method: "GET",
                url: url,
                timeout: 3000,
                responseType: "json",
                headers: {
                    "User-Agent": navigator.userAgent,
                    "Cookie": document.cookie,
                },
                onload: (response) => {
                    if (response.status === 200 ||
                        response.status === 304) {
                        that.deal(response.responseText);
                    }
                },
                onerror: (error) => {
                    console.error("联想功能异常,请排查:", error);
                }
            });
        }
        search(keyWord) {
            let isEmptyKeyWord = keyWord.trim().length <= 0;
            let emptyKeyWord = [""];
            if (isEmptyKeyWord) {
                this.update(emptyKeyWord);
            }
            else {
                this.request(keyWord);
            }
        }
    }
    class AvoidMulExecute {
        constructor() {
            this.SING_NAME = "IsRunBaidu";
        }
        getSignElement() {
            return $("#content_left");
        }
        setSign() {
            let container = this.getSignElement();
            container.attr(this.SING_NAME, "true");
        }
        hasSign() {
            let container = this.getSignElement();
            return !!container.attr(this.SING_NAME);
        }
    }
    let Baidu = (function () {
        class Node {
            constructor(obj) {
                this.obj = obj;
                this.isReady = false;
                this.isDelay = false;
            }
            setReadyRun() {
                this.isReady = true;
                return this;
            }
            setDealyRun() {
                this.isDelay = true;
                return this;
            }
            isReadyRun() {
                return this.isReady;
            }
            isDelayRun() {
                return this.isDelay;
            }
            start() {
                new this.obj().start();
            }
            execute() {
                if (this.isReadyRun()) {
                    $().ready(() => {
                        this.start();
                    });
                    return;
                }
                if (this.isDelayRun()) {
                    setTimeout(() => {
                        this.start();
                    }, 0);
                    return;
                }
                this.start();
            }
        }
        class Componse {
            constructor() {
                this.list = [];
            }
            add(node) {
                this.list.push(node);
            }
            execute() {
                for (let node of this.list) {
                    node.execute();
                }
            }
        }
        class Baidu extends Componse {
            constructor() {
                super();
            }
            add(obj) {
                let node = new Node(obj);
                super.add(node);
                return this;
            }
            addReady(obj) {
                let node = new Node(obj).setReadyRun();
                super.add(node);
                return this;
            }
            addDealy(obj) {
                let node = new Node(obj).setDealyRun();
                super.add(node);
                return this;
            }
            addDelayAndReady(obj) {
                this.addDealy(obj);
                this.addReady(obj);
                return this;
            }
            execute() {
                super.execute();
            }
        }
        return Baidu;
    })();
    class UrlEditor {
        constructor(url) {
            this.url = new URL(url);
        }
        getFinalUrl() {
            return this.url.href;
        }
        hasParam(name) {
            return this.url.searchParams.has(name);
        }
        getParamValue(name) {
            return String(this.url.searchParams.get(name));
        }
        setParam(key, value) {
            this.url.searchParams.set(key, value);
        }
    }
    class Component {
        constructor() {
            this.list = [];
        }
        add(obj) {
            this.list.push(obj);
        }
        execute() {
            for (let obj of this.list) {
                obj.execute();
            }
        }
    }
    class Docker {
        createDocker() {
            return $("<div>");
        }
    }
    class Leaf extends Component {
        constructor(obj) {
            super();
            this.obj = obj;
        }
        insert() {
            this.obj.insertNode();
        }
        add(obj) {
            super.add(obj);
        }
        execute() {
            this.insert();
            super.execute();
        }
    }
    class Router {
        getCurrentPagePathURL() {
            return location.origin + location.pathname;
        }
        isRouterPage(routers) {
            const currentRouterURL = this.getCurrentPagePathURL();
            return routers.some((routerURL) => {
                return routerURL === currentRouterURL;
            });
        }
        addRoute(routers, factory) {
            if (this.isRouterPage(routers)) {
                factory.create();
            }
        }
    }
    class BaiduSearch {
        constructor() {
            this.DEFAULT_URL = "https://www.baidu.com/s?ie=utf-8";
            this.URL = new UrlEditor(this.DEFAULT_URL);
        }
        addSearchKeyword(searchContent) {
            searchContent = searchContent.trim();
            this.URL.setParam("wd", searchContent);
            return this;
        }
        openRandonNumber() {
            let randomBase64Code = window.btoa(new Date().getTime()).replace(/=+/g, "");
            return this;
        }
        addRN(rate) {
            this.URL.setParam("rn", String(rate));
            return this;
        }
        addPN(order) {
            this.URL.setParam("pn", String(order));
            return this;
        }
        addParam(key, value) {
            this.URL.setParam(key, value);
            return this;
        }
        addBaiduDeaultParam() {
            let that = this;
            let $inputs = $("#form>input");
            $inputs.each(function (index, element) {
                let $element = $(element);
                let name = String($element.attr("name"));
                let value = String($element.val());
                if (name != "" && value != "") {
                    that.addParam(name, value);
                }
            });
            this.addParam("tn", "baidu");
            return this;
        }
        getFinalURL() {
            return this.URL.getFinalUrl();
        }
        openWebWithNewWindow() {
            let url = this.getFinalURL();
            window.open(url);
        }
        openWebWithCurrentWindow() {
            let url = this.getFinalURL();
            location.href = url;
        }
        tiggerBaiduSumbit() {
            let searchContent = String($(".bd-barbox-input").val()).trim();
            if (searchContent.length > 0) {
                $("#form #kw").attr("value", searchContent.trim());
                $("#form").trigger("submit");
            }
        }
    }
    class SearchResultsFilter {
        constructor() {
            this.regulars = [
                `[style]`,
                `[tpl="b2b_straight"]`,
                `[tpl="short_video_pc"]`,
                `[tpl="trade_purchase"]`,
                `[tpl="img_address"]`,
                `[tpl="ads_b2c_universal_card"]`,
                `[tpl="zp_exact_new"]`,
                `[tpl="se_com_irregular_gallery"]`,
                `[tpl="ask_doctor"]`,
                `[tpl="med_qa"]`,
                `[tpl^="timeliness"]`,
                `[tpl^="sp_realtime"]`,
                `[tpl="wenda_abstract_pc"]`,
                `[tpl="jingyan_summary"]`,
                `[tpl="se_st_single_video_zhanzhang"]`,
                `[tpl="open_source_software]"`,
                `[data-click*="safe:1|t:1"]`
            ];
        }
        getFilterGularExpress() {
            let filterRegular = "div[tpl]";
            filterRegular = this.regulars.reduce(function (prev, current) {
                return prev + `:not(${current})`;
            }, filterRegular);
            return filterRegular;
        }
        removeInvalidItem(items) {
            let filterRegular = this.getFilterGularExpress();
            let $items = $(items);
            $items = $items.filter(filterRegular);
            return $items;
        }
    }
    class SessionStorage {
        constructor(key, value) {
            this.key = key;
            this.value = value;
        }
        hasStorage() {
            return sessionStorage.getItem(this.key) === this.value;
        }
        storage() {
            sessionStorage.setItem(this.key, this.value);
        }
        clear() {
            sessionStorage.removeItem(this.key);
        }
    }
    class StyleContent {
        getStlyeForIndex() {
            return INLINE_STYLE_INDEX;
        }
        getStyleForBase() {
            return INLINE_STYLE_BASE;
        }
        getStyleForMenu() {
            return INLINE_STYLE_MENU;
        }
        getStyleForSidebar() {
            return INLINE_SIDEBAE;
        }
        getStyleForLayoutOneCenter() {
            return INLINE_STYLE_ONE_CENTER;
        }
        getStyleForLayoutTwoCenter() {
            return INLINE_STYLE_TWO_CENTER;
        }
        getStyleForLayoutThreeCenter() {
            return INLINE_STYLE_THREE_CENTER;
        }
    }
    class StyleControl {
        constructor() {
            this.GM = GM;
            this.cache = "";
        }
        reset() {
            this.cache = "";
        }
        addStyle() {
            this.GM.addStyle(this.cache);
        }
        add(style) {
            this.cache = this.cache.concat(style);
            return this;
        }
        end() {
            this.addStyle();
            this.reset();
        }
    }
    class SyncRequest {
        constructor(dealer) {
            this.GM = GM;
            this.responseType = "json";
            this.dealer = dealer;
        }
        deal(response) {
            this.dealer.deal(response);
        }
        setResponseType(responseType) {
            this.responseType = responseType;
            return this;
        }
        request(requestURL) {
            let that = this;
            this.GM.xmlhttpRequest({
                method: "GET",
                url: requestURL,
                timeout: 3000,
                responseType: that.responseType,
                headers: {
                    "User-Agent": navigator.userAgent,
                    "Cookie": document.cookie,
                },
                onload: (response) => {
                    if (response.status === 200 ||
                        response.status === 304) {
                        that.deal(response.response);
                    }
                }
            });
        }
    }
    class OptionSelect extends OptionControl {
        constructor(layoutConfig) {
            super(layoutConfig.saveName, layoutConfig.defaultValue);
        }
    }
    class PageLayoutOption extends OptionSelect {
        constructor() {
            super(LAYOUT_CONFIG);
        }
        getCurrentPageType() {
            return Number(super.getOptionValue());
        }
        getName() {
            return super.getOptionName();
        }
        setPageLayoutType(value) {
            return super.setOption(value);
        }
    }
    class SilderBarOption extends OptionSelect {
        constructor() {
            super(SILDER_BAR_CONFIG);
        }
        getCurrentMode() {
            return Number(super.getOptionValue());
        }
        getName() {
            return super.getOptionName();
        }
        setMode(value) {
            return super.setOption(value);
        }
    }
    class OptionSwitch extends OptionControl {
        constructor(functionConfig) {
            super(functionConfig.saveName, functionConfig.defaultSwitch);
            this.functionName = functionConfig.functionName;
        }
        isEnable() {
            return Boolean(super.getOptionValue());
        }
        enable() {
            super.setOption(true);
        }
        disable() {
            super.setOption(false);
        }
        getName() {
            return super.getOptionName();
        }
        getFunctionName() {
            return this.functionName;
        }
    }
    class AutoNextPageSwitch extends OptionSwitch {
        constructor() {
            super(ADDITION_FUNCTION_CONFIGS.AutoNextPage);
        }
    }
    class SideToolBarSwitch extends OptionSwitch {
        constructor() {
            super(ADDITION_FUNCTION_CONFIGS.SideToolBar);
        }
    }
    let WallPaperModel;
    (function (WallPaperModel) {
        class Bing {
            constructor() {
                this.GM = GM;
                this.BING_GM_NAME = "bing_images";
                this.BING_DEFALUT_IMAGES = ["https://pic.imgdb.cn/item/5eca80bfc2a9a83be52d1cb0.jpg"];
                this.BING_REMOTE_IMAGE_URL = `https://cn.bing.com/HPImageArchive.aspx?format=js&n=8&mkt=zh-CN`;
                this.BING_HOSTNAME = `https://cn.bing.com`;
            }
            getDefaultImages() {
                return this.BING_DEFALUT_IMAGES;
            }
            saveImagesToLocal(images) {
                let key = this.BING_GM_NAME;
                this.GM.setValue(key, images);
            }
            getImagesFromLocal() {
                let key = this.BING_GM_NAME;
                return this.GM.getValue(key) || this.getDefaultImages();
            }
            hasCacheLocalImage() {
                let images = this.getImagesFromLocal();
                return images.length > 1;
            }
        }
        WallPaperModel.Bing = Bing;
    })(WallPaperModel || (WallPaperModel = {}));
    (function (WallPaperModel) {
        class Images {
            constructor(o) {
                this.images1 = [
                    "http://img.netbian.com/file/2019/0808/7062756ab554ab172d31ae293d2fa9e6.jpg",
                    "https://ss0.bdstatic.com/94oJfD_bAAcT8t7mm9GUKT-xh_/timg?image&quality=100&size=b4000_4000&sec=1589899749&di=c016b13a5a98e2dbd6a207b8bb776580&src=http://pic1.win4000.com/wallpaper/2018-11-05/5bdfd64cbcd82.jpg",
                    "https://desk-fd.zol-img.com.cn/t_s1920x1080c5/g5/M00/09/04/ChMkJ14S2WmIcR4MAASTED6paWcAAwKOAIG18EABJMo577.jpg",
                    "https://desk-fd.zol-img.com.cn/t_s1920x1080c5/g5/M00/09/04/ChMkJ14S2UKIQ7V8AAHhgCbEWSkAAwKNwAT-XgAAeGY606.jpg",
                    "https://desk-fd.zol-img.com.cn/t_s2560x1440c5/g5/M00/09/04/ChMkJ14S2UqIAJhXAAZvffHvn_oAAwKNwD6CH8ABm-V325.jpg",
                    "https://desk-fd.zol-img.com.cn/t_s2560x1600c5/g5/M00/09/04/ChMkJl4S2W2INN3iACCh3pDxPQMAAwKOAKZtUsAIKH2841.jpg",
                    "https://desk-fd.zol-img.com.cn/t_s1920x1080c5/g5/M00/09/0D/ChMkJ1e2_KKIPLgPAAUyABcaCxEAAUkhANeazAABTIY478.jpg",
                    "https://desk-fd.zol-img.com.cn/t_s1920x1080c5/g5/M00/02/08/ChMkJ1bKzS-IMP1aAEMHk65qAm4AALI-QAAAAAAQwer218.jpg",
                    "https://desk-fd.zol-img.com.cn/t_s1920x1080c5/g5/M00/02/08/ChMkJlbKzTCIKFkcACIWcwMYvWsAALI-QDORlYAIhaL394.jpg",
                    "https://desk-fd.zol-img.com.cn/t_s1920x1080c5/g5/M00/02/08/ChMkJlbKzTGIEcieAFFa4NXfo20AALI-QEr_lIAUVr4406.jpg",
                    "https://desk-fd.zol-img.com.cn/t_s1920x1080c5/g5/M00/02/03/ChMkJlbKx2qIKB_ZAAKJbsI4qNMAALHzQFvTQ0AAomG519.jpg",
                    "https://desk-fd.zol-img.com.cn/t_s1920x1080c5/g4/M09/0F/01/ChMly12oJfuIDM0ZAAfuqk1g34AAAYKzgNEBzEAB-7C780.jpg",
                ];
                this.images2 = [
                    "https://momentumdash.com/backgrounds/01.jpg",
                    "https://momentumdash.com/backgrounds/02.jpg",
                    "https://momentumdash.com/backgrounds/03.jpg",
                    "https://momentumdash.com/backgrounds/04.jpg",
                    "https://momentumdash.com/backgrounds/05.jpg",
                    "https://momentumdash.com/backgrounds/06.jpg",
                    "https://momentumdash.com/backgrounds/07.jpg",
                    "https://momentumdash.com/backgrounds/08.jpg",
                    "https://momentumdash.com/backgrounds/09.jpg",
                    "https://momentumdash.com/backgrounds/10.jpg",
                    "https://momentumdash.com/backgrounds/11.jpg",
                    "https://momentumdash.com/backgrounds/12.jpg",
                    "https://momentumdash.com/backgrounds/13.jpg",
                ];
                this.o = o;
            }
            getImages() {
                return this.o.getImages();
            }
            getRandomIndex(minNumber, maxNumber) {
                return parseInt(Math.random() * (maxNumber - minNumber + 1) + minNumber, 10);
            }
            getMaxNumber(images) {
                return images.length - 1;
            }
            getMinNumber() {
                return 0;
            }
            getImageURL() {
                let images = this.getImages();
                let maxNumber = this.getMaxNumber(images);
                let minNumber = this.getMinNumber();
                let index = this.getRandomIndex(minNumber, maxNumber);
                return images[index];
            }
        }
        WallPaperModel.Images = Images;
    })(WallPaperModel || (WallPaperModel = {}));
    (function (WallPaperModel) {
        class SaveRequestWallPaterBing extends WallPaperModel.Bing {
            getAbsoluteImagesURL(images) {
                let hostName = this.BING_HOSTNAME;
                return images.map((image) => {
                    return new URL(image.url, hostName).href;
                });
            }
            saveImagesToLocal(images) {
                super.saveImagesToLocal(images);
            }
            deal(response) {
                let images = this.getAbsoluteImagesURL(response.images);
                this.saveImagesToLocal(images);
            }
        }
        WallPaperModel.SaveRequestWallPaterBing = SaveRequestWallPaterBing;
    })(WallPaperModel || (WallPaperModel = {}));
    (function (WallPaperModel) {
        class Tempalte {
            constructor(config) {
                this.config = config;
            }
            createImagePanelTemplate() {
                let nameBackgroundPanel = this.config.NODE_BG_UL;
                return `
                    <ul class="${nameBackgroundPanel}"></ul>
                `;
            }
            createImageItemTemplate() {
                let nameBackgroundItem = this.config.NODE_BG_LI;
                return `
                    <li class="${nameBackgroundItem}"></li>
                    `;
            }
            createImageAttribute(imageURL) {
                return `background-image: url("${imageURL}"); `;
            }
            createBingWallpaperNode(imageUrl) {
                let $ul = $(this.createImagePanelTemplate());
                let $li = $(this.createImageItemTemplate());
                let styleValue = this.createImageAttribute(imageUrl);
                $li.attr("style", styleValue);
                $ul.append($li);
                return $ul.html();
            }
        }
        WallPaperModel.Tempalte = Tempalte;
    })(WallPaperModel || (WallPaperModel = {}));
    (function (WallPaperModel) {
        class WallPaperBing extends WallPaperModel.Bing {
            hasSessionStorage() {
                let key = "wallpaper-bing";
                let value = "true";
                let session = new SessionStorage(key, value);
                if (session.hasStorage()) {
                    return true;
                }
                else {
                    session.storage();
                    return false;
                }
            }
            isNeedRequest() {
                let isNotNeedRequest = this.hasSessionStorage() && this.hasCacheLocalImage();
                return !isNotNeedRequest;
            }
            requestImagesFromRemoteBing() {
                let syncRequest = new SyncRequest(new WallPaperModel.SaveRequestWallPaterBing());
                syncRequest.request(this.BING_REMOTE_IMAGE_URL);
            }
            getImages() {
                if (this.isNeedRequest()) {
                    this.requestImagesFromRemoteBing();
                }
                return super.getImagesFromLocal();
            }
        }
        WallPaperModel.WallPaperBing = WallPaperBing;
    })(WallPaperModel || (WallPaperModel = {}));
    (function (WallPaperModel) {
        class WallpagerConfig {
            constructor() {
                this.NODE_BG_UL = "bd-bg-ul";
                this.NODE_BG_LI = "bd-bg-li";
                this.NODE_BG_DISPLAY = "bd-display";
            }
        }
        WallPaperModel.WallpagerConfig = WallpagerConfig;
    })(WallPaperModel || (WallPaperModel = {}));
    (function (WallPaperModel) {
        class WallPaperMomentumdash {
            constructor() {
                this.GM = GM;
                this.images = [
                    "https://momentumdash.com/backgrounds/01.jpg",
                    "https://momentumdash.com/backgrounds/02.jpg",
                    "https://momentumdash.com/backgrounds/03.jpg",
                    "https://momentumdash.com/backgrounds/04.jpg",
                    "https://momentumdash.com/backgrounds/05.jpg",
                    "https://momentumdash.com/backgrounds/06.jpg",
                    "https://momentumdash.com/backgrounds/07.jpg",
                    "https://momentumdash.com/backgrounds/08.jpg",
                    "https://momentumdash.com/backgrounds/09.jpg",
                    "https://momentumdash.com/backgrounds/10.jpg",
                    "https://momentumdash.com/backgrounds/11.jpg",
                    "https://momentumdash.com/backgrounds/12.jpg",
                    "https://momentumdash.com/backgrounds/13.jpg",
                ];
            }
            request(imageURL) {
                let requestURL = imageURL;
                this.GM.xmlhttpRequest({
                    method: "GET",
                    url: requestURL,
                    timeout: 3000,
                    responseType: "json",
                });
            }
            isPreloadAllImages() {
                let key = "wallpaper-Momentumdash";
                let value = "true";
                let session = new SessionStorage(key, value);
                if (session.hasStorage()) {
                    return true;
                }
                else {
                    session.storage();
                    return false;
                }
            }
            preloadAllImages() {
                for (const imageURL of this.images) {
                    this.request(imageURL);
                }
            }
            getImages() {
                return this.images;
            }
        }
    })(WallPaperModel || (WallPaperModel = {}));
    let SearchFormModel;
    (function (SearchFormModel) {
        class Action {
            constructor(Selector) {
                this.Selecor = Selector;
            }
            getInputValue() {
                return this.Selecor.$input.val();
            }
        }
        SearchFormModel.Action = Action;
        class ActionAssociateDockerShow extends Action {
            constructor(Selector) {
                super(Selector);
            }
            execute(event) {
                let $selector = this.Selecor.$associateDocker;
                if ($selector.hasClass("bd-none")) {
                    $selector.removeClass("bd-none");
                }
                this.Selecor.$associateDocker.show();
            }
        }
        SearchFormModel.ActionAssociateDockerShow = ActionAssociateDockerShow;
        class ActionAssociateDockerHide extends Action {
            constructor(Selector) {
                super(Selector);
            }
            execute(event) {
                let $associateDocker = this.Selecor.$associateDocker;
                $associateDocker.css("opacity", "0");
                setTimeout(() => {
                    $associateDocker.hide().css("opacity", "1");
                }, 200);
            }
        }
        SearchFormModel.ActionAssociateDockerHide = ActionAssociateDockerHide;
        class ActionAssociateSimilar extends Action {
            constructor(Selector) {
                super(Selector);
                this.Associate = new AssociateManager(new SearchFormModel.UpdateAssociateItem(Selector));
            }
            execute(event) {
                let inputValue = this.Selecor.$input.val();
                this.Associate.search(inputValue);
            }
        }
        SearchFormModel.ActionAssociateSimilar = ActionAssociateSimilar;
        class ActionSearchSelf extends Action {
            constructor(Selector) {
                super(Selector);
            }
            execute(event) {
                let inputValue = String(this.getInputValue()).trim();
                if (inputValue != "") {
                    new BaiduSearch().addSearchKeyword(inputValue)
                        .addBaiduDeaultParam()
                        .openWebWithCurrentWindow();
                }
            }
        }
        SearchFormModel.ActionSearchSelf = ActionSearchSelf;
        class ActionSearchBlank extends Action {
            constructor(Selector) {
                super(Selector);
            }
            execute(event) {
                let inputValue = this.getInputValue().trim();
                if (inputValue != "") {
                    new BaiduSearch().addSearchKeyword(inputValue)
                        .addBaiduDeaultParam()
                        .openWebWithCurrentWindow();
                }
            }
        }
        SearchFormModel.ActionSearchBlank = ActionSearchBlank;
        class ActionAssociateItemScrollUp extends Action {
            constructor(Selector) {
                super(Selector);
                this.ScrollAssociateItem = new SearchFormModel.ScrollAssociateItem(Selector);
            }
            execute(event) {
                this.ScrollAssociateItem.scrollUp();
            }
        }
        SearchFormModel.ActionAssociateItemScrollUp = ActionAssociateItemScrollUp;
        class ActionAssociateItemScrollDown extends Action {
            constructor(Selector) {
                super(Selector);
                this.ScrollAssociateItem = new SearchFormModel.ScrollAssociateItem(Selector);
            }
            execute(event) {
                this.ScrollAssociateItem.scrollDown();
            }
        }
        SearchFormModel.ActionAssociateItemScrollDown = ActionAssociateItemScrollDown;
        class ActionAssociatePanelHover extends Action {
            constructor(Selector) {
                super(Selector);
                this.ScrollAssociateItem = new SearchFormModel.ScrollAssociateItem(Selector);
            }
            execute(event) {
                this.ScrollAssociateItem.scrollHover();
            }
        }
        SearchFormModel.ActionAssociatePanelHover = ActionAssociatePanelHover;
        class ActionSetClickSelectedToInput extends Action {
            constructor(Selector) {
                super(Selector);
                this.ScrollAssociateItem = new SearchFormModel.ScrollAssociateItem(Selector);
            }
            execute(event) {
                this.ScrollAssociateItem.scrollHover();
            }
        }
        SearchFormModel.ActionSetClickSelectedToInput = ActionSetClickSelectedToInput;
    })(SearchFormModel || (SearchFormModel = {}));
    (function (SearchFormModel) {
        class Assistant {
            constructor() {
                this.SearchURL = new SearchFormModel.SearchURL();
                this.Element = SearchFormModel.SimpleElement.getInstance();
            }
            setInputValueFromURL() {
                let searchValue = this.SearchURL.getSearchValue();
                $(this.Element.getSelectorBarboxInput()).val(searchValue);
            }
            setInputFocus() {
                $(this.Element.getSelectorBarboxInput()).focus();
            }
        }
        SearchFormModel.Assistant = Assistant;
    })(SearchFormModel || (SearchFormModel = {}));
    (function (SearchFormModel) {
        class CheckElement {
            constructor() {
                this.Element = SearchFormModel.SimpleElement.getInstance();
            }
            hasSearchBox() {
                return $(this.Element.getSelectorBdContainer()).length > 0;
            }
        }
        SearchFormModel.CheckElement = CheckElement;
    })(SearchFormModel || (SearchFormModel = {}));
    (function (SearchFormModel) {
        class Count {
            constructor() {
                this.index = -1;
            }
            getUpperLimit(size) {
                return size - 1;
            }
            getLowerLimit() {
                return 0;
            }
            add(size) {
                let index = this.get();
                const UPPER_LIMIT = this.getUpperLimit(size);
                const LOWER_LIMIT = this.getLowerLimit();
                const isOverUpperLimit = (++index) > UPPER_LIMIT;
                if (isOverUpperLimit) {
                    index = LOWER_LIMIT;
                }
                this.set(index);
                return this;
            }
            sub(size) {
                let index = this.get();
                const UPPER_LIMIT = this.getUpperLimit(size);
                const LOWER_LIMIT = this.getLowerLimit();
                const isLessLowerLimit = (--index) < LOWER_LIMIT;
                if (isLessLowerLimit) {
                    index = UPPER_LIMIT;
                }
                this.set(index);
                return this;
            }
            set(index) {
                this.index = index;
                return this;
            }
            get() {
                return this.index;
            }
            reset() {
                this.index = -1;
            }
        }
        SearchFormModel.Count = Count;
        class SimpleCount {
            static getInstance() {
                if (!this.Count) {
                    this.Count = new Count();
                }
                return this.Count;
            }
            ;
        }
        SearchFormModel.SimpleCount = SimpleCount;
    })(SearchFormModel || (SearchFormModel = {}));
    (function (SearchFormModel) {
        class Docker {
            createDocker(template) {
                return $("<div>").append(template);
            }
        }
        SearchFormModel.Docker = Docker;
    })(SearchFormModel || (SearchFormModel = {}));
    (function (SearchFormModel) {
        class Element {
            constructor() {
                this.preClass = ".";
                this.preId = "#";
                this.bd_container = "bd-container-search";
                this.bd_docker = "bd-docker";
                this.barbox_panel = "bd-barbox-ul";
                this.barbox_item = "bd-barbox-li";
                this.barbox_center = "bd-barbox-center";
                this.barbox_input = "bd-barbox-input";
                this.barbox_button = "bd-barbox-button";
                this.associate_panel = "bd-associate-ul";
                this.associate_item = "bd-associate-li";
                this.associate_selected = "bd-associate-selected";
            }
            getClass(name) {
                return this.preClass + name;
            }
            getId(name) {
                return this.preId + name;
            }
            getNameBdContainer() {
                return this.bd_container;
            }
            getNameBdDocker() {
                return this.bd_docker;
            }
            getNameBarboxPanel() {
                return this.barbox_panel;
            }
            getNameBarboxItem() {
                return this.barbox_item;
            }
            getNameBarboxCenter() {
                return this.barbox_center;
            }
            getNameBarboxInput() {
                return this.barbox_input;
            }
            getNameBarboxButton() {
                return this.barbox_button;
            }
            getNameAssociatePanel() {
                return this.associate_panel;
            }
            getNameAssociateItem() {
                return this.associate_item;
            }
            getNameAssociateSelected() {
                return this.associate_selected;
            }
            getSelectorBdContainer() {
                return this.getClass(this.getNameBdContainer());
            }
            getSelectorBdDocker() {
                return this.getClass(this.getNameBdDocker());
            }
            getSelectorBarboxPanel() {
                return this.getClass(this.getNameBarboxPanel());
            }
            getSelectorBarboxItem() {
                return this.getClass(this.getNameBarboxItem());
            }
            getSelectorBarboxInput() {
                return this.getClass(this.getNameBarboxInput());
            }
            getSelectorBarboxButton() {
                return this.getClass(this.getNameBarboxButton());
            }
            getSelectorAssociatePanel() {
                return this.getClass(this.getNameAssociatePanel());
            }
            getSelectorAssociateItem() {
                return this.getClass(this.getNameAssociateItem());
            }
            getSelectorAssociateSelected() {
                return this.getClass(this.getNameAssociateSelected());
            }
        }
        SearchFormModel.Element = Element;
        class SimpleElement {
            static getInstance() {
                if (!this.instance) {
                    this.instance = new Element();
                }
                return this.instance;
            }
            ;
        }
        SearchFormModel.SimpleElement = SimpleElement;
    })(SearchFormModel || (SearchFormModel = {}));
    (function (SearchFormModel) {
        class Event {
            constructor(Selector) {
                this.Selecor = Selector;
            }
            isKeyDown(keyCode) {
                return keyCode === 40;
            }
            isKeyUp(keyCode) {
                return keyCode === 38;
            }
            isKeyEnter(keyCode) {
                return keyCode === 13;
            }
        }
        SearchFormModel.Event = Event;
        class EventInputFocus extends Event {
            constructor(Selector) {
                super(Selector);
            }
            listen(action) {
                this.Selecor.$input.on("focus", (event) => {
                    action.execute(event);
                    return false;
                });
            }
        }
        SearchFormModel.EventInputFocus = EventInputFocus;
        class EventInputBlur extends Event {
            constructor(Selector) {
                super(Selector);
            }
            listen(action) {
                this.Selecor.$input.on("blur", (event) => {
                    action.execute(event);
                    return false;
                });
            }
        }
        SearchFormModel.EventInputBlur = EventInputBlur;
        class EventInputKeyDownWithDown extends Event {
            constructor(Selector) {
                super(Selector);
            }
            listen(action) {
                this.Selecor.$input.on("keydown", (event) => {
                    let keyCode = event.keyCode || event.which || event.charCode;
                    if (this.isKeyDown(keyCode)) {
                        action.execute(event);
                        return false;
                    }
                });
            }
        }
        SearchFormModel.EventInputKeyDownWithDown = EventInputKeyDownWithDown;
        class EventInputKeyDownWithUp extends Event {
            constructor(Selector) {
                super(Selector);
            }
            listen(action) {
                this.Selecor.$input.on("keydown", (event) => {
                    let keyCode = event.keyCode || event.which || event.charCode;
                    if (this.isKeyUp(keyCode)) {
                        action.execute(event);
                        return false;
                    }
                });
            }
        }
        SearchFormModel.EventInputKeyDownWithUp = EventInputKeyDownWithUp;
        class EventInputKeyDownWithEnter extends Event {
            constructor(Selector) {
                super(Selector);
            }
            listen(action) {
                this.Selecor.$input.on("keydown", (event) => {
                    let keyCode = event.keyCode || event.which || event.charCode;
                    if (this.isKeyEnter(keyCode)) {
                        action.execute(event);
                        return false;
                    }
                });
            }
        }
        SearchFormModel.EventInputKeyDownWithEnter = EventInputKeyDownWithEnter;
        class EventInputChange extends Event {
            constructor(Selector) {
                super(Selector);
            }
            listen(action) {
                this.Selecor.$input.off("input propertychange").on("input propertychange", (event) => {
                    action.execute(event);
                    return false;
                });
            }
        }
        SearchFormModel.EventInputChange = EventInputChange;
        class EventButtonClick extends Event {
            constructor(Selector) {
                super(Selector);
            }
            listen(action) {
                this.Selecor.$button.on("click", (event) => {
                    action.execute(event);
                    return false;
                });
            }
        }
        SearchFormModel.EventButtonClick = EventButtonClick;
        class EventAssociatePanelMouseMove extends Event {
            constructor(Selector) {
                super(Selector);
            }
            listen(action) {
                this.Selecor.$associatePanel.on("mousemove", (event) => {
                    action.execute(event);
                    return false;
                });
            }
        }
        SearchFormModel.EventAssociatePanelMouseMove = EventAssociatePanelMouseMove;
        class EventAssociatePanelMouseEnter extends Event {
            constructor(Selector) {
                super(Selector);
            }
            listen(action) {
                this.Selecor.$associatePanel.on("mouseenter", (event) => {
                    action.execute(event);
                    return false;
                });
            }
        }
        SearchFormModel.EventAssociatePanelMouseEnter = EventAssociatePanelMouseEnter;
        class EventAssociatePanelClick extends Event {
            constructor(Selector) {
                super(Selector);
            }
            listen(action) {
                this.Selecor.$associatePanel.on("click", (event) => {
                    action.execute(event);
                    return false;
                });
            }
        }
        SearchFormModel.EventAssociatePanelClick = EventAssociatePanelClick;
    })(SearchFormModel || (SearchFormModel = {}));
    (function (SearchFormModel) {
        class ScrollAssociateItem {
            constructor(Selector) {
                this.Count = SearchFormModel.SimpleCount.getInstance();
                this.Element = SearchFormModel.SimpleElement.getInstance();
                this.Selector = Selector;
            }
            search(content) {
                let baiduSearch = new BaiduSearch();
                baiduSearch.addSearchKeyword(content)
                    .addBaiduDeaultParam()
                    .openWebWithCurrentWindow();
            }
            getItems() {
                return this.Selector.$associatePanel.find(this.Element.getSelectorAssociateItem());
            }
            getItemsSize(items) {
                return !!items ? items.length : 0;
            }
            setIputValue(associateValue) {
                this.Selector.$input.val(associateValue);
            }
            ScrollItem($items) {
                let index = this.Count.get();
                let setClassNameWithScorll = () => {
                    let nameItemSelected = this.Element.getNameAssociateSelected();
                    $items.removeClass(nameItemSelected);
                    $items.eq(index).addClass(nameItemSelected);
                };
                let setInputValue = () => {
                    let associateValue = $items.eq(index).attr("value");
                    this.setIputValue(associateValue);
                };
                setClassNameWithScorll();
                setInputValue();
            }
            scrollUp() {
                let items = this.getItems();
                let size = this.getItemsSize(items);
                this.Count.sub(size);
                this.ScrollItem(items);
            }
            scrollDown() {
                let items = this.getItems();
                let size = this.getItemsSize(items);
                this.Count.add(size);
                this.ScrollItem(items);
            }
            scrollHover_backup() {
                let $items = this.getItems();
                let nameItemHover = this.Element.getNameAssociateSelected();
                let lengthItems = $items.length;
                let isEmptyItems = lengthItems <= 0;
                if (isEmptyItems)
                    return;
                let setClassNameWithHover = (event) => {
                    let target = event.target;
                    $items.removeClass(nameItemHover);
                    if (target.nodeName.toUpperCase() == "LI") {
                        target.classList.add(nameItemHover);
                    }
                    if (target.nodeName.toUpperCase() == "SPAN") {
                        target.parentNode.classList.add(nameItemHover);
                    }
                };
                let setInputValue = () => {
                    $items.each((index, item) => {
                        let $item = $(item);
                        if ($item.hasClass(nameItemHover)) {
                            let itemValue = $item.attr("value");
                            this.setIputValue(itemValue);
                            this.Count.set(index);
                        }
                    });
                };
                setClassNameWithHover(event);
                setInputValue();
            }
            scrollHover() {
                let that = this;
                let $items = this.getItems();
                let nameItemHover = this.Element.getNameAssociateSelected();
                let lengthItems = $items.length;
                let isEmptyItems = lengthItems <= 0;
                if (isEmptyItems)
                    return;
                $items.off("mouseleave").on("mouseleave", function () {
                    let $item = $(this);
                    $item.removeClass(nameItemHover);
                });
                $items.off("mouseenter").on("mouseenter", function () {
                    let $item = $(this);
                    $items.removeClass(nameItemHover);
                    $item.addClass(nameItemHover);
                });
                $items.off("click").on("click", function () {
                    let $item = $(this);
                    let searchContent = String($item.attr("value"));
                    that.search(searchContent.trim());
                });
            }
        }
        SearchFormModel.ScrollAssociateItem = ScrollAssociateItem;
    })(SearchFormModel || (SearchFormModel = {}));
    (function (SearchFormModel) {
        class SearchURL {
            getSearchValue() {
                let currentURL = new URL(location.href);
                let searchValue = currentURL.searchParams.get("wd");
                return searchValue !== null ? decodeURIComponent(searchValue) : "";
            }
        }
        SearchFormModel.SearchURL = SearchURL;
    })(SearchFormModel || (SearchFormModel = {}));
    (function (SearchFormModel) {
        class Selector {
            constructor($docker) {
                this.Element = new SearchFormModel.Element();
                this.$docker = $docker;
                this.$input = this.search(this.Element.getSelectorBarboxInput());
                this.$button = this.search(this.Element.getSelectorBarboxButton());
                this.$associateDocker = this.search(this.Element.getSelectorBdDocker()).eq(1);
                this.$associatePanel = this.search(this.Element.getSelectorAssociatePanel());
            }
            search(selectorName) {
                return this.$docker.find(selectorName);
            }
        }
        SearchFormModel.Selector = Selector;
    })(SearchFormModel || (SearchFormModel = {}));
    (function (SearchFormModel) {
        class Template {
            constructor() {
                this.Element = SearchFormModel.SimpleElement.getInstance();
            }
        }
        class TemplateSearchBox extends Template {
            getTempalteSearchBar() {
                let nameBarboxPanel = this.Element.getNameBarboxPanel();
                let nameBarboxItem = this.Element.getNameBarboxItem();
                let nameBarboxCenter = this.Element.getNameBarboxCenter();
                let nameBarboxInput = this.Element.getNameBarboxInput();
                let nameBarboxButton = this.Element.getNameBarboxButton();
                return `
                    <div class="${nameBarboxPanel}">
                        <div class="${nameBarboxCenter}">
                            <div class="${nameBarboxItem}"><input class="${nameBarboxInput}" type="text" maxlength="255" autocomplete="off"></div>
                            <div  class="${nameBarboxItem}"><button class="${nameBarboxButton}">百度一下</button></div>
                        </div>
                    </div>
                `;
            }
            getTempalteAssociatePanel() {
                let nameAssociatePanel = this.Element.getNameAssociatePanel();
                return `
                    <ul class="${nameAssociatePanel}"></ul>
                `;
            }
            create() {
                let nameBdContainer = this.Element.getNameBdContainer();
                let nameBdDocker = this.Element.getNameBdDocker();
                return `
                    <div class="${nameBdContainer}">
                        <div class="${nameBdDocker}">${this.getTempalteSearchBar()}</div>
                        <div class="${nameBdDocker} bd-none">${this.getTempalteAssociatePanel()}</div>
                    </div>
                    `;
            }
        }
        SearchFormModel.TemplateSearchBox = TemplateSearchBox;
        class TemplateAssociateItem extends Template {
            create() {
                let nameAssociateItem = this.Element.getNameAssociateItem();
                return `
                    <li class="${nameAssociateItem}"></li>
                `;
            }
        }
        SearchFormModel.TemplateAssociateItem = TemplateAssociateItem;
    })(SearchFormModel || (SearchFormModel = {}));
    (function (SearchFormModel) {
        class UpdateAssociateItem {
            constructor(Selector) {
                this.Count = SearchFormModel.SimpleCount.getInstance();
                this.TemplateAssociateItem = new SearchFormModel.TemplateAssociateItem();
                this.Selector = Selector;
            }
            getCurrentInputVaule() {
                return this.Selector.$input.val().trim();
            }
            createTempateItem(inputValue, itemValue) {
                let pathValue = itemValue.replace(inputValue, "");
                let templateItem = this.TemplateAssociateItem.create();
                let $item = $(templateItem);
                $item.attr("value", itemValue);
                $item.html(`<span>${itemValue}</span>`);
                return $item.prop("outerHTML");
            }
            combineItemsTempate(items) {
                let template = "";
                let inputValue = this.getCurrentInputVaule();
                items.forEach((itemValue) => {
                    if (itemValue === "") {
                        template += "";
                    }
                    else {
                        template += this.createTempateItem(inputValue, itemValue);
                    }
                });
                return template;
            }
            isNotEmptyItems(items) {
                return !!items;
            }
            clearAssoicateOldItems() {
                this.Selector.$associatePanel.empty();
            }
            resetCount() {
                this.Count.reset();
            }
            insertItemsToPanel(items) {
                let itemsTemplate = this.combineItemsTempate(items);
                this.Selector.$associatePanel.append(itemsTemplate);
            }
            update(items) {
                this.clearAssoicateOldItems();
                this.resetCount();
                if (this.isNotEmptyItems(items)) {
                    this.insertItemsToPanel(items);
                }
            }
        }
        SearchFormModel.UpdateAssociateItem = UpdateAssociateItem;
    })(SearchFormModel || (SearchFormModel = {}));
    let MenuModel;
    (function (MenuModel) {
        MenuModel.MenuConfig = {
            DISABLE_NAME: "bd-none",
            CUSTOM_BUTTON_NAME: "bd-menu-btn",
            CUSTOM_DETIALS_PANEL_NAME: "bd-menu-detilas",
            OPTION_SELECT_NAME: "bd-page-select",
            OPTION_SWITCH_NAME: "bd-page-switch",
            OPTION_SAVE_NAME: "bd_menu_save",
            OPTION_SILDER_BAR_TAG_NAME: "bd-page-silderBar",
        };
    })(MenuModel || (MenuModel = {}));
    (function (MenuModel) {
        class MenuData {
            constructor() {
                this.MenuConfig = MenuModel.MenuConfig;
            }
            getCurrentPageSelectLayout() {
                return 1;
            }
        }
        MenuModel.MenuData = MenuData;
    })(MenuModel || (MenuModel = {}));
    (function (MenuModel) {
        class MenuElement {
            constructor() {
                this.Template = new MenuModel.MenuTemplate();
                this.PageLayoutOption = new PageLayoutOption();
                this.SilderBarOption = new SilderBarOption();
            }
            getSwitchContent(showContent, o) {
                return this.Template.getContentFunctionSwitch(showContent, o.isEnable(), o.getFunctionName());
            }
            getMenuPageSelectContent() {
                let currentType = this.PageLayoutOption.getCurrentPageType();
                let content = "";
                content += "<ol>页面选择";
                content += this.Template.getContentPageSelect("普通页面", LAYOUT_TYPE.General, currentType);
                content += this.Template.getContentPageSelect("单页居中", LAYOUT_TYPE.OneCenter, currentType);
                content += this.Template.getContentPageSelect("双页居中", LAYOUT_TYPE.TwoCenter, currentType);
                content += this.Template.getContentPageSelect("三页居中", LAYOUT_TYPE.ThreeCenter, currentType);
                content += "</ol>";
                return content;
            }
            getMenuPageFunctionSwitchContent() {
                let content = "";
                content += "<ol>功能选择";
                content += this.getSwitchContent("自动下一页", new AutoNextPageSwitch());
                content += this.getSwitchContent("开启侧边栏", new SideToolBarSwitch());
                content += "</ol>";
                return content;
            }
            getMenuSaveButtonConent(saveButtonName) {
                let content = "";
                content += "<ol>";
                content += `<input id="${saveButtonName}" type = "button" value = "保存" >`;
                content += "</ol>";
                return content;
            }
            getMenuCustomButtonHTML(buttonName) {
                return `<a id=${buttonName}>自定义</a>`;
            }
            getMenuPageSliderBar() {
                let currentMode = this.SilderBarOption.getCurrentMode();
                let content = "";
                content += "<ol>页面选择";
                content += this.Template.getContentSilderBar("自动", SILTER_BAR_MODE.auto, currentMode);
                content += this.Template.getContentSilderBar("显示", SILTER_BAR_MODE.show, currentMode);
                content += this.Template.getContentSilderBar("隐藏", SILTER_BAR_MODE.hidden, currentMode);
                content += "</ol>";
                return content;
            }
            getMenuDetialPanelHTML(detialPanelName, saveButtonName) {
                return `<div id="${detialPanelName}">
                            <div class="bt-menu-piece">
                                ${this.getMenuPageSelectContent()}
                                ${this.getMenuPageFunctionSwitchContent()}
                                ${this.getMenuSaveButtonConent(saveButtonName)}
                            </div>
                        </div>`;
            }
        }
        MenuModel.MenuElement = MenuElement;
    })(MenuModel || (MenuModel = {}));
    (function (MenuModel) {
        class MenuEvent {
            constructor() {
                this.MenuConfig = MenuModel.MenuConfig;
                this.UserConfigManager = new UserConfigManager();
            }
            refreshWeb() {
                location.href = location.href;
            }
            saveUserConfig() {
                this.UserConfigManager.savePageLayoutSelected();
                this.UserConfigManager.saveAdditionFuction();
                this.refreshWeb();
            }
            bindSaveEvent() {
                let saveID = "#" + this.MenuConfig.OPTION_SAVE_NAME;
                let $save = $(saveID);
                $save.off("click").on("click", this, () => {
                    $save.off("click");
                    this.saveUserConfig();
                    return false;
                });
            }
            bindCustonEvent() {
                let customButtonID = "#" + this.MenuConfig.CUSTOM_BUTTON_NAME;
                let detialsPanelID = "#" + this.MenuConfig.CUSTOM_DETIALS_PANEL_NAME;
                let $customButton = $(customButtonID);
                let $detialsPanel = $(detialsPanelID);
                let hiddenName = this.MenuConfig.DISABLE_NAME;
                $customButton.off("click").on("click", (e) => {
                    $detialsPanel.toggleClass(hiddenName);
                    return false;
                });
            }
            hideDetailPanel() {
                let detialsPanelID = "#" + this.MenuConfig.CUSTOM_DETIALS_PANEL_NAME;
                let $detialsPanel = $(detialsPanelID);
                let hiddenName = this.MenuConfig.DISABLE_NAME;
                $detialsPanel.addClass(hiddenName);
            }
            blurClickHideDetailPanel() {
                let detialsPanelID = "#" + this.MenuConfig.CUSTOM_DETIALS_PANEL_NAME;
                let rule = `:not(${detialsPanelID})`;
                $("#container").off("click").on('click', rule, () => {
                    this.hideDetailPanel();
                });
            }
        }
        MenuModel.MenuEvent = MenuEvent;
        class UserConfigManager {
            constructor() {
                this.MenuConfig = MenuModel.MenuConfig;
                this.PageLayoutOption = new PageLayoutOption();
                this.AutoNextPageSwitch = new AutoNextPageSwitch();
                this.SideToolBarSwitch = new SideToolBarSwitch();
            }
            savePageLayoutSelected() {
                let that = this;
                let containerRule = `#${this.MenuConfig.CUSTOM_DETIALS_PANEL_NAME}`;
                let radioRule = `input[name=${this.MenuConfig.OPTION_SELECT_NAME}]`;
                let $radios = $(containerRule).find(radioRule);
                $radios.each(function (index, element) {
                    let $radio = $(this);
                    if ($radio.prop('checked')) {
                        let option = Number($radio.attr("value"));
                        switch (option) {
                            case LAYOUT_TYPE.General:
                                that.PageLayoutOption.setPageLayoutType(LAYOUT_TYPE.General);
                                break;
                            case LAYOUT_TYPE.OneCenter:
                                that.PageLayoutOption.setPageLayoutType(LAYOUT_TYPE.OneCenter);
                                break;
                            case LAYOUT_TYPE.TwoCenter:
                                that.PageLayoutOption.setPageLayoutType(LAYOUT_TYPE.TwoCenter);
                                break;
                            case LAYOUT_TYPE.ThreeCenter:
                                that.PageLayoutOption.setPageLayoutType(LAYOUT_TYPE.ThreeCenter);
                                break;
                            default:
                                that.PageLayoutOption.setPageLayoutType(LAYOUT_TYPE.General);
                                break;
                        }
                        return;
                    }
                });
            }
            saveAdditionFuction() {
                let that = this;
                let containerRule = `#${this.MenuConfig.CUSTOM_DETIALS_PANEL_NAME}`;
                let switchRule = `input[name=${this.MenuConfig.OPTION_SWITCH_NAME}]`;
                let $switchs = $(containerRule).find(switchRule);
                $switchs.each(function (index, element) {
                    let $selector = $(this);
                    let functionName = Number($selector.attr("value"));
                    if (functionName == ADDITION_FUNCTION.AutoNextPage) {
                        if ($selector.prop('checked')) {
                            that.AutoNextPageSwitch.enable();
                        }
                        else {
                            that.AutoNextPageSwitch.disable();
                        }
                    }
                    if (functionName == ADDITION_FUNCTION.SideToolBar) {
                        if ($selector.prop('checked')) {
                            that.SideToolBarSwitch.enable();
                        }
                        else {
                            that.SideToolBarSwitch.disable();
                        }
                    }
                });
            }
        }
        MenuModel.UserConfigManager = UserConfigManager;
    })(MenuModel || (MenuModel = {}));
    (function (MenuModel) {
        class MenuTemplate {
            constructor() {
                this.MenuConfig = MenuModel.MenuConfig;
            }
            getContentPageSelect(content, layoutType, currentlayoutType) {
                let checked = layoutType === currentlayoutType ? "checked" : "";
                return `<li><input type="radio" name="${this.MenuConfig.OPTION_SELECT_NAME}" value="${layoutType}" ${checked}>${content}</li>`;
            }
            getContentFunctionSwitch(showContent, isEnable, additionFuntionName) {
                let checked = isEnable ? "checked" : "";
                return `<li><input type="checkbox" name="${this.MenuConfig.OPTION_SWITCH_NAME}"  value="${additionFuntionName}" ${checked}>${showContent}</li>`;
            }
            getContentSilderBar(showText, mode, currentMode) {
                let checked = (mode === currentMode) ? "checked" : "";
                return `<li><input type="radio"  name="${this.MenuConfig.OPTION_SILDER_BAR_TAG_NAME}" value="${mode}" ${checked}>${showText}</li>`;
            }
        }
        MenuModel.MenuTemplate = MenuTemplate;
    })(MenuModel || (MenuModel = {}));
    let SearchResult;
    (function (SearchResult) {
        class Cache {
            constructor() {
                this.caches = [];
            }
            hasCache() {
                return (this.caches.length > 0) ? true : false;
            }
            getCache() {
                return this.caches.shift();
            }
            add(content) {
                this.caches.push(content);
            }
        }
        SearchResult.Cache = Cache;
    })(SearchResult || (SearchResult = {}));
    (function (SearchResult) {
        SearchResult.Configs = {
            tplBlackLists: [
                "med_qa",
                "bjh_addressing",
                "recommend_list",
                "ads_b2c_universal_card",
                "sp_hot_sale",
                "b2b_straight",
                "b2b_factory2",
                "vmp_zxenterprise_new",
                "short_video",
            ]
        };
    })(SearchResult || (SearchResult = {}));
    (function (SearchResult) {
        class Fetch {
            constructor() {
                this.configs = SearchResult.Configs;
                this.Cache = new SearchResult.Cache();
                this.BaiduUrl = new UrlEditor(location.href);
                this.count = 0;
                this.request();
            }
            getNextPageURL() {
                this.Search = new BaiduSearch();
                this.Search.addSearchKeyword(this.BaiduUrl.getParamValue("wd"));
                this.Search.addPN(this.count);
                this.count += 30;
                this.Search.addRN(30);
                return this.Search.getFinalURL();
            }
            request() {
                let url = this.getNextPageURL();
                GM.xmlhttpRequest({
                    method: "GET",
                    url: url,
                    timeout: 3000,
                    responseType: "text",
                    headers: {
                        "User-Agent": navigator.userAgent,
                        "Cookie": document.cookie,
                    },
                    onload: (response) => {
                        if (response.status === 200 ||
                            response.status === 304) {
                            this.Cache.add(response.responseText);
                        }
                    },
                    onerror: (response) => {
                        console.error(response);
                    }
                });
            }
            run() {
                this.request();
                if (this.Cache.hasCache()) {
                    return this.Cache.getCache();
                }
                else {
                    return "";
                }
            }
        }
        SearchResult.Fetch = Fetch;
    })(SearchResult || (SearchResult = {}));
    (function (SearchResult) {
        class Filter {
            constructor() {
                this.config = SearchResult.Configs;
            }
            isAds(item) {
                let id = item.attr("id");
                if (id == "1") {
                    let items = $(item).find(".se_st_footer>a");
                    for (let i = 0, item; item = items[i++];) {
                        if ($(item).text() == "广告") {
                            return true;
                        }
                    }
                }
                return false;
            }
            isDryTpl(item) {
                let tplCurrentContent = item.attr("tpl");
                for (let tplBlackContent of this.config.tplBlackLists) {
                    if (tplBlackContent === tplCurrentContent) {
                        return true;
                    }
                }
                return false;
            }
            isWhiteItem(item) {
                let isRemove = false;
                if (!isRemove) {
                    isRemove = this.isAds(item);
                }
                if (!isRemove) {
                    isRemove = this.isDryTpl(item);
                }
                return isRemove ? false : true;
            }
            RemoveDryItem(items) {
                let temp = [];
                for (let i = 0, item; item = items[i++];) {
                    let $item = $(item);
                    let isNormal = this.isWhiteItem($item);
                    if (!isNormal) {
                        $item.remove();
                        continue;
                    }
                    temp.push(item);
                }
                return $(temp);
            }
            run(items) {
                return this.RemoveDryItem(items);
            }
        }
        SearchResult.Filter = Filter;
    })(SearchResult || (SearchResult = {}));
    (function (SearchResult) {
        class Manager {
            constructor() {
                this.Filter = new SearchResult.Filter();
                this.Fetch = new SearchResult.Fetch();
            }
            filterInvalidSearchResult(items) {
                return this.Filter.run(items);
            }
            getCurrentPageSerachResult() {
                let items = $("#content_left>div[id]");
                return this.filterInvalidSearchResult(items);
            }
            getNextPageSearchResult() {
                this.Fetch.run();
            }
            run() {
                console.log("SearchResultManager");
                this.getNextPageSearchResult();
            }
        }
        SearchResult.Manager = Manager;
    })(SearchResult || (SearchResult = {}));
    let SideToolBarModel;
    (function (SideToolBarModel) {
        SideToolBarModel.Configs = {
            SIDEBAR_NAME: "bd_sidebar",
        };
    })(SideToolBarModel || (SideToolBarModel = {}));
    (function (SideToolBarModel) {
        class Element {
            constructor() {
                this.Configs = SideToolBarModel.Configs;
                this.SIDEBAR_TOOLBAR_ITEMS = SIDEBAR_TOOLBAR_ITEMS;
            }
            getSiderbarItemsContent() {
                let content = "";
                for (let [name, value] of Object.entries(this.SIDEBAR_TOOLBAR_ITEMS)) {
                    content += `<li value=${value}>${name}</li>`;
                }
                return content;
            }
            getContainerHTML() {
                return `
                    <div id="${this.Configs.SIDEBAR_NAME}">
                    </div>
                   
                    
                `;
            }
            getItemsHTML() {
                return `
                    
                     <ol>
                        ${this.getSiderbarItemsContent()}
                    </ol>
                    
                   
                `;
            }
            getSignHTML() {
                return `<div class="bd_siderbar_sign">
                            <div class="box">
                                <div class="chevron"></div>
                                <div class="chevron"></div>
                                <div class="chevron"></div>
                            </div>
                            
                        </div>`;
            }
        }
        SideToolBarModel.Element = Element;
    })(SideToolBarModel || (SideToolBarModel = {}));
    (function (SideToolBarModel) {
        class SideToolBar {
            constructor() {
                this.Element = new SideToolBarModel.Element();
            }
            useThirdSearch(event) {
                let $target = $(event.target);
                let templateURL = String($target.attr("value"));
                let searchContent = new UrlEditor(location.href).getParamValue("wd").trim();
                searchContent = decodeURIComponent(searchContent);
                let finalURL = templateURL.replace("%s", encodeURIComponent(searchContent));
                location.href = finalURL;
            }
            bindClickEvent($selector) {
                $selector.off("click").on("click", "li", (event) => {
                    this.useThirdSearch(event);
                    return false;
                });
            }
            getSideToolBar() {
                let containerHTML = this.Element.getContainerHTML();
                let itemsHTML = this.Element.getItemsHTML();
                let $container = $(containerHTML);
                let $items = $(itemsHTML);
                $container.append($items);
                this.bindClickEvent($container);
                return $container;
            }
        }
        SideToolBarModel.SideToolBar = SideToolBar;
    })(SideToolBarModel || (SideToolBarModel = {}));
    class IndexPageInjectStyles {
        constructor() {
            this.StyleContent = new StyleContent();
        }
        construct() {
        }
        start() {
            let style = new StyleControl();
            style.add(this.StyleContent.getStlyeForIndex());
            style.end();
        }
    }
    class ResultPageInjectStyles {
        constructor() {
            this.StyleContent = new StyleContent();
            this.PageLayoutOption = new PageLayoutOption();
        }
        start() {
            let style = new StyleControl();
            let layoutType = this.PageLayoutOption.getCurrentPageType();
            style.add(this.StyleContent.getStyleForBase());
            style.add(this.StyleContent.getStyleForMenu());
            style.add(this.StyleContent.getStyleForSidebar());
            switch (layoutType) {
                case LAYOUT_TYPE.OneCenter:
                    style.add(this.StyleContent.getStyleForLayoutOneCenter());
                    break;
                case LAYOUT_TYPE.TwoCenter:
                    style.add(this.StyleContent.getStyleForLayoutTwoCenter());
                    break;
                case LAYOUT_TYPE.ThreeCenter:
                    style.add(this.StyleContent.getStyleForLayoutThreeCenter());
                    break;
                default:
                    break;
            }
            style.end();
        }
    }
    class CustomMenu {
        constructor() {
            this.Template = new MenuModel.MenuElement();
            this.MenuEvent = new MenuModel.MenuEvent();
            this.MenuCustomButton = new MenuModel.MenuCustomButton(this.Template);
            this.MenuDetialsPanel = new MenuModel.MenuCustomDetials(this.Template);
        }
        insertMenuCustomButton() {
            if (!this.MenuCustomButton.hasCustomButton()) {
                let $container = $("#u");
                let div = this.MenuCustomButton.getCustomButtonHTML();
                $container.prepend(div);
            }
        }
        insertMenuDetailPanel() {
            if (!this.MenuDetialsPanel.hasDetailsPanel()) {
                let $container = $("#u");
                let div = this.MenuDetialsPanel.getDetaialPanelHTML();
                $container.append(div);
            }
        }
        bindCustomButtonEvent() {
            this.MenuEvent.bindCustonEvent();
        }
        bindSaveEvent() {
            this.MenuEvent.bindSaveEvent();
        }
        blurClickHideDetailPanel() {
            this.MenuEvent.blurClickHideDetailPanel();
        }
        hideDetailPanel() {
            this.MenuEvent.hideDetailPanel();
        }
        start() {
            this.insertMenuCustomButton();
            this.insertMenuDetailPanel();
            this.hideDetailPanel();
            this.bindCustomButtonEvent();
            this.bindSaveEvent();
            this.blurClickHideDetailPanel();
        }
    }
    (function (MenuModel) {
        class MenuCustomButton {
            constructor(Template) {
                this.menuConfig = MenuModel.MenuConfig;
                this.buttonName = this.menuConfig.CUSTOM_BUTTON_NAME;
                this.buttonID = "#" + this.buttonName;
                this.Template = Template;
            }
            getCustomButtonHTML() {
                return this.Template.getMenuCustomButtonHTML(this.buttonName);
            }
            hasCustomButton() {
                return $(this.buttonID).length > 0 ? true : false;
            }
        }
        MenuModel.MenuCustomButton = MenuCustomButton;
    })(MenuModel || (MenuModel = {}));
    (function (MenuModel) {
        class MenuCustomDetials {
            constructor(Template) {
                this.MenuConfig = MenuModel.MenuConfig;
                this.Template = Template;
            }
            getDetaialPanelHTML() {
                return this.Template.getMenuDetialPanelHTML(this.MenuConfig.CUSTOM_DETIALS_PANEL_NAME, this.MenuConfig.OPTION_SAVE_NAME);
            }
            hasDetailsPanel() {
                let detailsPanelID = "#" + this.MenuConfig.CUSTOM_DETIALS_PANEL_NAME;
                return $(detailsPanelID).length > 0 ? true : false;
            }
        }
        MenuModel.MenuCustomDetials = MenuCustomDetials;
    })(MenuModel || (MenuModel = {}));
    class AddBingWallpaper {
        start() {
            let bingWallpater = new WallPaperModel.BingWallpaper();
            bingWallpater.insertBingWallpaperNode();
        }
    }
    (function (WallPaperModel) {
        class BingWallpaper {
            constructor() {
                this.config = new WallPaperModel.WallpagerConfig();
                this.isExcuteFlagName = "bd-BingWallpaper";
                this.isExcuteFlagClassName = "." + this.isExcuteFlagName;
            }
            createBingWallpaperNode(imageUrl) {
                let template = new WallPaperModel.Tempalte(this.config);
                return template.createBingWallpaperNode(imageUrl);
            }
            getBingWallpaperNode() {
                let images = new WallPaperModel.Images(new WallPaperModel.WallPaperBing());
                let url = images.getImageURL();
                return this.createBingWallpaperNode(url);
            }
            isExitNode() {
                return $(this.isExcuteFlagClassName).length > 0;
            }
            insertBingWallpaperNode() {
                if (!this.isExitNode()) {
                    let $node = $(this.getBingWallpaperNode());
                    $node.addClass(this.isExcuteFlagName);
                    $("body").append($node);
                }
            }
        }
        WallPaperModel.BingWallpaper = BingWallpaper;
    })(WallPaperModel || (WallPaperModel = {}));
    (function (SearchFormModel) {
        class Control {
            constructor() {
                this.isNewWindowSearch = false;
                this.Assistant = new SearchFormModel.Assistant();
                this.$docker = this.createDocker();
                this.Selector = new SearchFormModel.Selector(this.$docker);
            }
            createDocker() {
                return new SearchFormModel.Docker().createDocker(new SearchFormModel.TemplateSearchBox().create());
            }
            hasSearchBoxAtDom() {
                return new SearchFormModel.CheckElement().hasSearchBox();
            }
            bind(Event, Action) {
                new Event(this.Selector).listen(new Action(this.Selector));
            }
            events() {
                this.bind(SearchFormModel.EventInputFocus, SearchFormModel.ActionAssociateDockerShow);
                this.bind(SearchFormModel.EventInputFocus, SearchFormModel.ActionAssociateSimilar);
                this.bind(SearchFormModel.EventInputBlur, SearchFormModel.ActionAssociateDockerHide);
                this.bind(SearchFormModel.EventInputChange, SearchFormModel.ActionAssociateSimilar);
                this.bind(SearchFormModel.EventInputKeyDownWithUp, SearchFormModel.ActionAssociateItemScrollUp);
                this.bind(SearchFormModel.EventInputKeyDownWithDown, SearchFormModel.ActionAssociateItemScrollDown);
                this.bind(SearchFormModel.EventAssociatePanelMouseEnter, SearchFormModel.ActionAssociatePanelHover);
                this.bind(SearchFormModel.EventInputKeyDownWithEnter, SearchFormModel.ActionSearchSelf);
                this.bind(SearchFormModel.EventButtonClick, SearchFormModel.ActionSearchSelf);
            }
            insertDockerToDom(containerName) {
                $(containerName).append(this.$docker);
            }
            setInputValueFromURL() {
                this.Assistant.setInputValueFromURL();
            }
            setInputFocus() {
                this.Assistant.setInputFocus();
            }
            setNewWindowSearch() {
                this.isNewWindowSearch = true;
            }
            start(containerName) {
                if (!this.hasSearchBoxAtDom()) {
                    this.events();
                    this.insertDockerToDom(containerName);
                }
            }
        }
        SearchFormModel.Control = Control;
        class ConcreteControl extends Control {
            constructor() {
                super();
                this.isInputValueFromURL = false;
                this.isInputFocus = false;
            }
            executeCallback() {
                for (const fn of this.callbacks) {
                    fn();
                }
            }
            insertElementToDom() {
                $(this.targetContainer).append();
            }
            setPageIndex() {
                this.targetContainer = "#lg";
            }
            setPageResult() {
                this.targetContainer = ".s_form";
            }
            setInputFocus() {
                this.isInputFocus = true;
            }
            setInputValueFromURL() {
                this.isInputValueFromURL = true;
            }
            setNewWindowSearch() {
                super.setNewWindowSearch();
            }
            start() {
                super.start(this.targetContainer);
                if (!!this.isInputValueFromURL) {
                    super.setInputValueFromURL();
                }
                if (!!this.isInputFocus) {
                    super.setInputFocus();
                }
            }
        }
        SearchFormModel.ConcreteControl = ConcreteControl;
    })(SearchFormModel || (SearchFormModel = {}));
    class ResultPageAddSearchForm {
        start() {
            let control = new SearchFormModel.ConcreteControl();
            control.setPageResult();
            control.setInputValueFromURL();
            control.start();
        }
    }
    class IndexPageAddSearchForm {
        start() {
            let control = new SearchFormModel.ConcreteControl();
            control.setPageIndex();
            control.setInputFocus();
            control.start();
        }
    }
    class LayoutControl {
        constructor() {
            this.SearchResultManager = new SearchResult.Manager();
            this.LayoutElements = new LayoutElements();
            this.AutoNextPageSwitch = new AutoNextPageSwitch();
        }
        getListsHTML(ListTotal) {
            let listsHTML = "";
            for (let i = 0; i < ListTotal; i++) {
                listsHTML = listsHTML + this.LayoutElements.getListHTML();
            }
            return listsHTML;
        }
        getContainer(ListTotal) {
            let $container = $(this.LayoutElements.getContainerHTML());
            let $dock = $(this.LayoutElements.getDockHTML());
            let $lists = $(this.getListsHTML(ListTotal));
            $dock.append($lists);
            $container.append($dock);
            return $container;
        }
        insertListHTMLToWeb(ListTotal) {
            let $html = $("#content_left");
            let $container = this.getContainer(ListTotal);
            $html.after($container);
        }
        movePageResultToList() {
            let oldSearchResultItems = this.SearchResultManager.getCurrentPageSerachResult();
            let multipleLayout = new MultipleLayout();
            multipleLayout.addSearchResultToList(oldSearchResultItems);
        }
        addPageNumberModel() {
            let $pageNumberContainer = new PageNumber().getPageNumberContainer();
            $(this.LayoutElements.getContainerClassName()).after($pageNumberContainer);
        }
        autoNextPageLoad() {
            let nextPage = new NextPage();
            nextPage.autoLoad();
        }
        switchAutoNextPage() {
            return this.AutoNextPageSwitch.isEnable();
        }
        addAdditionModule() {
            this.movePageResultToList();
            if (this.switchAutoNextPage()) {
                this.autoNextPageLoad();
            }
            else {
                setTimeout(() => {
                    this.addPageNumberModel();
                }, 500);
            }
        }
        runGeneralLayout() {
            this.insertListHTMLToWeb(1);
            this.addAdditionModule();
        }
        runOneCenterLayout() {
            this.insertListHTMLToWeb(1);
            this.addAdditionModule();
        }
        runTwoCenterLayout() {
            this.insertListHTMLToWeb(2);
            this.addAdditionModule();
        }
        runThreeCenterLayout() {
            this.insertListHTMLToWeb(3);
            this.addAdditionModule();
        }
        start() {
            let pageLayoutOption = new PageLayoutOption();
            let currentLayout = pageLayoutOption.getCurrentPageType();
            switch (currentLayout) {
                case LAYOUT_TYPE.OneCenter:
                    this.runOneCenterLayout();
                    break;
                case LAYOUT_TYPE.TwoCenter:
                    this.runTwoCenterLayout();
                    break;
                case LAYOUT_TYPE.ThreeCenter:
                    this.runThreeCenterLayout();
                    break;
                default:
                    this.runGeneralLayout();
                    break;
            }
        }
    }
    class LayoutElements {
        constructor() {
            this.CONTAINER_NAME = "bd_search_result_container";
            this.DOCK_NAME = "bd_serach_result_dock";
            this.LIST_NAME = "bd_list";
        }
        getContainerClassName() {
            return "." + this.CONTAINER_NAME;
        }
        getDockClassName() {
            return "." + this.DOCK_NAME;
        }
        getListClassName() {
            return "." + this.LIST_NAME;
        }
        getContainerHTML() {
            return `
                <div class="${this.CONTAINER_NAME}">
                </div>
                `;
        }
        getDockHTML() {
            return `<div class="${this.DOCK_NAME}" > </div>`;
        }
        getListHTML() {
            return `<div class="${this.LIST_NAME}"></div>`;
        }
    }
    class MultipleLayout {
        constructor() {
            this.LayoutElements = new LayoutElements();
            this.listTotal = this.getListTotal();
        }
        getListTotal() {
            return this.getListSelector().length;
        }
        getListSelector() {
            return $(this.LayoutElements.getListClassName());
        }
        getListHeights() {
            let $listSelectors = this.getListSelector();
            let heights = new Array(this.listTotal).fill(0);
            $listSelectors.each(function (index, element) {
                heights[index] = $(this).outerHeight();
            });
            return heights;
        }
        useSinglePageLayout(searchResultItems) {
            let $lists = this.getListSelector();
            $lists.eq(0).append(searchResultItems);
        }
        useMultipageLayout(searchResultItems) {
            let that = this;
            let $lists = this.getListSelector();
            $(searchResultItems).each(function () {
                let listHeights = that.getListHeights();
                let minHeight = Reflect.apply(Math.min, null, listHeights);
                let order = listHeights.indexOf(minHeight);
                $lists.eq(order).append(this);
            });
        }
        addSearchResultToList(searchResultItems) {
            if (this.listTotal <= 1) {
                this.useSinglePageLayout(searchResultItems);
            }
            else {
                this.useMultipageLayout(searchResultItems);
            }
        }
    }
    class NextPage {
        constructor() {
            this.Page = new Page();
            this.MultipleLayout = new MultipleLayout();
            this.Filter = new SearchResult.Filter();
            this.nextPageOrder = 1;
            this.EXTRA_HEIGHT = 300;
            this.baiduNextPageHref = "";
            this.responTextCaches = [];
            this.baiduNextPageHref = this.getBaiduNextPageHref(this.getNextPageElement());
            setTimeout(() => {
                this.requireAndSave();
            }, 1000);
        }
        getNextPageElement() {
            return $("#page a").last();
        }
        getBaiduNextPageHref($element) {
            let tempURL = $element.attr("href");
            return String(tempURL);
        }
        updateBaiduNextPageHref($element) {
            let pathURL = this.getBaiduNextPageHref($element);
            this.baiduNextPageHref = pathURL;
        }
        hasBaiduNextPageHref() {
            return !!this.baiduNextPageHref ? true : false;
        }
        getNextPageURL() {
            return "https://www.baidu.com" + this.baiduNextPageHref;
        }
        isScrollToBottom() {
            let wh = Number($(window).height());
            let c = Number($(document).scrollTop());
            let h = Number($(document.body).height());
            return (Math.ceil(wh + c) + this.EXTRA_HEIGHT) >= h ? true : false;
        }
        hasResponTextCaches() {
            return this.responTextCaches.length > 0 ? true : false;
        }
        extractSearchItems(responseText) {
            return $(responseText).find("#content_left").children(" div[id]");
        }
        extractBaiduNextPageElement(responseText) {
            return $(responseText).find("#page a").last();
        }
        requireNextPageContent(nextPageURL) {
            let that = this;
            return new Promise((resolve) => {
                GM.xmlhttpRequest({
                    method: "GET",
                    url: nextPageURL,
                    timeout: 3000,
                    responseType: "text",
                    headers: {
                        "Host": "www.baidu.com",
                        "User-Agent": navigator.userAgent,
                        "Cookie": document.cookie,
                        "Accept- Encoding": "gzip, deflate, br",
                        "Is_xhr": 1,
                    },
                    onload: (response) => {
                        if (response.status === 200 ||
                            response.status === 304) {
                            resolve(response.responseText);
                        }
                    },
                    onerror: (response) => {
                        console.error(response);
                        console.error("不能获取下一页,请排查原因");
                        resolve("");
                    }
                });
            });
        }
        async requireAndSave(callback) {
            if (!this.hasBaiduNextPageHref()) {
                return;
            }
            let nextPageURL = this.getNextPageURL();
            let responseText = await this.requireNextPageContent(nextPageURL);
            let content = String(responseText);
            if (content == "") {
                return;
            }
            this.responTextCaches.push(content);
            if (callback) {
                Reflect.apply(callback, this, []);
            }
        }
        async addNextPageToWeb() {
            if (!this.hasBaiduNextPageHref()) {
                return;
            }
            if (this.hasResponTextCaches()) {
                let responseText = String(this.responTextCaches.shift());
                let $nextPageElement = this.extractBaiduNextPageElement(responseText);
                this.updateBaiduNextPageHref($nextPageElement);
                let oldSearchResultitems = this.extractSearchItems(responseText);
                let searchResultItems = this.Filter.run(oldSearchResultitems);
                this.MultipleLayout.addSearchResultToList(searchResultItems);
            }
            else {
                Reflect.apply(this.requireAndSave, this, [this.addNextPageToWeb]);
                return;
            }
            this.requireAndSave();
            setTimeout(() => {
                this.bindScrollEvent();
            }, 500);
        }
        bindScrollEvent() {
            $(window).on("scroll", document, () => {
                if (this.isScrollToBottom()) {
                    this.unbindScrollEvent();
                    this.addNextPageToWeb();
                }
            });
        }
        unbindScrollEvent() {
            $(window).off("scroll");
        }
        autoLoad() {
            setTimeout(() => {
                this.bindScrollEvent();
            }, 2000);
        }
    }
    class Page {
        constructor() {
            this.PN_DEFAULT_VALUE = 10;
            this.START_PN_MODIFIED_VALUE = 30;
            this.RN_SYSTEM_VALUE = 10;
            this.RN_VALUE = 30;
            this.pageNumberSelectedLabel = this.getSelectedLabelFromBaiduPageNumber();
            this.pageNumberStartLabel = this.getStartLabelFromBaiduPageNumber();
        }
        getStartLabelFromBaiduPageNumber() {
            let $element = $("#page span").first();
            let content = $element.find("span").text();
            return content == "" ? 1 : Number(content);
        }
        getSelectedLabelFromBaiduPageNumber() {
            let $element = $("#page strong").first();
            let content = $element.find("span").text();
            return content == "" ? 1 : Number(content);
        }
        getPageNumberStartLabel() {
            return Number(this.pageNumberStartLabel);
        }
        getPageNumberSelectedLabel() {
            return Number(this.pageNumberSelectedLabel);
        }
    }
    class Page_old {
        constructor() {
            this.PN_DEFAULT_VALUE = 10;
            this.START_PN_MODIFIED_VALUE = 30;
            this.RN_SYSTEM_VALUE = 10;
            this.RN_VALUE = 30;
            this.pageNumberSelectedLabel = this.getSelectedLabelFromBaiduPageNumber();
            this.pageNumberStartLabel = this.getStartLabelFromBaiduPageNumber();
        }
        getStartLabel(selectedLable) {
            let tempLable = selectedLable;
            let offset = tempLable % 10;
            let level = Math.floor(tempLable / 10);
            let startLable = level * 10 + offset;
            return startLable <= 5 ? 1 : startLable - 5;
        }
        getStartLabelFromBaiduPageNumber() {
            let $element = $("#page span").first();
            let content = $element.find("span").text();
            return content == "" ? 1 : Number(content);
        }
        getSelectedLabel() {
            let currentURL = new UrlEditor(location.href);
            if (!currentURL.hasParam("pn")) {
                return 1;
            }
            let pn = Number(currentURL.getParamValue("pn"));
            let rn = Number(currentURL.getParamValue("rn"));
            let firstTotal = this.getFirstPageToal();
            return (pn - firstTotal) / rn + 2;
        }
        getSelectedLabelFromBaiduPageNumber() {
            let $element = $("#page strong").first();
            let content = $element.find("span").text();
            return content == "" ? 1 : Number(content);
        }
        isFirstPage() {
            let currentSearchURL = new UrlEditor(location.href);
            let hasPnParam = currentSearchURL.hasParam("pn");
            if (!hasPnParam) {
                return true;
            }
            else {
                let pn = Number(currentSearchURL.getParamValue("pn"));
                return pn == 0 ? true : false;
            }
        }
        getPageNumberStartLabel() {
            return Number(this.pageNumberStartLabel);
        }
        getPageNumberSelectedLabel() {
            return Number(this.pageNumberSelectedLabel);
        }
        getFirstPageToal() {
            let currentSearchURL = new UrlEditor(location.href);
            let hasRandomParam = currentSearchURL.hasParam("rn");
            if (!hasRandomParam) {
                return this.PN_DEFAULT_VALUE;
            }
            else {
                return Number(currentSearchURL.getParamValue("rn"));
            }
        }
        getNewPageURL(pageOrder, baiduNextPageHref) {
            let currentSearchURL = new UrlEditor(location.href);
            let baiduSearch = new BaiduSearch();
            let firstPageTotal = this.getFirstPageToal();
            let rn = Number(currentSearchURL.getParamValue("rn")) || this.RN_SYSTEM_VALUE;
            let searchContent = currentSearchURL.getParamValue("wd");
            baiduSearch.addSearchKeyword(searchContent).addRN(rn).openRandonNumber();
            if (currentSearchURL.hasParam("si")) {
                baiduSearch.addParam("si", currentSearchURL.getParamValue("si"));
                baiduSearch.addParam("ct", currentSearchURL.getParamValue("ct"));
            }
            if (currentSearchURL.hasParam("gpc")) {
                baiduSearch.addParam("gpc", currentSearchURL.getParamValue("gpc"));
            }
            if (pageOrder > 1) {
                let level = pageOrder - 2;
                let finalPnValue = firstPageTotal * (pageOrder - 1);
                baiduSearch.addPN(finalPnValue);
            }
            if (!!baiduNextPageHref) {
                let fullURL = "https://www.baidu.com/" + baiduNextPageHref;
                let baiduNextParams = ["rsv_t", "rsv_idx", "rsv_pq"];
                let o = (new URL(fullURL)).searchParams;
                for (const param of baiduNextParams) {
                    if (o.has(param)) {
                        baiduSearch.addParam(param, String(o.get(param)));
                    }
                }
            }
            return baiduSearch.getFinalURL();
        }
    }
    class PageNumber {
        constructor() {
            this.Page = new Page();
            this.BAIDU_PAGE_NUMBER_CONTAINER_NAME = "bd_page_number";
            this.baiduNextPageHref = "";
            this.baiduNextPageHref = this.getBaiduNextPageHref();
        }
        createContainerElement() {
            return `<div id = "${this.BAIDU_PAGE_NUMBER_CONTAINER_NAME}"><div>`;
        }
        createPrePageElement() {
            let selectedLable = this.Page.getPageNumberSelectedLabel();
            let isFirstPage = selectedLable < 2;
            let template = "";
            if (isFirstPage) {
                template = `<div class="bd-none bd_page_item bd_page_pre_page"></div>`;
            }
            else {
                template = `<a class="bd_page_item bd_page_pre_page"><span order="1"}><上一页</span></a>`;
            }
            return template;
        }
        createNextPageElement() {
            let selectedLable = this.Page.getPageNumberSelectedLabel();
            let isFirstPage = selectedLable < 2;
            let order = 0;
            if (isFirstPage) {
                order = 11;
            }
            else {
                order = 12;
            }
            let template = `<a class="bd_page_item bd_page_next_page"><span order="${order}">下一页></span></a>`;
            return template;
        }
        createPageNumberElement() {
            let selectedLable = this.Page.getPageNumberSelectedLabel();
            let startLable = this.Page.getPageNumberStartLabel();
            let endLable = startLable + 10;
            let isFirstPage = selectedLable < 2;
            let pageNumberOrder = 0;
            let template = "";
            if (isFirstPage) {
                pageNumberOrder = 1;
            }
            else {
                pageNumberOrder = 2;
            }
            for (let pageNumber = startLable; pageNumber < endLable; pageNumber++) {
                if (pageNumber == selectedLable) {
                    let selectedClassName = "bd_page_number_selected";
                    template += `<a  class="bd_page_item bd_page_number ${selectedClassName}"><span order="${pageNumberOrder}"}">${pageNumber}</span></a>`;
                }
                else {
                    template += `<a  class="bd_page_item bd_page_number"><span order="${pageNumberOrder}"}">${pageNumber}</span></a>`;
                }
                pageNumberOrder++;
            }
            return template;
        }
        getBaiduNextPageHref() {
            let tempURL = $("#page a").last().attr("href");
            return String(tempURL);
        }
        addClickEvent($container) {
            $container.on("click", "span", (event) => {
                event = event || window.event;
                let order = $(event.target).attr("order");
                let $baiduPageNumberElement = $("#page>div>*").eq(Number(order) - 1);
                let href = $baiduPageNumberElement.attr("href");
                if (href != "") {
                    window.open(href, "_self");
                }
            });
        }
        getPageNumberContainer() {
            let $container = $(this.createContainerElement());
            $container.append(this.createPrePageElement());
            $container.append(this.createPageNumberElement());
            $container.append(this.createNextPageElement());
            this.addClickEvent($container);
            return $container;
        }
    }
    class PageNumber_old {
        constructor() {
            this.Page = new Page();
            this.BAIDU_PAGE_NUMBER_CONTAINER_NAME = "bd_page_number";
            this.baiduNextPageHref = "";
            this.getBaiduNextPageHref();
        }
        createContainerElement() {
            return `<div id = "${this.BAIDU_PAGE_NUMBER_CONTAINER_NAME}"><div>`;
        }
        createPrePageElement() {
            let selectedLable = this.Page.getPageNumberSelectedLabel();
            let order = selectedLable - 1;
            let template = `<div class="bd-none bd_page_item bd_page_pre_page"></div>`;
            if (order >= 1) {
                template = `<a class="bd_page_item bd_page_pre_page"><span order="${order}"}"><上一页</span></a>`;
            }
            return template;
        }
        createNextPageElement() {
            let selectedLable = this.Page.getPageNumberSelectedLabel();
            let order = selectedLable + 1;
            let template = `<a class="bd_page_item bd_page_next_page"><span order="${order}"}">下一页></span></a>`;
            return template;
        }
        createPageNumberElement() {
            let selectedLable = this.Page.getPageNumberSelectedLabel();
            let startLable = this.Page.getPageNumberStartLabel();
            let endLable = startLable + 10;
            let content = "";
            for (let order = startLable; order < endLable; order++) {
                let additionClassName = "";
                if (order == selectedLable) {
                    additionClassName = "bd_page_number_selected";
                }
                let template = `<a  class="bd_page_item bd_page_number ${additionClassName}"><span order="${order}"}">${order}</span></a>`;
                content += template;
            }
            return content;
        }
        getBaiduNextPageHref() {
            if (this.baiduNextPageHref == "") {
                let tempURL = $("#page a").first().attr("href");
                this.baiduNextPageHref = String(tempURL);
            }
        }
        addClickEvent($container) {
            let selector = "#" + this.BAIDU_PAGE_NUMBER_CONTAINER_NAME;
            $container.on("click", "span", (event) => {
                event = event || window.event;
                let order = $(event.target).attr("order");
                let $element = $("#page>div>*").eq(Number(order) - 1);
                let href = $element.attr("href");
                if (href != "") {
                    window.open($element.attr("href"), "_self");
                }
            });
        }
        getPageNumberContainer() {
            let $container = $(this.createContainerElement());
            $container.append(this.createPrePageElement());
            $container.append(this.createPageNumberElement());
            $container.append(this.createNextPageElement());
            this.addClickEvent($container);
            return $container;
        }
    }
    class FixSearchToolbar {
        getNewURL(url) {
            let search = new BaiduSearch();
            let keyword = url.getParamValue("wd");
            search.addSearchKeyword(keyword).addRN(30).openRandonNumber();
            if (url.hasParam("si")) {
                let siValue = url.getParamValue("si");
                search.addParam("si", siValue);
            }
            return search.getFinalURL();
        }
        refresh() {
        }
        refresh_null() {
            let url = new UrlEditor(location.href);
            console.log(url.getFinalUrl());
            if (!url.hasParam("random")) {
                let temp = String(cleanURL(url));
                location.href = temp;
            }
            function cleanURL(url) {
                let search = new BaiduSearch();
                let keyword = url.getParamValue("wd");
                search.addSearchKeyword(keyword).addRN(30).openRandonNumber();
                if (url.hasParam("si")) {
                    search.addParam("si", url.getParamValue("si"));
                    search.addParam("ct", url.getParamValue("ct"));
                }
                if (url.hasParam("gpc")) {
                    search.addParam("gpc", url.getParamValue("gpc"));
                }
                return search.getFinalURL();
            }
        }
        observer() {
            window.onload = () => {
                let MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver;
                if (!!MutationObserver) {
                    let observer = new MutationObserver(this.refresh_null);
                    let wrapper = document.querySelector("#form");
                    let observerConfig = {
                        childList: true,
                        subtree: true,
                    };
                    observer.observe(wrapper, observerConfig);
                }
                else {
                    console.error("百度搜索-优化: 浏览器不兼容 MutationObserver 接口, 请升级浏览器版本");
                }
            };
        }
        start() {
            this.observer();
        }
    }
    class ScrollToTop {
        isInputTarget(event) {
            return $(event.target).prop("tagName") == "INPUT" ? true : false;
        }
        bindScrollToTopEvent() {
            let $selector = $(".s_form ");
            $selector.off("click").on("click", (event) => {
                if (this.isInputTarget(event)) {
                    event.stopPropagation();
                    return;
                }
                let element = document.documentElement;
                let body = document.body;
                let node = element.scrollTop ? element : body;
                let top = node.scrollTop;
                let step = top / 20;
                let timer = setInterval(() => {
                    if (node.scrollTop <= 0) {
                        node.scrollTop = 0;
                        clearInterval(timer);
                    }
                    node.scrollTop -= step;
                }, 10);
                return false;
            });
        }
        start() {
            this.bindScrollToTopEvent();
        }
    }
    class ShortcutKey {
        constructor() {
            this.KEY_ENTER = 13;
            this.KEY_ALT = 18;
            this.KEY_SHIFT = 16;
            this.KEY_CTRL = 17;
            this.KEY_GOOGLE = "G";
        }
        googleSeach() {
            let google = new UrlEditor("https://www.google.com/search?q=%s");
            let url = new UrlEditor(location.href);
            let searchWord = url.getParamValue("wd");
            google.setParam("q", searchWord);
            location.href = google.getFinalUrl();
        }
        notAdditonKeyup(event) {
            if (!event.altKey &&
                !event.shiftKey &&
                !event.ctrlKey &&
                !event.metaKey) {
                return true;
            }
            else {
                return false;
            }
        }
        isInputKeyup(event) {
            let inputClassName = "bd-barbox-input";
            if ($(event.target).hasClass(inputClassName)) {
                return true;
            }
            else {
                return false;
            }
        }
        bingShortcutKeyEvent() {
            $(document).off("keyup").on("keyup", (event) => {
                let keyCode = event.keyCode || event.which || event.charCode;
                if (this.isInputKeyup(event)) {
                    return false;
                }
                if (keyCode ==
                    this.KEY_GOOGLE.toUpperCase().charCodeAt(0) && this.notAdditonKeyup(event)) {
                    this.googleSeach();
                }
            });
        }
        start() {
            this.bingShortcutKeyEvent();
        }
    }
    class Sidebar {
        constructor() {
            this.SideToolBar = new SideToolBarModel.SideToolBar();
            this.SideToolBarSwitch = new SideToolBarSwitch();
        }
        insertSidebarHTML() {
            let $container = $("#head");
            let $sideToolbar = this.SideToolBar.getSideToolBar();
            $container.after($sideToolbar);
        }
        start() {
            if (this.SideToolBarSwitch.isEnable())
                this.insertSidebarHTML();
        }
    }
    class BaiduIndexFactory {
        create() {
            let page = new Baidu();
            page.add(IndexPageInjectStyles);
            page.addDelayAndReady(IndexPageAddSearchForm);
            page.execute();
        }
    }
    class BaiduResultFactory {
        create() {
            let page = new Baidu();
            page.add(ResultPageInjectStyles);
            page.addDelayAndReady(ResultPageAddSearchForm);
            page.addDelayAndReady(CustomMenu);
            page.addReady(LayoutControl);
            page.addReady(ScrollToTop);
            page.addReady(Sidebar);
            page.addReady(ShortcutKey);
            page.execute();
            useObserver();
        }
    }
    function mutationfunc() {
        let avoidMulExecute = new AvoidMulExecute();
        if (avoidMulExecute.hasSign()) {
            return;
        }
        avoidMulExecute.setSign();
        location.href = location.href;
    }
    function useObserver() {
        window.onload = () => {
            let avoidMulExecute = new AvoidMulExecute();
            avoidMulExecute.setSign();
            let MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver;
            if (!!MutationObserver) {
                let observer = new MutationObserver(mutationfunc);
                let wrapper = document.querySelector("#wrapper");
                let observerConfig = {
                    childList: true,
                    subtree: true
                };
                observer.observe(wrapper, observerConfig);
            }
            else {
                console.error("百度搜索-优化: 浏览器不兼容 MutationObserver 接口, 请升级浏览器版本");
            }
        };
    }
    function cleanURL(url) {
        let search = new BaiduSearch();
        let keyword = url.getParamValue("wd");
        search.addSearchKeyword(keyword).addRN(30).openRandonNumber();
        if (url.hasParam("si")) {
            search.addParam("si", url.getParamValue("si"));
            search.addParam("ct", url.getParamValue("ct"));
        }
        if (url.hasParam("gpc")) {
            search.addParam("gpc", url.getParamValue("gpc"));
        }
        return search.getFinalURL();
    }
    function tidySearchLink() {
        let url = new UrlEditor(location.href);
        if (!url.hasParam("rn")) {
            url.setParam("rn", "30");
            location.href = url.getFinalUrl();
        }
    }
    const IndexPageRouters = ["https://www.baidu.com/", "https://www.baidu.com/#", "http://ipv6.baidu.com/", "https://ipv6.baidu.com/"];
    const ResultPagesRouters = ["https://www.baidu.com/s", "https://www.baidu.com/baidu"];
    let router = new Router();
    router.addRoute(IndexPageRouters, new BaiduIndexFactory());
    router.addRoute(ResultPagesRouters, new BaiduResultFactory());
})();