könnte es auch sein, dass einfach nur der Reload im falschen Fenster stattfindet? Dass z.b.: event.target.ownerGlobal.BrowserCommands.reloadSkipCache();statt BrowserCommands.reloadSkipCache(); schon reichen würde?
Das kann sein. Ich hab das mangels Kenntnis dieser Anweisungen nicht getestet.
Müsste die Funktion an sich dann nicht auch nach unten?
Hmm. Ich habe diese bei mir funktionierende Version und genau das getan:
JavaScript
/* AnimationToggleButton.uc.js, Symbole von Zitronella,
* https://www.camp-firefox.de/forum/thema/133649/
* Änderungen von Brokenheart: https://www.camp-firefox.de/forum/thema/133649/?postID=1187103#post1187103
* Änderungen von Endor: https://www.camp-firefox.de/forum/thema/137909/?postID=1249534#post1249534 (anderer Thread)
* (Speravir: alten Tooltiptext und alte Symbole wieder eingefügt),
letzte Änderung: https://www.camp-firefox.de/forum/thema/112673/?postID=1271468#post1271468
*/
(function() {
if (!window.gBrowser) return;
const
buttonID = 'animation-button',
configPref = 'image.animation_mode',
dataAttrib = 'data-animmode',
labelText = 'Animation',
tooltipText =
`Linksklick: GIF-Animationen einschalten
Mittelklick: Animation einmal abspielen
Rechtsklick: Ausschalten`,
css =
`#${buttonID}{
&[${dataAttrib}="normal"] {list-style-image: url("")}
&[${dataAttrib}="once"] {list-style-image: url("")}
&[${dataAttrib}="none"] {list-style-image: url("")}}`;
let prefVal = Services.prefs.getCharPref(configPref);
try {
CustomizableUI.createWidget({
id: buttonID,
type: 'custom',
defaultArea: CustomizableUI.AREA_NAVBAR,
onBuild: function(aDocument) {
let tb_button = aDocument.createElementNS('http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul', 'toolbarbutton');
let attributes = {
id: buttonID,
class: 'toolbarbutton-1 chromeclass-toolbar-additional',
removable: 'true',
label: labelText,
tooltiptext: tooltipText
};
for (let a in attributes) tb_button.setAttribute(a, attributes[a]);
tb_button.setAttribute(dataAttrib, prefVal);
tb_button.IsOnce = (prefVal == 'once');
return tb_button;
}
});
} catch(e) {};
document.getElementById(buttonID).addEventListener('click', event => {
const button = document.getElementById(buttonID);
function getPref() {return Services.prefs.getCharPref(configPref)};
function setPref(val) {Services.prefs.setCharPref(configPref,val)};
function setIsOnce(val) {
let win = Services.wm.getEnumerator('navigator:browser');
while (win.hasMoreElements()) {
win.getNext().document.getElementById(buttonID).IsOnce = val;
};
};
switch (event.button) {
case 0:
setPref('normal');
if (button.IsOnce) {
BrowserCommands.reloadSkipCache();
setIsOnce(false);
} else {
if (prefVal == 'normal')
BrowserCommands.reloadSkipCache()
else
BrowserCommands.reload();
};
break;
case 1:
setPref('once');
BrowserCommands.reloadSkipCache();
setIsOnce(true);
break;
case 2:
setPref('none');
event.preventDefault();
event.stopPropagation();
BrowserCommands.reload();
break;
};
let win = Services.wm.getEnumerator('navigator:browser');
while (win.hasMoreElements()) {
win.getNext().document.getElementById(buttonID).setAttribute(dataAttrib, getPref());
};
});
let stylesheet = document.createProcessingInstruction('xml-stylesheet', 'type="text/css" href="data:text/css;utf-8,' + encodeURIComponent(css) + '"');
document.insertBefore(stylesheet, document.documentElement);
})();
Alles anzeigen
moko2000, such dir eine der Varianten aus, diese von mir oder die vom Mitleser ein paar Postings weiter oben.
Und lassen sich so zum Bleistift einbinden.
Das kann man sogar zusammenfügen: Zeile 1 und 2 vertauscht, Variablenname angepasst:
JavaScript
let ButtonIcon = "default_icon.svg"; // Name & Dateiendung des anzuzeigenden Symbols!
let IconPath = PathUtils.toFileURI(PathUtils.join(PathUtils.profileDir, 'chrome', 'icons', ButtonIcon )); // Pfad zum Profilordner und gleich in den entsprechenden Unterordner
Und dann Zeile 6 entsprechend geändert: