Полезная информация

Список ответов на каверзные вопросы можно получить в FAQ-разделе форума.

№175103-09-2024 23:06:01

xrun1
Участник
 
Группа: Members
Зарегистрирован: 12-12-2013
Сообщений: 1228
UA: Firefox 129.0

Re: UCF - ваши кнопки, скрипты…

iG0R пишет

Кстати, а как Вы узнали, что я использую старый профиль (от 30.12.2023)?

Предположил по словосочетанию на скрине колёсико/ролик.:)

Отсутствует

 

№175204-09-2024 02:53:27

Dobrov
Участник
 
Группа: Members
Зарегистрирован: 04-10-2011
Сообщений: 476
UA: Firefox 128.0

Re: UCF - ваши кнопки, скрипты…

iG0R пишет

Правильно ли я нашел участок кода, отвечающий за всплывающую подсказку над вкладкой?

Да, но как видно в приведённом коде, над вкладкой подсказка только имя вкладки trg.label
Теперь для нового ucf_hookClicks.js в блоке Tag подсказка выключается так: [F.C]: "", … другие подсказки



Обновил демо-профиль, более 600 изменений в файлах, исправил несколько ошибок, сделал доработки согласно пожеланиям, дополнил встроенную справку (доступную в UserMenu по правому клику на unified-extensions), улучшил совместимость.

Отредактировано Dobrov (05-09-2024 01:47:19)

Отсутствует

 

№175304-09-2024 17:41:21

iG0R
Участник
 
Группа: Members
Зарегистрирован: 15-08-2015
Сообщений: 48
UA: Firefox 129.0

Re: UCF - ваши кнопки, скрипты…

xrun1 пишет

Предположил по словосочетанию на скрине колёсико/ролик.:)

ХитрО :)
---

Dobrov пишет

Да, но как видно в приведённом коде, над вкладкой подсказка только имя вкладки trg.label

Возможно ли добавить в неё Preview страницы, чтобы пользоваться только подсказками из пакета UCF?

Отсутствует

 

№175404-09-2024 23:32:14

Dobrov
Участник
 
Группа: Members
Зарегистрирован: 04-10-2011
Сообщений: 476
UA: unknown 0.0

Re: UCF - ваши кнопки, скрипты…

iG0R пишет

Возможно ли добавить в неё Preview страницы, чтобы пользоваться только подсказками из пакета UCF?

Нет. Предпросмотр вкладок по наведению и по Ctrl+Tab делается браузером. Проси Dumby или ищи расширение, мой скрипт, отображающий подсказки, предназначен для другого — описание в первой строке.

Отсутствует

 

№175505-09-2024 09:07:56

_zt
Участник
 
Группа: Members
Зарегистрирован: 10-11-2014
Сообщений: 1650
UA: Firefox 128.0

Re: UCF - ваши кнопки, скрипты…

iG0R
А у меня есть такой скрипт, но тебе не дам, ищи сам. )

скрытый текст
2024.09.05_091051.png

Отредактировано _zt (05-09-2024 09:12:59)

Отсутствует

 

№175605-09-2024 14:27:42

Dobrov
Участник
 
Группа: Members
Зарегистрирован: 04-10-2011
Сообщений: 476
UA: Firefox 128.0

Re: UCF - ваши кнопки, скрипты…

iG0R здесь есть TST TabPreview.mjs
но включение эскизов работает на [firefox] 128 без скрипта: browser.tabs.hoverPreview.enabled = true


_zt нечего скрывать чужой труд, это не ваш скрипт, вы сами попрошайничаете:
И, пожалуйста, переделайте в mjs jsm-ки: … TST TabPreview

Отредактировано Dobrov (05-09-2024 14:59:09)

Отсутствует

 

№175705-09-2024 18:20:38

_zt
Участник
 
Группа: Members
Зарегистрирован: 10-11-2014
Сообщений: 1650
UA: Firefox 128.0

Re: UCF - ваши кнопки, скрипты…

Dobrov
Сам то понял на что ссылку дал? :)

Отсутствует

 

№175820-09-2024 09:43:47

Den199
Участник
 
Группа: Members
Зарегистрирован: 26-06-2024
Сообщений: 7
UA: Firefox 132.0

Re: UCF - ваши кнопки, скрипты…

Можно ли с помощью UCF добавить в контекстное меню, вызываемое кликом правой кнопки мыши на странице, добавить свой пункт?
Возможно есть какой-то готовый шаблон (без излишеств) для создания кастомного пункта/кнопки?


Firefox 128 (64-bit) on windows 10 (64-bit).

Отсутствует

 

№175920-09-2024 13:33:21

Dobrov
Участник
 
Группа: Members
Зарегистрирован: 04-10-2011
Сообщений: 476
UA: Firefox 128.0

Re: UCF - ваши кнопки, скрипты…

Den199
в шапке Контекстное меню "Открыть ссылку в…"
Если клик не по ссылке, берёт адрес страницы. Код действий можно вбить произвольный и пункты меню назвать как нужно…

Отсутствует

 

№176024-09-2024 16:25:18

xrun1
Участник
 
Группа: Members
Зарегистрирован: 12-12-2013
Сообщений: 1228
UA: Firefox 130.0

Re: UCF - ваши кнопки, скрипты…

Dumby, приветствую!
На руборде в личной переписке с одним товарищем рассуждали о способах очистки буфера обмена. Нашли три.

1)
let clipboard = Cc["@mozilla.org/widget/clipboardhelper;1"].getService(Ci.nsIClipboardHelper);
clipboard.copyString("");

2) из глубин omni.ja
// This clears the logical clipboard, doesn't remove data.
Services.clipboard.emptyClipboard(Ci.nsIClipboard.kGlobalClipboard);

3) строчку закомментарил я, у меня с ней не работает. И что здесь лишнего?
let emptyStr = Cc["@mozilla.org/supports-string;1"].createInstance(Ci.nsISupportsString);
let trans = Cc["@mozilla.org/widget/transferable;1"].createInstance(Ci.nsITransferable);
// trans.init(getLoadContext());
trans.clearAllData();
trans.addDataFlavor("utiputi");
trans.setTransferData("utiputi", emptyStr);
Services.clipboard.setData(trans, null, Ci.nsIClipboard.kGlobalClipboard);
---
Понимаю, что вопрос глупый и всё же: какой способ, на твой взгляд, правильней для очистки (удаления) данных буфера обмена?

Отсутствует

 

№176125-09-2024 02:16:21

Dobrov
Участник
 
Группа: Members
Зарегистрирован: 04-10-2011
Сообщений: 476
UA: Firefox 128.0

Re: UCF - ваши кнопки, скрипты…

xrun1
замечу: в МакОС (вставка по ^+Y) и Линукс (колёсико мыши) есть второй буфер обмена, работающий штатно, без сторонних приложений.

Отсутствует

 

№176225-09-2024 08:42:04

fuchsfan
Участник
 
Группа: Members
Зарегистрирован: 07-08-2023
Сообщений: 130
UA: Firefox 128.0

Re: UCF - ваши кнопки, скрипты…

xrun1 пишет

способах очистки буфера обмена.

Системная очистка не подойдет? http://clipdiary.com/rus/clear-clipboard/

Отсутствует

 

№176325-09-2024 17:16:12

Dumby
Участник
 
Группа: Members
Зарегистрирован: 12-08-2012
Сообщений: 2262
UA: Firefox 78.0

Re: UCF - ваши кнопки, скрипты…

xrun1 пишет

какой способ, на твой взгляд, правильней для очистки (удаления) данных буфера обмена?

Всё ещё склоняюсь избегать обсуждения вопроса "правильности".
Скажу так: утилита InsideClipboard показывает мне, что


Способ 1) пишет в буфер два формата
CF_TEXT — один нулевой байт и CF_UNICODETEXT — два нулевых байта.


Способ 2) очищает буфер полностью.


Способ 3) пишет в буфер один формат "utiputi" — два нулевых байта,
что, для данной задачи, является избыточным.
Если убрать всё лишнее, то есть оставить только


Services.clipboard.setData(
    Cc["@mozilla.org/widget/transferable;1"].createInstance(Ci.nsITransferable),
    null,
    Ci.nsIClipboard.kGlobalClipboard
);
то результат будет такой же, как и у способа 2)

Отсутствует

 

№176426-09-2024 02:34:17

xrun1
Участник
 
Группа: Members
Зарегистрирован: 12-12-2013
Сообщений: 1228
UA: Firefox 130.0

Re: UCF - ваши кнопки, скрипты…

Dobrov пишет

замечу: в МакОС (вставка по ^+Y) и Линукс (колёсико мыши) есть второй буфер обмена

Интересно. Я в этих системах в такие системные дебри работы с буфером не забирался. Всё было проще и утилитарнее: в макОС графика и вёрстка, в линукс скрипты на перле - вытащить данные из баз и конвертнуть в Excel для Windows.
fuchsfan
Спасибо. Можно nircmd.exe clipboard clear

Dumby пишет

Всё ещё склоняюсь избегать обсуждения вопроса "правильности".

Я помню. Спасибо.
Меня зацепил комментарий к 2-му способу.

скрытый текст

// This clears the logical clipboard, doesn't remove data.
/* Это очищает логический буфер обмена, но не удаляет данные. */

Скопировал --> очистил 2-м способом. И так 100500+ раз. Буфер чистый, но данные в памяти остались. Т.е. память занята и свободная уменьшается по мере копирования. Мне стало интересно, может ли это привести к падению системы или браузера из-за отсутствия свободной памяти? Чисто гипотетически и теоретически.
Практически, наверное, можно посмотреть на память, если впихнуть что-то в браузер на 100 Мб и проделать раз 10...
Хотелось узнать мнение коллег, но это флуд в теме.:(

Отсутствует

 

№176527-09-2024 22:09:34

CoolCmd
Участник
 
Группа: Members
Зарегистрирован: 29-09-2008
Сообщений: 688
UA: Firefox 130.0

Re: UCF - ваши кнопки, скрипты…

в tor browser в файле Tor Browser\Browser\browser\omni.ja\defaults\preferences\000-tor-browser.js
есть такая строчка:

Выделить код

Код:

pref("privacy.resistFingerprinting", true, locked);

из-за locked я не могу в user.js задать эту настройку. менять omni.ja - это плохой вариант.
мне нужно, чтобы настройка всегда была равна false. как это сделать? как я понимаю, нужно создать Cc['@mozilla.org/preferences-service;1'].getService(Ci.nsIPrefService)
и дальше чета с ним сделать...


леса живет в лису?

Отсутствует

 

№176628-09-2024 09:32:16

Dumby
Участник
 
Группа: Members
Зарегистрирован: 12-08-2012
Сообщений: 2262
UA: Firefox 78.0

Re: UCF - ваши кнопки, скрипты…

CoolCmd пишет

мне нужно, чтобы настройка всегда была равна false

Я попробовал в Tor Browser 13.5.5 добавить в config-prefs.js
pref("privacy.resistFingerprinting", false, locked);


и мне, как about:config, так и консоль с кода
Services.prefs.getBoolPref("privacy.resistFingerprinting");
показывают false

Отсутствует

 

№176728-09-2024 11:17:02

CoolCmd
Участник
 
Группа: Members
Зарегистрирован: 29-09-2008
Сообщений: 688
UA: Firefox 130.0

Re: UCF - ваши кнопки, скрипты…

Dumby спасибо, работает


леса живет в лису?

Отсутствует

 

№176828-09-2024 13:55:14

xrun1
Участник
 
Группа: Members
Зарегистрирован: 12-12-2013
Сообщений: 1228
UA: Firefox 130.0

Re: UCF - ваши кнопки, скрипты…

Dumby
Возвращаясь к напечатанному №1760, просто для информации.
В WinXP была утилита для просмотра буфера обмена clipbrd.exe, до сих пор иногда пользуюсь. На третий способ показывает

скрытый текст
Image005_2024-09-27_17-38.png

После применения способов 1), 2) или "nircmd.exe clipboard clear" там чисто.
кнопка

Выделить код

Код:

try {
    CustomizableUI.createWidget({
        id: "add-additional-clearbuffer-button",
        label: "Очистить буфер",
        tooltiptext: "Очистить буфер обмена",
        onCreated: btn => btn.image = "",
        onCommand: function(event) {
//  https://forum.mozilla-russia.org/viewtopic.php?pid=811013#p811013
// 1)
// let clipboard = Cc["@mozilla.org/widget/clipboardhelper;1"].getService(Ci.nsIClipboardHelper);
// clipboard.copyString("");
// 2)
// Services.clipboard.emptyClipboard(Ci.nsIClipboard.kGlobalClipboard);
// 3)
            Services.clipboard.setData(
                Cc["@mozilla.org/widget/transferable;1"].createInstance(Ci.nsITransferable),
                null,
                Ci.nsIClipboard.kGlobalClipboard
            );
            var alertsService = Cc["@mozilla.org/alerts-service;1"].getService(Ci.nsIAlertsService);
            alertsService.showAlertNotification("chrome://browser/skin/customizableui/whimsy.png", "Clipboard", "Буфер обмена очищен!");
            setTimeout(() => alertsService.closeAlert(), 2000);
        }
    });
} catch(e) {}

Отсутствует

 

№176901-10-2024 12:45:28

unter_officer
Участник
 
Группа: Members
Откуда: Санкт-Петербург
Зарегистрирован: 27-03-2011
Сообщений: 606
UA: Firefox 127.0

Re: UCF - ваши кнопки, скрипты…

Dumby
Виталий недавно исправлял (для FF128), а в [firefox] 131 опять сломали.
Консоль пишет: TypeError: engine[0] is undefined
Если не трудно, поправьте пожалуйста.

скрытый текст

Выделить код

Код:

//
// Заменить значок Google-поисковика (FF128) .....
//
Services.search.getEnginesByExtensionID("google@search.mozilla.org").then(engine =>
    engine[0].getIconURL = async () => "chrome://user_chrome_files/content/icon/google.ico"
);


«The Truth Is Out There»

Отсутствует

 

№177001-10-2024 13:43:59

Farby
Участник
 
Группа: Members
Зарегистрирован: 21-11-2012
Сообщений: 318
UA: Google 2.1

Re: UCF - ваши кнопки, скрипты…

unter_officer
Поисковые расширения медленно, но верно отключают...
Но вы можете попробовать вместо ID использовать Name

скрытый текст

Выделить код

Код:

```Diff
- Services.search.getEnginesByExtensionID("google@search.mozilla.org") 
+ Services.search.getEngineByName("Google")

```


Жизнь иногда такое выкидывает, что хочется подобрать...

Отсутствует

 

№177102-10-2024 09:50:52

Dumby
Участник
 
Группа: Members
Зарегистрирован: 12-08-2012
Сообщений: 2262
UA: Firefox 78.0

Re: UCF - ваши кнопки, скрипты…

xrun1 пишет

утилита для просмотра буфера обмена clipbrd.exe

О, интересная штука. Показывает даже то, чего не показывает InsideClipboard

скрытый текст

Ну в смысле скорее показывает наличие некоторых форматов, чем данные.

После применения способов 1) ... там чисто.

Ну где же чисто, когда нет

Выделить код

Код:



Вот после применения способа 2) — совершенно чисто.

На третий способ показывает

Действительно, торчат DataObject и Ole Private Data


Кстати, поискал коммент «This clears the logical clipboard, doesn't remove data».
Есть такой в PlacesController. В idl'ке — нечто похожее:


    * This empties the clipboard and notifies the clipboard owner.
    * This empties the "logical" clipboard. It does not clear the native clipboard.


Но что-то мне сомнительно, выглядит как раз наоборот.
Если я правильно понял, там используется OleSetClipboard(null), и если запускаю

Выделить код

Код:

(url => {
	var {ctypes} = ChromeUtils.importESModule(url);
	var ole32 = ctypes.open("ole32.dll");
	ole32.declare("OleSetClipboard", ctypes.winapi_abi, ctypes.long, ctypes.voidptr_t)(null);
	ole32.close();

})("resource://gre/modules/ctypes.sys.mjs");

то clipbrd.exe также показывает, что очистка полная.


Так вот, там, в PlacesController, в следующей функции, используется способ 3)
но формат-пустышку всё таки добавляют, и такое объяснение:
// Empty transferables may cause crashes, so just add an unknown type.


Ремарка почтенного возраста, например, в Firefox 28 она уже есть,
возможно устарела, но всё равно стрёмно.
А раз очистка ещё и не полная, то я склоняюсь к предпочтению способа 2)

Farby пишет

вместо ID использовать Name

вместо ExtensionID использовать Name или Id

скрытый текст

Выделить код

Код:

(async icon => {
	await Services.search.promiseInitialized;
	icon = Promise.resolve(icon);
	Services.search.getEngineById("google")
		.wrappedJSObject.getIconURL = () => icon;
})("chrome://user_chrome_files/content/icon/google.ico");


В Firefox 131 немного покусали UCF.


Bug 1896764 - onViewToolbarsPopupShowing and ToolbarContextMenu should move out of browser.js


То есть, создание ToolbarContextMenu переместили в модуль,
и onViewToolbarsPopupShowing() туда же, из окна в этот ToolbarContextMenu.


В результате, в тулбарском контекстном меню
пропали пункты переключения нижнего и вертикального тулбаров.


У себя пока сделал так, перенёс часть кода из toolbars.js в UcfPrefs.mjs

toolbars.js

Выделить код

Код:

/*
        var newStrFn;
        if (toolbarcreate) {
            window.addEventListener("toolbarvisibilitychange", this);
            window.addEventListener("unload", () => this.destructor(), { once: true });
            let oVTC = window.onViewToolbarCommand;
            if (typeof oVTC === "function") {
                let strFn = `${oVTC}`, regExr = /(BrowserUsageTelemetry\s*\.\s*recordToolbarVisibility\s*\(\s*toolbarId.+?\)\s*\;)/g;
                if (regExr.test(strFn)) {
                    newStrFn = `window.onViewToolbarCommand = ${strFn.replace(/^(async\s)?.*?\(/, `$1function ${oVTC.name}(`)
                        .replace(regExr, 'if (!/ucf-additional-.+?-bar/.test(toolbarId)) { $1 }')};`;
                }
            }
        }
        if (externalToolbars) {
            let oVTPS = window.onViewToolbarsPopupShowing;
            if (typeof oVTPS === "function") {
                let strFn = `${oVTPS}`, regExr = /toolbarNodes\s*=\s*gNavToolbox\s*\.\s*querySelectorAll\s*\(\s*\"\s*toolbar\s*\"\s*\)/g;
                if (regExr.test(strFn)) {
                    newStrFn = `${newStrFn}${"\n"}window.onViewToolbarsPopupShowing = ${strFn.replace(/^(async\s)?.*?\(/, `$1function ${oVTPS.name}(`)
                        .replace(regExr, 'toolbarNodes = Array.from(document.querySelectorAll("toolbar[toolbarname]"))')};`;
                }
            }
        }
        if (!newStrFn) return;
        UcfPrefs.setSubToolbars(newStrFn);
        ChromeUtils.compileScript("resource://ucf_on_view_toolbars").then(script => script.executeInGlobal(window));
*/
        toolbarcreate && UcfPrefs.handleToolbars(window, externalToolbars);


UcfPrefs.mjs

Выделить код

Код:

/*
    setSubToolbars(newStrFn) {
        this.setSubToolbars = () => {};
        Services.io.getProtocolHandler("resource")
        .QueryInterface(Ci.nsIResProtocolHandler)
        .setSubstitution("ucf_on_view_toolbars", Services.io.newURI(`data:charset=utf-8,${encodeURIComponent(newStrFn)}`));
    },
*/
    handleToolbars: function handleToolbars(win, externalToolbars) {
        if ((handleToolbars.wins ??= new Set()).add(win).size > 1) return;

        var rph = Services.io.getProtocolHandler("resource").QueryInterface(Ci.nsIResProtocolHandler);
        var resURL = (code, sfx = "") => {
            var subst = "ucf_on_view_toolbars" + sfx
            rph.setSubstitution(subst, Services.io.newURI("data:charset=utf-8," + encodeURIComponent(code)));
            return "resource://" + subst;
        }
        var script = 
            'window.addEventListener("toolbarvisibilitychange", ucf_toolbars);\n' +
            'window.addEventListener("unload", () => ucf_toolbars.destructor(), {once: true});';

        var oVTC = win.onViewToolbarCommand;
        if (typeof oVTC === "function") {
            var strFn = `${oVTC}`, regExr = /(BrowserUsageTelemetry\s*\.\s*recordToolbarVisibility\s*\(\s*toolbarId.+?\)\s*\;)/g;
            if (regExr.test(strFn)) {
                script += `\nwindow.onViewToolbarCommand = ${strFn.replace(/^(async\s)?.*?\(/, `$1function ${oVTC.name}(`)
                    .replace(regExr, 'if (!/ucf-additional-.+?-bar/.test(toolbarId)) { $1 }')};`;
            }
        }
        if (externalToolbars) {
            var tcm = win.ToolbarContextMenu;
            var navToolbars = 'gNavToolbox.querySelectorAll("toolbar")';
            var oVTPS = tcm.onViewToolbarsPopupShowing || win.onViewToolbarsPopupShowing;

            if (typeof oVTPS == "function" && (strFn = String(oVTPS)).includes(navToolbars)) {

                strFn = strFn.replace(navToolbars, 'Array.from(document.querySelectorAll("toolbar[toolbarname]"))');

                if (strFn.startsWith("f")) script += "\n" + strFn;
                else {
                    var key = "temp_ToolbarContextMenu";
                    var code = `Object.assign(${key}, {${strFn.replace("gNavToolbox", "window: lazy")}});`;

                    globalThis[key] = tcm;
                    ChromeUtils.compileScript(resURL(code, "_mjs"))
                        .then(ps => ps.executeInGlobal(globalThis), Cu.reportError)
                        .finally(() => delete globalThis[key]);
                }
            }
        }
        var func;
        ChromeUtils.compileScript(resURL(script)).then(
            ps => func = win => ps.executeInGlobal(win),
            ex => func = () => Cu.reportError(ex)
        ).finally(() => {
            this.handleToolbars = func;
            for(var win of handleToolbars.wins) try {func(win);} catch(ex) {Cu.reportError(ex);}
        });
    },

Отсутствует

 

№177202-10-2024 12:24:40

unter_officer
Участник
 
Группа: Members
Откуда: Санкт-Петербург
Зарегистрирован: 27-03-2011
Сообщений: 606
UA: Firefox 131.0

Re: UCF - ваши кнопки, скрипты…

Dumby пишет

вместо ExtensionID использовать Name или Id

Dumby, большое спасибо.


«The Truth Is Out There»

Отсутствует

 

№177302-10-2024 19:04:37

xrun1
Участник
 
Группа: Members
Зарегистрирован: 12-12-2013
Сообщений: 1228
UA: Firefox 131.0

Re: UCF - ваши кнопки, скрипты…

Dumby
Спасибо за развёрнутый ответ. Я тоже поковырялся и пришёл к второму способу.

Отсутствует

 

№177404-10-2024 14:39:53

unter_officer
Участник
 
Группа: Members
Откуда: Санкт-Петербург
Зарегистрирован: 27-03-2011
Сообщений: 606
UA: Firefox 131.0

Re: UCF - ваши кнопки, скрипты…

Dumby
Возможно ли сделать скрипт, который решал бы такие задачи?
1. При добавлении закладки (Ctrl+D) не появлялось подобное окно.
dobavit_zakladku.png
2. Закладка всегда(!) сохранялась бы на Панедь закладок, даже если аналогичная заклака уже существует в какй либо папке закладок или на Панели закладок.
3. Если закладка уже существует в какой либо папке закладок или на Панели закладок, то при сохранении новой аналогичной закладки, существующая закладка из той папки закладок или с Панели закладок не удалялась.


P.S. Надеюсь, не очень путанно описал свою хотелку.


«The Truth Is Out There»

Отсутствует

 

№177505-10-2024 01:06:53

Dobrov
Участник
 
Группа: Members
Зарегистрирован: 04-10-2011
Сообщений: 476
UA: Firefox 128.0

Re: UCF - ваши кнопки, скрипты…

unter_officer - именно делает скрипт ucf_hookClicks.js из демо-профиля.
Как обычно, ответ стандартный – «Читайте шапку!» вторая строка справки из шапки:
…Добавить закладку без запроса…


вот код функции, можете вырезать его в ваш скрипт, только подсказка берётся отсюда

Отсутствует

 

Board footer

Powered by PunBB
Modified by Mozilla Russia
Copyright © 2004–2020 Mozilla Russia GitHub mark
Язык отображения форума: [Русский] [English]