ADictionary Blocker

A Ad-changer

// ==UserScript==
// @name         ADictionary Blocker
// @namespace    http://tampermonkey.net/
// @version      0.6
// @description  A Ad-changer
// @author       Thomas Thy Train
// @match        *://dictionary.cambridge.org/*
// @match        https://*/*
// @grant        GM_addStyle
// @require      http://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js
// @require      https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.9.1/underscore-min.js
// @grant        GM.setValue
// @grant        GM.getValue
// @icon         
// @CrossOrigin("*")
// ==/UserScript==

// this is from https://dictionary.cambridge.org/external/scripts/dblclick.js?version=5.0.175
function setupExtDoubleClick(websiteUrl, dictionary, showFirstEntry, areaClass, maxAllowedWords, target) {
    setupDoubleClick(websiteUrl, dictionary, areaClass, maxAllowedWords, target,
        function(websiteUrl, dictionary, showFirstEntry, lookup) { return websiteUrl + "search/" + (dictionary ? dictionary + "/" : "") + (showFirstEntry ? "direct/" : "") + "?q=" + lookup; });
}
function setupDoubleClick(websiteUrl, dictionary, showFirstEntry, areaClass, maxAllowedWords, target, urlCallback) {
    //warning message for developers
    if (!websiteUrl || !dictionary) {
        alert("Please specify required parameters (websiteUrl and dictionary) to setupDoubleClick()")
        return;
    }

    //shows the definition layer
    var showLayer = function(e) {
        var translateDictionary = dictionary;
        var node = e.target || e.srcElement;
        while (node != null) {
            var lang = node.getAttribute("dict");
            if (lang) {
                translateDictionary = lang;
                break;
            }
            if (node.parentNode == node.ownerDocument) {
                break;
            }
            node = node.parentNode;
        }
        e.preventDefault();
        var lookup = getSelectedText();
        // original space, but shitty api ont allow
        lookup = lookup.replace(/[\.\*\?;!()\+,\[:\]<>^_`\[\]{}~\\\/\"\'=]/g, "");
        lookup = lookup.replace(/\s+/g, "");
        if (lookup != null && lookup.replace("/\s/g", "").length > 0) {
            //disable the double-click feature if the lookup string
            //exceeds the maximum number of allowable words
            if (maxAllowedWords && lookup.split(/[ -]/).length > maxAllowedWords)
                return;
            // i give up on showing the meaning
            //I DID IT!!!!!!!
            let request = new XMLHttpRequest();
            request.open("GET","https://api.dictionaryapi.dev/api/v2/entries/en/"+lookup);
            request.responseType="json";
            // add a popup to show define
            // word is correct
            // new,store things
            let word="<h3 style='font-style:italic;font-weight:bold;'>power by Cambridge Dictionary</h3><h1 id='word_adb_explain'style='font-style:italic;font-weight:bold;'>"+lookup+"</h1>";
            // test zone
            if(!localStorage.getItem('wordlist')){
                localStorage.setItem("wordlist","");
            }
            let cur_wl=localStorage.getItem('wordlist').split(":");
            //unique
            cur_wl=Array.from(new Set(cur_wl));
            localStorage.setItem("wordlist",cur_wl.join(":"));
            let color="grey";
            if(cur_wl.includes(lookup)){
                color="green"
            }
            request.onload=()=>{
                //localStorage.clear();

                request.response[0].meanings.forEach((e)=>{word+="<p>"+e.definitions[0].definition+"</p>";word+="<span style='font-style:italic;opacity:0.5;'>"+e.partOfSpeech+"</span>"});
                $("#adb_explain").remove();
                $("body").append("<div id='adb_explain'style='position:fixed;background-color:#fff;border:2px solid #000;width:450px;'><button id='delete_block' style='border-radius: 50%;border-width:0px;'>X</button><button id='adb_addword' style='border-radius: 50%;background-color:"+color+";border-width:0px;'>&#10004;</button>"+word+"</div>");

            // test end
                let block=document.querySelector("#adb_explain");
                const size=block.getBoundingClientRect();
                block.style.left=(1420-size.width).toString()+"px";
                block.style.top=(740-size.height).toString()+"px";
                $("#delete_block").click(()=>{$("#adb_explain").remove()});
            }
            $("#adb_addword").click((e)=>{
                lookup=$("#word_adb_explain").text();
                    if(cur_wl.includes(lookup)){
                        $("#adb_addword").css("background-color","grey");
                        const index=cur_wl.findIndex((e)=>e===lookup);
                        delete cur_wl[index];
                        localStorage.setItem('wordlist', cur_wl.join(":"));
                    }else{
                        $("#adb_addword").css("background-color","green");
                        localStorage.setItem('wordlist', cur_wl.join(":")+":"+lookup);
                    }
                });
            request.send();

            //append the layer to the DOM only once
            // modify this part
            if ($("#definition_layer").length == 0) {
                var imageUrl = websiteUrl + "external/images/doubleclick/definition-layer.gif";
                $("body").append("<div id='definition_layer' style='position:absolute; cursor:pointer;'><img src='" + imageUrl + "' alt='' title=''/></div>");
                //$("body").append("<div id='definition_layer' style='position:absolute; cursor:pointer;'>" + word + "</div>");
            }

            //move the layer at the cursor position
            $("#definition_layer").map(function() {
                $(this).css({'left' : e.pageX-30, 'top' : e.pageY-40});
            });

            //open the definition popup clicking on the layer
            $("#definition_layer").mouseup(function(e) {
                e.stopPropagation();
                openPopup(lookup, translateDictionary);
            });
        } else {
            $("#definition_layer").remove();
        }
    };

    //opens the definition popup
    var openPopup = function(lookup, translateDictionary) {
        var searchUrl;
        if (urlCallback)
            searchUrl = urlCallback(websiteUrl, translateDictionary, showFirstEntry, lookup);
        else
            searchUrl = websiteUrl + "search/" + (translateDictionary ? translateDictionary + "/" : "") + (showFirstEntry ? "direct/" : "") + "?q=" + lookup;
        if(lookup.replace(/[a-zA-Z0-9]/g, '')!=""){
            searchUrl="https://www.collinsdictionary.com/dictionary/chinese-english/"+lookup;
        }
        if (target) {
            if (target == "self") {
                window.location.href = searchUrl;
                return;
            }
            var popup = window.open(searchUrl, target, "toolbar=no,location=no,directories=no,status=no,menubar=no,scrollbars=yes,resizable=no,copyhistory=no,width=915,height=760,top=300,left=300");
            if (popup)
                popup.focus();
        } else {
            window.open(searchUrl, 'cup_lookup');
        }
        /*window.location.href = searchUrl;*/
    };

    var area = areaClass ? "." + areaClass : "body";
    $(area).mouseup(showLayer);
}

/*
 * Cross-browser function to get selected text
 */
function getSelectedText(){
    if(window.getSelection)
        return window.getSelection().toString();
    else if(document.getSelection)
        return document.getSelection();
    else if(document.selection)
        return document.selection.createRange().text;
    return "";
}
(function() {
    'use strict';
    //setup clicker dictionary
    // problem, it only give you the link
    setupDoubleClick( 'https://dictionary.cambridge.org/', 'english-chinese-traditional', true, null, 5, 'popup' );
    let adtype=["iframe","ytd-display-ad-renderer","ins","div"];
    let adfinder=["google_ads","aswift","mys-wrapper","midcontentadcontainer"];

    // let interval = null;

    // let hostname = document.location.hostname;
    //make this the explain page,but not every go ad
    // new
    function cleanup() {

        //if(!localStorage.getItem('wordlist')){
        //    localStorage.setItem("wordlist",".");
        //}
        let request = new XMLHttpRequest();
        let word="Loading"
        try{
            let cur_wl=localStorage.getItem('wordlist').split(":").slice(1);
            let lookup= new String(_.sample(cur_wl));
            //let lookup="cat";
            request.open("GET","https://api.dictionaryapi.dev/api/v2/entries/en/"+lookup);
            request.responseType="json";
            word="<h6 style='font-style:italic;font-weight:bold;'>power by Dictionary API</h6><h5 style='font-style:italic;font-weight:bold;'>"+lookup+"</h5>";
        }catch(err){
            let lookup="Loading";
            request.open("GET","https://api.dictionaryapi.dev/api/v2/entries/en/"+lookup);
            request.responseType="json";
            word="Loading";
        }
        request.onload=()=>{
            request.response[0].meanings.forEach((e)=>{
                word+="<p>"+e.definitions[0].definition+"</p>";
                word+="<span style='font-style:italic;opacity:0.5;'>"+e.partOfSpeech+"</span>";
            });
            // clear ad
            adtype.forEach((i)=>{
                try{
                    document.querySelectorAll(i).forEach((elem)=>{
                        adfinder.forEach((adid)=>{
                            if(elem.id.slice(0,adid.length)==adid){
                                console.log(word);
                                elem.style.overflow="auto";
                                elem.innerHTML=word;
                                //elem.style.visibility = 'hidden';
                                //elem.style.width = '1px';
                                //elem.style.height = '1px';
                                //elem.style.overflow = 'hidden';
                                //elem.style.opacity = 0;
                                //elem.remove();
                            }
                        });


                    });}
                catch(err){console.log(err);
                          }
            }
                          );
        }
        request.send();
        document.body.dispatchEvent(new MouseEvent('mousemove'));
        // modify this part
        // if(sites[hostname].background) {
        //     document.body.style.background = sites[hostname].background;
        //     document.body.style.overflow = 'scroll';
        //     document.body.style.position = 'static';
        // }


    }
    let interval=null;

    cleanup();
    if(interval === null) {
        interval = window.setInterval(function(){
        cleanup();
    }, 5000);
    }

})();
//"ytd-display-ad-renderer"