Hallo Andreas,
leider hat nicht funktioniert wie du geschrieben hast.
Bei mir funktioniert nur mit das code dass ich vorher gepostet habe.
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:
(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();
}
Alles anzeigen
Mfg
Hallo Endor ,
vielen Dank für Info.
Eine kleine Info, in Browser Konsole zeigt nur diese Errors:
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
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
Alles anzeigen
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:
Uncaught 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
Alles anzeigen
Hier ist Label.uc.js code:
(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);
})();
Alles anzeigen
Vielen Dank
Mfg
Moin,
danke, mit diese Code funktioniert:
location.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();
})();
Alles anzeigen
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:
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-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:
location.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();
})();
Alles anzeigen
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:
// 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:
Uncaught 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
(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);
};
})();
Alles anzeigen
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
(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);
};
})();
Alles anzeigen
Restart.Toolbar.uc.js
(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);
};
})();
Alles anzeigen
Vielen Dank
Mfg
vielen Dank.
Mfg
Hallo Sören,
1- Nein
2- Ja (wir haben Users dass benutzen)
Mfg
Hallo Zusammen,
wegen diese Information, wie kann ich OpenH264-Videocodec von 2.3.2 auf Version 2.6 updaten?
Vielen Dank
Mfg
Hallo Andreas,
gerne geschehen
Mfg
Moin Andreas,
hier ist PowerShell Skript:
# PowerShell-Skript zum Deinstallieren von "DejaVuSans"-Schriftarten auf Windows 11
# Dieses Skript muss als Administrator ausgeführt werden
# Pfad zum Fonts-Verzeichnis
$fontsDirectory = "$env:windir\Fonts"
# Liste aller installierten Schriftarten erhalten
$installedFonts = Get-ChildItem -Path $fontsDirectory -Include "*DejaVu*" -Recurse
if ($installedFonts.Count -eq 0) {
Write-Host "Keine 'DejaVuSans'-Schriftarten im Fonts-Verzeichnis gefunden."
} else {
foreach ($font in $installedFonts) {
try {
Write-Host "Lösche Schriftartdatei: $($font.FullName)"
Remove-Item -Path $font.FullName -Force
} catch {
Write-Host "Fehler beim Löschen von $($font.FullName): $_"
}
}
}
# Schriftarten aus der Registrierung entfernen
$fontRegKeyPath = "HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion\Fonts"
$fontsInRegistry = Get-ItemProperty -Path $fontRegKeyPath
foreach ($font in $fontsInRegistry.PSObject.Properties) {
if ($font.Name -like "*DejaVu*") {
try {
Write-Host "Lösche Registrierungseintrag für Schriftart: $($font.Name)"
Remove-ItemProperty -Path $fontRegKeyPath -Name $font.Name -Force
} catch {
Write-Host "Fehler beim Löschen des Registrierungseintrags $($font.Name): $_"
}
}
}
# Schriftarten-Cache aktualisieren
Write-Host "Aktualisiere den Schriftarten-Cache..."
& rundll32.exe shell32.dll,Control_RunDLL fonts
Alles anzeigen
Mfg
Moin Sören,
herzlichen Dank. Leider Chefetage will nicht warten.
Mfg