So schnell wurden noch nie funktionierende Add-ons geschrieben, getestet, bereitgestellt und verwendet.
Fehlt nur noch der Hinweis am Beginn der Scripte:
// Autor(en): Softwareschmiede der DCFG (Die Camp-Firefox Gurus)...
Gruß Harry
So schnell wurden noch nie funktionierende Add-ons geschrieben, getestet, bereitgestellt und verwendet.
Fehlt nur noch der Hinweis am Beginn der Scripte:
// Autor(en): Softwareschmiede der DCFG (Die Camp-Firefox Gurus)...
Gruß Harry
Just for Fun:
Ich habe im Script für die userrChrome.css den Bereich der Button-Grafik "onCreated: function(aNode) { .... return aNode; }" gelöscht.
Dann im CSS ein Sonderzeichen erzeugt:
/* Die Grafik im Quelltext gelöscht und hier durch ein Sonderzeichen ersetzt
*/
#ucjs-register-userChrome::after {
color: white !important;
content: "\21bb" !important;
font-size: 28px !important;
margin-left: -26px !important;
margin-right: 2px !important;
}
Das klappt auch, und Sonderzeichen gibt es ja jede Menge, auch bunte Bildchen... Vielleicht könnte man das ja auch gleich im Script machen?
Gruß Harry
PS: Den ersten Teil gelöscht, war über... "\1f6a7" ist auch ein gutes Bildchen...
sehr gut gemacht...herzlichen Dank dafür :klasse:
Gern geschehen... :wink:
Der erste Button für die Datei...der zweite für die Vorschau.
Hier werden 2 andere Buttons angezeigt..
[attachment=0]Unbenannt.PNG[/attachment]
Ich nutze den Code von Andreas:
// cssLive.uc.js
(function() {
if (location != 'chrome://browser/content/browser.xul') {
return;
}
/*** OPTIONEN START *******************************************************/
var cssLiveOptions = {
/* Falls sich die Testdatei in einem Unterverzeichnis von "chrome"
befindet, bitte hier zwischen Anführungszeichen eintragen, ansonsten
nur die Anführungszeichen */
subdir: 'css',
/* Name der Testdatei */
file: 'Test.css'
};
/*** OPTIONEN ENDE ********************************************************/
var buttonPath = '';
var testFile = Services.dirsvc.get('UChrm', Ci.nsIFile);
if( cssLiveOptions.subdir != '' ) {
testFile.append( cssLiveOptions.subdir );
buttonPath += cssLiveOptions.subdir + "/";
}
testFile.append( cssLiveOptions.file );
buttonPath += cssLiveOptions.file;
var buttonTxt_1 = buttonPath + " aufrufen";
var buttonTxt_2 = buttonPath + " ausführen";
var errorTxt = "Die Datei \n" + testFile.path + "\n existiert nicht.";
Components.utils.import("resource:///modules/CustomizableUI.jsm");
try {
CustomizableUI.createWidget({
id: "fp-get-css-file",
defaultArea: CustomizableUI.AREA_NAVBAR,
removable: true,
label: buttonTxt_1,
tooltiptext: buttonTxt_1,
onClick: function() {
if( testFile.exists() ) {
testFile.launch();
} else {
alert( errorTxt );
}
},
onCreated: function(aNode) {
aNode.style.listStyleImage = 'url()';
return aNode;
}
});
} catch (e) {
Components.utils.reportError(e);
};
try {
CustomizableUI.createWidget({
id: "fp-register-css-file",
defaultArea: CustomizableUI.AREA_NAVBAR,
removable: true,
label: buttonTxt_2,
tooltiptext: buttonTxt_2,
onClick: function() {
if( testFile.exists() ) {
var CI = Components.interfaces;
var CC = Components.classes;
let sss = CC["@mozilla.org/content/style-sheet-service;1"].getService( CI.nsIStyleSheetService );
let ios = CC["@mozilla.org/network/io-service;1"].getService( CI.nsIIOService );
let fileURL = Services.io.getProtocolHandler( 'file' ).QueryInterface( Ci.nsIFileProtocolHandler ).getURLSpecFromFile( testFile );
let uri = ios.newURI( fileURL , null , null );
sss.loadAndRegisterSheet( uri , sss.AGENT_SHEET );
} else {
alert( errorTxt );
}
},
onCreated: function(aNode) {
aNode.style.listStyleImage = 'url()';
return aNode;
}
});
} catch (e) {
Components.utils.reportError(e);
}
})();
Alles anzeigen
Hier werden 2 andere Buttons angezeigt..
Dann hast du den Code evtl. doppelt eingetragen...denn:
Ich nutze den Code von Andreas:
zeigt einwandfrei die beiden Icons aus Beitrag Nr. 80 an.
Die bei dir angezeigten Icons stammen aus dem Code in Beitrag Nr. 78.
Du hast mal wieder recht....
Jetzt alles schick..
Ich habe eine Frage...
Wenn ich einen beliebigen Ordner auf meinem Computer öffnen möchte, nicht den Skript "Test.css", was muss dann geändert werden?
Das müsste dann so aussehen:
(function () {
if (location != 'chrome://browser/content/browser.xul')
return;
try {
/* ***************************************************************
Pfad zum auszuführenden Programm ODER Ordner definieren:
var APPpath = 'C:\\Windows\\notepad.exe';
var APPpath = 'C:\\Windows\\';
*****************************************************************
Label und Tooltip definieren:
var label = "Notepad";
var tooltiptext = "Notepad starten";
***************************************************************** */
var APPpath = 'C:\\Windows\\notepad.exe';
var label = 'Notepad';
var tooltiptext = 'Notepad starten';
Components.utils.import("resource:///modules/CustomizableUI.jsm");
CustomizableUI.createWidget({
id: "ucjs-" + label + "-button",
defaultArea: CustomizableUI.AREA_NAVBAR,
removable: true,
label: label,
tooltiptext: tooltiptext,
onClick: function () {
var file = Cc['@mozilla.org/file/local;1'].createInstance(Ci.nsIFile);
file.initWithPath(APPpath);
file.launch();
},
onCreated: function (aNode) {
var ICOpath = APPpath.replace(/\\/g, "//");
aNode.style.listStyleImage = 'url("moz-icon:file:///' + ICOpath + '?size=16")'
return aNode;
}
});
} catch (e) {
Components.utils.reportError(e);
};
})();
Alles anzeigen
Tanni Bestens!
Vielen Dank!
Damit wird ein Button erstellt, womit man die Datei: Test.css wenn sie sich um Ordner CSS befindet, gleich öffnen kann:Code Alles anzeigen(function() { if (location != 'chrome://browser/content/browser.xul') return; try { Components.utils.import("resource:///modules/CustomizableUI.jsm"); CustomizableUI.createWidget({ id: "button-testcss", defaultArea: CustomizableUI.AREA_NAVBAR, removable: true, label: "Test.ccs", tooltiptext: "Test.css", onClick: function() { var dir = Services.dirsvc.get('UChrm', Ci.nsIFile); dir.append('CSS'); dir.append('Test.css'); dir.launch(); }, onCreated: function(aNode) { aNode.style.listStyleImage = 'url()'; return aNode; } }); } catch (e) { Components.utils.reportError(e); }; })();
Damit wird ein Button erstellt, der nach einem Eintrag in obiger Datei eine Vorschau zeigt:
Code Alles anzeigen(function() { try { CustomizableUI.createWidget({ id: "fp-register-test", defaultArea: CustomizableUI.AREA_NAVBAR, removable: true, label: "register-test", tooltiptext: "register-test", onClick: function() { var CI = Components.interfaces; var CC = Components.classes; let sss = CC["@mozilla.org/content/style-sheet-service;1"].getService( CI.nsIStyleSheetService ); let ios = CC["@mozilla.org/network/io-service;1"].getService( CI.nsIIOService ); var file = Services.dirsvc.get('UChrm', Ci.nsIFile); file.append('css'); file.append('Test.css'); let fileURL = Services.io.getProtocolHandler( 'file' ).QueryInterface( Ci.nsIFileProtocolHandler ).getURLSpecFromFile( file ); let uri = ios.newURI( fileURL , null , null ); sss.loadAndRegisterSheet( uri , sss.AGENT_SHEET ); }, onCreated: function(aNode) { aNode.style.listStyleImage = 'url()'; return aNode; } }); } catch (e) { Components.utils.reportError(e); } })();
Und damit wird eine Vorschau angezeigt wenn der Code direkt in die userChrome.css eingetragen wurde:
Code Alles anzeigen(function() { if (location != 'chrome://browser/content/browser.xul') return; try { CustomizableUI.createWidget({ id: "ucjs-register-userChrome", defaultArea: CustomizableUI.AREA_NAVBAR, removable: true, label: "register-userChrome", tooltiptext: "userChrome.css erneut registrieren", onClick: function() { var CI = Components.interfaces; var CC = Components.classes; let sss = CC["@mozilla.org/content/style-sheet-service;1"].getService( CI.nsIStyleSheetService ); let ios = CC["@mozilla.org/network/io-service;1"].getService( CI.nsIIOService ); var file = Services.dirsvc.get('UChrm', Ci.nsIFile); //file.append('css'); /* Unterordner für Anpassungen an andere Dateien */ file.append('userChrome.css'); let fileURL = Services.io.getProtocolHandler( 'file' ).QueryInterface( Ci.nsIFileProtocolHandler ).getURLSpecFromFile( file ); let uri = ios.newURI( fileURL , null , null ); sss.loadAndRegisterSheet( uri , sss.AGENT_SHEET ); }, onCreated: function(aNode) { aNode.style.listStyleImage = 'url()'; return aNode; } }); } catch (e) { Components.utils.reportError(e); } })();
PS:
Es sind also sogar 3 Scripte in diesem Thread vorhanden, und nicht nur 2 wie ich weiter oben geschrieben hatte, sorry dafür.
Kann man dies auch für die Test.uc.js verwenden?
Kann man dies auch für die Test.uc.js verwenden?
Dafür bedarf es wohl ein komplett neues Script denke ich mal.
Angefragt hatte ich das hier ja schon mal:
Ok, A.. Dann warten wir mal ab, ob sich was tut.