1. Nachrichten
  2. Forum
    1. Unerledigte Themen
    2. Forenregeln
  3. Spenden
  • Anmelden
  • Registrieren
  • Suche
Alles
  • Alles
  • Artikel
  • Seiten
  • Forum
  • Erweiterte Suche
  1. camp-firefox.de
  2. Boersenfeger

Beiträge von Boersenfeger

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 18. Januar 2025 um 17:24
    Zitat von BrokenHeart

    Werde aber, wenn überhaupt, erst weitermachen, wenn mir Boersenfeger auf meine Frage antwortet. :(

    Hi, wie in #390 geschrieben, ist das Script, das ich zur Diskussion gestellt hatte, nicht das, was mir Pein bereitete, sondern Firefox_ToolBarButtons.uc.js, das ich nach Hinweis von 2002Andreas aktualisiert habe und in #392 bestätigte, dass nun mein Begehr erfüllt sei.

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 17. Januar 2025 um 18:37

    Hi siehe #390... es war eine falsche Fährte..

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 17. Januar 2025 um 16:22

    Danke, die und andere Seiten von Endor habe ich natürlich abgespeichert, allerdings war ich auf der falschen Fährte. Jetzt ist dies aber aktualisiert und es klappt auch wieder, wenn man sich aus dem Anpassen-Fenster den Button herauszieht. ;)

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 17. Januar 2025 um 15:59

    Das war eine falsche Fährte von mir. Der Eintrag, der nicht mehr funktioniert, ist in diesem Script inkludiert:

    Code
    // ==UserScript==
    // @name    Firefox_ToolBarButtons.uc.js
    // @charset UTF-8
    // Date	    2019‎/06/12 Firefox Nightly 69.0a1 document.createXULElement('toolbarbutton'); → aDocument.createXULElement('toolbarbutton'); 書き換えました。
    // Date	    2019‎/05/26 Firefox Nightly 69.0a1 createElement → createXULElement 書き換えました。
    // Date	    2019‎/02/25 ページ情報ボタンの2つあるidを同じidにするのを忘れていたので修正しました。
    // Date	    2019‎/02/20 タブ移動ボタンをホイールスクロールで左右のタブにフォーカスを移動(タブ切替え?)するようにしました。ズームコントロールボタンをホイールスクロールで拡大縮小するようにしました。開発ツールボタンとCookieとサイトデータを管理ボタンを追加しました。他いろいろ変更しました。
    // Date	    2019‎/02/04 クッキー表示 は 開発ツールを表示するようにしてみた
    // Date	    2019‎/02/02 idの重複修正 クッキー表示の修正
    // Date	    2018‎/07/10 ボタンを追加+いろいろ変更しました。
    // Date	    2018‎/05/03 アクティブタブを移動するボタンを追加しました。cssの多段タブでのタブ移動に便利? ショートカットキー(Ctrl+Shift+PageUp/PageDown)でタブ移動出来たりするので使うかはお好みで。
    // Date	    2018‎/04/04 拡大縮小ボタンを追加しました。
    // Date	    2018‎/02/05 GitHubのEndor8さんの所でボタンを増やしてくれていたのでそのまま日本語化だけしました。
    // Date     2018/01/16 2017/11/09版と同じようにボタンを一つにまとめ直しました。初期導入時、再起動するボタンのみツールバーに表示するようにしてみました。
    // Date     2017/11/23 ブックマーク、履歴、同期タブのサイドバーを開閉するボタンを追加して、個別に導入できるようにバラバラにしてみました。
    // Date     2017/11/09 RestartFirefoxButton_Movable.uc.js をベースに、再起動+ about:config、プロファイルフォルダ、クッキーマネージャのボタンをセットにしてみました。
    // @note    
    // @note    初期導入時、再起動するボタンのみツールバーに表示するようにしました。
    // @note    その他のボタンは、ツールバーのカスタマイズ内に格納されていると思います。
    // @note    カスタマイズから追加したいボタンを好きなところに出して使ってください。
    // @note	
    // @note    label と tooltiptext が環境によっては、文字化けするので、 Unicode に変換してます。
    // @note	
    // @note    再起動
    // @note    about:config
    // @note    新しいタブ
    // @note    プロファイルフォルダ
    // @note    クッキー (Firefox60ESR)
    // @note    ブックマーク サイドバー
    // @note    履歴 サイドバー
    // @note    同期タブ サイドバー
    // @note    ブラウジングライブラリー「ダウンロード」
    // @note    タブを更新(保存されているキャッシュを無視して更新)
    // @note    オプション
    // @note    プラグインについて
    // @note    ブラウジングライブラリー「ブックマーク」
    // @note    Chromeフォルダ
    // @note    ページ情報
    // @note    証明書マネージャー
    // @note    保存されたログイン情報
    // @note    履歴を削除
    // @note    拡大 (Ctrl++)
    // @note    縮小 (Ctrl+-)
    // @note    タブ移動(左:左にタブを移動|右:右にタブを移動|ホイール↑:左のタブに移動|ホイール↓:右のタブに移動)
    // @note    ズームコントロール (左 or ホイール↑: 拡大|中: リセット|右 or ホイール↓: 縮小)
    // @note    開発ツール
    // @note    Cookieとサイトデータを管理(一度Firefoxのオプションを開かないとCookieやサイトデータが表示されないようです。)
    // @note    カスタムボタン (左 or ホイール↑↓:新しいタブ | 中:about:config | 右:Chromeフォルダ)
    // @note    
    // @note    Firefox Nightly 69.0a1で動作確認しました。
    // @note    http://wiki.nothing.sh/page?userChrome.js%CD%D1%A5%B9%A5%AF%A5%EA%A5%D7%A5%C8#m5c944e2
    // @note    ↑ここの「サンドボックスが有効になった62以降でもuserChrome.js用スクリプトを利用する方法」を導入して確認しています。
    // @note
    // @note    Firefox60ESRなどでabout:系を使いたい場合 openTrustedLinkIn ⇒ openUILinkIn に変更してください。
    // @note
    // @note    Firefox61以降クッキーマネージャ?がCookieとサイトデータに変わり廃止されたのでクッキーマネージャ?を開くボタンが使え無くなります。
    // @note
    // @note    Firefox68以下でこのスクリプトを使いたい場合 aDocument.createXULElement ⇒ document.createElement に変更してください。
    // ==/UserScript==
    
    (function() {
        ChromeUtils.importESModule("resource:///modules/CustomizableUI.sys.mjs");
    
    	try {
    //		Firefox neustarten
    		CustomizableUI.createWidget({
    			id: 'restart-ToolBarButton',
    			type: 'custom',
    			defaultArea: CustomizableUI.AREA_NAVBAR,
    			onBuild: function(aDocument) {			
    				let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
    					id: 'restart-ToolBarButton',
    					class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    					label: 'Neustart',
    					tooltiptext: 'Linksklick: Firefox Neustart | Mittelklick: Firefox Neustart + Löschen des Skriptcaches',
    					style: 'list-style-image: url(%2F9hAAAACXBIWXMAAAsTAAALEwEAmpwYAAAKT2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtvUhUIIFJCi4AUkSYqIQkQSoghodkVUcERRUUEG8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89%2BbN%2FrXXPues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEKJHAAEAizZCFz%2FSMBAPh%2BPDwrIsAHvgABeNMLCADATZvAMByH%2Fw%2FqQplcAYCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZTAKAEAGDLY2LjAFAtAGAnf%2BbTAICd%2BJl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3AMDOEAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ5RYFbCC1xB1dXLh4ozkkXKxQ2YQJhmkAuwnmZGTKBNA%2Fg88wAAKCRFRHgg%2FP9eM4Ors7ONo62Dl8t6r8G%2FyJiYuP%2B5c%2BrcEAAAOF0ftH%2BLC%2BzGoA7BoBt%2FqIl7gRoXgugdfeLZrIPQLUAoOnaV%2FNw%2BH48PEWhkLnZ2eXk5NhKxEJbYcpXff5nwl%2FAV%2F1s%2BX48%2FPf14L7iJIEyXYFHBPjgwsz0TKUcz5IJhGLc5o9H%2FLcL%2F%2Fwd0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s%2BwM%2B3zUAsGo%2BAXuRLahdYwP2SycQWHTA4vcAAPK7b8HUKAgDgGiD4c93%2F%2B8%2F%2FUegJQCAZkmScQAAXkQkLlTKsz%2FHCAAARKCBKrBBG%2FTBGCzABhzBBdzBC%2FxgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD%2FphCJ7BKLyBCQRByAgTYSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5h1xGupE7yAAygvyGvEcxlIGyUT3UDLVDuag3GoRGogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8%2BQ8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8%2BxdwQSgUXACTYEd0IgYR5BSFhMWE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR%2BcQYYjIxh1hILCPWEo8TLxB7iEPENyQSiUMyJ7mQAkmxpFTSEtJG0m5SI%2BksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG%2BQh8lsKnWJAcaT4U%2BIoUspqShnlEOU05QZlmDJBVaOaUt2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdpr%2Bh0uhHdlR5Ol9BX0svpR%2BiX6AP0dwwNhhWDx4hnKBmbGAcYZxl3GK%2BYTKYZ04sZx1QwNzHrmOeZD5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI%2BpXlN9rkZVM1PjqQnUlqtVqp1Q61MbU2epO6iHqmeob1Q%2FpH5Z%2FYkGWcNMw09DpFGgsV%2FjvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY%2FR27iz2qqaE5QzNKM1ezUvOUZj8H45hx%2BJx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllirSKtRq0frvTau7aedpr1Fu1n7gQ5Bx0onXCdHZ4%2FOBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79up%2B6Ynr5egJ5Mb6feeb3n%2Bhx9L%2F1U%2FW36p%2FVHDFgGswwkBtsMzhg8xTVxbzwdL8fb8VFDXcNAQ6VhlWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TDtMx83MzaLN1pk1mz0x1zLnm%2Beb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lOk06rntZnw7Dxtsm2qbcZsOXYBtuutm22fWFnYhdnt8Wuw%2B6TvZN9un2N%2FT0HDYfZDqsdWh1%2Bc7RyFDpWOt6azpzuP33F9JbpL2dYzxDP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc%2BLpsbxt3IveRKdPVxXeF60vWdm7Obwu2o26%2FuNu5p7ofcn8w0nymeWTNz0MPIQ%2BBR5dE%2FC5%2BVMGvfrH5PQ0%2BBZ7XnIy9jL5FXrdewt6V3qvdh7xc%2B9j5yn%2BM%2B4zw33jLeWV%2FMN8C3yLfLT8Nvnl%2BF30N%2FI%2F9k%2F3r%2F0QCngCUBZwOJgUGBWwL7%2BHp8Ib%2BOPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQrSH355jOkc5pDoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo%2Bqi5qPNo3ujS6P8YuZlnM1VidWElsSxw5LiquNm5svt%2F87fOH4p3iC%2BN7F5gvyF1weaHOwvSFpxapLhIsOpZATIhOOJTwQRAqqBaMJfITdyWOCnnCHcJnIi%2FRNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5hCepkLxMDUzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z%2Bpn5mZ2y6xlhbL%2BxW6Lty8elQfJa7OQrAVZLQq2QqboVFoo1yoHsmdlV2a%2FzYnKOZarnivN7cyzytuQN5zvn%2F%2FtEsIS4ZK2pYZLVy0dWOa9rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQFr6wtVCuWFfevc1%2B1dT1gvWd%2B1YfqGnRs%2BFYmKrhTbF5cVf9go3HjlG4dvyr%2BZ3JS0qavEuWTPZtJm6ebeLZ5bDpaql%2BaXDm4N2dq0Dd9WtO319kXbL5fNKNu7g7ZDuaO%2FPLi8ZafJzs07P1SkVPRU%2BlQ27tLdtWHX%2BG7R7ht7vPY07NXbW7z3%2FT7JvttVAVVN1WbVZftJ%2B7P3P66Jqun4lvttXa1ObXHtxwPSA%2F0HIw6217nU1R3SPVRSj9Yr60cOxx%2B%2B%2Fp3vdy0NNg1VjZzG4iNwRHnk6fcJ3%2FceDTradox7rOEH0x92HWcdL2pCmvKaRptTmvtbYlu6T8w%2B0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO32oPb%2B%2B6EHTh0kX%2Fi%2Bc7vDvOXPK4dPKy2%2BUTV7hXmq86X23qdOo8%2FpPTT8e7nLuarrlca7nuer21e2b36RueN87d9L158Rb%2F1tWeOT3dvfN6b%2FfF9%2FXfFt1%2Bcif9zsu72Xcn7q28T7xf9EDtQdlD3YfVP1v%2B3Njv3H9qwHeg89HcR%2FcGhYPP%2FpH1jw9DBY%2BZj8uGDYbrnjg%2BOTniP3L96fynQ89kzyaeF%2F6i%2FsuuFxYvfvjV69fO0ZjRoZfyl5O%2FbXyl%2FerA6xmv28bCxh6%2ByXgzMV70VvvtwXfcdx3vo98PT%2BR8IH8o%2F2j5sfVT0Kf7kxmTk%2F8EA5jz%2FGMzLdsAAAAEZ0FNQQAAsY58%2B1GTAAAAIGNIUk0AAHolAACAgwAA%2Bf8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAN8SURBVHjaVJFNTBxlAIafb2Z29gd2l4VdYCkokAUt1AJplQRTrVqjUWMPPWHSCzb21IOn9qIHY2xMahoTTb00NmkUm5qAjdpUI61VaCxCpCVYixt%2ByvKzCwu7LDs7zMw3HmhM%2Bt6fJ0%2FyCp69wiOzZBCPcqSmIXg0HPHuC4R8nkLWyOXyYiIzfuVHzMIA%2BZsLtH18EApntUdhpzUSD5577nDLi%2FGWKjx%2BHVfR8HpFwNwsxTMzza%2BOXJ1%2B58Ev2sVEV%2ByEawXqxf8FllNWEQ9ePXzsqQOecIDU8jampSAVD76Al2BIIx4Dv2Nz7%2FYq%2B5%2BP8sNXE6WdAhdQlOM9rzUdaGiN8M9UjnKvQjzuA0UjV3AxDIcHywqRoEbXoVrKgyBtKXYEUvprmiN9oaoyvr9wl62NHJbtJeDzOo17YmprVzWOppLO2RRNwf1FSOzSUAXsCIR4QdP13UPfjhUde2mjuBXUjcXNEabOnJmq7Y4Nd7z1fu%2BJ%2FR2Jpgrm0jauAI8GlnSlBi4I0bO6sLBWHc9esxRdmjOZf5n%2B5CLWzCzOvsbKupBZ1xgmElUoC%2BgoKtRGQfNomoaND8P8XS%2Bby1olO7O6GHTl1DejGDOrNB%2BvpO7I%2Ba31%2FDP9Z28YUmqoqhCKcG2EYD6ZMUTojZ8WHmsqD%2BI6wnWFajugCkuuZaV%2FZS47wp99R7E3LbxPV6rtr7dV1pmyuBWs3hr7dZ380LC2tzseffvUHm86C1JC2A%2FrGcn509cn%2BPvTk9ibc1R06qL91Ms1CadF000ll9rVS2VykLzVr0lHOgtpuJ9yUFyXxqhKZjbH2nJRI9IZwyw2kXjvXV%2FIOWgaBcc2a%2BtjdVXR1J3iBDx8QUpQUJAuJJclseogxz441H5vrPO72cm0VSyVPJq27ZaHm8ST3Y0M9d9Kkr19A1A1x4VIObTGBfNrsJ5XmE9b6KqgvrOGhr1Vns2sgeNIkXiigvHf1liZuHWZYjINSEXRVLewZjN6bYmYbvN4rcDvVzFKLnOpErMLBpvbklClznyyyPDA6DjTX3wJWICr%2Bnb3ffjXSGpl5Nxnn88uh2ORUCBaHfVQU%2BsjVuGhKqJT5lFYShr8fGH4j42bH53EnJ4EtgEEPQOTzHx9mqXLl9AT9TS82RvreOmVcMTXVh4JhIr5kp3LFu6u3Lk%2ByMylQazU3ENYAvw3AFUTimFqj5i7AAAAAElFTkSuQmCC)',
    					onclick: 'if (event.button == 0) { \
                                      Services.startup.quit(Ci.nsIAppStartup.eRestart | Ci.nsIAppStartup.eAttemptQuit); \
                                  }; \
                                  if (event.button == 1) { \
                                      Services.appinfo.invalidateCachesOnRestart(); \
                                      Services.startup.quit(Ci.nsIAppStartup.eRestart | Ci.nsIAppStartup.eAttemptQuit); \
                                  };'
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});
    //		about:config öffnen
    		CustomizableUI.createWidget({
    			id: 'aboutconfig-ToolBarButton',
    			type: 'custom',
    			onBuild: function(aDocument) {			
    				let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
    					id: 'aboutconfig-ToolBarButton',
    					class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    					label: 'About:Config',
    					tooltiptext: 'About:Config öffnen',
    					style: 'list-style-image: url()',
    					onclick: 'if (event.button == 0) { \
    										openTrustedLinkIn("about:config", "tab");\
    								 }; '
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});
    //		Neuen Tab öffnen
    		CustomizableUI.createWidget({
    			id: 'newtab-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
    					id: 'newtab-ToolBarButton',
    					class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    					label: 'Neuer Tab',
    					tooltiptext: '\Neuen Tab öffnen',
    					style: 'list-style-image: url()',
    					onclick: 'if (event.button == 0) { \
                                      openTrustedLinkIn("about:newtab", "tabshifted");/*BrowserOpenTab(event);*/ \
    								 }; '
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});
    //		Profilordner öffnen
    		CustomizableUI.createWidget({
    			id: 'profilefolder-ToolBarButton',
    			type: 'custom',
    			onBuild: function(aDocument) {			
    				let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
    					id: 'profilefolder-ToolBarButton',
    					class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    					label: 'Profilordner',
    					tooltiptext: 'Profilordner öffnen',
    					style: 'list-style-image: url()',
    					onclick: 'if (event.button == 0) { \
                                      Services.dirsvc.get("ProfD", Ci.nsIFile).launch(); \
                                  }; '
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});
    //		Cookies anzeigen
    		CustomizableUI.createWidget({
    			id: 'showCookies-ToolBarButton',
    			type: 'custom',
    			onBuild: function(aDocument) {			
    				let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
    					id: 'showCookies-ToolBarButton',
    					class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    					label: 'Cookies',
    					tooltiptext: 'Cookies anzeigen',
    					style: 'list-style-image: url()',
    					onclick: 'if (event.button == 0) { \
                                         window.open("chrome://browser/content/preferences/cookies.xhtm","cookie","chrome,dialog,centerscreen,dependent"); \
                                      }; '
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});	
    //		Lesezeichen-Seitenleiste Öffnen/Schließen
    		CustomizableUI.createWidget({
    			id: 'BookmarksSidebar-ToolBarButton',
    			type: 'custom',
    			defaultArea: CustomizableUI.AREAS,
    			onBuild: function(aDocument) {			
    			    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
    					id: 'BookmarksSidebar-ToolBarButton',
    					class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    					label: 'Lesezeichen-Sidebar',
    					tooltiptext: 'Lesezeichen-Sidebar öffnen/schließen',
    					style: 'list-style-image: url()',
    					onclick: 'if (event.button == 0) { \
    									SidebarUI.toggle("viewBookmarksSidebar"); \
    								 }; '
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});
    //		Chronik-Seitenleiste Öffnen/Schließen
    		CustomizableUI.createWidget({
    			id: 'HistorySidebar-ToolBarButton',
    			type: 'custom',
    			onBuild: function(aDocument) {			
    				let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
    					id: 'HistorySidebar-ToolBarButton',
    					class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    					label: 'Chronik-Sidebar',
    					tooltiptext: 'Chronik-Sidebar öffnen/schließen',
    					style: 'list-style-image: url()',
    					onclick: 'if (event.button == 0) { \
    									SidebarUI.toggle("viewHistorySidebar"); \
    								 }; '
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});
    //		Tabs-Seitenleiste Öffnen/Schließen
    		CustomizableUI.createWidget({
    			id: 'viewTabsSidebar-ToolBarButton',
    			type: 'custom',
    			onBuild: function(aDocument) {			
    				let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
    					id: 'viewTabsSidebar-ToolBarButton',
    					class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    					label: 'Tabs-Sidebar',
    					tooltiptext: 'Tabs-Sidebar öffnen/schließen',
    					style: 'list-style-image: url()',
    					onclick: 'if (event.button == 0) { \
    									SidebarUI.toggle("viewTabsSidebar"); \
    								 }; '
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});
    //      Weitere Schaltflächen
    //      DownloadsFenster öffnen
                 CustomizableUI.createWidget({
                 id: 'Download-button',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'Download-button',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Downloads',
    				   accesskey: 'D',
                       tooltiptext: 'Download Fenster öffnen',
                       style: 'list-style-image: url()',
                       oncommand: "DownloadsPanel.showDownloadsHistory();"
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});
    //      Lesezeichenmanager öffnen	
    		     CustomizableUI.createWidget({
                 id: 'bookmarks-manager-button',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'bookmarks-manager-button',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       label: 'Lesezeichen Manager',
                       tooltiptext: 'Lesezeichen Manager öffnen',
                       style: 'list-style-image: url()',
                       oncommand: "PlacesCommandHook.showPlacesOrganizer('AllBookmarks');"
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
            });		
    		
    //      Tabs neuladen ohne Cache
                 CustomizableUI.createWidget({
                 id: 'reload-skip-cache-button',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'reload-skip-cache-button',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Tab neu laden',
                       tooltiptext: 'Tab neu laden, ohne den Browsercache zu benutzen',
                       style: 'list-style-image: url()',
                       oncommand: "BrowserReloadSkipCache();"
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});
    //      Einstellungen öffnen
                 CustomizableUI.createWidget({
                 id: 'Einstellungen-button',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'Einstellungen-button',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Einstellungen',
                       tooltiptext: 'Einstellungen-Button',
                       style: 'list-style-image: url()',
                       oncommand: "openPreferences();"
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});
    //      about:plugins öffnen
                CustomizableUI.createWidget({
    			id: 'aboutplugins-ToolBarButton',
    			type: 'custom',
    			onBuild: function(aDocument) {			
    				let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
    					id: 'aboutplugins-ToolBarButton',
    					class: 'toolbarbutton-1 chromeclass-toolbar-additional',
    					label: 'About:Plugins',
    					tooltiptext: 'About:Plugins öffnen',
    					style: 'list-style-image: url()',
    					onclick: 'if (event.button == 0) { \
    										openTrustedLinkIn("about:plugins", "tab");\
    								 }; '
    				};
    				for (var p in props)
    					toolbaritem.setAttribute(p, props[p]);
    				return toolbaritem;
    			}
    		});		
    //      Chrome Ordner öffnen
                 CustomizableUI.createWidget({
                 id: 'Open-Chrome-Folderbutton',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'Open-Chrome-Folderbutton',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Chrome Ordner',
                       tooltiptext: 'Chrome Ordner öffnen',
                       style: 'list-style-image: url()',
                       oncommand: 'Services.dirsvc.get("UChrm", Ci.nsIFile).launch();'
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
              });
    //        Seiteninformationen anzeigen
                 CustomizableUI.createWidget({
                 id: 'context-viewinfo',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'context-viewinfo',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Seiteninformationen',
    				   accesskey: 'i',
                       tooltiptext: 'Seiteninformationen anzeigen',
                       style: 'list-style-image: url()',
                       command: "View:PageInfo"
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
              });
    //        Zertifikate Anzeigen
                 CustomizableUI.createWidget({
                 id: 'context-viewcert',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'context-viewcert',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Zertifikate',
                       tooltiptext: 'Zertifikate anzeigen',
                       style: 'list-style-image: url()',
                       oncommand: "window.open('chrome://pippki/content/certManager.xhtml', 'mozilla:certmanager', 'chrome,resizable=yes,all,width=830,height=400');"
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
              });
    //      Passwörter anzeigen		  
                 CustomizableUI.createWidget({
                 id: 'context-viewpassword',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'context-viewpassword',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Passwörter',
                       tooltiptext: 'Passwörter anzeigen',
                       style: 'list-style-image: url()',
    				   onclick: 'if (event.button == 0) { \
    									window.open("chrome://passwordmgr/content/passwordManager.xhtml","PasswordManager","chrome,dialog,centerscreen,dependent,resizable"); \
    								 }; '
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
              });
    //       Chronik löschen öffnen
                 CustomizableUI.createWidget({
                 id: 'context-deletehistory',
                 type: 'custom',
                 onBuild: function(aDocument) {         
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                       id: 'context-deletehistory',
                       class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                       removable: true,
                       label: 'Chronik löschen',
                       tooltiptext: 'Chronik löschen',
                       style: 'list-style-image: url()',
    				   oncommand: "window.open('chrome://browser/content/sanitize.xhtml', 'Toolkit:SanitizeDialog', 'chrome,resizable=yes');"
                    };            
                    for (var p in props)
                       toolbaritem.setAttribute(p, props[p]);            
                    return toolbaritem;
                 }      
              });	
    //      Zoom Vergrößern (Strg++)
            CustomizableUI.createWidget({
                id: 'zoom-in-ToolBarbutton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'zoom-in-ToolBarbutton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Vergrößern (Strg ++)',
                        tooltiptext: 'Vergrößern (Strg ++)',
                        style: 'list-style-image: url()',
                        oncommand: "FullZoom.enlarge()"
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Zoom verkleinern (Strg+-)
            CustomizableUI.createWidget({
                id: 'zoom-out-ToolBarbutton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'zoom-out-ToolBarbutton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Verkleinern (Strg + -)',
                        tooltiptext: 'Verkleinern (Strg + -)',
                        style: 'list-style-image: url()',
                        oncommand: "FullZoom.reduce()"
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Aktiven Tab verschieben
            CustomizableUI.createWidget({
                id: 'moveTab-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'moveTab-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        oncontextmenu: 'return(false);',
                        label: 'Tab verschieben',
                        tooltiptext: 'Tabs verschieben linke Maustaste: nach links, Rechte Maustaste: nach rechts bewegen Rad: aufwärts Tab nach Links, Rab abwärts Tab nach rechts',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { \
                                      gBrowser.moveTabBackward(); \
                                  }; \
                                  if (event.button == 2) { \
                                      gBrowser.moveTabForward(); \
                                  };',
                        onwheel: 'if (event.deltaY < 0) { \
                                      gBrowser.tabContainer.advanceSelectedTab(-1, true); \
                                  } else { \
                                      gBrowser.tabContainer.advanceSelectedTab(1, true); \
                                  };'
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Zoom Steuerung
            CustomizableUI.createWidget({
                id: 'zoom-control-ToolBarbutton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'zoom-control-ToolBarbutton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        oncontextmenu: 'return(false);',
                        label: 'Zoomsteuerung',
                        tooltiptext: 'Linksklick oder Rad ↑: Vergrößern | Mitte: Zurücksetzen | Rechtsklick oder Rad ↓: Verkleinern',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { \
                                      FullZoom.enlarge(); \
                                  }; \
                                  if (event.button == 1) { \
                                      FullZoom.reset(); \
                                  }; \
                                  if (event.button == 2) { \
                                      FullZoom.reduce(); \
                                  };',
                        onwheel: 'if (event.deltaY < 0) { \
                                      FullZoom.enlarge(); \
                                  } else { \
                                      FullZoom.reduce(); \
                                  };'
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Cookies und Websitedaten verwalten (Cookies und Websitedaten werden anscheinend nur angezeigt, wenn Sie die Firefox-Option einmal öffnen.)
            CustomizableUI.createWidget({
                id: 'siteDataSettings-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'siteDataSettings-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Cookies und Websitedaten verwalten',
                        tooltiptext: 'Cookie- und Site-Datenverwaltung anzeigen (Firefox-Option muss anscheinend aber zuerst einmal geöffnet werden)',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { \
                                      window.open("chrome://browser/content/preferences/siteDataSettings.xhtml","cookie","chrome,dialog,centerscreen,dependent,resizable,width=700,height=560"); \
                                  }; '
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Entwicklerwerkzeuge
            CustomizableUI.createWidget({
                id: 'toggleToolbox-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'toggleToolbox-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        label: 'Entwicklerwerkzeuge',
                        tooltiptext: 'Entwicklerwerkzeuge öffnen',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { \
                                      let ev = new KeyboardEvent("keypress", {bubbles : true, cancelable : true, keyCode:  KeyboardEvent.DOM_VK_F9, shiftKey : true }); document.getElementById("main-window").dispatchEvent(ev); \
                                  }; '
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });
    //      Benutzerdefinierte Schaltfläche
            CustomizableUI.createWidget({
                id: 'three-ToolBarButton',
                type: 'custom',
                onBuild: function(aDocument) {
                    let toolbaritem = aDocument.createXULElement('toolbarbutton');
                    let props = {
                        id: 'three-ToolBarButton',
                        class: 'toolbarbutton-1 chromeclass-toolbar-additional',
                        oncontextmenu: 'return(false);',
                        label: 'Benutzerdefinierte Schaltfläche',
                        tooltiptext: 'Links oder Rad ↑ ↓: Neuer Tab | Mitte: about: config | Rechts: Chrome-Ordner',
                        style: 'list-style-image: url()',
                        onclick: 'if (event.button == 0) { /* 左クリック */ \
                                      openTrustedLinkIn("about:newtab", "tabshifted"); \
                                  }; \
                                  if (event.button == 1) { /* ホイールクリック */ \
                                      openTrustedLinkIn("about:config", "tab"); \
                                  }; \
                                  if (event.button == 2) { /* 右クリック */ \
                                      Services.dirsvc.get("UChrm", Ci.nsIFile).launch(); \
                                  };',
                        onwheel: 'if (event.deltaY < 0) { \
                                      openTrustedLinkIn("about:newtab", "tabshifted"); /* ホイールスクロール↑ */ \
                                  } else { \
                                      openTrustedLinkIn("about:newtab", "tabshifted"); /* ホイールスクロール↓ */ \
                                  };'
                    };
                    for (let p in props)
                        toolbaritem.setAttribute(p, props[p]);
                    return toolbaritem;
                }
            });		  
    		  
    		  
    		  
    	} catch(e) { };
    
    })();
    Alles anzeigen

    Der Schnipsel beginnt in Zeile 240

  • Neue Version ExtraConfigMenu.uc.js; die Kosmetik stimmt nicht mehr

    • Boersenfeger
    • 17. Januar 2025 um 15:03

    :P:thumbup:

    So ists hübsch!

  • Neue Version ExtraConfigMenu.uc.js; die Kosmetik stimmt nicht mehr

    • Boersenfeger
    • 17. Januar 2025 um 14:34

    Soweit, so gut... :)

    Allerdings sollten "dahinter" auch Icons erscheinen, so wie bei den Scripts...

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 17. Januar 2025 um 14:14

    Ja, ich suche eins nach dem anderen und überlege dabei, ob ich nicht darauf verzichten kann. Das in #386 ist allerdings für mich wichtig :)

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 17. Januar 2025 um 14:08

    Ich habe hier noch ein Script, das nicht mehr funktioniert:

    JavaScript
    // ==UserScript==
    // @name           ucjsDownloadsStatusModoki.uc.js
    // @namespace      http://space.geocities.yahoo.co.jp/gl/alice0775
    // @description    Downloads Status Modoki
    // @include        main
    // @compatibility  Firefox 117
    // @author         Alice0775
    // @note           DownloadsStatusModoki.uc.js.css Datei, muss in bzw. über userChrome.css geladen  werden!
    // @version        2023/07/17 00:00 use ES module imports
    // @version        2023/06/20 remove Bug 1780695 - Remove Services.jsm
    // @version        2023/06/18 21:00 null
    // @version        2023/05/18 21:00 
    // @version        2022/11/24 21:00 Bug 1802142 - Remove no longer used browser-bottombox
    // @version        2022/11/22 Bug 877389 - [meta] Replace calls to Cu.reportError, etc. from browser code, replace with console.error, etc.
    // @version        2022/11/20 19:00 107+ wip
    // @version        2022/04/01 23:00 Convert Components.utils.import to ChromeUtils.import
    // @version        2022/02/16 Bug 1747422 - Remove preprocessor variable use from downloads CSS
    // @version        2019/12/11 fix for 73 Bug 1601094 - Rename remaining .xul files to .xhtml in browser
    // @version        2019/10/20 12:30 workaround Bug 1497200: Apply Meta CSP to about:downloads, Bug 1513325 - Remove textbox binding
    // @version        2019/09/08 19:30 fix scrollbox
    // @version        2019/05/21 08:30 fix 69.0a1 Bug 1551320 - Replace all createElement calls in XUL documents with createXULElement
    // @version        2018/10/27 12:00 fix for 64+
    // @version        2018/06/12 21:00 fix for private window mode
    // @version        2018/06/07 12:00 fix file name for history
    // @version        2018/02/10 12:00 try catch error when DO_NOT_DELETE_HISTORY = true
    // @version        2017/12/10 12:00 fix error when DO_NOT_DELETE_HISTORY = true
    // @version        2017/12/10 12:00 remove workaround Bug 1279329. Disable btn while clear list is doing, close button styling for 57.
    // @version        2016/06/10 12:00 modify style independent of font-family
    // @version        2016/06/10 07:00 modify style of close button, fix typo
    // @version        2016/06/10 00:00 Workaround Bug 1279329. adjust some padding
    // @version        2015/05/08 00:00 remove padding due to Bug 1160734
    // @version        2014/03/31 00:00 fix for browser.download.manager.showWhenStarting
    // @version        2013/12/22 13:00 chromehidden
    // @version        2013/12/19 17:10 rename REMEMBERHISTOTY to DO_NOT_DELETE_HISTORY
    // @version        2013/12/16 23:28 fixed initialize numDls
    // @version        2013/12/16 23:24 open only download added
    // @version        2013/12/16 23:10 open only download started
    // @version        2013/12/16 21:20 modify css Windows7 Aero
    // @version        2013/12/16 21:00 modify css
    // @version        2013/12/16 19:30 add autocheck false
    // @version        2013/12/16 18:31 fix pref name
    // @version        2013/12/16 18:30
    // @note
    // ==/UserScript== 
    var ucjsDownloadsStatusModoki = {
      _summary: null,
      _list: null,
    
      get downloadsStatusModokiBar() {
        delete downloadsStatusModokiBar;
        return this.downloadsStatusModokiBar = document.getElementById("downloadsStatusModokiBar");
      },
    
      get toggleMenuitem() {
        delete toggleMenuitem;
        return this.toggleMenuitem = document.getElementById("toggle_downloadsStatusModokiBar");
      },
    
      init: function() {
        if (document.documentElement.getAttribute("chromehidden") !="" )
          return;
    
    
        ChromeUtils.defineESModuleGetters(this, {
          Downloads: "resource://gre/modules/Downloads.sys.mjs",
        });
    
        var style = ` 
          @namespace url(http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul); 
    
          #ucjsDownloadsStatusModoki { 
            width: 100%; 
            max-height: 100px; 
            height: 3.5em; 
          } 
         `.replace(/\s+/g, " ");
        var sspi = document.createProcessingInstruction(
          'xml-stylesheet',
          'type="text/css" href="data:text/css,' + encodeURIComponent(style) + '"'
        );
        document.insertBefore(sspi, document.documentElement);
        sspi.getAttribute = function(name) {
          return document.documentElement.getAttribute(name);
        };
    
    
        var toolbar = document.createXULElement("vbox");
        toolbar.setAttribute("id", "downloadsStatusModokiBar");
        toolbar.collapsed = true;
        var ref = document.getElementById("fullscreen-and-pointerlock-wrapper");
        ref.parentNode.insertBefore(toolbar, ref.nextSibling)
    //    var bottombox = document.getElementById("browser-bottombox");
    //    bottombox.insertBefore(toolbar, bottombox.firstChild);
        var browser = toolbar.appendChild(document.createXULElement("browser"));
        browser.setAttribute("disablehistory", true);
        browser.setAttribute("remote", false);
        browser.setAttribute("id", "ucjsDownloadsStatusModoki");
        browser.addEventListener("load", function(event){ucjsDownloadsStatusModoki.onload(event)}, true);
        browser.setAttribute("src", "chrome://browser/content/downloads/contentAreaDownloadsView.xhtml?StatusModoki");
        var menuitem = document.createXULElement("menuitem");
        menuitem.setAttribute("id", "toggle_downloadsStatusModokiBar");
        menuitem.setAttribute("type", "checkbox");
        menuitem.setAttribute("autocheck", false);
        menuitem.setAttribute("label", "Download Leiste");
        menuitem.setAttribute("checked", false);
        menuitem.setAttribute("accesskey", "D");
        menuitem.setAttribute("oncommand", "ucjsDownloadsStatusModoki.toggleDownloadsStatusModokiBar()");
        ref = document.getElementById("menu_customizeToolbars");
        ref.parentNode.insertBefore(menuitem, ref.previousSibling);
    
        // Ensure that the DownloadSummary object will be created asynchronously.
        if (!this._summary) {
          this.Downloads.getSummary(this.Downloads.ALL).then(summary => {
            this._summary = summary;
            return this._summary.addView(this);
          }).then(null, console.error);
        }
        if (!this._list) {
          this.Downloads.getList(this.Downloads.ALL).then(list => {
            this._list = list;
            return this._list.addView(this);
          }).then(null, console.error);
        }
    
        window.addEventListener("unload", this, false);
      },
    
      uninit: function() {
        window.removeEventListener("unload", this, false);
        if (this._summary) {
          this._summary.removeView(this);
        }
        if (this._list) {
          this._list.removeView(this);
        }
      },
    
      handleEvent: function(event) {
        switch (event.type) {
          case "unload":
            this.uninit();
            break;
        }
      },
    
      toggleDownloadsStatusModokiBar: function() {
        var collapsed = this.downloadsStatusModokiBar.collapsed;
        this.downloadsStatusModokiBar.collapsed = !collapsed;
        this.toggleMenuitem.setAttribute("checked", collapsed);
      },
    
      openDownloadsStatusModoki: function() {
        this.downloadsStatusModokiBar.collapsed = false;
        this.toggleMenuitem.setAttribute("checked", true);
      },
    
      hideDownloadsStatusModoki: function() {
        this.downloadsStatusModokiBar.collapsed = true;
        this.toggleMenuitem.setAttribute("checked", false);
      },
    
      onDownloadAdded: function (aDownload) {
        var showWhenStarting = true;
        try {
          showWhenStarting = Services.prefs.getBoolPref("userChrome.downloadsStatusModoki.showWhenStarting");
        } catch(e) {}
        this.numDls = 0;
        if (showWhenStarting) {
          if (this._list) {
            this._list.getAll().then(downloads => {
              for (let download of downloads) {
                if (!download.stopped)
                  this.numDls++;
              }
              if (this.numDls > 0)
                this.openDownloadsStatusModoki(false);
            }).then(null, console.error);
          }
        }
      },
    
      onSummaryChanged: function () {
        if (!this._summary)
          return;
        if (this._summary.allHaveStopped || this._summary.progressTotalBytes == 0) {
          var closeWhenDone = false;
          try {
            closeWhenDone = Services.prefs.getBoolPref("userChrome.downloadsStatusModoki.closeWhenDone");
          } catch(e) {}
          if (closeWhenDone) {
            this.hideDownloadsStatusModoki();
          }
        }
      },
    
    
    
      // chrome://browser/content/downloads/contentAreaDownloadsView.xhtml
      onload: function(event) {
        var doc = event.originalTarget;
        var win = doc.defaultView;
        doc.documentElement.setAttribute("ucjsDownloadsStatusModoki", "true");
    
        var button = doc.createXULElement("button");
        button.setAttribute("label", "Löschen");
        button.setAttribute("id", "ucjs_clearListButton");
        button.setAttribute("accesskey", "L");
        var ref = doc.getElementById("downloadsListEmptyDescription");
        var vbox = doc.createXULElement("vbox");
        var box = vbox.appendChild(doc.createXULElement("hbox"));
        box.appendChild(button);
        box.appendChild(doc.createXULElement("spacer")).setAttribute("flex", 1);
        var textbox = doc.createElementNS("http://www.w3.org/1999/xhtml", "input");
        textbox.setAttribute("id", "downloadFilter");
        textbox.setAttribute("clickSelectsAll", true);
        textbox.setAttribute("type", "search");
        textbox.setAttribute("placeholder", "Suchen...");
        box.appendChild(textbox);
        var closebtn = doc.createXULElement("toolbarbutton");
        closebtn.setAttribute("id", "ucjsDownloadsStatusModoki-closebutton");
        closebtn.setAttribute("class", "close-icon");
        closebtn.setAttribute("tooltiptext", "Download-Leiste schließen");
        box.appendChild(closebtn);
        ref.parentNode.insertBefore(vbox, ref.nextSibling);
        doc.getElementById("ucjs_clearListButton").addEventListener("command", function(event) {
            win.ucjsDownloadsStatusModoki_clearDownloads();
          });
        doc.getElementById("downloadFilter")
                .addEventListener("input", function(event) {
            win.ucjsDownloadsStatusModoki_doSearch(event.target.value);
          });
        doc.getElementById("ucjsDownloadsStatusModoki-closebutton")
                .addEventListener("command", function(event) {
            win.ucjsDownloadsStatusModoki_doClose();
          });
    
    /*
        // xxx Bug 1279329 "Copy Download Link" of context menu in Library is grayed out
        var listBox = doc.getElementById("downloadsListBox");
        var placesView = listBox._placesView;
        if (placesView) {
          var place = placesView.place;
          placesView.place= null;
          placesView.place = place;
        }
    */
        win.ucjsDownloadsStatusModoki_clearDownloads = function ucjs_clearDownloads() {
          var DO_NOT_DELETE_HISTORY = true; /* custmizable true or false */
          var richListBox = doc.getElementById("downloadsListBox");
    
          var places = [];
          function addPlace(aURI, aTitle, aVisitDate) {
            places.push({
              uri: aURI,
              title: aTitle,
              visits: [{
                visitDate: (aVisitDate || Date.now()) * 1000,
                transitionType: Ci.nsINavHistoryService.TRANSITION_LINK
              }]
            });
          }
          function moveDownloads2History() {
            if (DO_NOT_DELETE_HISTORY &&
                !PrivateBrowsingUtils.isWindowPrivate(window)) {
              try {
                for (let element of richListBox.childNodes) {
                  let download = element._shell.download;
                  let aURI = makeURI(download.source.url);
                  // let aTitle = document.getAnonymousElementByAttribute(element, "class", "downloadTarget").value
                  let aTitle = download.target.path;
                  aTitle = aTitle.match( /[^\\]+$/i )[0];
                  aTitle = aTitle.match( /[^/]+$/i )[0];
    
                  let aVisitDate = download.endTime || download.startTime;
                  addPlace(aURI, aTitle, aVisitDate)
                }
              } catch(ex) {}
            }
    
            // Clear List
            richListBox._placesView.doCommand('downloadsCmd_clearDownloads');
    
            if (DO_NOT_DELETE_HISTORY &&
                !PrivateBrowsingUtils.isWindowPrivate(window)) {
              try {
                if (places.length > 0) {
                  var asyncHistory = Components.classes["@mozilla.org/browser/history;1"]
                           .getService(Components.interfaces.mozIAsyncHistory);
                    asyncHistory.updatePlaces(places);
                }
              } catch(ex) {}
            }
          }
          var btn = doc.getElementById("ucjs_clearListButton");
          btn.setAttribute("disabled", true);
          moveDownloads2History();
          btn.removeAttribute("disabled");
    
          // close toolbar
          var closeWhenDone = false;
          try {
            closeWhenDone = Services.prefs.getBoolPref("userChrome.downloadsStatusModoki.closeWhenDone");
          } catch(e) {}
          if (closeWhenDone) {
            top.ucjsDownloadsStatusModoki.hideDownloadsStatusModoki();
          }
        };
    
        win.ucjsDownloadsStatusModoki_doSearch = function ucjs_doSearch(filterString) {
          var richListBox = doc.getElementById("downloadsListBox");
          richListBox._placesView.searchTerm = filterString;
        };
    
        win.ucjsDownloadsStatusModoki_doClose = function ucjs_doClose() {
          top.ucjsDownloadsStatusModoki.hideDownloadsStatusModoki();
        };
    
      }
    
    }
    ucjsDownloadsStatusModoki.init();
    Alles anzeigen
  • Neue Version ExtraConfigMenu.uc.js; die Kosmetik stimmt nicht mehr

    • Boersenfeger
    • 16. Januar 2025 um 18:31

    Ich habe eine neue Variante des Scripts ExtraConfigMenu.uc.js am Start, leider ist die dazu existierende CSS.Datei wohl nicht mehr so ganz passend, denn es fehlen die Icons vor "Meine CSS Dateien und im Submenü dahinter.

    Hier beide Dateien;

    CSS
    /*
    // ==UserScript==
    // @name           extras_config_menu.uc.js
    // @compatibility  Firefox 135*.*
    // @include        main
    // @version        1.0.20250112
    // @edit           @aborix 7/21 CSS Dateien als Untermenü eingefügt 
    // @edit           @2002Andreas 8/21 Shadow CSS Dateien als Untermenü + Ordner eingefügt
    // @edit 	   @BrokenHeart	1/25 Anpass. wg. Änderung der Sicherheitsrichtlinien bei 'inlineEvents'
    // ==/UserScript==
    */
    var uProfMenu = {
      // Beginn der Konfiguration
      // In der folgenden Zeile (11) den Pfad zum Texteditor eintragen (unter Ubuntu 10.04 z.B.: '/usr/bin/gedit'). Bei Fehleintrag wird view_source.editor.path ausgelesen:
      //TextOpenExe: 'C:\\Program Files (x86)\\Notepad++\\notepad++.exe',
      TextOpenExe: 'C:\\Program Files\\Notepad++\\notepad++.exe',
      // Falls gewuenscht, in Zeile 15 einen Dateimanager eintragen (komplett leer lassen fuer Dateimanager des Systems) Beispiele:
      // vFileManager: 'E:\\Total Commander\\Totalcmd.exe',
      // vFileManager: 'C:\\Program Files (x86)\\FreeCommander\\FreeCommander.exe'
      vFileManager: 'H:\\TotalCommander\\Totalcmd64.exe',
      // In der folgenden Zeile (19) 'menu' eintragen, damit es unter "Extras" als Menue erscheint, sonst die id des gewuenschten
      // Elements *nach* dem der Button erscheinen soll (z.B. 'urlbar', 'searchbar', 'undoclosetab-button','abp-toolbarbutton')
      // Bitte nicht so etwas wie die Menue- oder Navigationsleiste (sondern einen Menuepunkt oder einen Button mit id auf diesen Leisten) eintragen:
      warpmenuto: 'back-Button',
      // Unter Linux sollte/kann versucht werden, die userChromeJS-Skripte zu sortieren, unter Windows ist das evtl. nicht noetig (die Sortierung wird Gross- und Kleinschreibung *nicht* beruecksichtigen - dazu wird die sort()-Funktion entsprechend mit einer Vergleichsfunktion aufgerufen)
      sortScripts: 0,   // 1 zum Erzwingen der Sortierung
      // Einbindung GM-Skripte-Ordner (0: nein, 1: Greasemonkey [Profil-Verzeichnis], 2: UserScriptLoader [Chrome-Verzeichnis], 3: Scriptish [Profil-Verzeichnis]):
      gmOrdner: 0,
      // Einbindung CSS-Ordner (0: nein, 1: UserCSSLoader-Ordner im Chrome-Verzeichnis):
      cssOrdner: 1,
      // In Zeile 30 gueltige about:Adressen eintragen, die ebenfalls aufgerufen werden sollen.
      // - Zum Ausblenden: abouts: [],
      // - Damit die about:-Seiten nicht als Untermenue, sondern direkt als Menuepunkte aufgefuehrt werden, muss das erste Element '0' sein:
      // abouts: ['0','about:about','about:addons','about:cache','about:config','about:support'],
      abouts: ['about:about','about:addons','about:cache','about:config','about:crashes','about:downloads','about:home','about:logins','about:memory','about:support','about:preferences','about:performance','about:profiles'],
      // Die normalen Firefox-Einstellungen auch zur Verfuegung stellen (0: nein, 1: ja):
      showNormalPrefs: 1,
      // Stellt "Skriptliste in Zwischenablage" zur Verfuegung (1: ja, 2: mit getrennter Nummerierung, 3: mit gemeinsamer Nummerierung) oder nicht (0):
      enableScriptsToClip: 1,
      // Um den Eintrag "Neustart" zu erzwingen (falls z.B. das andere Skript zu spaet eingebunden und nicht erkannt wird), auf 1 setzen:
      enableRestart: 0,
      // Ende der Konfiguration
    
      init: function() {
        if (this.warpmenuto.toLowerCase() == 'menu') {
          // aufgrund des gewaehlten warpmenuto als Untermenue von Extras anlegen
          var zielmenu = document.getElementById('menu_ToolsPopup');
          if (zielmenu==null) {
            userChrome.log("extras_config_menu.uc.js findet Zielmenue nicht, evtl. weil ein anderes Fenster als das Hauptfenster " +
                           "geoeffnet wurde. Falls dieser Fehler auch im Hauptfenster auftritt, bitte die vorgehende Definition " +
                           "von 'zielmenu' kontrollieren.");
           return
          }
          var menu = zielmenu.appendChild(this.createME("menu","Config Men\u00FC",0,0,"ExtraConfigMenu"));
          menu.setAttribute("class","menu-iconic");
          menu.setAttribute("ondblclick","openTrustedLinkIn('about:config', 'tab');");
         } else {
    		 
    	 // als verschiebbaren Button anlegen
          if (window.__SSi == "window0") {
            CustomizableUI.createWidget({
              id: "ExtraConfigMenu-button",
              defaultArea: CustomizableUI.AREA_NAVBAR,
              label: "Extra Config Menü",
              tooltiptext: "Extra Config Menü\nRechtsklick \öffnet about:config"
            });
    		
          }
          var menu = document.getElementById("ExtraConfigMenu-button");
          menu.setAttribute("type", "menu");
    	  menu.addEventListener('click', function(event) {
    			if (event.button == 2 && !this.open) { 
    				openTrustedLinkIn("about:config", "tab");
    				event.preventDefault();
    			};
    	 },true);
    	  
        }
    	
        //ab hier ist alles gleich, egal ob Button oder Menue
        var css = " \
          #ExtraConfigMenu, #ExtraConfigMenu-button { \
            list-style-image: url();  \
    		 margin-top: 0px !important; \);  \
    		 margin-top: 0px !important; \
    		 opacity: 1 !important;\
          } \
          #ExtraConfigMenu-button > dropmarker, #ExtraConfigMenu-button > hbox > .toolbarbutton-menu-dropmarker { \
            display: none !important; \
          }";
        var sss = Cc['@mozilla.org/content/style-sheet-service;1'].getService(Ci.nsIStyleSheetService);
        var uri = makeURI('data:text/css;charset=UTF=8,' + encodeURIComponent(css));
        sss.loadAndRegisterSheet(uri,sss.AGENT_SHEET);
    	menu.addEventListener('popupshowing', function(event) {
    			uProfMenu.getScripts(0);
    			uProfMenu.getCss(3);
    			uProfMenu.getCss(4);
    			uProfMenu.getCss(5);
    	 },true);
    	
        var menupopup = menu.appendChild(this.createME("menupopup",0,0,0,"ExtraConfigMenu-popup"));
        // Anlegen von Untermenues fuer userChromeJS-Skripte und CSS-Dateien (befuellen spaeter)
        var submenu = menupopup.appendChild(this.createME("menu","Meine Scripte",0,0,"submenu-ucjs"));
        var submenupopup = submenu.appendChild(this.createME("menupopup",0,0,0,"submenu-ucjs-items"));
        // var submenu = menupopup.appendChild(this.createME("menu","uc.xul",0,0,"submenu-ucxul"));
        // var submenupopup = submenu.appendChild(this.createME("menupopup",0,0,0,"submenu-ucxul-items"));
        var submenu = menupopup.appendChild(this.createME("menu","css",0,0,"submenu-css"));
        var submenupopup = submenu.appendChild(this.createME("menupopup",0,0,0,"submenu-css-items"));
        //var submenu = menupopup.appendChild(this.createME("menu","CSSShadow",0,0,"submenu-CSSShadow"));
        //var submenupopup = submenu.appendChild(this.createME("menupopup",0,0,0,"submenu-CSSShadow-items"));
        //var submenu = menupopup.appendChild(this.createME("menu","cssweb",0,0,"submenu-cssweb"));
        var submenupopup = submenu.appendChild(this.createME("menupopup",0,0,0,"submenu-cssweb-items"));
        if (this.enableScriptsToClip) menupopup.appendChild(this.createME("menuitem","Skriptliste in Zwischenablage","uProfMenu.getScripts(1)","uProfMenu_clipboard",0));
        // Ende Anlegen von Untermenues
        menupopup.appendChild(document.createXULElement('menuseparator'));
        // Einbindung von Konfigdateien
        menupopup.appendChild(this.createME("menuitem","Bild Url","uProfMenu.edit(0,'Bild Url.css');","uProfMenu_edit",0));
        menupopup.appendChild(this.createME("menuitem","config Einträge.css","uProfMenu.edit(0,'config Einträge.css');","uProfMenu_edit",0));
        menupopup.appendChild(this.createME("menuitem","userChrome.css","uProfMenu.edit(0,'userChrome.css');","uProfMenu_edit",0));
        menupopup.appendChild(this.createME("menuitem","userChromeShadow.css","uProfMenu.edit(0,'userChromeShadow.css');","uProfMenu_edit",0));
        menupopup.appendChild(this.createME("menuitem","userContent.css","uProfMenu.edit(0,'userContent.css');","uProfMenu_edit",0));
        menupopup.appendChild(this.createME("menuitem","userChrome.js","uProfMenu.edit(0,'userChrome.js');","uProfMenu_edit",0));
        menupopup.appendChild(this.createME("menuitem","prefs.js","uProfMenu.edit(1,'prefs.js');","uProfMenu_edit",0));
        menupopup.appendChild(this.createME("menuitem","user.js","uProfMenu.edit(1,'user.js');","uProfMenu_edit"),0);
    
        // Ende Einbindung von Konfigdateien
        menupopup.appendChild(document.createXULElement('menuseparator'));
        // Einbindung von Ordnern
        switch (this.gmOrdner) {
          case 1:
            menupopup.appendChild(this.createME("menuitem","GM-skripty","uProfMenu.dirOpen(uProfMenu.getPrefDirectoryPath('ProfD')+uProfMenu.getDirSep()+'gm_scripts');","uProfMenu_folder"),0);
            break;
          case 2:
            menupopup.appendChild(this.createME("menuitem","USL-skripty","uProfMenu.dirOpen(uProfMenu.getPrefDirectoryPath('UChrm')+uProfMenu.getDirSep()+'UserScriptLoader');","uProfMenu_folder"),0);
            break;
          case 3:
            menupopup.appendChild(this.createME("menuitem","Skripty Scriptish","uProfMenu.dirOpen(uProfMenu.getPrefDirectoryPath('ProfD')+uProfMenu.getDirSep()+'scriptish_scripts');","uProfMenu_folder"),0);
            break;
        }
    
        menupopup.appendChild(this.createME("menuitem","CSS-Ordner ","uProfMenu.dirOpen(uProfMenu.getPrefDirectoryPath('UChrm')+uProfMenu.getDirSep()+'css');","uProfMenu_folder"),0);
        //menupopup.appendChild(this.createME("menuitem","CSSShadow-Ordner","uProfMenu.dirOpen(uProfMenu.getPrefDirectoryPath('UChrm')+uProfMenu.getDirSep()+'CSSShadow');","uProfMenu_folder"),0);
        //menupopup.appendChild(this.createME("menuitem","CSSWeb-Ordner","uProfMenu.dirOpen(uProfMenu.getPrefDirectoryPath('UChrm')+uProfMenu.getDirSep()+'CSSWeb');","uProfMenu_folder"),0);
        menupopup.appendChild(this.createME("menuitem","Chromeordner","uProfMenu.prefDirOpen('UChrm');","uProfMenu_folder"),0);
        menupopup.appendChild(this.createME("menuitem","Profilordner","uProfMenu.prefDirOpen('ProfD');","uProfMenu_folder"),0);
        //menupopup.appendChild(this.createME("menuitem","Icons-Ordner","uProfMenu.dirOpen(uProfMenu.getPrefDirectoryPath('UChrm')+uProfMenu.getDirSep()+'Icons');","uProfMenu_folder"),0);
        //menupopup.appendChild(this.createME("menuitem","Installationsordner","uProfMenu.prefDirOpen('CurProcD');","uProfMenu_folder"),0);
        //menupopup.appendChild(this.createME("menuitem","Addonordner","uProfMenu.dirOpen(uProfMenu.getPrefDirectoryPath('ProfD')+uProfMenu.getDirSep()+'extensions');","uProfMenu_folder"),0);
        menupopup.appendChild(this.createME("menuitem","Startup-Cacheordner","uProfMenu.dirOpen(uProfMenu.getPrefDirectoryPath('ProfLD')+uProfMenu.getDirSep()+'startupCache');","uProfMenu_folder"),0);
      /*   menupopup.appendChild(this.createME("menuitem","Ordner about","uProfMenu.dirOpen(uProfMenu.getPrefDirectoryPath('UChrm')+uProfMenu.getDirSep()+'about');","uProfMenu_folder"),0); */
        // Ende Einbindung von Ordnern
    	
        // Einbindung von abouts
        if (this.abouts.length>0) {
          menupopup.appendChild(document.createXULElement('menuseparator'));
          // falls der erste Eintrag des Arrays = '0' ist, dann kein Untermenue anlegen, sondern direkt als Menuepunkte einbinden
          if (this.abouts[0]=='0') {
            for (var i = 1; i < this.abouts.length; i++) {
            menupopup.appendChild(this.createME("menuitem",this.abouts[i],"openTrustedLinkIn('"+this.abouts[i]+"','tab')","uProfMenu_about"),0);
            }
           } else {
            // der erste Eintrag des arrays ist ungleich '0', deshalb als Untermenue einrichten
            var submenu = menupopup.appendChild(this.createME("menu","uc.js",0,0,"submenu-about"));
            var submenupopup = submenu.appendChild(this.createME("menupopup",0,0,0,"submenu-about-items"));
            this.fillMenu("submenu-about","submenu-about-items", "about:",this.abouts,"uProfMenu_about",1);
          }
        }
        // Ende Einbindung von abouts
        // Separator, falls dieser nicht schon durch abouts generiert wurde und weitere Menuepunkte folgen werden
        if (this.abouts.length==0 && (this.showNormalPrefs || typeof(ToolRstartMod) != "undefined")) menupopup.appendChild(document.createXULElement('menuseparator'));
        // Falls gewuenscht (s. Konfigurationsabschnitt), Zugriff auf die normalen Einstellungen
        if (this.showNormalPrefs) menupopup.appendChild(this.createME("menuitem","Einstellungen","try{openOptionsDialog();}catch(e){openPreferences();}","uProfMenu_prefs"),0);
        // Falls addRestartButton installiert ist, Neustart zur Verfuegung stellen (addRestartButton 1.0.20120105mod erforderlich)
        if(this.enableRestart) menupopup.appendChild(this.createME("menuitem","Neustart",
        "Services.appinfo.invalidateCachesOnRestart(); Services.startup.quit(Ci.nsIAppStartup.eRestart | Ci.nsIAppStartup.eAttemptQuit,0);"));
        },
    
      getDirSep:function() {
        // Betriebssystem nach https://developer.mozilla.org/en/Code_snippets/Miscellaneous ermitteln
        var osString = Components.classes["@mozilla.org/xre/app-info;1"].getService(Components.interfaces.nsIXULRuntime).OS;
        var dirsep = "/";
        switch(osString) {
          case "WINNT":
            dirsep = "\\";
            break;
          case "Linux":
            dirsep = "/";
            break;
          case "Darwin":
            dirsep = "/";
            break;
        }
        return dirsep;
      },
    
      edit:function(OpenMode,Filename){
        var Path = "";
        var dSep = this.getDirSep();  // die Trennzeichen zwischen Ordnern abhaengig vom Betriebssystem machen
        switch (OpenMode){
          //Current is Chrome Directory
          case 0:
            var Path = this.getPrefDirectoryPath("UChrm") + dSep + Filename;
            break;
          //Current is Profile Directory
          case 1:
            var Path = this.getPrefDirectoryPath("ProfD") + dSep + Filename;
            break;
          //Current is Root
          case 2:
            var Path = Filename;
            break;
          //Current is CSS folder
          case 3:
            var Path = this.getPrefDirectoryPath("UChrm") + dSep + "CSS" + dSep + Filename;
            break;
          //Current is CSSWeb folder
          case 4:
            var Path = this.getPrefDirectoryPath("UChrm") + dSep + "CSSWeb" + dSep + Filename;
            break;
    		//Current is CSSShadow folder
          case 5:
            var Path = this.getPrefDirectoryPath("UChrm") + dSep + "CSSShadow" + dSep + Filename;
            break;
        }
        this.launch(this.TextOpenExe,Path);
      },
    
      dirOpen:function(Path){
        if (this.vFileManager.length != 0) {
          var file = Cc['@mozilla.org/file/local;1'].createInstance(Ci.nsIFile);
          var process = Cc['@mozilla.org/process/util;1'].createInstance(Ci.nsIProcess);
          var args = [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
          var dir = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsIFile);
          dir.initWithPath(Path);
          dir.launch();
        }
      },
    
      prefDirOpen:function(prefDir){
        Path = this.getPrefDirectoryPath(prefDir);
        this.dirOpen(Path);
      },
    
      getPrefDirectoryPath:function(str){
        // get profile directory
        var file = Components.classes["@mozilla.org/file/directory_service;1"]
          .getService(Components.interfaces.nsIProperties)
          .get(str, Components.interfaces.nsIFile);
        if (str == 'CurProcD') {
          file = file.parent;
        };
        return file.path;
      },
    
      launch:function(RanPath,OpenPath){
        var file = Components.classes["@mozilla.org/file/local;1"].createInstance(Components.interfaces.nsIFile);
        var proc = Components.classes["@mozilla.org/process/util;1"].createInstance(Components.interfaces.nsIProcess);
        var args = [OpenPath];
        file.initWithPath(RanPath);
        // falls der im Konfigurationsabschnitt definierte Editor nicht gefunden wird, auf Einstellung in about:config ausweichen:
        if (!file.exists()) {
          var pref = Components.classes["@mozilla.org/preferences-service;1"].getService(Components.interfaces.nsIPrefBranch);
          RanPath = pref.getCharPref("view_source.editor.path");
          file.initWithPath(RanPath);
        }
        proc.init(file);
        proc.run(false, args, args.length);
      },
    
      stringComparison:function(a, b){
        a = a.toLowerCase();
        a = a.replace(/ä/g,"a");
        a = a.replace(/ö/g,"o");
        a = a.replace(/ü/g,"u");
        a = a.replace(/ß/g,"s");
        b = b.toLowerCase();
        b = b.replace(/ä/g,"a");
        b = b.replace(/ö/g,"o");
        b = b.replace(/ü/g,"u");
        b = b.replace(/ß/g,"s");
        return(a==b)?0:(a>b)?1:-1;
      },
    
      getScripts:function(iType) {
        // Arrays (jeweils ein Array fuer uc.js und uc.xul) nehmen Namen der gefundenen Skripte auf
        let ucJsScripts = [];
        let ucXulScripts = [];
        // Suchmuster, also die Dateierweiterungen uc.js und uc.xul
        let extjs = /\.uc\.js$/i;
        //let extxul = /\.uc\.xul$/i;
        let aFolder = Cc['@mozilla.org/file/local;1'].createInstance(Ci.nsIFile);
        aFolder.initWithPath(Services.dirsvc.get("UChrm", Ci.nsIFile).path);
        // files mit Eintraegen im Chrome-Ordner befuellen
        let files = aFolder.directoryEntries.QueryInterface(Ci.nsISimpleEnumerator);
        // Ordner bzw. files durchlaufen und kontrollieren, ob gesuchte Dateien dabei sind
        while (files.hasMoreElements()) {
          let file = files.getNext().QueryInterface(Ci.nsIFile);
          // keine gewuenschte Datei, deshalb continue
          //if (!extjs.test(file.leafName) && !extxul.test(file.leafName)) continue;
          // uc.js gefunden -> im Array ablegen
          if (extjs.test(file.leafName)) ucJsScripts.push(file.leafName);
          // uc.xul gefunden -> im Array ablegen
          //if (extxul.test(file.leafName)) ucXulScripts.push(file.leafName);
        }
        if (this.sortScripts) {
          ucJsScripts.sort(this.stringComparison);
          //ucXulScripts.sort(this.stringComparison);
        }
        // Aufruf der naechsten Methoden um die beiden Untermenues oder die Zwischenablage zu befuellen
        if (iType==0) {
          this.fillMenu("submenu-ucjs","submenu-ucjs-items", "Meine Scripte",ucJsScripts,"uProfMenu_ucjs",0);
          //this.fillMenu("submenu-ucxul","submenu-ucxul-items", "uc.xul",ucXulScripts,"uProfMenu_ucxul",0);
         } else {
          var result = this.fillClipboardValue(ucJsScripts,ucXulScripts);
          Components.classes["@mozilla.org/widget/clipboardhelper;1"].getService(Components.interfaces.nsIClipboardHelper).copyString(result);
        }
      },
    
      getCss:function(iType) {
        // Array nimmt Namen der gefundenen css-Dateien auf
        let cssFiles = [];
        // Suchmuster, also die Dateierweiterung css
        let extcss = /\.css$/i;
        let aFolder = Cc['@mozilla.org/file/local;1'].createInstance(Ci.nsIFile);
        if (iType==3) {
          aFolder.initWithPath(Services.dirsvc.get("UChrm", Ci.nsIFile).path+this.getDirSep()+"CSS");
         } else if (iType==4) {
          aFolder.initWithPath(Services.dirsvc.get("UChrm", Ci.nsIFile).path+this.getDirSep()+"CSSWeb");
        }  else if (iType==5) {
          aFolder.initWithPath(Services.dirsvc.get("UChrm", Ci.nsIFile).path+this.getDirSep()+"CSSShadow");
        }
        // files mit Eintraegen im CSS- bzw. CSSWeb-Ordner befuellen
        let files = aFolder.directoryEntries.QueryInterface(Ci.nsISimpleEnumerator);
        // Ordner bzw. files durchlaufen und kontrollieren, ob gesuchte Dateien dabei sind
        while (files.hasMoreElements()) {
          let file = files.getNext().QueryInterface(Ci.nsIFile);
          // css gefunden -> im Array ablegen
          if (extcss.test(file.leafName)) cssFiles.push(file.leafName);
        }
        if (this.sortScripts) {
          cssFiles.sort(this.stringComparison);
        }
        // Untermenue befuellen
        if (iType==3) {
          this.fillMenu("submenu-css","submenu-css-items","Meine CSS-Dateien",cssFiles,"uProfMenu_css",3);
         } else if (iType==4) {
          this.fillMenu("submenu-cssweb","submenu-cssweb-items","Meine CSSWeb-Dateien",cssFiles,"uProfMenu_css",4);
        }  else if (iType==5) {
          this.fillMenu("submenu-CSSShadow","submenu-CSSShadow-items","Meine CSSShadow-Dateien",cssFiles,"uProfMenu_css",5);
        }
      },
    
      fillMenu:function(whichsubmenu, whichsubmenuitems, strlabel, scriptArray,sClass,sTyp) {
        // Beschriftung des Untermenues mit Anzahl der gefundenen Dateien ergaenzen
        var e = document.getElementById(whichsubmenu);
        e.setAttribute('label',strlabel + ' (' + scriptArray.length + ')');
        var popup = document.getElementById(whichsubmenuitems);
        // zunaechst Untermenue zuruecksetzen
        while(popup.hasChildNodes()){
          popup.removeChild(popup.firstChild);
        }
        // Untermenue endlich befuellen
        for (var i = scriptArray.length-1; i > -1; i--) {
          // Typunterscheidung (userChromeJS-Skript oder about: oder css)
          if (sTyp==0){
            var mitem = this.createME("menuitem",scriptArray[i],"uProfMenu.edit(0,'"+scriptArray[i]+"')",sClass,0);
    		mitem.addEventListener('click', function(event) {
    			uProfMenu.openAtGithub(event,'"+scriptArray[i]+"');
    			event.preventDefault();
    		},true);
    		
            mitem.setAttribute("tooltiptext"," Linksklick: Bearbeiten,\n Mittelklick: https://github.com/.../"+this.cleanFileName(scriptArray[i])+" oeffnen,\n Rechtsklick: Suche auf GitHub");
           } else if (sTyp==1){
            var mitem = this.createME("menuitem",scriptArray[i],"openTrustedLinkIn('"+scriptArray[i]+"','tab')",sClass,0);
           } else if (sTyp==3){
            var mitem = this.createME("menuitem",scriptArray[i],"uProfMenu.edit(3,'"+scriptArray[i]+"')",sClass,0);
           } else if (sTyp==4){
            var mitem = this.createME("menuitem",scriptArray[i],"uProfMenu.edit(4,'"+scriptArray[i]+"')",sClass,0);
          }
    	  else if (sTyp==5){
            var mitem = this.createME("menuitem",scriptArray[i],"uProfMenu.edit(5,'"+scriptArray[i]+"')",sClass,0);
          }
          popup.insertBefore(mitem, popup.firstChild);
        }
      },
    
      fillClipboardValue:function(sArray,xArray) {
        var retValue;
        var s = 0;
        var x = 0;
        s = sArray.length;
        x = xArray.length;
        switch(this.enableScriptsToClip) {
          case 1:
            retValue = "userChromeJS/uc.js ("+s+"):\n------------------------\n"+sArray.join("\n")+
                       "\n\nuserChromeJS/uc.xul ("+x+"):\n-------------------------\n"+xArray.join("\n");
            break;
          default:
            retValue = "userChromeJS/uc.js ("+s+"):\n------------------------";
            for (var i = 0; i < s ; i++) {
              j = i + 1;
              retValue = retValue + "\n" + j + ". " + sArray[i];
            }
            retValue = retValue + "\n\nuserChromeJS/uc.xul ("+x+"):\n-------------------------";
            if (this.enableScriptsToClip==2) s = 0;
            for (var i = 0; i < x ; i++) {
              j = i + s + 1;
              retValue = retValue + "\n" + j + ". " + xArray[i];
            }
            break;
        }
        return retValue;
      },
    
      createME:function(sTyp,sLabel,sCommand,sClass,sId) {
        // Anlegen von menuitem, menu oder menupop - fuer bestimmte Typen nicht eingesetzte Parameter werden als 0 uebergeben
        const XUL_NS = "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul";
        var m = document.createElementNS(XUL_NS, sTyp);
        switch (sTyp) {
          case "menuitem":
            // this.createME("menuitem","Label des Items","ZuzuweisenderCodeFueroncommand","GewuenschteKlasseDesItems",0)
            m.setAttribute('label', sLabel);
            m.setAttribute('class',sClass);
    		m.addEventListener('command', function(event) {
    			Function(sCommand)();
    		}, true);
    		
            break;
          case "menu":
            // this.createME("menu","Label des Menues",0,0,"GewuenschteIdDesMenues")
            m.setAttribute('label', sLabel);
            m.setAttribute('id', sId);
            break;
          case "menupopup":
            //this.createME("menupopup",0,0,0,"GewuenschteIdDesMenupopups");
            m.setAttribute('id', sId);
            break;
        }
        return m;
      },
    
      openAtGithub:function(e,sScript) {
        if (e.button==1){
          // Mittelklick - Seite auf GitHub oeffnen (funktioniert nur, wenn Ordner- und bereinigter Dateiname [ohne Erweiterung] uebereinstimmen):
          var sUrl = "https://github.com/ardiman/userChrome.js/tree/master/"+this.cleanFileName(sScript);
          openWebLinkIn(sUrl, 'tab');
        }
        if (e.button==2){
          // Rechtsklick - Suche auf GitHub starten (funktioniert nur, wenn der Dateiname im Code hinterlegt ist):
          e.preventDefault();
          var sUrl = "https://github.com/search?langOverride=&language=&q="+sScript+"&repo=&start_value=1&type=Code";
          openWebLinkIn(sUrl, 'tab');
        }
      },
    
      cleanFileName:function(sName) {
        sName = sName.toLowerCase();
        /* Das folgende Array enthaelt regulaere Ausdruecke, um ungueltige Zeichenfolgen entfernen:
        /Datei-Erweiterungen am Ende/, /"ucjs_" am Anfang/, /"_"gefolgtVonZahlUndDanachBeliebigenZeichen/
        / "_fx"gefolgtVonZahl(en)/, /"-" oder "+" oder "."/, /"_v"gefolgtVonZahlen
        */
        var regs = [/\.uc\.js$/,/\.uc\.xul$/,/^ucjs_/,/_\d.+/,/_fx\d+/,/[-+\.]/g,/_v\d+/];
        for (var i = 0; i < regs.length; i++) {
          sName = sName.replace(regs[i],"");
        }
        return sName;
      }
    
    };
    
    uProfMenu.init();
    Alles anzeigen
    CSS
    				/* Extra-Config-Menü.css */
    
      @-moz-document url(chrome://browser/content/browser.xhtml){
    
    
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(10),
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(11),
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(12),
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(13),
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(14),
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(15),
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(16),
      #ExtraConfigMenu-button > menupopup > menuitem[label="Startup-Cacheordner"]{
      appearance:none!important;
      background: url("") no-repeat !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(10):hover,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(11):hover,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(12):hover,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(13):hover,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(14):hover,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(15):hover,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(16):hover,
      #ExtraConfigMenu-button > menupopup > menuitem[label="Startup-Cacheordner"]:hover{
      appearance:none!important;
      margin-right: -1px !important;
      background: #ecf0f6 url("") no-repeat !important;	
      border-width: thin !important;
      border-radius: 4px !important;
      border-color: #aecff7 !important;
      border-style: solid !important;
      min-height: 24px!important;
      padding-top: 7px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      .uProfMenu_clipboard{
      appearance:none!important;
      background: url("") no-repeat !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      .uProfMenu_clipboard:hover{
      appearance:none!important;
      margin-right: -1px !important;
      background: #ecf0f6 url("") no-repeat !important;	
      border-width: thin !important;
      border-radius: 4px !important;
      border-color: #aecff7 !important;
      border-style: solid !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      .uProfMenu_prefs{
      appearance:none!important;
      background: url("") no-repeat !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      .uProfMenu_prefs:hover{
      appearance:none!important;
      margin-right: -1px !important;
      background: #ecf0f6 url("") no-repeat !important;	
      border-width: thin !important;
      border-radius: 4px !important;
      border-color: #aecff7 !important;
      border-style: solid !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      .uProfMenu_restart{
      appearance:none!important;
      background: url("%2F9hAAAACXBIWXMAAAsTAAALEwEAmpwYAAAKT2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtvUhUIIFJCi4AUkSYqIQkQSoghodkVUcERRUUEG8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89%2BbN%2FrXXPues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEKJHAAEAizZCFz%2FSMBAPh%2BPDwrIsAHvgABeNMLCADATZvAMByH%2Fw%2FqQplcAYCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZTAKAEAGDLY2LjAFAtAGAnf%2BbTAICd%2BJl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3AMDOEAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ5RYFbCC1xB1dXLh4ozkkXKxQ2YQJhmkAuwnmZGTKBNA%2Fg88wAAKCRFRHgg%2FP9eM4Ors7ONo62Dl8t6r8G%2FyJiYuP%2B5c%2BrcEAAAOF0ftH%2BLC%2BzGoA7BoBt%2FqIl7gRoXgugdfeLZrIPQLUAoOnaV%2FNw%2BH48PEWhkLnZ2eXk5NhKxEJbYcpXff5nwl%2FAV%2F1s%2BX48%2FPf14L7iJIEyXYFHBPjgwsz0TKUcz5IJhGLc5o9H%2FLcL%2F%2Fwd0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s%2BwM%2B3zUAsGo%2BAXuRLahdYwP2SycQWHTA4vcAAPK7b8HUKAgDgGiD4c93%2F%2B8%2F%2FUegJQCAZkmScQAAXkQkLlTKsz%2FHCAAARKCBKrBBG%2FTBGCzABhzBBdzBC%2FxgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD%2FphCJ7BKLyBCQRByAgTYSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5h1xGupE7yAAygvyGvEcxlIGyUT3UDLVDuag3GoRGogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8%2BQ8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8%2BxdwQSgUXACTYEd0IgYR5BSFhMWE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR%2BcQYYjIxh1hILCPWEo8TLxB7iEPENyQSiUMyJ7mQAkmxpFTSEtJG0m5SI%2BksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG%2BQh8lsKnWJAcaT4U%2BIoUspqShnlEOU05QZlmDJBVaOaUt2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdpr%2Bh0uhHdlR5Ol9BX0svpR%2BiX6AP0dwwNhhWDx4hnKBmbGAcYZxl3GK%2BYTKYZ04sZx1QwNzHrmOeZD5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI%2BpXlN9rkZVM1PjqQnUlqtVqp1Q61MbU2epO6iHqmeob1Q%2FpH5Z%2FYkGWcNMw09DpFGgsV%2FjvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY%2FR27iz2qqaE5QzNKM1ezUvOUZj8H45hx%2BJx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllirSKtRq0frvTau7aedpr1Fu1n7gQ5Bx0onXCdHZ4%2FOBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79up%2B6Ynr5egJ5Mb6feeb3n%2Bhx9L%2F1U%2FW36p%2FVHDFgGswwkBtsMzhg8xTVxbzwdL8fb8VFDXcNAQ6VhlWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TDtMx83MzaLN1pk1mz0x1zLnm%2Beb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lOk06rntZnw7Dxtsm2qbcZsOXYBtuutm22fWFnYhdnt8Wuw%2B6TvZN9un2N%2FT0HDYfZDqsdWh1%2Bc7RyFDpWOt6azpzuP33F9JbpL2dYzxDP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc%2BLpsbxt3IveRKdPVxXeF60vWdm7Obwu2o26%2FuNu5p7ofcn8w0nymeWTNz0MPIQ%2BBR5dE%2FC5%2BVMGvfrH5PQ0%2BBZ7XnIy9jL5FXrdewt6V3qvdh7xc%2B9j5yn%2BM%2B4zw33jLeWV%2FMN8C3yLfLT8Nvnl%2BF30N%2FI%2F9k%2F3r%2F0QCngCUBZwOJgUGBWwL7%2BHp8Ib%2BOPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQrSH355jOkc5pDoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo%2Bqi5qPNo3ujS6P8YuZlnM1VidWElsSxw5LiquNm5svt%2F87fOH4p3iC%2BN7F5gvyF1weaHOwvSFpxapLhIsOpZATIhOOJTwQRAqqBaMJfITdyWOCnnCHcJnIi%2FRNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5hCepkLxMDUzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z%2Bpn5mZ2y6xlhbL%2BxW6Lty8elQfJa7OQrAVZLQq2QqboVFoo1yoHsmdlV2a%2FzYnKOZarnivN7cyzytuQN5zvn%2F%2FtEsIS4ZK2pYZLVy0dWOa9rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQFr6wtVCuWFfevc1%2B1dT1gvWd%2B1YfqGnRs%2BFYmKrhTbF5cVf9go3HjlG4dvyr%2BZ3JS0qavEuWTPZtJm6ebeLZ5bDpaql%2BaXDm4N2dq0Dd9WtO319kXbL5fNKNu7g7ZDuaO%2FPLi8ZafJzs07P1SkVPRU%2BlQ27tLdtWHX%2BG7R7ht7vPY07NXbW7z3%2FT7JvttVAVVN1WbVZftJ%2B7P3P66Jqun4lvttXa1ObXHtxwPSA%2F0HIw6217nU1R3SPVRSj9Yr60cOxx%2B%2B%2Fp3vdy0NNg1VjZzG4iNwRHnk6fcJ3%2FceDTradox7rOEH0x92HWcdL2pCmvKaRptTmvtbYlu6T8w%2B0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO32oPb%2B%2B6EHTh0kX%2Fi%2Bc7vDvOXPK4dPKy2%2BUTV7hXmq86X23qdOo8%2FpPTT8e7nLuarrlca7nuer21e2b36RueN87d9L158Rb%2F1tWeOT3dvfN6b%2FfF9%2FXfFt1%2Bcif9zsu72Xcn7q28T7xf9EDtQdlD3YfVP1v%2B3Njv3H9qwHeg89HcR%2FcGhYPP%2FpH1jw9DBY%2BZj8uGDYbrnjg%2BOTniP3L96fynQ89kzyaeF%2F6i%2FsuuFxYvfvjV69fO0ZjRoZfyl5O%2FbXyl%2FerA6xmv28bCxh6%2ByXgzMV70VvvtwXfcdx3vo98PT%2BR8IH8o%2F2j5sfVT0Kf7kxmTk%2F8EA5jz%2FGMzLdsAAAAEZ0FNQQAAsY58%2B1GTAAAAIGNIUk0AAHolAACAgwAA%2Bf8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAN8SURBVHjaVJFNTBxlAIafb2Z29gd2l4VdYCkokAUt1AJplQRTrVqjUWMPPWHSCzb21IOn9qIHY2xMahoTTb00NmkUm5qAjdpUI61VaCxCpCVYixt%2ByvKzCwu7LDs7zMw3HmhM%2Bt6fJ0%2FyCp69wiOzZBCPcqSmIXg0HPHuC4R8nkLWyOXyYiIzfuVHzMIA%2BZsLtH18EApntUdhpzUSD5577nDLi%2FGWKjx%2BHVfR8HpFwNwsxTMzza%2BOXJ1%2B58Ev2sVEV%2ByEawXqxf8FllNWEQ9ePXzsqQOecIDU8jampSAVD76Al2BIIx4Dv2Nz7%2FYq%2B5%2BP8sNXE6WdAhdQlOM9rzUdaGiN8M9UjnKvQjzuA0UjV3AxDIcHywqRoEbXoVrKgyBtKXYEUvprmiN9oaoyvr9wl62NHJbtJeDzOo17YmprVzWOppLO2RRNwf1FSOzSUAXsCIR4QdP13UPfjhUde2mjuBXUjcXNEabOnJmq7Y4Nd7z1fu%2BJ%2FR2Jpgrm0jauAI8GlnSlBi4I0bO6sLBWHc9esxRdmjOZf5n%2B5CLWzCzOvsbKupBZ1xgmElUoC%2BgoKtRGQfNomoaND8P8XS%2Bby1olO7O6GHTl1DejGDOrNB%2BvpO7I%2Ba31%2FDP9Z28YUmqoqhCKcG2EYD6ZMUTojZ8WHmsqD%2BI6wnWFajugCkuuZaV%2FZS47wp99R7E3LbxPV6rtr7dV1pmyuBWs3hr7dZ380LC2tzseffvUHm86C1JC2A%2FrGcn509cn%2BPvTk9ibc1R06qL91Ms1CadF000ll9rVS2VykLzVr0lHOgtpuJ9yUFyXxqhKZjbH2nJRI9IZwyw2kXjvXV%2FIOWgaBcc2a%2BtjdVXR1J3iBDx8QUpQUJAuJJclseogxz441H5vrPO72cm0VSyVPJq27ZaHm8ST3Y0M9d9Kkr19A1A1x4VIObTGBfNrsJ5XmE9b6KqgvrOGhr1Vns2sgeNIkXiigvHf1liZuHWZYjINSEXRVLewZjN6bYmYbvN4rcDvVzFKLnOpErMLBpvbklClznyyyPDA6DjTX3wJWICr%2Bnb3ffjXSGpl5Nxnn88uh2ORUCBaHfVQU%2BsjVuGhKqJT5lFYShr8fGH4j42bH53EnJ4EtgEEPQOTzHx9mqXLl9AT9TS82RvreOmVcMTXVh4JhIr5kp3LFu6u3Lk%2ByMylQazU3ENYAvw3AFUTimFqj5i7AAAAAElFTkSuQmCC") no-repeat !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      .uProfMenu_restart:hover{
      appearance:none!important;
      margin-right: -1px !important;
      background: #ecf0f6 url("%2F9hAAAACXBIWXMAAAsTAAALEwEAmpwYAAAKT2lDQ1BQaG90b3Nob3AgSUNDIHByb2ZpbGUAAHjanVNnVFPpFj333vRCS4iAlEtvUhUIIFJCi4AUkSYqIQkQSoghodkVUcERRUUEG8igiAOOjoCMFVEsDIoK2AfkIaKOg6OIisr74Xuja9a89%2BbN%2FrXXPues852zzwfACAyWSDNRNYAMqUIeEeCDx8TG4eQuQIEKJHAAEAizZCFz%2FSMBAPh%2BPDwrIsAHvgABeNMLCADATZvAMByH%2Fw%2FqQplcAYCEAcB0kThLCIAUAEB6jkKmAEBGAYCdmCZTAKAEAGDLY2LjAFAtAGAnf%2BbTAICd%2BJl7AQBblCEVAaCRACATZYhEAGg7AKzPVopFAFgwABRmS8Q5ANgtADBJV2ZIALC3AMDOEAuyAAgMADBRiIUpAAR7AGDIIyN4AISZABRG8lc88SuuEOcqAAB4mbI8uSQ5RYFbCC1xB1dXLh4ozkkXKxQ2YQJhmkAuwnmZGTKBNA%2Fg88wAAKCRFRHgg%2FP9eM4Ors7ONo62Dl8t6r8G%2FyJiYuP%2B5c%2BrcEAAAOF0ftH%2BLC%2BzGoA7BoBt%2FqIl7gRoXgugdfeLZrIPQLUAoOnaV%2FNw%2BH48PEWhkLnZ2eXk5NhKxEJbYcpXff5nwl%2FAV%2F1s%2BX48%2FPf14L7iJIEyXYFHBPjgwsz0TKUcz5IJhGLc5o9H%2FLcL%2F%2Fwd0yLESWK5WCoU41EScY5EmozzMqUiiUKSKcUl0v9k4t8s%2BwM%2B3zUAsGo%2BAXuRLahdYwP2SycQWHTA4vcAAPK7b8HUKAgDgGiD4c93%2F%2B8%2F%2FUegJQCAZkmScQAAXkQkLlTKsz%2FHCAAARKCBKrBBG%2FTBGCzABhzBBdzBC%2FxgNoRCJMTCQhBCCmSAHHJgKayCQiiGzbAdKmAv1EAdNMBRaIaTcA4uwlW4Dj1wD%2FphCJ7BKLyBCQRByAgTYSHaiAFiilgjjggXmYX4IcFIBBKLJCDJiBRRIkuRNUgxUopUIFVIHfI9cgI5h1xGupE7yAAygvyGvEcxlIGyUT3UDLVDuag3GoRGogvQZHQxmo8WoJvQcrQaPYw2oefQq2gP2o8%2BQ8cwwOgYBzPEbDAuxsNCsTgsCZNjy7EirAyrxhqwVqwDu4n1Y8%2BxdwQSgUXACTYEd0IgYR5BSFhMWE7YSKggHCQ0EdoJNwkDhFHCJyKTqEu0JroR%2BcQYYjIxh1hILCPWEo8TLxB7iEPENyQSiUMyJ7mQAkmxpFTSEtJG0m5SI%2BksqZs0SBojk8naZGuyBzmULCAryIXkneTD5DPkG%2BQh8lsKnWJAcaT4U%2BIoUspqShnlEOU05QZlmDJBVaOaUt2ooVQRNY9aQq2htlKvUYeoEzR1mjnNgxZJS6WtopXTGmgXaPdpr%2Bh0uhHdlR5Ol9BX0svpR%2BiX6AP0dwwNhhWDx4hnKBmbGAcYZxl3GK%2BYTKYZ04sZx1QwNzHrmOeZD5lvVVgqtip8FZHKCpVKlSaVGyovVKmqpqreqgtV81XLVI%2BpXlN9rkZVM1PjqQnUlqtVqp1Q61MbU2epO6iHqmeob1Q%2FpH5Z%2FYkGWcNMw09DpFGgsV%2FjvMYgC2MZs3gsIWsNq4Z1gTXEJrHN2Xx2KruY%2FR27iz2qqaE5QzNKM1ezUvOUZj8H45hx%2BJx0TgnnKKeX836K3hTvKeIpG6Y0TLkxZVxrqpaXllirSKtRq0frvTau7aedpr1Fu1n7gQ5Bx0onXCdHZ4%2FOBZ3nU9lT3acKpxZNPTr1ri6qa6UbobtEd79up%2B6Ynr5egJ5Mb6feeb3n%2Bhx9L%2F1U%2FW36p%2FVHDFgGswwkBtsMzhg8xTVxbzwdL8fb8VFDXcNAQ6VhlWGX4YSRudE8o9VGjUYPjGnGXOMk423GbcajJgYmISZLTepN7ppSTbmmKaY7TDtMx83MzaLN1pk1mz0x1zLnm%2Beb15vft2BaeFostqi2uGVJsuRaplnutrxuhVo5WaVYVVpds0atna0l1rutu6cRp7lOk06rntZnw7Dxtsm2qbcZsOXYBtuutm22fWFnYhdnt8Wuw%2B6TvZN9un2N%2FT0HDYfZDqsdWh1%2Bc7RyFDpWOt6azpzuP33F9JbpL2dYzxDP2DPjthPLKcRpnVOb00dnF2e5c4PziIuJS4LLLpc%2BLpsbxt3IveRKdPVxXeF60vWdm7Obwu2o26%2FuNu5p7ofcn8w0nymeWTNz0MPIQ%2BBR5dE%2FC5%2BVMGvfrH5PQ0%2BBZ7XnIy9jL5FXrdewt6V3qvdh7xc%2B9j5yn%2BM%2B4zw33jLeWV%2FMN8C3yLfLT8Nvnl%2BF30N%2FI%2F9k%2F3r%2F0QCngCUBZwOJgUGBWwL7%2BHp8Ib%2BOPzrbZfay2e1BjKC5QRVBj4KtguXBrSFoyOyQrSH355jOkc5pDoVQfujW0Adh5mGLw34MJ4WHhVeGP45wiFga0TGXNXfR3ENz30T6RJZE3ptnMU85ry1KNSo%2Bqi5qPNo3ujS6P8YuZlnM1VidWElsSxw5LiquNm5svt%2F87fOH4p3iC%2BN7F5gvyF1weaHOwvSFpxapLhIsOpZATIhOOJTwQRAqqBaMJfITdyWOCnnCHcJnIi%2FRNtGI2ENcKh5O8kgqTXqS7JG8NXkkxTOlLOW5hCepkLxMDUzdmzqeFpp2IG0yPTq9MYOSkZBxQqohTZO2Z%2Bpn5mZ2y6xlhbL%2BxW6Lty8elQfJa7OQrAVZLQq2QqboVFoo1yoHsmdlV2a%2FzYnKOZarnivN7cyzytuQN5zvn%2F%2FtEsIS4ZK2pYZLVy0dWOa9rGo5sjxxedsK4xUFK4ZWBqw8uIq2Km3VT6vtV5eufr0mek1rgV7ByoLBtQFr6wtVCuWFfevc1%2B1dT1gvWd%2B1YfqGnRs%2BFYmKrhTbF5cVf9go3HjlG4dvyr%2BZ3JS0qavEuWTPZtJm6ebeLZ5bDpaql%2BaXDm4N2dq0Dd9WtO319kXbL5fNKNu7g7ZDuaO%2FPLi8ZafJzs07P1SkVPRU%2BlQ27tLdtWHX%2BG7R7ht7vPY07NXbW7z3%2FT7JvttVAVVN1WbVZftJ%2B7P3P66Jqun4lvttXa1ObXHtxwPSA%2F0HIw6217nU1R3SPVRSj9Yr60cOxx%2B%2B%2Fp3vdy0NNg1VjZzG4iNwRHnk6fcJ3%2FceDTradox7rOEH0x92HWcdL2pCmvKaRptTmvtbYlu6T8w%2B0dbq3nr8R9sfD5w0PFl5SvNUyWna6YLTk2fyz4ydlZ19fi753GDborZ752PO32oPb%2B%2B6EHTh0kX%2Fi%2Bc7vDvOXPK4dPKy2%2BUTV7hXmq86X23qdOo8%2FpPTT8e7nLuarrlca7nuer21e2b36RueN87d9L158Rb%2F1tWeOT3dvfN6b%2FfF9%2FXfFt1%2Bcif9zsu72Xcn7q28T7xf9EDtQdlD3YfVP1v%2B3Njv3H9qwHeg89HcR%2FcGhYPP%2FpH1jw9DBY%2BZj8uGDYbrnjg%2BOTniP3L96fynQ89kzyaeF%2F6i%2FsuuFxYvfvjV69fO0ZjRoZfyl5O%2FbXyl%2FerA6xmv28bCxh6%2ByXgzMV70VvvtwXfcdx3vo98PT%2BR8IH8o%2F2j5sfVT0Kf7kxmTk%2F8EA5jz%2FGMzLdsAAAAEZ0FNQQAAsY58%2B1GTAAAAIGNIUk0AAHolAACAgwAA%2Bf8AAIDpAAB1MAAA6mAAADqYAAAXb5JfxUYAAAN8SURBVHjaVJFNTBxlAIafb2Z29gd2l4VdYCkokAUt1AJplQRTrVqjUWMPPWHSCzb21IOn9qIHY2xMahoTTb00NmkUm5qAjdpUI61VaCxCpCVYixt%2ByvKzCwu7LDs7zMw3HmhM%2Bt6fJ0%2FyCp69wiOzZBCPcqSmIXg0HPHuC4R8nkLWyOXyYiIzfuVHzMIA%2BZsLtH18EApntUdhpzUSD5577nDLi%2FGWKjx%2BHVfR8HpFwNwsxTMzza%2BOXJ1%2B58Ev2sVEV%2ByEawXqxf8FllNWEQ9ePXzsqQOecIDU8jampSAVD76Al2BIIx4Dv2Nz7%2FYq%2B5%2BP8sNXE6WdAhdQlOM9rzUdaGiN8M9UjnKvQjzuA0UjV3AxDIcHywqRoEbXoVrKgyBtKXYEUvprmiN9oaoyvr9wl62NHJbtJeDzOo17YmprVzWOppLO2RRNwf1FSOzSUAXsCIR4QdP13UPfjhUde2mjuBXUjcXNEabOnJmq7Y4Nd7z1fu%2BJ%2FR2Jpgrm0jauAI8GlnSlBi4I0bO6sLBWHc9esxRdmjOZf5n%2B5CLWzCzOvsbKupBZ1xgmElUoC%2BgoKtRGQfNomoaND8P8XS%2Bby1olO7O6GHTl1DejGDOrNB%2BvpO7I%2Ba31%2FDP9Z28YUmqoqhCKcG2EYD6ZMUTojZ8WHmsqD%2BI6wnWFajugCkuuZaV%2FZS47wp99R7E3LbxPV6rtr7dV1pmyuBWs3hr7dZ380LC2tzseffvUHm86C1JC2A%2FrGcn509cn%2BPvTk9ibc1R06qL91Ms1CadF000ll9rVS2VykLzVr0lHOgtpuJ9yUFyXxqhKZjbH2nJRI9IZwyw2kXjvXV%2FIOWgaBcc2a%2BtjdVXR1J3iBDx8QUpQUJAuJJclseogxz441H5vrPO72cm0VSyVPJq27ZaHm8ST3Y0M9d9Kkr19A1A1x4VIObTGBfNrsJ5XmE9b6KqgvrOGhr1Vns2sgeNIkXiigvHf1liZuHWZYjINSEXRVLewZjN6bYmYbvN4rcDvVzFKLnOpErMLBpvbklClznyyyPDA6DjTX3wJWICr%2Bnb3ffjXSGpl5Nxnn88uh2ORUCBaHfVQU%2BsjVuGhKqJT5lFYShr8fGH4j42bH53EnJ4EtgEEPQOTzHx9mqXLl9AT9TS82RvreOmVcMTXVh4JhIr5kp3LFu6u3Lk%2ByMylQazU3ENYAvw3AFUTimFqj5i7AAAAAElFTkSuQmCC") no-repeat !important;	
      border-width: thin !important;
      border-radius: 4px !important;
      border-color: #aecff7 !important;
      border-style: solid !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(3){
      appearance:none!important;
      background: url("") no-repeat !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(3):hover{
      appearance:none!important;
      margin-right: -1px !important;
      background: #ecf0f6 url("") no-repeat !important;	
      border-width: thin !important;
      border-radius: 4px !important;
      border-color: #aecff7 !important;
      border-style: solid !important;
      min-height: 24px!important;
      padding-top: 7px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #ExtraConfigMenu-button > menupopup > menuitem:first-child,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(5),
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(6),
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(7),
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(8),
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(9){
      appearance:none!important;
      background: url("") no-repeat !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #ExtraConfigMenu-button > menupopup > menuitem:first-child:hover,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(5):hover,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(6):hover,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(7):hover,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(8):hover,
      #ExtraConfigMenu-button > menupopup > menuitem:nth-child(9):hover{
      appearance:none!important;
      margin-right: -1px !important;
      background: #ecf0f6 url("") no-repeat !important;	
      border-width: thin !important;
      border-radius: 4px !important;
      border-color: #aecff7 !important;
      border-style: solid !important;
      min-height: 24px!important;
      padding-top: 7px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #submenu-about{
      appearance:none!important;
      background: url("") no-repeat !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #submenu-about:hover{
      appearance:none!important;
      margin-right: -1px !important;
      background: #ecf0f6 url("") no-repeat !important;	
      border-width: thin !important;
      border-radius: 4px !important;
      border-color: #aecff7 !important;
      border-style: solid !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #submenu-about-items > menuitem:nth-child(-n+20){
      appearance:none!important;
      background: url("") no-repeat !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #submenu-about-items > menuitem:nth-child(-n+20):hover{
      appearance:none!important;
      margin-right: -1px !important;
      background: #ecf0f6 url("") no-repeat !important;	
      border-width: thin !important;
      border-radius: 4px !important;
      border-color: #aecff7 !important;
      border-style: solid !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #submenu-ucjs{
      appearance:none!important;
      background: url("") no-repeat !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #submenu-ucjs:hover{
      appearance:none!important;
      margin-right: -1px !important;
      background: #ecf0f6 url("") no-repeat !important;	
      border-width: thin !important;
      border-radius: 4px !important;
      border-color: #aecff7 !important;
      border-style: solid !important;
      min-height: 24px!important;
      padding-top: 7px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #submenu-ucxul{
      appearance:none!important;
      background: url("") no-repeat !important;
      min-height: 24px!important;
      padding-top: 5px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      #submenu-ucxul:hover{
      appearance:none!important;
      margin-right: -1px !important;
      background: #ecf0f6 url("") no-repeat !important;	
      border-width: thin !important;
      border-radius: 4px !important;
      border-color: #aecff7 !important;
      border-style: solid !important;
      min-height: 24px!important;
      padding-top: 2px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      .uProfMenu_ucjs,.uProfMenu_ucxul{
      appearance:none!important;
      background: url("") no-repeat !important;
      min-height: 24px!important;
      padding-top: 7px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
    
      .uProfMenu_ucjs:hover,.uProfMenu_ucxul:hover{
      appearance:none!important;
      margin-right: -1px !important;
      background: #ecf0f6 url("") no-repeat !important;	
      border-width: thin !important;
      border-radius: 4px !important;
      border-color: #aecff7 !important;
      border-style: solid !important;
      min-height: 24px!important;
      padding-top: 7px! important;
      padding-left:28px!important;
      background-position:6px 5px!important;}
      }
    Alles anzeigen

    Icons liegen zuhauf im Unterordner des Chrome-Ordners.

    Wer kann da helfen? :)

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 13. Januar 2025 um 17:49

    Danke, dann mach ich das mal peu a peu 8)

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 13. Januar 2025 um 17:23

    Gibts eine Liste, in der die bereits umgeschriebenen Scripte aufgeführt sind?
    Ich nutze 75 Scripte und würde gerne, ohne den ganzen Thread zu durchsuchen, abgleichen, welche schon geändert sind, bzw, welche nicht geändert werden müssen!

    userChromeJS/uc.js (75):
    ------------------------
    AAAAStatusleiste.uc.js
    About_Dialog schliessen.uc.js
    AddBookmarkHere.uc.js
    Addons-Update-Check-Button1.uc.js
    AddonsPage.uc.js
    AnimationToggleButton.uc.js
    Anzahl der Ordner und Lesezeichen.uc.js
    AutoPopup.uc.js
    Back-forward.uc.js
    BackToTop.uc.js
    BackupProfile_Nightly.uc.js
    Blur2revert.uc.js
    BookmarkCount.uc.js
    Bookmarks-Manager-Button.uc.js
    BuildIdToAboutDialogue.uc.js
    Button Erweiterungen verschieben.uc.js
    ChangePassword.uc.js
    ClearCacheButtonMovable.uc.js
    CloseBlankTabOnCloseDownloadDialog.uc.js
    CloseDownloadDialogTab.uc.js
    ContextSearcher.uc.js
    Context_Translate_Deepl.com.uc.js
    CSSLive.uc.js
    Cursor in der URLBar.uc.js
    DownloadStatusModoki.uc.js
    EnableAutoLogin.uc.js
    Extras_Config_Menu.uc.js
    FavIconInURLBar.uc.js
    FindWrapPlayBeep.uc.js
    Firefox Kontextmenuefixer hinsichtlich Unterstreichungen.uc.js
    FirefoxButtons.uc.js
    FxForumNewTab.uc.js
    Gegen leere Tabs.uc.js
    Hamburger-Symbol.uc.js
    JsOff.uc.js
    LinkifiesLocationBar.uc.js
    Loading Bar.uc.js
    Mediasource ein und ausschalten.uc.js
    MemoryMonitorMod.uc.js
    Mousehover, Lesezeichenordner auf.uc.js
    MoveReloadIntoUrl.uc.js
    Neuer Tab wg Statusleiste.uc.js
    OpenBookModoki.uc.js
    OpenSearchNotification.uc.js
    Open_Password_Tab.uc.js
    Per Doppelklick auf Tab neuer Tab.uc.js
    PreferencesButton.uc.js
    Print_Preview.uc.js
    PrivateToolMenus.uc.js
    RAMBack.uc.js
    Rechtsklicksperre beseitigen.uc.js
    RestartButton.uc.js
    Revert_Stop_Reload_Button.uc.js
    SaveUCJS_lite.uc.js
    Scrollbars.uc.js
    ScrollWheel.uc.js
    ShowParentFolder.uc.js
    Space and Separatoren Restorer.uc.js
    Suchfeld immer leeren.uc.js
    Suchleiste auf Webseiten mit Doppelklick öffnen+schließen.uc.js
    SupportMozilla_Firefox.uc.js
    TabFocus.uc.js
    TabNumber.uc.js
    TooltipStyling.uc.js
    UhrinderNavBar_Nightly.uc.js
    UndoBookmarksContextMenu.uc.js
    UndoListInTabmenuToo_New.uc.js
    UpdateBookmark2mod.uc.js
    Updates Button.uc.js
    userChromeShadow.uc.js
    UserCSSLoader.uc.js
    Verzoegerung der Webseitendurchsuchung.uc.js
    Warn on Close.uc.js
    Wetterfuchsbutton.uc.js
    Zum_Anfang_oder_Ende_springen.uc.js

    Da ich manchen Scripten teilweise eigene Namen verpasst habe, ist es natürlich schwierig.

    Eins habe ich bereits hier gefunden und geändert, das hat nun ein _New am Ende der Bezeichnung.

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 9. Januar 2025 um 18:41

    Das schrieb ja auch Sören schon, dann müssen vermutlich diverse Scripts angepasst werden.
    Du hattest gesagt, dass die Zeile daran schuld ist, sie wird von Andreas aber auch so genutzt.
    Schliesslich teiltest du mit, dass es mit der Nichtänderung des Schlüsselwertes derzeit noch keine Lösung gibt. Das war aber bis zu deinem Eintritt in diesen Thread unstrittig und gar kein Thema. Dieser Diskussionspunkt wurde von dir eingebracht.

    Wenn du eine Lösung hast, wenn der Schlüssel nicht mehr zur Verfügung steht, bitte gerne hier oder in einem neuen Thread mitteilen. Danke! ;)

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 9. Januar 2025 um 18:23
    Zitat von milupo

    Boersenfeger will sicherlich die neue Zeile, mit security.browser_xhtml_csp.enabled auf true.

    Nee, will ich nicht..

  • Seit heute funktioniert die Sidebar via Hover einblenden mit einem CSS-Code bei Nightly 136 nicht mehr

    • Boersenfeger
    • 9. Januar 2025 um 18:23

    Tja, ist so...

  • Seit heute funktioniert die Sidebar via Hover einblenden mit einem CSS-Code bei Nightly 136 nicht mehr

    • Boersenfeger
    • 9. Januar 2025 um 17:47

    Es hatte was mit diesem Schlüssel zu tun: security.browser_xhtml_csp.enabled

    Auf false gesetzt, neu gestartet und die Zeile entsprechend auf diesen Wert geändert margin-left: -250px !important;

    Problem gelöst! :D
    Dankeee!

  • Seit heute funktioniert die Sidebar via Hover einblenden mit einem CSS-Code bei Nightly 136 nicht mehr

    • Boersenfeger
    • 9. Januar 2025 um 17:35

    Jetzt geht gar nix mehr ;(

    CSS
    @-moz-document url("chrome://browser/content/places/bookmarksSidebar.xhtml"),
                   url("chrome://browser/content/browser.xhtml") {
    
    				   
    #sidebar-main > sidebar-main {
        display: none !important;
    }
    
    #sidebar-box {
        display: flex !important;
        position: absolute !important;
        top: 107px;
        bottom: 27px;
        width: 260px !important;
        z-index: 100 !important;
        opacity: 0 !important;
        margin-left: -220px !important;
        transition: margin-left .5s linear .4s, opacity .6s ease-in .2s !important;
    }
    
    #sidebar-box:hover {
        z-index: 100 !important;
        opacity: 1 !important;
        margin-left: 0 !important;
        transition: margin-left .66s !important;
    }
    
    #bookmarks-view-children {
        margin-top: -100px !important;
        margin-left: -15px !important;
    }
    
    #sidebar-splitter {
        display: none !important;
    }
    
    #sidebar-header {
        display: none !important;
    }
    
    /* Beschriftungsende anpassen */
    treechildren::-moz-tree-cell,
    treechildren::-moz-tree-cell-text {
        margin-inline-end: -8px !important;
    }
    
    /* Lesezeichensidebar Icon-Abstand zur linken Seite */
    .sidebar-placesTreechildren[view="bookmarks-view"] {
        margin-left: -10px !important;
    }
    
    /* Lesezeichensidebar Icon-Abstand */
    #bookmarks-view-children:-moz-tree-image {
        margin-right: 5px !important;
    }
    
    /* Suchsymbol in der Sidebar ausblenden */
    .textbox-search-sign {
        display: none !important;
    }
    
    textbox input.textbox-input::-moz-placeholder,
    #search-container input.textbox-input::-moz-placeholder,
    #urlbar input.textbox-input::-moz-placeholder {
        color: transparent !important;
    }
    
    /* Suchleiste Schrift-Größe einstellen */
    .sidebar-placesTreechildren,
    sidebarheader,
    #sidebar-search-label,
    #search-box {
        font-size: 16px !important;
        font-family: Comic Sans MS, sans-serif !important;
    }
    
    /* Sidebar Hintergrundfarbe */
    #sidebar {
        background: #c1e7bb !important;
        opacity: 1 !important;
    }
    
    /* Lesezeichen-Sidebar Suchfeld und auch Haupt-Suchfeld ohne Eintrag */
    ::placeholder {
        color: transparent !important;
    }
    
    /* Lesezeichen Sidebar öffnende Dreiecke entfernen */
    #bookmarksPanel treechildren::-moz-tree-twisty(closed),
    #bookmarksPanel treechildren::-moz-tree-twisty(open) {
        height: 0!important;
        width: 0!important;
        display: none!important;
    }
    
    /* Lesezeichen verwalten */
    treechildren::-moz-tree-image(container) {
        list-style-image: url('') !important;
    }
    
    /* Zeilenhöhe reduzieren */
    .sidebar-placesTree treechildren::-moz-tree-row,
    .placesTree treechildren::-moz-tree-row {
        min-height: 20px !important;
    }
    
    /* Ordner aus der Sidebar ausblenden */
    .sidebar-placesTreechildren[view="bookmarks-view"] {
    
        margin-top: -10px!important;
    }
    
    /* Fokusring um Ordner entfernen */
    treechildren {
        --default-focusring: 0px !important;
    }
    }
    Alles anzeigen

    Die Sidebar verschwindet nicht mehr und die kosmetischen Änderungen wie Farbe und Schriftgrösse etc. sind weg..

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 9. Januar 2025 um 17:17

    und wie heisst dann die Zeile korrekt?

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 9. Januar 2025 um 17:11

    Stimmt, ich hatte da das UpDate noch nicht installiert... danach ist das mit dem Wert true auch hier so mit meiner Scriptversion aus #8

  • Seit heute funktioniert die Sidebar via Hover einblenden mit einem CSS-Code bei Nightly 136 nicht mehr

    • Boersenfeger
    • 9. Januar 2025 um 17:05

    Doch noch eine Nachfrage:

    Wenn ich mich mit dem Mauszeiger dem linken Rand nähere, wird die Sidebar schon recht früh ausgeklappt.
    Dies soll erst geschehen, wenn der Zeiger ca 2cm vor dem Rand steht. Gibts da eine Möglichkeit? :)

  • Div. Skripte funktionieren im aktuellem Nightly nicht mehr

    • Boersenfeger
    • 9. Januar 2025 um 17:01

    BTW: Der Eintrag, den Sören in #2 ansprach, ist hier nicht vorhanden.:/

Unterstütze uns!

Jährlich (2025)

92,9 %

92,9% (604,17 von 650 EUR)

Jetzt spenden
  1. Kontakt
  2. Datenschutz
  3. Impressum
Community-Software: WoltLab Suite™
Mastodon