Ich habe milupo schon vor ein paar Tagen diesbezüglich informiert.
Leider noch keine Antwort. Da sind auch noch zwei weitere Erweiterungen
die milupo immer macht. Hoffen wir, dass er bald mal Zeit dazu hat.
Mfg.
Endor
Beiträge von Endor
-
-
die Scripte die in die addonbar kommen.
Das müsstest Du schon merken wenn Du im 29er die aktuelle Version von ctr
installiert hast. Dann siehst Du ja ob und was fehlt.
Mfg.
Endor -
Diese mal sind die Leute von Amo schuld. Die die für die Überprüfung der
verschiedenen Erweiterungen zuständig sind. Aris musste sämtliche Bezeichnungen - Ids
der einzelnen Buttons, Symbolleisten usw. ändern, da die bis dahin verwendeten Ids nicht individuell
genug gewesen sind. Sonst hätten die die Erweiterung auf Amo nicht frei gegeben.Diese Änderung betrifft auch alle Scripte die irgendwie mit einer Id von der Ctr Erweiterung
zu tun haben und müssen entsprechend angepasst werden. Schöne Sauerei....
jetzt heißt es zbs. nicht mehr ctr_addonbar sonders ctraddon_addonbar.
Es ist also überall addon dazu gekommen.Mfg.
Endor -
Hallo zusammen.
Ein update für die Erweiterung Classic Theme Restorer
ab Version 1.1.9beta14 muss alles angepasst werden:[Blockierte Grafik: http://i.imgur.com/fqUzau5.png]
[Blockierte Grafik: http://i.imgur.com/x2DrOK7.png]
Hier wieder der ganze Code
CSS
Alles anzeigen@-moz-document url-prefix("chrome://classic_theme_restorer/content/options.xul") { button[label="OK"]{margin-top: 10px!important;} button[label="OK"]{ list-style-image: url("") !important;} button[label="OK"] .button-icon {margin-left: -15px !important; margin-top: 1px !important; margin-right: 10px !important; } menulist[preference="ctraddon_tabs"][sizetopopup="pref"]{ list-style-image: url("") !important;} menulist[preference="ctraddon_tabs"][sizetopopup="pref"].menulist-icon { margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } menulist[preference="ctraddon_tabsontop"][sizetopopup="pref"]{ list-style-image: url("") !important;} menulist[preference="ctraddon_tabsontop"][sizetopopup="pref"].menulist-icon { margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } menulist[preference="ctraddon_tabmwidth"][sizetopopup="pref"]{ list-style-image: url("") !important;} menulist[preference="ctraddon_tabmwidth"][sizetopopup="pref"].menulist-icon { margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } menulist[preference="ctraddon_tabwidth"][sizetopopup="pref"] { list-style-image: url("") !important;} menulist[preference="ctraddon_tabwidth"][sizetopopup="pref"].menulist-icon { margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } menulist[preference="ctraddon_nbiconsize"][sizetopopup="pref"]{ list-style-image: url("") !important;} menulist[preference="ctraddon_nbiconsize"][sizetopopup="pref"].menulist-icon { margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } #ctraddon_appbutton_list1 { list-style-image: url("") !important;} #ctraddon_appbutton_list1.menulist-icon { margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } #ctraddon_appbutton_list2 { list-style-image: url("") !important;} #ctraddon_appbutton_list2.menulist-icon { margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } menulist[preference="ctraddon_appbuttonc"][sizetopopup="pref"] { list-style-image: url("") !important;} menulist[preference="ctraddon_appbuttonc"][sizetopopup="pref"].menulist-icon { margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } menulist[preference="ctraddon_findbar"][sizetopopup="pref"] { list-style-image: url("") !important;} menulist[preference="ctraddon_findbar"][sizetopopup="pref"].menulist-icon { margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } menulist[preference="ctraddon_nav_txt_ico"][sizetopopup="pref"]{ list-style-image: url("") !important;} menulist[preference="ctraddon_nav_txt_ico"][sizetopopup="pref"].menulist-icon { margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } /*Tab-Titel*/ tab[label="Grundeinstellungen"]{min-width:145px !important;} tab[label="Grundeinstellungen"]{ list-style-image: url("") !important;} tab[label="Grundeinstellungen"] .tab-icon {margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } #ctraddon_sqtabcolorstab{min-width:95px !important;} #ctraddon_sqtabcolorstab{ list-style-image: url("") !important;} #ctraddon_sqtabcolorstab .tab-icon {margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } tab[label="Extra"]{min-width:70px !important;} tab[label="Extra"]{ list-style-image: url("") !important;} tab[label="Extra"] .tab-icon {margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } tab[label="Oberfläche"]{min-width:105px !important;} tab[label="Oberfläche"]{ list-style-image: url("") !important;} tab[label="Oberfläche"] .tab-icon {margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } tab[label="Spezial Einstellungen"]{min-width:155px !important;} tab[label="Spezial Einstellungen"]{ list-style-image: url("") !important;} tab[label="Spezial Einstellungen"] .tab-icon {margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } tab[label="Animation / CTR"]{min-width:135px !important;} tab[label="Animation / CTR"]{ list-style-image: url("") !important;} tab[label="Animation / CTR"] .tab-icon {margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } tab[label="Tab (aktiv/hover/standard)"]{min-width:188px !important;} tab[label="Tab (aktiv/hover/standard)"]{ list-style-image: url("") !important;} tab[label="Tab (aktiv/hover/standard)"] .tab-icon {margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } tab[label="Tab (ungelesen) / Neuer Tab"]{min-width:195px !important;} tab[label="Tab (ungelesen) / Neuer Tab"]{ list-style-image: url("") !important;} tab[label="Tab (ungelesen) / Neuer Tab"] .tab-icon {margin-left: 5px !important; margin-top: 1px !important; margin-right: 10px !important; } [href="https://addons.mozilla.org/addon/cstbb/versions/"]{ background: #efefef url("") no-repeat !important; color:black!important; font-size:14px!important; min-height: 25px!important; margin-top: 10px!important; text-decoration:none!important; padding-top: 2px !important; padding-right:15px!important; padding-left:35px!important; border-color: #A6A4A4 !important; border-style: outset !important; border-width:1px !important; background-position:10px 3px!important; border-radius:4px!important; } [href="https://addons.mozilla.org/addon/cstbb/versions/"]:hover{ background: #E1F3FC url("") no-repeat !important; color:black!important; font-size:14px!important; text-decoration:none!important; padding-right:15px!important; padding-left:35px!important; background-position:10px 3px!important; border-style: outset !important; border-width:1px !important; border-radius:4px!important; } #ctraddon_support{ background: #efefef url("") no-repeat !important; color:black!important; font-size:14px!important; min-height: 25px!important; margin-top: 10px!important; text-decoration:none!important; padding-top: 2px !important; padding-right:15px!important; padding-left:35px!important; border-color: #A6A4A4 !important; border-style: outset !important; border-width:1px !important; background-position:10px 3px!important; border-radius:4px!important; } #ctraddon_support:hover{ background: #E1F3FC url("") no-repeat !important; color:black!important; font-size:14px!important; text-decoration:none!important; padding-top: 2px !important; padding-right:15px!important; padding-left:35px!important; background-position:10px 3px!important; border-style: outset !important; border-width:1px !important; border-radius:4px!important; } }Mfg.
Endor -
Classic Theme Restorer Version 1.1.9beta15
https://addons.mozilla.org/de/firefox/add…torer/versions/Direkte Installation oder Download:
https://addons.mozilla.org/firefox/downlo…version-historyv1.1.9beta15
[fix] squared tabs: protected/locked/pinned tabs and TMP/TU addons
[fix] Windows small button mode: urlbar and star button margins
[fix] some tweaks for rtl locales
[fix] Windows + squared tabs: tabs toolbar gap in maximized modeMfg.
Endor -
Hallo Zusammen
Ich habe wieder eine Version mit Änderung gemacht, damit beim
Neustart kein neuer Tab, bzw. neues Fenster, mit der Tmp Update Seite geöffnet wird.
Die Übersetzung ist aktuell!Download oder direkte Installation: Tab Mix Plus-0.4.1.4pre.140414a1-fx-spezial.xpi
Verwendung wie immer auf eigene Gefahr.
Und nun viel Spaß!
Mfg.
Endor[Blockierte Grafik: http://dl.dropbox.com/u/15467633/Firefox/Linie.png]
[Blockierte Grafik: http://db.tt/iaNtST9y] Bei Fragen oder Problemen zu - mit Tabmixplus, bitte immer in diesem Thread schreiben:
:arrow: https://www.camp-firefox.de/forum/viewtopic.php?f=4&t=98563 -
Neue Dev Version Classic Toolbar Buttons 1.4.0beta7
https://addons.mozilla.org/de/firefox/addon/cstbb/versions/
Download
https://addons.mozilla.org/firefox/downlo…version-historyChangelog
[Fx29+] added support for CTRs new button ids (CTR1.1.9beta14 required)Mfg.
Endor -
Hallo Miccovin.
Habe hier alle meine Scripte die ich so verwende auch schon im 29er, 30er und 31er laufen.
Da ist mir was die Scripte betrifft, nichts gröberes vorgekommen.Was CSS Codes betrifft, da ist das dann schon etwas anderes. Speziell die für die Tabs.
Von denen muss man praktisch alle anpassen, und durch das besch... Australis Design
ist das nicht mehr ganz so einfach.
Mfg.
Endor -
Classic Theme Restorer Version 1.1.9beta14
https://addons.mozilla.org/de/firefox/add…torer/versions/Direkte Installation oder Download:
https://addons.mozilla.org/firefox/downlo…version-historyv1.1.9beta14
[fix] issues with pinned tabs and a few add-ons
[change] almost all CTR ids changed (requested by AMO editors) ** Previous ids were not unique enough.
Every id/class starting with "ctr_" was renamed to "ctraddon_", so all themes, extensions, userstyles etc. using them have to be updated, sorry.Because of this id change, some CTR items might end up in customization palette or at the end of the navigation toolbar.
They have to be moved back to where they were before manually.Some settings/features might got broken by this change, so report any new issues.
Mfg.
Endor -
Ja, das kann schon mal passieren.
//Sei tifoso di Valentino?
Mfg.
Endor -
Genau, den Thread würde es auch betreffen. Deswegen, bräuchte es eine Art Whitelist für bestimmte Threads,
wenn automatisch nach so und soviel Tagen, das Editieren nicht mehr möglich ist.
Keine Ahnung ob es so etwas überhaupt möglich ist.
Mfg.
Endor -
Ach so, Du verwendet eine beta Version des Flash Players.
Die gibt es hier zum download: http://labs.adobe.com/downloads/flashplayer.html
Du hast jetzt ja die aktuelle Beta im Moment. Also passt alles.
Ich verwende immer die aktuelle Finale Version.
Schön, dass es funktioniert hat.
Auch Dir einen schönen Abend.
Mfg.
Endor -
Hallo ostsee!
ich verwende immer die OFF Line Installation.
Also Datei runter laden und dann installieren:http://download.macromedia.com/pub/flashplaye…h_player_ax.exe für IE,
http://download.macromedia.com/pub/flashplaye…lash_player.exe für FirefoxTeste das mal. Klarerweise muss Firefox zum installieren geschlossen sein.
Hoffe, es klappt.
Mfg.
Endor -
Mir würde das mit unserer Seite im Übersetzungs Tread auch sehr ungelegen kommen. Da muss ich den Eingangsbeitrag auch
regelmäßig ändern, anpassen usw. Das gleiche mit dem NoScript Thread und den TMP Thread von Boersenfeger.
Edit-Sperre ja, aber mit Whitelist oder so.
Mfg.
Endor -
// Wenn dann die neueste Version davon 3.0.3 https://addons.mozilla.org/de/firefox/add…/versions/3.0.3
Ich ziehe aber die Erweiterung Classic Theme Restorer vor:
https://www.camp-firefox.de/forum/viewtopi…=911137#p911137Mfg.
Endor -
Das ist eine gute Idee, habe ich auch gleich mal per Twitter gemacht. Mal sehen
ob und was der Japaner antwortet. Kann aber etwas dauern....
Mfg.
Endor -
Hallo aborix.
Schade, dass Du da auch nicht weiter weißt.
Denn ich bin auch am ende meines Lateins.Es wird wohl so sein, dass wir das für Thunderbird nicht zum laufen bringen können.
Da bleibt wohl nur Übrig die Erweiterung Stylish zu verwenden, wenn man in Thunderbird
CSS Code anwenden will.Trotzdem Danke für Deine Mühe.
Mfg.
Endor -
Ich habe alles probiert was mir eingefallen ist.
Klar den Pfad zum Editor muss man in about:config eingeben, dann funktioniert auch
das Erstellen neuer CSS Codes über das Script. Der Editor wird geöffnet usw..
Leider ändert das aber nichts an dem Problem, dass man vorhandene CSS Codes
nicht mit rechts klick im Editor öffnen und bearbeiten kann, es tut sich einfach nichts bei
einem rechts klick, und beim Starten von Thunderbird werden die Stiles nicht automatische geladen.
Manuell mit Mittelklick geht es. Komische Sache.
Ich habe auch noch versucht, den Pfad zum CSS Ordner in about:config einzufügen, wie
am Anfang im Script geschrieben, UserCSSLoader.FOLDER aber auch das bringt nichts.Ich weiß auch nicht mehr weiter. Irgendwas muss man im Script ändern nur was... :-??
Mfg.
Endor -
Ist die NoScipt Seite eventuell bei dir als weitere Startseite eingetragen?
Extras - Einstellungen - Allgemein
dann bei Startseite mal nachschauen.Mfg.
Endor -
Hallo zusammen.
Ich habe mich mal daran versucht, aber wie schon oben geschrieben, es will einfach nicht so.
Hier mal mein aktuelles Werk,HTML
Alles anzeigen// ==UserScript== // @name UserCSSLoader // @description Stylish みたいなもの // @namespace http://d.hatena.ne.jp/Griever/ // @author Griever // @include main // @license MIT License // @compatibility Firefox 4 // @charset UTF-8 // @version 0.0.4e // @note 0.0.4 Remove E4X // @note CSSEntry クラスを作った // @note スタイルのテスト機能を作り直した // @note ファイルが削除された場合 rebuild 時に CSS を解除しメニューを消すようにした // @note uc で読み込まれた .uc.css の再読み込みに仮対応 // @note Version 0.0.4.b ermoeglicht "Styles importieren" per Mittelklick und anderen Dateimanager (s. vFileManager in Zeile 54) // @note Version 0.0.4.c ermoeglicht Darstellung als Button und Einstellung der Zielleiste (s. showAs und showWhere in Zeile 56 bzw. 57) // sowie Uebernahme des CSS-Pfades in die Zwischenablage per Strg+Rechtsklick, Version 0.0.4.e: Alt+Rechtsklick verschiebt css-Datei in den TEMP-Ordner // ==/UserScript== /****** 使い方 ****** chrome フォルダに CSS フォルダが作成されるのでそこに .css をぶち込むだけ。 ファイル名が "xul-" で始まる物、".as.css" で終わる物は AGENT_SHEET で、それ以外は USER_SHEET で読み込む。 ファイルの内容はチェックしないので @namespace 忘れに注意。 メニューバーに CSS メニューが追加される メニューを左クリックすると ON/OFF 中クリックするとメニューを閉じずに ON/OFF 右クリックするとエディタで開く Pfad zum Editor "view_source.editor.path" に指定されているものを使う Pfad zum User CSS Ordner "UserCSSLoader.FOLDER" にパスを入れれば変更可能 **** Beschreibung-Ende ****/ (function(){ let { classes: Cc, interfaces: Ci, utils: Cu, results: Cr } = Components; if (!window.Services) Cu.import("resource://gre/modules/Services.jsm"); // 起動時に他の窓がある(2窓目の)場合は抜ける let list = Services.wm.getEnumerator("messenger:messenger"); while(list.hasMoreElements()){ if(list.getNext() != window) return; } if (window.UCL) { window.UCL.destroy(); delete window.UCL; } window.UCL = { // vFileManager: 'C:\\Programme\\totalcmd\\TOTALCMD.EXE', // vFileManager: 'F:\\Adaten\\Downloads\\FreeComander\\FreeCommanderPortable\\FreeCommanderPortable.exe' args: ['T'], vFileManager: '', //etwas anderes als 'button' zeigt den Loader als Menue: showAs: 'menu', showWhere: 'mail-menubar', // wenn oben als Button darstellen gewählt wurde, dann hier tabbar-toolbar oder mail-toolbar-menubar2 verwenden in Thunderbird //Automatische Aktualisierung der Menüliste nach Verschieben einer CSS Datei in den TEMP Ordner mit "rechte Maustatste + Alt" AUTO_REBUILD: true, USE_UC: "UC" in window, AGENT_SHEET: Ci.nsIStyleSheetService.AGENT_SHEET, USER_SHEET : Ci.nsIStyleSheetService.USER_SHEET, readCSS : {}, get disabled_list() { let obj = []; try { obj = this.prefs.getComplexValue("disabled_list", Ci.nsISupportsString).data.split("|"); } catch(e) {} delete this.disabled_list; return this.disabled_list = obj; }, get prefs() { delete this.prefs; return this.prefs = Services.prefs.getBranch("UserCSSLoader.") }, get styleSheetServices(){ delete this.styleSheetServices; return this.styleSheetServices = Cc["@mozilla.org/content/style-sheet-service;1"].getService(Ci.nsIStyleSheetService); }, get FOLDER() { let aFolder; try { // UserCSSLoader.FOLDER があればそれを使う let folderPath = this.prefs.getCharPref("FOLDER"); aFolder = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile) aFolder.initWithPath(folderPath); } catch (e) { aFolder = Services.dirsvc.get("UChrm", Ci.nsILocalFile); aFolder.appendRelativePath("CSS"); } if (!aFolder.exists() || !aFolder.isDirectory()) { aFolder.create(Ci.nsIFile.DIRECTORY_TYPE, 0664); } delete this.FOLDER; return this.FOLDER = aFolder; }, getFocusedWindow: function() { let win = document.commandDispatcher.focusedWindow; if (!win || win == window) win = content; return win; }, init: function() { var xmlStart = '<menu id="usercssloader-menu"'; var xmlEnd = '</menu>'; if (UCL.showAs === 'button') { xmlStart = '<toolbarbutton type="menu" id="usercssloader-menu" class="toolbarbutton-1"'; xmlEnd = '</toolbarbutton>'; } var xml = xmlStart + ' \ label="CSS" accesskey="C" onclick="if (event.button === 1) {UCL.rebuild()};">\ <menupopup id="usercssloader-menupopup">\ <menu label="Style Loader Menü"\ accesskey="M">\ <menupopup id="usercssloader-submenupopup">\ <menuitem label="Styles importieren"\ accesskey="R"\ acceltext="Alt + R"\ oncommand="UCL.rebuild();" />\ <menuseparator />\ <menuitem label="CSS Datei erstellen"\ accesskey="D"\ oncommand="UCL.create();" />\ <menuitem label="CSS Ordner öffnen"\ accesskey="O"\ oncommand="UCL.openFolder();" />\ <menuitem label="userChrome.css bearbeiten"\ hidden="true"\ oncommand="UCL.editUserCSS(\'userChrome.css\')" />\ <menuitem label="userContent.css bearbeiten"\ hidden="true"\ oncommand="UCL.editUserCSS(\'userContent.css\')" />\ <menuseparator />\ <menuitem label="Style Test (Chrome)"\ id="usercssloader-test-chrome"\ accesskey="C"\ oncommand="UCL.styleTest(window);" />\ <menuitem label="Style Test (Web)"\ id="usercssloader-test-content"\ accesskey="W"\ oncommand="UCL.styleTest();" />\ <menuitem label="Styles dieser Seite auf userstyles.org finden"\ accesskey="S"\ oncommand="UCL.searchStyle();" />\ </menupopup>\ </menu>\ <menu label=".uc.css" accesskey="U" hidden="+ !UCL.USE_UC +">\ <menupopup id="usercssloader-ucmenupopup">\ <menuitem label="Importieren(.uc.js)"\ oncommand="UCL.UCrebuild();" />\ <menuseparator id="usercssloader-ucsepalator"/>\ </menupopup>\ </menu>\ <menuseparator id="ucl-sepalator"/>\ </menupopup>\ '; xml = xml + xmlEnd; var range = document.createRange(); range.selectNodeContents($(UCL.showWhere)); range.collapse(false); range.insertNode(range.createContextualFragment(xml.replace(/\n|\t/g, ''))); range.detach(); $("mainKeyset").appendChild($C("key", { id: "usercssloader-rebuild-key", oncommand: "UCL.rebuild();", key: "R", modifiers: "alt", })); this.rebuild(); this.initialized = true; if (UCL.USE_UC) { setTimeout(function() { UCL.UCcreateMenuitem(); }, 1000); } window.addEventListener("unload", this, false); }, uninit: function() { var dis = [x for(x in this.readCSS) if (!this.readCSS[x].enabled)]; var str = Cc["@mozilla.org/supports-string;1"].createInstance(Ci.nsISupportsString); str.data = dis.join("|"); this.prefs.setComplexValue("disabled_list", Ci.nsISupportsString, str); window.removeEventListener("unload", this, false); }, destroy: function() { var i = document.getElementById("usercssloader-menu"); if (i) i.parentNode.removeChild(i); var i = document.getElementById("usercssloader-rebuild-key"); if (i) i.parentNode.removeChild(i); this.uninit(); }, handleEvent: function(event) { switch(event.type){ case "unload": this.uninit(); break; } }, rebuild: function() { let ext = /\.css$/i; let not = /\.uc\.css/i; let files = this.FOLDER.directoryEntries.QueryInterface(Ci.nsISimpleEnumerator); while (files.hasMoreElements()) { let file = files.getNext().QueryInterface(Ci.nsIFile); if (!ext.test(file.leafName) || not.test(file.leafName)) continue; let CSS = this.loadCSS(file); CSS.flag = true; } for (let [leafName, CSS] in Iterator(this.readCSS)) { if (!CSS.flag) { CSS.enabled = false; delete this.readCSS[leafName]; } delete CSS.flag; this.rebuildMenu(leafName); } if (this.initialized) XULMessengerWindow.statusTextField.label = "Styles importieren"; }, loadCSS: function(aFile) { var CSS = this.readCSS[aFile.leafName]; if (!CSS) { CSS = this.readCSS[aFile.leafName] = new CSSEntry(aFile); if (this.disabled_list.indexOf(CSS.leafName) === -1) { CSS.enabled = true; } } else if (CSS.enabled) { CSS.enabled = true; } return CSS; }, rebuildMenu: function(aLeafName) { var CSS = this.readCSS[aLeafName]; var menuitem = document.getElementById("usercssloader-" + aLeafName); if (!CSS) { if (menuitem) menuitem.parentNode.removeChild(menuitem); return; } if (!menuitem) { menuitem = document.createElement("menuitem"); menuitem.setAttribute("label", aLeafName); menuitem.setAttribute("id", "usercssloader-" + aLeafName); menuitem.setAttribute("class", "usercssloader-item " + (CSS.SHEET == this.AGENT_SHEET? "AGENT_SHEET" : "USER_SHEET")); menuitem.setAttribute("type", "checkbox"); menuitem.setAttribute("autocheck", "false"); menuitem.setAttribute("oncommand", "UCL.toggle('"+ aLeafName +"');"); menuitem.setAttribute("onclick", "UCL.itemClick(event);"); document.getElementById("usercssloader-menupopup").appendChild(menuitem); } menuitem.setAttribute("checked", CSS.enabled); }, toggle: function(aLeafName) { var CSS = this.readCSS[aLeafName]; if (!CSS) return; CSS.enabled = !CSS.enabled; this.rebuildMenu(aLeafName); }, itemClick: function(event) { if (event.button == 0) return; event.preventDefault(); event.stopPropagation(); let label = event.currentTarget.getAttribute("label"); if (event.button == 1) { this.toggle(label); } // Kopieren des Pfades einer CSS-Datei in die Zwischenablage mit Strg + rechte Maustaste else if (event.ctrlKey && event.button == 2) { var clipboard = Cc['@mozilla.org/widget/clipboardhelper;1'].getService(Ci.nsIClipboardHelper); clipboard.copyString(this.getFileFromLeafName(label).path); } // Automatische Aktualisierung der Menüliste nach Verschieben einer CSS Datei in den TEMP Ordner mit "rechte Maustatste + Alt" else if (event.altKey && event.button == 2){ this.moveFile(this.getFileFromLeafName(label).path); if (this.AUTO_REBUILD) this.rebuild(); } else if (!event.ctrlKey && !event.altKey && event.button == 2){ closeMenus(event.target); this.edit(this.getFileFromLeafName(label)); } }, getFileFromLeafName: function(aLeafName) { let f = this.FOLDER.clone(); f.QueryInterface(Ci.nsILocalFile); // use appendRelativePath f.appendRelativePath(aLeafName); return f; }, styleTest: function(aWindow) { aWindow || (aWindow = this.getFocusedWindow()); new CSSTester(aWindow, function(tester){ if (tester.saved) UCL.rebuild(); }); }, searchStyle: function() { let win = this.getFocusedWindow(); let word = win.location.host || win.location.href; // openLinkIn("http://userstyles.org/styles/browse/site/" + word, "tab", {}); openLinkIn("http://userstyles.org/styles/browse_r?search_terms=" + word, "tab", {}); }, openFolder: function() { if (this.vFileManager.length != 0) { var file = Cc['@mozilla.org/file/local;1'].createInstance(Ci.nsILocalFile); var process = Cc['@mozilla.org/process/util;1'].createInstance(Ci.nsIProcess); var args=[this.FOLDER.path]; file.initWithPath(this.vFileManager); process.init(file); // Verzeichnis mit anderem Dateimanager oeffnen process.run(false, args, args.length); } else { // Verzeichnis mit Dateimanager des Systems oeffnen this.FOLDER.launch(); } }, // Verschieben einer CSS Datei in den TEMP Ordner moveFile: function(aFile){ var file = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile); var destDir = Services.dirsvc.get("Trsh", Ci.nsILocalFile); file.initWithPath(aFile); file.moveTo(destDir, ""); }, editUserCSS: function(aLeafName) { let file = Services.dirsvc.get("UChrm", Ci.nsILocalFile); file.appendRelativePath(aLeafName); this.edit(file); }, edit: function(aFile) { var editor = Services.prefs.getCharPref("view_source.editor.path"); if (!editor) return alert("Unter about:config den vorhandenen Schalter:\n view_source.editor.path mit dem Editorpfad ergänzen"); try { var UI = Cc["@mozilla.org/intl/scriptableunicodeconverter"].createInstance(Ci.nsIScriptableUnicodeConverter); UI.charset = window.navigator.platform.toLowerCase().indexOf("win") >= 0? "Shift_JIS": "UTF-8"; var path = UI.ConvertFromUnicode(aFile.path); var app = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile); app.initWithPath(editor); var process = Cc["@mozilla.org/process/util;1"].createInstance(Ci.nsIProcess); process.init(app); process.run(false, [path], 1); } catch (e) {} }, create: function(aLeafName) { if (!aLeafName) aLeafName = prompt("Name des Styles", new Date().toLocaleFormat("Neuer Style")); if (aLeafName) aLeafName = aLeafName.replace(/\s+/g, " ").replace(/[\\/:*?\"<>|]/g, ""); if (!aLeafName || !/\S/.test(aLeafName)) return; if (!/\.css$/.test(aLeafName)) aLeafName += ".css"; let file = this.getFileFromLeafName(aLeafName); this.edit(file); }, UCrebuild: function() { let re = /^file:.*\.uc\.css(?:\?\d+)?$/i; let query = "?" + new Date().getTime(); Array.slice(document.styleSheets).forEach(function(css){ if (!re.test(css.href)) return; if (css.ownerNode) { css.ownerNode.parentNode.removeChild(css.ownerNode); } let pi = document.createProcessingInstruction('xml-stylesheet','type="text/css" href="'+ css.href.replace(/\?.*/, '') + query +'"'); document.insertBefore(pi, document.documentElement); }); UCL.UCcreateMenuitem(); }, UCcreateMenuitem: function() { let sep = $("usercssloader-ucsepalator"); let popup = sep.parentNode; if (sep.nextSibling) { let range = document.createRange(); range.setStartAfter(sep); range.setEndAfter(popup.lastChild); range.deleteContents(); range.detach(); } let re = /^file:.*\.uc\.css(?:\?\d+)?$/i; Array.slice(document.styleSheets).forEach(function(css) { if (!re.test(css.href)) return; let fileURL = decodeURIComponent(css.href).split("?")[0]; let aLeafName = fileURL.split("/").pop(); let m = document.createElement("menuitem"); m.setAttribute("label", aLeafName); m.setAttribute("tooltiptext", fileURL); m.setAttribute("id", "usercssloader-" + aLeafName); m.setAttribute("type", "checkbox"); m.setAttribute("autocheck", "false"); m.setAttribute("checked", "true"); m.setAttribute("oncommand", "this.setAttribute('checked', !(this.css.disabled = !this.css.disabled));"); m.setAttribute("onclick", "UCL.UCItemClick(event);"); m.css = css; popup.appendChild(m); }); }, UCItemClick: function(event) { if (event.button == 0) return; event.preventDefault(); event.stopPropagation(); if (event.button == 1) { event.target.doCommand(); } else if (event.button == 2) { closeMenus(event.target); let fileURL = event.currentTarget.getAttribute("tooltiptext"); let file = Services.io.getProtocolHandler("file").QueryInterface(Ci.nsIFileProtocolHandler).getFileFromURLSpec(fileURL); this.edit(file); } }, }; function CSSEntry(aFile) { this.path = aFile.path; this.leafName = aFile.leafName; this.lastModifiedTime = 1; this.SHEET = /^xul-|\.as\.css$/i.test(this.leafName) ? Ci.nsIStyleSheetService.AGENT_SHEET: Ci.nsIStyleSheetService.USER_SHEET; } CSSEntry.prototype = { sss: Cc["@mozilla.org/content/style-sheet-service;1"].getService(Ci.nsIStyleSheetService), _enabled: false, get enabled() { return this._enabled; }, set enabled(isEnable) { var aFile = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile) aFile.initWithPath(this.path); var isExists = aFile.exists(); // ファイルが存在したら true var lastModifiedTime = isExists ? aFile.lastModifiedTime : 0; var isForced = this.lastModifiedTime != lastModifiedTime; // ファイルに変更があれば true var fileURL = Services.io.getProtocolHandler("file").QueryInterface(Ci.nsIFileProtocolHandler).getURLSpecFromFile(aFile); var uri = Services.io.newURI(fileURL, null, null); if (this.sss.sheetRegistered(uri, this.SHEET)) { // すでにこのファイルが読み込まれている場合 if (!isEnable || !isExists) { this.sss.unregisterSheet(uri, this.SHEET); } else if (isForced) { // 解除後に登録し直す this.sss.unregisterSheet(uri, this.SHEET); this.sss.loadAndRegisterSheet(uri, this.SHEET); } } else { // このファイルは読み込まれていない if (isEnable && isExists) { this.sss.loadAndRegisterSheet(uri, this.SHEET); } } if (this.lastModifiedTime !== 1 && isEnable && isForced) { log(this.leafName + " の更新を確認しました。"); } this.lastModifiedTime = lastModifiedTime; return this._enabled = isEnable; }, }; function CSSTester(aWindow, aCallback) { this.win = aWindow || window; this.doc = this.win.document; this.callback = aCallback; this.init(); } CSSTester.prototype = { sss: Cc["@mozilla.org/content/style-sheet-service;1"].getService(Ci.nsIStyleSheetService), preview_code: "", saved: false, init: function() { this.dialog = openDialog( "data:text/html;charset=utf8,"+encodeURIComponent('<!DOCTYPE HTML><html lang="de"><head><title>CSSTester</title></head><body></body></html>'), "", "width=550,height=400,dialog=no"); this.dialog.addEventListener("load", this, false); }, destroy: function() { this.preview_end(); this.dialog.removeEventListener("unload", this, false); this.previewButton.removeEventListener("click", this, false); this.saveButton.removeEventListener("click", this, false); this.closeButton.removeEventListener("click", this, false); }, handleEvent: function(event) { switch(event.type) { case "click": if (event.button != 0) return; if (this.previewButton == event.currentTarget) { this.preview(); } else if (this.saveButton == event.currentTarget) { this.save(); } else if (this.closeButton == event.currentTarget) { this.dialog.close(); } break; case "load": var doc = this.dialog.document; doc.body.innerHTML = '\ <style type="text/css">\ :not(input):not(select) { padding: 0px; margin: 0px; }\ table { border-spacing: 0px; }\ body, html, #main, #textarea { width: 100%; height: 100%; }\ #textarea { font-family: monospace; }\ </style>\ <table id="main">\ <tr height="100%">\ <td colspan="4"><textarea id="textarea"></textarea></td>\ </tr>\ <tr height="40">\ <td><input type="button" value="Vorschau" id="Vorschau"/></td>\ <td><input type="button" value="Speichern" id="Speichern"/></td>\ <td width="80%"><span class="log"></td>\ <td><input type="button" value="Schließen" id="Schliessen"/></td>\ </tr>\ </table>\ '; this.textbox = doc.querySelector("textarea"); this.previewButton = doc.querySelector('input[value="Vorschau"]'); this.saveButton = doc.querySelector('input[value="Speichern"]'); this.closeButton = doc.querySelector('input[value="Schließen"]'); this.logField = doc.querySelector('.log'); var code = "@namespace url(" + this.doc.documentElement.namespaceURI + ");\n"; code += this.win.location.protocol.indexOf("http") === 0? "@-moz-document domain(" + this.win.location.host + ") {\n\n\n\n}": "@-moz-document url(" + this.win.location.href + ") {\n\n\n\n}"; this.textbox.value = code; this.dialog.addEventListener("unload", this, false); this.previewButton.addEventListener("click", this, false); this.saveButton.addEventListener("click", this, false); this.closeButton.addEventListener("click", this, false); this.textbox.focus(); let p = this.textbox.value.length - 3; this.textbox.setSelectionRange(p, p); break; case "unload": this.destroy(); this.callback(this); break; } }, preview: function() { var code = this.textbox.value; if (!code || !/\:/.test(code)) return; code = "data:text/css;charset=utf-8," + encodeURIComponent(this.textbox.value); if (code == this.preview_code) return; this.preview_end(); var uri = Services.io.newURI(code, null, null); this.sss.loadAndRegisterSheet(uri, Ci.nsIStyleSheetService.AGENT_SHEET); this.preview_code = code; this.log("Vorschau"); }, preview_end: function() { if (this.preview_code) { let uri = Services.io.newURI(this.preview_code, null, null); this.sss.unregisterSheet(uri, Ci.nsIStyleSheetService.AGENT_SHEET); this.preview_code = ""; } }, save: function() { var data = this.textbox.value; if (!data) return; var fp = Cc["@mozilla.org/filepicker;1"].createInstance(Ci.nsIFilePicker); fp.init(window, "", Ci.nsIFilePicker.modeSave); fp.appendFilter("CSS Files","*.css"); fp.defaultExtension = "css"; if (window.UCL) fp.displayDirectory = UCL.FOLDER; var res = fp.show(); if (res != fp.returnOK && res != fp.returnReplace) return; var suConverter = Cc["@mozilla.org/intl/scriptableunicodeconverter"].createInstance(Ci.nsIScriptableUnicodeConverter); suConverter.charset = "UTF-8"; data = suConverter.ConvertFromUnicode(data); var foStream = Cc["@mozilla.org/network/file-output-stream;1"].createInstance(Ci.nsIFileOutputStream); foStream.init(fp.file, 0x02 | 0x08 | 0x20, 0664, 0); foStream.write(data, data.length); foStream.close(); this.saved = true; }, log: function() { this.logField.textContent = new Date().toLocaleFormat("%H:%M:%S") + ": " + $A(arguments); } }; UCL.init(); function $(id) { return document.getElementById(id); } function $A(arr) Array.slice(arr); function $C(name, attr) { var el = document.createElement(name); if (attr) Object.keys(attr).forEach(function(n) el.setAttribute(n, attr[n])); return el; } function log() { Application.console.log(Array.slice(arguments)); } })();Es wird in Thunderbird angezeigt, die CSS Codes funktionieren auch, aber
nach einem Neustart von Thunderbird werden die Codes nicht automatisch geladen.
manuelles importieren funktioniert. Aus den Script Menü heraus funktioniert das bearbeiten-
bzw. öffnen der Codes in einem Editor auch nicht. Es tut sich einfach nichts.
Ich fürchte ja, das ist zu kompliziert um es für Thunderbird richtig zum laufen zu bringen.Mfg.
Endor