Nein, ohne das const Cu = Components.utils; in der ersten Zeile warf Firefox beim Start die Fehlermeldung aus, dass die Konfigurationsdatei nicht gelesen werden konnte oder so ähnlich.
Beiträge von Lugi
-
-
Ja, die Buttons sind nach der Korrektur wieder da und funktionieren, wie sie sollen.
-
Die hier gezeigte config.js ist falsch. So ist sie korrekt:
Code: [Programmordner]\config.js
Alles anzeigenconst Cu = Components.utils; try { Cu.importGlobalProperties(['PathUtils']); if (!Services.appinfo.inSafeMode) { let path = PathUtils.parent(PathUtils.xulLibraryPath); if (Services.appinfo.OS == 'Darwin') { // macOS path = PathUtils.join(PathUtils.parent(path), 'Resources'); } var ucjsDirPath = PathUtils.join(path, 'userChromeJS'); path = PathUtils.join(ucjsDirPath, 'main.js'); const mainFileURI = PathUtils.toFileURI(path); Services.scriptloader.loadSubScript(mainFileURI, this, 'UTF-8'); } } catch(e) { Cu.reportError(e); }
-
Die Buttos sind komischer Weise verschwunden. Ich habe geprüft, ob alle Dateien noch da sind. Ein paar von ihnen fehlten. Ich habe sie erneut erstellt, Firefox abgesichtert neu gestartet, normal neu gestartet, aber die Buttos sind trotzdem nicht mehr vorhanden, auch nicht in Symbolleiste anpassen…. Hier ist noch mal die vollständige Liste, was als UTF-8 gespeichert vorhanden ist:
Code: [Profilordner]\chrome\sidebarumschalter.uc.js
Alles anzeigen(function() { if (location != 'chrome://browser/content/browser.xhtml') return; try { // Lesezeichen-Seitenleiste Öffnen/Schließen CustomizableUI.createWidget({ id: 'BookmarksSidebar-ToolBarButton', type: 'custom', defaultArea: CustomizableUI.AREAS, onBuild: function(aDocument) { var toolbaritem = aDocument.createElementNS('http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul', 'toolbarbutton'); var props = { id: 'BookmarksSidebar-ToolBarButton', class: 'toolbarbutton-1 chromeclass-toolbar-additional', label: 'Lesezeichen-Sidebar', tooltiptext: 'Lesezeichen-Sidebar öffnen/schließen', style: 'list-style-image: url()', onclick: 'if (event.button == 0) { \ SidebarUI.toggle("viewBookmarksSidebar"); \ }; ' }; for (var p in props) toolbaritem.setAttribute(p, props[p]); return toolbaritem; } }); // Chronik-Seitenleiste Öffnen/Schließen CustomizableUI.createWidget({ id: 'HistorySidebar-ToolBarButton', type: 'custom', defaultArea: CustomizableUI.AREAS, onBuild: function(aDocument) { var toolbaritem = aDocument.createElementNS('http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul', 'toolbarbutton'); var props = { id: 'HistorySidebar-ToolBarButton', class: 'toolbarbutton-1 chromeclass-toolbar-additional', label: 'Chronik-Sidebar', tooltiptext: 'Chronik-Sidebar öffnen/schließen', style: 'list-style-image: url()', onclick: 'if (event.button == 0) { \ SidebarUI.toggle("viewHistorySidebar"); \ }; ' }; for (var p in props) toolbaritem.setAttribute(p, props[p]); return toolbaritem; } }); } catch(e) { }; })();
Code: [Profilordner]\chrome\userChrome.css#menubar-items,#TabsToolbar,#sidebar-header,#sidebar-search-container{display:none!important}
Code: [Profilordner]\chrome\userChrome.jsuserChrome.ignoreCache = true; userChrome.import("*", "UChrm");
Code: [Programmordner]\config.js
Alles anzeigenconst Cu = Components.utils; try { Cu.import("resource://gre/modules/Services.jsm"); Cu.import("resource://gre/modules/osfile.jsm"); if (!Services.appinfo.inSafeMode) { let path = OS.Constants.Path.libDir; if (Services.appinfo.OS == 'Darwin') { // macOS path = OS.Path.join(OS.Path.dirname(path), "Resources"); }; var ucjsDirPath = OS.Path.join(path, "userChromeJS"); path = OS.Path.join(ucjsDirPath, "main.js"); let mainFileURI = OS.Path.toFileURI(path); Services.scriptloader.loadSubScript(mainFileURI, this, "UTF-8"); }; } catch(e) { Cu.reportError(e); };
Code: [Programmordner]\userChromeJS\main.js
Alles anzeigen/* ***** BEGIN LICENSE BLOCK ***** * Version: MPL 1.1/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Mozilla Public License Version * 1.1 (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Original Code is the userChrome.js component. * * The Initial Developer of the Original Code is * Simon Bünzli <zeniko@gmail.com> * * Portions created by the Initial Developer are Copyright (C) 2007 * the Initial Developer. All Rights Reserved. * * Contributor(s): * alta88 <alta88@gmail.com> * aborix <www.camp-firefox.de/forum> * * Alternatively, the contents of this file may be used under the terms of * either the GNU General Public License Version 2 or later (the "GPL"), or * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), * in which case the provisions of the GPL or the LGPL are applicable instead * of those above. If you wish to allow use of your version of this file only * under the terms of either the GPL or the LGPL, and not to allow others to * use your version of this file under the terms of the MPL, indicate your * decision by deleting the provisions above and replace them with the notice * and other provisions required by the GPL or the LGPL. If you do not delete * the provisions above, a recipient may use your version of this file under * the terms of any one of the MPL, the GPL or the LGPL. * * ***** END LICENSE BLOCK ***** */ Cu.import("resource://gre/modules/FileUtils.jsm"); let UserChrome_js = { init: function() { Services.obs.addObserver(this, "final-ui-startup", false); Services.obs.addObserver(this, "domwindowopened", false); }, // observer observe: function(aSubject, aTopic, aData) { switch (aTopic) { case "final-ui-startup": let path = OS.Constants.Path.profileDir; let ucFilePath = OS.Path.join(path, "chrome", "userChrome.js"); let ucFile = new FileUtils.File(ucFilePath); if (!ucFile.exists()) { let path = OS.Path.join(ucjsDirPath, "Readme.txt"); let readmeFile = new FileUtils.File(path); readmeFile.copyTo(ucFile.parent, "userChrome.js"); }; if (ucFile.exists() && ucFile.isFile()) { let path = OS.Path.join(ucjsDirPath, "utilities.js"); this.utilFileURI = OS.Path.toFileURI(path); this.ucFileURI = OS.Path.toFileURI(ucFilePath); // Services.obs.addObserver(this, "domwindowopened", false); }; Services.obs.removeObserver(this, "final-ui-startup"); break; case "domwindowopened": aSubject.addEventListener("load", this, {capture: true, once: true}); break; } }, // event listener for load handleEvent: function(aEvent) { let document = aEvent.originalTarget; let window = document.defaultView; if (document.location && document.location.protocol == "chrome:") { try { Services.scriptloader.loadSubScript(this.utilFileURI, window, "UTF-8"); Services.scriptloader.loadSubScript(this.ucFileURI, window, "UTF-8"); } catch (ex) { // script execution can be stopped with |throw "stop";| if (ex != "stop") { Cu.reportError(ex); } } }; } }; UserChrome_js.init();
Code: [Programmordner]\userChromeJS\Readme.txt
Alles anzeigen/* * userChromeJS * * The file userChrome.js can be used to customize the functioning of Mozilla's * user interface. Usage and syntax follow below; for useful code snippets see * http://mozilla.zeniko.ch/userchrome.js.html. * * Examples: * setTimeout(function() { document.title = "A new title for every window" }, 2000); * * if (location == "chrome://browser/content/browser.xul") { * alert("Script loaded in main browser only"); * } * * // DOMi window * if (location == "chrome://inspector/content/inspector.xul") { * // Move Urlbar box to main toolbar * var tb = document.getElementById('bxURLBar'); * var el = document.getElementById('mbrInspectorMain'); * if (tb && el) el.appendChild(tb, el.firstChild); * } * * NOTE: * userChromeJS includes an 'import' function to facilitate file management. * An absolute path or relative path with Directory name property token can be * used, as follows: * * // Single file (javascript .js or overlay .xul file) * userChrome.import("Full file path"); * userChrome.import("Relative file path", "Token"); * // All .js and .xul files in a folder will be loaded. * userChrome.import("Full file folder path"); * userChrome.import("Relative file folder path/name", "Token"); * userChrome.import("*", "Token"); * * NOTE: * Absolute windows files and folders must be have backslash escaped: * "C:\\Program Files\\Mozilla\\scripts\\myscript.js" * * Examples: * // Import script in [ProfileDir]/chrome/scripts/myscript.js * userChrome.import("scripts/myscript.js", "UChrm"); * // Import script in [Profiles]/scripts/myscript.js (share same script in * // multiple profiles * userChrome.import("scripts/myscript.js", "DefProfRt"); * // All .js or .xul in profile chrome directory * userChrome.import("*", "UChrm"); * // Import overlay * userChrome.import("C:\\Program Files\\Mozilla\\scripts\\myOverlay.xul"); * // Import everything in Desktop folder /scripts * userChrome.import("scripts", "Desk"); * // Perhaps the only thing you need in this file.. * if (location == "chrome://browser/content/browser.xul") { * userChrome.import("scripts", "DefProfRt"); * } * * NOTE: * For a full listing of directory tokens see the two links found here: * https://developer.mozilla.org/en-US/Add-ons/Code_snippets/File_I_O#Getting_files_in_special_directories * // What's the path for a token? This will print it in the console. * userChrome.log(userChrome.getAbsoluteFile("Desk").path, "getAbsoluteFile:'Desk'"); * * NOTE: * userChromeJS includes a log function, invoked as follows: * userChrome.log("string1"[, "string2"]) * Example: * userChrome.log("hello world!", "myscript.js"); * Results in a console message: * 2009-05-22 18:07:40 userChromeJS myscript.js: hello world! * * NOTE: * The date format for the userChrome.log console logger may be user defined: * Example: * userChrome.dateFormat = "%Y-%m-%d %H:%M:%S"; * * NOTE: * The default charSet is "UTF-8"; for code using the 'import' or * 'importFolder' functions to manage files, the charSet for subscript loader * may be user defined, prior to calling the import or importFolder functions: * Example: * userChrome.charSet = "UTF-8"; * * NOTE: * Scripts are stored in a startup cache and loaded from it. * After a change in userChrome.js you heve to restart Firefox with clearing * this cache to make sure the changed file is read. * By default this applies to imported .js files too. You can bypass the cache * for these scripts with this statement BEFORE any import statement: * userChrome.ignoreCache = true; * */
Code: [Programmordner]\userChromeJS\utilities.js
Alles anzeigen/* ***** BEGIN LICENSE BLOCK ***** * Version: MPL 1.1/GPL 2.0/LGPL 2.1 * * The contents of this file are subject to the Mozilla Public License Version * 1.1 (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" basis, * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License * for the specific language governing rights and limitations under the * License. * * The Original Code is the userChromeJS utilities. * * The Initial Developer of the Original Code is * alta88 <alta88@gmail.com> * * Portions created by the Initial Developer are Copyright (C) 2014 * the Initial Developer. All Rights Reserved. * * Contributor(s): * aborix <www.camp-firefox.de/forum> * * Alternatively, the contents of this file may be used under the terms of * either the GNU General Public License Version 2 or later (the "GPL"), or * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"), * in which case the provisions of the GPL or the LGPL are applicable instead * of those above. If you wish to allow use of your version of this file only * under the terms of either the GPL or the LGPL, and not to allow others to * use your version of this file under the terms of the MPL, indicate your * decision by deleting the provisions above and replace them with the notice * and other provisions required by the GPL or the LGPL. If you do not delete * the provisions above, a recipient may use your version of this file under * the terms of any one of the MPL, the GPL or the LGPL. * * ***** END LICENSE BLOCK ***** */ /* ........ Utility functions ............................................... */ var userChrome = { path: null, dirToken: null, ignoreCache: false, get loadOverlayDelay () { if (!this._loadOverlayDelay) this._loadOverlayDelay = 500; return this._loadOverlayDelay; }, set loadOverlayDelay(delay) { this._loadOverlayDelay = delay; }, get loadOverlayDelayIncr() { if (!this._loadOverlayDelayIncr) this._loadOverlayDelayIncr = 1600; return this._loadOverlayDelayIncr; }, set loadOverlayDelayIncr(delay) { this._loadOverlayDelayIncr = delay; }, import: function(aPath, aRelDirToken) { let file; this.path = aPath; this.dirToken = aRelDirToken; if (aRelDirToken) { // Relative file let absDir = this.getAbsoluteFile(aRelDirToken); if (!absDir) return; let pathSep = absDir.path.match(/[\/\\]/)[0]; file = absDir.path + (aPath == "*" ? "" : pathSep + aPath.replace(/[\/\\]/g, pathSep)); } else // Absolute file file = aPath; file = this.getFile(file); if (!file) return; if (file.isFile()) { if (/\.js$/i.test(file.leafName)) this.loadScript(file, aRelDirToken, null); else if (/\.xul$/i.test(file.leafName)) { let xul_files = []; xul_files.push(file); this.loadOverlay(xul_files, this.dirToken, null, this.loadOverlayDelay); // this.loadOverlayDelay = this.loadOverlayDelay + this.loadOverlayDelayIncr; } else this.log("File '" + this.path + "' does not have a valid .js or .xul extension.", "userChrome.import"); } else if (file.isDirectory()) this.importFolder(file); else this.log("File '" + this.path + "' is neither a file nor a directory.", "userChrome.import"); }, loadScript: function(aFile, aFolder, aRelDirToken) { setTimeout(function() { Components.classes["@mozilla.org/moz/jssubscript-loader;1"] .getService(Components.interfaces.mozIJSSubScriptLoader) .loadSubScriptWithOptions(userChrome.getURLSpecFromActualFile(aFile), {target: window, charset: userChrome.charSet, ignoreCache: userChrome.ignoreCache}); // log it userChrome.log(aRelDirToken ? ("[" + aRelDirToken + "]/" + (aFolder && aFolder != "*" ? aFolder + "/" : "") + aFile.leafName) : aFile.path, "userChrome.loadScript"); }, 0); }, // XXX: Due to bug 330458, an overlay must finish before another can be // called, otherwise neither are successful. Implementing an observer to // serialize is better left as a fix in the core bug. Here, settimout values // are set to minimize but there is no quarantee; overlay cdata (if any) // needs to consider overlay completions and logging does not strictly mean // an overlay has completed, rather that the overlay file has been invoked. loadOverlay: function(aFiles, aRelDirToken, aFolder, aDelay) { //userChrome.log(aDelay+" multiple import delay", userChrome.loadOverlay); // Increment multiple import delay this.loadOverlayDelay = this.loadOverlayDelay + this.loadOverlayDelayIncr; setTimeout(function() { if (aFiles.length > 0) { //userChrome.log(userChrome.loadOverlayDelay+" inter folder delay", userChrome.loadOverlay); // log it userChrome.log(aRelDirToken ? ("[" + aRelDirToken + "]/" + (aFolder && aFolder != "*" ? aFolder + "/" : "") + aFiles[0].leafName) : aFiles[0].path, "userChrome.loadOverlay"); document.loadOverlay(userChrome.getURLSpecFromActualFile(aFiles.shift()), null); setTimeout(arguments.callee, userChrome.loadOverlayDelay); } }, aDelay); }, // Include all files ending in .js and .xul from passed folder importFolder: function(aFolder) { let files = aFolder.directoryEntries .QueryInterface(Components.interfaces.nsISimpleEnumerator); let xul_files = []; while (files.hasMoreElements()) { let file = files.getNext().QueryInterface(Components.interfaces.nsIFile); if (/\.js$/i.test(file.leafName) && file.leafName != "userChrome.js") this.loadScript(file, this.path, this.dirToken); else if (/\.xul$/i.test(file.leafName)) { xul_files.push(file); } } if (xul_files.length > 0) this.loadOverlay(xul_files, this.dirToken, this.path); }, getFile: function(aPath, aRelDirToken) { try { let file = Components.classes["@mozilla.org/file/local;1"] .createInstance(Components.interfaces.nsIFile); file.initWithPath(aPath); // Bad file doesn't throw on initWithPath, need to test if (file.exists()) return file; this.log("Invalid file '" + this.path + (this.dirToken ? ("' or file not found in directory with token '" + this.dirToken) : "") + "' or other access error.", "userChrome.getFile"); } catch (e) { // Bad folder throws on initWithPath this.log("Invalid folder '" + this.path + (this.dirToken ? ("' or folder not found in directory with token '" + this.dirToken) : "") + "' or other access error.", "userChrome.getFile"); } return null; }, getAbsoluteFile: function(aRelDirToken) { try { let absDir = Components.classes["@mozilla.org/file/directory_service;1"] .getService(Components.interfaces.nsIProperties) .get(aRelDirToken, Components.interfaces.nsIFile); return absDir; } catch (e) { this.log("Invalid directory name token '" + this.dirToken + "' or directory cannot be accessed.", "userChrome.getAbsoluteFile"); return null; } }, getURLSpecFromActualFile: Components.classes["@mozilla.org/network/io-service;1"] .getService(Components.interfaces.nsIIOService) .getProtocolHandler("file") .QueryInterface(Components.interfaces.nsIFileProtocolHandler) .getURLSpecFromActualFile, /* Console logger */ log: function(aMsg, aCaller) { Components.classes["@mozilla.org/consoleservice;1"] .getService(Components.interfaces.nsIConsoleService) .logStringMessage(this.date + " userChromeJS " + (aCaller ? aCaller +": " : "") + aMsg); }, get dateFormat() { if (!this._dateFormat) this._dateFormat = "%Y-%m-%d %H:%M:%S"; return this._dateFormat; }, set dateFormat(format) { this._dateFormat = format; }, get date() { let date = new Date(); // return date.toLocaleFormat(this.dateFormat); try { date = date.toLocaleFormat(this.dateFormat); } catch(e) { date = date.toString(); }; return date; }, set charSet(val) { this._charSet = val; }, get charSet() { if (!this._charSet) this._charSet = "UTF-8"; // use "UTF-8". Defaults to ascii if null. return this._charSet; } };
-
Es geht um Buttons, die sich in der Sidebar öffnen.
-
Jo, das hatte ich übersehen. Diese Darstellung eines anderen Beitrags dort verleitet mich irgendwie darin, es zu ignorieren, weil es so eine typische Optik einer Signatur in Foren hat. Dazu kam meine Überforderung mit den vielen Links und Erklärungsseiten. Ich bedanke mich also sehr dafür, dass du noch mal drüber geschaut und mich erneut darauf hingewiesen hast. Nun funktionier es.
Cool wären jetzt noch solche Buttons für Download, Firefox-Konto und Erweiterungen, aber falls ihr dafür nicht auf Anhieb eine Lösung habt, ist das nicht schlimm. Dann fuchse ich mich da ein ander Mal rein oder öffne einen neuen Thread, falls diese Buttons überhaupt möglich sind… -
Wie du in meiner Auflistung sehen kannst, ist das alles so der Fall. Es funktioniert trotzdem nicht.
-
Ich schrieb bereits, dass ich diese Datei gelöscht habe. Scrolle in der Auflistung dort mal ganz runter.
-
Ich nehme mal an, die Zeile mit den zwei Schrägstrichen ist ein Kommentar und unwichtig. Die anderen drei Zeilen sind exakt so vorhanden. Wie beschrieben funktioniert es nicht.
-
Ich habe diese Datei gelöscht, Firefox mit sicheren Modus neu gestartet, dann normal neu gestartet und die Buttons sind weiterhin nicht in Symbolleiste anpassen.
-
Vielleicht habe ich dort ja auch die falsche Datei. Ich habe dir doch alles aufgeschrieben, dort in der Auflistung ganz unten. Die Datei ist doch so richtig? Soll ich die Datei ganz oben in der Auflistung löschen? Ändert das was?
Edit: Ich habe sie testweiste gelöscht, Firefox mit sicheren Modus neu gestartet, dann normal neu gestartet und die Buttons sind weiterhin nicht in Symbolleiste anpassen. -
Und, ist die Datei nicht in diesem Ordner?
-
In deinem Screenshot steht nichts von config-prefs.js.
-
Die ist doch in verschiedenen Formen bereits in beiden Ordnern, weil es auf den vielen Erklärungsseiten verschiedene Anweisungen gab.
-
Das nehme ich mal als Nein. Schade, aber okay.
-
-
Mich überfordern die vier oder mehr unterschiedliche Seiten mit Erklärungen sehr. Könntest du oben vielleicht mal drüber schauen und sagen, wo der Fehler ist? Ich kann ihn nicht finden.
-
Ja, und jetzt ist die Datei dort, wo sie sein soll, denke ich, und ich hatte gefragt, warum es immer noch nicht funktioniert und was mir noch fehlt.
-
In diesem Thread hier geht es aber um die Buttons, die ich mir wünschen würde.
-
Zitat
Du musst nicht den ganzen Text in Fettbuchstaben schreiben.
Ich habe gar nicht gemerkt, dass alles fett ist. Ich hatte was rein kopiert, das Fett war, und habe alles markiert und zwei Mal auf den B-Button im Beitrags-Editor gedrückt, weil das normaler Weise alles un-fett macht. Das hatte wohl nicht geklappt.
ZitatHier die Erklärung was man genau machen muss, und die benötigten Dateien dazu:
Jo, das habe ich alles gemacht, wie du in meiner Auflistung sehen kannst.
Was ich nicht gemacht habe, ist folgendes:ZitatAnschließend muss jeweils der Scriptcache gelöscht werden.
Dazu den Browser im abgesicherten Modus/Fehlerbehebungsmodus starten...schließen... und dann wieder normal starten.
Alternativ erst die Änderungen machen (beim Nightly also noch vor dem Update) bei geöffnetem Browser, und dann wenn vorhanden, einen Neustart per Restartbutton.uc.js machen.
Ich habe nämlich keine Ahnung, wie man diesen Button nutzt oder wie man Firefox abgesichert startet.Da ist die Anleitung wieder unvollständig. Es wird in Anleitungen scheinbar immer angenommen, dass Nutzer solche Dinge einfach schon wüssten.
Edit: Ich habe es ergooglet und gemacht. Es funktioniert trotzdem noch nicht. Die gewünschten Button sind nicht da.