您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Easier to read and view corrections in the "All Corrections" view. - https://greasyfork.org/en/users/3656-kaiko
当前为
// ==UserScript== // @name Lang-8 - "All Corrections" View Enhancer // @namespace Lang8LTR // @description Easier to read and view corrections in the "All Corrections" view. - https://greasyfork.org/en/users/3656-kaiko // @include http://lang-8.com/*/journals/* // @include https://lang-8.com/*/journals/* // @version 1 // @grant none // ==/UserScript== /* Remove strike-through text on corrections, "All Corrections" view and default. All Corrections View: Expands the view more dynamically for larger displays. Removes "No correction needed" green text messages. Re-injects the comment icon for comments, as they didn't always appear. Absurd hacked in feature: Removes corrections that are the same as your entry's sentence, but not duplicates of the same correction from others) Removes empty 'correct' fields that overlap their icons and spacing. Removes unnecessary and large spacing between corrections. Inserts a grey background for corrections to differentiate them from your written entry. */ function resizeAllCorrectionsWindow(){ var allCorrectionsParent = document.getElementById("allCorrectionsPanel_c"); var allCorrections = document.getElementById("allCorrectionsPanel"); var heightBox = allCorrections.getElementsByClassName("bd")[0]; if (allCorrectionsParent){ //Resize the window var w = Math.max(document.documentElement.clientWidth, window.innerWidth || 0); var h = Math.max(document.documentElement.clientHeight, window.innerHeight || 0); allCorrections.style.width = w/1.5 + "px"; heightBox.style.height = h/1.5 + "px"; //ReCenter it allCorrectionsParent.style.left = "16.5%"; allCorrectionsParent.style.top = parseFloat("100%") + document.documentElement.scrollTop + "px"; } } window.onresize = resizeAllCorrectionsWindow; // Credit: https://stackoverflow.com/a/6318729 RegExp.escape = function(text) { return text.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&"); } document.getElementById("showAll").onclick = function showallexecuteLineThroughRemoval() { resizeAllCorrectionsWindow(); var allCorrectionsParent = document.getElementById("allCorrectionsPanel_c"); var allCorrections = document.getElementById("allCorrectionsPanel"); var heightBox = allCorrections.getElementsByClassName("bd")[0]; //Remove "All Corrections" line-through var b = allCorrections.getElementsByTagName("span"); for (i = 0; i < b.length; ++i) { if (b[i].style.textDecorationLine){ b[i].innerHTML = ""; } } //Remove duplicate non-corrected lines from our entry, for further readability and less confusion //Hacked-in absurdly as Lang-8's developers didn't correctly use tags around our written text, and corrections. var bc = allCorrections.textContent; var bd = allCorrections.getElementsByClassName("correct"); //First, convert our HTMLCollection content to an array var arr = []; for (i = 0; i < bd.length; ++i){ arr.push(bd[i].textContent); } //Sort it var sortedArr = arr.sort(); var tempMatchObj = {}; var tempMatches = 0; //Find duplicates and add it to a key:value object, along with an int of how many of that duplicate we had for (i = 0; i < sortedArr.length; ++i){ if (sortedArr[i] === sortedArr[i+1]){ tempMatches+=1; //console.log(tempMatches); tempMatchObj[sortedArr[i]] = tempMatches; } else if (sortedArr[i] != sortedArr[i-1]){ tempMatches = 1; tempMatchObj[sortedArr[i]] = tempMatches; } } //Check this int of duplicate matches against the entirety of the html content //If we have more matches of the same than our corrections did, then remove the correction as that's the same sentence written by the author //Else, keep the correction since more than one corrector has corrected the same mistakes in the same way, creating a duplicate - which we keep for sanity. for(key in tempMatchObj) { if(tempMatchObj.hasOwnProperty(key)) { var innerValue = tempMatchObj[key]; var toMatch = RegExp.escape(key); var outterValue = (bc.match(toMatch, 'g')||[]).length; if (outterValue > innerValue){ //console.log(key +" "+outterValue); //console.log(key +" "+innerValue); for (i = 0; i < bd.length; ++i) { //console.log(textContent); //console.log(key); if (bd[i].textContent == key){ bd[i].textContent = "-"; } } } } } //Remove default NoCorrectionNecessary message var c = allCorrections.getElementsByClassName("corrected perfect"); for (i = 0; i < c.length; ++i) { c[i].innerHTML = ""; } //Remove empty 'correct' fields var e = allCorrections.getElementsByClassName("correct"); for (i = 0; i < e.length; ++i) { if (e[i].textContent == ''){ e[i].className = ''; } } //Reinsert comment image next to comments since they don't always have one var d = allCorrections.getElementsByClassName("correction_comment"); for (var i = d.length; i--;) { d[i].innerHTML = '  <img src="" />' + ' ' + d[i].innerHTML + '<br />'; d[i].style.backgroundColor = "#E5E5E5"; d[i].className = " "; d = allCorrections.getElementsByClassName("correction_comment"); } //Remove some unnecessary spacing var toRep = heightBox.innerHTML; var toRepB = toRep.replace(/<br>/g, ""); var toRepC = toRepB.replace(/<p><\/p>/g, ""); var toRepD = toRepC.replace(/<li class="corrected perfect"><\/li>/g, ""); var toRepE = toRepD.replace("Title", "Title<br>"); var toRepF = toRepE.replace("Main Body", "Main Body<br>"); heightBox.innerHTML = toRepF; //Break up our corrections with a background var bb = allCorrections.getElementsByClassName("correction_field"); for (i = 0; i < bb.length; ++i) { bb[i].style.backgroundColor = "#E5E5E5" } }; window.onload = function onloadexecuteLineThroughRemoval(){ //Remove correction posts' themselves' line-through var a = document.getElementsByClassName("sline"); for (i = 0; i < a.length; ++i) { a[i].innerHTML=''; } }