Beiträge von sam2008
-
-
-
kannst du bitte nochmals mit diese prüfen:
gerne doch, aber leider auch wieder nur das Standard Profil
Bei mir aber startet richtig. Wenn in in meine Appmenu.uc.js UserScript, "Firefox Verzeichnisse==>Profil" klicke, öffnet Profile Name dass am ende ".Clean" hat.
Meine Profiles.ini ist auch so:
Code
Alles anzeigen[InstallFFD4EDB6BAA7D4C3] Default=Profiles/3vt4xz1h.dev-edition-default [Profile2] Name=Clean IsRelative=1 Path=Profiles/jh2cmw09.Clean [Profile1] Name=default IsRelative=1 Path=Profiles/ptm2buf0.default Default=1 [Profile0] Name=dev-edition-default IsRelative=1 Path=Profiles/3vt4xz1h.dev-edition-default [InstallE7CF176E110C211B] Default=Profiles/ptm2buf0.default [General] StartWithLastProfile=0 Version=2
Mfg
-
bitte mit diese prüfen:
Hallo sam2008 ..
danke für deinen Versuch mir zu helfen
Es wird auch damit wieder das Standard Profil aufgerufen.
Sehr gerne, kannst du bitte nochmals mit diese prüfen:
Mfg
-
die Leerzeichen vor und nach dem -P fehlen …
Hallo Sören, danke für den Hinweis.
Auch so:
öffnet sich immer das Hauptprofil.
Hallo 2002Andreas ,
bitte mit diese prüfen:
Mfg
-
Hallo Andreas,
leider hat nicht funktioniert wie du geschrieben hast.
Bei mir funktioniert nur mit das code dass ich vorher gepostet habe.
Mfg
-
Hallo Endor ,
Ich habe endlich geschafft, hier ist ToolbarAutoHide.uc.js Code, wenn jemand braucht:
CSS
Alles anzeigen(function () { if (location != 'chrome://browser/content/browser.xhtml') return; try { let navbox = document.getElementById('navigator-toolbox'); let menubar = document.getElementById('toolbar-menubar'); let tabsbar = document.getElementById('TabsToolbar'); let navbar = document.getElementById('nav-bar'); let perbar = document.getElementById('PersonalToolbar'); let titlebar = document.getElementById('titlebar'); // Überwachen Änderungen an Symbolleistenattributen/toolbar let observer = new MutationObserver(function (mutations) { mutations.forEach(function (mutation) { toolbarFlag(mutation); }); }); let config = { attributes: true, attributeOldValue: true, attributeFilter: ['customizing', 'autohide', 'collapsed', 'barAuto'] }; if (menubar) observer.observe(menubar, config); if (tabsbar) observer.observe(tabsbar, config); if (navbar) observer.observe(navbar, config); if (perbar) observer.observe(perbar, config); // Überwachen Größe der Tableiste/tabsbar if (tabsbar) { let resizeObserver = new ResizeObserver(function (entries) { entries.forEach(function (entry) { toolbarFlag(entry); }); }); resizeObserver.observe(tabsbar); } // Tab-Leiste und Navigationsleiste können ebenfalls ausgeblendet werden if (tabsbar) tabsbar.setAttribute('toolbarname', tabsbar.getAttribute('aria-label') || "Browser-Tabs"); if (navbar) navbar.setAttribute('toolbarname', navbar.getAttribute('aria-label') || "Navigation"); if (menubar) menubar.setAttribute('toolbarname', "Menüleiste"); // Speichern, ob in Firefox automatisch geöffnet/geschlossen werden soll if (menubar) menubar.setAttribute('persist', 'barAuto'); if (tabsbar) tabsbar.setAttribute('persist', 'barAuto'); if (navbar) navbar.setAttribute('persist', 'barAuto'); if (perbar) perbar.setAttribute('persist', 'barAuto'); if (tabsbar) tabsbar.removeAttribute('barAuto'); // Fügen Navigationsfeld ein leeres Element hinzu if (navbox) { let box = MozXULElement.parseXULToFragment(` <vbox id="nav-box-escape" context="toolbar-context-menu" tooltiptext="Doppelklicken Sie, um die Symbolleiste anzuzeigen"/> `); navbox.appendChild(box); } // Element zum Symbolleistenmenü hinzufügen let menuCustomize = document.getElementById('menu_customizeToolbars'); if (menuCustomize) { let menu = MozXULElement.parseXULToFragment(` <menu id="toolbarauto-menu" label="Automatisch ausblenden"> <menupopup id="toolbarauto-popup"/> </menu> <menuseparator/> `); menuCustomize.before(menu); document.getElementById('toolbarauto-popup').addEventListener('popupshowing', autoHideToolbarsPopupShowing); } // Zum Rechtsklickmenü in der Navigation hinzufügen let viewSeparator = document.getElementById('viewToolbarsMenuSeparator'); if (viewSeparator) { let contextmenu = MozXULElement.parseXULToFragment(` <menu id="toolbarauto-contextmenu" label="Automatisch ausblenden"> <menupopup id="toolbarauto-contextpopup"/> </menu> <menuseparator/> `); viewSeparator.after(contextmenu); document.getElementById('toolbarauto-contextpopup').addEventListener('popupshowing', autoHideToolbarsPopupShowing); } // Überarbeitetes CSS für Auto-Hide let uccss = ` #toggle_TabsToolbar > label:before { content: "Browser-Tabs" !important; } #toggle_nav-bar > label:before { content: "Navigation" !important; } #navigator-toolbox #titlebar { -moz-box-ordinal-group: 0; } #navigator-toolbox #toolbar-menubar { -moz-box-ordinal-group: 1; } #navigator-toolbox #TabsToolbar { -moz-box-ordinal-group: 2; } #navigator-toolbox #nav-bar { -moz-box-ordinal-group: 3; } #navigator-toolbox #PersonalToolbar { -moz-box-ordinal-group: 4; } /* Wichtig: Überarbeitete CSS-Regeln für Auto-Hide */ #navigator-toolbox[barsAuto]:not([custommode]) { z-index: 100 !important; position: relative !important; } #navigator-toolbox:not([inFullscreen], [custommode]) #nav-box-escape[notShown] { -moz-box-ordinal-group: 10; transition: all 0.3s ease 0s; height: 5px; cursor: alias; } #navigator-toolbox:not([inFullscreen], [custommode]) #nav-box-escape:not([notShown]) { display: none; } #navigator-toolbox:not([inFullscreen], [custommode]) #nav-box-escape[allAuto] { margin-block-end: -5px; } #navigator-toolbox:not([inFullscreen], [custommode]):hover #nav-box-escape[allAuto] { height: 0; margin-block-end: 0; } /* Vereinfachte und korrigierte Hide/Show Logik */ #navigator-toolbox[barsAuto]:not([inFullscreen], [custommode]) { margin-block-end: 0; transition: all 0.3s ease 0s !important; } #navigator-toolbox[barsAuto]:not([inFullscreen], [custommode]):hover { margin-block-end: calc(var(--barshide-height) * -1px); } #navigator-toolbox:not([inFullscreen], [custommode]) > #titlebar[barsAuto] { margin-block-start: calc(var(--ttlhide-height) * -1px) !important; transition: all 0.3s ease 0s !important; } #navigator-toolbox:not([inFullscreen], [custommode]):hover > #titlebar[barsAuto] { margin-block-start: 0 !important; } /* Wichtig: Korrekte Hide/Show für alle Toolbars */ #navigator-toolbox:not([inFullscreen], [custommode]) #toolbar-menubar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]) #TabsToolbar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]) #nav-bar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]) #PersonalToolbar[barAuto] { transition: all 0.3s ease 0s !important; opacity: 0 !important; height: 0 !important; overflow: hidden !important; margin-block: 0 !important; padding-block: 0 !important; } #navigator-toolbox:not([inFullscreen], [custommode]):hover #toolbar-menubar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]):hover #TabsToolbar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]):hover #nav-bar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]):hover #PersonalToolbar[barAuto] { opacity: 1 !important; height: auto !important; overflow: visible !important; margin-block: initial !important; padding-block: initial !important; } `; let ucuri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(uccss)); let ucsss = Cc['@mozilla.org/content/style-sheet-service;1'] .getService(Ci.nsIStyleSheetService); ucsss.loadAndRegisterSheet(ucuri, ucsss.AGENT_SHEET); } catch (e) { console.error(e); }; })(); window.addEventListener('MozAfterPaint', toolbarsset, { once: true }); document.addEventListener('keydown', function (event) { if (event.keyCode == 27) navescape(); }); let escapeBox = document.getElementById('nav-box-escape'); if (escapeBox) { escapeBox.addEventListener('dblclick', navescape); } function navescape() { let navbar = document.getElementById('nav-bar'); let tabsbar = document.getElementById('TabsToolbar'); if (navbar) { navbar.setAttribute('collapsed', 'false'); navbar.removeAttribute('barAuto'); } if (tabsbar) { tabsbar.setAttribute('collapsed', 'false'); tabsbar.removeAttribute('barAuto'); } toolbarsset(); } function toolbarFlag(aEvent) { let barelm = aEvent.target; let attribute = aEvent.attributeName; if (barelm && barelm.id == 'TabsToolbar' && attribute == 'collapsed' && !barelm.hasAttribute('collapsed')) { barelm.setAttribute('collapsed', aEvent.oldValue); } toolbarsset(); } function toolbarsset() { let boxelm = document.getElementById('navigator-toolbox'); let ttlbar = document.getElementById('titlebar'); let escbox = document.getElementById('nav-box-escape'); let barshide = 0, barsAuto = false, custommode = false, notShown = true; let ttlhide = 0, tbarsAuto = false, allAuto = false; let toolbarsid = ['toolbar-menubar', 'TabsToolbar', 'nav-bar', 'PersonalToolbar']; for (let toolbar of toolbarsid) { let barelm = document.getElementById(toolbar); if (!barelm) continue; let hidingAttr = (barelm.getAttribute('type') == 'menubar') ? 'autohide' : 'collapsed'; let hasShown = (barelm.getAttribute(hidingAttr) == 'true'); if (hasShown) barelm.removeAttribute('barAuto'); let barheight = barelm.clientHeight; if (barelm.hasAttribute('barAuto')) { barsAuto = true; allAuto = true; barelm.style.setProperty("--barhide-height", barheight); barshide += barheight; if (toolbar == 'toolbar-menubar' || toolbar == 'TabsToolbar') { tbarsAuto = true; ttlhide += barheight; } } else { if (!hasShown) notShown = false; barelm.style.setProperty("--barhide-height", 0); } if (barelm.hasAttribute('customizing')) custommode = true; } if (boxelm) { if (barsAuto) boxelm.setAttribute('barsAuto', 'true'); else boxelm.removeAttribute('barsAuto'); if (custommode) boxelm.setAttribute('custommode', 'true'); else boxelm.removeAttribute('custommode'); } if (ttlbar) { if (tbarsAuto) ttlbar.setAttribute('barsAuto', 'true'); else ttlbar.removeAttribute('barsAuto'); ttlbar.style.setProperty("--ttlhide-height", ttlhide); } if (escbox) { if (notShown) { escbox.setAttribute('notShown', 'true'); if (allAuto) escbox.setAttribute('allAuto', 'true'); else escbox.removeAttribute('allAuto'); } else { escbox.removeAttribute('notShown'); } } if (boxelm) { boxelm.style.setProperty("--barshide-height", barshide); } } function autoHideToolbarsPopupShowing(aEvent) { let popup = aEvent.target; if (popup != aEvent.currentTarget) return; while (popup.firstChild) popup.removeChild(popup.firstChild); let toolbarsid = ['toolbar-menubar', 'TabsToolbar', 'nav-bar', 'PersonalToolbar']; for (let toolbar of toolbarsid) { let barelm = document.getElementById(toolbar); if (!barelm) continue; let hidingAttr = (barelm.getAttribute('type') == 'menubar') ? 'autohide' : 'collapsed'; let toolbarname = barelm.getAttribute('toolbarname') || toolbar; // CSP-konforme Erstellung des Menüelements let menuitem = document.createXULElement('menuitem'); menuitem.id = `toolbarauto-${toolbar}`; menuitem.setAttribute('toolbarId', toolbar); menuitem.setAttribute('type', 'checkbox'); menuitem.setAttribute('label', toolbarname); menuitem.setAttribute('checked', barelm.hasAttribute('barAuto')); menuitem.setAttribute('disabled', barelm.getAttribute(hidingAttr) == 'true'); // CSP-konformer Event-Handler menuitem.addEventListener('command', function(event) { autoHideToolbar(event); }); popup.appendChild(menuitem); } } function autoHideToolbar(aEvent) { let eventelm = aEvent.target; let barid = eventelm.getAttribute('toolbarId'); let barelm = document.getElementById(barid); if (!barelm) return; if (eventelm.getAttribute('checked') == "true") { barelm.setAttribute('barAuto', 'true'); } else { barelm.removeAttribute('barAuto'); } toolbarsset(); }
Mfg
-
Hallo Endor ,
vielen Dank für Info.
Eine kleine Info, in Browser Konsole zeigt nur diese Errors:
Code
Alles anzeigenUncaught TypeError: can't access property "removeAttribute", ttlbar is null toolbarsset file:///C:/Users/Tester/AppData/Roaming/Mozilla/Firefox/Profiles/ptm2buf0.default/chrome/ToolbarAutoHide.uc.js:250 toolbarFlag file:///C:/Users/Tester/AppData/Roaming/Mozilla/Firefox/Profiles/ptm2buf0.default/chrome/ToolbarAutoHide.uc.js:215 resizeObserver file:///C:/Users/Tester/AppData/Roaming/Mozilla/Firefox/Profiles/ptm2buf0.default/chrome/ToolbarAutoHide.uc.js:30 resizeObserver file:///C:/Users/Tester/AppData/Roaming/Mozilla/Firefox/Profiles/ptm2buf0.default/chrome/ToolbarAutoHide.uc.js:29 ToolbarAutoHide.uc.js:250:7 Uncaught TypeError: can't access property "removeAttribute", ttlbar is null toolbarsset file:///C:/Users/Tester/AppData/Roaming/Mozilla/Firefox/Profiles/ptm2buf0.default/chrome/ToolbarAutoHide.uc.js:250 ToolbarAutoHide.uc.js:250:7 Uncaught TypeError: can't access property "addEventListener", document.getElementById(...) is null <anonymous> file:///C:/Users/Tester/AppData/Roaming/Mozilla/Firefox/Profiles/ptm2buf0.default/chrome/ToolbarAutoHide.uc.js:196 Uncaught TypeError: can't access property "getAttribute", barelm is null toolbarsset file:///C:/Users/Tester/AppData/Roaming/Mozilla/Firefox/Profiles/ptm2buf0.default/chrome/ToolbarAutoHide.uc.js:228 ToolbarAutoHide.uc.js:228:3
Gibt es andere UserScript dass gleiche "Automatisch ausblenden" Funktion hat?
Mfg
-
Da sollte mal -moz-box-ordinal-group ausgetauscht werden
Hallo milupo, das habe ich mal gemacht
JavaScript
Alles anzeigen(function () { if (location != 'chrome://browser/content/browser.xhtml') return; try { let navbox = document.getElementById('navigator-toolbox'); let menubar = document.getElementById('toolbar-menubar'); let tabsbar = document.getElementById('TabsToolbar'); let navbar = document.getElementById('nav-bar'); let perbar = document.getElementById('PersonalToolbar'); // Überwachen Änderungen an Symbolleistenattributen/toolbar let observer = new MutationObserver(function (mutations) { mutations.forEach(function (mutation) { toolbarFlag(mutation); }); }); let config = { attributes: true, attributeOldValue: true, attributeFilter: ['customizing', 'autohide', 'collapsed', 'barAuto'] }; observer.observe(menubar, config); observer.observe(tabsbar, config); observer.observe(navbar, config); observer.observe(perbar, config); // Überwachen Größe der Tableiste/tabsbar let resizeObserver = new ResizeObserver(function (entries) { entries.forEach(function (entry) { toolbarFlag(entry); }); }); resizeObserver.observe(tabsbar); /**/ // Tab-Leiste und Navigationsleiste können ebenfalls ausgeblendet werden tabsbar.setAttribute('toolbarname', tabsbar.getAttribute('aria-label')); navbar.setAttribute('toolbarname', navbar.getAttribute('aria-label')); toolbar-menubar.setAttribute('toolbarname', "Menüleiste"); /* // Die Lesezeichenleiste wird standardmäßig automatisch geöffnet und geschlossen menubar.removeAttribute('barAuto'); tabsbar.removeAttribute('barAuto'); navbar.removeAttribute('barAuto'); perbar.setAttribute('barAuto', 'true'); */ // Speichern, ob in Firefox automatisch geöffnet/geschlossen werden soll menubar.setAttribute('persist', 'barAuto'); tabsbar.setAttribute('persist', 'barAuto'); navbar.setAttribute('persist', 'barAuto'); perbar.setAttribute('persist', 'barAuto'); // Die Tab-Leiste weist viele Probleme auf, daher sollte sie sich beim Start nicht automatisch öffnen und schließen. tabsbar.removeAttribute('barAuto'); // Fügen Navigationsfeld ein leeres Element hinzu, um alles zu löschen. Doppelklicken Sie zum Wiederherstellen. let box = MozXULElement.parseXULToFragment(` <vbox id="nav-box-escape" context="toolbar-context-menu" tooltiptext="Doppelklicken Sie, um die Symbolleiste anzuzeigen"/> `); navbox.appendChild(box); /* // Symbolleisten-Kontextmenü zum Kontextmenükopf hinzugefügt document.getElementById('context-navigation').setAttribute('context', 'toolbar-context-menu'); */ // Element zum Symbolleistenmenü hinzufügen let menu = MozXULElement.parseXULToFragment(` <menu id="toolbarauto-menu" label="Automatisch ausblenden"> <menupopup id="toolbarauto-popup" onpopupshowing="autoHideToolbarsPopupShowing(event);"/> </menu> <menuseparator/> `); document.getElementById('menu_customizeToolbars').before(menu); // Zum Rechtsklickmenü in der Navigation hinzufügen let contextmenu = MozXULElement.parseXULToFragment(` <menu id="toolbarauto-contextmenu" label="Automatisch ausblenden"> <menupopup id="toolbarauto-contextpopup" onpopupshowing="autoHideToolbarsPopupShowing(event);"/> </menu> <menuseparator/> `); document.getElementById('viewToolbarsMenuSeparator').after(contextmenu); let uccss = ` #toggle_TabsToolbar > label:before { content: "Browser-Tabs" !important; } #toggle_nav-bar > label:before { content: "Navigation" !important; } #navigator-toolbox #titlebar { order:0; } #navigator-toolbox #toolbar-menubar { order:1; } #navigator-toolbox #TabsToolbar { order:2; #navigator-toolbox #nav-bar { order:3; } #navigator-toolbox #PersonalToolbar { order:4; } #navigator-toolbox[barsAuto]:not([custommode]) { z-index : 100 !important; position : relative !important; } #navigator-toolbox[barsAuto]:not(:-moz-lwtheme, [custommode]) { background-color : var(--toolbar-bgcolor) !important; background-image : var(--toolbar-bgimage) !important; } #navigator-toolbox[barsAuto]:-moz-lwtheme:not([custommode]) { background-color : var(--lwt-accent-color) !important; background-image : var(--lwt-header-image, var(--lwt-additional-images)) !important; } #navigator-toolbox:not([inFullscreen], [custommode]) #nav-box-escape[notShown] { order: 10; transition : all 0.3s ease 0s; height : 5px; cursor : alias; } #navigator-toolbox:not([inFullscreen], [custommode]) #nav-box-escape:not([notShown]) { display : none; } #navigator-toolbox:not([inFullscreen], [custommode]) #nav-box-escape[allAuto] { margin-block-end : -5px; } #navigator-toolbox:not([inFullscreen], [custommode]):hover #nav-box-escape[allAuto] { height : 0; margin-block-end : 0; } #navigator-toolbox[barsAuto]:not([inFullscreen], [custommode]) { margin-block-end : 0; transition : all 0.3s ease 0s !important; } #navigator-toolbox[barsAuto]:not([inFullscreen], [custommode]):hover { margin-block-end : calc(var(--barshide-height) * -1px); } #navigator-toolbox:not([inFullscreen], [custommode]) > #titlebar[barsAuto] { margin-block-start : calc(var(--ttlhide-height) * -1px) !important; transition : all 0.3s ease 0s !important; } #navigator-toolbox:not([inFullscreen], [custommode]):hover > #titlebar[barsAuto] { margin-block-start : 0 !important; } #navigator-toolbox:not([inFullscreen], [custommode]) > #titlebar[barsAuto] #toolbar-menubar:not([barAuto]), #navigator-toolbox:not([inFullscreen], [custommode]) > #titlebar[barsAuto] #TabsToolbar:not([barAuto]) { order : 2; } #navigator-toolbox:not([inFullscreen], [custommode]) #toolbar-menubar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]) #TabsToolbar[barAuto] { order : 1; transition : all 0.3s ease 0s !important; opacity : 0 !important; } #navigator-toolbox:not([inFullscreen], [custommode]):hover #toolbar-menubar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]):hover > #titlebar[barsAuto] #TabsToolbar:not([barAuto]) { order : 1; } #navigator-toolbox:not([inFullscreen], [custommode]):hover > #titlebar[barsAuto] #toolbar-menubar:not([barAuto]), #navigator-toolbox:not([inFullscreen], [custommode]):hover #TabsToolbar[barAuto] { order : 2; } #navigator-toolbox:not([inFullscreen], [custommode]) #nav-bar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]) #PersonalToolbar[barAuto] { margin-block-start : calc(var(--barhide-height) * -1px) !important; transition : all 0.3s ease 0s !important; opacity : 0 !important; } #navigator-toolbox:not([inFullscreen], [custommode]):hover #toolbar-menubar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]):hover #TabsToolbar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]):hover #nav-bar[barAuto], #navigator-toolbox:not([inFullscreen], [custommode]):hover #PersonalToolbar[barAuto] { margin-block-start : 0 !important; opacity : 1 !important; } `; let ucuri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(uccss)); let ucsss = Cc['@mozilla.org/content/style-sheet-service;1'] .getService(Ci.nsIStyleSheetService); ucsss.loadAndRegisterSheet(ucuri, ucsss.AGENT_SHEET); } catch (e) { }; })(); // beim Start eingestellt window.addEventListener('MozAfterPaint', toolbarsset, { once: true }); // Anzeige von #TabsToolbar und Navigationsleiste mit ESC-Taste erzwingen document.addEventListener('keydown', function (event) { if (event.keyCode == 27) navescape(); }); // Doppelklicken Sie auf die Leiste, wenn alles gelöscht ist, um sie wiederherzustellen document.getElementById('nav-box-escape').addEventListener('dblclick', navescape); function navescape() { document.getElementById('nav-bar').setAttribute('collapsed', 'false'); document.getElementById('nav-bar').removeAttribute('barAuto'); document.getElementById('TabsToolbar').setAttribute('collapsed', 'false'); document.getElementById('TabsToolbar').removeAttribute('barAuto'); } // Änderung des Attributwerts der Symbolleiste (anpassen, ausblenden) function toolbarFlag(aEvent) { let barelm = aEvent.target; let attribute = aEvent.attributeName; // Deaktivieren Sie die Anzeige der Tab-Leiste beim Hinzufügen von Tabs if ((barelm.id == 'TabsToolbar') && (attribute == 'collapsed') && !(barelm.hasAttribute('collapsed'))) { barelm.setAttribute('collapsed', aEvent.oldValue); } toolbarsset(); } function toolbarsset() { let boxelm = document.getElementById('navigator-toolbox'); let ttlbar = document.getElementById('titlebar'); let escbox = document.getElementById('nav-box-escape'); let barelm, hidingAttr, barheight, hasShown; let barshide = 0, barsAuto = false, custommode = false, notShown = true; let ttlhide = 0, tbarsAuto = false, allAuto = false; let toolbarsid = ['toolbar-menubar', 'TabsToolbar', 'nav-bar', 'PersonalToolbar']; for (let toolbar of toolbarsid) { barelm = document.getElementById(toolbar); hidingAttr = (barelm.getAttribute('type') == 'menubar') ? 'autohide' : 'collapsed'; if (hasShown = (barelm.getAttribute(hidingAttr) == 'true')) barelm.removeAttribute('barAuto'); barheight = barelm.clientHeight; if (barelm.hasAttribute('barAuto')) { barsAuto = true; allAuto = true; barelm.style.setProperty("--barhide-height", barheight); barshide += barheight; if ((toolbar == 'toolbar-menubar') || (toolbar == 'TabsToolbar')) { tbarsAuto = true; ttlhide += barheight; } } else { if (!hasShown) notShown = false; barelm.style.setProperty("--barhide-height", 0); } if (barelm.hasAttribute('customizing')) custommode = true; } if (barsAuto) boxelm.setAttribute('barsAuto', 'true'); else boxelm.removeAttribute('barsAuto'); if (tbarsAuto) ttlbar.setAttribute('barsAuto', 'true'); else ttlbar.removeAttribute('barsAuto'); if (custommode) boxelm.setAttribute('custommode', 'true'); else boxelm.removeAttribute('custommode'); if (notShown) { escbox.setAttribute('notShown', 'true'); if (allAuto) escbox.setAttribute('allAuto', 'true'); else escbox.removeAttribute('allAuto'); } else { escbox.removeAttribute('notShown'); } boxelm.style.setProperty("--barshide-height", barshide); ttlbar.style.setProperty("--ttlhide-height", ttlhide); } // Menüerstellung function autoHideToolbarsPopupShowing(aEvent) { let popup = aEvent.target; if (popup != aEvent.currentTarget) return; while (popup.firstChild) popup.removeChild(popup.firstChild); // übersichtliches Menü let toolbarsid = ['toolbar-menubar', 'TabsToolbar', 'nav-bar', 'PersonalToolbar']; let barelm, hidingAttr; for (let toolbar of toolbarsid) { barelm = document.getElementById(toolbar); hidingAttr = (barelm.getAttribute('type') == 'menubar') ? 'autohide' : 'collapsed'; let menuitem = MozXULElement.parseXULToFragment(` <menuitem id="toolbarauto-${toolbar}" toolbarId="${toolbar}" type="checkbox" label="${barelm.getAttribute('toolbarname')}" checked="${(barelm.getAttribute('barAuto') == 'true')}" disabled="${(barelm.getAttribute(hidingAttr) == 'true')}" oncommand="autoHideToolbar(event);" /> `); popup.append(menuitem); } } // Automatische Prüfung des Öffnens/Schließens des Menüs function autoHideToolbar(aEvent) { let eventelm = aEvent.target; let barid = eventelm.getAttribute('toolbarId'); let barelm = document.getElementById(barid); if (eventelm.getAttribute('checked') == "true") { barelm.setAttribute('barAuto', 'true'); } else { barelm.removeAttribute('barAuto'); } }
Vielen Dank.
Gern geschehen
Besser du nimmst das oben geänderte Skript, weil es diesen Eintrag/Bezeichnung nicht mehr gibt.
Hallo Zusammen,
wenn ich diese ToolbarAutoHide.uc.js in Firefox 140.0 ESR benutze, bei "Automatisch ausblenden" kommt eine Punkt und funktioniert überhaupt nicht!
Kann bitte jemand helfen?
Vielen Dank
Mfg
-
Hallo Zusammen,
ich habe Probleme mit meine UserScript, Kann jemand mir sage was falsch ist (ich habe nicht geschafft, aber komisch ist das funktioniert!!).
hier ist Fehler:
Code
Alles anzeigenUncaught TypeError: can't access property "parentNode", position is undefined <anonymous> file:///C:/Users/Tester/AppData/Roaming/Mozilla/Firefox/Profiles/ptm2buf0.default/chrome/Label.uc.js:13 <anonymous> file:///C:/Users/Tester/AppData/Roaming/Mozilla/Firefox/Profiles/ptm2buf0.default/chrome/Label.uc.js:14 loadScript file:///C:/Program Files (x86)/Mozilla Firefox/userChromeJS/utilities.js:92 Label.uc.js:13:9 <anonym> file:///C:/Users/Tester/AppData/Roaming/Mozilla/Firefox/Profiles/ptm2buf0.default/chrome/Label.uc.js:13 <anonym> file:///C:/Users/Tester/AppData/Roaming/Mozilla/Firefox/Profiles/ptm2buf0.default/chrome/Label.uc.js:14 loadScript file:///C:/Program Files (x86)/Mozilla Firefox/userChromeJS/utilities.js:92 Content-Security-Policy: Die Einstellungen der Seite haben die Anwendung eines Inline-Styles (style-src-attr) blockiert, da er gegen folgende Direktive verstößt: "default-src chrome: resource:". Ziehen Sie die Verwendung eines Hashs ('sha256-TQANETlqHGfI02BqjupqUj7/JOv2IiPBabWbJdv1DTs=', benötigt 'unsafe-hashes' für Stil-Attribute) oder einer Nonce in Erwägung. Label.uc.js:10:17
Hier ist Label.uc.js code:
JavaScript
Alles anzeigen(function() { var cssFontFamily = 'Arial'; // Font Name var cssColor = '#EE0000'; // Font Farbe var css = 'font-family: ' + cssFontFamily + '; text-align: center; min-height: 20px; max-height: 20px; border-left: 1px solid #B2B2B2; padding-top: 3px; padding-right: 3px; padding-bottom: 0px; padding-left: 3px; color: ' + cssColor + '; font-weight: 500; text-shadow: none; width: 220px; margin-right: 1px; margin-bottom: 0px; margin-left: 0px;'; var cssA = 'font-family: ' + cssFontFamily + '; text-align: right; background: url("")no-repeat !important; background-position: 2px !important; min-height: 20px; max-height: 20px; padding-right: 3px; padding-bottom: 0px; padding-left: 24px !important; margin-right: 0px; margin-bottom: 0px; margin-left: 0px; width: 174px;'; var position = document.getElementsByClassName('titlebar-close')[0]; var FILabel = document.createXULElement('label'); FILabel.setAttribute('id', 'statusbar-FI-display'); FILabel.setAttribute('class', 'statusbarpanel-text'); FILabel.setAttribute('style', css + cssA); var text = "Firma (Kunden)"; FILabel.setAttribute('value', text); position.parentNode.insertBefore(FILabel, position.nextSibling); })();
Vielen Dank
Mfg
-
Moin,
danke, mit diese Code funktioniert:
JavaScript
Alles anzeigenlocation.href.startsWith("chrome://browser/content/browser.xhtml") && (function() { const MENU_NAME = "Mit einem anderen Browser öffnen"; const MENU_GROUP = true; // horizontales Menü //Ob das sekundäre Menü verwendet werden soll const USE_MENU_AREA = !MENU_GROUP && true; //Seite const USE_MENU_TAB = !MENU_GROUP && false; //Tab const USE_MENU_PLACE = !MENU_GROUP && false; //Lesezeichen function getFirefoxPath() { //firefox.exe return OS.Constants.Path.libDir; } function getRootPath() { //firefox Pfad var path = getFirefoxPath(); var index = path.indexOf(":"); return path.substring(0, index + 1); } //userChrome.js var browsers = { Edge: { enable: true, name: "Edge", path: "C:\\Program Files (x86)\\Microsoft\\Edge\\Application\\msedge.exe", image: "" } }; if (window.OpenWithManager) { window.OpenWithManager.destroy(); delete window.OpenWithManager; } function $(id) { return document.getElementById(id); } window.OpenWithManager = { useMenu: false, getTypeDesc: function(type) { switch (type) { case "page": return "Webseite"; case "link": return "Link"; case "tab": return "Tab"; case "place": return "Lesezeichen"; //case "tab": return "Tab"; //case "bm": return "Lesezeichen"; } return ""; }, buildMenuName: function(label, type) { return this.getTypeDesc(type) + " mit Microsoft " + label + " " +" öffnen"; // return "Mit Microsoft " + label + " öffnen"; }, attachNode: function(anchorNode, node) { if (this.useMenu) { anchorNode.appendChild(node); } else { anchorNode.parentNode.insertBefore(node, anchorNode); } }, createMenuPopup: function(anchorNode, type) { let menu = document.createXULElement("menu"); menu.setAttribute("label", MENU_NAME); menu.setAttribute("id", "openwith-menu-" + type); menu.setAttribute("class", "menu-iconic openwith-menu open-" + type); menu.setAttribute("image", browsers.all.image); anchorNode.parentNode.insertBefore(menu, anchorNode); let popup = document.createXULElement("menupopup"); popup.id = "openwith-popup-" + type; menu.appendChild(popup); return popup; }, createMenuItem: function(anchorNode, id, browser, type) { let menuitem = document.createXULElement("menuitem"); menuitem.id = "openwith-m-" + type + "-" + id; menuitem.setAttribute("label", this.buildMenuName(browser.name, type)); //menuitem.setAttribute("oncommand", "OpenWithManager.openWithOtherBrowser(this,'" + id + "','" + type + "')"); menuitem.addEventListener("command", function() { OpenWithManager.openWithOtherBrowser(this, id, type); }); menuitem.setAttribute("class", "menuitem-iconic openwith-menuitem open-" + type); if (browser.image) { menuitem.setAttribute("image", browser.image); } if (MENU_GROUP) { anchorNode.appendChild(menuitem); } else { this.attachNode(anchorNode, menuitem); } }, createBrowserMenu: function(anchorNode, type) { if (MENU_GROUP) { let newAnchorNode = document.createXULElement('menugroup'); newAnchorNode.setAttribute('id', 'OpenWithManager-Group') newAnchorNode.classList.add('openwith-menu'); this.attachNode(anchorNode, newAnchorNode); anchorNode = newAnchorNode; } for (let key in browsers) { try { if (browsers[key].enable) { this.createMenuItem(anchorNode, key, browsers[key], type); } } catch (e) { alert(e.message); } } }, //contentAreaContextMenu initContentAreaMenu: function() { var inspos = $("inspect-separator"); let sep = document.createXULElement("menuseparator"); sep.setAttribute("class", "openwith-menuitem"); inspos.parentNode.insertBefore(sep, inspos); this.useMenu = USE_MENU_AREA; var anchorNode; if (this.useMenu) { anchorNode = this.createMenuPopup(inspos, "area"); } else { anchorNode = inspos; } //Linkbereich this.createBrowserMenu(anchorNode, "link"); let sepLink = document.createXULElement("menuseparator"); sepLink.setAttribute("class", "open-link openwith-menuitem"); this.attachNode(anchorNode, sepLink); //Steuern Anzeige von Linkmenüs inspos.parentNode.addEventListener("popupshowing", this, false); //Seitenabschnitt this.createBrowserMenu(anchorNode, "page"); }, //tabContextMenu initTabContextMenu: function() { var inspos = $("context_closeTabOptions"); let sep = document.createXULElement("menuseparator"); sep.setAttribute("class", "openwith-menuitem"); inspos.parentNode.insertBefore(sep, inspos.nextSibling); this.useMenu = USE_MENU_TAB; var anchorNode; if (this.useMenu) { anchorNode = this.createMenuPopup(sep.nextSibling, "tab"); } else { anchorNode = sep.nextSibling; } this.createBrowserMenu(anchorNode, "tab"); }, //placesContext initPlacesContextMenu: function() { var inspos = $("placesContext_openSeparator"); //let sep = document.createXULElement("menuseparator"); //inspos.parentNode.insertBefore(sep, inspos); this.useMenu = USE_MENU_PLACE; var anchorNode; if (this.useMenu) { anchorNode = this.createMenuPopup(inspos, "place"); } else { anchorNode = inspos; } this.createBrowserMenu(anchorNode, "place"); //Ordneranzeige inspos.parentNode.addEventListener("popupshowing", this, false); }, handleEvent: function(event) { if (event.target.id == "placesContext") { var isFloder = false; try { let selectedNode = PlacesUIUtils.getViewForNode(event.target.triggerNode).selectedNode; isFloder = !selectedNode || selectedNode.hasChildren; } catch (e) {} let menus = $("placesContext").querySelectorAll(".open-place"); for (let menu of menus) { if (isFloder) { menu.hidden = true; } else { menu.hidden = false; menu.disabled = false; } } } if (event.target.id == "contentAreaContextMenu") { let menus = $("contentAreaContextMenu").querySelectorAll(".openwith-menuitem"); for (let menu of menus) { if (gContextMenu.onLink) { if (menu.classList.contains('open-link')) { menu.hidden = false; } else { menu.hidden = true; } } else { if (menu.classList.contains('open-link')) { menu.hidden = true; } else { menu.hidden = false; } } } } }, init: function() { //contentAreaContextMenu this.initContentAreaMenu(); //tabContextMenu this.initTabContextMenu(); //placesContext this.initPlacesContextMenu(); this.setStyle(); }, destroy: function() { $("contentAreaContextMenu").removeEventListener("popupshowing", this, false); $("placesContext_openSeparator").removeEventListener("popupshowing", this, false); let menus = document.querySelectorAll(".openwith-menu"), menuitems = document.querySelectorAll(".openwith-menuitem"); for (let menuitem of menuitems) { menuitem.parentNode.removeChild(menuitem); } for (let menu of menus) { menu.parentNode.removeChild(menu); } this.sss.unregisterSheet(this.STYLE.url, this.STYLE.type); }, setStyle() { this.STYLE = { url: Services.io.newURI('data:text/css;charset=UTF-8,' + encodeURIComponent(` @-moz-document url('chrome://browser/content/browser.xhtml') { #OpenWithManager-Group > menuitem { -moz-box-flex: 1; -moz-box-pack: center; -moz-box-align: center; flex-grow: 1; justify-content: center; align-items: center; padding-block: 3px; padding-inline-start: 1em; } #OpenWithManager-Group > menuitem:not(:first-child) > .menu-iconic-text, #OpenWithManager-Group > menuitem:not(:first-child) > .menu-accel-container { display: none; } #OpenWithManager-Group > menuitem:first-child { -moz-box-flex: 1 } } `)), type: 1 } this.sss = Components.classes["@mozilla.org/content/style-sheet-service;1"].getService(Components.interfaces.nsIStyleSheetService); this.sss.loadAndRegisterSheet(this.STYLE.url, this.STYLE.type); }, openWithBrowser: function(url, path) { if (!path) { alert("Browserpfad nicht festgelegt "); return; } let clientApp = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsIFile); clientApp.initWithPath(path); if (!clientApp.exists()) { alert("Fehler im Browserpfad: " + path); return; } try { let ss = Cc["@mozilla.org/browser/shell-service;1"] .getService(Ci.nsIShellService); ss.openApplicationWithURI(clientApp, url); } catch (e) { let p = Cc["@mozilla.org/process/util;1"] .createInstance(Ci.nsIProcess); p.init(clientApp); p.run(false, [url], 1); } }, openWithOtherBrowser: function(obj, id, type) { var url; switch (type) { case "page": url = gBrowser.currentURI.spec; break; case "link": url = gContextMenu.linkURL; break; case "tab": { let tab = document.popupNode && document.popupNode.localName == "tab" ? document.popupNode : gBrowser.selectedTab; let bw = tab && tab.linkedBrowser, uri = bw.documentURI.spec || bw.currentURI.spec; url = bw && uri; } break; case "place": url = PlacesUIUtils.getViewForNode(PlacesUIUtils.lastContextMenuTriggerNode).selectedNode.uri; break; } if (url) { if (id == "all") { for (let key in browsers) { let browser = browsers[key]; if (browser.enable && key != "all" && browser.path) { this.openWithBrowser(url, browser.path); } } } else { let browser = browsers[id]; this.openWithBrowser(url, browser.path); } } } }; OpenWithManager.init(); })();
Mfg
-
Moin,
von hier:
Directory Listing: /pub/firefox/releases/140.0esr/
Hallo,
PS: Weil es mir ins Auge sticht: In der ersten Zeile des Scripts ist es überflüssig, eine startsWith()-Abfrage auszuführen, statt direkt auf browser.xhtml zu prüfen. Vielleicht kann derjenige, der das Script anpasst, das gleich mit anpassen.
Kannst du bitte mehr erklären?
Vielen Dank
-
Hallo Zusammen
mit Firefox 140.0 ESR Version habe ich Probleme mit paar meine UserScript:
Kann jemand bitte helfen?
Hier ist meine OpenMitEdge.uc.js code und Errors:
Errors:
CodeContent-Security-Policy: Die Einstellungen der Seite haben die Ausführung eines Ereignis-Handlers (script-src-attr) blockiert, weil er gegen folgende Direktive verstößt: "script-src chrome: moz-src: resource: 'report-sample'". Ziehen Sie die Verwendung eines Hashs ('sha256-EX/oIAl8spf7/MJcXSDlguVw+bZ6Ky48qFuSwNkR7jk=') zusammen mit 'unsafe-hashes' in Erwägung. OpenMitEdge.uc.js:84:22 Content-Security-Policy: Die Einstellungen der Seite haben die Ausführung eines Ereignis-Handlers (script-src-attr) blockiert, weil er gegen folgende Direktive verstößt: "script-src chrome: moz-src: resource: 'report-sample'". Ziehen Sie die Verwendung eines Hashs ('sha256-bVD1vGKHJ2/cGMJr/0NiEuGdtdmOTj+N82Vb0ZOE4uU=') zusammen mit 'unsafe-hashes' in Erwägung. OpenMitEdge.uc.js:84:22 Content-Security-Policy: Die Einstellungen der Seite haben die Ausführung eines Ereignis-Handlers (script-src-attr) blockiert, weil er gegen folgende Direktive verstößt: "script-src chrome: moz-src: resource: 'report-sample'". Ziehen Sie die Verwendung eines Hashs ('sha256-8VCzM+KOaNzRLMVmaeckNeI1cDJO1pKlh6kuOuce+3Q=') zusammen mit 'unsafe-hashes' in Erwägung. OpenMitEdge.uc.js:84:22 Content-Security-Policy: Die Einstellungen der Seite haben die Ausführung eines Ereignis-Handlers (script-src-attr) blockiert, weil er gegen folgende Direktive verstößt: "script-src chrome: moz-src: resource: 'report-sample'". Ziehen Sie die Verwendung eines Hashs ('sha256-JabsnXfLzO+vfpBIs4N+6nwTBH5SsI0eSQ0uXVWrhRk=') zusammen mit 'unsafe-hashes' in Erwägung. OpenMitEdge.uc.js:84:22
Code:
JavaScript
Alles anzeigenlocation.href.startsWith("chrome://browser/content/browser.x") && (function() { const MENU_NAME = "Mit einem anderen Browser öffnen"; const MENU_GROUP = true; // horizontales Menü //Ob das sekundäre Menü verwendet werden soll const USE_MENU_AREA = !MENU_GROUP && true; //Seite const USE_MENU_TAB = !MENU_GROUP && false; //Tab const USE_MENU_PLACE = !MENU_GROUP && false; //Lesezeichen function getFirefoxPath() { //firefox.exe return OS.Constants.Path.libDir; } function getRootPath() { //firefox Pfad var path = getFirefoxPath(); var index = path.indexOf(":"); return path.substring(0, index + 1); } //userChrome.js var browsers = { Edge: { enable: true, name: "Edge", path: "C:\\Program Files (x86)\\Microsoft\\Edge\\Application\\msedge.exe", image: "" } }; if (window.OpenWithManager) { window.OpenWithManager.destroy(); delete window.OpenWithManager; } function $(id) { return document.getElementById(id); } window.OpenWithManager = { useMenu: false, getTypeDesc: function(type) { switch (type) { case "page": return "Webseite"; case "link": return "Link"; case "tab": return "Tab"; case "place": return "Lesezeichen"; //case "tab": return "Tab"; //case "bm": return "Lesezeichen"; } return ""; }, buildMenuName: function(label, type) { return this.getTypeDesc(type) + " mit Microsoft " + label + " " +" öffnen"; // return "Mit Microsoft " + label + " öffnen"; }, attachNode: function(anchorNode, node) { if (this.useMenu) { anchorNode.appendChild(node); } else { anchorNode.parentNode.insertBefore(node, anchorNode); } }, createMenuPopup: function(anchorNode, type) { let menu = document.createXULElement("menu"); menu.setAttribute("label", MENU_NAME); menu.setAttribute("id", "openwith-menu-" + type); menu.setAttribute("class", "menu-iconic openwith-menu open-" + type); menu.setAttribute("image", browsers.all.image); anchorNode.parentNode.insertBefore(menu, anchorNode); let popup = document.createXULElement("menupopup"); popup.id = "openwith-popup-" + type; menu.appendChild(popup); return popup; }, createMenuItem: function(anchorNode, id, browser, type) { let menuitem = document.createXULElement("menuitem"); menuitem.id = "openwith-m-" + type + "-" + id; menuitem.setAttribute("label", this.buildMenuName(browser.name, type)); menuitem.setAttribute("oncommand", "OpenWithManager.openWithOtherBrowser(this,'" + id + "','" + type + "')"); menuitem.setAttribute("class", "menuitem-iconic openwith-menuitem open-" + type); if (browser.image) { menuitem.setAttribute("image", browser.image); } if (MENU_GROUP) { anchorNode.appendChild(menuitem); } else { this.attachNode(anchorNode, menuitem); } }, createBrowserMenu: function(anchorNode, type) { if (MENU_GROUP) { let newAnchorNode = document.createXULElement('menugroup'); newAnchorNode.setAttribute('id', 'OpenWithManager-Group') newAnchorNode.classList.add('openwith-menu'); this.attachNode(anchorNode, newAnchorNode); anchorNode = newAnchorNode; } for (let key in browsers) { try { if (browsers[key].enable) { this.createMenuItem(anchorNode, key, browsers[key], type); } } catch (e) { alert(e.message); } } }, //contentAreaContextMenu initContentAreaMenu: function() { var inspos = $("inspect-separator"); let sep = document.createXULElement("menuseparator"); sep.setAttribute("class", "openwith-menuitem"); inspos.parentNode.insertBefore(sep, inspos); this.useMenu = USE_MENU_AREA; var anchorNode; if (this.useMenu) { anchorNode = this.createMenuPopup(inspos, "area"); } else { anchorNode = inspos; } //Linkbereich this.createBrowserMenu(anchorNode, "link"); let sepLink = document.createXULElement("menuseparator"); sepLink.setAttribute("class", "open-link openwith-menuitem"); this.attachNode(anchorNode, sepLink); //Steuern Anzeige von Linkmenüs inspos.parentNode.addEventListener("popupshowing", this, false); //Seitenabschnitt this.createBrowserMenu(anchorNode, "page"); }, //tabContextMenu initTabContextMenu: function() { var inspos = $("context_closeTabOptions"); let sep = document.createXULElement("menuseparator"); sep.setAttribute("class", "openwith-menuitem"); inspos.parentNode.insertBefore(sep, inspos.nextSibling); this.useMenu = USE_MENU_TAB; var anchorNode; if (this.useMenu) { anchorNode = this.createMenuPopup(sep.nextSibling, "tab"); } else { anchorNode = sep.nextSibling; } this.createBrowserMenu(anchorNode, "tab"); }, //placesContext initPlacesContextMenu: function() { var inspos = $("placesContext_openSeparator"); //let sep = document.createXULElement("menuseparator"); //inspos.parentNode.insertBefore(sep, inspos); this.useMenu = USE_MENU_PLACE; var anchorNode; if (this.useMenu) { anchorNode = this.createMenuPopup(inspos, "place"); } else { anchorNode = inspos; } this.createBrowserMenu(anchorNode, "place"); //Ordneranzeige inspos.parentNode.addEventListener("popupshowing", this, false); }, handleEvent: function(event) { if (event.target.id == "placesContext") { var isFloder = false; try { let selectedNode = PlacesUIUtils.getViewForNode(event.target.triggerNode).selectedNode; isFloder = !selectedNode || selectedNode.hasChildren; } catch (e) {} let menus = $("placesContext").querySelectorAll(".open-place"); for (let menu of menus) { if (isFloder) { menu.hidden = true; } else { menu.hidden = false; menu.disabled = false; } } } if (event.target.id == "contentAreaContextMenu") { let menus = $("contentAreaContextMenu").querySelectorAll(".openwith-menuitem"); for (let menu of menus) { if (gContextMenu.onLink) { if (menu.classList.contains('open-link')) { menu.hidden = false; } else { menu.hidden = true; } } else { if (menu.classList.contains('open-link')) { menu.hidden = true; } else { menu.hidden = false; } } } } }, init: function() { //contentAreaContextMenu this.initContentAreaMenu(); //tabContextMenu this.initTabContextMenu(); //placesContext this.initPlacesContextMenu(); this.setStyle(); }, destroy: function() { $("contentAreaContextMenu").removeEventListener("popupshowing", this, false); $("placesContext_openSeparator").removeEventListener("popupshowing", this, false); let menus = document.querySelectorAll(".openwith-menu"), menuitems = document.querySelectorAll(".openwith-menuitem"); for (let menuitem of menuitems) { menuitem.parentNode.removeChild(menuitem); } for (let menu of menus) { menu.parentNode.removeChild(menu); } this.sss.unregisterSheet(this.STYLE.url, this.STYLE.type); }, setStyle() { this.STYLE = { url: Services.io.newURI('data:text/css;charset=UTF-8,' + encodeURIComponent(` @-moz-document url('chrome://browser/content/browser.xhtml') { #OpenWithManager-Group > menuitem { -moz-box-flex: 1; -moz-box-pack: center; -moz-box-align: center; flex-grow: 1; justify-content: center; align-items: center; padding-block: 3px; padding-inline-start: 1em; } #OpenWithManager-Group > menuitem:not(:first-child) > .menu-iconic-text, #OpenWithManager-Group > menuitem:not(:first-child) > .menu-accel-container { display: none; } #OpenWithManager-Group > menuitem:first-child { -moz-box-flex: 1 } } `)), type: 1 } this.sss = Components.classes["@mozilla.org/content/style-sheet-service;1"].getService(Components.interfaces.nsIStyleSheetService); this.sss.loadAndRegisterSheet(this.STYLE.url, this.STYLE.type); }, openWithBrowser: function(url, path) { if (!path) { alert("Browserpfad nicht festgelegt "); return; } let clientApp = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsIFile); clientApp.initWithPath(path); if (!clientApp.exists()) { alert("Fehler im Browserpfad: " + path); return; } try { let ss = Cc["@mozilla.org/browser/shell-service;1"] .getService(Ci.nsIShellService); ss.openApplicationWithURI(clientApp, url); } catch (e) { let p = Cc["@mozilla.org/process/util;1"] .createInstance(Ci.nsIProcess); p.init(clientApp); p.run(false, [url], 1); } }, openWithOtherBrowser: function(obj, id, type) { var url; switch (type) { case "page": url = gBrowser.currentURI.spec; break; case "link": url = gContextMenu.linkURL; break; case "tab": { let tab = document.popupNode && document.popupNode.localName == "tab" ? document.popupNode : gBrowser.selectedTab; let bw = tab && tab.linkedBrowser, uri = bw.documentURI.spec || bw.currentURI.spec; url = bw && uri; } break; case "place": url = PlacesUIUtils.getViewForNode(PlacesUIUtils.lastContextMenuTriggerNode).selectedNode.uri; break; } if (url) { if (id == "all") { for (let key in browsers) { let browser = browsers[key]; if (browser.enable && key != "all" && browser.path) { this.openWithBrowser(url, browser.path); } } } else { let browser = browsers[id]; this.openWithBrowser(url, browser.path); } } } }; OpenWithManager.init(); })();
Vielen Dank
Mfg
-
Moin Sören,
herzlichen Dank, das hat funktioniert.
Mfg
-
Moin milupo ,
ich habe gemacht aber habe ich immer noch mit Restore aber Backup funktioniert.
.Wenn ich "Bookmarks Restore" klicke, öffnet Fenster und ich wähle eine Backup Datei aber dann bekomme ich diese Fehler für diese Teil in Code:
JavaScript// confirm ok to delete existing bookmarks if (!Services.prompt.confirm(null, PlacesUIUtils.getString("bookmarksRestoreAlertTitle"), // <=== das ist Line 100 PlacesUIUtils.getString("bookmarksRestoreAlert"))) return;
Mfg
-
ich habe so das Code geändert, jetzt wenn ich Bookmarks von eine Backup Datei wiederherstellen klick dann kommt Error:
CodeUncaught TypeError: PlacesUIUtils.getString is not a function Uncaught TypeError: PlacesUIUtils.getString is not a function fpCallback file:///C:/Users/sam2008/AppData/Roaming/Mozilla/Firefox/Profiles/vi5nw3kj.default/chrome/bookmarks_backup_restore_button.uc.js:76 bookmarks_backup_restore_button.uc.js:76:34
JavaScript
Alles anzeigen(function() { try { //Components.utils.import("resource:///modules/CustomizableUI.jsm"); ChromeUtils.importESModule("resource:///modules/CustomizableUI.sys.mjs"); var sss = Components.classes["@mozilla.org/content/style-sheet-service;1"].getService(Components.interfaces.nsIStyleSheetService); var RESTORE_FILEPICKER_FILTER_EXT = "*.json;*.jsonlz4"; //ChromeUtils.import("resource://gre/modules/Services.jsm"); //ChromeUtils.defineModuleGetter(this, "MigrationUtils", "resource:///modules/MigrationUtils.jsm"); //ChromeUtils.defineModuleGetter(this, "BookmarkJSONUtils", "resource://gre/modules/BookmarkJSONUtils.jsm"); //ChromeUtils.defineModuleGetter(this, "PlacesBackups", "resource://gre/modules/PlacesBackups.jsm"); const lazy = {}; ChromeUtils.defineESModuleGetters(lazy, { MigrationUtils: "resource:///modules/MigrationUtils.sys.mjs", }); ChromeUtils.defineESModuleGetters(lazy, { BookmarkJSONUtils: "resource://gre/modules/BookmarkJSONUtils.sys.mjs", }); ChromeUtils.defineESModuleGetters(lazy, { PlacesBackups: "resource://gre/modules/PlacesBackups.sys.mjs", }); ChromeUtils.defineESModuleGetters(lazy, { PlacesUtils: "resource://gre/modules/PlacesUIUtils.sys.mjs",}); CustomizableUI.createWidget({ id: "uc-bookmarks_backup", // button id defaultArea: CustomizableUI.AREA_NAVBAR, removable: true, label: "Bookmarks Backup", // button title tooltiptext: "Bookmarks Backup", // tooltip title onClick: function(event) { if(event.button=='0') { let backupsDir = Services.dirsvc.get("Desk", Ci.nsIFile); let fp = Cc["@mozilla.org/filepicker;1"].createInstance(Ci.nsIFilePicker); let fpCallback = function fpCallback_done(aResult) { if (aResult != Ci.nsIFilePicker.returnCancel) { // There is no OS.File version of the filepicker yet (Bug 937812). lazy.PlacesBackups.saveBookmarksToJSONFile(fp.file.path) .catch(Cu.reportError); } }; fp.init(BrowsingContext.getFromWindow(window), "json", Ci.nsIFilePicker.modeSave); fp.appendFilter("json", RESTORE_FILEPICKER_FILTER_EXT); fp.defaultString = lazy.PlacesBackups.getFilenameForDate(); fp.defaultExtension = "json"; fp.displayDirectory = backupsDir; fp.open(fpCallback); } }, onCreated: function(button) { return button; } }); CustomizableUI.createWidget({ id: "uc-bookmarks_restore", // button id defaultArea: CustomizableUI.AREA_NAVBAR, removable: true, label: "Bookmarks Restore", // button title tooltiptext: "Bookmarks Restore", // tooltip title onClick: function(event) { if(event.button=='0') { let backupsDir = Services.dirsvc.get("Desk", Ci.nsIFile); let fp = Cc["@mozilla.org/filepicker;1"].createInstance(Ci.nsIFilePicker); let fpCallback = aResult => { if (aResult != Ci.nsIFilePicker.returnCancel) { // check file extension if (!fp.file.path.toLowerCase().endsWith("json") && !fp.file.path.toLowerCase().endsWith("jsonlz4")) { this._showErrorAlert(PlacesUIUtils.getString("bookmarksRestoreFormatError")); return; } // confirm ok to delete existing bookmarks if (!Services.prompt.confirm(null, PlacesUIUtils.getString("bookmarksRestoreAlertTitle"), PlacesUIUtils.getString("bookmarksRestoreAlert"))) return; (async function() { try { await lazy.BookmarkJSONUtils.importFromFile(fp.file.path, { replace: true, }); } catch (ex) { PlacesOrganizer._showErrorAlert(PlacesUIUtils.getString("bookmarksRestoreParseError")); } })(); } }; fp.init(BrowsingContext.getFromWindow(window), "json", Ci.nsIFilePicker.modeOpen); fp.appendFilter("json", RESTORE_FILEPICKER_FILTER_EXT); fp.appendFilters(Ci.nsIFilePicker.filterAll); fp.displayDirectory = backupsDir; fp.open(fpCallback); } }, onCreated: function(button) { return button; } }); // style button icon var uri = Services.io.newURI("data:text/css;charset=utf-8," + encodeURIComponent('\ \ #uc-bookmarks_backup .toolbarbutton-icon {\ list-style-image: url( ); /* icon / path to icon */ \ fill: red; /* icon color name/code */\ }\ #uc-bookmarks_restore .toolbarbutton-icon {\ list-style-image: url( ); /* icon / path to icon */ \ fill: green; /* icon color name/code */\ }\ \ '), null, null); sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET); } catch (e) { Components.utils.reportError(e); }; })();
-
milupo ,
danke, jetzt alles funktioniert außer Backup Button. Wenn ich Backup Button klicke, passiert gar nicht!!
-
Hallo 2002Andreas , Hallo milupo ,
danke, ich habe gemacht und jetzt "Restart.Toolbar.uc.js" funktioniert aber "bookmarks_backup_restore_button.uc.js" nicht.
Mfg
-
Moin Zusammen,
mit Firefox 137 Version wird nicht Backup, Restore und neue Start in Toolbar angezeigt, kann bitte jemand sagen wo das Problem ist?
bookmarks_backup_restore_button.uc.js
JavaScript
Alles anzeigen(function() { try { //Components.utils.import("resource:///modules/CustomizableUI.jsm"); ChromeUtils.importESModule("resource:///modules/CustomizableUI.sys.mjs"); var sss = Components.classes["@mozilla.org/content/style-sheet-service;1"].getService(Components.interfaces.nsIStyleSheetService); var RESTORE_FILEPICKER_FILTER_EXT = "*.json;*.jsonlz4"; //ChromeUtils.import("resource://gre/modules/Services.jsm"); ChromeUtils.defineModuleGetter(this, "MigrationUtils", "resource:///modules/MigrationUtils.jsm"); ChromeUtils.defineModuleGetter(this, "BookmarkJSONUtils", "resource://gre/modules/BookmarkJSONUtils.jsm"); ChromeUtils.defineModuleGetter(this, "PlacesBackups", "resource://gre/modules/PlacesBackups.jsm"); CustomizableUI.createWidget({ id: "uc-bookmarks_backup", // button id defaultArea: CustomizableUI.AREA_NAVBAR, removable: true, label: "Bookmarks Backup", // button title tooltiptext: "Bookmarks Backup", // tooltip title onClick: function(event) { if(event.button=='0') { let backupsDir = Services.dirsvc.get("Desk", Ci.nsIFile); let fp = Cc["@mozilla.org/filepicker;1"].createInstance(Ci.nsIFilePicker); let fpCallback = function fpCallback_done(aResult) { if (aResult != Ci.nsIFilePicker.returnCancel) { // There is no OS.File version of the filepicker yet (Bug 937812). PlacesBackups.saveBookmarksToJSONFile(fp.file.path) .catch(Cu.reportError); } }; fp.init(BrowsingContext.getFromWindow(window), "json", Ci.nsIFilePicker.modeSave); fp.appendFilter("json", RESTORE_FILEPICKER_FILTER_EXT); fp.defaultString = PlacesBackups.getFilenameForDate(); fp.defaultExtension = "json"; fp.displayDirectory = backupsDir; fp.open(fpCallback); } }, onCreated: function(button) { return button; } }); CustomizableUI.createWidget({ id: "uc-bookmarks_restore", // button id defaultArea: CustomizableUI.AREA_NAVBAR, removable: true, label: "Bookmarks Restore", // button title tooltiptext: "Bookmarks Restore", // tooltip title onClick: function(event) { if(event.button=='0') { let backupsDir = Services.dirsvc.get("Desk", Ci.nsIFile); let fp = Cc["@mozilla.org/filepicker;1"].createInstance(Ci.nsIFilePicker); let fpCallback = aResult => { if (aResult != Ci.nsIFilePicker.returnCancel) { // check file extension if (!fp.file.path.toLowerCase().endsWith("json") && !fp.file.path.toLowerCase().endsWith("jsonlz4")) { this._showErrorAlert(PlacesUIUtils.getString("bookmarksRestoreFormatError")); return; } // confirm ok to delete existing bookmarks if (!Services.prompt.confirm(null, PlacesUIUtils.getString("bookmarksRestoreAlertTitle"), PlacesUIUtils.getString("bookmarksRestoreAlert"))) return; (async function() { try { await BookmarkJSONUtils.importFromFile(fp.file.path, { replace: true, }); } catch (ex) { PlacesOrganizer._showErrorAlert(PlacesUIUtils.getString("bookmarksRestoreParseError")); } })(); } }; fp.init(BrowsingContext.getFromWindow(window), "json", Ci.nsIFilePicker.modeOpen); fp.appendFilter("json", RESTORE_FILEPICKER_FILTER_EXT); fp.appendFilters(Ci.nsIFilePicker.filterAll); fp.displayDirectory = backupsDir; fp.open(fpCallback); } }, onCreated: function(button) { return button; } }); // style button icon var uri = Services.io.newURI("data:text/css;charset=utf-8," + encodeURIComponent('\ \ #uc-bookmarks_backup .toolbarbutton-icon {\ list-style-image: url( ); /* icon / path to icon */ \ fill: red; /* icon color name/code */\ }\ #uc-bookmarks_restore .toolbarbutton-icon {\ list-style-image: url( ); /* icon / path to icon */ \ fill: green; /* icon color name/code */\ }\ \ '), null, null); sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET); } catch (e) { Components.utils.reportError(e); }; })();
Restart.Toolbar.uc.js
JavaScript
Alles anzeigen(function() { try { Components.utils.import("resource:///modules/CustomizableUI.jsm"); ChromeUtils.importESModule("resource:///modules/CustomizableUI.sys.mjs"); var sss = Components.classes["@mozilla.org/content/style-sheet-service;1"].getService(Components.interfaces.nsIStyleSheetService); var appversion = parseInt(Services.appinfo.version); var button_label = "Neu Starten"; CustomizableUI.createWidget({ id: "uc-restart", // button id defaultArea: CustomizableUI.AREA_NAVBAR, removable: true, label: button_label, // button title tooltiptext: button_label, // tooltip title onClick: function(event) { var cancelQuit = Components.classes["@mozilla.org/supports-PRBool;1"].createInstance(Components.interfaces.nsISupportsPRBool); var observerSvc = Components.classes["@mozilla.org/observer-service;1"].getService(Components.interfaces.nsIObserverService); if(event.button=='1') { // middle-click - clear caches Components.classes["@mozilla.org/xre/app-info;1"].getService(Components.interfaces.nsIXULRuntime).invalidateCachesOnRestart(); } if(event.button=='0' || event.button=='1') { // left/middle-click - restart observerSvc.notifyObservers(cancelQuit, "quit-application-requested", "restart"); if(cancelQuit.data) return false; Services.startup.quit(Services.startup.eRestart | Services.startup.eAttemptQuit); } }, onCreated: function(button) { return button; } }); var icon = "chrome://global/skin/icons/reload.svg"; if(appversion < 92) icon = "chrome://browser/skin/reload.svg"; // style button icon var uri = Services.io.newURI("data:text/css;charset=utf-8," + encodeURIComponent('\ \ #uc-restart .toolbarbutton-icon {\ list-style-image: url("'+icon+'"); /* icon / path to icon */ \ transform: scaleX(-1); /* icon mirroring */\ fill: red; /* icon color name/code */\ }\ \ '), null, null); sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET); } catch (e) { Components.utils.reportError(e); }; })();
Vielen Dank
Mfg
-
vielen Dank.
Mfg