Правильно ли я нашел участок кода, отвечающий за всплывающую подсказку над вкладкой?
Да, но как видно в приведённом коде, над вкладкой подсказка только имя вкладки trg.label
Теперь для нового ucf_hookClicks.js в блоке Tag подсказка выключается так: [F.C]: "", … другие подсказки
Обновил демо-профиль, более 600 изменений в файлах, исправил несколько ошибок, сделал доработки согласно пожеланиям, дополнил встроенную справку (доступную в UserMenu по правому клику на unified-extensions), улучшил совместимость.
Отредактировано Dobrov (05-09-2024 01:47:19)
Отсутствует
Предположил по словосочетанию на скрине колёсико/ролик.
ХитрО
---
Да, но как видно в приведённом коде, над вкладкой подсказка только имя вкладки trg.label
Возможно ли добавить в неё Preview страницы, чтобы пользоваться только подсказками из пакета UCF?
Отсутствует
Возможно ли добавить в неё Preview страницы, чтобы пользоваться только подсказками из пакета UCF?
Нет. Предпросмотр вкладок по наведению и по Ctrl+Tab делается браузером. Проси Dumby или ищи расширение, мой скрипт, отображающий подсказки, предназначен для другого — описание в первой строке.
Отсутствует
iG0R здесь есть TST TabPreview.mjs
но включение эскизов работает на 128 без скрипта: browser.tabs.hoverPreview.enabled = true
_zt нечего скрывать чужой труд, это не ваш скрипт, вы сами попрошайничаете:
И, пожалуйста, переделайте в mjs jsm-ки: … TST TabPreview
Отредактировано Dobrov (05-09-2024 14:59:09)
Отсутствует
Можно ли с помощью UCF добавить в контекстное меню, вызываемое кликом правой кнопки мыши на странице, добавить свой пункт?
Возможно есть какой-то готовый шаблон (без излишеств) для создания кастомного пункта/кнопки?
Firefox 128 (64-bit) on windows 10 (64-bit).
Отсутствует
Den199
в шапке Контекстное меню "Открыть ссылку в…"
Если клик не по ссылке, берёт адрес страницы. Код действий можно вбить произвольный и пункты меню назвать как нужно…
Отсутствует
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);
---
Понимаю, что вопрос глупый и всё же: какой способ, на твой взгляд, правильней для очистки (удаления) данных буфера обмена?
Отсутствует
способах очистки буфера обмена.
Системная очистка не подойдет? http://clipdiary.com/rus/clear-clipboard/
Отсутствует
какой способ, на твой взгляд, правильней для очистки (удаления) данных буфера обмена?
Всё ещё склоняюсь избегать обсуждения вопроса "правильности".
Скажу так: утилита 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)
Отсутствует
замечу: в МакОС (вставка по ^+Y) и Линукс (колёсико мыши) есть второй буфер обмена
Интересно. Я в этих системах в такие системные дебри работы с буфером не забирался. Всё было проще и утилитарнее: в макОС графика и вёрстка, в линукс скрипты на перле - вытащить данные из баз и конвертнуть в Excel для Windows.
fuchsfan
Спасибо. Можно nircmd.exe clipboard clear
Всё ещё склоняюсь избегать обсуждения вопроса "правильности".
Я помню. Спасибо.
Меня зацепил комментарий к 2-му способу.
// This clears the logical clipboard, doesn't remove data.
/* Это очищает логический буфер обмена, но не удаляет данные. */
Скопировал --> очистил 2-м способом. И так 100500+ раз. Буфер чистый, но данные в памяти остались. Т.е. память занята и свободная уменьшается по мере копирования. Мне стало интересно, может ли это привести к падению системы или браузера из-за отсутствия свободной памяти? Чисто гипотетически и теоретически.
Практически, наверное, можно посмотреть на память, если впихнуть что-то в браузер на 100 Мб и проделать раз 10...
Хотелось узнать мнение коллег, но это флуд в теме.
Отсутствует
в tor browser в файле Tor Browser\Browser\browser\omni.ja\defaults\preferences\000-tor-browser.js
есть такая строчка:
из-за locked я не могу в user.js задать эту настройку. менять omni.ja - это плохой вариант.
мне нужно, чтобы настройка всегда была равна false. как это сделать? как я понимаю, нужно создать Cc['@mozilla.org/preferences-service;1'].getService(Ci.nsIPrefService)
и дальше чета с ним сделать...
леса живет в лису?
Отсутствует
мне нужно, чтобы настройка всегда была равна false
Я попробовал в Tor Browser 13.5.5 добавить в config-prefs.js
pref("privacy.resistFingerprinting", false, locked);
и мне, как about:config, так и консоль с кода
Services.prefs.getBoolPref("privacy.resistFingerprinting");
показывают false
Отсутствует
Dumby
Возвращаясь к напечатанному №1760, просто для информации.
В WinXP была утилита для просмотра буфера обмена clipbrd.exe, до сих пор иногда пользуюсь. На третий способ показывает
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) {}
Отсутствует
Dumby
Виталий недавно исправлял (для FF128), а в 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»
Отсутствует
unter_officer
Поисковые расширения медленно, но верно отключают...
Но вы можете попробовать вместо ID использовать Name
```Diff - Services.search.getEnginesByExtensionID("google@search.mozilla.org") + Services.search.getEngineByName("Google") ```
Жизнь иногда такое выкидывает, что хочется подобрать...
Отсутствует
утилита для просмотра буфера обмена 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)
вместо 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
/* 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);
/* 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);} }); },
Отсутствует
вместо ExtensionID использовать Name или Id
Dumby, большое спасибо.
«The Truth Is Out There»
Отсутствует
Dumby
Возможно ли сделать скрипт, который решал бы такие задачи?
1. При добавлении закладки (Ctrl+D) не появлялось подобное окно.
2. Закладка всегда(!) сохранялась бы на Панедь закладок, даже если аналогичная заклака уже существует в какй либо папке закладок или на Панели закладок.
3. Если закладка уже существует в какой либо папке закладок или на Панели закладок, то при сохранении новой аналогичной закладки, существующая закладка из той папки закладок или с Панели закладок не удалялась.
P.S. Надеюсь, не очень путанно описал свою хотелку.
«The Truth Is Out There»
Отсутствует
unter_officer - именно делает скрипт ucf_hookClicks.js из демо-профиля.
Как обычно, ответ стандартный – «Читайте шапку!» вторая строка справки из шапки:
…Добавить закладку без запроса…
вот код функции, можете вырезать его в ваш скрипт, только подсказка берётся отсюда…
Отсутствует