// ==UserScript==
// @name AC-双击选中高亮
// @icon https://coding.net/u/zb227/p/zbImg/git/raw/master/img0/icon.jpg
// @namespace ntaow.com
// @version 2.4
// @include *
// @copyright 2018, AC
// @description 双击选中高亮 或者 普通选中后按G高亮
// @note 2018.05.15-V2.4 修复某些分词的问题,现在分词应该足够可以用了
// @note 2018.03.26-V2.3 更新,根据TamperMonkey的函数修复了复制操作的代码
// @note 2018.03.18-V2.2 更新,新增了点击之后复制的效果
// @note 2017.12.06-V2.1 修复一个小bug,导致abc_def高亮出问题,同时优化了以前的移除规则,避免了对原始html的影响-待测试
// @note 2017.11.03-V1.2 修复双击触发的问题以及选中文字的问题
// @note 2017.09.06-V1.1 第一版本
// @grant GM_setClipboard
// @downloadURL https://update.greasyfork.icu/scripts/36057/AC-%E5%8F%8C%E5%87%BB%E9%80%89%E4%B8%AD%E9%AB%98%E4%BA%AE.user.js
// @updateURL https://update.greasyfork.icu/scripts/36057/AC-%E5%8F%8C%E5%87%BB%E9%80%89%E4%B8%AD%E9%AB%98%E4%BA%AE.meta.js
// ==/UserScript==
document.addEventListener('dblclick', DoHighLight, false);
document.addEventListener('mouseup', DoHighLight, false);
document.addEventListener('keyup', DoHighLight, false);
var isDBClickOn = true;
var enableCharCode = 'G';
var keySets = new Object();
var counter = 0;
var isInDebug = false;
var colorList = ["#FFFF80", "#89c3fa", "#f95f52"];
function DoHighLight(e) {
var target = e.target;
var selectedText = getSelectedText(target);
var s_dblclick = (e.type === 'dblclick')&&isDBClickOn; // 是双击选中
var s_keyup = (e.type === 'keyup') && (enableCharCode.charCodeAt(0)==e.keyCode);// 是按下特殊按键
if (selectedText && getBLen(selectedText) >= 3) {
myConsoleLog(selectedText)
if (s_keyup){
doHighLightTextS(selectedText);
}else if (s_dblclick) {
doHighLightTextS(selectedText);
}
}
}
function myConsoleLog(text){
if(isInDebug){
console.log(text);
}
}
function doHighLightTextS(selectedText) {
unHighLightAll_Text();
myConsoleLog("双击:" + selectedText);
GM_setClipboard(selectedText);
initKeySets(selectedText);
myConsoleLog(keySets.keywords);
doHighLightAll_CSS();
doHighLightAll_Text();
}
function getSelectedText(target) {
function getTextSelection() {
var selectedText = '';
if (target.getAttribute("type")) {
if (target.getAttribute("type").toLowerCase() === "checkbox") return '';
}
var value = target.value;
if (value) {
var startPos = target.selectionStart;
var endPos = target.selectionEnd;
if (!isNaN(startPos) && !isNaN(endPos)) selectedText = value.substring(startPos, endPos);
return selectedText;
} else return '';
}
var selectedText = window.getSelection().toString();
if (!selectedText) selectedText = getTextSelection();
myConsoleLog(selectedText);
return selectedText;
}
function getBLen(str) {
if (str == null) return 0;
if (typeof str != "string"){
str += "";
}
return str.replace(/[^\x00-\xff]/g,"01").length;
}
// 初始化点击的文字信息
function initKeySets(selection){
// 1.split通过特殊字符和字符边界分割串[非[0-9A-Za-z]特殊字符]
// 2.通过特定字符连接原始串,
// 3.1移除多次重复的特定串,非常用串移除,避免空串
// 3.2移除开头或者结尾的特定串,避免分割后出现空白数据,
// 4.按特定串分割
keySets.keywords = selection
.split(/\b |[\u0000-\u002F\u003A-\u0040\u005B-\u0060\u007B-\u00FF\uFF00-\uFFFF\u3000-\u303F]/g)
.join('ACsCA')
.replace(/[^\u4E00-\u9FA5|0-9|a-z|A-Z_]+/g, "")
.replace(/(ACsCA){2}/g, "ACsCA")
.replace(/(^ACsCA|ACsCA$)/g, "")
.split("ACsCA");
keySets.length = keySets.keywords.length;
keySets.textcolor = new Array();
// keySets.backcolor = new Array();
keySets.visible = new Array();
for(var i=0; i < keySets.keywords.length; i++){
keySets.textcolor[i] = "rgb(0,0,0)";
// keySets.backcolor[i] = colorList[i % colorList.length];
keySets.visible[i] = "true";
}
}
function doHighLightAll_CSS(){ // 顶部的那一堆数组
if (keySets.visible[0] == "true"){
var rule = ".acWHSet{display:inline!important;";
if (keySets.textcolor.length > 0) rule += "color:"+keySets.textcolor[0]+";";
// if (keySets.backcolor.length > 0) rule += "background-color:"+keySets.backcolor[0]+";";
rule += "font-weight:inherit;}";
for(var i = 0; i < keySets.keywords.length; i++){
rule += ".acWHSet[data='"+keySets.keywords[i]+"']{background-color:"+colorList[i % colorList.length]+";}";
}
var setrule = document.querySelector('style[hlset="acWHSet"]');
if (!setrule){
var s = document.createElement("style");
s.type = "text/css";
s.setAttribute("hlset", "acWHSet");
s.appendChild(document.createTextNode(rule));
document.body.appendChild(s);
} else {
setrule.innerHTML = rule;
}
}
}
function doHighLightAll_Text(){
if(keySets.keywords.length == 0) return;
var patExp = "";
for(var index=0; index/g, '>').replace(pat, '$1');
sp.innerHTML = repNodeHTML;
node.parentNode.replaceChild(sp, node);
// try to un-nest containers
if (sp.parentNode.hasAttribute("thdcontain")) sp.outerHTML = sp.innerHTML;
}
}
}
function unHighLightAll_Text(){
var tgts = document.querySelectorAll('thdfrag[txhidy15="acWHSet"]');
for (var i=0; i/g, '>');
tgtspan = parpar;
} else {
tgts[i].outerHTML = tgts[i].textContent.replace(//g, '>');
tgtspan = parnode;
}
tgtspan.normalize(); // 不影响显示,但是影响html内部文字排版---》new 不影响html结果了
if (tgtspan.hasAttribute("thdcontain")){
parnode = tgtspan.parentNode;
if (parnode){
if (parnode.hasAttribute("thdcontain") && parnode.innerHTML == tgtspan.outerHTML && tgtspan.querySelectorAll('thdfrag[txhidy15]').length == 0){
parnode.outerHTML = tgtspan.innerHTML;
} else if (parnode.innerHTML == tgtspan.outerHTML && tgtspan.querySelectorAll('thdfrag[txhidy15]').length == 0) {
parnode.innerHTML = tgtspan.innerHTML;
}
}
}
}
var oldTgs = document.querySelectorAll("thdfrag[thdcontain='true']");
counter = 0;
for(var i=0; i < oldTgs.length; i++){
var curTg = oldTgs[i];
markChildandRemove(curTg);
}
myConsoleLog("次数是:"+counter);
}
function markChildandRemove(node){
try{
if(node.tagName.toLowerCase() == "thdfrag"){
myConsoleLog("this?"+node.innerHTML);
node.outerHTML = node.innerHTML;
}
var childList = node.childNodes;
for(var i=0; i < childList.length; i++){
counter++;
myConsoleLog(node.tagName+'--prein');
var node = childList[i];
myConsoleLog(node.tagName+'--in');
markChildandRemove(node);
myConsoleLog(node.tagName+'--out');
if(node.tagName.toLowerCase() == "thdfrag"){
myConsoleLog("this?"+node.innerHTML);
node.outerHTML = node.innerHTML;
}
}
}catch (e){}
}