您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Popup search box and translate button (etc) for selected texts
当前为
// ==UserScript== // @name Popup Search // @author lkytal // @namespace Lkytal // @homepage https://lkytal.github.io/ // @description Popup search box and translate button (etc) for selected texts // @include * // @exclude */test/*.html* // @exclude http://acid3.acidtests.org/* // @exclude http://www.acfun.tv/* // @require https://cdn.bootcss.com/jquery/3.1.1/jquery.min.js // @version 3.5.0 // @icon http://lkytal.qiniudn.com/ic.ico // @grant GM_xmlhttpRequest // @grant GM_addStyle // @grant unsafeWindow // @grant GM_openInTab // @grant GM_setClipboard // @grant GM_download // @grant GM_getValue // @grant GM_setValue // @grant GM_registerMenuCommand // @charset UTF-8 // @homepageURL https://git.oschina.net/coldfire/GM // ==/UserScript== "use strict"; var CopyText, GetOpt, InTextBox, Init, Load, OpenSet, SaveOpt, SetOpt, SettingWin, ShowBar, TimeOutHide, addCSS, fixPos, getLastRange, get_selection_offsets, isChrome, log, popData, praseTranslation, praseTranslationMore, hasProp = {}.hasOwnProperty; window.$ = this.$ = this.jQuery = jQuery.noConflict(true); popData = { count: 0, mouseIn: 0, bTrans: 0, text: "", icons: { baiduIcon: "", bingIcon: "", translateIcon: "", googleIcon: "", ieIcon: "", inSiteIcon: '', tipdown: "", tipup: "", pending: "" }, optionList: [ { id: "Google_st", text: "Google搜索", defaultValue: 1 }, { id: "Bing_st", text: "Bing搜索", defaultValue: 1 }, { id: "Baidu_st", text: "Baidu搜索", defaultValue: 1 }, { id: "Site_st", text: "站内搜索按钮", defaultValue: 1 }, { id: "Fade_st", text: "超时自动隐藏", defaultValue: 1 }, { id: "Dis_st", text: "显示于文字上方", defaultValue: 1 }, { id: "Tab_st", text: "新标签页打开", defaultValue: 1 }, { id: "Focus_st", text: "前台标签页打开", defaultValue: 1 }, { id: "Iframe_st", text: "在Iframe中显示", defaultValue: 0 }, { id: "Copy_st", text: "自动复制选中文字", defaultValue: 0 }, { id: "Open_st", text: "打开选中文本按钮", defaultValue: 0 }, { id: "Ctrl_st", text: "仅按下Ctrl时显示", defaultValue: 0 } ] }; popData.engines = [ { id: "openurl", title: "Open Url", setId: 'Open_st', src: popData.icons.ieIcon, href: '${rawText}' }, { id: "sSite", title: "In Site Search", setId: 'Site_st', src: popData.icons.inSiteIcon, href: 'https://www.google.com/search?newwindow=1&safe=off&q=${text}%20site:${domain}' }, { id: "sbaidu", title: "Baidu", setId: 'Baidu_st', src: popData.icons.baiduIcon, href: 'https://www.baidu.com/s?wd=${text}&ie=utf-8' }, { id: "sbing", title: "Bing", setId: 'Bing_st', src: popData.icons.bingIcon, href: 'https://bing.com/search?q=${text}&form=MOZSBR' }, { id: "sgoogle", title: "Google", setId: 'Google_st', src: popData.icons.googleIcon, href: 'https://www.google.com/search?newwindow=1&safe=off&q=${text}' } ]; log = function(msg) { popData.count += 1; return console.log("MsgId " + popData.count + " : " + msg); }; isChrome = function() { if ((typeof GM_download !== "undefined" && GM_download !== null) || navigator.userAgent.indexOf("Chrome") > -1) { return true; } }; fixPos = function(sel, e) { var eventLeft, eventTop, fix, m_left, offsetLeft, offsetTop, offsets; offsets = get_selection_offsets(sel); offsetTop = offsets[0]; offsetLeft = offsets[1]; if (e != null) { eventTop = e.pageY; eventLeft = e.pageX; if (Math.abs(offsetTop - eventTop) > 50) { offsetTop = eventTop - 8; } if (Math.abs(offsetLeft - eventLeft) > 50) { offsetLeft = eventLeft + 10; } } else { $('#showupbody').css('margin-left', '60px'); } if (GetOpt('Dis_st')) { offsetTop = offsetTop - 2 - $('#ShowUpBox').height(); if ((offsetTop - document.documentElement.scrollTop) < 40) { offsetTop = document.documentElement.scrollTop + 40; } } else { offsetTop += 1.1 * offsets[2]; } m_left = $('#ShowUpBox').width(); fix = 0; if (offsetLeft - m_left < 4) { fix = 4 - offsetLeft + m_left; } $('#ShowUpBox').css("top", offsetTop + "px").css("left", (offsetLeft - m_left + fix) + "px"); return $('#popuptip').css('margin-left', m_left - 20 - fix); }; $(document).mousedown(function(event) { if (popData.bTrans === 1) { Init(); } return $('#ShowUpBox').hide(); }); TimeOutHide = function() { if (popData.mouseIn === 0 && GetOpt("Fade_st") && !popData.bTrans) { return $('#ShowUpBox').fadeOut(600); } }; Init = function() { var $DivBox, EngineList, EngineSelector, engine, i, j, len, len1, ref, ref1; $('#ShowUpBox').remove(); EngineList = "<a id='gtrans' href=''><img title='Translate' src='" + popData.icons.translateIcon + "' /></a>"; ref = popData.engines; for (i = 0, len = ref.length; i < len; i++) { engine = ref[i]; EngineList += "<a id='" + engine.id + "' href=''><img title='engine.title' src='" + engine.src + "' /></a>"; } $('body').append("<span id=\"ShowUpBox\"> <span id=\"showupbody\"> <span id=\"popupwapper\"> " + EngineList + " </span> <span id=\"Gspan\" /> </span> </span>"); $DivBox = $('#ShowUpBox'); $DivBox.hide(); $DivBox.on("click mousedown dblclick mouseup", function(event) { return event.stopPropagation(); }); $DivBox.hover(function() { $(this).fadeTo(150, 1); return popData.mouseIn = 1; }, function() { if (popData.bTrans === 0 && $(this).is(":visible") && $(this).attr("opacity") === 1) { $(this).fadeTo(300, 0.7); clearTimeout(popData.timer); popData.timer = setTimeout(TimeOutHide, 6000); } return popData.mouseIn = 0; }); $('#popupwapper').on("mouseup", function(event) { if (event.which === 3) { CopyText(); $('#ShowUpBox').fadeOut(200); return false; } else if (event.which === 2) { GM_openInTab(document.defaultView.getSelection().toString()); return false; } }); $('#popupwapper').on("contextmenu", function(event) { return false; }); EngineSelector = ((function() { var j, len1, ref1, results; ref1 = popData.engines; results = []; for (j = 0, len1 = ref1.length; j < len1; j++) { engine = ref1[j]; results.push("#" + engine.id); } return results; })()).join(','); $(EngineSelector).on("click", function(e) { if (isChrome()) { GM_openInTab($(this).attr('href'), { active: GetOpt("Focus_st") === 1 }); } else { GM_openInTab($(this).attr('href'), !GetOpt("Focus_st")); } $('#ShowUpBox').fadeOut(200); return false; }); ref1 = popData.engines; for (j = 0, len1 = ref1.length; j < len1; j++) { engine = ref1[j]; if (!GetOpt(engine.setId)) { $("#" + engine.id).hide(); } } if (GetOpt('Tab_st')) { $DivBox.find('a').attr('target', '_blank'); } else { $DivBox.find('a').attr('target', '_self'); } $('#gtrans').on("click", function(event) { var callback; event.preventDefault(); popData.bTrans = 1; $("#Gspan").empty().append("<div style='padding:10px;'><img src='" + popData.icons.pending + "' /></div>").show(); $('#popupwapper').hide(); fixPos(document.defaultView.getSelection()); callback = function(err) { return $('#Gspan').empty().append("Translate Error:\n" + err).show(); }; if (popData.text.length < 380) { return GM_xmlhttpRequest({ method: 'GET', timeout: 3000, url: "http://fanyi.youdao.com/openapi.do?keyfrom=tinxing&key=1312427901&type=data&doctype=json&version=1.1&q=" + popData.text, onload: praseTranslation, onerror: callback, ontimeout: callback }); } else { return GM_xmlhttpRequest({ method: 'GET', timeout: 3000, url: "http://fanyi.baidu.com/transapi?from=auto&to=auto&query=" + popData.text, onload: praseTranslationMore, onerror: callback, ontimeout: callback }); } }); if (GetOpt('Dis_st')) { popData.tip = popData.tipup; return $DivBox.append('<span id="popuptip" class="tipup"></span>'); } else { popData.tip = popData.tipdown; return $DivBox.prepend('<span id="popuptip" class="tipdown"></span>'); } }; praseTranslation = function(responseDetails) { var Result, Rline, Rst, Rtxt, i, j, len, len1, lines, ref, ref1; if (!popData.bTrans) { return; } Rtxt = JSON.parse(responseDetails.responseText); Rline = ""; ref = Rtxt.translation; for (i = 0, len = ref.length; i < len; i++) { lines = ref[i]; Rline += lines + "<br>"; } Rst = ""; if (Rtxt.basic != null) { ref1 = Rtxt.basic.explains; for (j = 0, len1 = ref1.length; j < len1; j++) { lines = ref1[j]; Rst = lines + "<br>"; } } Result = "<div id=\"tranRst\" style=\"font-size:13px;overflow:auto;padding:5px 15px;\"> <div style=\"line-height:160%;font-size:14px;padding:5px 0px;\">" + Rline + "</div> <p style=\"line-height:180%;font-size:13px;\"> " + Rst + " </p> </div>"; $('#Gspan').empty().append(Result).show(); fixPos(document.defaultView.getSelection()); }; praseTranslationMore = function(responseDetails) { var Result, Rline, Rtxt, i, len, lines, ref; if (!popData.bTrans) { return; } Rtxt = JSON.parse(responseDetails.responseText); Rline = ""; ref = Rtxt.data; for (i = 0, len = ref.length; i < len; i++) { lines = ref[i]; Rline += lines.dst + "<br>"; } Result = "<div id=\"tranRst\" style=\"font-size:13px;overflow:auto;padding:5px 15px;\"> <p style=\"line-height:180%;font-size:13px;\"> " + Rline + " </p> </div>"; $('#Gspan').empty().append(Result).show(); fixPos(document.defaultView.getSelection()); }; $(document).on("mouseup", function(event) { if (event.which !== 1) { return; } if (GetOpt('Ctrl_st') && !event.ctrlKey) { return; } return ShowBar(event); }); InTextBox = function(selection) { var area, i, len, ref; ref = $('textarea, input[type=text], *[contenteditable="true"]', document); for (i = 0, len = ref.length; i < len; i++) { area = ref[i]; if (selection.containsNode(area, true)) { return true; } } return false; }; ShowBar = function(event) { var engine, href, i, len, para, paraList, ref, sel, seltxt, value; sel = document.defaultView.getSelection(); seltxt = sel.toString(); if (seltxt === '' || InTextBox(sel)) { return; } if (GetOpt("Copy_st")) { CopyText(seltxt); } popData.text = encodeURIComponent(seltxt); $('#Gspan').empty().hide(); paraList = { "\\${text}": popData.text, "\\${rawText}": seltxt, "\\${domain}": document.domain, "\\${url}": location.href }; ref = popData.engines; for (i = 0, len = ref.length; i < len; i++) { engine = ref[i]; href = engine.href; for (para in paraList) { if (!hasProp.call(paraList, para)) continue; value = paraList[para]; href = href.replace(RegExp("" + para, "g"), value); } $("#" + engine.id).attr("href", href); } popData.mouseIn = 0; popData.bTrans = 0; clearTimeout(popData.timer); popData.timer = setTimeout(TimeOutHide, 6000); fixPos(sel, event); return $('#ShowUpBox').css('opacity', 0.9).fadeIn(150); }; CopyText = function(seltxt) { var e; if (seltxt == null) { seltxt = document.defaultView.getSelection().toString(); } try { return GM_setClipboard(seltxt, "text"); } catch (error) { e = error; if (GetOpt("Copy_st")) { alert("ERROR: Auto copying not supported and will be disabled now"); return SetOpt("Copy_st", 0); } } }; GetOpt = function(id) { return $("#" + id).data('val'); }; SetOpt = function(id) { var $dom, val; $dom = $("#" + id); val = GM_getValue(id); if (!val) { $dom.addClass('close'); } $dom.data('val', val); return $dom.click(function() { $(this).toggleClass('close'); if ($(this).data('val') === 1) { return $(this).data('val', 0); } else { return $(this).data('val', 1); } }); }; SaveOpt = function(id) { return GM_setValue(id, $("#" + id).data('val')); }; OpenSet = function() { if ($('#popup_setting_bg').length === 0) { SettingWin(); } return $('#popup_setting_bg').fadeIn(400); }; SettingWin = function() { var i, item, len, option, optionList, ref; $('#popup_setting_bg').remove(); optionList = ((function() { var i, len, ref, results; ref = popData.optionList; results = []; for (i = 0, len = ref.length; i < len; i++) { option = ref[i]; results.push("<span id='" + option.id + "'>" + option.text + "</span>"); } return results; })()).join(' '); $("body").append("<div id='popup_setting_bg'> <div id='popup_setting_win'> <div id='popup_title'>PopUp Search 设置</div> <div id='pop_st_wapper'> <div id='option_box'> " + optionList + " </div> <br> <div id='btnarea'> <div id='popup_tip'>可在GreaseMonkey'用户脚本命令'菜单下的'Popup Search设置'打开此选项</div> <div id='popup_close' class='setting_btn'>Close</div> <div id='popup_save' class='setting_btn'>Save</div> </div> </div> </div> </div>"); $("#option_box > span").addClass("setting_sp_btn"); ref = $("#popup_setting_win .setting_sp_btn"); for (i = 0, len = ref.length; i < len; i++) { item = ref[i]; if (item != null) { SetOpt(item.id); } } $("#popup_save").click(function() { var j, len1, ref1; ref1 = $("#popup_setting_win .setting_sp_btn"); for (j = 0, len1 = ref1.length; j < len1; j++) { item = ref1[j]; if (item != null) { SaveOpt(item.id); } } return $("#popup_setting_bg").fadeOut(300, function() { $("#popup_setting_bg").remove(); SettingWin(); $('#ShowUpBox').remove(); return Init(); }); }); $("#popup_close, #popup_setting_bg").click(function() { return $("#popup_setting_bg").fadeOut(300, function() { $("#popup_setting_bg").remove(); return SettingWin(); }); }); $('#popup_setting_win').click(function(e) { return e.stopPropagation(); }); return $('#popup_setting_bg').hide(); }; Load = function() { var UpdateAlert, i, len, option, popupmenu, ref; if (window.self !== window.top || window.frameElement) { if (!GM_getValue("Iframe_st", 0)) { return; } } addCSS(); UpdateAlert = GM_getValue("UpdateAlert", 0); if (UpdateAlert < 6) { GM_setValue("UpdateAlert", 6); ref = popData.optionList; for (i = 0, len = ref.length; i < len; i++) { option = ref[i]; GM_setValue(option.id, GM_getValue(option.id, option.defaultValue)); } OpenSet(); } else { SettingWin(); } Init(); GM_registerMenuCommand("Popup Search设置", OpenSet, 'p'); if (GM_getValue("PopupMenu", 0)) { popupmenu = document.body.appendChild(document.createElement("menu")); popupmenu.outerHTML = '<menu id="userscript-popup" type="context"><menuitem id="Popupset" label="Popup Search设置"></menuitem></menu>'; document.querySelector("#Popupset").addEventListener("click", OpenSet, false); return $(document).on("contextmenu", function() { return document.body.setAttribute("contextmenu", "userscript-popup"); }); } }; setTimeout(Load, 100); addCSS = function() { return GM_addStyle("#ShowUpBox { all: unset; width: auto; height: auto; position: absolute; z-index: 102400000; display: inline-block; line-height: 0; vertical-align: baseline; box-sizing: content-box; } #showupbody { min-width: 20px; max-width: 750px; min-height: 20px; max-height: 500px; display: block; border:solid 2px rgb(144,144,144); border-radius:1px; background:rgba(252, 252, 252, 1); } #popupwapper { margin: 3px 2px 3.8px 2px; display:block; line-height: 0; font-size:0; } #Gspan { line-height: normal; width: auto; font-size: 16px; overflow: auto; display: none; } #ShowUpBox img { margin: 0px 2px; height: 22px; width: 22px; border-radius: 0px; padding: 0px; display: inline-block; transition-duration: 0.1s; -moz-transition-duration: 0.1s; -webkit-transition-duration: 0.1s; } #ShowUpBox img:hover { margin: -1px 1px -1px 1px; height: 24px; width: 24px; } #popuptip { display:inline-block; clear:both; height:9px; width:9px; } .tipup { background: url(" + popData.icons.tipup + ") 0px 0px no-repeat transparent; margin-top: -2px; margin-bottom: 0px; } .tipdown { background: url(" + popData.icons.tipdown + ") 0px 0px no-repeat transparent; margin-top: 0px; margin-bottom: -2px; } #ShowUpBox a { text-decoration: none; display:inline-block; } #popup_setting_bg { all: unset; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.2); position: fixed; left: 0px; top: 0px; z-index:102400; display: none; display:flex; justify-content:center; align-items: center; } #popup_setting_win { all: unset; text-align: justify; box-shadow:0 0 10px #222; z-index:102400; width: 720px; box-sizing: content-box !important; background: rgba(255, 255, 255, 0.98); font-family: \"Hiragino Sans GB\", \"Microsoft Yahei\", Arial, sans-serif; -moz-user-select: none; -webkit-user-select: none; } #popup_title { font-size:26px; text-align:center; padding: 20px; } #pop_st_wapper { padding:10px 40px 25px 40px; } #option_box { display: -webkit-flex; display: flex; justify-content: space-between; flex-wrap: wrap; } #btnarea { display: -webkit-flex; display: flex; justify-content: flex-start; align-items: flex-end; flex-wrap: wrap; } #popup_tip { display:inline-block; font-size:11px; color:red; flex-grow: 1 } .setting_btn { display: inline-block; font-size: 16px; text-align: center; border: 2px solid #20CC66; width: 50px; padding: 4px 10px; border-radius: 2px; margin: 0px 0px 0px 20px; color: #20CC66; } .setting_btn:hover { box-shadow: 0px 0px 1px #20CC66; } .setting_sp_btn { width: 160px; height: 18px; font-size: 14px; padding: 4px; cursor:default; position:relative; margin: 10px 0px; display:inline-block; } .setting_sp_btn:hover { box-shadow: 0px 0px 5px #DDD; background:#DDD; } .setting_sp_btn:active { box-shadow:0 0 3px #999 inset; } .setting_sp_btn::before { position: absolute; right:0px; top:0px; content:\" \"; width:26px; height:26px; background: #6B4; transition-duration: 0.2s; -moz-transition-duration: 0.2s; -webkit-transition-duration: 0.2s; } .setting_sp_btn.close { border:none; background:#DDD; } .setting_sp_btn.close::before { background:#C54; }"); }; getLastRange = function(selection) { var i, rangeNum, ref; for (rangeNum = i = ref = selection.rangeCount - 1; ref <= 0 ? i <= 0 : i >= 0; rangeNum = ref <= 0 ? ++i : --i) { if (!selection.getRangeAt(rangeNum).collapsed) { return selection.getRangeAt(rangeNum); } } return selection.getRangeAt(selection.rangeCount - 1); }; get_selection_offsets = function(selection) { var $test_span, Rect, lastRange, newRange; $test_span = $('<span style="display:inline;">x</span>'); lastRange = getLastRange(selection); newRange = document.createRange(); newRange.setStart(lastRange.endContainer, lastRange.endOffset); newRange.insertNode($test_span[0]); Rect = $test_span[0].getBoundingClientRect(); $test_span.remove(); return [Rect.top + window.scrollY, Rect.left + window.scrollX, 0, 0]; };
QingJ © 2025
镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址