Ein Rechtsklick auf einen beliebigen Button erzeugt ja immer:
Man müsste also wenn dann das kompl. Rechtsklick Popup deaktivieren.
Aber ob das wirklich Sinn macht
Das ist meine:
Nutze ich hier auch.
Siehe mein Movie in Beitrag Nr. 101
Ein Rechtsklick auf einen beliebigen Button erzeugt ja immer:
Man müsste also wenn dann das kompl. Rechtsklick Popup deaktivieren.
Aber ob das wirklich Sinn macht
Das ist meine:
Nutze ich hier auch.
Siehe mein Movie in Beitrag Nr. 101
Ich kann hier keine Probleme damit feststellen.
Ich auch nicht mehr.
Das Script, was ich im Einsatz hatte, war eines der ersten von hier, das ich dann nur mit neuem Icon und meinen Adressen abgeändert hatte. Leider habe ich es gestern gelöscht, weil dieser Fehler auftrat.
Nun habe ich im aktuellen Nightly mit diesem Script RE: Quicklink-Button getestet, funktioniert alles ohne Probleme, erstes Fenster und auch zweites Fenster.
Das Popup erscheint hier auch kurz, wäre schön, wenn es nicht mehr so ist.
Danke, für den Test, Andreas.
Ja.
Das habe ich aber auch bei einem anderen Skript mit Doppelfunktion Rechts- Linksklick.
Danke für die Info! Eigentlich ist die rechte Maustaste ja auch für diese Funktionalität vorgesehen und so gesehen ist diese Taste wohl auch nicht 1.Wahl, da dann eben auch die Systemfunktionen aus dem Kontextmenü fehlen. Na ja, man könnte auch wahlweise die ctrl/alt/shift-Taste beim Klicken nehmen oder die mittlere Maustaste.
Ist jetzt aber nicht so wichtig, finde ich...
Danke, für den Test, Andreas.
Gerne doch, wir helfen uns doch immer
Siehe mein Movie in Beitrag Nr. 101
Da war kein Code dabei.
Hast Du mit meinem code getestet?
Hast Du mit meinem code getestet?
Ich nutze das Skript aus Beitrag Nr. 96
Ich meinte den Code für meine Zusatzleiste....
den Code für meine Zusatzleiste....
Mein Skript ist fast identisch:
// Author @aborix
(function() {
if (location.href !== 'chrome://browser/content/browser.xhtml') return;
var tb = document.createXULElement('toolbar');
tb.id = 'new-toolbar';
tb.setAttribute('customizable', true);
tb.setAttribute('mode', 'icons');
tb.setAttribute("context","toolbar-context-menu");
var vbox = document.createXULElement('vbox');
document.getElementById('navigator-toolbox').parentNode.parentNode.insertBefore( vbox, null);
vbox.style.backgroundColor = '';
vbox.appendChild(tb);
CustomizableUI.registerArea('new-toolbar', {legacy: true});
CustomizableUI.registerToolbarNode(tb);
})();
Alles anzeigen
In einer Bugzilla-Diskussion (Link muss ich erst suchen) wurde z.B. das Aufrufen eines Lesezeichens als typische Anwendung für OpenTrustedLinkIn beschrieben.
Das interessiert mich. Falls du den Link noch findest, teile ihn bitte mit.
Jetzt müsste man noch herausfinden, wie man das kurzzeitige Aufpoppen des Kontextmenüs beim Rechtsklick verhindern kann.
Mit event.preventDefault().
Fällt dir evtl. dazu etwas ein?
BeitragRE: Quicklink-Button
[…]
Hallo @aborix .
Im Prinzip funtioniert es gut.
Nur das neue Fenster ist immer kleiner
camp-firefox.de/attachment/39572/
Ich kann es vergrößern, aber bei einem erneuten Rechtsklick ist es wieder kleiner.
Oder mache ich etwas falsch?2002Andreas27. November 2022 um 10:13
Öffne mal mit Strg+N ein neues Fenster. Ist es gleich groß?
Öffne mal mit Strg+N ein neues Fenster.
Das hat die ganz normale Größe dann.
Noch ein Test: Wie ist es, wenn du in die Browserkonsole eingibst:
OpenBrowserWindow()
Das interessiert mich. Falls du den Link noch findest, teile ihn bitte mit.
Mittlerweile glaube ich auch, dass du recht hast .
Mit Trusted-Links sind wohl in erster Linie Seitenaufrufe gemeint, welche (Firefox-)interne Seiten darstellen z.B. 'about:config' und diese sollen mit 'OpenTrustedLinkIn' geöffnet werden. Da wird dann das 'System Principal' eingestellt, bei allen anderen Inhalten wird dann wohl 'ContentPrincipal' oder 'NullPrincipal' eingestellt, welche über die Vorschaltfunktion 'openWebLinkIn' aufgerufen werden. Ich habe die Aussagen aus der Bugzilla-Diskussion wohl genau anders herum interpretiert, weil ich davon ausgegangen bin, dass mit 'Trusted' die Quelle des Aufrufs (eben die FirefoxUI) gemeint sind und nicht das Ziel (ein Webseite) ,
Sorry... .
Hier trotzdem noch der Bugzilla-Link:
Hier die Aussagen, auf die ich mich bezogen hatte:
Mit event.preventDefault().
Danke, funktioniert perfekt!
Guten Morgen auch.
Und mit dem Skript aus #96 klappt es nicht?
Und mit dem Skript aus #96 klappt es nicht?
Doch, das funktioniert hier einwandfrei.
Mich hat nur interessiert, warum es mit dem anderen Skript nicht so ist.
event.preventDefault()
Ist das so richtig eingetragen?
Mich hat nur interessiert, warum es mit dem anderen Skript nicht so ist.
Welches Skript nochmal genau?
Ist das so richtig eingetragen?
Das funktioniert zwar auch, aber ich meinte nach diesen Zeilen:
Welches Skript nochmal genau?
Dieses hier:
Das funktioniert zwar auch, aber ich meinte nach diesen Zeilen:
Ich hatte mich oben im Beitrag vertan, und meinte diesen neuen Eintrag:
event.preventDefault()
Dieses hier:
aborix26. November 2022 um 23:29
Da wird das neue Fenster nicht mit
OpenBrowserWindow()
sondern mit
openDialog(AppConstants.BROWSER_CHROME_URL)
geöffnet.
Wie ist es, wenn du diese Anweisung in die Browserkonsole eingibst?
Ich hatte mich oben im Beitrag vertan, und meinte diesen neuen Eintrag:
event.preventDefault()
Den meinte ich ohnehin auch.
wenn du diese Anweisung in die Browserkonsole eingibst?
Dann erscheint wieder dieses kleinere Fenster.
Danke für die Erklärung
Den meinte ich ohnehin auch.
Alles klar, danke.
Dann ändere ich das hier mal.
Ich habe mal alle Änderungen an meinem Skript aus #96 , welche hier im weiteren Verlauf diskutiert wurden, in ein sauberes Skript mit eigenem Icon übertragen. Außerdem wird jetzt ein Array verwendet und man muss die Links nur einmal dort eintragen.
Der notwendige 'Timeout' von 500ms in Zeile 50 beim Öffnen eines neuen Fensters ist unabhängig von der Zahl der zu öffnenden Tabs (na immerhin) und bei Problemen diesen Wert schrittweise leicht erhöhen. Einen Ersatz dafür habe ich leider nicht gefunden.
(function() {
if (!window.gBrowser){
return;
}
const quickLinks =
[
'https://www.tagesschau.de/',
'https://www.zdf.de/',
'https://www.br24.de/',
'https://www.spiegel.de/',
];
try {
CustomizableUI.createWidget({
id: 'link-button',
type: 'custom',
defaultArea: CustomizableUI.AREA_NAVBAR,
onBuild: function(aDocument) {
var toolbaritem = aDocument.createElementNS('http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul', 'toolbarbutton');
var props = {
id: 'link-button',
class: 'toolbarbutton-1 chromeclass-toolbar-additional',
removable: 'true',
label: 'Quicklink',
accesskey: '',
tooltiptext: 'Quicklink:\nForum - camp-firefox.de',
style: 'list-style-image: url()',
};
for (var p in props)
toolbaritem.setAttribute(p, props[p]);
return toolbaritem;
}
});
} catch(e) { };
document.getElementById('link-button').addEventListener( 'click', function(event) {
let linkCaller=null;
let timeout=0;
if (event.button == 0) {
linkCaller = event.target;
}
else if (event.button == 2) {
event.preventDefault();
linkCaller = OpenBrowserWindow();
timeout=500;
}
else
return;
setTimeout(function() {
quickLinks.forEach((weblink,nIndex) => {
if( nIndex == 0 && event.button == 2 )
{
linkCaller.ownerGlobal.openWebLinkIn(weblink,"current");
}
else
{
linkCaller.ownerGlobal.openWebLinkIn(weblink,"tab");
}
});
}, timeout);
}, true);
}) ();
Alles anzeigen