您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Allows custom components for kanji
当前为
// ==UserScript== // @name Jpdb custom components // @namespace http://tampermonkey.net/ // @version 0.0.2 // @description Allows custom components for kanji // @author Calonca // @match https://jpdb.io/kanji/* // @match https://jpdb.io/review // @icon  // @require http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js // @run-at document-start // @grant GM_addStyle // @grant GM_setValue // @grant GM_getValue // @license GPLv2 // ==/UserScript== (function() { 'use strict'; function getCCList(mnemonic){//returns custom component array from mnemonic if (mnemonic == null){ return []; }else { let componetsPharagraph = Array.from(mnemonic.childNodes) .filter(p=>p.nodeName=="P") .map(p=>p.innerHTML) .find(t=>t.includes("Composed of: ")); return componetsPharagraph.substring(componetsPharagraph.indexOf(':') + 2).split(","); } } function addComponents(){ let mnemonicHTML = document.getElementsByClassName("mnemonic")[0]; const componentsList = document.getElementsByClassName("subsection-composed-of-kanji")[0].getElementsByClassName("subsection")[0].childNodes; const componentsLen = componentsList.length; let customSpellingList = getCCList(mnemonicHTML); const customSpellingLen = customSpellingList.length; if (customSpellingLen>0){ let nodesToRemove = componentsLen-customSpellingLen; console.log(nodesToRemove); //Removes nodes if the custom componets are less then the original ones for (let i=0;i<nodesToRemove;i++){ componentsList[0].parentNode.removeChild(componentsList[customSpellingLen]) } //Replaces the kanji/radical/spelling and the keyword/description for (let i=0;i<customSpellingLen;i++){ if (i>=componentsLen){//Duplicates nodes if we have more custom componets then the original ones componentsList[0].parentNode.appendChild(componentsList[0].cloneNode(true)); } let plain = componentsList[i].querySelector(".spelling .plain"); plain.innerHTML = customSpellingList[i]; plain.href = "/kanji/"+customSpellingList[i]+"#a" //Gets the keyword for each compnent $.get( plain.href, function( data ) { let doc22 = $(data); let containerBugFix = doc22[24]; let desc = containerBugFix.querySelector(".vbox.gap .subsection").innerHTML; componentsList[i].querySelector(".description").innerHTML = desc; }); } } } if(window.location.href.indexOf("https://jpdb.io/kanji") > -1) { addComponents(); } else if (window.location.href.indexOf("https://jpdb.io/review#a") > -1){//If reviewing wait for mnemonic to show up before adding the components waitForKeyElements ( ".mnemonic" , addComponents ); } })(); //Put the function here instead of requires due to GreasyFolk rules, original can be found at https://gist.github.com/BrockA/2625891 /*--- waitForKeyElements(): A utility function, for Greasemonkey scripts, that detects and handles AJAXed content. Usage example: waitForKeyElements ( "div.comments" , commentCallbackFunction ); //--- Page-specific function to do what we want when the node is found. function commentCallbackFunction (jNode) { jNode.text ("This comment changed by waitForKeyElements()."); } IMPORTANT: This function requires your script to have loaded jQuery. */ function waitForKeyElements ( selectorTxt, /* Required: The jQuery selector string that specifies the desired element(s). */ actionFunction, /* Required: The code to run when elements are found. It is passed a jNode to the matched element. */ bWaitOnce, /* Optional: If false, will continue to scan for new elements even after the first match is found. */ iframeSelector /* Optional: If set, identifies the iframe to search. */ ) { var targetNodes, btargetsFound; if (typeof iframeSelector == "undefined") targetNodes = $(selectorTxt); else targetNodes = $(iframeSelector).contents () .find (selectorTxt); if (targetNodes && targetNodes.length > 0) { btargetsFound = true; /*--- Found target node(s). Go through each and act if they are new. */ targetNodes.each ( function () { var jThis = $(this); var alreadyFound = jThis.data ('alreadyFound') || false; if (!alreadyFound) { //--- Call the payload function. var cancelFound = actionFunction (jThis); if (cancelFound) btargetsFound = false; else jThis.data ('alreadyFound', true); } } ); } else { btargetsFound = false; } //--- Get the timer-control variable for this selector. var controlObj = waitForKeyElements.controlObj || {}; var controlKey = selectorTxt.replace (/[^\w]/g, "_"); var timeControl = controlObj [controlKey]; //--- Now set or clear the timer as appropriate. if (btargetsFound && bWaitOnce && timeControl) { //--- The only condition where we need to clear the timer. clearInterval (timeControl); delete controlObj [controlKey] } else { //--- Set a timer, if needed. if ( ! timeControl) { timeControl = setInterval ( function () { waitForKeyElements ( selectorTxt, actionFunction, bWaitOnce, iframeSelector ); }, 300 ); controlObj [controlKey] = timeControl; } } waitForKeyElements.controlObj = controlObj; }