Полезная информация

Юристы зарабатывают огромные деньги и славу, оперируя хорошим знанием законов. Правила форума — простой путь к успешному общению.

№117-12-2016 23:33:01

xoreax
Забанен
 
Группа: Members
Зарегистрирован: 07-11-2016
Сообщений: 54
UA: Firefox 32.0

adblock.js Lex1 - другое место хранения данных

Этот замечтательный скрипт написанный для Опера Presto, так же замечтательно работает и в Mozilla (FF, PaleMoon). И как-то до недавнего времени совершенно не заморачивался и удалял вручную кукисы и проч. "накопления из сети", и незамечал что вместе с тем... по-новой жмакал-блокировал и все.
Недавно поставил настройки , чтоб бравзер сам очищал здесь:
8684513m.jpg
Оказалось, что и данные заблокированных элементов  при помощью скрипта, тоже удаляются при закрытии бравзера.
Если это не сложно, может кто может сделать (или подсказать куда почитать, не уверен что  у мя получится, но...) другое место хранения данных для скрипта?

сам скрипт

Выделить код

Код:

// ==UserScript==
// @name                     AdBlock+
// @author                    Lex1
// @version                   1.3.14
// @include                     *.*
// @run-at                    document-start
// @description            Css AdBlock. Press Alt+Shift+A(X) for blocking ads and Alt+Shift+U for unblocking. Press Alt+Shift+E for editing styles.
// @license                  GPL 3
// ==/UserScript==
// изменил трошки цвет и гор.клавиши оригинала. блок простой Alt+Shift+X блок с :nth-child  - Alt+Shift+A
(function(){
    var style, enabled = false, prefix = 'ujs_adblock';
    var none = '{display: none !important;}', highlight = '{background-color: #FF5555 !important; outline: 2px solid #FF1111 !important; opacity: 0.7 !important;}', padding = 'iframe, embed, object{padding-left: 16px !important; background: url("") no-repeat scroll 0 0 !important;}';

    var getValue = function(name){
        if(window.localStorage){
            return window.localStorage.getItem(name) || '';
        }else{
            var eq = name+'=', ca = document.cookie.split(';');
            for(var i = ca.length; i--;){
                var c = ca[i];
                while(c.charAt(0) == ' ')c = c.slice(1);
                if(c.indexOf(eq) == 0)return unescape(c.slice(eq.length));
            };
            return '';
        }
    };
    var setValue = function(name, value, del){
        if(window.localStorage){
            if(del){window.localStorage.removeItem(name)}else{window.localStorage.setItem(name, value)};
        }else{
            if(document.cookie.split(';').length < 30 && document.cookie.length-escape(getValue(name)).length+escape(value).length < 4000){
                var date = new Date();
                date.setTime(date.getTime()+((del ? -1 : 10*365)*24*60*60*1000));
                document.cookie = name+'='+escape(value)+'; expires='+date.toGMTString()+'; path=/';
            }else{
                alert('Cookies are full!');
            }
        }
    };
    var delEle = function(ele){
        if(ele && ele.parentNode)ele.parentNode.removeChild(ele);
    };
    var addStyle = function(css){
        var s = document.createElement('style');
        s.setAttribute('type', 'text/css');
        s.setAttribute('style', 'display: none !important;');
        s.appendChild(document.createTextNode(css));
        return (document.getElementsByTagName('head')[0] || document.documentElement).appendChild(s);
    };
    var replaceStyle = function(ele, css){
        if(ele){
            while(ele.firstChild)ele.removeChild(ele.firstChild);
            ele.appendChild(document.createTextNode(css));
        }
    };
    var splitCss = function(css){
        var rez = [];
        css.replace(/(([\w#:.~>+()\s-]+|\*|\[.*?\])+)\s*(,|$)/g, function(s, m){rez.push(m.replace(/^\s+|\s+$/g, ''))});
        return rez;
    };
    var clearCss = function(css){
        var a = splitCss(css);
        for(var i = a.length; i--;){
            var rule = a[i]+'>';
            for(var j = a.length; j--;){
                if(a[j].indexOf(rule) == 0)a.splice(j, 1);
            }
        };
        return a.join(',');
    };
    var delCss = function(css, del){
        var a = splitCss(css);
        if(del){
            for(var i = a.length; i--;){
                if(del.indexOf(a[i]) == 0)a.splice(i, 1);
            }
        }else{
            a.pop();
        };
        return a.join(',');
    };
    var getCssRule = function(el, wide){
        var getNth = function(el){
            var nth, n = 0, p = el.parentNode;
            for(var i = 0, c; c = p.childNodes[i]; i++){if(c.nodeType == 1){n++; if(c == el)nth = n}};
            return (!nth || n < 2) ? '' : ':nth-child('+nth+')';
        };
        var getAtt = function(el, tags){
            var rez = '';
            if(el.attributes){
                var r = new RegExp('^('+tags+')$');
                for(var i = 0, a; a = el.attributes[i]; i++){
                    var n = a.nodeName.toLowerCase();
                    if(r.test(n))rez += '['+n+'=\x22'+a.nodeValue.replace(/[\x22\x5C]/g, '\\$&').replace(/[\x01-\x1F\x7F]/g, function(s){return '\\'+s.charCodeAt(0).toString(16)+' '})+'\x22]';
                }
            };
            return rez;
        };
        var att, tag, rez = [];
        var ver = document.querySelectorAll ? 10 : (window.postMessage ? 9.5 : (window.getSelection ? 9 : 8));
        while(el){
            if(el.nodeType == 1){
                tag = el.nodeName;
                att = getAtt(el, 'src') || getAtt(el, 'href');
                if(att){
                    rez.unshift(tag+((wide && ver >= 9) ? att.replace(/^(\[\w+)(=\x22https?:\/\/)([^?#]+\/[^?#]+\/|[^?#]+).*(\x22\])$/i, '$1^$2$3$4') : att));
                    break;
                }else{
                    att = getAtt(el, 'id|class|height|width|color|bgcolor'+(ver >= 9 ? '|align|valign|type' : ''));
                    rez.unshift(tag+att+((wide != false || ver < 9.5 || /^(html|body)$/i.test(tag)) ? '' : getNth(el)));
                    if(wide && att && (ver >= 10 ? document.querySelectorAll(tag+att).length == 1 : /\[id=\x22.*?\x22\]|\[class=\x22.*?\x22\]\[|\]\[class=\x22.*?\x22\]/.test(att)))break;
                }
            };
            el = el.parentNode;
        };
        return rez.join('>');
    };
    var setBlockStyle = function(){
        if(document.documentElement && document.documentElement.nodeName.toLowerCase() == 'html'){
            var css = getValue(prefix);
            if(css)style = addStyle(css+none);
            return true;
        }
    };

    var editStyles = function(){
        var rez = prompt(window.navigator.language.slice(0, 2) == 'ru' ? '\u041F\u043E\u0436\u0430\u043B\u0443\u0439\u0441\u0442\u0430, \u043E\u0442\u0440\u0435\u0434\u0430\u043A\u0442\u0438\u0440\u0443\u0439\u0442\u0435 \u0441\u0442\u0438\u043B\u0438:' : 'Please, edit styles:', getValue(prefix));
        if(rez != null){
            setValue(prefix, rez);
            if(rez)rez += none;
            if(style){replaceStyle(style, rez)}else{style = addStyle(rez)};
        }
    };
    var unblockEle = function(latest){
        var padCss, css = getValue(prefix);
        if(enabled || !style || !css)return;

        var remove = function(){
            document.removeEventListener('click', click, false);
            document.removeEventListener('keyup', press, false);
            delEle(padCss);
            enabled = false;
        };
        var click = function(ev){
            ev.preventDefault();
            var oldCss = getValue(prefix);
            var css = delCss(oldCss, getCssRule(ev.target, false));
            if(css == oldCss)css = delCss(oldCss, getCssRule(ev.target, null));
            if(css == oldCss)css = delCss(oldCss, getCssRule(ev.target, true));
            if(css != oldCss)setValue(prefix, css);
            replaceStyle(style, css ? css+(ev.shiftKey ? highlight : none) : '');
            if(!ev.shiftKey)remove();
        };
        var press = function(ev){
            if(ev.keyCode == 27){
                var css = getValue(prefix);
                replaceStyle(style, css ? css+none : '');
                remove();
            }
        };

        if(latest){
            css = delCss(css);
            setValue(prefix, css);
            replaceStyle(style, css ? css+none : '');
        }else{
            enabled = true;
            padCss = addStyle(padding);
            replaceStyle(style, css+highlight);
            document.addEventListener('click', click, false);
            document.addEventListener('keyup', press, false);
        }
    };
    var blockEle = function(wide){
        if(enabled)return;
        var css, tmpCss, padCss, ele, outline = '', bgColor = '', title = '';

        var remove = function(){
            document.removeEventListener('mouseover', over, false);
            document.removeEventListener('mouseout', out, false);
            document.removeEventListener('click', click, false);
            document.removeEventListener('keyup', press, false);
        };
        var quit = function(){
            delEle(tmpCss);
            delEle(padCss);
            enabled = false;
        };
        var over = function(ev){
            ele = ev.target;
            title = ele.title;
            ele.title = 'Tag: '+ele.nodeName+(ele.id ? ', ID: '+ele.id : '')+(ele.className ? ', Class: '+ele.className : '');
            outline = ele.style.outline;
//            ele.style.outline = '2px solid #306EFF';
            ele.style.outline = '2px solid #FF00AE';
            bgColor = ele.style.backgroundColor;
            ele.style.backgroundColor = '#D0FF00';
//            ele.style.backgroundColor = '#C6DEFF';
        };
        var out = function(){
            if(ele){
                ele.title = title;
                ele.style.outline = outline;
                ele.style.backgroundColor = bgColor;
            }
        };
        var click = function(ev){
            if(ele){
                ev.preventDefault();
                out();
                var rules, rule = getCssRule(ele, !wide != !ev.altKey);
                css = css ? (css != (rules = delCss(css, rule)) ? (ev.shiftKey ? rules : css) : css+','+rule) : rule;
                if(tmpCss){replaceStyle(tmpCss, css+highlight)}else{tmpCss = addStyle(css+highlight)};
                if(!ev.shiftKey){
                    remove();
                    css = prompt(window.navigator.language.slice(0, 2) == 'ru' ? '\u0417\u0430\u0431\u043B\u043E\u043A\u0438\u0440\u043E\u0432\u0430\u0442\u044C \u0434\u0430\u043D\u043D\u044B\u0439 \u044D\u043B\u0435\u043C\u0435\u043D\u0442?' : 'Block this element(s)?', css);
                    if(css){
                        rules = getValue(prefix);
                        if(rules)css = clearCss(rules+','+css);
                        setValue(prefix, css);
                        if(style){replaceStyle(style, css+none)}else{style = addStyle(css+none)};
                    };
                    quit();
                }
            }
        };
        var press = function(ev){
            if(ev.keyCode == 27){
                out();
                remove();
                quit();
            }
        };

        enabled = true;
        padCss = addStyle(padding);
        document.addEventListener('mouseover', over, false);
        document.addEventListener('mouseout', out, false);
        document.addEventListener('click', click, false);
        document.addEventListener('keyup', press, false);
    };


    // Set style at loading a page (with workaround for Opera 8)
    if(!setBlockStyle())window.addEventListener('load', setBlockStyle, false);

    // Hotkeys
    document.addEventListener('keydown', function(e){
//        if(!e.shiftKey && e.ctrlKey && e.altKey){
        if(e.ctrlKey && e.altKey){
            switch(e.keyCode){
                // Edit styles with Alt+Shift+E
                case 69: editStyles(); break;
                // Unblock elements with Alt+Shift+U
                case 85: unblockEle(); break;
                 // Block element with Alt+Shift+B
                //case 66: blockEle(); break;
                // Клавиша Z - 90, A -65
                case 65: blockEle(); break;
                // Unblock latest element with Alt+Shift+L
                case 76: unblockEle(true); break;
                 // Block elements (don't use nth-child) with Alt+Shift+A
                //case 65: blockEle(true); break;
                // Alt+Shift+X
                case 88: blockEle(true); break;
            }
        }
    }, false);

    // For buttons
    window.navigator[prefix] = {block: blockEle, edit: editStyles, unblock: unblockEle};
})();

Отсутствует

 

Board footer

Powered by PunBB
Modified by Mozilla Russia
Copyright © 2004–2020 Mozilla Russia GitHub mark
Язык отображения форума: [Русский] [English]