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. lenny2

Beiträge von lenny2

  • Firefox v136.0 - Skript "export_folder_to_html.uc.js" funktioniert nicht mehr

    • lenny2
    • 7. März 2025 um 15:21

    milupo Der Code wurde von einem Campusnachbarn zur Verfügung gestellt. Das Skript kann durch die Erweiterung Selective Bookmarks Export Tool v1.6.0 ersetzt werden. Es leistet gute Arbeit beim teilweisen Exportieren von Lesezeichen, auch aus dem Lesezeichenbedienfeld. Vielen Dank für Ihre Hilfe.

  • Firefox v136.0 - Skript "export_folder_to_html.uc.js" funktioniert nicht mehr

    • lenny2
    • 7. März 2025 um 07:24

    milupo  Speravir Nichts hat geholfen, der Speicherdialog erscheint nicht.
    Normalerweise ist der Algorithmus wie folgt: Wenn Sie klicken, erscheint der Standard-Speicherdialog, der Name des exportierten Ordners wird automatisch in den Dateinamen eingefügt, z. B. Android.html. Die Exportdatei wird an dem vom Benutzer gewählten Ort gespeichert.
    Wenn Sie die Exportdatei in einem Browser öffnen, sieht sie wie folgt aus

  • Firefox v136.0 - Skript "export_folder_to_html.uc.js" funktioniert nicht mehr

    • lenny2
    • 6. März 2025 um 18:19
    Zitat von milupo

    den Kontextmenüeintrag anzuzeigen.

    Es war vorher da, hat aber die Speicheraktion nicht ausgeführt.

  • Firefox v136.0 - Skript "export_folder_to_html.uc.js" funktioniert nicht mehr

    • lenny2
    • 6. März 2025 um 17:44

    Es ist eine Schande, aber nichts hat funktioniert :(

  • Firefox v136.0 - Skript "export_folder_to_html.uc.js" funktioniert nicht mehr

    • lenny2
    • 6. März 2025 um 15:30

    Dieses Skript funktioniert nicht mehr in v136.0. Vielen Dank für Ihre Hilfe!

    JavaScript
    // export_folder_to_html.uc.js
    // Exports folder bookmarks to HTML file
    // Item "Export folder to HTML" in the context menu of the folder in “Manage Bookmarks” and Sidebar
    (async topic => {
        var imp = (m, n = m) => Cu.import(`resource://gre/modules/${m}.jsm`, {})[n];
        var exporter = {
            get dps() {
                delete this.dps;
                return this.dps = imp("DownloadPaths");
            },
            get exporter() {
                delete this.exporter;
                return this.exporter = imp("BookmarkHTMLUtils", "BookmarkExporter");
            },
            async export(popup) {
                var win = popup.ownerGlobal, tn = popup.triggerNode;
                var node, pu = win.PlacesUtils, bm = pu.bookmarks;
                if (tn.nodeName == "treechildren") node = popup._view.selectedNode;
                else if (tn.id == "OtherBookmarks")
                    node = {bookmarkGuid: bm.unfiledGuid, title: tn.getAttribute("label")};
                else node = tn._placesNode || popup._view.result.root;
                var fp = Cc["@mozilla.org/filepicker;1"].createInstance(Ci.nsIFilePicker);
                fp.init(win, win.PlacesUIUtils.promptLocalization.formatValueSync("places-bookmarks-export"), fp.modeSave);
                fp.appendFilters(fp.filterHTML);
                fp.defaultString = (node.title ? this.dps.sanitize(node.title) : "untitled") + ".html";
                if (await new Promise(fp.open) == fp.returnCancel) return;
                var tree = await pu.promiseBookmarksTree(pu.getConcreteItemGuid(node), {includeItemIds: true});
                tree.title = bm.getLocalizedTitle(tree);
                var bookmarks = {children: [
                    {root: "toolbarFolder"},
                    {root: "unfiledBookmarksFolder"},
                    {root: "bookmarksMenuFolder", children: [tree], guid: bm.menuGuid}
                ]};
                new this.exporter(bookmarks).exportToFile(fp.file.path);
            },
            observe(doc) {
                var popup = doc.querySelector("menupopup#placesContext");
                if (!popup) return;
                var menuitem = (doc.createXULElement || doc.createElement).call(doc, "menuitem");
                for(var args of Object.entries({
                    label: "Export folder to HTML",
                    selection: "folder",
                    "node-type": "folder",
                    "selection-type": "single|none",
                    id: "placesContext_exportFolder",
                    oncommand: "exporter.export(parentNode);"
                }))
                    menuitem.setAttribute(...args);
                menuitem.exporter = this;
                doc.getElementById("placesContext_openSeparator").before(menuitem);
            }
        };
        Services.obs.addObserver(exporter, topic);
        Services.obs.addObserver(function quit(s, t) {
            Services.obs.removeObserver(quit, t);
            Services.obs.removeObserver(exporter, topic);
        }, "quit-application-granted");
    })("chrome-document-loaded");
    Alles anzeigen
  • Steurungsmöglichkeiten bzgl. about:config-Einträgen -> Aktivierung bzw. Deaktivierung von Java-Script per shortcut

    • lenny2
    • 6. März 2025 um 14:46
    Zitat von Jogi32

    about:config javascript.enabled

    Natürlich ist es besser, auf v136.0 zu aktualisieren.
    Skript

  • Oblivious HTTP und DAP

    • lenny2
    • 1. März 2025 um 12:52

    Introducing a terms of use and updated privacy notice for Firefox
    Firefox Terms of Use
    Firefox Privacy Notice

  • Trotz Einstellung Downloads in /downloads Verzeichnis

    • lenny2
    • 23. Februar 2025 um 06:37

    Dieses Verhalten beim Booten begann um v98 (noch nicht in v91).

  • Trotz Einstellung Downloads in /downloads Verzeichnis

    • lenny2
    • 22. Februar 2025 um 15:52

    Öffnen Sie das User Manual (PDF) in Firefox, wird die Datei nicht nur geöffnet, sondern auch auf Ihrer Festplatte gespeichert. Die von mir angegebene Einstellung vermeidet das unnötige Speichern.

  • Trotz Einstellung Downloads in /downloads Verzeichnis

    • lenny2
    • 22. Februar 2025 um 11:24

    Wenn ich Ihr Problem richtig verstehe, ändern Sie in about:config
    browser.download.start_downloads_in_tmp_dir = true

  • Wiederherstellen meines alten Profils und damit auch meiner Lesezeichen nicht möglich.

    • lenny2
    • 22. Februar 2025 um 07:26

    Sonnenfreundin Entfernen Sie die Datei compatibility.ini aus dem alten v135-Profil und das Profil wird in v128 akzeptiert.
    Um nur die Lesezeichen zu migrieren, übertragen Sie die Dateien favicons.sqlite und places.sqlite aus dem alten v135-Profil in das neue v128-Profil.

  • Tabname oder URL in Zwischenablage kopieren

    • lenny2
    • 20. Februar 2025 um 08:49

    Dr.Rock Schade, dass Sie die Erweiterung nicht nutzen wollen. So könnte es aussehen

  • userChrome.js Scripte für den Fuchs (Diskussion)

    • lenny2
    • 9. Februar 2025 um 14:57

    Das Skript bietet vier Optionen für die Erstellung eines Screenshots einer Seite

    JavaScript
    // SavePageAsPNG.uc.js
    (async func => CustomizableUI.createWidget({
        id: "SavePageAsPNG",
        label: "Save Page As PNG",
        tooltiptext: "Save Page As PNG",
        localized: false,
        // defaultArea: CustomizableUI.AREA_NAVBAR,
        onCreated(btn) {
            var win = btn.ownerGlobal;
            new win.Function("_id, xhtmlns, addDestructor", func.toString().slice(7, -1)).call(
                btn, this.id, "http://www.w3.org/1999/xhtml",
                destructor => win.addEventListener("unload", destructor, {once: true})
            );
            btn.setAttribute("image", "");
        }
    }))(() => {
    
    ((main, parts) => this._handleClick = () => {
        var df = MozXULElement.parseXULToFragment(`
            <menupopup>
                <menuitem class="menuitem-iconic"
                    image=""
                    label="Save whole page as PNG"
                    value="all"/>
                <menuitem class="menuitem-iconic"
                    image=""
                    label="Save visible part of the page as PNG"
                    value="page"/>
                <menuitem class="menuitem-iconic"
                    image=""
                    label="Save selected page element as PNG"
                    value="click"/>
                <menuitem class="menuitem-iconic"
                    image=""
                    label="Save selected page area as PNG"
                    value="clipping"/>
            </menupopup>
        `);
        var popup = df.firstChild;
        popup.setAttribute("context", "");
        popup.addEventListener("command", e => popup.handleCommand(e));
        popup.handleCommand = e => {
            var name = _id + ":DataURLReady";
            main = main.replace("%MESSAGE_NAME%", name);
            var urls = {}, configurable = true, enumerable = true;
            Object.entries(parts).forEach(([key, part]) => Object.defineProperty(urls, key, {
                configurable, enumerable, get() {
                    var value = `data:;charset=utf-8,({${
                        encodeURIComponent(main + part)
                    }%0A}).init("${key}")`;
                    Object.defineProperty(urls, key, {configurable, enumerable, value});
                    return value;
            }}));
            // Get tab name without non-saved characters and extra spaces
            var getTabLabel = () => {
                var label = gBrowser.selectedTab.label;
                var label = label.replace(/[:+.\\\/<>?*|"]+/g, " ").replace(/\s\s+/g, " ");
                return label.substring(0, 50);
            }
            var listener = msg => {
                var fp = makeFilePicker();
                // fp.init(window, "Save As…", fp.modeSave);
                fp.init(
                    !("inIsolatedMozBrowser" in window.browsingContext.originAttributes)
                      ? window.browsingContext
                      : window
                    , "Save As…", fp.modeSave);
                fp.appendFilter("", "*.png");
                var fileName = getTabLabel();
                fileName = fileName.replace(/[:\\\/<>?*|"]+/g, '').replace(/\s+/g, '_').slice(0, 100).replace(/^\s+|\s+$/g, '');
                var fileDate = (function () {
                  var d = new Date(), z = function(n){return (n < 10 ? '0' : '') + n};
                  return '[' + z(d.getFullYear()) + '_' + z(d.getMonth()+1) + '_' + z(d.getDate()) + '\u2014' + z(d.getHours()) + '_' + z(d.getMinutes()) + '_' + z(d.getSeconds()) + ']';
                })();
                fp.defaultString = fileName + "_" + fileDate + ".png";
                fp.open(res => res == fp.returnCancel || !fp.file || makeWebBrowserPersist().saveURI(
                    Services.io.newURI(msg.data), document.nodePrincipal,
                    null, null, null, null, null, fp.file, null, null
                ));
            }
            messageManager.addMessageListener(name, listener);
            addDestructor(() => messageManager.removeMessageListener(name, listener));
            (popup.handleCommand = e => gBrowser.selectedBrowser.messageManager
                .loadFrameScript(urls[e.target.value], false)
            )(e);
        }
        this.append(df);
        (this._handleClick = () => popup.openPopup(this, "after_start"))();
    })(`
        init(cmd) {
            cmd.startsWith("c")
                ? this[cmd].init(this[cmd].parent = this)
                : this[cmd]();
        },
        capture(win, x, y, width, height) {
            var canvas = win.document.createElementNS("${xhtmlns}", "canvas");
            canvas.width = width;
            canvas.height = height;
            var ctx = canvas.getContext("2d");
            var tryDraw = ind => {
                try {ctx.drawWindow(win, x, y, canvas.width, canvas.height, "white")}
                catch(ex) {canvas.height = ind * canvas.width; tryDraw(--ind);}
            }
            tryDraw(17);
            sendAsyncMessage("%MESSAGE_NAME%", canvas.toDataURL("image/png"));
        },
        `, {
        all: `all() {
            var win = content;
            this.capture(win, 0, 0, win.innerWidth + win.scrollMaxX, win.innerHeight + win.scrollMaxY);
        }`,
        page: `page() {
            var win = content, doc = win.document, body = doc.body, html = doc.documentElement;
            var scrX = (body.scrollLeft || html.scrollLeft) - html.clientLeft;
            var scrY = (body.scrollTop || html.scrollTop) - html.clientTop;
            this.capture(win, scrX, scrY, win.innerWidth, win.innerHeight);
        }`,
        clipping: `clipping: {
            handleEvent(e) {
                if (e.button) return false;
                e.preventDefault();
                e.stopPropagation();
                switch(e.type) {
                    case "mousedown":
                        this.downX = e.pageX;
                        this.downY = e.pageY;
                        this.bs.left = this.downX + "px";
                        this.bs.top = this.downY + "px";
                        this.body.appendChild(this.box);
                        this.flag = true;
                        break;
                    case "mousemove":
                        if (!this.flag) return;
                        this.moveX = e.pageX;
                        this.moveY = e.pageY;
                        if (this.downX > this.moveX) this.bs.left = this.moveX + "px";
                        if (this.downY > this.moveY) this.bs.top  = this.moveY + "px";
                        this.bs.width = Math.abs(this.moveX - this.downX) + "px";
                        this.bs.height = Math.abs(this.moveY - this.downY) + "px";
                        break;
                    case "mouseup":
                        this.uninit();
                        break;
                }
            },
            init() {
                var win = {};
                Cc["@mozilla.org/focus-manager;1"].getService(Ci.nsIFocusManager)
                    .getFocusedElementForWindow(content, true, win);
                this.win = win.value;
                this.doc = this.win.document;
                this.body = this.doc.body;
                if (!HTMLBodyElement.isInstance(this.body)) {
                    Cc["@mozilla.org/alerts-service;1"].getService(Ci.nsIAlertsService)
                        .showAlertNotification("${self.image}", ${JSON.stringify(self.label)}, "Не удается захватить!");
                    return false;
                }
                this.flag = null;
                this.box = this.doc.createElement("div");
                this.bs = this.box.style;
                this.bs.border = "red dashed 1px";
                this.bs.position = "absolute";
                this.bs.zIndex = "2147483647";
                this.defaultCursor = this.win.getComputedStyle(this.body, "").cursor;
                this.body.style.cursor = "crosshair";
                ["click", "mouseup", "mousemove", "mousedown"].forEach(type=> this.doc.addEventListener(type, this, true));
            },
            uninit() {
                var pos = [this.win, parseInt(this.bs.left), parseInt(this.bs.top), parseInt(this.bs.width), parseInt(this.bs.height)];
                this.body.style.cursor = this.defaultCursor;
                this.body.removeChild(this.box);
                this.parent.capture.apply(this, pos);
                ["click", "mouseup", "mousemove", "mousedown"].forEach(type=> this.doc.removeEventListener(type, this, true));
            }
        }`,
        click: `click: {
            getPosition() {
                var html = this.doc.documentElement;
                var body = this.doc.body;
                var rect = this.target.getBoundingClientRect();
                return [
                    this.win,
                    Math.round(rect.left) + (body.scrollLeft || html.scrollLeft) - html.clientLeft,
                    Math.round(rect.top) + (body.scrollTop || html.scrollTop) - html.clientTop,
                    parseInt(rect.width),
                    parseInt(rect.height)
                ];
            },
            highlight() {
                this.orgStyle = this.target.hasAttribute("style") ? this.target.style.cssText : false;
                this.target.style.cssText += "outline: red 1px solid; outline-offset: 1px; -moz-outline-radius: 2px;";
            },
            lowlight() {
                if (this.orgStyle) this.target.style.cssText = this.orgStyle;
                else this.target.removeAttribute("style");
            },
            handleEvent(e) {
                switch(e.type){
                    case "click":
                        if (e.button) return;
                        e.preventDefault();
                        e.stopPropagation();
                        this.lowlight();
                        this.parent.capture.apply(this, this.getPosition());
                        this.uninit();
                        break;
                    case "mouseover":
                        if (this.target) this.lowlight();
                        this.target = e.target;
                        this.highlight();
                        break;
                }
            },
            init() {
                this.win = content;
                this.doc = content.document;
                ["click", "mouseover"].forEach(type=> this.doc.addEventListener(type, this, true));
            },
            uninit() {
                this.target = false;
                ["click", "mouseover"].forEach(type=> this.doc.removeEventListener(type, this, true));
            }
        }`
    });
    });
    Alles anzeigen
  • Mein Sidebar Script funktioniert seit einiger Zeit nicht mehr. Was muss angepasst werden? Gibt es bessere Alternativen?

    • lenny2
    • 9. Februar 2025 um 14:26
    Zitat von 2002Andreas

    teste bitte:

    Danke :thumbup:

  • Mein Sidebar Script funktioniert seit einiger Zeit nicht mehr. Was muss angepasst werden? Gibt es bessere Alternativen?

    • lenny2
    • 9. Februar 2025 um 12:42

    2002Andreas Haben Sie den CSS-Code aus Beitrag #5 für v136 angepasst?

  • Mozilla veröffentlicht Firefox 135

    • lenny2
    • 5. Februar 2025 um 13:52

    Ich weiß nicht, in welchem Thread dies gepostet werden könnte. In Firefox v135.0 müssen Sie die Werte von zwei Parametern in about:config auf die Werte von v128.7.0esr oder v134 setzen, um die Darstellung von Schriften zu verbessern.

  • Firefox v136.0a1-OpenWith.uc.js funktioniert nicht mehr

    • lenny2
    • 4. Februar 2025 um 07:39

    Dieses Skript funktioniert definitiv.

  • Eintrag im Kontextmenü der URL-Bar anpassen

    • lenny2
    • 3. Februar 2025 um 16:19

    v136, v135

    CSS
    [data-l10n-id="main-context-menu-copy-clean-link"]::before, #strip-on-share::before {
       background: url("file:///D:/Firefox/Profiles/Chrome/icons/link.png")!important;

    v128, v134

    CSS
    [data-l10n-id="main-context-menu-strip-on-share-link"]::before, #strip-on-share::before {
       background: url("file:///D:/Firefox/Profiles/Chrome/icons/link.png")!important;
  • userChrome.js Scripte für den Fuchs (Diskussion)

    • lenny2
    • 3. Februar 2025 um 13:56

    Page info im Hauptkontextmenü (kompatibel mit Firefox v136.0a1)

    JavaScript
    // Page_Info_in_Context.uc.js
    (async (
       id = "context-viewPageInfo",
       image = "",
    
       subst = `${id.toLowerCase()}-img`,
       PHandler = Services.io.getProtocolHandler("resource").QueryInterface(Ci.nsIResProtocolHandler)
    ) => {
       if (location != "chrome://browser/content/browser.xhtml") return;
       if (!PHandler.hasSubstitution(subst))
           PHandler.setSubstitution(subst, Services.io.newURI(image));
       var menuitem = document.createXULElement("menuitem");
       document.getElementById("context-viewsource").before(menuitem);
       var hidden = () => {
           var d = nsContextMenu.contentData, {context, browser} = d;
           return context.link || d.selectionInfo.text || context.onImage || context.onCanvas || context.onVideo || context.onAudio || context.onTextInput || browser.className.startsWith("webext");
       }
       menuitem.hidden = true;
       menuitem.render = () => {
           if (hidden()) return;
           menuitem.hidden = false;
           menuitem.id = `${id}`;
           menuitem.label = "Page Info";
           delete menuitem.render;
           menuitem.className = "menuitem-iconic";
           menuitem.style.cssText = `list-style-image:url("resource://${subst}");`;
           menuitem.addEventListener("command", () => gContextMenu.viewInfo());
           menuitem.render();
           menuitem.render = () => menuitem.hidden = hidden();
       }
    })(); 
    Alles anzeigen
  • Neues Profil, Nightly-Icon in der Taskleiste ziert ein Einkaufswagen

    • lenny2
    • 1. Februar 2025 um 10:46

    Ist der neue ProfilManager in v136.0a1 verfügbar?

Unterstütze uns!

Jährlich (2025)

104,5 %

104,5% (679,10 von 650 EUR)

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