// ==UserScript== // @name 多重搜索|联合搜索|聚合搜索|搜索跳转|搜索切换|搜索引擎增强工具|searchEngineJump|MultipleSearch // @author omoristation // @contributor omoristation // @description 方便的在各个搜索引擎之间跳转,增加可视化设置菜单,能更友好的自定义设置,做到最大兼容性 // @version 0.0.1 // @license MIT // @namespace https://greasyfork.org/zh-CN/scripts/ // @homepage https://github.com/omoristation/searchEngineJump // @icon  // @include *github.io* // @include *google.com* // @include *baidu.com* // @include *bing.com* // @include *sogou.com* // @include *so.com* // @include *yahoo.com* // @include *duckduckgo.com* // @include *yandex.com* // @include *ask.com* // @include *aol.com* // @match *://*/* // @grant GM_getValue // @grant GM_setValue // @grant GM_addStyle // @grant GM_deleteValue // @grant GM_setClipboard // @grant GM_registerMenuCommand // @run-at document-end // @downloadURL https://update.greasyfork.icu/scripts/530550/%E5%A4%9A%E9%87%8D%E6%90%9C%E7%B4%A2%7C%E8%81%94%E5%90%88%E6%90%9C%E7%B4%A2%7C%E8%81%9A%E5%90%88%E6%90%9C%E7%B4%A2%7C%E6%90%9C%E7%B4%A2%E8%B7%B3%E8%BD%AC%7C%E6%90%9C%E7%B4%A2%E5%88%87%E6%8D%A2%7C%E6%90%9C%E7%B4%A2%E5%BC%95%E6%93%8E%E5%A2%9E%E5%BC%BA%E5%B7%A5%E5%85%B7%7CsearchEngineJump%7CMultipleSearch.user.js // @updateURL https://update.greasyfork.icu/scripts/530550/%E5%A4%9A%E9%87%8D%E6%90%9C%E7%B4%A2%7C%E8%81%94%E5%90%88%E6%90%9C%E7%B4%A2%7C%E8%81%9A%E5%90%88%E6%90%9C%E7%B4%A2%7C%E6%90%9C%E7%B4%A2%E8%B7%B3%E8%BD%AC%7C%E6%90%9C%E7%B4%A2%E5%88%87%E6%8D%A2%7C%E6%90%9C%E7%B4%A2%E5%BC%95%E6%93%8E%E5%A2%9E%E5%BC%BA%E5%B7%A5%E5%85%B7%7CsearchEngineJump%7CMultipleSearch.meta.js // ==/UserScript== (function () { 'use strict'; function iqxinstart(){ // 根据规则把搜索引擎列表插入到指定网站 var css ={}; css = { style:"float:left;margin-left:1px;z-index:100000;margin-top:1px;" }; var rules = [ // 网页搜索/////////////第一个可以当模板看 {name: "google网页搜索",// 你要加载的网站的名字(方便自己查找) // 是否启用. enabled: true, // 在哪个网站上加载,正则. url: /^https?:\/\/www\.google\.com\/search/, // 加载哪个类型的列表: // ['web'|'music'|'video'|'image'|'download'|'shopping'|'translate'|'knowledge'|'sociality'] engineList: 'web', // 给引擎列表的样式 style: css.style, // 插入文档,相关 // target 将引擎跳转工具栏插入到文档的某个元素 // (请使用xpath匹配,比如: '//*[@id="subform_ctrl"]' 或者 css匹配(请加上 'css;' 的前缀),比如: 'css;#subform_ctrl' ); // keyword 使用 xpath 或者 css选中一个form input元素 或者 该项是一个函数,使用返回值 // where 四种: // 'beforeBegin'(插入到给定元素的前面) ; // 'afterBegin'(作为给定元素的第一个子元素) ; // 'beforeEnd' (作为给定元素的最后一个子元素) ; // 'afterEnd'(插入到给定元素的后面);. insertIntoDoc: { keyword: '//textarea[@name="q"]', target: 'css;body', where: 'beforeBegin', //整个项目作为独立部分插入head和body之间,最大限度提高兼容性 }, }, {name: "百度网页搜索", url: /^https?:\/\/www\.baidu\.com\/(?:s|baidu)/, enabled: true, engineList: 'web', style: css.style, insertIntoDoc: { keyword: '//input[@name="wd"]', target: 'css;body', where: 'beforeBegin', }, }, {name: "必应网页搜索", url: /^https?:\/\/www\.bing\.com\/search/, enabled: true, engineList: 'web', style: css.style, insertIntoDoc: { keyword: '//input[@name="q"]', target: 'css;body', where: 'beforeBegin', }, }, {name: "搜狗", url: /^https?:\/\/www\.sogou\.com\/(?:web|s)/, enabled: true, engineList: 'web', style: css.style, insertIntoDoc: { keyword: 'css;.query', target: 'css;body', where: 'beforeBegin', }, }, {name: "360", url: /^https?:\/\/www\.so\.com\/s/i, enabled: true, engineList: 'web', style: css.style, insertIntoDoc: { keyword: '//input[@name="q"]', target: 'css;body', where: 'beforeBegin', }, }, {name: "雅虎网页搜索", url: /^https?:\/\/search\.yahoo\.com\/search/i, engineList: 'web', enabled: true, style: css.style, insertIntoDoc: { keyword: '//input[@name="p"]', target: 'css;body', where: 'beforeBegin', }, }, {name: "DDG", url: /^https?:\/\/duckduckgo\.com\/\?q/i, enabled: true, engineList: 'web', style: css.style, insertIntoDoc: { keyword: '//input[@name="q"]', target: 'css;body', where: 'beforeBegin', }, }, {name: "yandex", url: /^https?:\/\/www\.yandex\.com\/search/i, enabled: true, engineList: 'web', style: css.style, insertIntoDoc: { keyword: '//input[@name="text"]', target: 'css;body', where: 'beforeBegin', }, }, {name: "ask", url: /^https?:\/\/www\.ask\.com\/web\?q/i, enabled: true, engineList: 'web', style: css.style, insertIntoDoc: { keyword: '//input[@name="q"]', target: 'css;body', where: 'beforeBegin', }, }, ]; // 搜索引擎列表 var engineList = {}; // 有些图标需要重复使用 var imgurl = "//omoristation.github.io/searchEngineJump/images"; var icon ={}; icon = { google: imgurl+'/google.svg', baidu: imgurl+'/baidu.svg', sogou: imgurl+'/sogou.svg', so: imgurl+'/so.svg', bing: imgurl+'/bing.svg', yahoo: imgurl+'/yahoo.svg', duckduckgo: imgurl+'/duckduckgo.svg', yandex: imgurl+'/yandex.svg', aol: imgurl+'/aol.svg', ask: imgurl+'/ask.svg', config: imgurl+'/config.svg', edit: imgurl+'/edit.svg', del: imgurl+'/del.svg', plus: imgurl+'/plus.svg', }; // 网页搜索列表 engineList.web = []; // engineList.web[0] 中间的数字表示排序(数字不能重复,否则后面的会覆盖掉前面的),越小数字越靠前,小于0该引擎不会显示在页面上 engineList.web[0] = { // 搜索引擎名称 name: 'Google', // 搜索引擎地址,关键字变量用%s代替 url: 'https://www.google.com/search?q=%s&ie=utf-8&oe=utf-8', // 搜索引擎的站点图标 favicon: icon.google, // 搜索引擎编码(默认utf-8)如果跳转后乱码可以填写 'gbk' //encoding: 'utf-8', // 新标签页打开 // blank:true, // 禁用 // disable:true, }; engineList.web[1] = { name: '百度', url: 'https://www.baidu.com/s?wd=%s&ie=utf-8', favicon: icon.baidu, }; engineList.web[2] = { name: '必应', url: 'https://www.bing.com/search?q=%s', favicon: icon.bing, }; engineList.web[3] = { name: '搜狗', url: 'https://www.sogou.com/web?query=%s', favicon: icon.sogou, }; engineList.web[4] = { name: '360', url: 'https://www.so.com/s?ie=utf-8&q=%s', favicon: icon.so, }; engineList.web[5] = { name: 'yahoo', url: 'https://search.yahoo.com/search;?p=%s', favicon: icon.yahoo, disable:true, }; engineList.web[6] = { name: 'DDG', url: 'https://duckduckgo.com/?q=%s', favicon: icon.duckduckgo, disable:true, }; engineList.web[7] = { name: 'yandex', url: 'https://www.yandex.com/search/?text=%s', favicon: icon.yandex, disable:true, }; engineList.web[8] = { name: 'ask', url: 'https://www.ask.com/web?q=%s', favicon: icon.ask, disable:true, }; engineList.web[9] = { name: 'aol', url: 'https://search.aol.com/aol/search?q=%s', favicon: icon.aol, disable:true, }; var settingData = { "message":"$相关说明$(status: 这个在将来或许很重要)..."+ "(version: 若有新功能加入,靠这个版本号识别)..." + "(addSearchItems: 允许更新时,添加新的搜索到你的搜索列表,将来更新使用)..." + "(modifySearchItems: 允许更新时,修改你的搜索列表中的项目,将来更新使用)..." + "(connectToTheServer: 允许连接到我的服务器(更新列表,将图标转换为base64等),将来更新使用或永不使用)..." + "(closetext: 设置页面右上角的“关闭圆圈”是否显示。true显示,false隐藏)..." + "(newtab: 0为默认设置,1为新标签页打开)..." + "(position: 搜索按钮排列方向,0为水平,1为默认竖排,切换后可以调整left和top值来适应页面)..." + "(left: 搜索按钮到浏览器左边的距离)..." + "(top: 搜索按钮到浏览器上面的距离)..." + "(foldlist: 折叠当前搜索分类列表。true为折叠,false为展开。)..." + "(animation: 关闭搜索按钮动画。true显示,false隐藏)..." + "(setBtnOpacity: 搜索按钮的透明度.)..." + "(debug: debug模式,开启后,控制台会输出一些信息,“关闭并保存”按钮将不会在刷新页面)..." + "(fixedTop: 将搜索按钮固定。 true开启,false关闭)..." + "(engineDetails: 第一个值为分类列表标题名称,第二个值与enginelist相关联,必须匹配,第三个值true为显示列表,false为禁用列表。可以用它将分类列表按自己喜欢排序)..." + "(engineList: 各个搜索的相关信息)" + "(rules: 添加陌生搜索后,需要在此将此搜索的搜索样式插入到目标网页才可以显示按钮,同脚本中的rules设置相同。自带了aol搜索,可仿写)...", "status":1, "version":0.01, "addSearchItems":true, "modifySearchItems":true, "connectToTheServer":true, "closetext":false, "newtab":0, "position":1, "left":1, "top":10, "foldlist":false, "animation":true, "setBtnOpacity":0.6, "debug":false, "fixedTop":true, "engineDetails":[['网页', 'web',true]], "engineList":{}, "rules":[{"name": "aol", "url": "/^https?:\\/\\/search\\.aol\\.com\\/aol\\/search/", "enabled": true, "engineList": "web","style": css.style, "insertIntoDoc": {"keyword": "//input[@name='q']", "target": "//body[@*]", "where": "beforeBegin"}}] }; var getSettingData = GM_getValue("searchEngineJumpData"); if(getSettingData){ // console.log("本地存在列表:",getSettingData); if(!getSettingData.status && confirm("设置发生错误,脚本将会复原出厂设置")){ GM_deleteValue("searchEngineJumpData"); window.location.reload(); } // 查看本地配置信息是否完整 for(let value in settingData){ if(!getSettingData.hasOwnProperty(value)){ console.log("属性不存在: ",value); getSettingData[value] = settingData[value]; GM_setValue("searchEngineJumpData",getSettingData); } } // 获取版本,用于搜索列表更新 // console.log("当前版本号和目标版本号: ",getSettingData.version,settingData.version); if(parseFloat(getSettingData.version) < settingData.version){ console.log("版本过低,开始更新,当前版本号和目标版本号: ",getSettingData.version,settingData.version); // 1.93更新 360界面变动 if(getSettingData.modifySearchItems){ getSettingData.engineList = modifySearchItemsFun(getSettingData.engineList,"https://www.google.com/cse?q=%s&newwindow=1&cx=006100883259189159113%3Atwgohm0sz8q","https://cse.google.com/?q=%s&newwindow=1&cx=006100883259189159113%3Atwgohm0sz8q"); } // 更新本地版本 其他相关信息 getSettingData.version = settingData.version; getSettingData.message = settingData.message; GM_setValue("searchEngineJumpData",getSettingData); } engineList = getSettingData.engineList; } else { console.log("未发现本地列表"); settingData.engineList = engineList; console.log("初始化:",settingData); GM_setValue("searchEngineJumpData",settingData); getSettingData = GM_getValue("searchEngineJumpData"); } // 处理enginlist.detail的相关信息 var engineDetails = getSettingData.engineDetails; //列表分类显示情况 var getDetails = engineDetails.map(function(value,index){ // console.log(value,value[2]); return value[2]?index:-index; }); // 列表分类的key value var getDetailsL = getDetails.length; var details = []; for(let i=0;i // MIT License var parseUri = function(str) { var o = parseUri.options, m = o.parser[o.strictMode ? "strict" : "loose"].exec(str), uri = {}, i = 14; while (i--) uri[o.key[i]] = m[i] || ""; uri[o.ds.name] = {}; uri[o.ds.name][0] = {}; uri[o.ds.name][0].key = (uri.protocol ? uri.protocol : "http") + "://" + uri.host + (uri.port ? ":" + uri.port : "") + "/"; uri[o.ds.name][0].val = "/"; i = 0; var tempsub = "/", subs = uri[o.key[10]].substr(1).split("/"); for (var j = 1; j < (subs.length + 1); j++, i++) { tempsub += tempsub === "/" ? subs[i] : "/" + subs[i]; if (subs[i]) { uri[o.ds.name][j] = {}; uri[o.ds.name][j].key = subs[i]; uri[o.ds.name][j].val = tempsub; } } uri[o.q.name] = {}; uri[o.key[12]].replace(o.q.parser, function($0, $1, $2) { if ($1) uri[o.q.name][$1] = $2; }); uri[o.aq.name] = {}; uri[o.key[13]].replace(o.aq.parser, function($0, $1, $2) { if ($1) uri[o.aq.name][$1] = $2; }); return uri; }; parseUri.options = { strictMode: false, key: ["source", "protocol", "authority", "userInfo", "user", "password", "host", "port", "relative", "path", "directory", "file", "query", "anchor"], q: { name: "queryKey", parser: /(?:^|&)([^&=]*)=?([^&]*)/g }, aq: { name: "anchorqueryKey", parser: /(?:^|&)([^&=]*)=?([^&]*)/g }, ds: { name: "directorySub" }, parser: { strict: /^(?:([^:\/?#]+):)?(?:\/\/((?:(([^:@]*)(?::([^:@]*))?)?@)?([^:\/?#]*)(?::(\d*))?))?((((?:[^?#\/]*\/)*)([^?#]*))(?:\?([^#]*))?(?:#(.*))?)/, loose: /^(?:(?![^:@]+:[^:@\/]*@)([^:\/?#.]+):)?(?:\/\/)?((?:(([^:@]*)(?::([^:@]*))?)?@)?([^:\/?#]*)(?::(\d*))?)(((\/(?:[^?#](?![^?#\/]*\.[^?#\/.]+(?:[?#]|$)))*\/?)?([^?#\/]*))(?:\?([^#]*))?(?:#(.*))?)/ } }; function getElementLeft(element){ var actualLeft = element.offsetLeft; var current = element.offsetParent; while (current !== null){ actualLeft += current.offsetLeft; current = current.offsetParent; } console.log(actualLeft); return actualLeft; } // --------------------可设置项结束------------------------ // console.log("engineList: ",engineList); //xpath 获取单个元素 function getElementByXPath(xPath, contextNode, doc) { doc = doc || document; contextNode = contextNode || doc; return doc.evaluate(xPath, contextNode, null, 9, null).singleNodeValue; } // 从函数中获取多行注释的字符串 function getMStr(fn) { var fnSource = fn.toString(); var ret = {}; fnSource = fnSource.replace(/^[^{]+/, ''); // console.log(fnSource); var matched; var reg = /var\s+([$\w]+)[\s\S]*?\/\*([\s\S]+?)\*\//g; while (matched = reg.exec(fnSource)) { // console.log(matched); ret[matched[1]] = matched[2]; } return ret; } // 事件支持检测. // 比如 eventSupported('fullscreenchange', document); function eventSupported(eventName, elem) { elem = elem || document.createElement('div'); var prefix = ['o', 'ms', 'moz', 'webkit', '']; var l = prefix.length; var pEventName; var isFunction; var setAttr; while(l --) { pEventName = 'on' + prefix[l] + eventName; if (pEventName in elem) { return pEventName.slice(2); } else if (typeof elem.setAttribute == 'function') { // setAttribute 是元素节点的方法 setAttr = false; if (!elem.hasAttribute(pEventName)) { setAttr = true; elem.setAttribute(pEventName, 'return;'); } isFunction = typeof elem[pEventName] == 'function'; if (setAttr) elem.removeAttribute(pEventName); if (isFunction) { return pEventName.slice(2); } } } return false; } // 保存指定对象相关数据 var data = (function () { //'use strict'; var cache = { objs: [], data: {}, }; function data(obj, key, value) { var id = cache.objs.indexOf(obj); if (id == -1) { id = cache.objs.push(obj) - 1; } if (!cache.data[id]) {//初始化 cache.data[id] = {}; } if (typeof value == 'undefined') {// 取值 return typeof key == 'undefined' ? cache.data[id] : cache.data[id][key]; } else { return cache.data[id][key] = value; } } return data; })(); // 为mouseleave mouseenter事件做个兼容 // 需要 eventSupported, data函数支持 var mouseEventListener = (function () { var support = { mouseleave : eventSupported('mouseleave'), mouseenter : eventSupported('mouseenter'), }; var map = { mouseleave : 'mouseout', mouseenter : 'mouseover', }; return { add : function (type, ele, callback) { //事件类型,元素,监听函数 if (support[type]) { ele.addEventListener(type, callback, false); //mouseleave,enter不冒泡,所以在冒泡阶段监听事件,不要担心子孙元素进出发生的事件冒泡上来。 } else { var listener = data(callback, 'mouseELListener'); if (!listener) { listener = function (e) { var relatedTarget = e.relatedTarget; //mouseout,去往的元素;mouseover,来自的元素 // 当mouseout(离开ele)去往的元素不是自己的子孙元素 // 当mouseover(进入ele)来自的元素不是自己的子孙元素 if (!ele.contains(relatedTarget)) { // contains函数,自己.contains(自己) 返回true callback.call(ele, e); } }; data(callback, 'mouseELListener', listener); } ele.addEventListener(map[type], listener, true); } }, remove : function (type, ele, callback) { if (support[type]) { ele.removeEventListener(type, callback, false); } else { ele.removeEventListener(map[type], data(callback, 'mouseELListener'), true); } }, }; })(); //获取已滚动的距离 function getScrolled(container) { if (container) { return { x:container.scrollLeft, y:container.scrollTop, }; } return { x: 'scrollX' in window ? window.scrollX : ('pageXOffset' in window ? window.pageXOffset : document.documentElement.scrollLeft || document.body.scrollLeft), y: 'scrollY' in window ? window.scrollY : ('pageYOffset' in window ? window.pageYOffset : document.documentElement.scrollTop || document.body.scrollTop), }; } function getElement(selector) { if (selector.indexOf('css;') == 0) { return document.querySelector(selector.slice(4)); } else { return getElementByXPath(selector); } } function mousedownhandler(e) { var target = e.target; target = getElementByXPath('ancestor-or-self::a[contains(@class, "sej-engine")]', target); // if (!target || target.className.indexOf('sej-engine') == -1) return; if (!target || !this.contains(target)) return; var value; if (typeof iInput == 'function') { value = iInput(); } else { if (iInput.nodeName == 'INPUT') { value = iInput.value; } else { value = iInput.textContent; } } // // @name searchEngineJump-NextStage if (document.characterSet != "UTF-8") value = encodeURIComponent(value); var targetURL = target.getAttribute('url'); // console.log(targetURL); // 如果有post请求 var postSign = targetURL.indexOf('$post$'); if(~postSign){ // var targetBlank = var f=getPostFormHTML(targetURL.substring(0,postSign),[targetURL.substring(postSign+6),value],target.getAttribute('target')); // a = a.replace("$form$", f); target.appendChild(f); // a = a.replace("$onclick$", "this.getElementsByTagName('form')[0].submit();return false;"); // target.removeAttribute('onclick'); target.setAttribute("onclick","this.getElementsByTagName('form')[0].submit();return false;"); // alert(f); } else{ console.log(value); target.href = target.getAttribute('url').replace('%s', value); } } //获取 POST 的表单的 HTML function getPostFormHTML(url, value, newTab) { console.log(url,value,newTab); var ospan = document.createElement('span'); ospan.style.cssText = 'width:0px;height:0px;'; var form = "" + "
" + "" + "
"; ospan.innerHTML = form; return ospan; } // iframe 禁止加载 if (window.self != window.top) return; var url = location.href; var matchedRule; var marchedSign; //先判断用户规则 marchedSign = getSettingData.rules.some(function (rule) { rule.url = new RegExp(rule.url.substring(1,rule.url.length-1)); if (rule.url.test(url)) { matchedRule = rule; return true; } }); // console.log(marchedSign,matchedRule); if(!marchedSign){ rules.some(function (rule) { if (rule.url.test(url)) { matchedRule = rule; return true; } }); } // console.log(matchedRule); if (!matchedRule || !matchedRule.enabled) return; var iTarget = getElement(matchedRule.insertIntoDoc.target); var iInput = typeof matchedRule.insertIntoDoc.keyword == 'function' ? matchedRule.insertIntoDoc.keyword : getElement(matchedRule.insertIntoDoc.keyword); ///test -------------- 测试 start debug("searchEngineJump test iTarget, iInput: ",iTarget, iInput); ///test -------------- 测试 end if (!iTarget || !iInput) { console.log("目标有误: iTarget:" + iTarget + "\niInput: " + iInput); return; } // 添加全局样式 var globalStyle = document.createElement('style'); globalStyle.type = 'text/css'; globalStyle.textContent = getMStr(function(){ var cssText; /* #sej-container { display: block; #position: absolute; #position: fixed; z-index: 2; padding: 1px 5px 1px 5px; line-height: 1.5; font-size: 13px; font-family: arial,sans-serif; transform-origin: top center; #animation: sejopen 0.3s !important; border-bottom-right-radius: 4px; } #sej-expanded-category { font-weight: bold; } .sej-engine { line-height: 1.5; display: inline-block; margin: 4px 0px 0 0; border: none; padding: 4px 4px; text-align:center; text-decoration: none; font-weight:500; color: #333 !important; transition: background-color 0.15s ease-in-out; } .sej-drop-list-trigger { } .sej-drop-list-trigger-shown { background-color: #DEEDFF !important; } .sej-drop-list-trigger::after { content: ''; display: inline-block; margin: 0 0 0 3px; padding: 0; width: 0; height: 0; border-top: 6px solid #BCBCBC; border-right: 5px solid transparent; border-left: 5px solid transparent; border-bottom: 0px solid transparent; vertical-align: middle; transition: -webkit-transform 0.3s ease-in-out; transition: transform 0.3s ease-in-out; } .sej-drop-list-trigger-shown::after { -webkit-transform: rotate(180deg); transform: rotate(180deg); } .sej-engine:hover { background-color: #EAEAEA; } .sej-drop-list > .sej-engine { display: block; padding-top: 4px; padding-bottom: 4px; width: 50px; } .sej-drop-list > .sej-engine:hover { background-color: #DEEDFF; } .sej-engine-icon { display: block; width: 50px; height: 50px; border: none; padding: 0; margin: 0 0px 0 0; vertical-align: text-bottom; } .sej-engine-icon-edit { display: block; width: 20px; height: 20px; border: none; padding: 0; margin: 0 0px 0 0; vertical-align: text-bottom; } .sej-drop-list { position: absolute; display: none; opacity: 0.3; top: -10000px; left: 0; min-width: 50px; border: 1px solid #FAFAFA; padding: 5px 0; text-align: left; font-size: 13px; -moz-box-shadow: 2px 2px 5px #ccc; -webkit-box-shadow: 2px 2px 5px #ccc; box-shadow: 2px 2px 5px #ccc; background-color: white; transition: opacity 0.2s ease-in-out, top 0.2s ease-in-out; } @keyframes sejopen { 0% { transform: scale(1, 0.1); opacity: 0; } 100% { transform: scale(1, 1); opacity: 1; } } @keyframes iqxinsejopen { 0% { transform: scale(0.01, 0.01); opacity: 0; } 100% { transform: scale(1, 1); opacity: 1; } } */ }).cssText; //document.head.appendChild(globalStyle); 插入head和body之间 插入head中百度会不刷新url重置head,只能作为单独的部分插入页面 iTarget.parentNode.insertBefore(globalStyle, iTarget); // 列表对象 function DropDownList(a, list) { this.a = a; this.list = list; this.init(); } DropDownList.zIndex = 100000000; DropDownList.prototype = { hidden: true, showDelay: 233, hideDelay: 233, aShownClass: 'sej-drop-list-trigger-shown', init: function () { var a = this.a; var list = this.list; var self = this; // 进入显示 mouseEventListener.add('mouseenter', a, function () { clearTimeout(self.hideTimerId); if (self.hidden) { self.showTimerId = setTimeout(function () { self.show(); }, self.showDelay); } else { var style = list.style; style.zIndex = DropDownList.zIndex ++; style.opacity = 0.96; } }); // 离开隐藏 mouseEventListener.add('mouseleave', a, function () { clearTimeout(self.showTimerId); if (!self.hidden) { //list.style.top = parseInt(list.style.top)+6 +"px"; list.style.opacity = 0.04; self.hideTimerId = setTimeout(function () { self.hide(); }, self.hideDelay); } }); mouseEventListener.add('mouseenter', list, function () { clearTimeout(self.hideTimerId); var style = list.style; style.zIndex = DropDownList.zIndex ++; style.opacity = 0.96; }); mouseEventListener.add('mouseleave', list, function () { list.style.opacity = 0.04; list.style.top = parseInt(list.style.top) +"px"; self.hideTimerId = setTimeout(function () { self.hide(); }, self.hideDelay); }); }, show: function () { if (!this.hidden) return; this.hidden = false; var scrolled = getScrolled(); var aBCRect = this.a.getBoundingClientRect(); var style = this.list.style; var top = scrolled.y + aBCRect.bottom; var left = scrolled.x + aBCRect.left; style.top = top + 'px'; style.left = left + 'px'; style.zIndex = DropDownList.zIndex ++; style.display = 'block'; setTimeout(function () { style.opacity = 0.96; style.top = top + 'px'; }, 30); this.a.classList.add(this.aShownClass); }, hide: function () { if (this.hidden) return; this.hidden = true; var style = this.list.style; style.display = 'none'; style.opacity = 0.1; this.a.classList.remove(this.aShownClass); } }; var pageEncoding = (document.characterSet || document.charset).toLowerCase(); // 创建dom var aPattern = '$name$'; var container = document.createElement('sejspan'); container.id = 'sej-container'; container.className = "rwl-exempt"; container.addEventListener('mousedown', mousedownhandler, true); if (matchedRule.style) { container.style.cssText = matchedRule.style; } var dropLists = []; engineList.details.forEach(function (item) { var category = item[1]; var cName = item[0]; var engines = []; engineList[category].forEach(function (engine) { // 检测是否用搜索搜某一网站 site:xxx.xx var engineUrl = engine.url; var siteIndex = engineUrl.lastIndexOf("site"); var siteMark = null; if(~siteIndex){ var siteURL = engineUrl.slice(siteIndex); siteMark = /([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,6}/.test(siteURL); // console.log(/([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,6}/.test(siteURL),siteURL); } if (!siteMark && matchedRule.url.test(engineUrl)) return;// 去掉跳转到当前引擎的引擎 if(engine.disable) return; var a = aPattern.replace('$encoding$', (engine.encoding || 'utf-8').toLowerCase()) .replace('$url$', engineUrl) .replace('$name$', engine.name); if (engine.favicon) { a = a.replace('$favicon$', engine.favicon); } else { a = a.replace('src="$favicon$"', ''); } if (getSettingData.newtab || engine.blank) { a = a.replace('$blank$', "_blank"); } else { a = a.replace('target="$blank$"', ''); } engines.push(a); }); // 非空列表 if (!engines.length) return; engines = engines.join(''); // 展开当前搜索分类列表 if (!getSettingData.foldlist && category == matchedRule.engineList) { container.innerHTML = engines; } else { var dropList = document.createElement('sejspan'); dropList.className = 'sej-drop-list rwl-exempt'; dropList.innerHTML = engines; // 非空列表 var a = dropList.firstElementChild.cloneNode(true); a.className = a.className + ' sej-drop-list-trigger'; a.lastChild.nodeValue = cName; dropLists.push([a, dropList]); } }); //将各个搜索列表插入文档中 dropLists.forEach(function (item) { container.appendChild(item[0]); //document.body.appendChild(item[1]);插入head和body之间 iTarget.parentNode.insertBefore(item[1], iTarget); item[1].addEventListener('mousedown', mousedownhandler, true); new DropDownList(item[0], item[1]); }); // 插入到文档中 switch (matchedRule.insertIntoDoc.where.toLowerCase()) { case 'beforebegin' : iTarget.parentNode.insertBefore(container, iTarget); break; case 'afterbegin' : if (iTarget.firstChild) { iTarget.insertBefore(container, iTarget.firstChild); } else { iTarget.appendChild(container); } break; case 'beforeend' : iTarget.appendChild(container); break; case 'afterend' : if (iTarget.nextSibling) { iTarget.parentNode.insertBefore(container, iTarget.nextSibling); } else { iTarget.parentNode.appendChild(container); } break; } // -------------------设置相关-------------------------------- // 设置按钮相关 var dragEl = null; var dragData = null; function SEJsetting(){ this.ele = document.createElement("div"); this.mask = document.createElement("div"); this.parentTemp = null; this.editTemp = null; this.online = null; this.init(); } SEJsetting.prototype = { testabc : "hahah", aPatternParent : "
", init: function () { // console.log("init..."); var that = this; this.ele.id = "settingLayer"; this.mask.id = "settingLayerMask"; this.addGlobalStyle(); this.addContent(); this.mask.addEventListener("click",function(){ that.hide(); }); this.ele.addEventListener("click",function(e){ e.stopPropagation(); }); this.mask.appendChild(this.ele); document.body.appendChild(this.mask); // 绑定事件 this.ele.addEventListener("click",that.domClick.bind(this),false); this.dragEvent(); // input[range] 滑动条相关 that.rangeChange(true); document.querySelector("#setBtnOpacityRange").addEventListener("input",that.rangeChange); document.querySelector("#leftRange").addEventListener("input",that.rangeChange); document.querySelector("#topRange").addEventListener("input",that.rangeChange); }, //拖拽相关 dragEvent: function(){ var that = this; var odivsdrag = document.querySelectorAll(".drag"); [].forEach.call(odivsdrag,function(odiv){ odiv.addEventListener("dragstart",that.domdragstart,false); odiv.addEventListener('dragenter', that.domdragenter, false); odiv.addEventListener('dragover', that.domdragover, false); odiv.addEventListener('dragleave', that.domdragleave, false); odiv.addEventListener('drop', that.domdrop, false); odiv.addEventListener('dragend',that.domdropend, false); }); }, //按钮相关 addContent: function(){ var aPattern = '' + '$name$' + ' ' + ' ' + ''; var details = engineList.details; // 若根据数组长度获取,负数引导的为属性,不再length长度之内,所以来个大体的数字,当都为空时,结束循环 // var detailsLength = details.length; var detailsLength = 99; for (let i=0;i' + ''+ ' '; odiv.appendChild(oDivTitle); var oDivCon = document.createElement("div"); oDivCon.classList.add("sejcon"); var oDivConStr = ""; var engineListItme = engineList[details[j][1]]; var itemLength = engineListItme.length; for(let ii=0;ii' + '' + '' + ""; oDivCon.innerHTML = oDivConStr; odiv.appendChild(oDivCon); this.ele.appendChild(odiv); } var fixedTop_checked = getSettingData.fixedTop?"checked":""; var debug_checked = getSettingData.debug?"checked":""; var foldlist_checked = getSettingData.foldlist?"checked":""; var closetext_checked = getSettingData.closetext?"checked":""; var animation_checked = getSettingData.animation?"checked":""; // 增加搜索列表 var nSearchList = document.createElement("div"); nSearchList.id = "nSearchList"; nSearchList.setAttribute("title","添加新的搜索列表"); nSearchList.innerHTML = ""+ "" + ""; this.ele.appendChild(nSearchList); // 添加按钮 var btnEle = document.createElement("div"); btnEle.id = "btnEle"; var btnStr = "
" + "油猴 代码" + "打开方式" + "" + " " + "方向" + "" + " " + "重置" + "配置" + "" + "" + "" + "" + "" + "" + "" + "" + "" + "" + "" + "" + "" + "" + "" + "透明度 " + "靠左 " + "靠上 " + "应用" + "保存并关闭" + "
"; btnEle.innerHTML = btnStr; this.ele.appendChild(btnEle); // 关闭按钮 var closebtnELe = document.createElement("span"); closebtnELe.id = "xin-close"; closebtnELe.setAttribute("title","close 关闭"); this.ele.appendChild(closebtnELe); }, show: function(){ var style = this.mask.style; var eleStyle = this.ele.style; style.display = "flex"; eleStyle.transform = "translateY(-20%)"; document.body.style.overflow = "hidden"; this.windowResize(); setTimeout(function () { style.opacity = 1; eleStyle.transform = "none"; }, 30); }, hide: function(){ this.allBoxClose(); // 关闭所有次级窗口、菜单 var style = this.mask.style; this.ele.style.transform = "translateY(20%)"; style.opacity = 0; setTimeout(function () { style.display = "none"; document.body.style.overflow = "auto"; }, 500); var elems = document.querySelectorAll('#settingLayerMask'); if (!elems) return; console.log("elems: " + elems); // return; [].forEach.call(elems, function(elem) { elem.parentNode.removeChild(elem); }); }, reset: function(){ if(confirm("将会删除用户设置!")){ GM_deleteValue("searchEngineJumpData"); window.location.reload(); } }, // 界面,框:添加新的搜索 addItemBox: function(bool){ this.isOnline(); this.addItemBoxRemove(); var newDiv = document.createElement("div"); newDiv.id= "newSearchBox"; newDiv.innerHTML=""+ "标       题 :

" + "链       接 :

" + "图       标 :

" + "打开方式 : " + ' ' + "" + "

" + "相关使用说明" + "       " + "      " + "" + ""; this.ele.appendChild(newDiv); document.querySelector("#iqxin-newTitle").focus(); }, // 内部逻辑,:添加新的搜索 addItemEnger: function(){ var otitle,olink,oimg,oblank; otitle = document.querySelector("#iqxin-newTitle").value; olink = document.querySelector("#iqxin-newLink").value; oimg = document.querySelector("#iqxin-newIcon").value; oblank = document.querySelector("#iqxin-newTarget").selectedIndex; if (!oimg){ var uri = parseUri(olink); var ohttp = uri.protocol?uri.protocol:"http"; debug("能否连接至google:",this.online); if (this.online){ oimg = 'https://www.google.com/s2/favicons?domain=' + uri.host; } else { oimg = ohttp + "://" + uri.host + "/favicon.ico"; } } var a = '$name$' + '' + '' + ' ' + '' + '' + '' ; a = a.replace("$img$", oimg) .replace("$title$", otitle) .replace("$link$", olink); if (oblank){ a = a.replace('data-iqxintarget="$blank$"', ''); } else { a = a.replace('$blank$', "_blank"); } a = a.replace('$name$', otitle) .replace('$favicon$', oimg); var ospan = document.createElement("span"); ospan.className = "drag"; ospan.innerHTML = a; this.parentNode.insertBefore(ospan,this.parentNode.lastChild); // 添加完成,移除添加框 this.addItemBoxRemove(); }, addItemBoxRemove: function(ele){ ele = ele?ele:"#newSearchBox"; var newBox = document.querySelector(ele); if(newBox){ newBox.style.transform = "scale(0.01, 0.01)"; newBox.style.opacity = "0"; setTimeout(function(){ newBox.parentNode.removeChild(newBox); },550); } }, // 界面, 框: 添加新的搜索列表 addSearchListBox: function(){ var odiv = document.querySelector("#newSearchListBox"); if (odiv){ this.boxClose("#newSearchListBox"); return; } var newDiv = document.createElement("div"); newDiv.id= "newSearchListBox"; var myDate = new Date(); var hash = "user" + myDate.getTime(); newDiv.innerHTML=""+ "列表名称: " + "

" + "内部名称: " + "

" + "      " + "" + ""; this.ele.appendChild(newDiv); document.querySelector("#iqxin-newSearchListName").focus(); }, addSearchListEnger: function(){ var name = document.querySelector("#iqxin-newSearchListName").value; var innerName = document.querySelector("#iqxin-newSearchListInnerName").value; if(innerName.length===0){ alert("内部名称不能为空"); return; } if(name.length===0){ name = innerName; } var odiv = document.createElement("div"); odiv.id = innerName; odiv.className = "iqxin-items"; odiv.innerHTML = "" + '
' + ''+ name +'' + '' + '' + ' ' + '' + '' + '' + '
' + '
' + '' + '' + '' + '
' + ""; // this.boxClose("#newSearchListBox"); this.addItemBoxRemove("#newSearchListBox"); var nSearchList = document.querySelector("#nSearchList"); nSearchList.parentNode.insertBefore(odiv,nSearchList); }, boxClose: function(ele){ var odiv = document.querySelector(ele); if(odiv){ odiv.parentNode.removeChild(odiv); } }, // 界面 框:修改框 addEditBox: function(e){ console.log(e); this.addItemBoxRemove(); var target = e.target.parentNode.firstChild; var otitle = target.dataset.iqxintitle; var olink = target.dataset.iqxinlink; var oicon = target.dataset.iqxinimg; var otarget = target.dataset.iqxintarget; var odisabled = target.dataset.iqxindisabled; this.editTemp = target; var strblank; if(otarget){ strblank = ' '; } else{ strblank = ''; } var strdisable = ""; if(odisabled){ strdisable = "checked='checked'"; } var newDiv = document.createElement("div"); newDiv.id= "newSearchBox"; newDiv.style.cssText = "top:"+(e.screenY-120) +"px;left:"+(e.screenX-140) +"px;"; var innerHTML=""+ "标       题 :

" + "链       接 :

" + "图       标 :

" + "打开方式 : " + ' ' + "" + "

" + "" + "             " + "      " + "" + ""; newDiv.innerHTML = innerHTML.replace("$strblank$", strblank) .replace("$checked$",strdisable); this.ele.appendChild(newDiv); setTimeout(function(){newDiv.style.cssText="";},10); document.querySelector("#iqxin-newTitle").select(); }, addEditBoxEnger: function(){ var otitle,olink,oimg,oblank,odisabled; otitle = document.querySelector("#iqxin-newTitle").value; olink = document.querySelector("#iqxin-newLink").value; oimg = document.querySelector("#iqxin-newIcon").value; oblank = document.querySelector("#iqxin-newTarget").selectedIndex; odisabled = document.querySelector("#iqxin-newDisabled").checked; this.editTemp.dataset.iqxintitle = otitle; this.editTemp.lastChild.innerText = otitle; //文本节点 this.editTemp.dataset.iqxinlink = olink; this.editTemp.dataset.iqxinimg = oimg; this.editTemp.firstChild.src = oimg; // 是否新标签页打开 if (oblank){ this.editTemp.removeAttribute("data-iqxintarget"); } else { this.editTemp.dataset.iqxintarget = "_blank"; } // 是否禁用 if (odisabled){ this.editTemp.dataset.iqxindisabled = "true"; } else{ this.editTemp.removeAttribute("data-iqxindisabled"); } // 修改完成,移除添加框 this.addItemBoxRemove(); }, // 标题编辑 addTitleEditBox: function(e){ this.addItemBoxRemove(); var element = e.target.parentNode.firstChild; element.classList.remove("iqxin-pointer-events"); var flag = document.querySelector("#titleEdit"); if(flag){ element.innerHTML = element.firstChild.value?element.firstChild.value:"空"; element.classList.add("iqxin-pointer-events"); }else{ var oldhtml = element.innerHTML; var newobj = document.createElement("input"); newobj.id = "titleEdit"; newobj.type = "text"; newobj.value = oldhtml; // newobj.onblur = function(){ // element.innerHTML = this.value?this.value:oldhtml; // } newobj.onkeydown = function(e){ if((e.keyCode || e.which) == 13){ element.innerHTML = this.value?this.value:oldhtml; } else if((e.keyCode || e.which) == 27){ element.innerHTML = oldhtml; } element.classList.add("iqxin-pointer-events"); }; element.innerHTML = ""; element.appendChild(newobj); newobj.select(); } }, addTitleEditBoxRemove:function(){ var odiv = document.querySelector("#titleEdit"); if(odiv){ odiv.parentNode.innerHTML = odiv.value?odiv.value:"空"; } }, // 高级菜单,配置文件编辑界面 editCodeBox: function(){ console.log("原始数据: ",getSettingData); var userSetting = GM_getValue("searchEngineJumpData"); var editbox = document.createElement("div"); // var sData = editbox.id = "iqxin-editCodeBox"; editbox.style.cssText = "position:fixed;" + "top:50%;left:50%;" + "transform:translate(-50%,-50%);" + "background:#ccc;" + "border-radius:4px;" + "padding:10px 20px;" ; var innerH = " "+ "

! ! !
"+ "此处有更多的设置选项,自由度更高,
"+ "但设置错误会导致脚本无法运行"+ "

" + "" + "
" + "    " + "    " + "    " + "" + ""; // console.log(JSON.stringify(getSettingData,4)); // console.log(JSON.stringify(getSettingData,null,4)); editbox.innerHTML = innerH; this.ele.appendChild(editbox); }, editCodeBoxSave: function(){ var codevalue = document.querySelector("#iqxin-editCodeBox textarea").value; if(codevalue){ // console.log(JSON.parse(codevalue)); GM_setValue("searchEngineJumpData",JSON.parse(codevalue)); // console.log(GM_getValue("searchEngineJumpData")); // 刷新页面 setTimeout(function(){ window.location.reload(); },300); } else { // alert("输入为空"); this.reset(); } }, editCodeBoxClose: function(){ var box = document.querySelector("#iqxin-editCodeBox"); if(box){ box.parentNode.removeChild(box); } }, // 标题点击 (开关搜索列表)(可以并入到下面的点击事件) titleClick: function(e){ var target = e.target; target.dataset.xin = -parseInt(target.dataset.xin); }, // 点击事件 此处的 if 需要根据实际情况替换成 elseif (switch) domClick: function(e){ var targetClass = e.target.className; var targetid = e.target.id; debug("点击事件:%o, ID: %o, class: %o, e: %o",e.target,targetid,targetClass,e); // 删除搜索 if(~e.target.className.indexOf("iqxin-set-del")){ // console.log(e.target); e.target.parentNode.parentNode.removeChild(e.target.parentNode); } // 删除搜索列表 if(~e.target.className.indexOf("iqxin-set-title-del")){ // console.log(e.target, e.target.parentNode.parentNode); e.target.parentNode.parentNode.parentNode.removeChild(e.target.parentNode.parentNode); } if(~e.target.className.indexOf("iqxin-additem")){ // console.log("此处会有个弹框添加新搜索"); this.parentNode = e.target.parentNode; this.addItemBox(); // console.log(this); } if(e.target.className==="sej-engine"){ console.log("sej-engine 被点击"); e.target.dataset.iqxindisabled = e.target.dataset.iqxindisabled?"":"true"; } if(~targetClass.indexOf("addItemBoxCancel")){ this.addItemBoxRemove(); } // 添加新的搜索 确定 if(~targetClass.indexOf("addItemBoxEnter")){ this.addItemEnger(); } // 添加新的搜索列表 确定 if(targetid === "nSearchList"){ debug("添加新的搜索列表"); this.addSearchListBox(); } if(targetid === "addSearchListBoxEnter"){ debug("向网页添加元素"); this.addSearchListEnger(); } if(targetid === "addSearchListBoxCancel"){ debug("移除盒子"); // this.boxClose("#newSearchListBox"); this.addItemBoxRemove("#newSearchListBox"); } // 修改搜索 确定 if(~targetClass.indexOf("editItemBoxEnter")){ // console.log(e); this.addEditBoxEnger(); } // 编辑框 if(~e.target.className.indexOf("iqxin-set-edit")){ this.addEditBox(e); } // 标题编辑框 if(~targetClass.indexOf("iqxin-title-edit")){ e.stopPropagation(); this.addTitleEditBox(e); } if(~targetClass.indexOf("sejtitle")){ this.titleClick(e); } // codebox 源代码编辑框 if(targetid ==="codeboxclose"){ this.editCodeBoxClose(); } else if(targetid==="xin-reset"){ this.reset(); } else if( targetid === "xin-codeboxsave"){ this.editCodeBoxSave(); } else if( targetid === "xin-copyCode"){ // this.copyCode(); GM_setClipboard(JSON.stringify(getSettingData,false,4)); iqxinShowTip("复制成功"); } // 关闭设置菜单 if (targetid === "xin-close"){ this.hide(); } // 空白地方点击 if(~targetClass.indexOf("iqxin-items") || targetid === "settingLayer" || targetClass==="btnEleLayer"){ this.allBoxClose(); } }, // 关闭所有次级窗口、菜单 allBoxClose: function(){ this.addItemBoxRemove(); // 新的搜索添加框 // this.addDelremove(); // 增加/删除界面 this.editCodeBoxClose(); // code编辑框 this.addTitleEditBoxRemove(); //标题编辑框 this.addItemBoxRemove("#newSearchListBox"); // 添加新的搜索列表 this.boxClose("#iqxin-sortBox"); // 搜索列表排序 // document.querySelector("#btnEle2").classList.remove("btnEle2active"); // 更多设置 }, // 拖拽相关 domdragstart:function (e) { if(~this.className.indexOf("sejtitle")){ dragEl = this.parentNode; } else{ dragEl = this; } dragData = dragEl.innerHTML; console.info("start"); console.info(e.target); e.dataTransfer.effectAllowed = "move"; e.dataTransfer.setData("text/html",dragEl.innerHTML); }, domdragenter:function (e) { var target = e.target; var targetClass = target.className; if(~targetClass.indexOf("sejtitle")){ target = target.parentNode; } target.classList.add('drop-over'); }, domdragover:function (e) { if (e.preventDefault) { e.preventDefault(); } e.dataTransfer.dropEffect = 'move'; // return false; var _this = e.target; var that = _this.parentNode; var pparentNode = that.parentNode; // 防止跨区域移动 SEJsetting.prototype.domdropend(); if(dragEl.className != that.className){ console.log("移动对象 之前,现在: ", dragEl.className); console.log(that.className); return; } // Sortable.js https://github.com/RubaXa/Sortable var targetRect = _this.getBoundingClientRect(); // var width = targetRect.right - targetRect.left; //目标节点的宽 var height = targetRect.bottom - targetRect.top; //目标节点的高 var domPosition = null; if(~_this.className.indexOf("sejtitle")){ debug(e.clientX,targetRect.left,height,e.clientX - targetRect.left,(e.clientX - targetRect.left) / height); if((e.clientX - targetRect.left) / width > 0.5){ debug("右"); domPosition = true; }else{ debug("左"); domPosition = false; } } else { if((e.clientY - targetRect.top) / height > 0.5){ debug("下"); domPosition = true; }else{ debug("上"); domPosition = false; } } if(domPosition){ if(pparentNode.lastChild == that){ pparentNode.insertBefore(dragEl,that); }else{ pparentNode.insertBefore(dragEl,that.nextElementSibling); } }else{ that.parentNode.insertBefore(dragEl,that); } }, domdragleave:function (e) { var target = e.target; var targetClass = target.className; if(~targetClass.indexOf("sejtitle")){ target = target.parentNode; } target.classList.remove('drop-over'); }, domdrop:function (e) { debug("拖拽结束"); //dragEl.style.transformOrigin = "top center"; //dragEl.style.animation = "sejopen 0.3s"; // 重新绑定拖拽事件 SEJsetting.prototype.dragEvent(); return false; }, domdropend:function(){ var dom = document.querySelector(".drop-over"); if(dom){ dom.classList.remove("drop-over"); } }, // 判断是否能连接至google isOnline: function(){ console.log("this.online",this.online); if(this.online)return; var that = this; var myImage = new Image(); myImage.src = 'https://www.google.com/s2/favicons?domain=www.baidu.com&' + Math.random() ; setTimeout(function(){ // console.log("取消加载"); console.log(myImage.width); if(myImage.width){ that.online = true; }else{ myImage.src = undefined; // that.online = "哈哈"; } },2000); }, // 重新加载工具 reloadSet: function(){ var elems = document.querySelectorAll('#sej-container, sejspan.sej-drop-list'); if (!elems) return; console.log("elems: " + elems); // return; [].forEach.call(elems, function(elem) { elem.parentNode.removeChild(elem); }); iqxinstart(); iqxinShowTip("保存成功"); }, // 设置按钮透明度,靠左宽度,靠上宽度进度条 rangeChange: function(bool){ // console.log(this); console.log(bool); // if(bool){ var odombtn = document.querySelector("#setBtnOpacityRange"); odombtn.style.background = "-webkit-linear-gradient(left,#3ABDC1,#83e7ea) no-repeat, #fff"; odombtn.style.backgroundSize = odombtn.value*100 +"% 100%"; document.querySelector(".iqxin-setBtnOpacityRangeValue").innerHTML = odombtn.value*100 +"%"; getSettingData.setBtnOpacity = odombtn.value; var odomleft = document.querySelector("#leftRange"); odomleft.style.background = "-webkit-linear-gradient(left,#3ABDC1,#83e7ea) no-repeat, #fff"; odomleft.style.backgroundSize = odomleft.value*1 +"% 100%"; document.querySelector(".iqxin-leftRangeValue").innerHTML = odomleft.value +"%"; getSettingData.left = odomleft.value; var odomtop = document.querySelector("#topRange"); odomtop.style.background = "-webkit-linear-gradient(left,#3ABDC1,#83e7ea) no-repeat, #fff"; odomtop.style.backgroundSize = odomtop.value*2 +"% 100%"; document.querySelector(".iqxin-topRangeValue").innerHTML = odomtop.value +"%"; getSettingData.top = odomtop.value; // } }, // 窗口大小改变 windowResize: function(){ var eleStyle = window.getComputedStyle(this.ele , null); var w = parseInt(eleStyle.width) ; var h = parseInt(eleStyle.height) + 54; var ww = document.documentElement.clientWidth; var wh = document.documentElement.clientHeight; var maskStyle = this.mask.style; if(w>=ww){ maskStyle.justifyContent = "stretch"; }else{ maskStyle.justifyContent = "center"; } if(h>=wh){ maskStyle.alignItems = "stretch"; }else{ maskStyle.alignItems = "center"; } }, saveData: function(){ // this.addTitleEditBoxRemove(); //标题栏处于编辑状态 var obj = {}; var parentdiv = document.querySelectorAll("#settingLayer .iqxin-items"); for (let i=0;i=0?true:false; } // 新标签页全局设置 var onewtab = document.querySelector("#iqxin-globalNewtab").selectedIndex; //折叠搜索分类 var foldlist = document.querySelector("#iqxin-foldlist").checked; //隐藏按钮文字 var closetext = document.querySelector("#iqxin-closetext").checked; //开启动画 var animation = document.querySelector("#iqxin-animation").checked; // 工具条方向设置 var position = document.querySelector("#iqxin-prefs-position").selectedIndex; // 以防不测,重新获取本地配置文件 var getData = GM_getValue("searchEngineJumpData"); getData.newtab = onewtab; getData.position = position; getData.foldlist = foldlist; getData.closetext = closetext; getData.animation = animation; getData.setBtnOpacity = getSettingData.setBtnOpacity; getData.left = getSettingData.left; getData.top = getSettingData.top; getData.debug = document.querySelector("#iqxin-debug").checked; getData.fixedTop = document.querySelector("#iqxin-fixedTop").checked; getData.engineDetails = engineDetails; getData.engineList = obj; debug('将要保存的数据:',getData); GM_setValue("searchEngineJumpData",getData); }, addGlobalStyle: function(){ var head, style; var css = "#settingLayerMask{" + "display: none;" + "justify-content: center;" + "align-items: center;" + "position: fixed;" + "top:0; right:0; bottom:0; left:0;" + "background-color: rgba(130,130,130,.5);" + "z-index: 200000000;" + "overflow: auto;" + "font-family: arial,sans-serif;" + "min-height: 100%;" + "font-size:14px;" + "transition:0.5s;" + "opacity:0;" + "user-select: none;" + "-moz-user-select: none;" + //"padding-bottom: 80px;" + "box-sizing: border-box;" + "}" + "#settingLayer{" + "display: inline-block;" + "flex-wrap: wrap;" + "padding: 20px;" + "margin: 0px 5px 50px 5px;" + "background-color: #fff;" + "border-radius: 4px;" + "position: absolute;" + "min-width: 700px;" + "width: 70%;" + "transition:0.5s;" + "}" + ".iqxin-items{" + "min-width:50px;" + "margin: 20px 5px 20px 5px;" + "}" + "#settingLayer .drag{" + "float:left;" + "position: relative;" + "}" + "#settingLayer .sej-engine{" + "display: inline-block;" + "width: 100%;" + "box-sizing: border-box;" + "}" + ".iqxin-pointer-events," + ".sej-engine-icon," + ".sej-engine-icon-edit," + "#settingLayer .sej-engine *{" + "pointer-events:none;" + "}" + ".sejtitle{" + "float:left;" + "text-align: center;" + "padding: 58px 15px 2px 15px;" + "cursor: pointer;" + "position: relative;" + "}" + "#settingLayerMask [data-xin]{" + "margin:4px 0;" + "line-height:1.5;" + "border-radius:4px;" + "}" + ".sejtitle:not([data-xin^='-']):hover{" + "background:#cff9ff;" + "}" + ".sejcon [data-xin]{"+ "cursor: pointer;" + "}" + "#settingLayerMask .sej-engine:hover{" + "background-color:#cff9ff" + "}" + "#settingLayerMask [data-iqxindisabled='true']," + "[data-xin^='-']{" + "background-color: #ccc;" + "text-decoration: line-through;" + "text-decoration-color:red;" + "border-radius:2px;" + "transition:.3s;" + "}" + "#settingLayerMask [data-iqxindisabled='true']:hover," + "[data-xin^='-']:hover{" + "background-color: #ffa2a2;" + "}" + "#settingLayerMask label{" + "cursor:pointer;" + "}" + "#settingLayerMask .sej-engine-icon-edit{" + "vertical-align:middle;" + "}" + "#btnEle span{" + "display: inline-block;" + "background: #CCCCCC;" + "margin: 5px 2px 0 5px;" + "padding: 5px 10px;" + "border-radius: 4px;" + "cursor: pointer;" + "outline: none;" + "transition: 0.3s;" + "}" + "#btnEle a{" + "color: #999;" + "text-decoration: none;" + "}" + "#btnEle a:hover{" + "text-decoration: underline;" + "color: #ef8957;" + "}" + "#btnEle>div{" + "width: 100%;" + "display:block;" + "justify-content: space-around;" + "border-radius: 4px;" + "}" + ".drop-over{" + "opacity: 0.6;" + "}" + ".iqxin-title-edit," + ".iqxin-set-edit {" + "visibility: hidden;" + "opacity:0;" + "position: absolute;" + "background: rgba(135, 247, 141, 0.86);" + "color: red;" + "top: 0;" + "transform: translate(0,-50%);" + "left: 0;" + "padding: 3px 3px 3px 3px;" + "border-radius: 2px;" + "cursor: pointer;" + "transition: .3s;" + "}" + ".iqxin-set-title-del," + ".iqxin-set-del {" + "visibility: hidden;" + "opacity:0;" + "position: absolute;" + "background: rgba(135, 247, 141, 0.86);" + "color: red;" + "top: 0;" + "transform: translate(0,-50%);" + "right: 0;" + "padding: 3px 3px 3px 3px;" + "border-radius: 2px;" + "cursor: pointer;" + "transition: .3s;" + "}" + ".iqxin-set-title-del {" + "background: #f18d96;" + "}" + "span.iqxin-additem {" + "display: inline-block;" + "text-align: center;" + "margin: 10px 0;" + "border: 1px" + "color: red;" + "cursor: pointer;" + "visibility:hidden;" + "opacity:0;" + "transition:0.3s;" + "transform:scale(0);" + "}" + "#settingLayer .sejtitle:hover .iqxin-title-edit," + "#settingLayer .sejtitle:hover .iqxin-set-title-del," + "#settingLayer .sejcon:hover .iqxin-additem," + "#settingLayer .sejcon>span:hover .iqxin-set-edit," + "#settingLayer .sejcon>span:hover .iqxin-set-del{" + "visibility:visible;" + "opacity:0.8;" + "transform:scale(1);" + "}" + "#nSearchList {" + "opacity:0.3;" + "position:relative;" + "width: 50px;" + "margin: 20px 5px 20px 5px;" + "border-radius:4px;" + "cursor:pointer;" + "background:#fff;" + "}" + "#nSearchList:hover{" + "opacity:1;" + "}" + "#newSearchListBox," + "#newSearchBox{" + "transition:0.6s;" + "transform-origin: center center;" + "animation-timing-function: ease-in;" + "animation: iqxinsejopen 0.8s;" + "position:fixed;" + "z-index:200000100;" + "top:50%;" + "left:50%;" + "padding:22px;" + "background:rgb(29, 29, 29);" + "border-radius:4px;" + "color: #e8e8e8;" + "margin: -149px -117px;" + "}" + "#newSearchListBox input," + "#newSearchBox input{" + "border: none;" + "padding: 4px 0 4px 5px;" + "border-radius: 4px;" + "outline: none;" + "}" + "#newSearchListBox input:focus," + "#newSearchBox input:focus {" + "background: #f1d2d2;" + "transition: 0.5s;" + "}" + ".addItemBoxBtn{" + "cursor: pointer;" + "background: #fff;" + "border: none;" + "border-radius: 4px;" + "padding: 4px 10px;" + "color: #333;" + "transition:0.3s;" + "}" + "#titleEdit{" + "width:6em;" + "}" + // 按钮效果 : 确定 取消按钮 ".iqxin-closeBtn," + ".iqxin-enterBtn{" + "box-sizing: border-box;" + "}" + ".iqxin-closeBtn:hover{" + "background: #ff6565;" + "border-color: #ff6565;" + "color: #fff;" + "}" + ".iqxin-enterBtn:hover{" + "background: #84bb84;" + "border-color: #84bb84;" + "color: #fff;" + "}" + "#iqxin-editCodeBox button{" + "cursor:pointer;" + "}" + // 关闭按钮 "#xin-close{" + "background:white;" + "color:#3ABDC1;" + "line-height:20px;" + "text-align:center;" + "height:20px;" + "width:20px;" + "text-align:center;" + "font-size:20px;" + "padding:10px;" + "border: 3px solid #3ABDC1;" + "border-radius: 50%;" + "transition: .5s;" + "top: -20px;" + "right:-20px;" + "position: absolute;" + "}" + "#xin-close::before{" + "content:'\\2716';" + "}" + "#xin-close:hover{" + "background: indianred;" + "border-color: indianred;" + "color: #fff;" + "}" + // type[range] 效果 "input[type=range] {" + "outline: none;" + "-webkit-appearance: none;" + "background:-webkit-linear-gradient(left,#3ABDC1,#83e7ea) no-repeat, #fff;" + "border-radius: 10px; /*这个属性设置使填充进度条时的图形为圆角*/" + "}" + "input[type=range]::-webkit-slider-thumb {" + "-webkit-appearance: none;" + "} " + "input[type=range]::-webkit-slider-runnable-track {" + "height: 10px;" + "border-radius: 10px; /*将轨道设为圆角的*/" + "box-shadow: 0 1px 1px #def3f8, inset 0 .125em .125em #0d1112; /*轨道内置阴影效果*/" + "}" + "input[type=range]::-webkit-slider-thumb {" + "-webkit-appearance: none;" + "height: 18px;" + "width: 18px;" + "margin-top: -5px; /*使滑块超出轨道部分的偏移量相等*/" + "background: #fff; " + "border-radius: 50%; /*外观设置为圆形*/" + "border: solid 0.125em rgba(205, 224, 230, 0.5); /*设置边框*/" + "box-shadow: 0 .125em .125em #3b4547; /*添加底部阴影*/" + "}" + ""; head = document.getElementsByTagName('head')[0]; style = document.createElement('style'); style.type = 'text/css'; style.innerHTML = css; head.appendChild(style); } }; // 设置按钮相关:图标透明度 靠左宽度 靠上宽度 是否固定按钮 是否竖排还是水平排列搜索图标 是否开启动画 是否隐藏文字(当折叠搜索分类功能关闭时才能隐藏文字,避免隐藏搜索分类文字) var setBtnStyle = document.createElement('style'); setBtnStyle.type = 'text/css'; setBtnStyle.textContent = "#sej-container{" + "opacity:"+getSettingData.setBtnOpacity+";"+ "left:"+getSettingData.left+"%;"+ "top:"+getSettingData.top+"%;"+ (getSettingData.position?"width:50px;":"width:100%;") + (getSettingData.fixedTop?"position:fixed;":"position:absolute;") + (getSettingData.animation?"animation:sejopen 0.5s !important;":"") + (getSettingData.closetext && !getSettingData.foldlist?"font-size:0;":"") + "}" + "#sej-container:hover{" + "opacity:1;" + "}" + ""; //插入设置按钮 var setBtn = document.createElement("span"); setBtn.id = "setBtn"; iTarget.parentNode.insertBefore(setBtnStyle, iTarget); //插入head和body之间 setBtn.innerHTML = ""; document.querySelector("#sej-container").appendChild(setBtn); var sejSet = null; setBtn.addEventListener("click",setBtnStart); // 注册菜单 GM_registerMenuCommand("search jump 搜索跳转设置",setBtnStart); function setBtnStart(){ if(!document.querySelector("#settingLayerMask")){ sejSet = new SEJsetting(); var sej_save = document.querySelector("#xin-save"); var sej_save_close = document.querySelector("#xin-save-close"); var odombtn = document.querySelector("#setBtnOpacityRange"); var odomleft = document.querySelector("#leftRange"); var odomtop = document.querySelector("#topRange"); var sej_edit = document.querySelector("#xin-modification"); // sej_save.addEventListener("click",function(){sejSet.saveData();sejSet.hide();if(!getSettingData.debug)window.location.reload();}); sej_save.addEventListener("click",function(){sejSet.saveData();sejSet.reloadSet();}); sej_save_close.addEventListener("click",function(){sejSet.saveData();sejSet.hide();sejSet.reloadSet();}); odombtn.addEventListener("click",function(){sejSet.saveData();sejSet.reloadSet();}); odomleft.addEventListener("click",function(){sejSet.saveData();sejSet.reloadSet();}); odomtop.addEventListener("click",function(){sejSet.saveData();sejSet.reloadSet();}); // sej_reset.addEventListener("click",function(){sejSet.reset();sejSet.hide();window.location.reload();}); sej_edit.addEventListener("click",function(){sejSet.editCodeBox();}); window.addEventListener("resize",sejSet.windowResize.bind(sejSet)); } sejSet.show(); } // 获取存储的数据信息 function get_data(){ setData = GM_getValue("searchEngineJumpData"); } var setData = null; // get_data(); } // 从此处开始执行 var debug; function reloadDebug(bool) { debug = bool ? console.info.bind(console) : function() {}; } // 消息提示框 // 目前只是为了给用户一个反馈。 - 成功了么 - 嗯,成功了 var iqxinTimerGlobalTip = null; function iqxinShowTip(text,duration){ console.log("iqxin -- 消息提示框: ", text); var odom = document.querySelector("#iqixn-global-tip"); if(!odom){ odom = document.createElement("iqxinDiv"); odom.id = "iqixn-global-tip"; odom.style.cssText = "" + "opacity: 0;" + "height: 25px;" + "line-height: 25px;" + "letter-spacing: 1px;" + "font-size: 1em;" + "color: #fff;" + "padding: 5px 20px;" + "border-radius: 5px;" + "background-color: #666;" + "position: fixed;" + "z-index: 200000001;" + "left: 50%;" + "bottom: 5%;" + "transform: translate(-50%);" + "transition: .4s;" ; document.body.appendChild(odom); } odom.innerHTML=text; odom.style.opacity=1; duration = duration?duration:1500; //防止持续时间内多次触发提示 if(!iqxinTimerGlobalTip){ iqxinTimerGlobalTip = setTimeout(function(){ odom.style.opacity=0; iqxinTimerGlobalTip = null; },duration); } } // console.log("普通插入"); iqxinstart(); })();