searchEngineJump 搜索引擎快捷跳转

方便的在各个搜索引擎之间跳转,增加可视化设置菜单,能更友好的自定义设置,修复百度搜索样式丢失的问题

目前为 2022-08-24 提交的版本。查看 最新版本

  1. // ==UserScript==
  2. // @name searchEngineJump 搜索引擎快捷跳转
  3. // @author NLF&锐经(修改) & iqxin(修改)
  4. // @contributor iqxin
  5. // @description 方便的在各个搜索引擎之间跳转,增加可视化设置菜单,能更友好的自定义设置,修复百度搜索样式丢失的问题
  6. // @version 5.24.13
  7. // @created 2011-07-02
  8. // @lastUpdated 2022-08-23
  9.  
  10. // @namespace https://gf.qytechs.cn/zh-CN/scripts/27752-searchenginejump
  11. // @homepage https://github.com/qxinGitHub/searchEngineJump
  12. // @require https://gf.qytechs.cn/scripts/408009-togbk/code/toGBK.js?version=832799
  13. // @icon 
  14. // @license MIT
  15.  
  16. // @match *://*.163.com/*
  17. // @match *://*.1688.com/*
  18. // @match *://*.1ting.com/*
  19. // @match *://*.25pp.com/*
  20. // @match *://*.3dmgame.com/*
  21. // @match *://*.acfun.cn/*
  22. // @match *://*.alternativeto.net/*
  23. // @match *://*.amazon.cn/*
  24. // @match *://*.assrt.net/*
  25. // @match *://*.baidu.com/*
  26. // @match *://*.bbc.co.uk/*
  27. // @match *://*.bilibili.com/*
  28. // @match *://*.bing.com/*
  29. // @match *://*.brave.com/*
  30. // @match *://*.caniuse.com/*
  31. // @match *://*.cnki.net/*
  32. // @match *://*.cnn.com/*
  33. // @match *://*.dangdang.com/*
  34. // @match *://*.deepl.com/*
  35. // @match *://*.dict.cn/*
  36. // @match *://*.dmhy.org/*
  37. // @match *://*.dnspod.cn/*
  38. // @match *://*.docin.com/*
  39. // @match *://*.douban.com/*
  40. // @match *://*.duckduckgo.com/*
  41. // @match *://*.ebscohost.com/*
  42. // @match *://*.ed2000.com/*
  43. // @match *://*.enginelist.news/*
  44. // @match *://*.facebook.com/*
  45. // @match *://*.feng.com/*
  46. // @match *://*.flickr.com/*
  47. // @match *://*.fnd.io/*
  48. // @match *://*.forfrigg.com/*
  49. // @match *://*.forvo.com/*
  50. // @match *://*.github.com/*
  51. // @include *://*.google.tld/*
  52. // @match *://*.huaban.com/*
  53. // @match *://*.ifeng.com/*
  54. // @match *://*.imomoe.in/*
  55. // @match *://*.infinitynewtab.com/*
  56. // @match *://*.iqiyi.com/*
  57. // @match *://*.jd.com/*
  58. // @match *://*.jiumodiary.com/*
  59. // @match *://*.kugou.com/*
  60. // @match *://*.kuwo.cn/*
  61. // @match *://*.letv.com/*
  62. // @match *://*.mebook.cc/*
  63. // @match *://*.microsoft.com/*
  64. // @match *://*.moegirl.org/*
  65. // @match *://*.mozilla.org/*
  66. // @match *://*.nicovideo.jp/*
  67. // @match *://*.neeva.com/*
  68. // @match *://*.nyaa.si/*
  69. // @match *://*.pinterest.com/*
  70. // @match *://*.pixiv.net/*
  71. // @match *://*.qq.com/*
  72. // @match *://*.quora.com/*
  73. // @match *://*.rs05.com/*
  74. // @match *://*.runoob.com/*
  75. // @match *://*.rus.ec/*
  76. // @match *://*.searx.me/*
  77. // @match *://*.sina.com.cn/*
  78. // @match *://*.smzdm.com/*
  79. // @match *://*.so.com/*
  80. // @match *://*.sogou.com/*
  81. // @match *://*.sohu.com/*
  82. // @match *://*.soku.com/*
  83. // @match *://*.springer.com/*
  84. // @match *://*.stackoverflow.com/*
  85. // @match *://*.startpage.com/*
  86. // @match *://*.suning.com/*
  87. // @match *://*.taobao.com/*
  88. // @match *://*.thepiratebay.org/*
  89. // @match *://*.tmall.com/*
  90. // @match *://*.toutiao.com/*
  91. // @match *://*.tuoniao.me/*
  92. // @match *://*.twitter.com/*
  93. // @match *://*.userstyles.org/*
  94. // @match *://*.verycd.com/*
  95. // @match *://*.wanfangdata.com.cn/*
  96. // @match *://*.webofknowledge.com/*
  97. // @match *://*.weibo.com/*
  98. // @match *://*.wikipedia.org/*
  99. // @match *://*.xiami.com/*
  100. // @match *://*.xiaoso.net/*
  101. // @include *://*.yahoo.tld/*
  102. // @match *://*.yandex.com/*
  103. // @match *://*.yandex.ru/*
  104. // @match *://*.yhd.com/*
  105. // @match *://*.yinyuetai.com/*
  106. // @match *://*.youdao.com/*
  107. // @match *://*.youtube.com/*
  108. // @match *://*.zdic.net/*
  109. // @match *://*.zhihu.com/*
  110. // @match *://*.zimuzu.tv/*
  111. // @match *://*.ecosia.org/*
  112. // @match *://*.qcc.com/*
  113. // @match *://*.tianyancha.com/*
  114. // @match *://www.iciba.com/*
  115. // @match *://fsoufsou.com/*
  116. // @match *://*.douyin.com/*
  117. // @match *谷歌.ml/*
  118. // @match *xn--flw351e.ml/*
  119.  
  120. // @grant GM_getValue
  121. // @grant GM_setValue
  122. // @grant GM_addStyle
  123. // @grant GM_deleteValue
  124. // @grant GM_setClipboard
  125. // @grant GM_registerMenuCommand
  126. // @grant GM_openInTab
  127. // @grant GM_xmlhttpRequest
  128. // @run-at document-end
  129.  
  130. // ==/UserScript==
  131.  
  132. (function () {
  133. 'use strict';
  134.  
  135. console.log("脚本: 搜索引擎快捷跳转 --- 开始执行 --- 发布者: qxin --- GitHub:https://github.com/qxinGitHub/searchEngineJump ← 问题反馈地址")
  136. function iqxinstart(){
  137. // 根据规则把搜索引擎列表插入到指定网站
  138. var rules = [
  139. // 网页搜索/////////////第一个可以当模板看
  140. {name: "google网页搜索",// 你要加载的网站的名字(方便自己查找)
  141. // 是否启用.
  142. enabled: true,
  143. // 在哪个网站上加载,正则.
  144. url: /^https?:\/\/www\.google(?:\.[A-z]{2,3}){1,2}\/[^?]+\?(?!tbm=)(?:&?q=|(?:[^#](?!&tbm=))+?&q=)(?:.(?!&tbm=))*$|(^https?:\/\/xn--flw351e\.ml\/search\?q=)/,
  145. // 加载哪个类型的列表:
  146. // ['web'|'music'|'video'|'image'|'download'|'shopping'|'translate'|'knowledge'|'sociality']
  147. engineList: 'web',
  148. // 若固定到顶栏,是否给一个高度
  149. class: "s6JM6d", // 添加一个class, 用来使用目标网站的样式
  150. fixedTop: 52,
  151. // 给引擎列表的样式 (“style_ACBaidu” 可选,是为了兼容 “AC Baidu” 脚本)
  152. style: '\
  153. z-index: 100;\
  154. margin-top:5px;\
  155. ',
  156. style_ACBaidu: '\
  157. text-align: center;\
  158. z-index: 100;\
  159. margin-top:5px;\
  160. ',
  161. // 插入文档,相关
  162. // target 将引擎跳转工具栏插入到文档的某个元素
  163. // (请使用xpath匹配,比如: '//*[@id="subform_ctrl"]' 或者 css匹配(请加上 'css;' 的前缀),比如: 'css;#subform_ctrl' );
  164. // keyword 使用 xpath 或者 css选中一个form input元素 或者 该项是一个函数,使用返回值
  165. // where 四种:
  166. // 'beforeBegin'(插入到给定元素的前面) ;
  167. // 'afterBegin'(作为给定元素的第一个子元素) ;
  168. // 'beforeEnd' (作为给定元素的最后一个子元素) ;
  169. // 'afterEnd'(插入到给定元素的后面);.
  170. insertIntoDoc: {
  171. target: 'css;#appbar',
  172. // 若 keyword 使用函数获取
  173. // keyword: function () {
  174. // var input = document.getElementById('lst-ib');
  175. // if (input) return input.value;
  176. // },
  177. keyword: '//input[@name="q"]',
  178. where: 'beforeBegin',
  179. },
  180. // 修改源网页用来适应跳转栏(可选)
  181. stylish: 'body.vasq #hdtbMenus.hdtb-td-o{top:100px !important;} #hdtbMenus{top:92px;}'
  182. },
  183. {name: "google-hash-query",// 不刷新页面显示搜索结果的google
  184. enabled: true,
  185. url: /^https?:\/\/www\.google(?:\.[A-z]{2,3}){1,2}\/[^#]*#(?:&?q=|.+?&q=).+/,
  186. engineList: 'web',
  187. style: '\
  188. margin-left: 142px;\
  189. z-index: 100;\
  190. margin-top:5px;\
  191. ',
  192. style_ACBaidu: '\
  193. text-align: center;\
  194. z-index: 100;\
  195. margin-top:5px;\
  196. ',
  197. insertIntoDoc: {
  198. target: 'css;#appbar',
  199. keyword: function () {
  200. var input = document.getElementById('lst-ib');
  201. if (input) return input.value;
  202. },
  203. where: 'beforeBegin',
  204. },
  205. stylish: 'body.vasq #hdtbMenus.hdtb-td-o{top:100px !important}'
  206. },
  207. {name: "百度网页搜索",
  208. url: /^https?:\/\/www\.baidu\.com\/(?:s|baidu)/,
  209. enabled: true,
  210. engineList: "web",
  211. fixedTop:70,
  212. fixedTop2:88,
  213. fixedTopTarget: "css;.s_form ",
  214. fixedTopWhere:"beforeEnd",
  215. style: '\
  216. margin-top:8px;\
  217. margin-bottom: -5px;\
  218. z-index: 101;\
  219. margin-left: 144px;\
  220. ',
  221. style_ACBaidu: '\
  222. margin-top: 8px;\
  223. margin-bottom: -5px;\
  224. z-index: 99;\
  225. text-align: center;\
  226. padding-left:0px !important;\
  227. background: rgba(248,248,248,0.4);\
  228. backdrop-filter: blur(10px);\
  229. ',
  230. insertIntoDoc: {
  231. keyword: 'css;input#kw',
  232. target: 'css;#s_tab',
  233. where: 'afterEnd',
  234. },
  235. stylish:".headBlock,.se_common_hint{display:none !important} #wrapper>.result-molecule{z-index:300 !important}"
  236. },
  237. {name: "必应网页搜索",
  238. url: /^https?:\/\/[^.]*\.bing\.com\/search/,
  239. enabled: true,
  240. engineList: "web",
  241. style: '\
  242. padding-left:15px;\
  243. margin-top:6px;\
  244. margin-left: 148px;\
  245. margin-bottom:-10px;\
  246. ',
  247. style_ACBaidu: '\
  248. text-align: center;\
  249. margin-left: -120px;\
  250. margin-right: 0px;\
  251. margin-bottom:-20px;\
  252. ',
  253. insertIntoDoc: {
  254. keyword: 'css;#sb_form_q',
  255. target: 'css;#b_content',
  256. where: 'beforeBegin',
  257. },
  258. },
  259. {name: "DDG",
  260. url: /^https?:\/\/duckduckgo\.com\/*/i,
  261. enabled: true,
  262. engineList: "web",
  263. style: '\
  264. margin-top:5px;\
  265. ',
  266. insertIntoDoc: {
  267. keyword: '//input[@name="q"]',
  268. target: 'css;.results--main',
  269. where: 'beforeBegin',
  270. },
  271. },
  272. {name:"雅虎网页搜索",
  273. url:/^https?:\/\/search\.yahoo\.com\/search/i,
  274. engineList:"web",
  275. enabled:true,
  276. fixedTop:54,
  277. style:"\
  278. margin-left:122px;\
  279. ",
  280. insertIntoDoc:{
  281. keyword:'css;#yschsp',
  282. target:'css;#horizontal-bar',
  283. where:'afterBegin',
  284. },
  285. },
  286. {name:"雅虎日本网页搜索",
  287. url:/^https?:\/\/search\.yahoo\.co\.jp\/search/i,
  288. engineList:"web",
  289. enabled:true,
  290. style:"\
  291. margin-left:0px;\
  292. width:1050px;\
  293. display:flex;\
  294. -webkit-box-orient: vertical;\
  295. -webkit-box-direction: normal;\
  296. margin: auto;\
  297. ",
  298. insertIntoDoc:{
  299. keyword:'//input[@name="p"]',
  300. target:'css;.Header__inner',
  301. where:'afterEnd',
  302. },
  303. },
  304. {name:"台湾雅虎网页搜索",
  305. url:/^https?:\/\/tw\.search\.yahoo\.com\/search/i,
  306. engineList:"web",
  307. enabled:true,
  308. fixedTop:52,
  309. style:"\
  310. margin-left:-10px;\
  311. margin-bottom:10px;\
  312. ",
  313. insertIntoDoc:{
  314. keyword:'css;#yschsp',
  315. target:'css;#results',
  316. where:'afterBegin',
  317. },
  318. },
  319. {name:"searx",
  320. url:/^https?:\/\/searx\.me\/\?q/i,
  321. engineList:"web",
  322. enabled:true,
  323. style:"\
  324. margin-left:-10px;\
  325. margin-bottom:10px;\
  326. ",
  327. insertIntoDoc:{
  328. keyword:'css;#q',
  329. target:'css;#categories',
  330. where:'beforeBegin',
  331. },
  332. },
  333. {name: "搜狗",
  334. url: /^https?:\/\/www\.sogou\.com\/(?:web|s)/,
  335. enabled: true,
  336. engineList: "web",
  337. fixedTop:60,
  338. style: "\
  339. top:-46px;\
  340. z-index:99;\
  341. margin-left:-5px;\
  342. ",
  343. style_ACBaidu: "\
  344. top:-46px;\
  345. z-index:99;\
  346. margin-left:60px;\
  347. padding-left: 0px !important;\
  348. ",
  349. insertIntoDoc: {
  350. keyword: "css;#upquery",
  351. target: "css;#wrapper",
  352. where: "afterBegin",
  353. },
  354. stylish:"#float_uphint{display:none;}",
  355. },
  356. {name:"yandex",
  357. url:/^https?:\/\/yandex\.(?:com|ru)\/search/i,
  358. engineList:"web",
  359. enabled:true,
  360. fixedTop:56,
  361. style:"\
  362. margin-top:10px;\
  363. padding-left:130px;\
  364. ",
  365. insertIntoDoc:{
  366. keyword:'css;.input__control',
  367. target:'css;.navigation',
  368. where:'beforeBegin',
  369. },
  370. },
  371. {name: "google网页分类搜索",
  372. enabled: true,
  373. url: /^https?:\/\/www\.google(?:\.[A-z]{2,3}){1,2}\/[^?]+\?(?:tbm=)(?:&?q=|(?:[^#](?!&tbm=))+?&q=)(?:.(?!&tbm=))*$/,
  374. engineList: 'web',
  375. style: '\
  376. margin-left: 142px;\
  377. z-index: 100;\
  378. margin-top:5px;\
  379. ',
  380. insertIntoDoc: {
  381. target: 'css;#appbar',
  382. keyword: '//input[@name="q"]',
  383. where: 'beforeBegin',
  384. },
  385. stylish: 'body.vasq #hdtbMenus.hdtb-td-o{top:100px !important}'
  386. },
  387. {name: "startpage",
  388. enabled: true,
  389. url:/^https?:\/\/(www\.)?startpage\.com\/[a-zA-Z]{2,3}\/search/,
  390. engineList: 'web',
  391. style: '\
  392. z-index: 100;\
  393. margin-left: 135px;\
  394. ',
  395. insertIntoDoc: {
  396. target: 'css;.layout-web',
  397. keyword: '//input[@name="query"]',
  398. // where: 'beforeBegin',
  399. where: 'beforeEnd',
  400. },
  401. },
  402. {name: "startpage2",
  403. enabled: true,
  404. url:/^https?:\/\/www\.startpage\.com\/do\/asearch/,
  405. engineList: 'web',
  406. fixedTop: 102,
  407. fixedTopColor:"#202c46",
  408. nightMode: true,
  409. style: '\
  410. z-index: 100;\
  411. margin-left: 135px;\
  412. color:#ccc;\
  413. ',
  414. insertIntoDoc: {
  415. target: 'css;.layout-web__header',
  416. keyword: '//input[@name="query"]',
  417. // where: 'beforeBegin',
  418. where: 'beforeEnd',
  419. },
  420. stylish:".layout-web__body{margin-top:110px;}",
  421. },
  422. {name: "infinitynewtab",
  423. enabled: true,
  424. url:/^https?:\/\/google\.infinitynewtab\.com\/\?q/i,
  425. engineList: 'web',
  426. style: '\
  427. z-index: 100;\
  428. margin-top: 20px;\
  429. ',
  430. insertIntoDoc: {
  431. target: 'css;.search-types',
  432. // keyword: 'css;input.gsc-input',
  433. keyword: '//input[@name="search"]',
  434. where: 'afterBegin',
  435. },
  436. },
  437. {name: "ecosia",
  438. enabled: true,
  439. url:/^https?:\/\/www\.ecosia\.org\/search\?/i,
  440. engineList: 'web',
  441. style: '\
  442. margin-left: -10px;\
  443. margin-top: -20px;\
  444. z-index:1;\
  445. background-color:#fff;\
  446. ',
  447. insertIntoDoc: {
  448. target: 'css;.mainline',
  449. keyword: '//input[@name="q"]',
  450. where: 'afterBegin',
  451. },
  452. },
  453. {name: "f搜",
  454. enabled: true,
  455. url: /^https?:\/\/fsoufsou\.com\/search/,
  456. engineList: 'web',
  457. fixedTop: 111,
  458. style: '\
  459. margin-left: 50px;\
  460. z-index: -99999;\
  461. margin-top:5px;\
  462. ',
  463. style_ACBaidu: '\
  464. text-align: center;\
  465. z-index: -99999;\
  466. margin-top:5px;\
  467. ',
  468. insertIntoDoc: {
  469. target: 'css;.input-with-suggestion',
  470. keyword: function () {
  471. var input = document.getElementById('search-input');
  472. if (input) return input.value;
  473. },
  474. where: 'beforeEnd',
  475. },
  476. stylish: '.tabs-bottom-border{transform: translate(0, 32px); !important}'
  477. },
  478. {name: "brave",
  479. enabled: true,
  480. // https://search.brave.com/search?q=0
  481. url:/^https?:\/\/search\.brave\.com\/search\?/i,
  482. engineList: 'web',
  483. class: "container-80",
  484. style: '\
  485. z-index:1;\
  486. ',
  487. insertIntoDoc: {
  488. target: 'css;#search-main',
  489. keyword: '//input[@name="q"]',
  490. where: 'beforeBegin',
  491. },
  492. },
  493. {name: "neeva",
  494. enabled: true,
  495. // https://neeva.com/search?q=0
  496. url:/^https?:\/\/neeva\.com\/search\?/i,
  497. engineList: 'web',
  498. fixedTop: 80,
  499. style: '\
  500. z-index:1;\
  501. ',
  502. insertIntoDoc: {
  503. target: 'css;#search header',
  504. keyword: '//input[@name="q"]',
  505. where: 'afterEnd',
  506. },
  507. },
  508.  
  509. // 知识
  510. {name: "百度百科词条",
  511. url: /^https?:\/\/baike\.baidu\.com\/item/,
  512. engineList: "knowledge",
  513. fixedTop:65,
  514. enabled: true,
  515. style: "\
  516. text-align: center;\
  517. background: #fff;\
  518. ",
  519. insertIntoDoc: {
  520. keyword: 'css;#query',
  521. target: 'css;.navbar-wrapper',
  522. where: 'beforeBegin',
  523. },
  524. },
  525. {name: "百度百科搜索",
  526. url: /^https?:\/\/baike\.baidu\.com\/search/,
  527. engineList: "knowledge",
  528. enabled: true,
  529. fixedTop:56,
  530. style: "\
  531. padding-left: 120px;\
  532. margin: 5px 0 -10px 0px;\
  533. ",
  534. insertIntoDoc: {
  535. keyword: 'css;#query',
  536. target: 'css;.header-wrapper',
  537. where: 'afterEnd',
  538. },
  539. },
  540. {name: "百度文库",
  541. url: /^https?:\/\/wenku\.baidu\.com\/search/i,
  542. engineList: "knowledge",
  543. enabled: true,
  544. fixedTop: 96,
  545. style: "\
  546. margin-bottom: 6px;\
  547. margin-top:-16px;\
  548. padding:0;\
  549. ",
  550. insertIntoDoc: {
  551. keyword: function(){
  552. var str = document.querySelector("#kw").value;
  553. return str;
  554. },
  555. target: 'css;.bd-wrap',
  556. where: 'afterBegin',
  557. },
  558. },
  559. {name: "百度知道",
  560. url: /^https?:\/\/zhidao\.baidu\.com\/search/i,
  561. engineList: "knowledge",
  562. enabled: true,
  563. style: "\
  564. border-top: 1px solid #e5e5e5;\
  565. border-bottom: 1px solid #e5e5e5;\
  566. margin-bottom: 1px;\
  567. margin-left:112px;\
  568. ",
  569. insertIntoDoc: {
  570. keyword: 'css;#kw',
  571. target: 'css;#header',
  572. where: 'afterEnd',
  573. },
  574. },
  575. {name: "维基百科",
  576. url: /^https?:\/\/\D{2,5}\.wikipedia\.org\/wiki/i,
  577. engineList: "knowledge",
  578. enabled: true,
  579. style: "\
  580. position: absolute;\
  581. padding-left: 14em;\
  582. ",
  583. insertIntoDoc: {
  584. keyword: function(){
  585. var url = window.location.href.substring(window.location.href.lastIndexOf("/")+1);
  586. return decodeURIComponent(url);
  587. },
  588. target: 'css;#mw-head',
  589. where: 'afterBegin',
  590. },
  591. },
  592. {name: "知乎",
  593. url: /^https?:\/\/www\.zhihu\.com\/search\?/i,
  594. engineList: "knowledge",
  595. enabled: true,
  596. fixedTop:50,
  597. style: "\
  598. margin: 5px auto 0px;\
  599. width:960px;\
  600. z-index:19;\
  601. background: #fff;\
  602. box-shadow: 0 1px 3px 0 rgba(0,34,77,.05); \
  603. padding: 5px 20px; \
  604. ",
  605. // 兼容“知乎排版优化”
  606. // https://gf.qytechs.cn/zh-CN/scripts/21659
  607. style_ZhihuChenglinz: "\
  608. margin: 5px auto 0px;\
  609. width:654px;\
  610. z-index:19;\
  611. background: #fff;\
  612. box-shadow: 0 1px 3px 0 rgba(0,34,77,.05); \
  613. padding: 5px 20px; \
  614. ",
  615. insertIntoDoc: {
  616. keyword: 'css;.Input',
  617. target:"css;.App-main .SearchTabs",
  618. where: 'afterEnd', //beforeBegin
  619. },
  620. stylish:".TopSearch.Card{margin:30px auto;}",
  621. },
  622. {name: "互动百科搜索页",
  623. url: /^https?:\/\/so\.baike\.com\/doc/i,
  624. engineList: "knowledge",
  625. enabled: true,
  626. style: "\
  627. border-top: 1px solid #e5e5e5;\
  628. text-align: center;\
  629. border-bottom: 1px solid #e5e5e5;\
  630. margin-bottom: 1px;\
  631. ",
  632. insertIntoDoc: {
  633. keyword: 'css;.ac_input',
  634. target: 'css;.bk-head',
  635. where: 'afterEnd',
  636. },
  637. },
  638. {name: "互动百科词条页",
  639. url: /^https?:\/\/www\.baike\.com\/wiki/i,
  640. engineList: "knowledge",
  641. enabled: true,
  642. style: "\
  643. border-top: 1px solid #e5e5e5;\
  644. text-align: center;\
  645. border-bottom: 1px solid #e5e5e5;\
  646. margin-bottom: 1px;\
  647. ",
  648. insertIntoDoc: {
  649. keyword: 'css;.ac_input',
  650. target: 'css;.bk-head',
  651. where: 'afterEnd',
  652. },
  653. },
  654. {name: "豆丁文档",
  655. url: /^https?:\/\/www\.docin\.com\/search\.do/,
  656. engineList: "knowledge",
  657. enabled: true,
  658. style: "\
  659. text-align: center;\
  660. margin:0 auto;\
  661. padding-top:1px;\
  662. border-top:1px solid #00000;\
  663. border-bottom:1px solid #D9E1F7;\
  664. ",
  665. insertIntoDoc: {
  666. keyword: 'css;#topsearch',
  667. target: 'css;.doc_hd_mini',
  668. where: 'afterEnd',
  669. },
  670. },
  671. {name: "知乎(搜狗)",
  672. url: /^https?:\/\/zhihu\.sogou\.com\/zhihu/,
  673. enabled: true,
  674. engineList: 'web',
  675. fixedTop:55,
  676. style: "\
  677. margin: auto;\
  678. width: 1000px;\
  679. z-index:99;\
  680. ",
  681. insertIntoDoc: {
  682. keyword: 'css;#upquery',
  683. target: 'css;#header',
  684. where: 'afterEnd',
  685. },
  686. stylish: '.header{ margin-bottom: 5px; }'
  687. },
  688. {name: "微信搜狗",
  689. url: /^https?:\/\/weixin\.sogou\.com\/weixin\?/,
  690. enabled: true,
  691. engineList: "web",
  692. fixedTop:55,
  693. style: "width: 1000px;margin: 8px auto -5px;z-index:99;",
  694. insertIntoDoc: {
  695. keyword: "//input[@name='query']",
  696. target: "css;.header-box",
  697. where: "afterEnd",
  698. },
  699. },
  700. {name: "Quora",
  701. // https://www.quora.com/search?q=china
  702. url: /^https?:\/\/www\.quora\.com\/search\?/i,
  703. enabled: true,
  704. engineList: "knowledge",
  705. fixedTop:53,
  706. style: "width: 1000px;margin: 0px auto 0px; padding-left:180px;",
  707. insertIntoDoc: {
  708. keyword: function(){
  709. var url = window.location.href.substring(window.location.href.lastIndexOf("=")+1);
  710. return decodeURIComponent(url);
  711. },
  712. target: "css;.SiteHeader",
  713. where: "beforeEnd",
  714. },
  715. },
  716. {name: "stackoverflow",
  717. url: /^https?:\/\/stackoverflow\.com\/search\?/i,
  718. enabled: true,
  719. engineList: "knowledge",
  720. fixedTop:50,
  721. style: "width: 1000px;margin: 8px auto 0px;z-index:99;",
  722. insertIntoDoc: {
  723. keyword: "//input[@name='q']",
  724. target: "css;.top-bar",
  725. where: "afterEnd",
  726. },
  727. },
  728.  
  729.  
  730. // 视频网站
  731. {name: "优酷",
  732. url: /^https?:\/\/www\.soku\.com\/search_video\//,
  733. engineList: "video",
  734. enabled: true,
  735. fixedTop:54,
  736. style: "\
  737. width:1190px;\
  738. margin:0 auto;\
  739. z-index:99999;\
  740. ",
  741. insertIntoDoc: {
  742. keyword: 'css;#headq',
  743. target: 'css;.sk_container',
  744. where: 'beforeBegin',
  745. },
  746. },
  747. {name: "土豆",
  748. url: /^https?:\/\/www\.soku\.com\/t\/nisearch\//,
  749. enabled: true,
  750. engineList: "video",
  751. style: "\
  752. padding-left: 10px;\
  753. border-top: 1px solid #FC6500;\
  754. border-bottom: 1px solid #FC6500;\
  755. text-align: center;\
  756. ",
  757. insertIntoDoc: {
  758. keyword: 'css;#headq',
  759. target: 'css;body > .sk_container',
  760. where: 'beforeBegin',
  761. },
  762. },
  763. {name: "哔哩哔哩",
  764. url: /^https?:\/\/search\.bilibili\.com\/all/,
  765. enabled: true,
  766. engineList: "video",
  767. // fixedTop:62,
  768. style: "\
  769. width:980px;\
  770. margin:10px auto -5px;\
  771. text-align:center;\
  772. ",
  773. insertIntoDoc: {
  774. // keyword: 'css;#search-keyword', //旧
  775. // target: 'css;.filter-wrap', //旧
  776. // keyword: 'css;.search-input-el',
  777. keyword: function(){
  778. if(document.querySelector("#search-keyword")){
  779. return document.querySelector("#search-keyword").value;
  780. } else{
  781. return document.querySelector(".search-input-el").value;
  782. }
  783. },
  784. // target: 'css;.search-input',
  785. target: function(){
  786. if(document.querySelector(".head-contain")){
  787. return document.querySelector(".head-contain");
  788. } else{
  789. return document.querySelector(".search-input");
  790. }
  791. },
  792. where: 'afterEnd',
  793. },
  794. },
  795. {name: "AcFun",
  796. url: /^https?:\/\/www\.acfun\.cn\/search/,
  797. enabled: true,
  798. engineList: "video",
  799. fixedTop:46,
  800. style: "\
  801. width:980px;\
  802. margin: -30px 0 10px 0;\
  803. text-align:center;\
  804. ",
  805. insertIntoDoc: {
  806. keyword: 'css;#search-text--standalone',
  807. target: 'css;.search__main__container',
  808. where: 'afterEnd',
  809. },
  810. },
  811. {name: "YouTube",
  812. url: /^https?:\/\/www\.youtube\.com\/results/,
  813. enabled: true,
  814. engineList: "video",
  815. fixedTop:56,
  816. style: "\
  817. z-index:9;\
  818. margin-top: 62px;\
  819. margin-bottom: -80px;\
  820. text-align: center;\
  821. backgroud:#fff;\
  822. ",
  823. insertIntoDoc: {
  824. keyword: 'css;input#search',
  825. target: 'css;#page-manager',
  826. where: 'beforeBegin',
  827. },
  828. },
  829. {name: "niconico",
  830. url: /^https?:\/\/www\.nicovideo\.jp\/search\//,
  831. enabled: true,
  832. engineList: "video",
  833. style: "\
  834. border-top: 1px solid #E8E8E8;\
  835. border-bottom: 1px solid #E8E8E8;\
  836. text-align: center;\
  837. ",
  838. insertIntoDoc: {
  839. keyword: 'css;#search_united',
  840. target: 'css;.tagListBox',
  841. where: 'beforeBegin',
  842. },
  843. },
  844. {name: "Iqiyi",
  845. url: /^https?:\/\/so\.iqiyi\.com\/so\/q/,
  846. enabled: true,
  847. engineList: "video",
  848. fixedTop:60,
  849. style: '\
  850. margin:0 auto;\
  851. width:1180px;\
  852. ',
  853. insertIntoDoc: {
  854. keyword: 'css;#data-widget-searchword',
  855. target: 'css;.mod_search_header',
  856. where: 'afterEnd'
  857. },
  858. },
  859. {name: "腾讯视频",
  860. url: /^https?:\/\/v\.qq\.com\/x\/search/i,
  861. engineList: "video",
  862. enabled: true,
  863. fixedTop:60,
  864. style: "width:1140px;margin:0 auto;",
  865. insertIntoDoc: {
  866. keyword: 'css;#keywords',
  867. target: 'css;.site_head_simple',
  868. where: 'afterEnd',
  869. },
  870. },
  871. {name: "樱花动漫",
  872. url: /^https?:\/\/www\.imomoe\.ai\/search/,
  873. engineList: "video",
  874. enabled: true,
  875. style: " \
  876. width:1140px;\
  877. margin:-10px auto 10px;,\
  878. ",
  879. insertIntoDoc: {
  880. keyword: '//input[@name="searchword"]',
  881. target: 'css;.head',
  882. where: 'afterEnd',
  883. },
  884. },
  885.  
  886.  
  887. // 音乐
  888. {name: "百度音乐",
  889. url: /^https?:\/\/music\.baidu\.com\/search/,
  890. enabled: true,
  891. engineList: "music",
  892. style: "\
  893. border-top: 0px solid #0064C4;\
  894. margin-bottom: 5px;\
  895. ",
  896. insertIntoDoc: {
  897. keyword: 'css;#ww',
  898. target: 'css;.nav-wrapper',
  899. where: 'beforeBegin',
  900. },
  901. },
  902. {name: "一听音乐",
  903. url: /^https?:\/\/so\.1ting\.com\/all\.do/,
  904. enabled: true,
  905. engineList: "music",
  906. style: "\
  907. text-align: center;\
  908. border-bottom: 1px solid #13B310;\
  909. border-top: 1px solid #13B310;\
  910. ",
  911. insertIntoDoc: {
  912. keyword: 'css;#keyword',
  913. target: 'css;.nav',
  914. where: 'beforeBegin',
  915. },
  916. },
  917. {name: "xiami",
  918. url: /^https?:\/\/www\.xiami\.com\/search/,
  919. enabled: true,
  920. engineList: "music",
  921. style: "\
  922. border-top: 1px solid #93D3FF;\
  923. text-align: center;\
  924. ",
  925. insertIntoDoc: {
  926. keyword: 'css;#search_text',
  927. target: 'css;.search_result',
  928. where: 'beforeBegin',
  929. },
  930. },
  931. {name: 'QQ音乐',
  932. url: /^https?:\/\/s\.music\.qq\.com/i,
  933. enabled: true,
  934. engineList: 'music',
  935. style:"\
  936. border-bottom: 1px solid #2B6DAE;\
  937. border-top: 1px solid #2B6DAE;\
  938. text-align: center;\
  939. ",
  940. insertIntoDoc: {
  941. keyword: 'css;#keyword',
  942. target: 'css;.mod_soso',
  943. where: 'afterEnd',
  944. },
  945. },
  946. {name: '网易云音乐',
  947. url: /^https?:\/\/music\.163\.com\/.*?#\/search/i,
  948. enabled: true,
  949. engineList: 'music',
  950. fixedTop:80,
  951. style:"\
  952. text-align: center;\
  953. padding-top:8px;\
  954. ",
  955. insertIntoDoc: {
  956. keyword: (function(){return decodeURI(document.URL.match(/s=(.+?)(&|$)/)[1]);}),
  957. target: 'css;.m-subnav.m-subnav-up.f-pr.j-tflag',
  958. where: 'afterEnd',
  959. },
  960. },
  961. {name: '音悦台',
  962. url: /^https?:\/\/so\.yinyuetai\.com\/\?keyword/,
  963. enabled: true,
  964. engineList: 'music',
  965. style:"\
  966. border-bottom: 1px solid #2B6DAE;\
  967. border-top: 1px solid #2B6DAE;\
  968. text-align: center;\
  969. ",
  970. insertIntoDoc: {
  971. keyword:function(){
  972. var url = window.location.href.substring(window.location.href.lastIndexOf("=")+1);
  973. return decodeURIComponent(url);
  974. },
  975. target: 'css;.content',
  976. where: 'afterEnd'
  977. },
  978. },
  979.  
  980.  
  981. // 图片
  982. {name: "百度图片",
  983. url: /^https?:\/\/image\.baidu\.com\/search/i,
  984. enabled: true,
  985. engineList: "image",
  986. fixedTop:95, //关闭关联联想的情况下
  987. // fixedTop:135, //
  988. style: '\
  989. margin-left:127px;\
  990. ',
  991. insertIntoDoc: {
  992. keyword: 'css;input#kw',
  993. target: 'css;.s_tab',
  994. where: 'afterEnd',
  995. },
  996. },
  997. {name: "谷歌图片",
  998. url: /^https?:\/\/\w{2,10}\.google(?:\.\D{1,3}){1,2}\/[^?]+\?.*&tbm=isch/i,
  999. enabled: true,
  1000. engineList: "image",
  1001. fixedTop:54,
  1002. style: '\
  1003. margin-left:136px;\
  1004. padding: 10px 5px 1px 22px;\
  1005. ',
  1006. insertIntoDoc: {
  1007. keyword: 'css;input[name=q]',
  1008. // target: 'css;#ucs',
  1009. target: 'css;.ndYZfc',
  1010. where: 'afterBegin',
  1011. // where: 'beforeEnd',
  1012. },
  1013. },
  1014. {name: "必应图片",
  1015. url: /^https?:\/\/.*\.bing\.com\/images\/search/i,
  1016. enabled: true,
  1017. engineList: "image",
  1018. fixedTop: 62,
  1019. style: '\
  1020. padding-left:90px;\
  1021. margin-top:-6px;\
  1022. ',
  1023. insertIntoDoc: {
  1024. keyword: 'css;#sb_form_q',
  1025. target: 'css;#rfPaneIn',
  1026. where: 'afterBegin',
  1027. },
  1028. },
  1029. {name: "flickr",
  1030. url: /^https?:\/\/www\.flickr\.com\/search\//,
  1031. engineList: "image",
  1032. enabled: true,
  1033. style: '\
  1034. z-index:1999;\
  1035. width:100%;\
  1036. border-top:1px solid #EBF1FF;\
  1037. border-bottom:0px solid #EBF1FF;\
  1038. ',
  1039. insertIntoDoc: {
  1040. keyword: function() {
  1041. var input = document.getElementById("autosuggest-input");
  1042. if (input) {
  1043. return input.value;
  1044. } else {
  1045. var m = location.search.match(/q=([^&]+)/i);
  1046. if (m) {
  1047. return decodeURIComponent(m[1]);
  1048. }
  1049. }
  1050. },
  1051. target: 'css;.using-slender-advanced-panel',
  1052. where: 'afterBegin'
  1053. },
  1054. },
  1055. {name: "pixiv",
  1056. url: /^http:\/\/www\.pixiv\.net\/search\.php/i,
  1057. engineList: "image",
  1058. enabled: true,
  1059. style: '\
  1060. margin: 0 auto;\
  1061. text-align: center;\
  1062. font-family: 微软雅黑;\
  1063. ',
  1064. insertIntoDoc: {
  1065. keyword: 'css;input[name=word]',
  1066. target: 'css;body',
  1067. where: 'beforeBegin'
  1068. },
  1069. },
  1070. {name: "花瓣",
  1071. url: /^https?:\/\/huaban\.com\/search\/\?/,
  1072. engineList: "image",
  1073. enabled: true,
  1074. style: '\
  1075. border-top:1px solid #EBF1FF;\
  1076. text-align: center;\
  1077. ',
  1078. insertIntoDoc: {
  1079. keyword: 'css;#query',
  1080. target: 'css;#search_switch',
  1081. where: 'afterEnd'
  1082. },
  1083. },
  1084. {name: "Pinterest",
  1085. url: /^https?:\/\/www\.pinterest\.com\/search\//,
  1086. engineList: "image",
  1087. enabled: true,
  1088. style: '\
  1089. text-align: center;\
  1090. margin-top:-11px;\
  1091. ',
  1092. insertIntoDoc: {
  1093. keyword: '//input[@name="q"]',
  1094. target: 'css;.headerContainer',
  1095. where: 'afterEnd'
  1096. },
  1097. },
  1098.  
  1099.  
  1100. // 资源下载
  1101. {
  1102. name: '海盗湾thepiratebay',
  1103. url: /^https?:\/\/thepiratebay\.org\/search/i,
  1104. engineList: 'bittorrent',
  1105. enabled: true,
  1106. style: '\
  1107. text-align: center;\
  1108. z-index: 9999;\
  1109. ',
  1110. insertIntoDoc: {
  1111. keyword: 'css;.inputbox',
  1112. target: 'css;#SearchResults',
  1113. where: 'beforeBegin',
  1114. },
  1115. },
  1116. {
  1117. name: '动漫花园',
  1118. url: /^https?:\/\/share\.dmhy\.org\/topics\/list\?keyword\=/i,
  1119. engineList: 'download',
  1120. enabled: true,
  1121. style: '\
  1122. text-align: center;\
  1123. ',
  1124. insertIntoDoc: {
  1125. keyword: 'css;#keyword',
  1126. target: 'css;.table.clear',
  1127. where: 'beforeBegin',
  1128. },
  1129. },
  1130. {
  1131. name: 'ED2K',
  1132. url: /^https?:\/\/www\.ed2000\.com\/filelist\.asp/i,
  1133. engineList: 'download',
  1134. enabled: true,
  1135. insertIntoDoc: {
  1136. keyword: 'css;.searchtxt',
  1137. target: 'css;.topsearch',
  1138. where: 'afterEnd',
  1139. },
  1140. },
  1141. {name: "人人影视",
  1142. url: /^https?:\/\/www\.zimuzu\.tv\/search\//,
  1143. engineList: "download",
  1144. enabled: true,
  1145. style: '\
  1146. border-bottom: 1px solid #00AFFF;\
  1147. text-align: center;\
  1148. ',
  1149. insertIntoDoc: {
  1150. keyword: '//input[@name="q"]',
  1151. target: 'css;.Header',
  1152. where: 'afterEnd',
  1153. },
  1154. },
  1155. {name: "subHD字幕",
  1156. url: /^https?:\/\/subhd\.com\/search/i,
  1157. engineList: "download",
  1158. enabled: true,
  1159. style: "\
  1160. border-bottom: 0px solid #CAD9EA;\
  1161. border-top: 0px solid #CAD9EA;\
  1162. text-align: center;\
  1163. top: -20px;\
  1164. ",
  1165. insertIntoDoc: {
  1166. keyword: 'css;#sn',
  1167. target: 'css;.navbar.navbar-inverse',
  1168. where: 'afterEnd',
  1169. },
  1170. },
  1171.  
  1172.  
  1173. //翻译词典
  1174. {name: "谷歌翻译",
  1175. url: /^https?:\/\/translate\.google(?:\.\D{1,4}){1,2}/i,
  1176. enabled: true,
  1177. engineList: "translate",
  1178. style: '\
  1179. padding-left:1px;\
  1180. margin:-1px 0 0 20px;\
  1181. ',
  1182. insertIntoDoc: {
  1183. keyword: 'css;#source',
  1184. target: 'css;#gba',
  1185. where: 'afterEnd',
  1186. },
  1187. },
  1188. {name: "百度翻译",
  1189. url: /^https?:\/\/fanyi\.baidu\.com/i,
  1190. enabled: true,
  1191. engineList: "translate",
  1192. style: '\
  1193. padding-left:1px;\
  1194. margin:0px auto;\
  1195. width:1220px;\
  1196. ',
  1197. insertIntoDoc: {
  1198. keyword: function(){
  1199. return document.querySelector("#baidu_translate_input").value;
  1200. },
  1201. target: 'css;.header',
  1202. where: 'afterEnd',
  1203. },
  1204. },
  1205. {name: "必应翻译",
  1206. url: /^https?:\/\/.*\.bing\.com\/dict\/search\?q\=/i,
  1207. enabled: true,
  1208. engineList: "translate",
  1209. style: '\
  1210. padding-left:110px;\
  1211. margin-top:-0px;\
  1212. ',
  1213. insertIntoDoc: {
  1214. keyword: 'css;#sb_form_q',
  1215. target: 'css;#b_header',
  1216. where: 'beforeEnd',
  1217. },
  1218. },
  1219. {name: "有道翻译",
  1220. url: /^https?:\/\/dict\.youdao\.com\/search/i,
  1221. enabled: true,
  1222. engineList: "translate",
  1223. fixedTop:64,
  1224. style: '\
  1225. padding-left:0px;\
  1226. margin-top:2px;\
  1227. text-align:center;\
  1228. ',
  1229. insertIntoDoc: {
  1230. keyword: 'css;#query',
  1231. target: 'css;.c-topbar-wrapper',
  1232. where: 'beforeEnd',
  1233. },
  1234. },
  1235. {name: "有道翻译2",
  1236. url: /^https?:\/\/dict\.youdao\.com\/w/i,
  1237. enabled: true,
  1238. engineList: "translate",
  1239. fixedTop:64,
  1240. style: '\
  1241. padding-left:0px;\
  1242. margin-top:2px;\
  1243. text-align:center;\
  1244. ',
  1245. insertIntoDoc: {
  1246. keyword: 'css;#query',
  1247. target: 'css;.c-topbar-wrapper',
  1248. where: 'beforeEnd',
  1249. },
  1250. },
  1251. {name: "海词",
  1252. url: /^https?:\/\/dict\.cn\/./,
  1253. enabled: true,
  1254. engineList: "translate",
  1255. style: "\
  1256. z-index : 99;\
  1257. margin : -30px auto 0;\
  1258. position : absolute;\
  1259. width : 100%;\
  1260. text-align : center;\
  1261. ",
  1262. insertIntoDoc: {
  1263. keyword: 'css;#q',
  1264. target: 'css;.top',
  1265. where: 'afterEnd'
  1266. }
  1267. },
  1268. {name: "金山词霸",
  1269. // https://www.iciba.com/word?w=test
  1270. url: /^https?:\/\/www\.iciba\.com\/word/i,
  1271. enabled: true,
  1272. engineList: "translate",
  1273. fixedTop:122,
  1274. style: '\
  1275. z-index : 0;\
  1276. ',
  1277. insertIntoDoc: {
  1278. keyword: '//input[@type="search"]',
  1279. target: 'css;.Search_input__1qgiU',
  1280. where: 'afterEnd',
  1281. },
  1282. },
  1283.  
  1284. // 购物
  1285. {name: "淘宝搜索",
  1286. url: /^https?:\/\/s\.taobao\.com\/search/,
  1287. enabled: true,
  1288. engineList: "shopping",
  1289. style: "\
  1290. margin:10px auto -10px;\
  1291. text-align: center;\
  1292. z-index: 99;\
  1293. ",
  1294. insertIntoDoc: {
  1295. keyword: function() {
  1296. var input = document.querySelector('#q');
  1297. if (input) {
  1298. return input.value;
  1299. } else {
  1300. var m = location.search.match(/q=([^&]+)/);
  1301. if (m) {
  1302. return decodeURIComponent(m[1]);
  1303. }
  1304. }
  1305. },
  1306. target: 'css;#main',
  1307. where: 'beforeBegin',
  1308. },
  1309. },
  1310. {name: "天猫超市搜索",
  1311. url: /^https?:\/\/list\.tmall\.com\/search_product\.htm.*from=chaoshi/i,
  1312. enabled: true,
  1313. engineList: "shopping",
  1314. fixedTop:37,
  1315. style: "\
  1316. z-index:9999;\
  1317. margin: 2px auto -10px;\
  1318. left:0;\
  1319. right:0;\
  1320. text-align:center;\
  1321. position:absolute;\
  1322. ",
  1323. insertIntoDoc: {
  1324. keyword: 'css;#mq',
  1325. target: 'css;.headerCon',
  1326. where: 'beforeBegin',
  1327. },
  1328. },
  1329. {name: "天猫搜索",
  1330. url: /^https?:\/\/list\.tmall\.com\/search_product\.htm/i,
  1331. enabled: true,
  1332. engineList: "shopping",
  1333. fixedTop:34,
  1334. style: "\
  1335. margin: 10px auto -10px;\
  1336. text-align:center;\
  1337. ",
  1338. insertIntoDoc: {
  1339. keyword: 'css;#mq',
  1340. target: 'css;.headerCon',
  1341. where: 'beforeBegin',
  1342. },
  1343. },
  1344. {name: "京东",
  1345. url: /^https?:\/\/search\.jd\.com\/Search/,
  1346. enabled: true,
  1347. engineList: "shopping",
  1348. style: "\
  1349. margin: 10px auto -10px;\
  1350. text-align: center;\
  1351. ",
  1352. insertIntoDoc: {
  1353. keyword: 'css;#key',
  1354. target: 'css;#header-2013',
  1355. where: 'beforeBegin',
  1356. },
  1357. },
  1358. {name: "苏宁",
  1359. url: /^https?:\/\/search\.suning\.com/i,
  1360. enabled: true,
  1361. engineList: "shopping",
  1362. style: "\
  1363. border-bottom: 1px solid #E5E5E5;\
  1364. border-top: 1px solid #E5E5E5;\
  1365. text-align: center;\
  1366. ",
  1367. insertIntoDoc: {
  1368. keyword: 'css;#searchKeywordsHidden',
  1369. target: 'css;.ng-toolbar',
  1370. where: 'afterEnd',
  1371. },
  1372. },
  1373. {name: "1号店",
  1374. url: /^https?:\/\/search\.yhd\.com\/c0-0\/k/i,
  1375. enabled: true,
  1376. engineList: "shopping",
  1377. style: "\
  1378. border-bottom: 1px solid #E5E5E5;\
  1379. border-top: 1px solid #E5E5E5;\
  1380. text-align: center;\
  1381. ",
  1382. insertIntoDoc: {
  1383. keyword: 'css;#keyword',
  1384. target: 'css;#global_top_bar',
  1385. where: 'afterEnd',
  1386. },
  1387. },
  1388. {name: "什么值得买",
  1389. // http://search.smzdm.com/?c=home&s=%E8%A5%BF%E6%B8%B8%E8%AE%B0
  1390. url: /^https?:\/\/search\.smzdm\.com\/\?/i,
  1391. enabled: true,
  1392. engineList: "shopping",
  1393. fixedTop:40,
  1394. style: "\
  1395. text-align: center;\
  1396. ",
  1397. insertIntoDoc: {
  1398. keyword: 'css;#J_search_input',
  1399. target: 'css;.search-inner',
  1400. where: 'afterEnd',
  1401. },
  1402. },
  1403. {name: "亚马逊",
  1404. // https://www.amazon.cn/s?k=%E4%BA%9A%E9%A9%AC%E9%80%8A%E7%BD%91
  1405. url: /^https?:\/\/www\.amazon\.cn\/s\?k/i,
  1406. enabled: true,
  1407. engineList: "shopping",
  1408. style: "\
  1409. margin:2px 0 -10px 0;\
  1410. ",
  1411. insertIntoDoc: {
  1412. keyword: 'css;#twotabsearchtextbox',
  1413. target: 'css;.sg-row',
  1414. where: 'afterBegin',
  1415. },
  1416. },
  1417. {name: "1688",
  1418. // https://s.1688.com/selloffer/offer_search.htm?keywords=%
  1419. url: /^https?:\/\/s\.1688\.com\/selloffer\/offer_search/i,
  1420. enabled: true,
  1421. engineList: "shopping",
  1422. fixedTop:88,
  1423. style: "\
  1424. margin:6px auto -20px;\
  1425. width:1390px;\
  1426. ",
  1427. insertIntoDoc: {
  1428. keyword: '//input[@name="keywords"]',
  1429. target: 'css;.header-container',
  1430. where: 'afterEnd',
  1431. },
  1432. },
  1433.  
  1434.  
  1435. //社交
  1436. {name: "新浪微博",
  1437. url: /^https?:\/\/s\.weibo\.com\/weibo\//i,
  1438. enabled: true,
  1439. engineList: "sociality",
  1440. fixedTop:48,
  1441. style: "\
  1442. // border-bottom: 1px solid #E5E5E5;\
  1443. // border-top: 1px solid #E5E5E5;\
  1444. // text-align: center;\
  1445. ",
  1446. insertIntoDoc: {
  1447. keyword: 'css;.searchInp_form',
  1448. target: 'css;#pl_common_searchTop',
  1449. where: 'afterEnd',
  1450. },
  1451. },
  1452. {name: "百度贴吧",
  1453. url: /^https?:\/\/tieba\.baidu\.com\/f\/search/i,
  1454. enabled: true,
  1455. engineList: "sociality",
  1456. style: "\
  1457. border-top: 1px solid #e5e5e5;\
  1458. text-align: center;\
  1459. border-bottom: 1px solid #e5e5e5;\
  1460. margin-bottom: 1px;\
  1461. ",
  1462. insertIntoDoc: {
  1463. keyword: 'css;#wd1',
  1464. target: 'css;.s_container.clearfix',
  1465. where: 'beforeBegin',
  1466. },
  1467. },
  1468. {name: "豆瓣1",
  1469. url: /^https?:\/\/(movie|music|book)\.douban\.com\/subject_search?/,
  1470. enabled: true,
  1471. engineList: "sociality",
  1472. style: "\
  1473. border-top: 1px solid #e5e5e5;\
  1474. text-align: center;\
  1475. border-bottom: 1px solid #e5e5e5;\
  1476. margin-bottom: 1px;\
  1477. ",
  1478. insertIntoDoc: {
  1479. keyword: 'css;#inp-query',
  1480. target: 'css;.nav-secondary',
  1481. where: 'afterEnd'
  1482. },
  1483. },
  1484. {name: "豆瓣2",
  1485. url: /^https?:\/\/www\.douban\.com\/search/i,
  1486. enabled: true,
  1487. engineList: "sociality",
  1488. style: "\
  1489. border-top: 1px solid #e5e5e5;\
  1490. text-align: center;\
  1491. border-bottom: 1px solid #e5e5e5;\
  1492. margin-bottom: 1px;\
  1493. ",
  1494. insertIntoDoc: {
  1495. keyword: 'css;#inp',
  1496. target: 'css;#db-global-nav',
  1497. where: 'afterEnd'
  1498. },
  1499. },
  1500.  
  1501.  
  1502. //学术搜索列表
  1503. {name: "百度学术",
  1504. url: /^https?:\/\/xueshu\.baidu\.com\/(?:s|baidu)/,
  1505. enabled: true,
  1506. engineList: "scholar",
  1507. style: '\
  1508. text-align: center;\
  1509. margin:0px;\
  1510. top:0px;\
  1511. z-index:99999;\
  1512. ',
  1513. insertIntoDoc: {
  1514. keyword: 'css;input#kw',
  1515. target: 'css;#head_wr',
  1516. where: 'afterEnd',
  1517. },
  1518. },
  1519. {name: "谷歌学术",
  1520. enabled: true,
  1521. url: /^https?:\/\/scholar\.google(?:\.\D{1,3}){1,2}\/scholar\?/,
  1522. engineList: "scholar",
  1523. style: '\
  1524. z-index:999;\
  1525. position:relative;\
  1526. ',
  1527. insertIntoDoc: {
  1528. target: 'css;#gs_ab',
  1529. keyword: '//input[@name="q"]',
  1530. where: 'beforeBegin'
  1531. }
  1532. },
  1533. {name: "cnki",
  1534. url: /^http:\/\/search\.cnki\.net\/search\.aspx/i,
  1535. enabled: true,
  1536. engineList: "scholar",
  1537. style: '\
  1538. padding-left:15px;\
  1539. border-top:1px solid #D9E1F7;\
  1540. border-bottom:1px solid #D9E1F7;\
  1541. margin-top:-1px;\
  1542. ',
  1543. insertIntoDoc: {
  1544. keyword:'css;#txtSearchKey',
  1545. target:'css;.main',
  1546. where:'afterBegin',
  1547. },
  1548. },
  1549. {name: "知网",
  1550. enabled: true,
  1551. url: /^http:\/\/epub\.cnki\.net\/kns\/brief\/default_result\.aspx/i,
  1552. engineList: "scholar",
  1553. style: '\
  1554. border-bottom:1px solid #E5E5E5;\
  1555. border-top:1px solid #E5E5E5;\
  1556. z-index:999;\
  1557. position:relative;\
  1558. ',
  1559. insertIntoDoc: {
  1560. keyword:'css;#txt_1_value1',
  1561. target:'css;#TopSearchBar',
  1562. where:'afterEnd',
  1563. }
  1564. },
  1565. {name: "万方",
  1566. enabled: true,
  1567. url: /^https?:\/\/s\.g\.wanfangdata\.com\.cn\/Paper\.aspx/i,
  1568. engineList: "scholar",
  1569. style: '\
  1570. border-bottom:1px solid #E5E5E5;\
  1571. border-top:1px solid #E5E5E5;\
  1572. z-index:999;\
  1573. position:relative;\
  1574. ',
  1575. insertIntoDoc: {
  1576. keyword:'css;#queryBox',
  1577. target:'css;#content',
  1578. where:'beforeBegin',
  1579. }
  1580. },
  1581. {name: "EBSCO",
  1582. enabled: true,
  1583. url: /^http:\/\/.*?ebscohost\.com\/.*?results/i,
  1584. engineList: "scholar",
  1585. style: '\
  1586. border-bottom:1px solid #E5E5E5;\
  1587. border-top:1px solid #E5E5E5;\
  1588. position:relative;\
  1589. ',
  1590. insertIntoDoc: {
  1591. keyword:'css;#SearchTerm1',
  1592. target:'css;#findFieldOuter',
  1593. where:'afterend',
  1594. }
  1595. },
  1596. {name: "Springer",
  1597. enabled: true,
  1598. url: /^http:\/\/link\.springer\.com\/search\?query=/i,
  1599. engineList: "scholar",
  1600. style: '\
  1601. border-bottom:1px solid #E5E5E5;\
  1602. border-top:1px solid #E5E5E5;\
  1603. position:relative;\
  1604. ',
  1605. insertIntoDoc: {
  1606. keyword:'css;#query',
  1607. target:'css;#content',
  1608. where:'beforeBegin',
  1609. }
  1610. },
  1611. {name: "JSTOR",
  1612. enabled: true,
  1613. url: /^https?:.*?jstor.org\/action\/doAdvancedSearch/i,
  1614. engineList: "scholar",
  1615. style: '\
  1616. border-bottom:1px solid #E5E5E5;\
  1617. border-top:1px solid #E5E5E5;\
  1618. position:relative;\
  1619. ',
  1620. insertIntoDoc: {
  1621. keyword:'css;#searchBox',
  1622. target:'css;.tabs-search-results',
  1623. where:'beforeBegin',
  1624. }
  1625. },
  1626.  
  1627. //html 列表
  1628. {name: "w3c",
  1629. enabled:true,
  1630. url:/^https?:.*?runoob\.com\//i,
  1631. engineList:"mine",
  1632. style: '\
  1633. border-bottom:1px solid #E5E5E5;\
  1634. border-top:1px solid #E5E5E5;\
  1635. position:relative;\
  1636. text-align:center;\
  1637. ',
  1638. insertIntoDoc: {
  1639. keyword:function(){
  1640. var url = window.location.href.substring(window.location.href.lastIndexOf("=")+1);
  1641. return decodeURIComponent(url);
  1642. },
  1643. target:'css;.navigation',
  1644. where:'afterEnd',
  1645. }
  1646. },
  1647. {
  1648. name: "GitHub",
  1649. enabled:true,
  1650. url:/^https?:\/\/github\.com\/search/,
  1651. engineList:"mine",
  1652. style:'\
  1653. position:relative;\
  1654. text-align:center;\
  1655. ',
  1656. insertIntoDoc: {
  1657. keyword:'//input[@name="q"]',
  1658. target:'css;.Header',
  1659. where:'afterEnd',
  1660. }
  1661. },
  1662. {
  1663. name: "MDN",
  1664. enabled:true,
  1665. url:/^https?:\/\/developer\.mozilla\.org\/.{2,5}\/search/,
  1666. engineList:"mine",
  1667. style:'\
  1668. position:relative;\
  1669. text-align:center;\
  1670. ',
  1671. insertIntoDoc: {
  1672. keyword:function(){
  1673. var url = window.location.href.substring(window.location.href.lastIndexOf("=")+1);
  1674. return decodeURIComponent(url);
  1675. },
  1676. target:'css;.results-search-form',
  1677. where:'afterEnd',
  1678. }
  1679. },
  1680.  
  1681. // 其他补充, 这个脚本将会朝重型方向发展,如果嫌弃代码过多,可自行删减无用代码
  1682. {
  1683. name: "infinitynewtab",
  1684. enabled:true,
  1685. //https://google.infinitynewtab.com/?q=苹果
  1686. url:/^https?:\/\/google\.infinitynewtab\.com\/\?q/,
  1687. engineList:"web",
  1688. style:'\
  1689. text-align:center;\
  1690. position:fixed;\
  1691. z-index:99999;\
  1692. top:0;\
  1693. ',
  1694. insertIntoDoc: {
  1695. target: 'css;.searchbox-results',
  1696. // keyword: '//input[@name="search"]',
  1697. keyword: 'css;input.gsc-input',
  1698. where: 'beforeBegin',
  1699. }
  1700. },
  1701. {
  1702. name: "头条搜索",
  1703. //https://so.toutiao.com/search
  1704. url:/^https?:\/\/so\.toutiao\.com\/search/,
  1705. engineList:"web",
  1706. enabled:true,
  1707. fixedTop:75,
  1708. style:'\
  1709. margin-left:146px;\
  1710. z-index:99999;\
  1711. ',
  1712. insertIntoDoc: {
  1713. target: 'css;.result-content',
  1714. // keyword: '//input[@name="search"]',
  1715. keyword: '//input[@type="search"]',
  1716. where: 'beforeEnd',
  1717. }
  1718. },
  1719. {
  1720. name: "抖音搜索",
  1721. //https://www.douyin.com/search/
  1722. url:/^https?:\/\/www\.douyin\.com\/search/,
  1723. engineList:"web",
  1724. enabled:true,
  1725. fixedTop:116,
  1726. fixedTopColor:"rgb(22 23 34)",
  1727. style:'\
  1728. margin:-10px 0 0 -10px;\
  1729. z-index:99999;\
  1730. ',
  1731. insertIntoDoc: {
  1732. target: 'css;.CHUUyANc',
  1733. // keyword: '//input[@name="search"]',
  1734. keyword: function () {
  1735. var input = document.querySelector('input[type="text"]');
  1736. if (input) return input.value;
  1737. },
  1738. where: 'beforeEnd',
  1739. }
  1740. },
  1741. // 用户补充: kidzgy
  1742. // https://gf.qytechs.cn/zh-CN/scripts/27752/discussions/90497
  1743. {
  1744. name: "企查查",
  1745. url: /^https?:\/\/www\.qcc\.com\/(?:web|firm|)/,
  1746. engineList: 'enterprise',
  1747. enabled: true,
  1748. fixedTop:56,
  1749. style: '\
  1750. width:1250px;\
  1751. margin: 0 auto;\
  1752. padding-left: 15px;\
  1753. ',
  1754. insertIntoDoc: {
  1755. keyword: 'css;#searchKey',
  1756. target: 'css;.app-nheader',
  1757. where: 'AfterEnd',
  1758. },
  1759. stylish: ' .bigsearch-nav.fixed > .nav-wrap { position: static !important; }',
  1760. },
  1761. {
  1762. name: "天眼查",
  1763. url: /^https?:\/\/www\.tianyancha\.com\/(?:search|company)/,
  1764. engineList: 'enterprise',
  1765. enabled: true,
  1766. fixedTop:73,
  1767. style: '\
  1768. top:80px;\
  1769. margin: 0 auto;\
  1770. width:1248px;\
  1771. ',
  1772. insertIntoDoc: {
  1773. keyword: 'css;#header-company-search',
  1774. target: 'css;.tyc-header',
  1775. where: 'AfterEnd',
  1776. },
  1777. stylish: '#web-content.mt122{margin-top:90px !important} .search-bar{position:static !important}',
  1778. },
  1779.  
  1780.  
  1781. // 回家没网,用8090端口离线测试使用。
  1782. {
  1783. name:"test",
  1784. enabled:true,
  1785. url:/^https?:\/\/127\.0\.0\.1:8090\/./,
  1786. style:"\
  1787. margin:150px;\
  1788. ",
  1789. insertIntoDoc: {
  1790. keyword:function(){return false},
  1791. target:'css;body',
  1792. where:'beforeEnd',
  1793. }
  1794. }
  1795. ];
  1796. // 有些图标需要重复使用
  1797. var icon ={};
  1798. icon = {
  1799. google:"",
  1800. // baidu:"",
  1801. baidu:"",
  1802. bing:'',
  1803. edit:"",
  1804. del:"",
  1805. web : "",
  1806. translate: "",
  1807. knowledge:"",
  1808. image:"",
  1809. video:"",
  1810. music:"",
  1811. shopping:"",
  1812. sociality:"",
  1813. download:"",
  1814. scholar:"",
  1815. news:"",
  1816. mine:"",
  1817. };
  1818.  
  1819. // 搜索引擎列表
  1820. var engineList = {};
  1821.  
  1822. // 网页搜索列表
  1823. engineList.web = [];
  1824.  
  1825. engineList.web[0] = {
  1826. name: '百度',
  1827. url: 'https://www.baidu.com/s?wd=%s&ie=utf-8',
  1828. favicon: icon.baidu,
  1829. };
  1830. // engineList.web[0] 中间的数字表示排序(数字不能重复,否则后面的会覆盖掉前面的),越小数字越靠前,小于0该引擎不会显示在页面上
  1831. engineList.web[1] = {
  1832. // 搜索引擎名称
  1833. name: 'Google',
  1834. // 搜索引擎地址,关键字变量用%s代替
  1835. url: 'https://www.google.com/search?q=%s&ie=utf-8&oe=utf-8',
  1836. // 搜索引擎的站点图标
  1837. // favicon: '',
  1838. favicon: icon.google,
  1839. // 弃用;搜索引擎编码(默认utf-8)如果跳转后乱码可以填写 'gbk'
  1840. // 弃用:encoding: 'utf-8',
  1841. // 如果网站使用的gbk编码
  1842. gbk:false,
  1843. // 新标签页打开
  1844. // blank:true,
  1845. // 禁用该搜索, 只在设置中显示该搜索
  1846. // disable:true,
  1847. };
  1848. engineList.web[2] = {
  1849. name: '必应',
  1850. url: 'https://cn.bing.com/search?q=%s',
  1851. favicon: icon.bing,
  1852. };
  1853. engineList.web[3] = {
  1854. name: '360',
  1855. url: 'https://www.so.com/s?ie=utf-8&q=%s',
  1856. favicon: '',
  1857. // disable:true,
  1858. };
  1859. engineList.web[4] = {
  1860. name: 'yahoo',
  1861. url: 'https://search.yahoo.com/search;?p=%s',
  1862. favicon: '',
  1863. disable:true,
  1864. };
  1865. engineList.web[5] = {
  1866. name: '搜狗',
  1867. url: 'https://www.sogou.com/web?query=%s',
  1868. favicon: '',
  1869. disable:true,
  1870. };
  1871. engineList.web[6] = {
  1872. name: 'Startpage',
  1873. url: 'https://www.startpage.com/do/asearch$post$query',
  1874. favicon: '',
  1875. disable:true,
  1876. };
  1877. engineList.web[7] = {
  1878. name: 'Yandex',
  1879. url: 'https://yandex.com/search/?text=%s',
  1880. favicon: '',
  1881. };
  1882. engineList.web[8] = {
  1883. name: 'DDG',
  1884. url: 'https://duckduckgo.com/?q=%s',
  1885. favicon: '',
  1886. disable:true,
  1887. };
  1888.  
  1889.  
  1890. // 视频搜索列表
  1891. engineList.video = [];
  1892.  
  1893. engineList.video[0] = {
  1894. name: 'bilibili',
  1895. url: 'http://search.bilibili.com/all?keyword=%s',
  1896. favicon: '',
  1897. };
  1898. engineList.video[1] = {
  1899. name: 'youtube',
  1900. url: 'https://www.youtube.com/results?search_query=%s',
  1901. favicon: '',
  1902. };
  1903. engineList.video[2] = {
  1904. name: '优酷',
  1905. url: "http://www.soku.com/search_video/q_%s",
  1906. favicon: '',
  1907. };
  1908. engineList.video[3] = {
  1909. name: '腾讯视频',
  1910. url: 'https://v.qq.com/x/search/?q=%s',
  1911. favicon: '',
  1912. };
  1913. engineList.video[4] = {
  1914. name: 'AcFun',
  1915. url: 'https://www.acfun.cn/search/?type=complex&keyword=%s',
  1916. favicon: '',
  1917. };
  1918. engineList.video[5] = {
  1919. name: '乐视',
  1920. url: 'http://so.letv.com/s?wd=%s',
  1921. favicon: '',
  1922. blank:true,
  1923. };
  1924. engineList.video[6] = {
  1925. name: '搜狐',
  1926. url: 'http://so.tv.sohu.com/mts?wd=%s',
  1927. favicon: '',
  1928. blank:true,
  1929. };
  1930. engineList.video[7] = {
  1931. name: 'niconico',
  1932. url: 'http://www.nicovideo.jp/search/%s',
  1933. favicon: '',
  1934. };
  1935. engineList.video[8] = {
  1936. name: '爱奇艺',
  1937. url: 'http://so.iqiyi.com/so/q_%s',
  1938. favicon: '',
  1939. };
  1940. engineList.video[9] = {
  1941. name: "樱花动漫",
  1942. url: "http://www.imomoe.in/search.asp?searchword=%s",
  1943. favicon: "",
  1944. gbk: "true",
  1945. disable:true,
  1946. }
  1947.  
  1948. // 音乐搜索列表
  1949. engineList.music = [];
  1950.  
  1951. engineList.music[0] = {
  1952. name: '网易音乐',
  1953. url: 'http://music.163.com/#/search/m/?s=%s',
  1954. favicon: '',
  1955. };
  1956. engineList.music[1] = {
  1957. name: 'QQ音乐',
  1958. url: 'https://y.qq.com/portal/search.html#page=1&searchid=1&remoteplace=txt.yqq.top&t=song&w=%s',
  1959. favicon: '',
  1960. blank:true,
  1961. };
  1962. engineList.music[2] = {
  1963. name: '百度音乐',
  1964. url: 'http://music.baidu.com/search?ie=utf-8&oe=utf-8&key=%s',
  1965. favicon: icon.baidu,
  1966. };
  1967. engineList.music[3] = {
  1968. name: '酷我音乐',
  1969. url: 'http://sou.kuwo.cn/ws/NSearch?type=all&key=%s',
  1970. favicon: '',
  1971. blank:true,
  1972. };
  1973. engineList.music[4] = {
  1974. name: '5sing',
  1975. url: 'http://search.5sing.kugou.com/?keyword=%s',
  1976. favicon: '',
  1977. blank:true,
  1978. };
  1979. engineList.music[5] = {
  1980. name: '一听',
  1981. url: 'http://so.1ting.com/all.do?q=%s',
  1982. favicon: '',
  1983. };
  1984.  
  1985. // 图片搜索列表
  1986. engineList.image = [];
  1987.  
  1988. engineList.image[0] = {
  1989. name: '百度图片',
  1990. url: 'http://image.baidu.com/search/index?tn=baiduimage&ie=utf-8&word=%s',
  1991. favicon: icon.baidu,
  1992. };
  1993. engineList.image[1] = {
  1994. name: '谷歌图片',
  1995. url: 'https://www.google.com/search?q=%s&tbm=isch',
  1996. favicon: icon.google,
  1997. };
  1998. engineList.image[2] = {
  1999. name: '必应图片',
  2000. url: 'https://www.bing.com/images/search?q=%s',
  2001. favicon: icon.bing
  2002. };
  2003. engineList.image[3] = {
  2004. name: 'pixiv',
  2005. url: 'http://www.pixiv.net/search.php?word=%s',
  2006. favicon: '',
  2007. };
  2008. engineList.image[4] = {
  2009. name: 'flickr',
  2010. url: 'http://www.flickr.com/search/?q=%s',
  2011. favicon: '',
  2012. };
  2013. engineList.image[5] = {
  2014. name: '花瓣',
  2015. url: 'http://huaban.com/search/?q=%s',
  2016. favicon: '',
  2017. };
  2018. engineList.image[6] = {
  2019. name: 'Pinterest',
  2020. url: 'https://www.pinterest.com/search/pins/?q=%s&rs=typed&term_meta',
  2021. favicon: '',
  2022. };
  2023. engineList.image[7] = {
  2024. name: 'Yandex',
  2025. url: 'https://yandex.com/images/search?from=tabbar&text=%s',
  2026. favicon: '',
  2027. };
  2028.  
  2029. // 下载资源
  2030. engineList.download = [];
  2031.  
  2032. engineList.download[0] = {
  2033. name: '海盗湾',
  2034. url: 'https://thepiratebay.org/search/%s',
  2035. favicon: ''
  2036. };
  2037. engineList.download[1] = {
  2038. name: '谷歌搜索',
  2039. blank:true,
  2040. url: 'https://cse.google.com/?q=%s&newwindow=1&cx=006100883259189159113%3Atwgohm0sz8q',
  2041. favicon: icon.google,
  2042. };
  2043. engineList.download[2] = {
  2044. name: '动漫花园',
  2045. url: 'https://share.dmhy.org/topics/list?keyword=%s',
  2046. favicon: ''
  2047. };
  2048.  
  2049.  
  2050. // 购物列表
  2051.  
  2052. engineList.shopping = [];
  2053. engineList.shopping[0] = {
  2054. name: '淘宝',
  2055. url: 'http://s.taobao.com/search?q=%s',
  2056. favicon: '',
  2057. };
  2058. engineList.shopping[1] = {
  2059. name: '京东',
  2060. url: 'http://search.jd.com/Search?keyword=%s&enc=utf-8',
  2061. favicon: '',
  2062. };
  2063. engineList.shopping[2] = {
  2064. name: '苏宁',
  2065. url: 'http://search.suning.com/%s/',
  2066. favicon: '',
  2067. };
  2068. engineList.shopping[3] = {
  2069. name: '亚马逊',
  2070. url: 'http://www.amazon.cn/s/ref=nb_sb_noss?field-keywords=%s',
  2071. favicon: '',
  2072. };
  2073. engineList.shopping[4] = {
  2074. name: '天猫',
  2075. url: 'http://list.tmall.com/search_product.htm?q=%s',
  2076. favicon: '',
  2077. };
  2078. engineList.shopping[5] = {
  2079. name: '值得买',
  2080. url: 'http://search.smzdm.com/?c=home&s=%s',
  2081. favicon: '',
  2082. blank:true,
  2083. };
  2084. engineList.shopping[6] = {
  2085. name: '当当网',
  2086. url: 'http://search.dangdang.com/?key=%s',
  2087. favicon: '',
  2088. blank:true,
  2089. };
  2090. engineList.shopping[7] = {
  2091. name: '1688',
  2092. url: 'https://s.1688.com/selloffer/offer_search.htm?keywords=%s',
  2093. favicon: '',
  2094. blank:true,
  2095. gbk:true,
  2096. };
  2097.  
  2098. //翻译列表
  2099. engineList.translate = [];
  2100.  
  2101. engineList.translate[0] = {
  2102. name: '百度翻译',
  2103. url: 'http://fanyi.baidu.com/#auto/zh/%s',
  2104. favicon: '',
  2105. };
  2106. engineList.translate[1] = {
  2107. name: '谷歌翻译',
  2108. url: 'https://translate.google.com/?q=%s',
  2109. favicon: '',
  2110. };
  2111. engineList.translate[2] = {
  2112. name: '有道词典',
  2113. url: 'http://dict.youdao.com/search?q=%s',
  2114. favicon: '',
  2115. blank:true,
  2116. };
  2117. engineList.translate[3] = {
  2118. name: '必应翻译',
  2119. url: 'http://cn.bing.com/dict/search?q=%s',
  2120. favicon: icon.bing
  2121. };
  2122. engineList.translate[4] = {
  2123. name: 'Forvo发音',
  2124. url: 'https://zh.forvo.com/search/%s',
  2125. favicon: '',
  2126. blank:true,
  2127. };
  2128. engineList.translate[5] = {
  2129. name: 'CNKI翻译',
  2130. url: 'http://dict.cnki.net/dict_result.aspx?searchword=%s',
  2131. favicon: '',
  2132. disable:true,
  2133. };
  2134. engineList.translate[6] = {
  2135. name: '汉典',
  2136. url: 'http://www.zdic.net/sousuo/?q=%s',
  2137. favicon: '',
  2138. disable:true,
  2139. };
  2140. engineList.translate[7] = {
  2141. name: '海词',
  2142. url: 'http://dict.cn/%s',
  2143. favicon: "",
  2144. };
  2145. engineList.translate[8] = {
  2146. name: 'DeepL',
  2147. url: 'https://www.deepl.com/translator#zh/en/%s',
  2148. favicon: "",
  2149. disable:true,
  2150. };
  2151. engineList.translate[9] = {
  2152. name: '金山词霸',
  2153. url: 'https://www.iciba.com/word?w=%s',
  2154. favicon: "",
  2155. blank:true,
  2156. };
  2157.  
  2158. //知识列表
  2159. engineList.knowledge = [];
  2160. engineList.knowledge[0] = {
  2161. name: '知乎',
  2162. url: 'http://www.zhihu.com/search?q=%s',
  2163. favicon: '',
  2164. };
  2165. engineList.knowledge[1] = {
  2166. name: '维基',
  2167. url: 'http://zh.wikipedia.org/wiki/%s',
  2168. favicon: '',
  2169. };
  2170. engineList.knowledge[2] = {
  2171. name: '百度百科',
  2172. url: 'http://baike.baidu.com/search/word?pic=1&sug=1&word=%s',
  2173. favicon: icon.baidu,
  2174. disable:true,
  2175. };
  2176. engineList.knowledge[3] = {
  2177. name: '百度文库',
  2178. url: 'http://wenku.baidu.com/search?word=%s&ie=utf-8',
  2179. favicon: icon.baidu,
  2180. };
  2181. engineList.knowledge[4] = {
  2182. name: '豆丁文档',
  2183. url: 'http://www.docin.com/search.do?searchcat=2&searchType_banner=p&nkey=%s',
  2184. favicon: '',
  2185. disable:true,
  2186. };
  2187. engineList.knowledge[5] = {
  2188. name: '爱问知识',
  2189. url: 'http://iask.sina.com.cn/search?searchWord=%s',
  2190. favicon: '',
  2191. disable:true,
  2192. };
  2193. engineList.knowledge[6] = {
  2194. name: '萌娘百科',
  2195. url: 'https://zh.moegirl.org/%s',
  2196. favicon: "",
  2197. blank:true,
  2198. };
  2199. engineList.knowledge[7] = {
  2200. name: '知乎(搜狗)',
  2201. url: 'http://zhihu.sogou.com/zhihu?ie=utf8&query=%s',
  2202. favicon: '',
  2203. disable:true,
  2204. };
  2205. engineList.knowledge[8] = {
  2206. name: 'Quora',
  2207. url: 'https://www.quora.com/search?q=%s',
  2208. favicon: '',
  2209. };
  2210. engineList.knowledge[9] = {
  2211. name: 'stackoverflow',
  2212. url: 'https://stackoverflow.com/search?q=%s',
  2213. favicon: '',
  2214. };
  2215.  
  2216. //社交列表
  2217. engineList.sociality = [];
  2218.  
  2219. engineList.sociality[0] = {
  2220. name: '百度贴吧',
  2221. url: 'http://tieba.baidu.com/f?kw=%s&ie=utf-8',
  2222. favicon: icon.baidu,
  2223. blank:true,
  2224. };
  2225. engineList.sociality[1] = {
  2226. name: '新浪微博',
  2227. url: 'http://s.weibo.com/weibo/%s',
  2228. favicon: '',
  2229. };
  2230. engineList.sociality[2] = {
  2231. name: '抖音搜索',
  2232. url: 'https://www.douyin.com/search/%s',
  2233. favicon: '',
  2234. };
  2235. engineList.sociality[3] = {
  2236. name: '豆瓣',
  2237. url: 'http://www.douban.com/search?source=suggest&q=%s',
  2238. favicon: '',
  2239. };
  2240. engineList.sociality[4] = {
  2241. name: 'Twitter',
  2242. url: 'https://twitter.com/search/%s',
  2243. favicon: '',
  2244. };
  2245. engineList.sociality[5] = {
  2246. name: 'Facebook',
  2247. url: 'https://www.facebook.com/search/results.php?q=%s',
  2248. favicon: '',
  2249. };
  2250. engineList.sociality[6] = {
  2251. name: '微信搜索',
  2252. url: 'http://weixin.sogou.com/weixin?ie=utf8&type=2&query=%s',
  2253. favicon: '',
  2254. };
  2255.  
  2256.  
  2257. // 学术搜索列表
  2258. engineList.scholar = [];
  2259.  
  2260. engineList.scholar[0] = {
  2261. name: '谷歌学术',
  2262. url: 'https://scholar.google.com/scholar?hl=zh-CN&q=%s',
  2263. favicon: '',
  2264. };
  2265. engineList.scholar[1] = {
  2266. name: '百度学术',
  2267. url: 'http://xueshu.baidu.com/s?wd=%s',
  2268. favicon: icon.baidu,
  2269. };
  2270. engineList.scholar[2] = {
  2271. name: '知网',
  2272. url: 'https://kns.cnki.net/kns8/defaultresult/index?code=SCDB&kw=%s',
  2273. favicon: '',
  2274. };
  2275. engineList.scholar[3] = {
  2276. name: '万方',
  2277. url: 'http://s.g.wanfangdata.com.cn/Paper.aspx?q=%s',
  2278. favicon: '',
  2279. };
  2280. engineList.scholar[4] = {
  2281. name: 'EBSCO',
  2282. url: 'http://web.b.ebscohost.com/ehost/results?sid=8e76c941-084d-4b93-b05a-d5f182196017%40sessionmgr102&vid=1&hid=128&bquery=%s',
  2283. favicon: '',
  2284. };
  2285. engineList.scholar[5] = {
  2286. name: 'WOS',
  2287. url: 'http://apps.webofknowledge.com/UA_GeneralSearch.do?fieldCount=3&action=search&product=UA&search_mode=GeneralSearch&max_field_count=25&max_field_notice=Notice%3A+You+cannot+add+another+field.&input_invalid_notice=Search+Error%3A+Please+enter+a+search+term.&input_invalid_notice_limits=+%3Cbr%2F%3ENote%3A+Fields+displayed+in+scrolling+boxes+must+be+combined+with+at+least+one+other+search+field.&sa_img_alt=Select+terms+from+the+index&value(input1)=%s&value%28select1%29=TI&value%28hidInput1%29=initVoid&value%28hidShowIcon1%29=0&value%28bool_1_2%29=AND&value%28input2%29=&value%28select2%29=AU&value%28hidInput2%29=initAuthor&value%28hidShowIcon2%29=1&value%28bool_2_3%29=AND&value%28input3%29=&value%28select3%29=SO&value%28hidInput3%29=initSource&value%28hidShowIcon3%29=1&limitStatus=collapsed&expand_alt=Expand+these+settings&expand_title=Expand+these+settings&collapse_alt=Collapse+these+settings&collapse_title=Collapse+these+settings&SinceLastVisit_UTC=&SinceLastVisit_DATE=&timespanStatus=display%3A+block&timeSpanCollapsedListStatus=display%3A+none&period=Range+Selection&range=ALL&ssStatus=display%3Anone&ss_lemmatization=On&ss_query_language=&rsStatus=display%3Anone&rs_rec_per_page=10&rs_sort_by=PY.D%3BLD.D%3BVL.D%3BSO.A%3BPG.A%3BAU.A&rs_refinePanel=visibility%3Ashow',
  2288. favicon: '',
  2289. };
  2290. engineList.scholar[6] = {
  2291. name: 'JSTOR',
  2292. url: 'http://www.jstor.org/action/doAdvancedSearch?q0=%s',
  2293. favicon: '',
  2294. };
  2295. engineList.scholar[7] = {
  2296. name: 'Springer',
  2297. url: 'http://rd.springer.com/search?query=%s',
  2298. favicon: '',
  2299. };
  2300.  
  2301. engineList.news = [];
  2302.  
  2303. engineList.news[0] = {
  2304. name: "谷歌中文",
  2305. url: "https://news.google.com/search?q=%s&hl=zh-CN&gl=CN&ceid=CN:zh-Hans",
  2306. favicon:"",
  2307. blank: true,
  2308. };
  2309. engineList.news[1] = {
  2310. name: "百度新闻",
  2311. url: "http://news.baidu.com/ns?word=%s&tn=news&from=news&cl=2&rn=20&ct=1",
  2312. favicon:icon.baidu,
  2313. blank: true,
  2314. };
  2315. engineList.news[2] = {
  2316. name: "网易-百度",
  2317. url: "https://www.baidu.com/s?wd=%s%20site%3Anews.163.com",
  2318. favicon:"",
  2319. blank: true,
  2320. };
  2321. engineList.news[3] = {
  2322. name: "网易-谷歌",
  2323. url: "https://www.google.com.hk/search?q=site:news.163.com+%s",
  2324. favicon:"",
  2325. blank: true,
  2326. };
  2327. engineList.news[4] = {
  2328. name: "腾讯新闻",
  2329. url: "https://www.sogou.com/sogou?site=news.qq.com&query=%s",
  2330. favicon:"",
  2331. blank: true,
  2332. };
  2333. engineList.news[5] = {
  2334. name: "凤凰新闻",
  2335. url: "http://search.ifeng.com/sofeng/search.action?q=%s",
  2336. favicon:"",
  2337. blank: true,
  2338. };
  2339. engineList.news[6] = {
  2340. name: "CNN",
  2341. url: "https://edition.cnn.com/search/?q=%s",
  2342. favicon:"",
  2343. blank: true,
  2344. };
  2345. engineList.news[7] = {
  2346. name: "BBC",
  2347. url: "https://www.bbc.co.uk/search?q=%s",
  2348. favicon:"",
  2349. blank: true,
  2350. };
  2351. engineList.news[8] = {
  2352. name: "Economis",
  2353. url: "https://www.google.com/search?q=site:www.economist.com%20%s",
  2354. favicon:"",
  2355. blank: true,
  2356. };
  2357. engineList.news[9] = {
  2358. name: "今日头条",
  2359. url: "https://www.toutiao.com/search/?keyword=%s",
  2360. favicon:"",
  2361. blank: true,
  2362. };
  2363.  
  2364. // 自用 该列表默认隐藏,
  2365. engineList.mine = [];
  2366.  
  2367. engineList.mine[0] = {
  2368. name: 'MDN',
  2369. url: 'https://developer.mozilla.org/zh-CN/search?q=%s',
  2370. favicon: '',
  2371. };
  2372. engineList.mine[1] = {
  2373. name: 'Can I Use',
  2374. url: 'http://caniuse.com/#search=%s',
  2375. blank:true,
  2376. favicon: '',
  2377. };
  2378. engineList.mine[2] = {
  2379. name: 'GitHub',
  2380. url: 'https://github.com/search?utf8=✓&q=%s',
  2381. favicon: '',
  2382. blank:true,
  2383. };
  2384. engineList.mine[3] = {
  2385. name: 'w3c',
  2386. url: 'http://www.runoob.com/?s=%s',
  2387. favicon: '',
  2388. };
  2389. engineList.mine[4] = {
  2390. name: 'GreasyFork',
  2391. url: 'https://gf.qytechs.cn/scripts?q=%s&utf8=✓',
  2392. favicon: '',
  2393. blank:true,
  2394. };
  2395. engineList.mine[5] = {
  2396. name: '人生05电影',
  2397. url: 'http://www.rs05.com/search.php?s=%s',
  2398. favicon: '',
  2399. blank:true,
  2400. };
  2401. engineList.mine[6] = {
  2402. name: '射手网(伪)',
  2403. url: 'http://assrt.net/sub/?searchword=%s',
  2404. favicon: '',
  2405. blank:true,
  2406. };
  2407. engineList.mine[7] = {
  2408. name: '游戏-3dm',
  2409. url: 'http://so.3dmgame.com/?type=4&keyword=%s',
  2410. favicon: '',
  2411. blank:true,
  2412. };
  2413. engineList.mine[8] = {
  2414. name: '搜狗表情',
  2415. url: 'https://pic.sogou.com/pic/emo/searchList.jsp?statref=home_form&keyword=%s',
  2416. favicon: '',
  2417. blank:true,
  2418. };
  2419.  
  2420.  
  2421. // 福利列表
  2422. var engineList_fuli = [];
  2423. engineList_fuli[0] = {
  2424. "status":3,
  2425. "version":1,
  2426. "message":"福利列表,默认隐藏,",
  2427. "name":"福利",
  2428. "engineDetails":['福利',"iqxin_fuli",true],
  2429. "engineList":[
  2430. {
  2431. name: 'JAVlibrary',
  2432. url: 'http://www.javlibrary.com/cn/vl_searchbyid.php?keyword=%s',
  2433. favicon: '',
  2434. blank:true
  2435. },
  2436. {
  2437. name: 'javbus',
  2438. url: 'https://www.javbus.com/search/%s',
  2439. favicon: '',
  2440. blank:true
  2441. },
  2442. {
  2443. name: '草榴',
  2444. url: 'https://www.google.com/search?q=site:www.t66y.com %s',
  2445. // 长
  2446. favicon: '',
  2447. blank:true
  2448. },
  2449. {
  2450. name: 'sukebei',
  2451. url: 'https://sukebei.nyaa.si/?f=0&c=0_0&q=%s',
  2452. favicon: '',
  2453. blank:true
  2454. },
  2455. {
  2456. name: 'jable',
  2457. url: 'https://jable.tv/search/%s',
  2458. favicon: '',
  2459. blank:true
  2460. },
  2461. {
  2462. name: 'PornHub',
  2463. url: 'https://cn.pornhub.com/video/search?search=%s',
  2464. favicon: '',
  2465. blank:true
  2466. },
  2467. ]
  2468. }
  2469.  
  2470. // 导入列表
  2471. var engineList_plus = [];
  2472. engineList_plus[0] = {
  2473. "status":3,
  2474. "version":1,
  2475. "message":"应用app下载,由奔跑中的奶酪整理",
  2476. "name":"应用",
  2477. "engineDetails":['应用',"app_xin",true],
  2478. "engineList":[
  2479. {
  2480. name: 'AppStore',
  2481. url: 'https://fnd.io/#/us/search?mediaType=all&term=%s',
  2482. favicon: '',
  2483. blank:true
  2484. },
  2485. {
  2486. name: ' PP助手',
  2487. url: 'https://www.25pp.com/ios/search_app_0/%s',
  2488. favicon: '',
  2489. blank:true
  2490. },
  2491. {
  2492. name: 'Google Play',
  2493. url: 'https://play.google.com/store/search?q=%s',
  2494. favicon: '',
  2495. blank:true
  2496. },
  2497. {
  2498. name: 'Microsoft Store',
  2499. url: 'https://www.microsoft.com/zh-cn/search/result.aspx?q=%s&form=MSHOME',
  2500. favicon: '',
  2501. blank:true
  2502. },
  2503. {
  2504. name: 'Alternativeto',
  2505. url: 'https://alternativeto.net/browse/search?q=%s',
  2506. favicon: '',
  2507. blank:true
  2508. },
  2509. {
  2510. name: 'Github',
  2511. url: 'https://www.runningcheese.com/go/?url=https://github.com/search?q=%s',
  2512. favicon: '',
  2513. blank:true
  2514. },
  2515. {
  2516. name: 'GreaseFork',
  2517. url: 'https://gf.qytechs.cn/zh-CN/scripts?utf8=%E2%9C%93&q=%s',
  2518. favicon: '',
  2519. blank:true
  2520. },
  2521. {
  2522. name: 'Chrome WebStore',
  2523. url: 'https://chrome.google.com/webstore/search/%s',
  2524. favicon: '',
  2525. blank:true
  2526. },
  2527. {
  2528. name: 'Firefox Add-ons',
  2529. url: 'https://addons.mozilla.org/zh-CN/firefox/search/?platform=windows&q=%s',
  2530. favicon: '',
  2531. blank:true
  2532. },
  2533. {
  2534. name: 'Userstyles',
  2535. url: 'https://userstyles.org/styles/browse?search_terms=%s',
  2536. favicon: '',
  2537. blank:true
  2538. }
  2539. ]
  2540. }
  2541. engineList_plus[1] = {
  2542. "status":3,
  2543. "version":1,
  2544. "engineDetails":['电子书',"ebook_xin",true],
  2545. "message":"由奔跑中的奶酪整理",
  2546. "engineList":[
  2547. // {
  2548. // name: 'jiumodiary',
  2549. // url: 'https://www.jiumodiary.com/$post$q',
  2550. // favicon: '',
  2551. // blank:true
  2552. // },
  2553. {
  2554. name: 'forfrigg',
  2555. url: 'http://forfrigg.com/#gsc.tab=0&gsc.q=%s&gsc.sort=',
  2556. favicon: '',
  2557. blank:true
  2558. },
  2559. {
  2560. name: '威锋网',
  2561. url: 'https://s.feng.com/index.php?srchtxt=%s',
  2562. favicon: '',
  2563. blank:true
  2564. },
  2565. {
  2566. name: '我的小书屋',
  2567. url: 'http://mebook.cc/?s=%s',
  2568. favicon: '',
  2569. blank:true
  2570. },
  2571. {
  2572. name: 'Library Genesis',
  2573. url: 'http://gen.lib.rus.ec/search.php?req=%s',
  2574. favicon: '',
  2575. blank:true
  2576. },
  2577. {
  2578. name: 'B-OK',
  2579. url: 'http://b-ok.xyz/s/?q=%s',
  2580. favicon: '',
  2581. blank:true
  2582. }
  2583. ]
  2584. }
  2585. engineList_plus[2] = {
  2586. "status":3,
  2587. "version":1,
  2588. "engineDetails":['网盘',"netdisc_xin",true],
  2589. "message":"由奔跑中的奶酪整理,https://www.runningcheese.com/resources",
  2590. "engineList":[
  2591. // {
  2592. // name: 'jiumodiary',
  2593. // url: 'https://www.jiumodiary.com/$post$q',
  2594. // favicon: '',
  2595. // blank:true
  2596. // },
  2597. {
  2598. name: '百度网盘',
  2599. url: 'https://pan.baidu.com/disk/home?#/search?key=%s&vmode=list',
  2600. favicon: '',
  2601. blank:true
  2602. },
  2603. {
  2604. name: '盘多多',
  2605. url: 'http://www.panduoduo.net/s/name/%s',
  2606. favicon: '',
  2607. blank:true
  2608. },
  2609. {
  2610. name: '56网盘',
  2611. url: 'http://www.56wangpan.com/search/kw%s',
  2612. favicon: '',
  2613. blank:true
  2614. },
  2615. {
  2616. name: 'Pan115',
  2617. url: 'http://www.pan115.com/search?key=%s',
  2618. favicon: '',
  2619. blank:true
  2620. },
  2621. {
  2622. name: '鸵鸟搜索',
  2623. url: 'http://www.tuoniao.me/search/%s/list',
  2624. favicon: '',
  2625. blank:true
  2626. },
  2627. {
  2628. name: '胖次分享',
  2629. url: 'https://www.panc.cc/s/%s/td_0',
  2630. favicon: '',
  2631. blank:true
  2632. },
  2633. {
  2634. name: '小不点搜索',
  2635. url: 'https://www.xiaoso.net/mod/app_search?wd=%E9%92%A2%E7%82%BC&mod=app_search&oksubmit=true&okbtn=XiaoSo%s',
  2636. favicon: '',
  2637. blank:true
  2638. }
  2639. ]
  2640. }
  2641.  
  2642.  
  2643.  
  2644.  
  2645. var settingData = {
  2646. "status":1,
  2647. "message":"$相关说明$(status: 这个在将来或许很重要)..."+
  2648. "(version: 若有新功能加入,靠这个版本号识别)..." +
  2649. "(addSearchItems: 允许更新时,添加新的搜索网站到你的搜索列表)..." +
  2650. "(modifySearchItems: 允许更新时,修改你的搜索列表中的项目)..." +
  2651. "(connectToTheServer: 允许连接到我的服务器(更新列表,将图标转换为base64等),将来更新使用或永不使用)..." +
  2652. "(closeBtn: 设置页面右上角的“关闭”按钮是否显示。true显示,false隐藏)..." +
  2653. "(newtab: 新标签页打开。0为默认设置,1为新标签页打开)..." +
  2654. "(foldlist: 折叠当前搜索分类列表。true为折叠,false为展开。)..." +
  2655. "(settingOpacity: 设置按钮的透明度,值为0-1之间的数,0为透明,1为完全显示,中间值半透明。注:-1为直接关闭按钮,关闭之前请确定自己知道如何再次打开它)..." +
  2656. "(debug: debug模式,开启后,控制台会输出一些信息,“关闭并保存”按钮将不会在刷新页面)..." +
  2657. "(fixedTop: 将搜索栏固定到顶端。 true开启,false关闭)..." +
  2658. "(fixedTopUpward: 固定顶端后,搜索栏下拉不会出现,只有上拉时才出现。 true开启,false关闭)..." +
  2659. "(baiduOffset: 在百度页面鼠标划过的菜单会出现位移,若有使用其他的style样式,可以修改这个来修复二级菜单的偏移)..." +
  2660. "(getIcon: 自己添加搜索后获取图标的方式。0为自动,能连接谷歌的情况下用谷歌获取,无法连接的情况下,域名加favicon.ico获取;1为域名加favicon获取,2为使用谷歌获取,3为使用dnspot的服务获取(不建议使用)。或者添加网址,关键字使用%s代替,未测试)..." +
  2661. "(allOpen:一键搜索,点击相关分类后,打开该分类下的所有搜索)..." +
  2662. "(HideTheSameLink:隐藏同站链接。默认开启,百度页面会隐藏百度搜索。如果想在同一个搜索网站,但是想通过不同语言来搜索, 可以选择false来实现)..." +
  2663. "(center:是否居中显示,主要是为了兼容脚本 ac 百度 : 0 不居中,强制在左。 1, 强制居中 。 2,自动判断)..." +
  2664. "(icon: 图标的显示方式, true显示抽象图标,false显示网站图标。当脚本中不存在抽象图标时,显示网站图标)..." +
  2665. "(transtion: 是否有动画效果, true为开启所有动画效果,false关闭所有动画(包括模糊效果)。)" +
  2666. "(engineDetails: 第一个值为分类列表标题名称,第二个值与enginelist相关联,必须匹配,第三个值true为显示列表,false为禁用列表。排列顺序与跳转栏上的显示顺序相同,可以用它将分类列表按自己喜欢排序)..." +
  2667. "(engineList: 各个搜索的相关信息)" +
  2668. "(rules: 已弃用--将搜索样式插入到目标网页,同脚本中的rules设置相同,优先级高于脚本中自带的规则。自带了360搜索,可仿写)...",
  2669. "version":4.05,
  2670. "addSearchItems":true,
  2671. "modifySearchItems":true,
  2672. "connectToTheServer":true,
  2673. "closeBtn":true,
  2674. "newtab":0,
  2675. "foldlist":true,
  2676. "setBtnOpacity":0.6,
  2677. "debug":false,
  2678. "fixedTop":true,
  2679. "fixedTopUpward":false,
  2680. "baiduOffset":-120,
  2681. "getIcon":0,
  2682. "allOpen":false,
  2683. "HideTheSameLink":true,
  2684. "center":2,
  2685. "icon":false,
  2686. "transtion":true,
  2687. "engineDetails":[['网页', 'web',true],['翻译', 'translate',true],['知识', 'knowledge',true],['图片', 'image',true],['视频', 'video',true],['音乐', 'music',true],['学术', 'scholar',false], ['社交', 'sociality',true],['购物', 'shopping',true],["下载","download",false],["新闻","news",false],['mine', 'mine',false]],
  2688. "engineList":{},
  2689. "rules":[{"name": "360", "url": "/^https?:\\/\\/www\\.so\\.com\\/s\\?/", "enabled": true, "engineList": "web","fixedTop":50, "style": "padding: 10px 0 0 120px;margin-bottom:-10px;z-index:3001;", "insertIntoDoc": {"keyword": "//input[@name='q']", "target": "css;#tabs-wrap", "where": "afterEnd"}}]
  2690. }
  2691. // --------------------可设置项结束------------------------
  2692. // GM_deleteValue("searchEngineJumpData");
  2693. var getSettingData = GM_getValue("searchEngineJumpData");
  2694. if(getSettingData){
  2695. // console.log("本地存在列表:",getSettingData);
  2696. if(!getSettingData.status && confirm("设置发生错误,脚本将会复原出厂设置")){
  2697. GM_deleteValue("searchEngineJumpData");
  2698. window.location.reload();
  2699. }
  2700.  
  2701. // 查看本地配置信息是否完整
  2702. for(let value in settingData){
  2703. if(!getSettingData.hasOwnProperty(value)){
  2704. console.log("属性不存在: ",value);
  2705. getSettingData[value] = settingData[value];
  2706. GM_setValue("searchEngineJumpData",getSettingData);
  2707. }
  2708. }
  2709.  
  2710. // 获取版本,用于搜索列表更新
  2711. // console.log("当前版本号和目标版本号: ",getSettingData.version,settingData.version);
  2712. if(parseFloat(getSettingData.version) < settingData.version){
  2713. console.log("版本过低,开始更新,当前版本号和目标版本号: ",getSettingData.version,settingData.version);
  2714. // 1.96 更新 修改a站搜索链接
  2715. // if(getSettingData.modifySearchItems){
  2716. // getSettingData.engineList = modifySearchItemsFun(getSettingData.engineList,"http://www.acfun.tv/search.aspx#query=%s","http://www.acfun.cn/search/?#query=%s")
  2717. // }
  2718. // 版本3.02 添加 自用网站-搜狗表情
  2719. // if(getSettingData.addSearchItems && getSettingData.engineList.hasOwnProperty("mine")){
  2720. // // engineList.mine[8].disable = true; // 对于老用户,默认禁用的状态添加
  2721. // getSettingData.engineList["mine"].push(engineList.mine[8])
  2722. // }
  2723. // 4.01
  2724. // if(getSettingData.addSearchItems){
  2725. // if(getSettingData.engineList.hasOwnProperty("music")){
  2726. // getSettingData.engineList["music"].push(engineList.music[6])
  2727. // getSettingData.engineList["music"].push(engineList.music[7])
  2728. // }
  2729. // }
  2730. // 4.03
  2731. // if(getSettingData.addSearchItems){
  2732. // // engineList.mine[8].disable = true; // 对于老用户,默认禁用的状态添加
  2733. // if(getSettingData.engineList.hasOwnProperty("translate")){
  2734. // getSettingData.engineList["translate"].push(engineList.translate[8])
  2735. // }
  2736. // }
  2737. // 4.04 更改 b站图标
  2738. // 导致了5.23.7 的严重bug, 致使无法使用。原因是用户已经删除了相关列表, 但是脚本依旧去读取,出现了读取错误。
  2739. // if(getSettingData.modifySearchItems){
  2740. // getSettingData.engineList.video = modifySearchItemsIcon(getSettingData.engineList.video,"http://search.bilibili.com/all?keyword=%s",engineList.video[1].favicon)
  2741. // }
  2742.  
  2743. // 更新本地版本 其他相关信息
  2744. getSettingData.version = settingData.version;
  2745. getSettingData.message = settingData.message;
  2746. GM_setValue("searchEngineJumpData",getSettingData);
  2747. }
  2748.  
  2749. engineList = getSettingData.engineList;
  2750.  
  2751. } else {
  2752. console.log("未发现本地列表");
  2753. settingData.engineList = engineList;
  2754. console.log("初始化:",settingData);
  2755.  
  2756. GM_setValue("searchEngineJumpData",settingData);
  2757. getSettingData = GM_getValue("searchEngineJumpData");
  2758. }
  2759.  
  2760. // 处理enginlist.detail的相关信息
  2761. var engineDetails = getSettingData.engineDetails;
  2762. //列表分类显示情况
  2763. var getDetails = engineDetails.map(function(value,index){
  2764. return value[2]?index:-index;
  2765. })
  2766.  
  2767. // 列表分类的key value
  2768. var getDetailsL = getDetails.length;
  2769. var details = [];
  2770. for(let i=0;i<getDetailsL;i++){
  2771. details[getDetails[i]] = engineDetails[i];
  2772. };
  2773. engineList.details = details;
  2774.  
  2775. reloadDebug(getSettingData.debug);
  2776.  
  2777. ///test -------------- 测试 start
  2778. debug("searchEngineJump test location.href: ",window.location.href)
  2779. ///test -------------- 测试 end
  2780.  
  2781. // 更新已过期的搜索链接
  2782. function modifySearchItemsFun(engineList,oldURL,newURL){
  2783. for(let value in engineList){
  2784. var item = engineList[value]
  2785. for(let i=0;i<item.length;i++){
  2786. if(item[i].url === oldURL){
  2787. item[i].url = newURL;
  2788. return engineList;
  2789. }
  2790. }
  2791. }
  2792. return engineList;
  2793. }
  2794. // 更新图标
  2795. function modifySearchItemsIcon(engineList,url,newIcon){
  2796. for (let i=0;i<engineList.length;i++){
  2797. if(engineList[i].url ==url){ //用户可能自己更改网站名称,所以此处用url来匹配
  2798. engineList[i].favicon=newIcon;
  2799. console.log("发现旧的图标");
  2800. }
  2801. }
  2802. return engineList;
  2803. }
  2804. // 更新本地 rule
  2805. function modifySearchItemsRuleFun(name,value){
  2806. var oldRule = getSettingData.rules;
  2807. for(let item in oldRule){
  2808. if(oldRule[item].name == name){
  2809. console.log("匹配成功, 更新 rule : ", name);
  2810. oldRule[item] = value;
  2811. GM_setValue("searchEngineJumpData",getSettingData);
  2812. }
  2813. }
  2814. }
  2815.  
  2816. // parseUri 1.2.2
  2817. // (c) Steven Levithan <stevenlevithan.com>
  2818. // MIT License
  2819. var parseUri = function(str) {
  2820. var o = parseUri.options,
  2821. m = o.parser[o.strictMode ? "strict" : "loose"].exec(str),
  2822. uri = {},
  2823. i = 14;
  2824.  
  2825. while (i--) uri[o.key[i]] = m[i] || "";
  2826.  
  2827. uri[o.ds.name] = {};
  2828. uri[o.ds.name][0] = {};
  2829. uri[o.ds.name][0]["key"] = (uri.protocol ? uri.protocol : "http") + "://" + uri.host + (uri.port ? ":" + uri.port : "") + "/";
  2830. uri[o.ds.name][0]["val"] = "/";
  2831. i = 0;
  2832. var tempsub = "/",
  2833. subs = uri[o.key[10]].substr(1).split("/");
  2834. for (var j = 1; j < (subs.length + 1); j++, i++) {
  2835. tempsub += tempsub === "/" ? subs[i] : "/" + subs[i];
  2836. if (subs[i]) {
  2837. uri[o.ds.name][j] = {};
  2838. uri[o.ds.name][j]["key"] = subs[i];
  2839. uri[o.ds.name][j]["val"] = tempsub;
  2840. }
  2841. }
  2842.  
  2843. uri[o.q.name] = {};
  2844. uri[o.key[12]].replace(o.q.parser, function($0, $1, $2) {
  2845. if ($1) uri[o.q.name][$1] = $2;
  2846. });
  2847. uri[o.aq.name] = {};
  2848. uri[o.key[13]].replace(o.aq.parser, function($0, $1, $2) {
  2849. if ($1) uri[o.aq.name][$1] = $2;
  2850. });
  2851.  
  2852. return uri;
  2853. };
  2854. parseUri.options = {
  2855. strictMode: false,
  2856. key: ["source", "protocol", "authority", "userInfo", "user", "password", "host", "port", "relative", "path", "directory", "file", "query", "anchor"],
  2857. q: {
  2858. name: "queryKey",
  2859. parser: /(?:^|&)([^&=]*)=?([^&]*)/g
  2860. },
  2861. aq: {
  2862. name: "anchorqueryKey",
  2863. parser: /(?:^|&)([^&=]*)=?([^&]*)/g
  2864. },
  2865. ds: {
  2866. name: "directorySub"
  2867. },
  2868. parser: {
  2869. strict: /^(?:([^:\/?#]+):)?(?:\/\/((?:(([^:@]*)(?::([^:@]*))?)?@)?([^:\/?#]*)(?::(\d*))?))?((((?:[^?#\/]*\/)*)([^?#]*))(?:\?([^#]*))?(?:#(.*))?)/,
  2870. loose: /^(?:(?![^:@]+:[^:@\/]*@)([^:\/?#.]+):)?(?:\/\/)?((?:(([^:@]*)(?::([^:@]*))?)?@)?([^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/
  2871. }
  2872. };
  2873.  
  2874. function getElementLeft(element){
  2875. var actualLeft = element.offsetLeft;
  2876. var current = element.offsetParent;
  2877. while (current !== null){
  2878. actualLeft += current.offsetLeft;
  2879. current = current.offsetParent;
  2880. }
  2881. return actualLeft;
  2882. };
  2883. // console.log("engineList: ",engineList);
  2884. //xpath 获取单个元素
  2885. function getElementByXPath(xPath, contextNode, doc) {
  2886. doc = doc || document;
  2887. contextNode = contextNode || doc;
  2888. return doc.evaluate(xPath, contextNode, null, 9, null).singleNodeValue;
  2889. };
  2890.  
  2891. // 从函数中获取多行注释的字符串
  2892. function getMStr(fn) {
  2893. var fnSource = fn.toString();
  2894. var ret = {};
  2895. fnSource = fnSource.replace(/^[^{]+/, '');
  2896. // console.log(fnSource);
  2897. var matched;
  2898. var reg = /var\s+([$\w]+)[\s\S]*?\/\*([\s\S]+?)\*\//g;
  2899. while (matched = reg.exec(fnSource)) {
  2900. // console.log(matched);
  2901. ret[matched[1]] = matched[2];
  2902. };
  2903.  
  2904. return ret;
  2905. };
  2906.  
  2907. // 事件支持检测.
  2908. // 比如 eventSupported('fullscreenchange', document);
  2909. function eventSupported(eventName, elem) {
  2910. elem = elem || document.createElement('div');
  2911. var prefix = ['o', 'ms', 'moz', 'webkit', ''];
  2912.  
  2913. var l = prefix.length;
  2914. var pEventName;
  2915. var isFunction;
  2916. var setAttr;
  2917.  
  2918. while(l --) {
  2919. pEventName = 'on' + prefix[l] + eventName;
  2920.  
  2921. if (pEventName in elem) {
  2922. return pEventName.slice(2);
  2923. } else if (typeof elem.setAttribute == 'function') { // setAttribute 是元素节点的方法
  2924. setAttr = false;
  2925. if (!elem.hasAttribute(pEventName)) {
  2926. setAttr = true;
  2927. elem.setAttribute(pEventName, 'return;');
  2928. };
  2929.  
  2930. isFunction = typeof elem[pEventName] == 'function';
  2931.  
  2932. if (setAttr) elem.removeAttribute(pEventName);
  2933.  
  2934. if (isFunction) {
  2935. return pEventName.slice(2);
  2936. };
  2937. };
  2938. };
  2939.  
  2940. return false;
  2941. };
  2942.  
  2943. // 保存指定对象相关数据
  2944. var data = (function () {
  2945. 'use strict';
  2946.  
  2947. var cache = {
  2948. objs: [],
  2949. data: {},
  2950. };
  2951.  
  2952. function data(obj, key, value) {
  2953. var id = cache.objs.indexOf(obj);
  2954. if (id == -1) {
  2955. id = cache.objs.push(obj) - 1;
  2956. };
  2957. if (!cache.data[id]) {//初始化
  2958. cache.data[id] = {};
  2959. };
  2960. if (typeof value == 'undefined') {// 取值
  2961. return typeof key == 'undefined' ? cache.data[id] : cache.data[id][key];
  2962. } else {
  2963. return cache.data[id][key] = value;
  2964. };
  2965. };
  2966.  
  2967. return data;
  2968. })();
  2969.  
  2970. // 为mouseleave mouseenter事件做个兼容
  2971. // 需要 eventSupported, data函数支持
  2972. var mouseEventListener = (function () {
  2973.  
  2974. var support = {
  2975. mouseleave : eventSupported('mouseleave'),
  2976. mouseenter : eventSupported('mouseenter'),
  2977. };
  2978.  
  2979. var map = {
  2980. mouseleave : 'mouseout',
  2981. mouseenter : 'mouseover',
  2982. };
  2983.  
  2984. return {
  2985. add : function (type, ele, callback) { //事件类型,元素,监听函数
  2986. if (support[type]) {
  2987. ele.addEventListener(type, callback, false); //mouseleave,enter不冒泡,所以在冒泡阶段监听事件,不要担心子孙元素进出发生的事件冒泡上来。
  2988. } else {
  2989. var listener = data(callback, 'mouseELListener');
  2990. if (!listener) {
  2991. listener = function (e) {
  2992. var relatedTarget = e.relatedTarget; //mouseout,去往的元素;mouseover,来自的元素
  2993. // 当mouseout(离开ele)去往的元素不是自己的子孙元素
  2994. // 当mouseover(进入ele)来自的元素不是自己的子孙元素
  2995. if (!ele.contains(relatedTarget)) { // contains函数,自己.contains(自己) 返回true
  2996. callback.call(ele, e);
  2997. };
  2998. };
  2999. data(callback, 'mouseELListener', listener);
  3000. };
  3001.  
  3002. ele.addEventListener(map[type], listener, true);
  3003. };
  3004. },
  3005. remove : function (type, ele, callback) {
  3006. if (support[type]) {
  3007. ele.removeEventListener(type, callback, false);
  3008. } else {
  3009. ele.removeEventListener(map[type], data(callback, 'mouseELListener'), true);
  3010. };
  3011. },
  3012. };
  3013. })();
  3014.  
  3015. //获取已滚动的距离
  3016. function getScrolled(container) {
  3017. if (container) {
  3018. return {
  3019. x:container.scrollLeft,
  3020. y:container.scrollTop,
  3021. };
  3022. };
  3023. return {
  3024. x: 'scrollX' in window ? window.scrollX : ('pageXOffset' in window ? window.pageXOffset : document.documentElement.scrollLeft || document.body.scrollLeft),
  3025. y: 'scrollY' in window ? window.scrollY : ('pageYOffset' in window ? window.pageYOffset : document.documentElement.scrollTop || document.body.scrollTop),
  3026. };
  3027. };
  3028.  
  3029. function getElement(selector) {
  3030. if (selector.indexOf('css;') == 0) {
  3031. return document.querySelector(selector.slice(4));
  3032. } else {
  3033. return getElementByXPath(selector);
  3034. };
  3035. };
  3036.  
  3037. function mousedownhandler(e) {
  3038. var target = e.target;
  3039.  
  3040. target = getElementByXPath('ancestor-or-self::a[contains(@class, "sej-engine")]', target);
  3041.  
  3042. // if (!target || target.className.indexOf('sej-engine') == -1) return;
  3043. if (!target || !this.contains(target)) return;
  3044.  
  3045. var value;
  3046. if (typeof iInput == 'function') {
  3047. value = iInput();
  3048. } else {
  3049. if (iInput.nodeName == 'INPUT') {
  3050. value = iInput.value;
  3051. } else {
  3052. value = iInput.textContent;
  3053. };
  3054. };
  3055.  
  3056. // 编码 解码
  3057. // 对搜索词编码 (未做解码处理,浏览器自动处理) 网站1688采用gbk编码
  3058. var ogbk = target.getAttribute('gbk');
  3059. if (ogbk){
  3060. value = toGBK(value)
  3061. } else {
  3062. value = encodeURIComponent(value);
  3063. }
  3064. // // @name searchEngineJump-NextStage
  3065. if (document.characterSet != "UTF-8") value = encodeURIComponent(value);
  3066.  
  3067. var targetURL = target.getAttribute('url');
  3068.  
  3069. // 一键搜索
  3070. if(getSettingData.allOpen && target.classList.contains("sej-drop-list-trigger")){
  3071. var list = engineList[target.dataset.iqxincategory]
  3072. // console.log("allOpen")
  3073. // console.log(list)
  3074.  
  3075. for(var i=0;i<list.length;i++){
  3076. if (list[i].url.indexOf("site:")<0 && matchedRule.url.test(list[i].url)) continue ;
  3077. if (list[i].disable) continue ;
  3078. var href = list[i].url.replaceAll('%s', value);
  3079. GM_openInTab(href)
  3080. }
  3081. target.setAttribute("onclick","return false;");
  3082. return
  3083. }
  3084.  
  3085.  
  3086. // 如果有post请求
  3087. var postSign = targetURL.indexOf('$post$');
  3088. if(~postSign){
  3089. var f=getPostFormHTML(targetURL.substring(0,postSign),[targetURL.substring(postSign+6),value],target.getAttribute('target'))
  3090. target.appendChild(f)
  3091. target.setAttribute("onclick","this.getElementsByTagName('form')[0].submit();return false;");
  3092.  
  3093. // var postURL = parseUri(target.getAttribute('url'));
  3094. // console.log(postURL);
  3095. // target.setAttribute("onclick","return false;");
  3096. // GM_xmlhttpRequest({
  3097. // method: "post",
  3098. // url: target.url,
  3099. // data: targetURL.substring(postSign + 6) + '=' + value ,
  3100. // get data() {
  3101. // return this._data;
  3102. // },
  3103. // set data(value) {
  3104. // this._data = value;
  3105. // },
  3106. // headers: {
  3107. // "Content-Type": "application/x-www-form-urlencoded",
  3108. // "Origin":postURL.host,
  3109. // "Referer":postURL.host
  3110. // },
  3111. // onload: function(res){
  3112. // if(res.status === 200){
  3113. // console.log('成功')
  3114. // }else{
  3115. // console.log('失败')
  3116. // console.log(res)
  3117. // }
  3118. // },
  3119. // onerror : function(err){
  3120. // console.log('error')
  3121. // console.log(err)
  3122. // }
  3123. // });
  3124.  
  3125. } else{
  3126. //console.log(value);
  3127. target.href = target.getAttribute('url').replaceAll('%s', value);
  3128. }
  3129. };
  3130. //获取 POST 的表单的 HTML
  3131. function getPostFormHTML(url, value, newTab) {
  3132. //console.log(url,value,newTab)
  3133. var ospan = document.createElement('span');
  3134. ospan.style.cssText = 'width:0px;height:0px;';
  3135. var form = "" +
  3136. "<form method='post'" +
  3137. " action='" + url + "'" +
  3138. (newTab ? " target='_blank'" : "") +
  3139. ">" +
  3140. "<input type='hidden'" +
  3141. " name='" + value[0] + "'" +
  3142. " value='" + value[1] + "'" +
  3143. " />" +
  3144. "</form>";
  3145. ospan.innerHTML = form;
  3146. return ospan;
  3147. };
  3148.  
  3149. // iframe 禁止加载
  3150. if (window.self != window.top) return;
  3151.  
  3152. var url = location.href;
  3153. var matchedRule;
  3154. var marchedSign;
  3155.  
  3156. //先判断用户规则
  3157. marchedSign = getSettingData.rules.some(function (rule) {
  3158. if(typeof(rule.url)=="string"){ // 2020-12-19 todo: 重新导入用户配置文件后, 会解析错误的问题。 是由于用户保存的rule.url由字符串变成了空对象{},具体在什么情况下会导致变成空对象,并未排查
  3159. rule.url = new RegExp(rule.url.substring(1,rule.url.length-1));
  3160. if (rule.url.test(url)) {
  3161. matchedRule = rule;
  3162. return true;
  3163. };
  3164. }
  3165. });
  3166.  
  3167. // console.log(marchedSign,matchedRule);
  3168. if(!marchedSign){
  3169. rules.some(function (rule) {
  3170. if (rule.url.test(url)) {
  3171. matchedRule = rule;
  3172. return true;
  3173. };
  3174. });
  3175. }
  3176.  
  3177. if (!matchedRule || !matchedRule.enabled) return;
  3178.  
  3179. // var iTarget = getElement(matchedRule.insertIntoDoc.target);
  3180. var iTarget = typeof matchedRule.insertIntoDoc.target == "function" ? matchedRule.insertIntoDoc.target() : getElement(matchedRule.insertIntoDoc.target);
  3181. var iInput = typeof matchedRule.insertIntoDoc.keyword == 'function' ? matchedRule.insertIntoDoc.keyword : getElement(matchedRule.insertIntoDoc.keyword);
  3182.  
  3183. ///test -------------- 测试 start
  3184. // console.log("searchEngineJump test iTarget, iInput: ",iTarget, iInput);
  3185. ///test -------------- 测试 end
  3186.  
  3187. if (!iTarget || !iInput) {
  3188. console.log("脚本 searchEngineJump 搜索引擎快捷跳转 遇到了错误: ");
  3189. console.log("目标有误:\n iTarget:" + iTarget + "\niInput(keyword): " + iInput);
  3190. return;
  3191. }
  3192.  
  3193. // 添加全局样式
  3194. var globalStyle = document.createElement('style');
  3195. globalStyle.type = 'text/css';
  3196. globalStyle.textContent = getMStr(function(){
  3197. var cssText;
  3198. /*
  3199. #sej-container {
  3200. display: block;
  3201. position: relative;
  3202. z-index: 2;
  3203. // padding: 1px 5px 1px 5px;
  3204. line-height: 1.5;
  3205. font-size: 13px;
  3206. font-family: arial,sans-serif;
  3207. transform-origin: top center;
  3208. animation: sejopen 0.3s;
  3209. border-bottom-right-radius: 4px;
  3210. border-bottom-left-radius: 4px;
  3211. color: #333;
  3212. //transition:0.3s;
  3213. }
  3214. #sej-container a{
  3215. border-radius:2px;
  3216. }
  3217. #sej-expanded-category {
  3218. font-weight: bold;
  3219. }
  3220.  
  3221. .sej-engine {
  3222. line-height: 2;
  3223. display: inline-block;
  3224. margin: 0 0px 0 0;
  3225. border: none;
  3226. padding: 0 6px;
  3227. text-decoration: none;
  3228. font-weight:500;
  3229. transition: background-color 0.15s ease-in-out;
  3230. }
  3231. .sej-drop-list-trigger {
  3232.  
  3233. }
  3234. .sej-drop-list-trigger-shown {
  3235. background-color: #DEEDFF !important;
  3236. }
  3237. .sej-drop-list-trigger::after {
  3238. content: '';
  3239. display: inline-block;
  3240. margin: 0 0 0 3px;
  3241. padding: 0;
  3242. width: 0;
  3243. height: 0;
  3244. border-top: 6px solid #BCBCBC;
  3245. border-right: 5px solid transparent;
  3246. border-left: 5px solid transparent;
  3247. border-bottom: 0px solid transparent;
  3248. vertical-align: middle;
  3249. transition: -webkit-transform 0.3s ease-in-out;
  3250. transition: transform 0.3s ease-in-out;
  3251. }
  3252. .sej-drop-list-trigger-shown::after {
  3253. -webkit-transform: rotate(180deg);
  3254. transform: rotate(180deg);
  3255. }
  3256. .sej-drop-list a:visited,
  3257. .sej-drop-list a:hover,
  3258. .sej-engine a:visited,
  3259. .sej-engine a:hover,
  3260. #sej-container a:visited,
  3261. #sej-container a:hover{
  3262. color:#333;
  3263. }
  3264. .sej-engine:hover {
  3265. background-color: #EAEAEA;
  3266. }
  3267. .sej-drop-list > .sej-engine:hover {
  3268. background-color: #DEEDFF;
  3269. }
  3270. .sej-drop-list > .sej-engine {
  3271. display: block;
  3272. padding-top: 4px;
  3273. padding-bottom: 4px;
  3274. top: 0px;
  3275. border-radius:4px;
  3276. }
  3277.  
  3278. .sej-engine-icon {
  3279. display: inline-block;
  3280. width: 16px;
  3281. height: 16px;
  3282. border: none;
  3283. padding: 0;
  3284. margin: 0 3px 0 0;
  3285. vertical-align: text-bottom;
  3286. box-sizing:unset;
  3287. }
  3288.  
  3289. .sej-drop-list {
  3290. position: absolute;
  3291. display: none;
  3292. opacity: 0.3;
  3293. top: -10000px;
  3294. left: 0;
  3295. min-width: 90px;
  3296. padding: 5px 0;
  3297. text-align: left;
  3298. font-size: 13px;
  3299. -moz-box-shadow: 1px 1px 5px #999;
  3300. -webkit-box-shadow: 2px 2px 5px #999;
  3301. box-shadow: 2px 2px 5px #999;
  3302. background-color: rgba(255,255,255,.7);
  3303. backdrop-filter: blur(7px);
  3304. border-bottom-right-radius: 3px;
  3305. border-bottom-left-radius: 3px;
  3306. transition: opacity 0.2s ease-in-out,
  3307. top 0.2s ease-in-out;
  3308. }
  3309. @keyframes sejopen {
  3310. 0% {
  3311. transform: scale(1, 0.1);
  3312. opacity: 0;
  3313. }
  3314. 100% {
  3315. transform: scale(1, 1);
  3316. opacity: 1;
  3317. }
  3318. }
  3319. @keyframes iqxinsejopen {
  3320. 0% {
  3321. transform: scale(0.01, 0.01);
  3322. opacity: 0;
  3323. }
  3324. 100% {
  3325. transform: scale(1, 1);
  3326. opacity: 1;
  3327. }
  3328. }
  3329. */
  3330. }).cssText;
  3331. document.head.appendChild(globalStyle);
  3332. // 工具列表动画
  3333. if(!getSettingData.transtion){
  3334. GM_addStyle(".sej-engine," +
  3335. ".sej-drop-list-trigger," +
  3336. ".sej-drop-list{" +
  3337. "transition:none!important;" +
  3338. "}" +
  3339. "#sej-container{" +
  3340. "animation:none!important;" +
  3341. "}" +
  3342. ".sej-drop-list {" +
  3343. "backdrop-filter:none!important;" +
  3344. "background-color: rgba(255,255,255,.9)!important;" +
  3345. "}" +
  3346. ""
  3347. )
  3348. }
  3349.  
  3350. // 列表对象
  3351. function DropDownList(a, list) {
  3352. this.a = a;
  3353. this.list = list;
  3354. this.init();
  3355. };
  3356. DropDownList.zIndex = 100000000;
  3357.  
  3358. DropDownList.prototype = {
  3359. hidden: true,
  3360. showDelay: 233,
  3361. hideDelay: 233,
  3362. aShownClass: 'sej-drop-list-trigger-shown',
  3363.  
  3364. init: function () {
  3365. var a = this.a;
  3366. var list = this.list;
  3367.  
  3368. var self = this;
  3369.  
  3370. // 关闭动画
  3371. if(!getSettingData.transtion){
  3372. this.showDelay = 0;
  3373. this.hideDelay = 0;
  3374. }
  3375.  
  3376. // 进入显示
  3377. mouseEventListener.add('mouseenter', a, function () {
  3378. clearTimeout(self.hideTimerId);
  3379. if (self.hidden) {
  3380. self.showTimerId = setTimeout(function () {
  3381. self.show();
  3382. }, self.showDelay);
  3383. } else {
  3384. var style = list.style;
  3385. style.top = parseInt(list.style.top) -6 +"px";
  3386. style.zIndex = DropDownList.zIndex ++;
  3387. style.opacity = 0.96;
  3388. };
  3389. });
  3390.  
  3391. // 离开隐藏
  3392. mouseEventListener.add('mouseleave', a, function () {
  3393. clearTimeout(self.showTimerId);
  3394. if (!self.hidden) {
  3395. list.style.top = parseInt(list.style.top)+6 +"px";
  3396. list.style.opacity = 0.04;
  3397. self.hideTimerId = setTimeout(function () {
  3398. self.hide();
  3399. }, self.hideDelay);
  3400. };
  3401. });
  3402.  
  3403. mouseEventListener.add('mouseenter', list, function () {
  3404. clearTimeout(self.hideTimerId);
  3405. var style = list.style;
  3406. style.zIndex = DropDownList.zIndex ++;
  3407. style.opacity = 0.96;
  3408. style.top = parseInt(list.style.top) -6 +"px";
  3409. });
  3410.  
  3411. mouseEventListener.add('mouseleave', list, function () {
  3412.  
  3413. list.style.opacity = 0.04;
  3414. list.style.top = parseInt(list.style.top)+6 +"px";
  3415. self.hideTimerId = setTimeout(function () {
  3416. self.hide();
  3417. }, self.hideDelay);
  3418. });
  3419. },
  3420. show: function () {
  3421. if (!this.hidden) return;
  3422. this.hidden = false;
  3423.  
  3424. var scrolled = getScrolled();
  3425. var aBCRect = this.a.getBoundingClientRect();
  3426. var thisBCRect = this.a.parentNode.getBoundingClientRect()
  3427.  
  3428. var style = this.list.style;
  3429.  
  3430. var top = scrolled.y + aBCRect.bottom;
  3431. var left = scrolled.x + aBCRect.left;
  3432.  
  3433. // 百度界面二级搜索会出现偏移的问题
  3434. // if(/^https?:\/\/www\.baidu\.com\/(?:s|baidu)/.test(url)){
  3435. // top = 26;
  3436. // if(document.querySelector(".AC-style-logo") && getSettingData.center != 0){
  3437. // // left += 0;
  3438. // left = aBCRect.x -thisBCRect.x
  3439. // } else {
  3440. // // left += getSettingData.baiduOffset; 不需要用户自己修改,直接写死
  3441. // left += -134;
  3442. // }
  3443. // }
  3444.  
  3445. style.top = top + 6 + 'px';
  3446. style.left = left + 'px';
  3447.  
  3448. // console.log(aBCRect)
  3449. // console.log(thisBCRect)
  3450. // style.left = aBCRect.x + "px";
  3451. // style.top = aBCRect.y + aBCRect.height + "px";
  3452.  
  3453. style.zIndex = DropDownList.zIndex --;
  3454. style.display = 'block';
  3455.  
  3456. setTimeout(function () {
  3457. style.opacity = 0.96;
  3458. style.top = top + 'px';
  3459. }, 30);
  3460.  
  3461. this.a.classList.add(this.aShownClass);
  3462.  
  3463. },
  3464. hide: function () {
  3465. if (this.hidden) return;
  3466. this.hidden = true;
  3467.  
  3468. var style = this.list.style;
  3469. style.display = 'none';
  3470. style.opacity = 0.1;
  3471.  
  3472. this.a.classList.remove(this.aShownClass);
  3473.  
  3474. }
  3475. };
  3476.  
  3477. var pageEncoding = (document.characterSet || document.charset).toLowerCase();
  3478.  
  3479. // 创建dom
  3480. var container = document.createElement('sejspan');
  3481. container.id = 'sej-container';
  3482. container.className = "rwl-exempt";
  3483.  
  3484. // 添加 class 以获取目标网站相同的样式。
  3485. if(matchedRule.class){
  3486. container.className = container.className + " " + matchedRule.class;
  3487. }
  3488. container.addEventListener('mousedown', mousedownhandler, true);
  3489. var aPattern = '<a href="" class="sej-engine" target="$blank$" data-iqxincategory="$category$" encoding="$encoding$" gbk="$gbk$" url="$url$"><img src="$favicon$" class="sej-engine-icon" />$name$</a>';
  3490. var dropLists = [];
  3491. engineList.details.forEach(function (item) {
  3492. // console.log(item); // 搜索菜单  ["网页", "web", true]
  3493. var category = item[1]; // "web"
  3494. var cName = item[0]; // "网页"
  3495. var engines = [];
  3496.  
  3497. engineList[category].forEach(function (engine) {
  3498. // 检测是否用搜索搜某一网站 site:xxx.xx
  3499. var engineUrl = engine.url;
  3500. var siteIndex = engineUrl.lastIndexOf("site");
  3501. var siteMark = null;
  3502. if(~siteIndex){
  3503. var siteURL = engineUrl.slice(siteIndex);
  3504. siteMark = /([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,6}/.test(siteURL);
  3505. // console.log(/([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,6}/.test(siteURL),siteURL);
  3506. }
  3507. console.log(matchedRule.url,engineUrl)
  3508. console.log(matchedRule.url.test(engineUrl))
  3509. if (getSettingData.HideTheSameLink && !siteMark && matchedRule.url.test(engineUrl)) return;// 去掉跳转到当前引擎的引擎
  3510.  
  3511. if(engine.disable) return;
  3512. var a = aPattern.replace('$encoding$', (engine.encoding || 'utf-8').toLowerCase())
  3513. .replace('$url$', engineUrl)
  3514. .replace('$name$', engine.name)
  3515. .replace("$category$",category);
  3516.  
  3517. // 图标
  3518. if (engine.favicon) {
  3519. a = a.replace('$favicon$', engine.favicon);
  3520. } else {
  3521. a = a.replace('src="$favicon$"', '');
  3522. };
  3523. // gbk编码
  3524. if (engine.gbk) {
  3525. a = a.replace('$gbk$', engine.gbk);
  3526. } else {
  3527. a = a.replace('gbk="$gbk$"', '');
  3528. };
  3529. // 新标签页
  3530. if (getSettingData.newtab || engine.blank) {
  3531. a = a.replace('$blank$', "_blank");
  3532. } else {
  3533. a = a.replace('target="$blank$"', '');
  3534. };
  3535.  
  3536. engines.push(a);
  3537. });
  3538. // 非空列表
  3539. if (!engines.length) return;
  3540.  
  3541. engines = engines.join('');
  3542.  
  3543. // 展开当前搜索分类列表
  3544. if (!getSettingData.foldlist && category == matchedRule.engineList) {
  3545. container.innerHTML = engines;
  3546. } else {
  3547. var dropList = document.createElement('sejspan');
  3548. dropList.className = 'sej-drop-list rwl-exempt';
  3549. dropList.innerHTML = engines;
  3550.  
  3551. // a:主搜索菜单
  3552. // dropList: 搜索子菜单
  3553. var a = dropList.firstElementChild.cloneNode(true);
  3554. a.className = a.className + ' sej-drop-list-trigger';
  3555. a.lastChild.nodeValue = cName;
  3556. dropLists.push([a, dropList]);
  3557. };
  3558. });
  3559.  
  3560. //将各个搜索列表插入文档中
  3561. dropLists.forEach(function (item) {
  3562.  
  3563. // console.log(item[0]);
  3564. // console.log(item[0].dataset.iqxincategory) //"web"
  3565. // console.log(item[0].querySelector("img").src); // 图片链接
  3566. // console.log(item[0].innerText); // 网页
  3567. // console.log(item[1]);
  3568.  
  3569. if(getSettingData.icon){
  3570. console.log(icon[item[0].dataset.iqxincategory])
  3571. if(icon[item[0].dataset.iqxincategory]){
  3572. item[0].querySelector("img").src = icon[item[0].dataset.iqxincategory]
  3573.  
  3574. }
  3575. }
  3576.  
  3577.  
  3578. container.appendChild(item[0]); //将搜索列表放入主搜索
  3579. document.body.appendChild(item[1]); // 插入搜索子菜单
  3580. item[1].addEventListener('mousedown', mousedownhandler, true);
  3581.  
  3582. new DropDownList(item[0], item[1]);
  3583. });
  3584.  
  3585. // 将主搜索插入网页中
  3586. switch (matchedRule.insertIntoDoc.where.toLowerCase()) {
  3587. case 'beforebegin' : // 'beforeBegin'(插入到给定元素的前面) ;
  3588. iTarget.parentNode.insertBefore(container, iTarget);
  3589. break;
  3590. case 'afterbegin' : // 'afterBegin'(作为给定元素的第一个子元素) ;
  3591. if (iTarget.firstChild) {
  3592. iTarget.insertBefore(container, iTarget.firstChild);
  3593. } else {
  3594. iTarget.appendChild(container);
  3595. };
  3596. break;
  3597. case 'beforeend' : // 'beforeEnd' (作为给定元素的最后一个子元素) ;
  3598. iTarget.appendChild(container);
  3599. break;
  3600. case 'afterend' : // 'afterEnd'(插入到给定元素的后面);.
  3601. if (iTarget.nextSibling) {
  3602. iTarget.parentNode.insertBefore(container, iTarget.nextSibling);
  3603. } else {
  3604. iTarget.parentNode.appendChild(container);
  3605. };
  3606. break;
  3607. };
  3608.  
  3609. // todo: 此处与上面重复,在百度页面会插入两次
  3610. // 2022-07-04 重复插入后, 会导致百度界面中下拉搜索偏移,已经忘了当初加入这个是为了解决什么bug了, 但是这几行代码又引来了源源不断的bug。
  3611. // if(/^https?:\/\/www\.baidu\.com\/(?:s|baidu)/.test(url)){
  3612. // var sej = document.getElementsByTagName("sejspan")[0];
  3613. // sej.appendChild(globalStyle);
  3614.  
  3615. // dropLists.forEach(function (item) {
  3616. // container.appendChild(item[0]);
  3617. // // document.body.appendChild(item[1]);
  3618. // var sej = document.getElementsByTagName("sejspan")[0];
  3619. // sej.appendChild(item[1]);
  3620. // item[1].addEventListener('mousedown', mousedownhandler, true);
  3621.  
  3622. // new DropDownList(item[0], item[1]);
  3623. // });
  3624. // };
  3625.  
  3626. // 兼容其他修改网页的脚本
  3627. if (matchedRule.style) {
  3628. // 判断是否存在脚本 “AC-baidu:重定向优化百度搜狗谷歌搜索_去广告_favicon_双列”
  3629. if(getSettingData.center==2){ // 自动判断是否添加
  3630. // console.log("判断是否自动添加");
  3631. // console.log(document.querySelector("#myuser"));
  3632. // console.log(matchedRule.style_ACBaidu);
  3633. if(document.querySelector(".AC-style-logo") && matchedRule.style_ACBaidu){
  3634. console.log("检测到脚本:“AC-baidu:重定向优化百度搜狗谷歌搜索_去广告_favicon_双列” ------自动添加");
  3635. matchedRule.style = matchedRule.style_ACBaidu;
  3636. }
  3637. } else if (getSettingData.center==1){ // 强制添加
  3638. console.log("检测到脚本:“AC-baidu:重定向优化百度搜狗谷歌搜索_去广告_favicon_双列” ------强制添加");
  3639. matchedRule.style = matchedRule.style_ACBaidu?matchedRule.style_ACBaidu:matchedRule.style;
  3640. } //
  3641. // 判断是否存在脚本“知乎排版优化”
  3642. if(document.getElementById('SearchMain')){
  3643. if(document.getElementById('SearchMain').style.marginLeft=='150px'){
  3644. matchedRule.style = matchedRule.style_ZhihuChenglinz;
  3645. matchedRule.fixedTop = null;
  3646. console.log("检测到‘知乎排版优化’脚本")
  3647. }
  3648. }
  3649. container.style.cssText = matchedRule.style;
  3650. };
  3651.  
  3652. //兼容ac百度中lite选项, fixedtop和正常的不一样
  3653. setTimeout(function(){
  3654. if(document.querySelector(".AC-baiduLiteStyle") && matchedRule.fixedTop2){
  3655. console.log("检测到 AC-baiduLiteStyle")
  3656. matchedRule.fixedTop = matchedRule.fixedTop2
  3657. }else{
  3658. console.log("没找到 AC-baiduLiteStyle")
  3659. }
  3660. },2500)
  3661.  
  3662. // 由于与要插入网页的样式无法很好的兼容,更改源网页的样式
  3663. if(matchedRule.stylish){GM_addStyle(matchedRule.stylish);};
  3664. //固定搜索栏
  3665. if(getSettingData.fixedTop){
  3666. // 判断是否需要只在向上滚动时显示
  3667. if(getSettingData.fixedTopUpward){
  3668. window.onmousewheel = document.onmousewheel = function(eee){
  3669. if(eee.wheelDelta>0){
  3670. fixedTopFun(matchedRule.fixedTop, matchedRule.fixedTopColor);
  3671. }else{
  3672. var obj = document.getElementById("sej-container");
  3673. obj.style.cssText = matchedRule.style;
  3674. }
  3675. }
  3676. } else {
  3677. window.onscroll = function(){
  3678. fixedTopFun(matchedRule.fixedTop, matchedRule.fixedTopColor);
  3679. };
  3680. }
  3681. } else {
  3682. window.onscroll = function(){
  3683. return true;
  3684. };
  3685. };
  3686.  
  3687. // 固定搜索栏
  3688. function fixedTopFun(height, color){
  3689. var obj = document.getElementById("sej-container");
  3690. var objTop = obj.offsetTop ;
  3691. var objLeft = obj.offsetLeft ;
  3692.  
  3693. var current = obj.offsetParent;
  3694. while (current !== null){
  3695. objLeft += current.offsetLeft;
  3696. current = current.offsetParent;
  3697. }
  3698.  
  3699. var scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
  3700.  
  3701. if(height){
  3702. objTop = height;
  3703. }else{
  3704. height = 0;
  3705. }
  3706.  
  3707. if(scrollTop <= objTop){
  3708. obj.style.cssText = matchedRule.style;
  3709. }else if(obj.style.position!="fixed"){
  3710. // console.log("固定到顶端");
  3711. // console.log(scrollTop,objTop,scrollTop - objTop);
  3712. var objstyle = window.getComputedStyle(obj , null);
  3713. var marginTop = parseInt(objstyle.marginTop);
  3714. var marginLeft = parseInt(objstyle.marginLeft);
  3715. var marginRight = parseInt(objstyle.marginRight);
  3716. //console.log(objLeft,marginLeft);
  3717.  
  3718. obj.style.top = height - marginTop + 'px';
  3719.  
  3720. // 如果之前未设置颜色,则默认设置为白色
  3721. // 2020-12-19 增加选项,可以通过代码自定义颜色,但是无法通过网站自动获取
  3722. if(color){
  3723. obj.style.background = color;
  3724. } else if(objstyle.backgroundColor === "rgba(0, 0, 0, 0)" || objstyle.backgroundColor === "transparent"){
  3725. obj.style.background = '#fff';
  3726. }
  3727. obj.style.left = getElementLeft(obj) - marginLeft + "px";
  3728. // obj.style.left = getElementLeft(obj) + "px";
  3729. debug("objLeft: ",objLeft,"marginLeft: ",marginLeft,"marginRight: ",marginRight,"getElementLeft: ",getElementLeft(obj));
  3730. // 知乎等网站的情况 利用 margin 居中
  3731. if(marginRight === marginLeft && marginRight != 0){
  3732. obj.style.left = marginLeft + "px";
  3733. }
  3734. // 淘宝等网站的情况 利用 text-align 居中
  3735. if(obj.style.textAlign === "center"){
  3736. obj.style.width = objstyle.width;
  3737. }
  3738. obj.style.position = 'fixed';
  3739.  
  3740. // if(document.querySelectorAll("input[name='sp-ac-a_force_style_baidu']").length !=0){
  3741. // console.log("检测到 ac脚本单列居中选项")
  3742. // if((document.querySelectorAll("input[name='sp-ac-a_force_style_baidu']")[2].checked)){
  3743. // obj.style.display = "none";
  3744. // obj.style.transform = "translate(-50%, 0)";
  3745. // obj.style.top = "none" ;
  3746. // obj.style.position = 'fixed';
  3747. // fixedTopFun2(matchedRule.fixedTopTarget,matchedRule.fixedTopWhere);
  3748. // return;
  3749. // }
  3750. // }
  3751. }
  3752. }
  3753. function fixedTopFun2(Target,where){
  3754. var obj = document.getElementById("sej-container");
  3755. var oTarget = getElement(Target)
  3756.  
  3757. console.log("fixedTopFun2");
  3758. console.log(Target);
  3759. console.log(where);
  3760. switch (where.toLowerCase()) {
  3761. case 'beforebegin' : // 'beforeBegin'(插入到给定元素的前面) ;
  3762. oTarget.parentNode.insertBefore(obj, oTarget);
  3763. break;
  3764. case 'afterbegin' : // 'afterBegin'(作为给定元素的第一个子元素) ;
  3765. if (oTarget.firstChild) {
  3766. oTarget.insertBefore(obj, oTarget.firstChild);
  3767. } else {
  3768. oTarget.appendChild(obj);
  3769. };
  3770. break;
  3771. case 'beforeend' : // 'beforeEnd' (作为给定元素的最后一个子元素) ;
  3772. oTarget.appendChild(obj);
  3773. break;
  3774. case 'afterend' : // 'afterEnd'(插入到给定元素的后面);.
  3775. if (oTarget.nextSibling) {
  3776. oTarget.parentNode.insertBefore(obj, oTarget.nextSibling);
  3777. } else {
  3778. oTarget.parentNode.appendChild(obj);
  3779. };
  3780. break;
  3781. };
  3782. };
  3783.  
  3784. // -------------------设置相关--------------------------------
  3785. // 设置按钮相关
  3786. var dragEl = null;
  3787. var dragData = null;
  3788.  
  3789. function SEJsetting(){
  3790. this.ele = document.createElement("div");
  3791. this.mask = document.createElement("div");
  3792.  
  3793. this.parentTemp = null;
  3794. this.editTemp = null;
  3795. this.online = null;
  3796. this.init();
  3797. };
  3798.  
  3799. SEJsetting.prototype = {
  3800. testabc : "hahah",
  3801. aPatternParent : "<div></div>",
  3802.  
  3803. init: function () {
  3804. // console.log("init...");
  3805. var that = this;
  3806.  
  3807. this.ele.id = "settingLayer";
  3808. this.mask.id = "settingLayerMask";
  3809.  
  3810. this.addGlobalStyle();
  3811.  
  3812. this.addContent();
  3813.  
  3814. this.mask.addEventListener("click",function(){
  3815. that.hide();
  3816. });
  3817. this.ele.addEventListener("click",function(e){
  3818. e.stopPropagation();
  3819. });
  3820.  
  3821. this.mask.appendChild(this.ele);
  3822. document.body.appendChild(this.mask);
  3823.  
  3824. // 绑定事件
  3825. this.ele.addEventListener("click",that.domClick.bind(this),false);
  3826. this.dragEvent();
  3827. this.setDragNode(this.ele); //设置拖动
  3828. // input[range]
  3829. that.rangeChange(true);
  3830. document.querySelector("#setBtnOpacityRange").addEventListener("input",that.rangeChange);
  3831. },
  3832. dragEvent: function(){
  3833. var that = this;
  3834. var odivsdrag = document.querySelectorAll(".drag");
  3835. [].forEach.call(odivsdrag,function(odiv){
  3836. odiv.addEventListener("dragstart",that.domdragstart,false);
  3837. odiv.addEventListener('dragenter', that.domdragenter, false);
  3838. odiv.addEventListener('dragover', that.domdragover, false);
  3839. odiv.addEventListener('dragleave', that.domdragleave, false);
  3840. odiv.addEventListener('drop', that.domdrop, false);
  3841. odiv.addEventListener('dragend',that.domdropend, false);
  3842. });
  3843. },
  3844. addContent: function(){
  3845. var aPattern = '<span draggable="true" class="drag">' +
  3846. '<span class="sej-engine"' +
  3847. ' data-xin="$xin$" ' +
  3848. ' data-iqxinimg="$img$" ' +
  3849. ' data-iqxintitle="$title$" ' +
  3850. ' data-iqxinlink="$link$" ' +
  3851. ' data-iqxintarget="$blank$" ' +
  3852. ' data-iqxindisabled="$disabled$" ' +
  3853. ' data-iqxingbk="$gbk$" ' +
  3854. '><img src="$favicon$" class="sej-engine-icon" style="padding-bottom:3px;"/><span>$name$</span></span>' +
  3855. ' <span class="iqxin-set-edit" title="编辑 Edit"><img class="sej-engine-icon" src=""/></span>' +
  3856. ' <span class="iqxin-set-del" title="删除 Delete"><img class="sej-engine-icon" src=""></span>' +
  3857. '</span>';
  3858. var details = engineList.details;
  3859. // 若根据数组长度获取,负数引导的为属性,不再length长度之内,所以来个大体的数字,当都为空时,结束循环
  3860. // var detailsLength = details.length;
  3861. var detailsLength = 99;
  3862. for (let i=0;i<detailsLength;i++){
  3863. var j = i;
  3864. j = details[j] ? j : -j;
  3865. if (!details[j]){break};
  3866.  
  3867. var odiv = document.createElement("div");
  3868. odiv.id = details[j][1]; // "web"
  3869. odiv.classList.add("iqxin-items");
  3870.  
  3871. var oDivTitle = document.createElement("div");
  3872. oDivTitle.classList.add("sejtitle","drag");
  3873. oDivTitle.setAttribute("draggable","true");
  3874. oDivTitle.dataset.iqxintitle = details[j][1];
  3875. oDivTitle.dataset.xin = j;
  3876. oDivTitle.innerHTML ='<span class="iqxin-pointer-events">' + details[j][0] + '</span>' +
  3877. '<span class="iqxin-title-edit" title="编辑 Edit"><img class="sej-engine-icon" src="' + icon.edit + '"/></span>'+
  3878. ' <span class="iqxin-set-title-del" title="删除 Delete"><img class="sej-engine-icon" src="' + icon.del + '"></span>';
  3879. odiv.appendChild(oDivTitle);
  3880.  
  3881. var oDivCon = document.createElement("div");
  3882. oDivCon.classList.add("sejcon");
  3883. var oDivConStr = "";
  3884. var engineListItme = engineList[details[j][1]];
  3885. var itemLength = engineListItme.length;
  3886. for(let ii=0;ii<itemLength;ii++){
  3887. var jj = ii;
  3888. if (!engineListItme[jj]){break};
  3889. var a = aPattern.replace('$name$', engineListItme[jj].name)
  3890. .replace('$favicon$', engineListItme[jj].favicon)
  3891. .replace("$xin$",jj);
  3892. // 添加属性
  3893. a = a.replace("$img$", engineListItme[jj].favicon)
  3894. .replace("$title$", engineListItme[jj].name)
  3895. .replace("$link$", engineListItme[jj].url);
  3896. if (engineListItme[jj].blank) {
  3897. a = a.replace('$blank$', "_blank");
  3898. } else {
  3899. a = a.replace('data-iqxintarget="$blank$"', '');
  3900. };
  3901. if (engineListItme[jj].disable) {
  3902. a = a.replace('$disabled$', "true");
  3903. } else {
  3904. a = a.replace('data-iqxindisabled="$disabled$"', '');
  3905. };
  3906. if (engineListItme[jj].gbk) {
  3907. a = a.replace('$gbk$', "true");
  3908. } else {
  3909. a = a.replace('data-iqxingbk="$gbk$"', '');
  3910. };
  3911.  
  3912. oDivConStr += a;
  3913. };
  3914.  
  3915. oDivConStr += "<span class='iqxin-additem'>+</span>";
  3916.  
  3917. oDivCon.innerHTML = oDivConStr;
  3918. odiv.appendChild(oDivCon);
  3919.  
  3920. this.ele.appendChild(odiv);
  3921. };
  3922.  
  3923. // 更多设置 菜单
  3924. var btnEle2 = document.createElement("div");
  3925. btnEle2.id = "btnEle2"
  3926. var fixedTop_checked = getSettingData.fixedTop?"checked":"";
  3927. var fixedTopUpward_checked = getSettingData.fixedTopUpward?"checked":"";
  3928. // var debug_checked = getSettingData.debug?"checked":"";
  3929. var transition_checked = getSettingData.transtion?"checked":"";
  3930. var foldlist_checked = getSettingData.foldlist?"checked":"";
  3931. var allOpen_checked = getSettingData.allOpen?"checked":"";
  3932. var HideTheSameLink_checked = getSettingData.HideTheSameLink?"checked":"";
  3933.  
  3934. // var setBtnOpacity_value = getSettingData.setBtnOpacity;
  3935. var btnStr2 = "<div>" +
  3936. // "<span id='xin-reset' title='慎点,出厂重置'>清空设置</span>" +
  3937. "<span id='xin-modification' title='edit 分享自己的配置或清空配置'>配置文件</span>" +
  3938. "<span id='xin-importing' title='importing 导入更为专业的搜索引擎'>导入</span>" +
  3939. // "<span id='iqxin-debugS' title='对设置菜单有一定的影响'>" +
  3940. // "<label>debug<input id='iqxin-debug' type='checkbox' name='' " +
  3941. // debug_checked +
  3942. // " style='vertical-align:middle;'></label>" +
  3943. // "</span>" +
  3944. "<span id='xin-transtion' title='动画,该设置需要刷新页面生效'>" +
  3945. "<label>动画<input id='iqxin-transtion' type='checkbox' name='' " +
  3946. transition_checked +
  3947. " style='vertical-align:middle;'></label>" +
  3948. "</span>" +
  3949. "<span id='xin-foldlists' title='将当前所在搜索分类折叠'>" +
  3950. "<label>折叠当前搜索分类<input id='iqxin-foldlist' type='checkbox' name='' " +
  3951. foldlist_checked +
  3952. " style='vertical-align:middle;'></label>" +
  3953. "</span>" +
  3954. "<span id='iqxin-fixedTopS' title='fixedTop 当滚动页面时,固定到页面顶端。某些页面的样式存在问题'>" +
  3955. "<label>固定到顶端<input id='iqxin-fixedTop' type='checkbox' name='' " +
  3956. fixedTop_checked +
  3957. " style='vertical-align:middle;'></label>" +
  3958. "</span>" +
  3959. "<span id='iqxin-fixedTopUpward' title='固定到顶端后,仅向上滚动才显示,需要刷新网页生效'>" +
  3960. "<label>仅上拉显示<input id='iqxin-fixedTopUpward-item' type='checkbox' name='' " +
  3961. fixedTopUpward_checked +
  3962. " style='vertical-align:middle;'></label>" +
  3963. "</span>" +
  3964. "<span id='xin-HideTheSameLink' title='隐藏同站链接,如果想在同一个搜索网站,但是想通过不同语言来搜索, 可以取消该选项'>" +
  3965. "<label>隐藏同站链接<input id='iqxin-HideTheSameLink' type='checkbox' name='' " +
  3966. HideTheSameLink_checked +
  3967. " style='vertical-align:middle;'></label>" +
  3968. "</span>" +
  3969. "<span id='xin-setBtnOpacity' title='设置按钮透明度'>设置按钮透明度 <input type='range' step='0.05' min='0' max='1' value='"+ (getSettingData.setBtnOpacity<0?-getSettingData.setBtnOpacity:getSettingData.setBtnOpacity) +"' id='setBtnOpacityRange'><i style='display:inline-block;width:3em;text-align:center;' class='iqxin-setBtnOpacityRangeValue' title='按钮 显示/隐藏(非透明)),请确定知道自己如何再次打开; 火狐非高级玩家建议别禁用'></i></span>" +
  3970.  
  3971. "</div>" ;
  3972. // "<div><span>test</span></div>";
  3973. btnEle2.innerHTML = btnStr2;
  3974. this.ele.appendChild(btnEle2);
  3975.  
  3976.  
  3977. // 添加按钮
  3978. var btnEle = document.createElement("div");
  3979. btnEle.id = "btnEle"
  3980.  
  3981. var btnStr = "<div class='btnEleLayer'>" +
  3982. "<span class='feedback' title='在 GreasyFork 进行反馈'><a target='_blank' href='https://gf.qytechs.cn/zh-CN/scripts/27752-searchenginejump'>Greasy Fork镜像</a></span>" +
  3983. "<span class='feedback' title='在 Github 进行反馈'><a target='_blank' href='https://github.com/qxinGitHub/searchEngineJump'>GitHub</a></span>" +
  3984. "<span id='xin-allOpen' title='后台打开该搜索分类的所有网站'>" +
  3985. "<label>一键搜索<input id='iqxin-allOpen-item' type='checkbox' name='' " +
  3986. allOpen_checked +
  3987. " style='vertical-align:middle;'></label>" +
  3988. "</span>" +
  3989. "<span id='xin-centerDisplay' title='center 居中显示。主要是兼容AC-baidu:重定向优化百度搜狗谷歌搜索_去广告_favicon_双列'>居中:" +
  3990. "<select id='iqxin-center'>" +
  3991. "<option value='original'" + (getSettingData.center == 0?"selected":"") + ">默认 ▽</option>" +
  3992. "<option value='force'" + (getSettingData.center == 1?"selected":"") + ">强制 ▽</option>" +
  3993. "<option value='auto'" + (getSettingData.center == 2?"selected":"") + ">自动 ▽</option>" +
  3994. "</select>" +
  3995. "</span> " +
  3996. "<span id='xin-newtab' title='open newtab 是否采用新标签页打开的方式'>打开方式:" +
  3997. "<select id='iqxin-globalNewtab'>" +
  3998. "<option value='globalDef'>默认页面 ▽</option>" +
  3999. "<option value='globalNewtab'" + (getSettingData.newtab?"selected":"") + ">新标签页 ▽</option>" +
  4000. "</select>" +
  4001. "</span> " +
  4002. "<span id='xin-addDel' title='add & del 增加新的或者删除现有的搜索'>增加 / 删除</span> " +
  4003. "<span id='moreSet' title='more set'>更多设置</span>" +
  4004. "<span id='xin-save' title='save & close'>保存并关闭</span>" +
  4005. "</div>";
  4006. btnEle.innerHTML = btnStr;
  4007. this.ele.appendChild(btnEle);
  4008.  
  4009. // 可以拖动的顶栏
  4010. var dragDom = document.createElement("div");
  4011. dragDom.id = "dragDom";
  4012. dragDom.style.cssText = "height:16px;width:97%;position:absolute;top:0;cursor:move;";
  4013. this.ele.appendChild(dragDom);
  4014.  
  4015. // 增加搜索列表
  4016. var nSearchList = document.createElement("div");
  4017. nSearchList.id = "nSearchList";
  4018. nSearchList.style.cssText = "visibility:hidden;opacity:0;transition:0.3s;position:absolute;bottom:10%;right:5%;padding:5px 10px;border-radius:4px;border:1px solid #EC6D51;color:#ec6d51;cursor:pointer;background:#fff;";
  4019. nSearchList.innerHTML = "增加新的搜索列表";
  4020. this.ele.appendChild(nSearchList);
  4021.  
  4022. // 关闭按钮
  4023. if(getSettingData.closeBtn){
  4024. var closebtnELe = document.createElement("span");
  4025. closebtnELe.id = "xin-close";
  4026. closebtnELe.setAttribute("title","close 关闭");
  4027. this.ele.appendChild(closebtnELe);
  4028. }
  4029. },
  4030. show: function(){
  4031. var style = this.mask.style;
  4032. var eleStyle = this.ele.style;
  4033. style.display = "flex";
  4034. eleStyle.transform = "translateY(-20%)";
  4035. document.body.style.overflow = "hidden";
  4036.  
  4037. this.windowResize();
  4038.  
  4039. // if(document.querySelector("xin-newtab")){
  4040. // document.querySelector("#xin-newtab").querySelectorAll("option")[getSettingData.newtab].setAttribute("selected","selected");
  4041. // }
  4042.  
  4043. setTimeout(function () {
  4044. style.opacity = 1;
  4045. eleStyle.transform = "none";
  4046. }, 30);
  4047. },
  4048. hide: function(){
  4049. this.allBoxClose(); // 关闭所有次级窗口、菜单
  4050.  
  4051. var style = this.mask.style;
  4052. this.ele.style.transform = "translateY(20%)";
  4053. style.opacity = 0;
  4054. setTimeout(function () {
  4055. style.display = "none";
  4056. document.body.style.overflow = "auto";
  4057. }, 500);
  4058. },
  4059. reset: function(){
  4060. if(confirm("将会删除用户设置!")){
  4061. GM_deleteValue("searchEngineJumpData");
  4062. window.location.reload();
  4063. }
  4064. },
  4065. // 增加 “添加删除框”
  4066. addDel: function(e){
  4067. if (e.target.classList.contains("iqxin-btn-active")){
  4068. this.addDelremove();
  4069. } else {
  4070. // console.log("不存在,增加增加");
  4071. var obtn = document.querySelector("#xin-addDel");
  4072. obtn.classList.add("iqxin-btn-active");
  4073.  
  4074. var odom = document.querySelectorAll(".iqxin-set-del");
  4075. [].forEach.call(odom,function(div){
  4076. div.classList.add("iqxin-set-active");
  4077. });
  4078.  
  4079. // 标题添加删除框
  4080. var odom = document.querySelectorAll(".iqxin-set-title-del");
  4081. [].forEach.call(odom,function(div){
  4082. // console.log(div);
  4083. div.classList.add("iqxin-set-active");
  4084. });
  4085.  
  4086. // 增加单个搜索
  4087. var oitemAdd = document.querySelectorAll(".iqxin-additem");
  4088. [].forEach.call(oitemAdd,function(div){
  4089. // console.log(div);
  4090. div.classList.add("iqxin-set-active");
  4091. });
  4092.  
  4093. // 添加搜索列表
  4094. var olistAdd = document.querySelector("#nSearchList");
  4095. olistAdd.classList.add("iqxin-set-active");
  4096.  
  4097. }
  4098. },
  4099. // 关闭 “添加删除框”
  4100. addDelremove: function(bool){
  4101. var obtn = document.querySelector(".iqxin-btn-active");
  4102. if(obtn){
  4103. obtn.classList.remove("iqxin-btn-active");
  4104.  
  4105. var odom = document.querySelectorAll(".iqxin-set-active");
  4106. [].forEach.call(odom,function(div){
  4107. div.classList.remove("iqxin-set-active");
  4108. });
  4109.  
  4110. var oitemAdd = document.querySelectorAll(".iqxin-additem");
  4111. [].forEach.call(oitemAdd,function(div){
  4112. div.classList.remove("iqxin-set-active");
  4113. });
  4114. }
  4115. this.addItemBoxRemove();
  4116. },
  4117.  
  4118. // 界面,框:添加新的搜索
  4119. addItemBox: function(bool){
  4120. this.isOnline();
  4121. this.addItemBoxRemove();
  4122.  
  4123. var newDiv = document.createElement("div");
  4124. newDiv.id= "newSearchBox";
  4125. newDiv.style.cssText = "top:43%;opacity:0.1;";
  4126. newDiv.innerHTML=""+
  4127. "<span>标&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp题 : </span><input id='iqxin-newTitle' placeholder='必填' onfocus='this.select()' /> <br/><br/>" +
  4128. "<span>链&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp接 : </span><input id='iqxin-newLink' placeholder='必填' onfocus='this.select()' /> <br/><br/>" +
  4129. "<span>图&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp标 : </span><input id='iqxin-newIcon' placeholder='选填,留空则自动获取' onfocus='this.select()' /> <br/><br/>" +
  4130. "<span>打开方式 : " +
  4131. '<select id="iqxin-newTarget" style="border-radius: 4px;border: none;padding: 2px 0 2px 2px"> ' +
  4132. '<option value="default">新标签页打开</option> ' +
  4133. '<option value="newtab">当前页打开</option> ' +
  4134. '<select> ' +
  4135. "</span>" +
  4136. "<br/><br/>" +
  4137. "<span style=''><a target='_blank' style='color:#999;' href='https://gf.qytechs.cn/zh-CN/scripts/27752-searchenginejump'>相关使用说明</a></span>" +
  4138. "&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp;" +
  4139. "<button id='addItemBoxEnter' class='addItemBoxEnter addItemBoxBtn iqxin-enterBtn'>确定</button>&nbsp;&nbsp;&nbsp&nbsp&nbsp;&nbsp" +
  4140. "<button id='addItemBoxCancel' class='addItemBoxCancel addItemBoxBtn iqxin-closeBtn'>取消</button>" +
  4141. "";
  4142.  
  4143. this.ele.appendChild(newDiv);
  4144. setTimeout(function(){newDiv.style.cssText="";},10);
  4145. document.querySelector("#iqxin-newTitle").focus();
  4146. },
  4147. // 内部逻辑,:添加新的搜索
  4148. addItemEnger: function(){
  4149. var otitle,olink,oimg,oblank;
  4150. otitle = document.querySelector("#iqxin-newTitle").value;
  4151. olink = document.querySelector("#iqxin-newLink").value;
  4152. oimg = document.querySelector("#iqxin-newIcon").value;
  4153. oblank = document.querySelector("#iqxin-newTarget").selectedIndex;
  4154.  
  4155. if (!oimg){
  4156. oimg = this.getICON(olink);
  4157. }
  4158.  
  4159. var a = '<span class="sej-engine"' +
  4160. ' data-iqxinimg="$img$" ' +
  4161. ' data-iqxintitle="$title$" ' +
  4162. ' data-iqxinlink="$link$" ' +
  4163. ' data-iqxintarget="$blank$" ' +
  4164. '><img src="$favicon$" class="sej-engine-icon" />$name$</span>' +
  4165. '<span class="iqxin-set-edit" title="编辑 Edit">' +
  4166. '<img class="sej-engine-icon" src="' + icon.edit + '">' +
  4167. '</span> ' +
  4168. '<span class="iqxin-set-del iqxin-set-active" title="删除 Delete">' +
  4169. '<img class="sej-engine-icon" src="' + icon.del + '">' +
  4170. '</span>' ;
  4171.  
  4172. a = a.replace("$img$", oimg)
  4173. .replace("$title$", otitle)
  4174. .replace("$link$", olink);
  4175.  
  4176. if (oblank){
  4177. a = a.replace('data-iqxintarget="$blank$"', '');
  4178. } else {
  4179. a = a.replace('$blank$', "_blank");
  4180. };
  4181.  
  4182. a = a.replace('$name$', otitle)
  4183. .replace('$favicon$', oimg);
  4184.  
  4185. var ospan = document.createElement("span");
  4186. ospan.className = "drag";
  4187. ospan.innerHTML = a;
  4188.  
  4189. this.parentNode.insertBefore(ospan,this.parentNode.lastChild);
  4190.  
  4191. // 添加完成,移除添加框
  4192. this.addItemBoxRemove();
  4193. },
  4194. addItemBoxRemove: function(ele){
  4195. ele = ele?ele:"#newSearchBox"
  4196. var newBox = document.querySelector(ele);
  4197. if(newBox){
  4198. // newBox.style.transform = "translateY(30%)";
  4199. newBox.style.top = "60%";
  4200. newBox.style.opacity = "0";
  4201. setTimeout(function(){
  4202. newBox.parentNode.removeChild(newBox);
  4203. },550);
  4204. }
  4205. },
  4206. // 获取图标
  4207. getICON: function(olink){
  4208. var ourl;
  4209. var mark;
  4210. var uri = parseUri(olink);
  4211. var ohttp = uri.protocol?uri.protocol:"http";
  4212. var siteURL = ohttp + "://" + uri.host;
  4213. // console.log(siteURL);
  4214.  
  4215. if(isNaN(getSettingData.getIcon)){
  4216. ourl = getSettingData.getIcon;
  4217. } else {
  4218. mark = parseInt(getSettingData.getIcon);
  4219. console.log(mark);
  4220. switch (mark){
  4221. case 1: ourl = siteURL + "/favicon.ico";break;
  4222. case 2: ourl = 'https://www.google.com/s2/favicons?domain='+siteURL;break;
  4223. case 3: ourl = 'http://statics.dnspod.cn/proxy_favicon/_/favicon?domain='+uri.host;break;
  4224. }
  4225. }
  4226.  
  4227. if(ourl){
  4228. ourl = ourl.replace("%s", siteURL)
  4229. return ourl;
  4230. }
  4231. debug("能否连接至google:",this.online);
  4232. if (this.online){
  4233. ourl = 'https://www.google.com/s2/favicons?domain=' + uri.host;
  4234. return ourl;
  4235. } else {
  4236. ourl = ohttp + "://" + uri.host + "/favicon.ico";
  4237. return ourl;
  4238. }
  4239. },
  4240.  
  4241. // 界面, 框: 添加新的搜索列表
  4242. addSearchListBox: function(){
  4243. var odiv = document.querySelector("#newSearchListBox");
  4244. if (odiv){
  4245. this.boxClose("#newSearchListBox");
  4246. return;
  4247. }
  4248. var newDiv = document.createElement("div");
  4249. newDiv.id= "newSearchListBox";
  4250.  
  4251. var myDate = new Date();
  4252. // var hash = "user" + myDate.getFullYear() + myDate.getMonth() + myDate.getDate() + myDate.getHours() +myDate.getMinutes()+myDate.getSeconds();
  4253. var hash = "user" + myDate.getTime();
  4254.  
  4255. newDiv.innerHTML=""+
  4256. "<span>列表名称: </span><input id='iqxin-newSearchListName' onfocus='this.select()'>" +
  4257. "<br><br>" +
  4258. "<span>内部名称: </span><input id='iqxin-newSearchListInnerName' onfocus='this.select()' value='" + hash + "'>" +
  4259. "<br><br>" +
  4260. "<button id='addSearchListBoxEnter' class='addSearchListBoxEnter addItemBoxBtn'>确定</button>&nbsp;&nbsp;&nbsp&nbsp&nbsp;&nbsp" +
  4261. "<button id='addSearchListBoxCancel' class='addSearchListBoxCancel addItemBoxBtn'>取消</button>" +
  4262. "";
  4263. this.ele.appendChild(newDiv);
  4264.  
  4265. document.querySelector("#iqxin-newSearchListName").focus();
  4266. },
  4267. addSearchListEnger: function(){
  4268. var name = document.querySelector("#iqxin-newSearchListName").value;
  4269. var innerName = document.querySelector("#iqxin-newSearchListInnerName").value;
  4270.  
  4271. if(innerName.length===0){
  4272. alert("内部名称不能为空");
  4273. return;
  4274. }
  4275. if(name.length===0){
  4276. name = innerName;
  4277. }
  4278.  
  4279. var odiv = document.createElement("div");
  4280. odiv.id = innerName;
  4281. odiv.className = "iqxin-items";
  4282. odiv.innerHTML = "" +
  4283. '<div class="sejtitle" data-iqxintitle="' + innerName + '" data-xin="99">' +
  4284. '<span class="iqxin-pointer-events">'+ name +'</span>' +
  4285. '<span class="iqxin-title-edit" title="编辑 Edit">' +
  4286. '<img class="sej-engine-icon" src="' + icon.edit + '">' +
  4287. '</span> ' +
  4288. '<span class="iqxin-set-title-del iqxin-set-active" title="删除 Delete">' +
  4289. '<img class="sej-engine-icon" src="' + icon.del + '">' +
  4290. '</span>' +
  4291. '</div>' +
  4292. '<div class="sejcon">' +
  4293. '<span class="iqxin-additem iqxin-set-active">+</span>' +
  4294. '</div>' +
  4295. "";
  4296.  
  4297. // this.boxClose("#newSearchListBox");
  4298. this.addItemBoxRemove("#newSearchListBox");
  4299.  
  4300. var btnEle = document.querySelector("#btnEle");
  4301. btnEle.parentNode.insertBefore(odiv,btnEle);
  4302. },
  4303.  
  4304. boxClose: function(ele){
  4305. var odiv = document.querySelector(ele);
  4306. if(odiv){
  4307. odiv.parentNode.removeChild(odiv);
  4308. }
  4309. },
  4310.  
  4311. // 界面 框:修改框
  4312. addEditBox: function(e){
  4313. console.log(e);
  4314. this.addItemBoxRemove();
  4315.  
  4316. var target = e.target.parentNode.firstChild;
  4317.  
  4318. var otitle = target.dataset.iqxintitle;
  4319. var olink = target.dataset.iqxinlink;
  4320. var oicon = target.dataset.iqxinimg;
  4321. var otarget = target.dataset.iqxintarget;
  4322. var odisabled = target.dataset.iqxindisabled;
  4323.  
  4324. this.editTemp = target;
  4325.  
  4326. var strblank;
  4327. if(otarget){
  4328. strblank = '<option value="default">新标签页打开</option><option value="newtab">当前页打开</option> ';
  4329. } else{
  4330. strblank = '<option value="default">新标签页打开</option><option value="newtab" selected="selected">当前页打开</option>';
  4331. }
  4332.  
  4333. var strdisable = "";
  4334. if(odisabled){
  4335. strdisable = "checked='checked'";
  4336. }
  4337.  
  4338. var newDiv = document.createElement("div");
  4339. newDiv.id= "newSearchBox";
  4340. // 从鼠标点击所在的项目展开菜单(2021-03-16,从上线至今,动画一直有卡顿现象)
  4341. // newDiv.style.cssText = "top:"+(e.screenY-120) +"px;left:"+(e.screenX-140) +"px;";
  4342. newDiv.style.cssText = "top:43%;opacity:0.1;";
  4343. var innerHTML=""+
  4344. "<span>标&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp题 : </span><input id='iqxin-newTitle' placeholder='必填' onfocus='this.select()' value='"+ otitle +"' /> <br/><br/>" +
  4345. "<span>链&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp接 : </span><input id='iqxin-newLink' placeholder='必填' onfocus='this.select()' value='"+ olink +"' /> <br/><br/>" +
  4346. "<span>图&nbsp;&nbsp;&nbsp&nbsp&nbsp&nbsp&nbsp标 : </span><input id='iqxin-newIcon' placeholder='选填,留空则自动获取' onfocus='this.select()' value='"+ oicon +"' /> <br/><br/>" +
  4347. "<span>打开方式 : " +
  4348. '<select id="iqxin-newTarget" style="border-radius: 4px;border: none;padding: 2px 0 2px 2px"> ' +
  4349. '$strblank$' +
  4350. '<select> ' +
  4351. "</span>" +
  4352. "<br/><br/>" +
  4353. "<span style=''><label>禁用:<input type='checkbox' name='' id='iqxin-newDisabled' $checked$ style='vertical-align:middle;'></label></span>" +
  4354. "&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;" +
  4355. "<button id='editItemBoxEnter' class='editItemBoxEnter addItemBoxBtn iqxin-enterBtn'>确定</button>&nbsp;&nbsp;&nbsp&nbsp&nbsp;&nbsp" +
  4356. "<button id='addItemBoxCancel' class='addItemBoxCancel addItemBoxBtn iqxin-closeBtn'>取消</button>" +
  4357. "";
  4358.  
  4359. newDiv.innerHTML = innerHTML.replace("$strblank$", strblank)
  4360. .replace("$checked$",strdisable);
  4361.  
  4362. this.ele.appendChild(newDiv);
  4363. setTimeout(function(){newDiv.style.cssText="";},10);
  4364. document.querySelector("#iqxin-newTitle").select();
  4365. },
  4366. addEditBoxEnger: function(){
  4367. var otitle,olink,oimg,oblank,odisabled;
  4368. otitle = document.querySelector("#iqxin-newTitle").value;
  4369. olink = document.querySelector("#iqxin-newLink").value;
  4370. oimg = document.querySelector("#iqxin-newIcon").value;
  4371. oblank = document.querySelector("#iqxin-newTarget").selectedIndex;
  4372. odisabled = document.querySelector("#iqxin-newDisabled").checked;
  4373.  
  4374. this.editTemp.dataset.iqxintitle = otitle;
  4375. this.editTemp.lastChild.innerText = otitle; //文本节点
  4376.  
  4377. this.editTemp.dataset.iqxinlink = olink;
  4378. this.editTemp.dataset.iqxinimg = oimg;
  4379. this.editTemp.firstChild.src = oimg;
  4380.  
  4381. // 是否新标签页打开
  4382. if (oblank){
  4383. this.editTemp.removeAttribute("data-iqxintarget");
  4384. } else {
  4385. this.editTemp.dataset.iqxintarget = "_blank";
  4386. }
  4387. // 是否禁用
  4388. if (odisabled){
  4389. this.editTemp.dataset.iqxindisabled = "true";
  4390. } else{
  4391. this.editTemp.removeAttribute("data-iqxindisabled");
  4392. }
  4393.  
  4394. // 修改完成,移除添加框
  4395. this.addItemBoxRemove();
  4396. },
  4397.  
  4398. // 标题编辑
  4399. addTitleEditBox: function(e){
  4400. this.addItemBoxRemove();
  4401.  
  4402. var element = e.target.parentNode.firstChild;
  4403. element.classList.remove("iqxin-pointer-events");
  4404.  
  4405. var flag = document.querySelector("#titleEdit");
  4406. // 存在编辑的标题 && 之前的编辑的节点与点击的节点是同一个节点
  4407. if(flag && flag.parentNode == element){
  4408. element.innerHTML = element.firstChild.value?element.firstChild.value:"空";
  4409. element.classList.add("iqxin-pointer-events");
  4410. } else {
  4411. // 存在编辑的标题,但与点击的不是同一个节点
  4412. if(flag){
  4413. flag.parentNode.innerHTML = flag.parentNode.firstChild.value;
  4414. }
  4415. var oldhtml = element.innerHTML;
  4416. var newobj = document.createElement("input");
  4417. newobj.id = "titleEdit";
  4418. newobj.type = "text";
  4419. newobj.value = oldhtml;
  4420. // newobj.onblur = function(){
  4421. // element.innerHTML = this.value?this.value:oldhtml;
  4422. // }
  4423. newobj.onkeydown = function(e){
  4424. if((e.keyCode || e.which) == 13){
  4425. element.innerHTML = this.value?this.value:oldhtml;
  4426. } else if((e.keyCode || e.which) == 27){
  4427. element.innerHTML = oldhtml;
  4428. }
  4429.  
  4430. element.classList.add("iqxin-pointer-events");
  4431. }
  4432. element.innerHTML = "";
  4433. element.appendChild(newobj);
  4434. newobj.select();
  4435. }
  4436. },
  4437. addTitleEditBoxRemove:function(){
  4438. var odiv = document.querySelector("#titleEdit");
  4439. if(odiv){
  4440. odiv.parentNode.innerHTML = odiv.value?odiv.value:"空";
  4441. }
  4442. },
  4443.  
  4444. // 高级菜单,配置文件编辑界面
  4445. editCodeBox: function(){
  4446. console.log("原始数据: ",getSettingData);
  4447. var userSetting = GM_getValue("searchEngineJumpData")
  4448. var editbox = document.createElement("div");
  4449. // var sData =
  4450. editbox.id = "iqxin-editCodeBox";
  4451. editbox.style.cssText = "position:fixed;" +
  4452. "top:50%;left:50%;" +
  4453. "transform:translate(-50%,-50%);" +
  4454. "background:#ccc;" +
  4455. "border-radius:4px;" +
  4456. "padding:10px 20px;" ;
  4457. var innerH = " "+
  4458. "<p><span style='color:red;font-size:1.2em;'>! ! !</span></br>"+
  4459. "此处有更多的设置选项,自由度更高,</br>"+
  4460. "但设置错误会导致脚本无法运行"+
  4461. "</p>" +
  4462. "<textarea wrap='off' cols='45' rows='20' style='overflow:auto;border-radius:4px;'>" + JSON.stringify(userSetting,false,4) + "</textarea>" +
  4463. "<br>" +
  4464. "<button id='xin-reset'>清空设置</button> &nbsp;&nbsp;&nbsp;" +
  4465. "<button id='xin-copyCode'>复制</button> &nbsp;&nbsp;&nbsp;" +
  4466. "<button id='codeboxclose' class='iqxin-closeBtn'>关闭</button> &nbsp;&nbsp;&nbsp;" +
  4467. "<button id='xin-codeboxsave' class='iqxin-enterBtn'>保存</button>" +
  4468. "<button id='xin-fulibtn' class='iqxin-fuliBtn'>福利</button>" +
  4469. "";
  4470. // console.log(JSON.stringify(getSettingData,4));
  4471. // console.log(JSON.stringify(getSettingData,null,4));
  4472. editbox.innerHTML = innerH;
  4473. this.ele.appendChild(editbox);
  4474. },
  4475. editCodeBoxSave: function(){
  4476. var codevalue = document.querySelector("#iqxin-editCodeBox textarea").value;
  4477. if(codevalue){
  4478. // console.log(JSON.parse(codevalue));
  4479. GM_setValue("searchEngineJumpData",JSON.parse(codevalue));
  4480. // console.log(GM_getValue("searchEngineJumpData"));
  4481. // 刷新页面
  4482. setTimeout(function(){
  4483. window.location.reload();
  4484. },300);
  4485. } else {
  4486. // alert("输入为空");
  4487. this.reset();
  4488. }
  4489. },
  4490. editCodeBoxClose: function(){
  4491. var box = document.querySelector("#iqxin-editCodeBox");
  4492. if(box){
  4493. box.parentNode.removeChild(box);
  4494. }
  4495. },
  4496.  
  4497. // 导入窗口
  4498. addImportingBox: function(){
  4499. var odiv = document.querySelector("#importingBox");
  4500. if (odiv){
  4501. this.boxClose("#importingBox");
  4502. return;
  4503. }
  4504. var newDiv = document.createElement("div");
  4505. newDiv.id= "importingBox";
  4506.  
  4507. var a ="<p>更加细分的搜索列表, 列表之间会有所重合</p>" +
  4508. "<ul>";
  4509.  
  4510. for(let i=0;i<engineList_plus.length;i++){
  4511. // if(engineList_plus.status!=3){continue};
  4512. console.log(engineList_plus[i]);
  4513.  
  4514. // 包含网站名称
  4515. var includeWeb = "";
  4516. for(let j=0; j<engineList_plus[i].engineList.length;j++){
  4517. if(j!=0){
  4518. includeWeb += " | " + engineList_plus[i].engineList[j].name;
  4519. } else{
  4520. includeWeb += engineList_plus[i].engineList[j].name;
  4521. }
  4522. }
  4523.  
  4524. a += "<li>"+
  4525. "<span class='xin-importing-item' xin-importing-id='" + i +"' title='"+ (engineList_plus[i].message?engineList_plus[i].message:engineList_plus[i].engineDetails[0]) +"'>"+ (engineList_plus[i].name?engineList_plus[i].name:engineList_plus[i].engineDetails[0]) + " : </span>" +
  4526. "<p title='"+ includeWeb +"'>"+ includeWeb +"</p>"
  4527. "</li>";
  4528. }
  4529.  
  4530. a += "</ul>";
  4531.  
  4532. newDiv.innerHTML=a;
  4533.  
  4534. this.ele.appendChild(newDiv);
  4535. },
  4536. addImportingEnger:function(e){
  4537. // console.log(e);
  4538. // console.log("第几个: ",e.target.getAttribute("xin-importing-id"));
  4539. var engineListID = e.target.getAttribute("xin-importing-id");
  4540. var engineList_temp = engineList_plus[engineListID];
  4541. var elist = engineList_temp.engineList;
  4542.  
  4543. var name = engineList_temp.engineDetails[0];
  4544. var innerName = engineList_temp.engineDetails[1];
  4545.  
  4546. var odiv = document.createElement("div");
  4547. odiv.id = innerName;
  4548. odiv.className = "iqxin-items";
  4549. var innerHTML = "" +
  4550. '<div class="sejtitle" data-iqxintitle="' + innerName + '" data-xin="99">' +
  4551. '<span class="iqxin-pointer-events">'+ name +'</span>' +
  4552. '<span class="iqxin-title-edit" title="编辑 Edit">' +
  4553. '<img class="sej-engine-icon" src="' + icon.edit + '">' +
  4554. '</span> ' +
  4555. '<span class="iqxin-set-title-del iqxin-set-active" title="删除 Delete">' +
  4556. '<img class="sej-engine-icon" src="' + icon.del + '">' +
  4557. '</span>' +
  4558. '</div>' +
  4559. '<div class="sejcon">' +
  4560. "";
  4561.  
  4562. // 具体列表
  4563. for(let i=0;i<elist.length;i++){
  4564. var a = '<span draggable="true" class="drag">' +
  4565. '<span class="sej-engine"' +
  4566. ' data-iqxinimg="$img$" ' +
  4567. ' data-iqxintitle="$title$" ' +
  4568. ' data-iqxinlink="$link$" ' +
  4569. ' data-iqxintarget="$blank$" ' +
  4570. '><img src="$favicon$" class="sej-engine-icon" />$name$</span>' +
  4571. '<span class="iqxin-set-edit" title="编辑 Edit">' +
  4572. '<img class="sej-engine-icon" src="' + icon.edit + '">' +
  4573. '</span> ' +
  4574. '<span class="iqxin-set-del iqxin-set-active" title="删除 Delete">' +
  4575. '<img class="sej-engine-icon" src="' + icon.del + '">' +
  4576. '</span>' +
  4577. '</span>';
  4578.  
  4579. a = a.replace("$img$", elist[i].favicon)
  4580. .replace("$title$", elist[i].name)
  4581. .replace("$link$", elist[i].url);
  4582.  
  4583. if (elist[i].blank){
  4584. a = a.replace('$blank$', "_blank");
  4585. } else {
  4586. a = a.replace('data-iqxintarget="$blank$"', '');
  4587. };
  4588.  
  4589. a = a.replace('$name$', elist[i].name)
  4590. .replace('$favicon$', elist[i].favicon);
  4591.  
  4592. innerHTML += a;
  4593. }
  4594.  
  4595. innerHTML += "" +
  4596. '<span class="iqxin-additem iqxin-set-active">+</span>' +
  4597. '</div>' +
  4598. "";
  4599.  
  4600.  
  4601. odiv.innerHTML = innerHTML;
  4602.  
  4603. this.addItemBoxRemove("#importingBox");
  4604.  
  4605. var btnEle = document.querySelector("#btnEle");
  4606. btnEle.parentNode.insertBefore(odiv,btnEle);
  4607. },
  4608. // 添加福利搜索 与上面的函数大量重复,可提出一个共用函数
  4609. addImportingFuLiEnger:function(e){
  4610. // console.log(e);
  4611. // console.log("第几个: ",e.target.getAttribute("xin-importing-id"));
  4612. // var engineListID = e.target.getAttribute("xin-importing-id");
  4613. // var engineList_temp = engineList_plus[engineListID];
  4614. var elist = engineList_fuli[0].engineList;
  4615.  
  4616. var name = engineList_fuli[0].engineDetails[0];
  4617. var innerName = engineList_fuli[0].engineDetails[1];
  4618.  
  4619. var odiv = document.createElement("div");
  4620. odiv.id = innerName;
  4621. odiv.className = "iqxin-items";
  4622. var innerHTML = "" +
  4623. '<div class="sejtitle" data-iqxintitle="' + innerName + '" data-xin="99">' +
  4624. '<span class="iqxin-pointer-events">'+ name +'</span>' +
  4625. '<span class="iqxin-title-edit" title="编辑 Edit">' +
  4626. '<img class="sej-engine-icon" src="' + icon.edit + '">' +
  4627. '</span> ' +
  4628. '<span class="iqxin-set-title-del iqxin-set-active" title="删除 Delete">' +
  4629. '<img class="sej-engine-icon" src="' + icon.del + '">' +
  4630. '</span>' +
  4631. '</div>' +
  4632. '<div class="sejcon">' +
  4633. "";
  4634.  
  4635. // 具体列表
  4636. for(let i=0;i<elist.length;i++){
  4637. var a = '<span draggable="true" class="drag">' +
  4638. '<span class="sej-engine"' +
  4639. ' data-iqxinimg="$img$" ' +
  4640. ' data-iqxintitle="$title$" ' +
  4641. ' data-iqxinlink="$link$" ' +
  4642. ' data-iqxintarget="$blank$" ' +
  4643. '><img src="$favicon$" class="sej-engine-icon" />$name$</span>' +
  4644. '<span class="iqxin-set-edit" title="编辑 Edit">' +
  4645. '<img class="sej-engine-icon" src="' + icon.edit + '">' +
  4646. '</span> ' +
  4647. '<span class="iqxin-set-del iqxin-set-active" title="删除 Delete">' +
  4648. '<img class="sej-engine-icon" src="' + icon.del + '">' +
  4649. '</span>' +
  4650. '</span>';
  4651.  
  4652. a = a.replace("$img$", elist[i].favicon)
  4653. .replace("$title$", elist[i].name)
  4654. .replace("$link$", elist[i].url);
  4655.  
  4656. if (elist[i].blank){
  4657. a = a.replace('$blank$', "_blank");
  4658. } else {
  4659. a = a.replace('data-iqxintarget="$blank$"', '');
  4660. };
  4661.  
  4662. a = a.replace('$name$', elist[i].name)
  4663. .replace('$favicon$', elist[i].favicon);
  4664.  
  4665. innerHTML += a;
  4666. }
  4667.  
  4668. innerHTML += "" +
  4669. '<span class="iqxin-additem iqxin-set-active">+</span>' +
  4670. '</div>' +
  4671. "";
  4672.  
  4673. odiv.innerHTML = innerHTML;
  4674.  
  4675. var btnEle = document.querySelector("#btnEle");
  4676. btnEle.parentNode.insertBefore(odiv,btnEle);
  4677. },
  4678.  
  4679. // “设置按钮” 透明度
  4680. setBtnOpacityFun: function(){
  4681. if(~window.navigator.userAgent.indexOf("Chrome")){
  4682. var odom = document.querySelector("#setBtnOpacityRange");
  4683. var odomV = odom.value;
  4684. // odom.style.backgroundSize = odom.value*100 +"% 100%";
  4685. console.log(odomV,getSettingData.setBtnOpacity);
  4686. if(getSettingData.setBtnOpacity<0){
  4687. document.querySelector(".iqxin-setBtnOpacityRangeValue").innerHTML = odomV;
  4688. odom.style.background = "-webkit-linear-gradient(left,#3ABDC1,#83e7ea) no-repeat, #fff";
  4689. }else{
  4690. document.querySelector(".iqxin-setBtnOpacityRangeValue").innerHTML = "禁用";
  4691. odom.style.background = "-webkit-linear-gradient(left,#bdbdbd,#c6c7c7) no-repeat, #fff";
  4692. }
  4693. odom.style.backgroundSize = odom.value*100 +"% 100%";
  4694.  
  4695. getSettingData.setBtnOpacity = -getSettingData.setBtnOpacity;
  4696. } else {
  4697. // console.log("非chrome");
  4698. iqxinShowTip("抱歉,目前只支持chrome类浏览器",2500);
  4699. }
  4700. },
  4701.  
  4702. // 标题点击 (开关搜索列表)(可以并入到下面的点击事件)
  4703. titleClick: function(e){
  4704. var target = e.target;
  4705. target.dataset.xin = -parseInt(target.dataset.xin);
  4706. target.dataset.xin>0 ? iqxinShowTip("启用") : iqxinShowTip("禁用");
  4707. },
  4708. // 点击事件 此处的 if 需要根据实际情况替换成 elseif (switch)
  4709. domClick: function(e){
  4710. var targetClass = e.target.className;
  4711. var targetid = e.target.id;
  4712. debug("点击事件:%o, ID: %o, class: %o, e: %o",e.target,targetid,targetClass,e)
  4713.  
  4714. // 删除搜索
  4715. if(~e.target.className.indexOf("iqxin-set-del")){
  4716. // console.log(e.target);
  4717. e.target.parentNode.parentNode.removeChild(e.target.parentNode);
  4718. };
  4719. // 删除搜索列表
  4720. if(~e.target.className.indexOf("iqxin-set-title-del")){
  4721. // console.log(e.target, e.target.parentNode.parentNode);
  4722. e.target.parentNode.parentNode.parentNode.removeChild(e.target.parentNode.parentNode);
  4723. };
  4724.  
  4725. if(~e.target.className.indexOf("iqxin-additem")){
  4726. this.parentNode = e.target.parentNode;
  4727. this.addItemBox();
  4728. };
  4729. if(e.target.className==="sej-engine"){
  4730. e.target.dataset.iqxindisabled = e.target.dataset.iqxindisabled ? "": "true";
  4731. e.target.dataset.iqxindisabled ? iqxinShowTip("禁用") : iqxinShowTip("启用");
  4732. };
  4733. if(~targetClass.indexOf("addItemBoxCancel")){
  4734. this.addItemBoxRemove();
  4735. };
  4736. // 添加新的搜索 确定
  4737. if(~targetClass.indexOf("addItemBoxEnter")){
  4738. this.addItemEnger();
  4739. };
  4740. // 添加新的搜索列表 确定
  4741. if(targetid === "nSearchList"){
  4742. debug("添加新的搜索列表");
  4743. this.addSearchListBox();
  4744. };
  4745. if(targetid === "addSearchListBoxEnter"){
  4746. debug("向网页添加元素");
  4747. this.addSearchListEnger();
  4748. };
  4749. if(targetid === "addSearchListBoxCancel"){
  4750. debug("移除盒子");
  4751. // this.boxClose("#newSearchListBox");
  4752. this.addItemBoxRemove("#newSearchListBox");
  4753. };
  4754.  
  4755. // 修改搜索 确定
  4756. if(~targetClass.indexOf("editItemBoxEnter")){
  4757. this.addEditBoxEnger();
  4758. };
  4759.  
  4760. // 编辑框
  4761. if(~e.target.className.indexOf("iqxin-set-edit")){
  4762. this.addEditBox(e);
  4763. }
  4764. // 标题编辑框
  4765. if(~targetClass.indexOf("iqxin-title-edit")){
  4766. e.stopPropagation();
  4767. this.addTitleEditBox(e);
  4768. }
  4769. if(~targetClass.indexOf("sejtitle")){
  4770. this.titleClick(e);
  4771. }
  4772. // codebox 源代码编辑框
  4773. if(targetid ==="codeboxclose"){
  4774. this.editCodeBoxClose();
  4775. } else if(targetid==="xin-reset"){
  4776. this.reset();
  4777. } else if( targetid === "xin-codeboxsave"){
  4778. this.editCodeBoxSave();
  4779. } else if( targetid === "xin-fulibtn"){
  4780. this.addImportingFuLiEnger();
  4781. } else if( targetid === "xin-copyCode"){
  4782. GM_setClipboard(JSON.stringify(getSettingData,false,4));
  4783. iqxinShowTip("复制成功");
  4784. }
  4785.  
  4786. // 点击更多菜单
  4787. if(targetid ==="moreSet"){
  4788. document.querySelector("#btnEle2").classList.toggle("btnEle2active");
  4789. // iqxin-btn-active
  4790. e.target.classList.toggle("iqxin-btn-active");
  4791. }
  4792.  
  4793. // 点击导入菜单
  4794. if(targetid ==="xin-importing"){
  4795. this.addImportingBox();
  4796. }
  4797. if(targetClass ==="xin-importing-item"){
  4798. this.addImportingEnger(e);
  4799. }
  4800.  
  4801. // 关闭"设置菜单按钮"
  4802. if(targetClass === "iqxin-setBtnOpacityRangeValue"){
  4803. this.setBtnOpacityFun();
  4804. }
  4805.  
  4806. // 关闭设置菜单
  4807. if (targetid === "xin-close"){
  4808. this.hide();
  4809. }
  4810.  
  4811. // 空白地方点击
  4812. if(~targetClass.indexOf("iqxin-items") || targetid === "settingLayer" || targetClass==="btnEleLayer"){
  4813. this.allBoxClose();
  4814. }
  4815. },
  4816.  
  4817. // 关闭所有次级窗口、菜单
  4818. allBoxClose: function(){
  4819. this.addItemBoxRemove(); // 新的搜索添加框
  4820. this.addDelremove(); // 增加/删除界面
  4821. this.editCodeBoxClose(); // code编辑框
  4822. this.addTitleEditBoxRemove(); //标题编辑框
  4823. this.addItemBoxRemove("#newSearchListBox"); // 添加新的搜索列表
  4824. this.boxClose("#iqxin-sortBox"); // 搜索列表排序
  4825. this.addItemBoxRemove("#importingBox"); //导入框
  4826. document.querySelector("#btnEle2").classList.remove("btnEle2active"); // 更多设置
  4827. },
  4828.  
  4829. // 窗口位置拖动
  4830. setDragNode: function(ele) {
  4831. var node = document.querySelector("#dragDom");
  4832.  
  4833. node.addEventListener("mousedown",function(event){
  4834. ele.style.transition = "null";
  4835. // offsetLeft 距离 body 的位置, 得到的 dis 即鼠标到窗口左上角的位置
  4836. var disX = event.clientX - ele.offsetLeft;
  4837. var disY = event.clientY - ele.offsetTop;
  4838.  
  4839. var move = function(event) {
  4840. //鼠标的位置减去到左上角的位置 即窗口的位置
  4841. // console.log(event.clientX - disX,event.clientY - disY)
  4842. ele.style.left = event.clientX - disX + "px";
  4843. ele.style.top = event.clientY - disY + "px";
  4844. };
  4845.  
  4846. document.addEventListener("mousemove",move);
  4847. document.addEventListener("mouseup",function(){
  4848. ele.style.transition = "0.5s";
  4849. document.removeEventListener("mousemove",move);
  4850. })
  4851. });
  4852. },
  4853.  
  4854. // 拖动
  4855. domdragstart:function (e) {
  4856. if(~this.className.indexOf("sejtitle")){
  4857. dragEl = this.parentNode;
  4858. } else{
  4859. dragEl = this;
  4860. }
  4861. dragData = dragEl.innerHTML;
  4862. e.dataTransfer.effectAllowed = "move";
  4863. e.dataTransfer.setData("text/html",dragEl.innerHTML);
  4864. },
  4865. domdragenter:function (e) {
  4866. var target = e.target;
  4867. var targetClass = target.className;
  4868. if(~targetClass.indexOf("sejtitle")){
  4869. target = target.parentNode;
  4870. }
  4871. target.classList.add('drop-over');
  4872. },
  4873. domdragover:function (e) {
  4874. if (e.preventDefault) {
  4875. e.preventDefault();
  4876. }
  4877. e.dataTransfer.dropEffect = 'move';
  4878. return false;
  4879. },
  4880. domdragleave:function (e) {
  4881. var target = e.target;
  4882. var targetClass = target.className;
  4883. if(~targetClass.indexOf("sejtitle")){
  4884. target = target.parentNode;
  4885. }
  4886. target.classList.remove('drop-over');
  4887. },
  4888. domdrop:function (e) {
  4889. debug("拖拽结束")
  4890. // e.target === this
  4891. var _this = e.target;
  4892. var that = _this.parentNode;
  4893. var pparentNode = that.parentNode;
  4894.  
  4895. // 防止跨区域移动
  4896. SEJsetting.prototype.domdropend();
  4897. if(dragEl.className != that.className){
  4898. console.log("移动对象 之前,现在: ", dragEl.className);
  4899. console.log(that.className);
  4900. return;
  4901. }
  4902.  
  4903. // Sortable.js https://github.com/RubaXa/Sortable
  4904. var targetRect = _this.getBoundingClientRect(); //
  4905. var width = targetRect.right - targetRect.left; //目标节点的宽
  4906. var height = targetRect.bottom - targetRect.top; //目标节点的高
  4907. var domPosition = null;
  4908. if(~_this.className.indexOf("sejtitle")){
  4909. debug(e.clientX,targetRect.left,height,e.clientX - targetRect.left,(e.clientX - targetRect.left) / height)
  4910. if((e.clientX - targetRect.left) / width > 0.5){
  4911. debug("右");
  4912. domPosition = true;
  4913. }else{
  4914. debug("左");
  4915. domPosition = false;
  4916. }
  4917. } else {
  4918. if((e.clientY - targetRect.top) / height > 0.5){
  4919. debug("下");
  4920. domPosition = true;
  4921. }else{
  4922. debug("上");
  4923. domPosition = false;
  4924. }
  4925. }
  4926.  
  4927. dragEl.style.transformOrigin = "top center";
  4928. dragEl.style.animation = "sejopen 0.3s";
  4929.  
  4930. if(domPosition){
  4931. if(pparentNode.lastChild == that){
  4932. pparentNode.insertBefore(dragEl,that);
  4933. }else{
  4934. pparentNode.insertBefore(dragEl,that.nextElementSibling)
  4935. }
  4936. }else{
  4937. that.parentNode.insertBefore(dragEl,that);
  4938. }
  4939.  
  4940. // 重新绑定拖拽事件
  4941. SEJsetting.prototype.dragEvent();
  4942. return false;
  4943. },
  4944. domdropend:function(){
  4945. var dom = document.querySelector(".drop-over");
  4946. if(dom){
  4947. dom.classList.remove("drop-over")
  4948. }
  4949. },
  4950.  
  4951. // 判断是否能连接至google
  4952. isOnline: function(){
  4953. console.log("this.online",this.online);
  4954. if(this.online)return;
  4955.  
  4956. var that = this;
  4957. var myImage = new Image;
  4958. myImage.src = 'https://www.google.com/s2/favicons?domain=www.baidu.com&' + Math.random() ;
  4959. setTimeout(function(){
  4960. // console.log("取消加载");
  4961. console.log(myImage.width);
  4962. if(myImage.width){
  4963. that.online = true;
  4964. }else{
  4965. myImage.src = undefined;
  4966. };
  4967. },2000);
  4968. },
  4969.  
  4970. // 重新加载工具
  4971. reloadSet: function(){
  4972. var elems = document.querySelectorAll('#sej-container, #settingLayerMask, sejspan.sej-drop-list');
  4973. if (!elems) return;
  4974. console.log("elems: " + elems);
  4975. // return;
  4976.  
  4977. [].forEach.call(elems, function(elem) {
  4978. elem.parentNode.removeChild(elem);
  4979. });
  4980.  
  4981. iqxinstart();
  4982. iqxinShowTip("保存成功");
  4983. },
  4984.  
  4985. // 设置按钮透明度设置
  4986. rangeChange: function(bool){
  4987. var odom = document.querySelector("#setBtnOpacityRange");
  4988. if(getSettingData.setBtnOpacity<0){
  4989. odom.style.background = "-webkit-linear-gradient(left,#bdbdbd,#c6c7c7) no-repeat, #fff";
  4990. odom.style.backgroundSize = odom.value*100 +"% 100%";
  4991. document.querySelector(".iqxin-setBtnOpacityRangeValue").innerHTML = "禁用";
  4992. getSettingData.setBtnOpacity = -odom.value;
  4993. } else{
  4994. odom.style.background = "-webkit-linear-gradient(left,#3ABDC1,#83e7ea) no-repeat, #fff";
  4995. odom.style.backgroundSize = odom.value*100 +"% 100%";
  4996. document.querySelector(".iqxin-setBtnOpacityRangeValue").innerHTML = odom.value;
  4997. getSettingData.setBtnOpacity = odom.value;
  4998. }
  4999. },
  5000.  
  5001. // 窗口大小改变
  5002. windowResize: function(){
  5003. var eleStyle = window.getComputedStyle(this.ele , null);
  5004. var w = parseInt(eleStyle.width) ;
  5005. var h = parseInt(eleStyle.height) + 54;
  5006. var ww = document.documentElement.clientWidth;
  5007. var wh = document.documentElement.clientHeight;
  5008. var maskStyle = this.mask.style;
  5009.  
  5010. if(w>=ww){
  5011. maskStyle.justifyContent = "stretch";
  5012. }else{
  5013. maskStyle.justifyContent = "center";
  5014. }
  5015. if(h>=wh){
  5016. maskStyle.alignItems = "stretch";
  5017. }else{
  5018. maskStyle.alignItems = "center";
  5019. }
  5020. },
  5021. saveData: function(){
  5022. //
  5023. this.addTitleEditBoxRemove(); //标题栏处于编辑状态
  5024.  
  5025. var obj = {};
  5026. var parentdiv = document.querySelectorAll("#settingLayer .iqxin-items");
  5027. for (let i=0;i<parentdiv.length;i++){
  5028. var data = parentdiv[i].querySelectorAll(".sej-engine");
  5029. var id = parentdiv[i].id;
  5030. obj[id]=[];
  5031. for(let ii=0;ii<data.length;ii++){
  5032. if (data[ii].dataset.xin<0){
  5033. var ij = -ii;
  5034. } else {
  5035. ij = ii;
  5036. }
  5037. obj[id][ij]={};
  5038. obj[id][ij].favicon=data[ii].dataset.iqxinimg;
  5039. obj[id][ij].name=data[ii].dataset.iqxintitle;
  5040. obj[id][ij].url=data[ii].dataset.iqxinlink;
  5041. if(data[ii].dataset.iqxintarget){
  5042. obj[id][ij].blank=data[ii].dataset.iqxintarget;
  5043. };
  5044. if(data[ii].dataset.iqxindisabled){
  5045. obj[id][ij].disable=data[ii].dataset.iqxindisabled;
  5046. };
  5047. if(data[ii].dataset.iqxingbk){
  5048. obj[id][ij].gbk=data[ii].dataset.iqxingbk;
  5049. };
  5050. }
  5051. }
  5052.  
  5053. // 分类名称
  5054. var engineDetails=[];
  5055.  
  5056. // 分类排序
  5057. var odetails = document.querySelectorAll(".sejtitle");
  5058. var odetailsLength = odetails.length;
  5059. for(let i=0;i<odetailsLength;i++){
  5060. debug(odetails[i]);
  5061. engineDetails[i] = [];
  5062. engineDetails[i][0] = odetails[i].firstChild.innerHTML;
  5063. engineDetails[i][1] = odetails[i].dataset.iqxintitle;
  5064. engineDetails[i][2] = odetails[i].dataset.xin>=0?true:false;
  5065. }
  5066.  
  5067. // 新标签页全局设置
  5068. var onewtab = document.querySelector("#iqxin-globalNewtab").selectedIndex;
  5069. var foldlist = document.querySelector("#iqxin-foldlist").checked;
  5070.  
  5071. // 以防不测,重新获取本地配置文件
  5072. var getData = GM_getValue("searchEngineJumpData");
  5073. getData.newtab = onewtab;
  5074. getData.foldlist = foldlist;
  5075. getData.setBtnOpacity = getSettingData.setBtnOpacity;
  5076. // getData.debug = document.querySelector("#iqxin-debug").checked;
  5077. getData.center = document.querySelector("#iqxin-center").selectedIndex;
  5078. getData.fixedTop = document.querySelector("#iqxin-fixedTop").checked;
  5079. getData.allOpen = document.querySelector("#iqxin-allOpen-item").checked;
  5080. getData.fixedTopUpward = document.querySelector("#iqxin-fixedTopUpward-item").checked;
  5081. getData.transtion = document.querySelector("#iqxin-transtion").checked;
  5082. getData.HideTheSameLink = document.querySelector("#iqxin-HideTheSameLink").checked;
  5083. getData.engineDetails = engineDetails;
  5084. getData.engineList = obj;
  5085.  
  5086. debug('将要保存的数据:',getData);
  5087. GM_setValue("searchEngineJumpData",getData);
  5088. },
  5089. addGlobalStyle: function(){
  5090. var head, style;
  5091. var css =
  5092. "#settingLayerMask{" +
  5093. "display: none;" +
  5094. "justify-content: center;" +
  5095. "align-items: center;" +
  5096. "position: fixed;" +
  5097. "top:0; right:0; bottom:0; left:0;" +
  5098. "background-color: rgba(0,0,0,.3);" +
  5099. "backdrop-filter: blur(10px);" +
  5100. "z-index: 200000000;" +
  5101. "overflow: auto;" +
  5102. "font-family: arial,sans-serif;" +
  5103. "min-height: 100%;" +
  5104. "font-size:16px;" +
  5105. "transition:0.5s;" +
  5106. "opacity:0;" +
  5107. "user-select: none;" +
  5108. "-moz-user-select: none;" +
  5109. "padding-bottom: 80px;" +
  5110. "box-sizing: border-box;" +
  5111. "}" +
  5112. "#settingLayer{" +
  5113. "display: flex;" +
  5114. "flex-wrap: wrap;" +
  5115. "padding: 20px 20px 50px 20px;" +
  5116. "margin: 2% 25px 50px 5px;" +
  5117. "background-color: #fff;" +
  5118. "border-radius: 4px;" +
  5119. "position: absolute;" +
  5120. "min-width: 700px;" +
  5121. "max-width: 94%;" +
  5122. "transition:0.5s;" +
  5123. "}" +
  5124. ".iqxin-items{" +
  5125. "min-width:5em;" +
  5126. "margin: 0 5px 0px;" +
  5127. "}" +
  5128. "#settingLayer .drag{" +
  5129. "display: block;" +
  5130. "position: relative;" +
  5131. "}" +
  5132. "#settingLayer .sej-engine{" +
  5133. "display: inline-block;" +
  5134. "width: 100%;" +
  5135. "box-sizing: border-box;" +
  5136. "}" +
  5137. ".iqxin-pointer-events," +
  5138. ".sej-engine-icon," +
  5139. "#settingLayer .sej-engine *{" +
  5140. "pointer-events:none;" +
  5141. "}" +
  5142. ".sejtitle{" +
  5143. "text-align: center;" +
  5144. "padding: 2px 0;" +
  5145. "cursor: pointer;" +
  5146. "position: relative;" +
  5147. "}" +
  5148. "#settingLayerMask [data-xin]{" +
  5149. "margin:4px 0;" +
  5150. "line-height:1.7;" +
  5151. "border-radius:4px;" +
  5152. "}" +
  5153. "#settingLayerMask .iqxin-set-edit," +
  5154. "#settingLayerMask .iqxin-set-del{" +
  5155. "border-radius:4px;" +
  5156. "line-height: 1em;" +
  5157. "}" +
  5158. ".sejtitle:not([data-xin^='-']):hover{" +
  5159. "background:#cff9ff;" +
  5160. "}" +
  5161. ".sejcon [data-xin]{"+
  5162. "cursor: pointer;" +
  5163. "}" +
  5164. "#settingLayerMask .sej-engine:hover{" +
  5165. "background-color:#cff9ff" +
  5166. "}" +
  5167. "#settingLayerMask [data-iqxindisabled='true']," +
  5168. "[data-xin^='-']{" +
  5169. "background-color: #ccc;" +
  5170. "text-decoration: line-through;" +
  5171. "text-decoration-color:red;" +
  5172. "border-radius:2px;" +
  5173. "transition:.3s;" +
  5174. "}" +
  5175. "#settingLayerMask [data-iqxindisabled='true']:hover," +
  5176. "[data-xin^='-']:hover{" +
  5177. "background-color: #ffa2a2;" +
  5178. "}" +
  5179. "#settingLayerMask label{" +
  5180. "cursor:pointer;" +
  5181. "}" +
  5182. "#settingLayerMask .sej-engine-icon{" +
  5183. "vertical-align:middle;" +
  5184. "}" +
  5185. "#btnEle2," +
  5186. "#btnEle{" +
  5187. "position:absolute;" +
  5188. "width:100%;" +
  5189. "bottom: 0px;" +
  5190. "right: 0;" +
  5191. "background: #fff;" +
  5192. "border-radius: 4px;" +
  5193. "}" +
  5194. "#btnEle2 span," +
  5195. "#btnEle span{" +
  5196. "display: inline-block;" +
  5197. "background: #EFF4F8;" +
  5198. "border: 1px solid #3abdc1;" +
  5199. "margin: 12px auto 10px;" +
  5200. "color: #3abdc1;" +
  5201. "padding: 5px 10px;" +
  5202. "border-radius: 4px;" +
  5203. "cursor: pointer;" +
  5204. "outline: none;" +
  5205. "transition: 0.3s;" +
  5206. "}" +
  5207. "#btnEle a{" +
  5208. "color: #999;" +
  5209. "text-decoration: none;" +
  5210. "font-family: auto;" +
  5211. "}" +
  5212. "#btnEle a:hover{" +
  5213. "text-decoration: underline;" +
  5214. "color: #ef8957;" +
  5215. "}" +
  5216. "#btnEle2 span.feedback:hover," +
  5217. "#btnEle span.feedback:hover{" +
  5218. "border-color:#ef8957;" +
  5219. "}" +
  5220. "#btnEle2 span:not(.feedback):hover," +
  5221. "#btnEle span:not(.feedback):hover{" +
  5222. "background:#3ACBDD;" +
  5223. "color:#fff;" +
  5224. "}" +
  5225. "#btnEle .feedback{" +
  5226. "border-color: #aaa;" +
  5227. "}" +
  5228. "#btnEle2>div," +
  5229. "#btnEle>div{" +
  5230. "width: 100%;" +
  5231. "display:flex;" +
  5232. "justify-content: space-around;" +
  5233. "background: #EFF4F8;" +
  5234. "border-radius: 4px;" +
  5235. "}" +
  5236. "#btnEle2{" +
  5237. "visibility:hidden;" +
  5238. "opacity:0;" +
  5239. "transform:translate(0,40px);" +
  5240. "transition : 0.3s;" +
  5241. "}" +
  5242. "#btnEle2.btnEle2active{" +
  5243. "visibility:visible;" +
  5244. "opacity:1;" +
  5245. // "transform:translate(0,108px);" // 两行的情况下
  5246. "transform:translate(0,53px);" +
  5247. "}" +
  5248. "#settingLayerMask input[type=checkbox]{" +
  5249. "width: 12px;" +
  5250. "height: 12px;" +
  5251. "display: inline-block;" +
  5252. "text-align: center;" +
  5253. "vertical-align: middle;" +
  5254. "line-height: 10px!important;" +
  5255. "margin: 0 5px 5px 5px!important;" +
  5256. "position: relative;" +
  5257. "}" +
  5258. "#settingLayerMask input[type=checkbox]:before{" +
  5259. "content: '';" +
  5260. "position: absolute;" +
  5261. "top: 0;" +
  5262. "left: 0;" +
  5263. "background: #fff;" +
  5264. "width: 100%;" +
  5265. "height: 100%;" +
  5266. "border: 1px solid #d9d9d9;" +
  5267. "}" +
  5268. "#settingLayerMask input[type=checkbox]:checked:after{" +
  5269. 'content: "✔";' +
  5270. "background-color: #63d4d8;" +
  5271. "position: absolute;" +
  5272. "top: 0;" +
  5273. "left: 0;" +
  5274. "width: 12px;" +
  5275. "height: 12px;" +
  5276. "border: 1px solid #63d4d8;" +
  5277. "color: #fff;" +
  5278. "font-size: 10px;" +
  5279. "}" +
  5280. ".drop-over{" +
  5281. "opacity: 0.6;" +
  5282. "}" +
  5283. ".iqxin-title-edit," +
  5284. ".iqxin-set-edit," +
  5285. ".iqxin-set-title-del," +
  5286. ".iqxin-set-del {" +
  5287. "visibility: hidden;" +
  5288. "opacity:0;" +
  5289. "position: absolute;" +
  5290. "background: rgba(207, 249, 255, 0.86);" +
  5291. "color: red;" +
  5292. "top: 50%;" +
  5293. "transform: translate(0,-50%);" +
  5294. "right: 0;" +
  5295. "padding: 3px 3px 6px 6px;" +
  5296. "border-radius: 2px;" +
  5297. "cursor: pointer;" +
  5298. "transition: .3s;" +
  5299. "}" +
  5300. ".iqxin-set-title-del.iqxin-set-active {" +
  5301. "background: #fff;" +
  5302. "border-radius: 50% 0 0 50%;" +
  5303. "}" +
  5304. ".iqxin-title-edit{" +
  5305. "padding: 0px 3px 6px 6px;" +
  5306. "}" +
  5307. "span.iqxin-additem {" +
  5308. "display: inline-block;" +
  5309. "text-align: center;" +
  5310. "width: 100%;" +
  5311. "margin: 10px 0;" +
  5312. "border: 1px dotted red;" +
  5313. "color: red;" +
  5314. "cursor: pointer;" +
  5315. "visibility:hidden;" +
  5316. "opacity:0;" +
  5317. "transition:0.3s;" +
  5318. "transform:scale(0);" +
  5319. "}" +
  5320. "span.iqxin-additem.iqxin-set-active {" +
  5321. "visibility:visible;" +
  5322. "opacity:1;" +
  5323. "margin:10px 0;" +
  5324. "transform:scale(1);" +
  5325. "}" +
  5326. "#settingLayer .sejtitle:hover .iqxin-title-edit," +
  5327. "#settingLayer .sejcon>span:hover .iqxin-set-edit{" +
  5328. "visibility:visible;" +
  5329. "opacity:0.8;" +
  5330. "}" +
  5331. "#nSearchList.iqxin-set-active," +
  5332. ".iqxin-set-edit.iqxin-set-active," +
  5333. ".iqxin-set-title-del.iqxin-set-active," +
  5334. ".iqxin-set-del.iqxin-set-active {" +
  5335. "visibility:visible !important;" +
  5336. "opacity:1 !important;" +
  5337. "}" +
  5338. "#btnEle span.iqxin-btn-active{" +
  5339. "color:red;" +
  5340. "border-color:red;" +
  5341. "}" +
  5342. "#newSearchListBox," +
  5343. "#newSearchBox{" +
  5344. "transition:0.6s;" +
  5345. "transform : translateY(0%);" +
  5346. "opacity: 1;" +
  5347. "position:fixed;" +
  5348. "z-index:200000100;" +
  5349. "top:50%;" +
  5350. "left:50%;" +
  5351. "padding:22px;" +
  5352. "background:rgb(29, 29, 29);" +
  5353. "border-radius:4px;" +
  5354. "color: #e8e8e8;" +
  5355. "margin: -149px -117px;" +
  5356. "}" +
  5357. "#newSearchListBox input," +
  5358. "#newSearchBox input{" +
  5359. "border: none;" +
  5360. "padding: 4px 0 4px 5px;" +
  5361. "border-radius: 4px;" +
  5362. "outline: none;" +
  5363. "}" +
  5364. "#newSearchListBox input:focus," +
  5365. "#newSearchBox input:focus {" +
  5366. "background: #f1d2d2;" +
  5367. "transition: 0.5s;" +
  5368. "}" +
  5369. ".addItemBoxBtn{" +
  5370. "cursor: pointer;" +
  5371. "background: #fff;" +
  5372. "border: none;" +
  5373. "border-radius: 4px;" +
  5374. "padding: 4px 10px;" +
  5375. "color: #333;" +
  5376. "transition:0.3s;" +
  5377. "}" +
  5378. "#xin-centerDisplay select," +
  5379. "#xin-newtab select{" +
  5380. "height:auto;" +
  5381. "border: none;" +
  5382. "outline: none;" +
  5383. "color: #3ABDC1;" +
  5384. "font-size: 1em;" +
  5385. "font-family: arial,sans-serif;" +
  5386. "appearance: none;" +
  5387. "-moz-appearance: none;" +
  5388. "-webkit-appearance: none;" +
  5389. "padding: 0px 5px;" +
  5390. "cursor: pointer;" +
  5391. "text-decoration: underline;" +
  5392. "background: #EFF4F8;" +
  5393. "}" +
  5394. "#titleEdit{" +
  5395. "width:6em;" +
  5396. "}" +
  5397. // 按钮效果 : 确定 取消按钮
  5398. ".iqxin-closeBtn," +
  5399. ".iqxin-enterBtn{" +
  5400. "box-sizing: border-box;" +
  5401. "}" +
  5402. ".iqxin-closeBtn:hover{" +
  5403. "background: #ff6565;" +
  5404. "border-color: #ff6565;" +
  5405. "color: #fff;" +
  5406. "}" +
  5407. ".iqxin-enterBtn:hover{" +
  5408. "background: #84bb84;" +
  5409. "border-color: #84bb84;" +
  5410. "color: #fff;" +
  5411. "}" +
  5412. "#iqxin-editCodeBox button{" +
  5413. "cursor:pointer;" +
  5414. "}" +
  5415. ".iqxin-fuliBtn{" +
  5416. "border: none;" +
  5417. "background: none;" +
  5418. "color: #ccc;" +
  5419. "margin-left: 30px;" +
  5420. "}" +
  5421.  
  5422. // 关闭按钮
  5423. "#xin-close{" +
  5424. "background:white;" +
  5425. "color:#3ABDC1;" +
  5426. "line-height:20px;" +
  5427. "text-align:center;" +
  5428. "height:20px;" +
  5429. "width:20px;" +
  5430. "text-align:center;" +
  5431. "font-size:20px;" +
  5432. "padding:10px;" +
  5433. "border: 3px solid #3ABDC1;" +
  5434. "border-radius: 50%;" +
  5435. "transition: .5s;" +
  5436. "top: -20px;" +
  5437. "right:-20px;" +
  5438. "position: absolute;" +
  5439. "box-sizing: unset;" +
  5440. "}" +
  5441. "#xin-close::before{" +
  5442. "content:'\\2716';" +
  5443. "margin:-10px;" +
  5444. "}" +
  5445. "#xin-close:hover{" +
  5446. "background: indianred;" +
  5447. "border-color: indianred;" +
  5448. "color: #fff;" +
  5449. "}" +
  5450. // type[range] 效果
  5451. "input[type=range] {" +
  5452. "outline: none;" +
  5453. "-webkit-appearance: none;" +
  5454. "background:-webkit-linear-gradient(left,#3ABDC1,#83e7ea) no-repeat, #fff;" +
  5455. "border-radius: 10px; /*这个属性设置使填充进度条时的图形为圆角*/" +
  5456. "}" +
  5457. "input[type=range]::-webkit-slider-thumb {" +
  5458. "-webkit-appearance: none;" +
  5459. "} " +
  5460. "input[type=range]::-webkit-slider-runnable-track {" +
  5461. "height: 10px;" +
  5462. "border-radius: 10px; /*将轨道设为圆角的*/" +
  5463. "box-shadow: 0 1px 1px #def3f8, inset 0 .125em .125em #0d1112; /*轨道内置阴影效果*/" +
  5464. "}" +
  5465. "input[type=range]::-webkit-slider-thumb {" +
  5466. "-webkit-appearance: none;" +
  5467. "height: 18px;" +
  5468. "width: 18px;" +
  5469. "margin-top: -5px; /*使滑块超出轨道部分的偏移量相等*/" +
  5470. "background: #fff; " +
  5471. "border-radius: 50%; /*外观设置为圆形*/" +
  5472. "border: solid 0.125em rgba(205, 224, 230, 0.5); /*设置边框*/" +
  5473. "box-shadow: 0 .125em .125em #3b4547; /*添加底部阴影*/" +
  5474. "}" +
  5475. // 导入
  5476. "#importingBox{" +
  5477. "position:fixed;" +
  5478. "width:350px;" +
  5479. "top:50%;" +
  5480. "left:50%;" +
  5481. "transform:translate(-50%,-50%);" +
  5482. "padding: 15px 30px;" +
  5483. "border-radius: 4px;" +
  5484. "background:#1D1D1D;" +
  5485. "color:#fff;" +
  5486. "}" +
  5487. "#importingBox li{" +
  5488. "margin:5px;" +
  5489. "border-bottom:1px solid #3ACBDD;" +
  5490. "}" +
  5491. "#importingBox li p{" +
  5492. "white-space: nowrap;" +
  5493. "overflow: hidden;" +
  5494. "text-overflow: ellipsis;" +
  5495. "margin-top:0;" +
  5496. "margin-bottom:0;" +
  5497. "}" +
  5498. ".xin-importing-item{" +
  5499. "cursor:pointer;" +
  5500. "}" +
  5501. "";
  5502. head = document.getElementsByTagName('head')[0];
  5503. style = document.createElement('style');
  5504. style.type = 'text/css';
  5505. style.innerHTML = css;
  5506. head.appendChild(style);
  5507. // 关闭设置菜单中的所有动画效果
  5508. if(!getSettingData.transtion){
  5509. GM_addStyle("#settingLayer," +
  5510. "#btnEle span," +
  5511. "#btnEle2," +
  5512. ".iqxin-set-del," +
  5513. "span.iqxin-additem," +
  5514. "#newSearchBox," +
  5515. ".addItemBoxBtn," +
  5516. "#xin-close," +
  5517. "#settingLayerMask{" +
  5518. "transition:none;"+
  5519. "}"+
  5520. "#settingLayerMask{" +
  5521. "backdrop-filter:none;" +
  5522. "background-color: rgba(0,0,0,.7);" +
  5523. "}"+
  5524. "");
  5525. }
  5526. }
  5527. };
  5528.  
  5529. // 增加设置按钮
  5530. if (getSettingData.setBtnOpacity>=0){
  5531. var setBtn = document.createElement("span");
  5532. setBtn.id = "setBtn";
  5533. GM_addStyle("#setBtn{" +
  5534. "opacity:"+getSettingData.setBtnOpacity+";"+
  5535. "transition:0.5s;"+
  5536. "}"+
  5537. "#sej-container:hover span#setBtn{" +
  5538. "opacity:1;" +
  5539. "}" +
  5540. "");
  5541. setBtn.innerHTML = "<img style='margin:0 0 -3px 6px;width:16px;vertical-align: baseline;display:inline-block;cursor:pointer;' src=''>"
  5542. document.querySelector("#sej-container").appendChild(setBtn);
  5543. var sejSet = null;
  5544.  
  5545. setBtn.addEventListener("click",setBtnStart);
  5546. };
  5547.  
  5548. // 注册(不可用)菜单
  5549. GM_registerMenuCommand("search jump 搜索跳转设置",setBtnStart);
  5550.  
  5551. function setBtnStart(){
  5552. if(!document.querySelector("#settingLayerMask")){
  5553. sejSet = new SEJsetting();
  5554.  
  5555. var sej_save = document.querySelector("#xin-save");
  5556. // var sej_close = document.querySelector("#xin-close");
  5557. // var sej_reset = document.querySelector("#xin-reset");
  5558. var sej_addDel = document.querySelector("#xin-addDel");
  5559. var sej_edit = document.querySelector("#xin-modification");
  5560.  
  5561. // sej_save.addEventListener("click",function(){sejSet.saveData();sejSet.hide();if(!getSettingData.debug)window.location.reload();});
  5562. sej_save.addEventListener("click",function(){sejSet.saveData();sejSet.hide();sejSet.reloadSet();});
  5563. // sej_close.addEventListener("click",function(){sejSet.hide();});
  5564. // sej_reset.addEventListener("click",function(){sejSet.reset();sejSet.hide();window.location.reload();});
  5565. sej_addDel.addEventListener("click",function(e){sejSet.addDel(e);});
  5566. // sej_edit.addEventListener("click",function(e){sejSet.addEdit(e);});
  5567. sej_edit.addEventListener("click",function(){sejSet.editCodeBox();});
  5568.  
  5569. window.addEventListener("resize",sejSet.windowResize.bind(sejSet));
  5570. }
  5571. sejSet.show();
  5572. }
  5573.  
  5574. // 获取存储的数据信息
  5575. function get_data(){
  5576. setData = GM_getValue("searchEngineJumpData");
  5577. }
  5578. var setData = null;
  5579. // get_data();
  5580. }
  5581.  
  5582. // 从此处开始执行
  5583. var debug;
  5584. function reloadDebug(bool) {
  5585. debug = bool ? console.info.bind(console) : function() {};
  5586. }
  5587.  
  5588. // 消息提示框
  5589. // 目前只是为了给用户一个反馈。 - 成功了么 - 嗯,成功了
  5590. var iqxinTimerGlobalTip = null
  5591. function iqxinShowTip(text,duration){
  5592. console.log("iqxin -- 消息提示框: ", text);
  5593. var odom = document.querySelector("#iqixn-global-tip");
  5594. if(!odom){
  5595. odom = document.createElement("iqxinDiv");
  5596. odom.id = "iqixn-global-tip";
  5597. odom.style.cssText = "" +
  5598. "opacity: 0;" +
  5599. "height: 25px;" +
  5600. "line-height: 25px;" +
  5601. "letter-spacing: 1px;" +
  5602. "font-size: 1em;" +
  5603. "color: #fff;" +
  5604. "padding: 5px 20px;" +
  5605. "border-radius: 5px;" +
  5606. "background-color: #666;" +
  5607. "position: fixed;" +
  5608. "z-index: 200000001;" +
  5609. "left: 50%;" +
  5610. "bottom: 5%;" +
  5611. "transform: translate(-50%);" +
  5612. "transition: .4s;" ;
  5613. document.body.appendChild(odom);
  5614. }
  5615.  
  5616. odom.innerHTML=text;
  5617. odom.style.opacity=1;
  5618.  
  5619. duration = duration?duration:1500;
  5620. //防止持续时间内多次触发提示
  5621. if(!iqxinTimerGlobalTip){
  5622. iqxinTimerGlobalTip = setTimeout(function(){
  5623. odom.style.opacity=0;
  5624. iqxinTimerGlobalTip = null;
  5625. },duration);
  5626. }
  5627. }
  5628.  
  5629. // hash-query 不刷新页面的搜索
  5630. // hashchange 和 popstate 都无法检测到谷歌和百度搜索时网址的变化,不理解
  5631. if (window.self != window.top) return;
  5632. // 下面这种方法百度一直报错无法使用,遂用定时器
  5633. // 2022-07-31 能用。 可以解决百度页面不刷新,直接显示搜索结果导致样式丢失的问题
  5634. if (true) {
  5635. console.log('iqxin添加标题节点监视器: title');
  5636.  
  5637. var watch = document.querySelector('title');
  5638. // console.log("titile: ",watch);
  5639. // console.log("titile: ",document.title);
  5640. new (window.MutationObserver || window.WebKitMutationObserver)(function(mutations){
  5641. console.log('iqxin标题发生了变化', document.title);
  5642. var sejSpan = document.querySelector('sejspan')
  5643. if(!sejSpan){
  5644. iqxinstart();
  5645. }else{
  5646. sejSpan.parentNode.removeChild (sejSpan);
  5647. iqxinstart();
  5648. }
  5649. }).observe(watch, {childList: true, subtree: true, characterData: true});
  5650. }
  5651. // 给谷歌和百度搜索的主页单独加个列表
  5652. var url = window.location.href;
  5653. var hashList = [
  5654. /^https?:\/\/www\.baidu\.com\/$/i,
  5655. /^https?:\/\/www\.google(?:\.[A-z]{2,3}){1,2}\/$/i,
  5656. /^https?:\/\/www\.google(?:\.[A-z]{2,3}){1,2}\/[^#]*#(?:&?q=|.+?&q=).+/,
  5657. /^https?:\/\/www\.youtube\.com\/results/,
  5658. // /^https?:\/\/searx\.me\//i,
  5659. ];
  5660. // 部分网站或内因或外因的原因加载缓慢,所以推迟插入
  5661. var delayList = [
  5662. /^https?:\/\/google\.infinitynewtab\.com\/\?q/,
  5663. /^https?:\/\/www\.zhihu\.com\/search\?/,
  5664. /^https?:\/\/www\.iciba\.com\/word\?/,
  5665. /^https?:\/\/neeva\.com\/search\?/i,
  5666. ]
  5667.  
  5668. var hashListTag = hashList.some(function hashUrl(element, index, array){
  5669. return ~url.search(element);
  5670. });
  5671. var delayListTag = delayList.some(function hashUrl(element, index, array){
  5672. return ~url.search(element);
  5673. });
  5674.  
  5675. if (hashListTag){
  5676. var oldTitle = document.title;
  5677. var newTitle = "";
  5678. var timer = setInterval(function(){
  5679. // console.log("循环中",newTitle,oldTitle);
  5680. newTitle = document.title;
  5681. if (document.querySelector("#appbar") && !document.querySelector("sejspan")){
  5682. // console.log("new");
  5683. iqxinstart();
  5684. } else if (document.querySelector("sejspan")){
  5685. // console.log("已存在");
  5686. clearInterval(timer);
  5687. }else if (oldTitle!=newTitle){
  5688. // console.log("不存在开始插入");
  5689. iqxinstart();
  5690. }
  5691. },1000)
  5692. } else if (delayListTag){
  5693. setTimeout(function(){
  5694. // console.log("延时运行");
  5695. var sejSpan = document.querySelector('sejspan');
  5696. if(sejSpan){
  5697. return;
  5698. } else{
  5699. iqxinstart();
  5700. }
  5701. },2000);
  5702. } else {
  5703. // console.log("普通插入");
  5704. iqxinstart();
  5705. }
  5706.  
  5707. })();
  5708.  

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址