b0ttle
как пример, закрытие вкладки по "Escape" и панели поиска по Ctrl+F
ucf_custom_script_win.loadскрытый текстВыделить кодКод:
(this.keyboardshortcuts = { init(that) { document.addEventListener("keydown", this); that.unloadlisteners.push("keyboardshortcuts"); }, handleEvent(e) { ({ "Escape": () => { if (!e.ctrlKey && !e.altKey && !e.shiftKey && !window.fullScreen) { e.preventDefault(); gBrowser.removeCurrentTab(); } }, "KeyF": () => { if (e.ctrlKey && !e.altKey && !e.shiftKey && window.gFindBarInitialized && !gFindBar.hidden) { e.preventDefault(); gFindBar.close?.(); } }, })[e.code]?.(); }, destructor() { document.removeEventListener("keydown", this); }, }).init(this);
1) "1", "2", "]", "`"... не получается эти ключи пристроить.
"3":()=>{if(!e.ctrlKey&&!e.altKey&&!e.shiftKey)openPreferences();}, "]":()=>{if(!e.ctrlKey&&e.altKey&&!e.shiftKey)TabStickOnTop();},
2) Копирует везде, можно сделать чтобы он не копировал в окнах когда печатаешь?
Текст можно убрать, главное чтобы текст пропадал на секунду и видно что скопировался.
"KeyV":()=>{if(!e.ctrlKey&&!e.altKey&&!e.shiftKey){gClipboard.write(gURLBar.value);var gub=gURLBar.value,line1='...',line=" "+line1,i=0; line_a=()=>{if(i++<line.length){gURLBar.value=line.substring(1,i)}setTimeout(()=>{line_a()},10)} line_a();setTimeout(()=>{gURLBar.value=readFromClipboard()},1000);}},
3) А есть ключ или что, чтобы можно было перебивать стандартный key.
Как !e.ctrlKey&&!e.altKey&& но как игнорировать Ctrl+1, стандартный перекидывает на первое окно.
Отредактировано b0ttle (15-12-2020 16:48:58)
Отсутствует
Как смог перекинул, где data:image/x-icon;base64, подставил data:;base64
Это у runningcheese так.
KeychangerBase.js
data:;base64,// ==UserScript==
// @name           KeyChanger.uc.js
// @author         Griever
// @namespace      http://d.hatena.ne.jp/Griever/
// @include        main
// @description    Additional shortcuts for Firefox
// @license        MIT License
// @charset        UTF-8
// @version        2019.09.18.1
// @note           0.0.2 Improved: you can open the configuration file by right-clicking on the menu.
// @note           0.0.2 Meta You may now be able to use the key as a decorative key(not tested）
// @note           0.0.2 Windows Keys may now be used as decoration keys (untested Firefox 17 or later）
// @note           2018.1.25.2 Firefox59+ Repair
// ==/UserScript==

location.href.startsWith('chrome://browser/content/browser.x') && (() => {
    var useScraptchpad = true;  // If the editor does not exist, use the code snippet shorthand, otherwise set the editor path
    window.KeyChanger = {
        get file(){
            var aFile = FileUtils.getFile("UChrm", ["user_chrome_files", "custom_scripts", "keych.js"], false);
            if (!aFile.exists()) {
                saveFile(aFile, '');
                alert('_keychanger Configuration is empty，The document is in local Under the directory');
            }
            delete this.file;
            return this.file = aFile;
        },
        get FILE() {
            return this.file;
        },
        isBuilding: false,
        makeKeyset: function (isAlert) {
            KeyChanger.isBuilding = true;
            var s = new Date();
            var keys = this.makeKeys();
            if (!keys) {
                isBuilding = false;
                return this.alert('KeyChanger', 'Load error.');
            }
            var keyset = document.getElementById('keychanger-keyset');
            if (keyset)
                keyset.parentNode.removeChild(keyset);
            keyset = document.createXULElement('keyset');
            keyset.setAttribute('id', 'keychanger-keyset');
            keyset.appendChild(keys);

            var df = document.createDocumentFragment();
            Array.prototype.slice(document.getElementsByTagName('keyset')).forEach(function (elem) {
                df.appendChild(elem);
            });
            var insPos = document.getElementById('mainPopupSet');
            insPos.parentNode.insertBefore(keyset, insPos);
            insPos.parentNode.insertBefore(df, insPos);
            var e = new Date() - s;
            if (isAlert) {
                this.alert('KeyChanger: Loaded', e + 'ms');
            }
            setTimeout(function () {
                KeyChanger.isBuilding = false;
            }, 100);

        },
        makeKeys: function () {
            var str = this.loadText(this.file);
            if (!str)
                return null;

            var sandbox = new Cu.Sandbox(new XPCNativeWrapper(window));
            var keys = Cu.evalInSandbox('var keys = {};\n' + str + ';\nkeys;', sandbox);
            if (!keys)
                return null;
            var dFrag = document.createDocumentFragment();

            Object.keys(keys).forEach(function (n) {
                let keyString = n.toUpperCase().split("+");
                let modifiers = "", key, keycode, k;

                for (let i = 0, l = keyString.length; i < l; i++) {
                    k = keyString[i];
                    switch (k) {
                        case "CTRL":
                        case "CONTROL":
                        case "ACCEL":
                            modifiers += "accel,";
                            break;
                        case "SHIFT":
                            modifiers += "shift,";
                            break;
                        case "ALT":
                        case "OPTION":
                            modifiers += "alt,";
                            break;
                        case "META":
                        case "COMMAND":
                            modifiers += "meta,";
                            break;
                        case "OS":
                        case "WIN":
                        case "WINDOWS":
                        case "HYPER":
                        case "SUPER":
                            modifiers += "os,";
                            break;
                        case "":
                            key = "+";
                            break;
                        case "BACKSPACE":
                        case "BKSP":
                        case "BS":
                            keycode = "VK_BACK";
                            break;
                        case "RET":
                        case "ENTER":
                            keycode = "VK_RETURN";
                            break;
                        case "ESC":
                            keycode = "VK_ESCAPE";
                            break;
                        case "PAGEUP":
                        case "PAGE UP":
                        case "PGUP":
                        case "PUP":
                            keycode = "VK_PAGE_UP";
                            break;
                        case "PAGEDOWN":
                        case "PAGE DOWN":
                        case "PGDN":
                        case "PDN":
                            keycode = "VK_PAGE_DOWN";
                            break;
                        case "TOP":
                            keycode = "VK_UP";
                            break;
                        case "BOTTOM":
                            keycode = "VK_DOWN";
                            break;
                        case "INS":
                            keycode = "VK_INSERT";
                            break;
                        case "DEL":
                            keycode = "VK_DELETE";
                            break;
                        default:
                            if (k.length === 1) {
                                key = k;
                            } else if (k.indexOf("VK_") === -1) {
                                keycode = "VK_" + k;
                            } else {
                                keycode = k;
                            }
                            break;
                    }
                }
                let elem = document.createXULElement('key');
                if (modifiers !== '')
                    elem.setAttribute('modifiers', modifiers.slice(0, -1));
                if (key)
                    elem.setAttribute('key', key);
                else if (keycode)
                    elem.setAttribute('keycode', keycode);

                let cmd = keys[n];
                switch (typeof cmd) {
                    case 'function':
                        elem.setAttribute('oncommand', '(' + cmd.toString() + ').call(this, event);');
                        break;
                    case 'object':
                        Object.keys(cmd).forEach(function (a) {
                            elem.setAttribute(a, cmd[a]);
                        }, this);
                        break;
                    default:
                        elem.setAttribute('oncommand', cmd);
                }
                dFrag.appendChild(elem);
            }, this);
            return dFrag;
        },
        createMenuitem: function () {
            var menuitem = document.createXULElement('menuitem');
            menuitem.setAttribute('id', 'toolsbar_KeyChanger_rebuild');
            menuitem.setAttribute('label', 'KeyChanger');
            menuitem.setAttribute('tooltiptext', 'Left click: reload configuration\nRight click: edit configuration');
            menuitem.setAttribute('oncommand', 'setTimeout(function(){ KeyChanger.makeKeyset(true); }, 10);');
            menuitem.setAttribute('onclick', 'if (event.button == 2) { event.preventDefault();KeyChanger.edit(KeyChanger.file); }');
            var insPos = document.getElementById('devToolsSeparator');
            insPos.parentNode.insertBefore(menuitem, insPos);
        },
        loadText: function (aFile) {
            var fstream = Cc["@mozilla.org/network/file-input-stream;1"].createInstance(Ci.nsIFileInputStream);
            var sstream = Cc["@mozilla.org/scriptableinputstream;1"].createInstance(Ci.nsIScriptableInputStream);
            fstream.init(aFile, -1, 0, 0);
            sstream.init(fstream);

            var data = sstream.read(sstream.available());
            try {
                data = decodeURIComponent(escape(data));
            } catch (e) {
            }
            sstream.close();
            fstream.close();
            return data;
        },
        alert: function (aMsg, aTitle, aCallback) {
            var callback = aCallback ? {
                observe: function (subject, topic, data) {
                    if ("alertclickcallback" != topic)
                        return;
                    aCallback.call(null);
                }
            } : null;
            var alertsService = Cc["@mozilla.org/alerts-service;1"].getService(Ci.nsIAlertsService);
            alertsService.showAlertNotification(
                "chrome://global/skin/icons/information-32.png", aTitle || "addMenu",
                aMsg + "", !!callback, "", callback);
        },
        edit: function (aFile, aLineNumber) {
            if (KeyChanger.isBuilding) return;
            if (!aFile || !aFile.exists() || !aFile.isFile()) return;

            var editor;
            try {
                editor = Services.prefs.getComplexValue("view_source.editor.path", Ci.nsIFile);
            } catch (e) {
            }

            if (!editor || !editor.exists()) {
                if (useScraptchpad) {
                    this.openScriptInScratchpad(window, aFile);
                    return;
                } else {
                    alert("Please set the path to the editor first!!!");
                    var fp = Cc['@mozilla.org/filepicker;1'].createInstance(Ci.nsIFilePicker);
                    fp.init(window, "Setting up the global script editor", fp.modeOpen);
                    fp.appendFilter("Execution files", "*.exe");
                    if (fp.show() == fp.returnCancel || !fp.file)
                        return;
                    else {
                        editor = fp.file;
                        Services.prefs.setCharPref("view_source.editor.path", editor.path);
                    }
                }
            }

            // Call comes with the
			if(typeof(userChrome) == 'undefined') {	
				this.openScriptInScratchpad(window, aFile);
                return;
			} else {			
            var aURL = userChrome.getURLSpecFromFile(aFile);
            var aDocument = null;
            var aCallBack = null;
            var aPageDescriptor = null;
            gViewSourceUtils.openInExternalEditor({
                URL: aURL,
                lineNumber: aLineNumber
            }, aPageDescriptor, aDocument, aLineNumber, aCallBack);	
			}

        },
        openScriptInScratchpad: function (parentWindow, file) {
            let spWin = window.openDialog("chrome://devtools/content/scratchpad/index.xul", "Toolkit:Scratchpad", "chrome,resizable=yes,centerscreen,dependent");

            spWin.addEventListener("load", function spWinLoaded() {
                spWin.removeEventListener("load", spWinLoaded, false);

                let Scratchpad = spWin.Scratchpad;
                Scratchpad.setFilename(file.path);
                Scratchpad.addObserver({
                    onReady: function () {
                        Scratchpad.removeObserver(this);
                        Scratchpad.importFromFile.call(Scratchpad, file);
                    }
                });
            }, false);
        },
        exec: function (path, arg) {
            var file = Cc['@mozilla.org/file/local;1'].createInstance(Ci.nsIFile);
            var process = Cc['@mozilla.org/process/util;1'].createInstance(Ci.nsIProcess);
            try {
                var a = (typeof arg == 'string' || arg instanceof String) ? arg.split(/\s+/) : [arg];
                file.initWithPath(path);
                process.init(file);
                process.run(false, a, a.length);
            } catch (e) {
                this.log(e);
            }
        },
        log: function () {
            Services.console.logStringMessage("[KeyChanger] " + Array.prototype.slice(arguments));
        },
    };

    window.KeyChanger.createMenuitem();
    window.KeyChanger.makeKeyset();

})();
keych.js
data:;base64,//Firefox Custom shortcut RunningCheese Version for 64+//Boss Key
keys['1']="duplicateTabIn(gBrowser.selectedTab,'tab')";
keys['2']='BrowserPageInfo()';
keys['3']='openPreferences()';
keys['V']=()=>{gClipboard.write(gURLBar.value);var gub=gURLBar.value,line1='...',line=" "+line1,i=0;
line_a=()=>{if(i++<line.length){gURLBar.value=line.substring(1,i)}setTimeout(()=>{line_a()},10)}
line_a();setTimeout(()=>{gURLBar.value=readFromClipboard()},1000);};
//F1-12Keys-----------------------------------------------------------------------------------------------------------------------------------
keys['F1']="var s=prompt('Search within Google sites:','');if(s.length>0)gBrowser.addTrustedTab('https://www.google.com/search?q=site:'+encodeURIComponent(gBrowser.currentURI.host)+' '+encodeURIComponent(s));";   //Google Station search
keys['F2']=()=>{gBrowser.loadURI("javascript:{d=document;b=d.body;o=d.createElement('scri'+'pt');o.setAttribute('src','https://translate.google.com/translate_a/element.js?cb=googleTranslateElementInit');o.setAttribute('type','text/javascript');b.appendChild(o);v=b.insertBefore(d.createElement('div'),b.firstChild);v.id='google_translate_element';v.style.display='none';p=d.createElement('scri'+'pt');p.text='function%20googleTranslateElementInit(){new%20google.translate.TranslateElement({pageLanguage:%22%22},%22google_translate_element%22);}';p.setAttribute('type','text/javascript');b.appendChild(p);}void%200",{triggeringPrincipal:gBrowser.contentPrincipal});}; //Enable translation
//Alt Hot-Keys--------------------------------------------------------------------------------------------------------------------------------
/*keys["Alt+F1"]=()=>{..};*/
keys['Alt+N']=()=>{gBrowser.loadURI("javascript:(function(){var%20night=function(w){(function(d){var%20css='html{opacity:0.7!important;background:black!important;}body{background:white!important;}';var%20s=d.getElementsByTagName('style');for(var%20i=0,si;si=s[i];i++){if(si.innerHTML==css){si.parentNode.removeChild(si);return}};var%20heads=d.getElementsByTagName('head');if(heads.length){var%20node=d.createElement('style');node.type='text/css';node.appendChild(d.createTextNode(css));heads[0].appendChild(node)}})(w.document);%20for(var%20i=0,f;f=w.frames[i];i++){try{arguments.callee(f)}catch(e){}}};night(window)})();",{triggeringPrincipal:gBrowser.contentPrincipal});};  //Night mode
keys['Alt+P']='OpenBrowserWindow({private:true})';
keys['Alt+]']='TabStickOnTop()';//Pin the current window to the top
//Ctrl+Alt Hot-Keys---------------------------------------------------------------------------------------------------------------------------
keys['Ctrl+Q']=()=>{FileUtils.getFile('UChrm',['user_chrome_files','QTranslate','QTranslate.exe']).launch();};
keys['Ctrl+Alt+S']=()=>{FileUtils.getFile('UChrm',['user_chrome_files','Everything','Everything.exe']).launch();};
//keys["Ctrl+Alt+X"]=()=>{var toolbar=document.getElementById("toolbar-menubar");var visibility=toolbar.getAttribute("autohide")=="true";setToolbarVisibility(toolbar,visibility);};//Open it. Alt Menu(ff70+)
//keys['F1']=()=>{document.getElementById("cmd_newNavigatorTab").doCommand();}; //Create a new tab and position the cursor to the address bar
//keys['F9']=()=>{gBrowser.loadURI("javascript:(function(bookmarklets)%7Bfor(var%20i=0;i%3Cbookmarklets.length;i++)%7Bvar%20code=bookmarklets%5Bi%5D.url;if(code.indexOf(%22javascript:%22)!=-1)%7Bcode=code.replace(%22javascript:%22,%22%22);eval(code)%7Delse%7Bcode=code.replace(/%5Es+%7Cs+$/g,%22%22);if(code.length%3E0)%7Bwindow.open(code)%7D%7D%7D%7D)(%5B%7Btitle:%22%E7%A0%B4%E9%99%A4%E5%8F%B3%E9%94%AE%E8%8F%9C%E5%8D%95%E9%99%90%E5%88%B6%22,url:%22javascript:function%20applyWin(a)%7Bif(typeof%20a.__nnANTImm__===%5Cx22undefined%5Cx22)%7Ba.__nnANTImm__=%7B%7D;a.__nnANTImm__.evts=%5B%5Cx22mousedown%5Cx22,%5Cx22mousemove%5Cx22,%5Cx22copy%5Cx22,%5Cx22contextmenu%5Cx22%5D;a.__nnANTImm__.initANTI=function()%7Ba.__nnantiflag__=true;a.__nnANTImm__.evts.forEach(function(c,b,d)%7Ba.addEventListener(c,this.fnANTI,true)%7D,a.__nnANTImm__)%7D;a.__nnANTImm__.clearANTI=function()%7Bdelete%20a.__nnantiflag__;a.__nnANTImm__.evts.forEach(function(c,b,d)%7Ba.removeEventListener(c,this.fnANTI,true)%7D,a.__nnANTImm__);delete%20a.__nnANTImm__%7D;a.__nnANTImm__.fnANTI=function(b)%7Bb.stopPropagation();return%20true%7D;a.addEventListener(%5Cx22unload%5Cx22,function(b)%7Ba.removeEventListener(%5Cx22unload%5Cx22,arguments.callee,false);if(a.__nnantiflag__===true)%7Ba.__nnANTImm__.clearANTI()%7D%7D,false)%7Da.__nnantiflag__===true?a.__nnANTImm__.clearANTI():a.__nnANTImm__.initANTI()%7DapplyWin(top);var%20fs=top.document.querySelectorAll(%5Cx22frame,%20iframe%5Cx22);for(var%20i=0,len=fs.length;i%3Clen;i++)%7Bvar%20win=fs%5Bi%5D.contentWindow;try%7Bwin.document%7Dcatch(ex)%7Bcontinue%7DapplyWin(fs%5Bi%5D.contentWindow)%7D;void%200;%22%7D,%7Btitle:%22%E7%A0%B4%E9%99%A4%E9%80%89%E6%8B%A9%E5%A4%8D%E5%88%B6%E9%99%90%E5%88%B6%22,url:%22javascript:(function()%7Bvar%20doc=document;var%20bd=doc.body;bd.onselectstart=bd.oncopy=bd.onpaste=bd.onkeydown=bd.oncontextmenu=bd.onmousemove=bd.onselectstart=bd.ondragstart=doc.onselectstart=doc.oncopy=doc.onpaste=doc.onkeydown=doc.oncontextmenu=null;doc.onselectstart=doc.oncontextmenu=doc.onmousedown=doc.onkeydown=function%20()%7Breturn%20true;%7D;with(document.wrappedJSObject%7C%7Cdocument)%7Bonmouseup=null;onmousedown=null;oncontextmenu=null;%7Dvar%20arAllElements=document.getElementsByTagName(%5Cx27*%5Cx27);for(var%20i=arAllElements.length-1;i%3E=0;i--)%7Bvar%20elmOne=arAllElements;with(elmOne.wrappedJSObject%7C%7CelmOne)%7Bonmouseup=null;onmousedown=null;%7D%7Dvar%20head=document.getElementsByTagName(%5Cx27head%5Cx27)%5B0%5D;if(head)%7Bvar%20style=document.createElement(%5Cx27style%5Cx27);style.type=%5Cx27text/css%5Cx27;style.innerHTML=%5Cx22html,*%7B-moz-user-select:auto!important;%7D%5Cx22;head.appendChild(style);%7Dvoid(0);%7D)();%22%7D%5D)",{triggeringPrincipal:gBrowser.contentPrincipal});}; //Remove the right-click menu restriction
//keys['F10']=()=>{gBrowser.loadURI("javascript:document.body.contentEditable%20=%20'true';%20document.designMode='on';%20void%200",{triggeringPrincipal:gBrowser.contentPrincipal});}; //Edit the current page
//keys['Alt+W']='document.getElementById("pageAction-urlbar-_cd7e22de-2e34-40f0-aeff-cec824cbccac_").click();' //Read tag/Remove Tag later
//keys['Alt+E']=()=>{if(gBrowser.selectedTab.getAttribute("pinned")!=="true"){gBrowser.removeCurrentTab();}};  //Close the current tab
//keys['Alt+E']='ReaderParent.toggleReaderMode(event);';                                                       //Reading mode
//keys['F5|6|7'];//Native button:refresh||Native button:navigate to address bar||Native button:enable browse cursor
//Ctrl+Shift Hot-Keys-------------------------------------------------------------------------------------------------------------------------
//keys['Ctrl+Shift+A|S|D']=Native shortcut: open the Add-On bar||Open Firefox's native screenshot function||Save all current tabs


Добавлено 15-12-2020 17:41:40
Vitaliy V.
Похоже сломался в 84? Findbar.
Хотя ладно, уже не удобно так много просить, просто проверьте работает ли у вас?
https://forum.mozilla-russia.org/viewtopic.php?pid=782586#p782586
Отредактировано b0ttle (15-12-2020 17:41:40)
Отсутствует
ub0ttle
1. Это не тоже самое что символы на клавиатуре см. https://developer.mozilla.org/en-US/doc … Event/code + https://developer.mozilla.org/en-US/doc … ode_values
или просто запустите этот код в консоле и понажимайте клавиши
если нужно использовать символы для конкретной раскладки, тогда можно использовать KeyboardEvent.key вместо KeyboardEvent.code
2. Конечно если добавить модификаторы Shift, Ctrl, Alt, минимум две клавиши чтобы были, а одной если только которые редко используются. Или в зависимости где находится фокус можно сделать...
и видно что скопировался.
Может так + некоторые другие ваши функции
(this.keyboardshortcuts = { init(that) { document.addEventListener("keydown", this); that.unloadlisteners.push("keyboardshortcuts"); }, handleEvent(e) { ({ "Digit1": () => { if (!e.ctrlKey && !e.altKey && e.shiftKey) { // Shift+1 e.preventDefault(); duplicateTabIn(gBrowser.selectedTab, "tab"); } }, "Digit2": () => { if (!e.ctrlKey && !e.altKey && e.shiftKey) { // Shift+2 e.preventDefault(); BrowserPageInfo(); } }, "Digit3": () => { if (!e.ctrlKey && !e.altKey && e.shiftKey) { // Shift+3 e.preventDefault(); openPreferences(); } }, "KeyV": () => { if (e.ctrlKey && !e.altKey && !e.shiftKey) { // Ctrl+V e.preventDefault(); Cc["@mozilla.org/widget/clipboardhelper;1"] .getService(Ci.nsIClipboardHelper) .copyString(gURLBar.makeURIReadable(gBrowser.selectedBrowser.currentURI).displaySpec); showBrowserPageActionFeedback(PageActions.actionForID("copyURL")); } }, })[e.code]?.(); }, destructor() { document.removeEventListener("keydown", this); }, }).init(this);
Похоже сломался в 84? Findbar. просто проверьте работает ли у вас?
А вы сами то проверяли? Я недавно только обновлял его по просьбе...
Отсутствует
Vitaliy V.
Извините, даже не догадывался что его обновили, поэтому просто ссылку быстро копирнул и вставил, спасибо поиск работает, остальное пока разбераюсь.
e.preventDefault(); допер, ура..англ.хромает, вам наверно трудно с такими как я.
1-2) Почему кинул от runningcheese, если писать в формах, те же хоткеи 1-9, и V.. то они не активные. А так очень даже удобно, ими пользоваться, вне форм, просто на пустое место клик и применил key.
Добавлено 15-12-2020 22:03:24
Vitaliy V.
С кодами не сложно вник, спасибо, в консоли очень кстати удобно, искать не надо.
Зачем усложнять что-то, главное работает, то что хотел. Осталось разобраться с формами(фокусом).
Отредактировано b0ttle (15-12-2020 22:23:41)
Отсутствует
Или в зависимости где находится фокус можно сделать...
(?) Как насчёт проверять docShell.isCommandEnabled("cmd_insertText");
Вот, записал не слишком оптимально, зато довольно отвязно
(ucf_custom_script_win.keyboardshortcuts = { init() { windowRoot.addEventListener("keydown", this, true); ucf_custom_script_win.unloadlisteners.push("keyboardshortcuts"); this.destructor = () => windowRoot.removeEventListener("keydown", this, true); this.handleEvent = e => this[ String(+e.ctrlKey) + +e.shiftKey + +e.altKey + e.code ]?.(e); }, get skip() { return docShell.isCommandEnabled("cmd_insertText"); }, stop(e, eat) { e.preventDefault(); eat && e.stopImmediatePropagation(); }, get ch() { delete this.ch; return this.ch = Cc["@mozilla.org/widget/clipboardhelper;1"] .getService(Ci.nsIClipboardHelper); }, "000Digit2"(e) { // 2 this.skip || BrowserPageInfo(); }, "100KeyV"(e) { // Ctrl+V if (this.skip) return; this.ch.copyString(gURLBar.makeURIReadable(gBrowser.currentURI).displaySpec); showBrowserPageActionFeedback(PageActions.actionForID("copyURL")); }, "110KeyP"(e) { // Ctrl+Shift+P this.stop(e); Services.prompt.alert(window, "test", "stop"); }, // ... }).init();
Отсутствует
Dumby
Ваш код улет, у меня слов нет, более отзывчивым показался, все так быстро реагирует.
000,110 тоже класс, alt+,ctrl+alt какие коды?
Отредактировано b0ttle (16-12-2020 13:27:04)
Отсутствует
В 84-й отвалился стиль "./css/generalui/findbar_on_top.css" от Aris-t2/CustomCSSforFx. Что ещё из его комплекта отвалилось пока не знаю... У кого-нибудь есть стиль для строки поиска вверху или знаете как поправить? Привык уже, ещё с Opera Presto.
Отсутствует
Как насчёт проверять docShell.isCommandEnabled("cmd_insertText");
Ага спс или можно как в runningcheese сделать с <keyset
Вот, записал не слишком оптимально, зато довольно отвязно
Мне кажется так оптимальней, по крайней мере не проверяются, конвертируются при нажатии любой клавиши +e.ctrlKey +e.shiftKey +e.altKey
(this.keyboardshortcuts = { get clipboardHelp() { delete this.clipboardHelp; return this.clipboardHelp = Cc["@mozilla.org/widget/clipboardhelper;1"] .getService(Ci.nsIClipboardHelper); }, get insertText() { return docShell.isCommandEnabled("cmd_insertText"); }, init(that) { var keydown = { "Digit1": { "false_false_false": (e) => { // 1 if (this.insertText) return; e.preventDefault(); duplicateTabIn(gBrowser.selectedTab, "tab"); } }, "Digit2": { "false_false_false": (e) => { // 2 if (this.insertText) return; e.preventDefault(); BrowserPageInfo(); } }, "Digit3": { "false_false_false": (e) => { // 3 if (this.insertText) return; e.preventDefault(); openPreferences(); } }, "KeyV": { "true_false_false": (e) => { // Ctrl+V if (this.insertText) return; e.preventDefault(); this.clipboardHelp.copyString(gURLBar.makeURIReadable(gBrowser.selectedBrowser.currentURI).displaySpec); showBrowserPageActionFeedback(PageActions.actionForID("copyURL")); } }, handleEvent(e) { if (AppConstants.platform != "macosx") { (this.handleEvent = e => { this[e.code]?.[`${e.ctrlKey}_${e.altKey}_${e.shiftKey}`]?.(e); })(e); return; } (this.handleEvent = e => { this[e.code]?.[`${e.metaKey}_${e.altKey}_${e.shiftKey}`]?.(e); })(e); }, }; document.addEventListener("keydown", keydown, true); this.destructor = () => document.removeEventListener("keydown", keydown, true); that.unloadlisteners.push("keyboardshortcuts"); }, }).init(this);
боковая панель заезжает под панель поиска и не виден значок закладок.
С этим стилем https://forum.mozilla-russia.org/viewto … 19#p721919 ?
С z-index поиграйтесь, уменьшите в стиле для findbar или прибавьте для бок. панели
Отсутствует
Я смотрю, здесь и скрипты обсуждаются. Может, кто-нибудь знает, как убрать из Библиотеки, из списка в левой части, строчки Журнал, Загрузки, Метки, Все закладки. Я пока сделала их иконки и текст невидимыми (более-менее). Но сами строчки остались. Как бы скрыть их совсем?
И ещё. В окошке правой кнопки мыши "Информация о странице" есть горизонтальная полоса прокрутки. Как бы её перекрасить и сделать тоньше?
Отредактировано linlin (16-12-2020 21:22:19)
Отсутствует
Скажите, пожалуйста, можно ли в Закладках на правой панели убрать строки внизу: "Метки" и "Краткое имя"?
Еслив файл userChrome.css вставить:
, то Метки и Краткое имя исчезнут из редактора окна "Библиотека", из редактора звёздочки адресной строки и из окошка "Свойства".
Отредактировано linlin (16-12-2020 22:26:05)
Отсутствует
Vitaliy V.
боковая панель заезжает под панель поиска и не виден значок закладок
Это про стиль панели поиска вверху https://forum.mozilla-russia.org/viewtopic.php?pid=782586#p782586
и когда вертикальная панель появляется при наведении на край экрана. Это не критично, меня панель поиска устраивает.
Отсутствует
Это про стиль панели поиска вверху
это я понял, не понял про боковую панель, оказывается вертикальную
Я смотрю, здесь и скрипты обсуждаются. Может, кто-нибудь знает, как убрать из Библиотеки, из списка в левой части, строчки Журнал, Загрузки, Метки, Все закладки.
что вы используете для загрузки скриптов?
Информация о странице" есть горизонтальная полоса прокрутки. Как бы её перекрасить и сделать тоньше?
@-moz-document url("chrome://browser/content/pageinfo/pageInfo.xhtml") { #imagecontainerbox, #permList, scrollbar.scrollbar-topmost { scrollbar-width: thin !important; scrollbar-color: #00334f transparent !important; } }
Отредактировано Vitaliy V. (17-12-2020 12:22:16)
Отсутствует
что вы используете для загрузки скриптов?
А что лучше использовать? Greasemonkey? Я по незнанию полагала, что можно создать userChrome.js, который будет работать, как userChrome.css - без установки дополнительных расширений, но, кажется, без них в 83.0 уже не обойтись.
Спасибо за полосы прокрутки - получилось.
Отсутствует
linlin
Расширения давно бесполезны у них нет прямого доступа к интерфейсу.
Вообще то здесь иногда обсуждают скрипты для user_chrome_files
Попробуйте вот набросал код для custom_script_all_win.js
добавить в конец файла
(() => { var load_scripts_by_url = { "chrome://browser/content/browser.xhtml": win => { if (win != window) return; var box = document.querySelector("tabpanels#tabbrowser-tabpanels") || window; var listener = e => { var doc = e.target || ({}); load_scripts_by_url[doc.documentURI]?.(doc.defaultView); }; box.addEventListener("DOMContentLoaded", listener); ucf_custom_script_all_win.placesorganizerleftpanebuiltin = { destructor() { box.removeEventListener("DOMContentLoaded", listener); } }; ucf_custom_script_all_win.unloadlisteners.push("placesorganizerleftpanebuiltin"); }, "chrome://browser/content/places/places.xhtml": win => { if (win.arguments?.find(f => f === "Downloads" || f === "History" || f === "Tags")) return; win.PlacesOrganizer.__initFolderTree = win.PlacesOrganizer._initFolderTree; win.PlacesOrganizer._initFolderTree = win.eval(`(${win.PlacesOrganizer._initFolderTree})` .replace(/^\((async\s)?.*?_initFolderTree/, "($1function _initFolderTree") .replace("RESULTS_AS_LEFT_PANE_QUERY", "RESULTS_AS_ROOTS_QUERY")); win.PlacesOrganizer.__selectLeftPaneContainerByHierarchy = win.PlacesOrganizer.selectLeftPaneContainerByHierarchy; win.PlacesOrganizer.selectLeftPaneContainerByHierarchy = win.eval(`(${win.PlacesOrganizer.selectLeftPaneContainerByHierarchy})` .replace(/^\((async\s)?.*?selectLeftPaneContainerByHierarchy/, "($1function selectLeftPaneContainerByHierarchy") .replace(/PlacesUtils\s*\.\s*asContainer\s*\(\s*this\s*\.\s*_places\s*\.\s*selectedNode\s*\)\s*\.\s*containerOpen\s*=\s*true\s*;/, "")); win.PlacesOrganizer.__selectLeftPaneBuiltIn = win.PlacesOrganizer.selectLeftPaneBuiltIn; win.PlacesOrganizer.selectLeftPaneBuiltIn = win.eval(`(${win.PlacesOrganizer.selectLeftPaneBuiltIn})` .replace(/^\((async\s)?.*?selectLeftPaneBuiltIn/, "($1function selectLeftPaneBuiltIn") .replace("{", `{ if (/^(?:Downloads|History|Tags)$/.test(arguments[0])) { this._initFolderTree = this.__initFolderTree; this._initFolderTree(); this.selectLeftPaneContainerByHierarchy = this.__selectLeftPaneContainerByHierarchy; this.selectLeftPaneBuiltIn = this.__selectLeftPaneBuiltIn; return this.selectLeftPaneBuiltIn.apply(this, arguments); }`) .replace(/(case\s*"AllBookmarks":[\S\s]+?)PlacesUtils\s*\.\s*asContainer\s*\(\s*this\s*\.\s*_places\s*\.\s*selectedNode\s*\)\s*\.\s*containerOpen\s*=\s*true\s*;/, "$1") .replace(/\[\s*PlacesUtils\s*\.\s*virtualAllBookmarksGuid\s*\]/, "[PlacesUtils.bookmarks.virtualToolbarGuid]") .replace(/(\[)\s*PlacesUtils\s*\.\s*virtualAllBookmarksGuid\s*,/g, "$1")); }, "chrome://browser/content/places/places.xhtml?site_query": win => { load_scripts_by_url["chrome://browser/content/places/places.xhtml"](win); win.PlacesOrganizer._initFolderTree = win.eval(`(${win.PlacesOrganizer._initFolderTree})` .replace("RESULTS_AS_ROOTS_QUERY", "RESULTS_AS_SITE_QUERY") .replace(/\}\)$/, "if (this._places.view.rowCount > 0) this._places.view.selection.select(0);\n})")); }, "chrome://browser/content/places/places.xhtml?date_site_query": win => { load_scripts_by_url["chrome://browser/content/places/places.xhtml"](win); win.PlacesOrganizer._initFolderTree = win.eval(`(${win.PlacesOrganizer._initFolderTree})` .replace("RESULTS_AS_ROOTS_QUERY", "RESULTS_AS_DATE_SITE_QUERY") .replace(/\}\)$/, "if (this._places.view.rowCount > 0) this._places.view.selection.select(0);\n})")); }, }; load_scripts_by_url[location.href]?.(window); })();
Отредактировано Vitaliy V. (18-12-2020 18:38:20)
Отсутствует
linlin
Попробуйте вот набросал код для custom_script_all_win.js
добавить в конец файла
Работает, ура!
Только Панель закладок с развёрнутым списком получилась. Лучше, чтобы сначала все списки были свёрнуты, а я бы потом нужный мне развернула.
Отсутствует
linlin
Теперь пойдёт?
Вот ещё такое дополнение можно сделать для закладок во вкладке
del
и открыть адрес chrome://browser/content/places/places.xhtml?site_query
слева будут папки сайтов из истории
Отредактировано Vitaliy V. (18-12-2020 18:40:29)
Отсутствует
linlin
Теперь пойдёт?
В сообщении №9463 новый подкорректированный код? Что-то результат пока тот же - список "Панель закладок" появляется сразу развёрнутым. Попробовала на чистом профиле, там дополнительные панельки с кнопками появились, а файл custom_script_all_win.js что-то похоже не сработал совсем - Журнал, Загрузки, Метки, Все закладки не исчезли.
linlin
Вот ещё такое дополнение можно сделать для закладок во вкладкеи открыть адрес chrome://browser/content/places/places.xhtml?site_query
слева будут папки сайтов из истории
Это тоже в конец custom_script_all_win.js надо вставить? Я не пробовала пока. Но вообще, наверное, это для тех, кто историю смотрит, а не удаляет её из Библиотеки, как я.
Отсутствует
В сообщении №9463 новый подкорректированный код?
Да, в Readme.txt написано что делать после редактирования или см. скриншот https://github.com/VitaliyVstyle/Vitali … eenshot_03
на новом профиле в настройках не забудьте включить custom_script_all_win.js
Если папка всё равно открыта, закройте, их состояние запоминается...
Отредактировано Vitaliy V. (26-12-2020 19:46:18)
Отсутствует