Dobrov
Вы невнимательно прочитали, что мне требуется. Увидели первый пункт и сразу же начали указывать: «Читайте шапку!»
Но за наводку на вашу функцию спасибо. Правда пришлось немного её переделать, чтобы добиться нужного мне результата.
В общем, повесил всё это на клик по звёздочке в адресной строке.
(this.ucfaddbookmark = { init(that) { if (!Services.prefs.getIntPref('bookmarksparentguid', '')) { Services.prefs.setIntPref('bookmarksparentguid', 0); } var starbuttonbox = this.starbuttonbox = document.querySelector("#star-button-box"); if (!starbuttonbox) return; starbuttonbox.addEventListener("click", this, true); that.unloadlisteners.push("ucfaddbookmark"); }, handleEvent(e) { toFav =()=> {with (PlacesUtils.bookmarks) { var url = gBrowser.selectedBrowser.currentURI.spec; search({url}).then(async array => { try {await insert({ url: Services.io.newURI(url), title: (gBrowser.contentTitle || gBrowser.selectedTab.label || url), parentGuid: [() => toolbarGuid, () => menuGuid, () => unfiledGuid][Services.prefs.getIntPref("bookmarksparentguid",0)](), index: DEFAULT_INDEX });} catch(e) { Cu.reportError(e); } }); }} if (e.button != 0) return; e.preventDefault(); e.stopPropagation(); if (e.type != "click") return; toFav(); }, }).init(this);
Отредактировано unter_officer (06-10-2024 06:19:04)
«The Truth Is Out There»
Отсутствует
Надеюсь, не очень путанно описал свою хотелку.
Ну так, на четвёрочку.
Первый пункт, я так понимаю, относится и к звезде,
иначе, наверно, было бы написано «по Ctrl+D» вместо «(Ctrl+D)».
Второй пункт, видимо, относится к первому пункту, а не вообще «всегда».
Третий пункт я просто не понял. Если имеется в виду сохранение
со звёздочной панельки в состоянии «Изменить закладку», то это
не «сохранении новой аналогичной закладки», а перемещение существующей.
А если заказано чтобы звёздочная панелька в состоянии «Изменить закладку»
не появлялась, то третий пункт получается избыточен.
Однако, на всякий случай, задумал, чтобы если звезда активируется
с модификатором Ctrl или Shift, тогда поведение не меняется, остаётся каким было.
Вот, в окно браузера (не в сандбокс).
(async mod => (await ChromeUtils.compileScript("data:," + encodeURIComponent( `Object.assign(PlacesCommandHook, {${ String(PlacesCommandHook.bookmarkPage) .replace("{", `{\n let e = window.event;\n let mod = ${mod};`) .replace("!info", "(StarUI._isRealNewBookmark = $&) || mod") .replace( "await PlacesUIUtils.defaultParentGuid", `mod ? "${PlacesUtils.bookmarks.toolbarGuid}" : $&` ) }});\n\nObject.assign(StarUI, {${ String(StarUI._handlePopupHiddenEvent) .replace("BookmarkingUI", "this._isRealNewBookmark && $&") }});` ))).executeInGlobal(window))( 'e && (e.target?.id == "Browser:AddBookmarkAs" || !e.ctrlKey && !e.shiftKey)' );
Отсутствует
Впрочем, это код вмешательства, а твоя адаптация Dobrov'ского,
хоть и весьма кривовата, но это всё таки скорее код созидания.
Dumby
Ваш вариант мне нравится больше.
Большое спасибо!
«The Truth Is Out There»
Отсутствует
Dumby, поправьте пожалуйста кнопочку для FF 131.
В консоль пишет: Uncaught TypeError: lazy.PrivateBrowsingUtils is undefined
// // Сохранять изображение без запроса в указанную папку из контекстного меню ..... // try { (this.contextsaveimg = { path: "E:\\Download", init(that) { var contextMenu = this.contextMenu = document.querySelector("#contentAreaContextMenu"); if (!contextMenu) return; contextMenu.addEventListener("popupshowing", this); that.unloadlisteners.push("contextsaveimg"); }, destructor() { this.contextMenu.removeEventListener("popupshowing", this); }, handleEvent(e) { if (!gContextMenu.onImage || gContextMenu.webExtBrowserType === "popup") return; var menuitem = document.createXULElement("menuitem"); menuitem.setAttribute("id", "ucf_SaveImg"); menuitem.setAttribute("label", "Сохранить изображение в папку: " + this.path); menuitem.setAttribute("oncommand", "saveImg();"); menuitem.className = "menuitem-iconic"; menuitem.setAttribute("image", "data:image/x-icon;base64,....."); (this.contextMenu.querySelector("#context-sendimage") || this.contextMenu.lastElementChild).after(menuitem); this.handleEvent = () => menuitem.hidden = (!gContextMenu.onImage || gContextMenu.webExtBrowserType === "popup"); menuitem.saveImg = () => { var p = Services.prefs; var data = Object.assign(Object.create(null), { "browser.download.folderList": { type: "Int", set: 2 }, "browser.download.useDownloadDir": { type: "Bool", set: true }, "browser.download.dir": { type: "String", set: this.path } }); var save = eval(`(function ${gContextMenu.saveMedia})`.replace( "\n false, // don't", "\n true, //" )); (menuitem.saveImg = () => { for(var pref in data) { var obj = data[pref], meth = `et${obj.type}Pref`; obj.val = p.prefHasUserValue(pref) ? p["g" + meth](pref) : null; p["s" + meth](pref, obj.set); } try {save.call(gContextMenu);} finally { for(var pref in data) data[pref].val === null ? p.clearUserPref(pref) : p[`set${data[pref].type}Pref`](pref, data[pref].val); } })(); } } }).init(this); } catch(e) { Cu.reportError(e); }
«The Truth Is Out There»
Отсутствует
Farby, спасибо.
Это не дежавю, это я уже совсем "заработался". Совсем забыл об этом фиксе.
«The Truth Is Out There»
Отсутствует
Уважаемые Гуру! В 128 версии перестал работать скрипт "вернуть в адресную строку значок "Копировать ссылку"
Что надо исправить?
(async (url, pa = ChromeUtils.import(url).PageActions) => pa.addAction(new pa.Action({
title: "Копировать ссылку",
tooltip: " ",
iconURL: "chrome://global/skin/icons/link.svg",
id: "ucf-copyURL",
pinnedToUrlbar: true,
onCommand(e) {
var MozXULElement = {insertFTLIfNeeded() {}};
var document = {l10n: {setAttributes: msg => msg.textContent = "Скопировано в буфер обмена!"}};
var show = eval(`(function ${e.view.ConfirmationHint.show})`);
var helper = Cc["@mozilla.org/widget/clipboardhelper;1"]
.getService(Ci.nsIClipboardHelper);
(this.onCommand = e => {
var win = e.view;
var uri = win.gBrowser.selectedBrowser.currentURI;
helper.copyString(win.gURLBar.makeURIReadable(uri).displaySpec);
var anchor = win.BrowserPageActions.panelAnchorNodeForAction(this, e);
show.call(win.ConfirmationHint, anchor, "", {event: e, hideArrow: true});
})(e);
}
Отсутствует
Что надо исправить?
Консоль что ли не подруга?
(async (url, pa = ChromeUtils.importESModule(url).PageActions) => pa.addAction(new pa.Action({
// .......
})))("resource:///modules/PageActions.sys.mjs");
Отсутствует
Dumby
Не работает..
title: "Копировать ссылку",
tooltip: " ",
iconURL: "chrome://global/skin/icons/link.svg",
id: "ucf-copyURL",
pinnedToUrlbar: true,
onCommand(e) {
var MozXULElement = {insertFTLIfNeeded() {}};
var document = {l10n: {setAttributes: msg => msg.textContent = "Скопировано в буфер обмена!"}};
var show = eval(`(function ${e.view.ConfirmationHint.show})`);
var helper = Cc["@mozilla.org/widget/clipboardhelper;1"]
.getService(Ci.nsIClipboardHelper);
(this.onCommand = e => {
var win = e.view;
var uri = win.gBrowser.selectedBrowser.currentURI;
helper.copyString(win.gURLBar.makeURIReadable(uri).displaySpec);
var anchor = win.BrowserPageActions.panelAnchorNodeForAction(this, e);
show.call(win.ConfirmationHint, anchor, "", {event: e, hideArrow: true});
})(e);
}
})))("resource:///modules/PageActions.sys.mjs");
Отсутствует
Dumby
Скрипт работает даже со старым вариантом импорта, загвоздка в том что если использовать скрипт Quick Mark от Yeesha то там задаётся стиль для Hint
if (settings.hideThatStupidGreenTooltipOnSaving) { // document.querySelector('#confirmation-hint').style.display = 'none'; // Null since FF78 or 79 because of “lazy load” (see browser.js) let hint = document.querySelector('#confirmation-hint') || ConfirmationHint._panel; // This creates the hint in FF78-79 if missed or just gets it in older versions hint.style.display = 'none'; }
Жизнь иногда такое выкидывает, что хочется подобрать...
Отсутствует
Не работает..
Вот спецом скачал и собрал 128.3.1esr
Развернул UCF 2024-10-6
Сунул приведённый код в custom_script_win.js
Всё работает

не видно
Само звено тоже не видно?
Отредактировано Dumby (21-10-2024 17:47:21)
Отсутствует
Dumby
Значок "копировать ссылку" виден, но при нажатии ничего не происходит,уведомление не появляется, ссылка не копируется
Связано ли это что у меня win7?
Отредактировано doud (21-10-2024 17:57:37)
Отсутствует
Само звено тоже не видно?
Звено на месте, копируется, но пока стиль не поправил фразы "Скопировано в буфер обмена!" небыло
Жизнь иногда такое выкидывает, что хочется подобрать...
Отсутствует
Связано ли это что у меня win7?
128 на Win7?
А ссылка на это чудо инженерной мысли тогда где?
пока стиль не поправил фразы "Скопировано в буфер обмена!" небыло
Вроде как, это называется: «
Что мы сеем?
А то и пожинаем ...
»;
Безотносительно вероятности использования,
это, несомненно, "nice catch".
Разреши тогда похвалить, что ли.
Отсутствует
https://github.com/adeii/supermium-portable/releases/tag/F127
Скачал Firefox-portable-128.0-x86-win7.7z
Значок "копировать ссылку" виден, но при нажатии ничего не происходит,уведомление не появляется, ссылка не копируется
Хмм, странно.
У меня вообще значок не виден, и даже звезды нет.

Вобщем, добавил ожидание promiseAllWindowsRestored и вызов init()
//(async (url, pa = ChromeUtils.importESModule(url).PageActions) => pa.addAction(new pa.Action({ (async (url, pa = ChromeUtils.importESModule(url).PageActions) => await ChromeUtils.importESModule("resource:///modules/sessionstore/SessionStore.sys.mjs") .SessionStore.promiseAllWindowsRestored || pa.init() || pa.addAction(new pa.Action({

Иначе говоря, получается,
что воспроизвести как у тебя, мне, увы, не удалось .
Отсутствует
Dumby
А в какую часть скрипта добавить ваш код?
Покажите ваш код целиком
P.S меня версия 64, поставил версию 32 Работает и старый код!
Отредактировано doud (22-10-2024 16:15:28)
Отсутствует
Звено на месте, копируется, но пока стиль не поправил фразы "Скопировано в буфер обмена!" небыло
115.15, текст скрипта
(async (url, pa = ChromeUtils.import(url).PageActions) => pa.addAction(new pa.Action({
title: "Копировать ссылку",
tooltip: "Копировать ссылку",
iconURL: "chrome://global/skin/icons/link.svg",
id: "ucf-copyURL",
pinnedToUrlbar: true,
onCommand(e) {
var gBrowserBundle = {
GetStringFromName: () => "Скопировано в буфер обмена!"
};
var show = eval(`(function ${e.view.ConfirmationHint.show})`);
var helper = Cc["@mozilla.org/widget/clipboardhelper;1"]
.getService(Ci.nsIClipboardHelper);
(this.onCommand = e => {
var win = e.view;
var uri = win.gBrowser.selectedBrowser.currentURI;
helper.copyString(win.gURLBar.makeURIReadable(uri).displaySpec);
var anchor = win.BrowserPageActions.panelAnchorNodeForAction(this, e);
show.call(win.ConfirmationHint, anchor, "", {event: e, hideArrow: true});
})(e);
}
})))("resource:///modules/PageActions.jsm");
Кнопка копирования в адресной строке есть, после нажатия на неё
адрес копируется в буфер обмена,
но сообщения "Скопировано в буфер обмена!" неть...
В консоли вот такое
https://s1.hostingkartinok.com/uploads/images/2024/10/6526712a1a2426cc57f7bb129962718a.png
Это скриншот текста скрипта с номерами строк
https://s1.hostingkartinok.com/uploads/images/2024/10/e62a6902c7b375f1ba23311f2b2ae143.png
Подскажите, пожалуйста, чего надо поправить в коде скрипта,
чтобы сообщение о результате копирования было видно. Спасибо
Отсутствует
Viatcheslav
Попробуйте так:
// (async (url, pa = ChromeUtils.import(url).PageActions) => pa.addAction(new pa.Action({ title: "Копировать ссылку", tooltip: "Копировать ссылку", iconURL: "chrome://global/skin/icons/link.svg", id: "ucf-copyURL", pinnedToUrlbar: true, onCommand(e) { var MozXULElement = {insertFTLIfNeeded() {}}; var document = {l10n: {setAttributes: msg => msg.textContent = "Скопировано в буфер обмена!"}}; var show = eval(`(function ${e.view.ConfirmationHint.show})`); var helper = Cc["@mozilla.org/widget/clipboardhelper;1"].getService(Ci.nsIClipboardHelper); (this.onCommand = e => { var win = e.view; var uri = win.gBrowser.selectedBrowser.currentURI; helper.copyString(win.gURLBar.makeURIReadable(uri).displaySpec); var anchor = win.BrowserPageActions.panelAnchorNodeForAction(this, e); show.call(win.ConfirmationHint, anchor, "", {event: e, hideArrow: true}); })(e); } })))("resource:///modules/PageActions.jsm");
«The Truth Is Out There»
Отсутствует
Попробуйте так:
О, замечательно, благодарствую
Отсутствует
Уважаемые Гуру! Был такой скрипт для открытия Findbar двойным щелчком СКМ. На новых версиях уже не работает. Что надо исправить?
var findbar = gFindBar;
if (findbar) {
if (!findbar.hidden) return //findbar.close();
} else {
findbar = await gFindBarPromise;
await new Promise(resolve => setTimeout(resolve, 0));
}
findbar.onFindCommand();
}, false, gBrowser.tabpanels || 1);
Отсутствует
Добрый день, уважаемые!
Очень прошу в очередной раз оказать мне помощь.
Что-то нужно поправить/заменить
Я использую UCF, для вытаскивания/прятания боковой панели закладок.
Т.е. подводишь мышь к левому краю окна она выезжает. А убирается она по клику на свободном месте.
И вот настал очередной момент, когда она перестала выезжать. Т.е. реагировать.
Это произошло в 133. С самой первой альфы.
Несколько раз мне помогал сам автор Vitaliy V.
В последний раз мне помог sandro79 вот здесьhttps://forum.mozilla-russia.org/viewto … 77#p796277
Собственно в файле auto_hide_sidebar.js содержится, то что дал sandro79
Использую UCF вот отсюда https://github.com/VitaliyVstyle/Vitali … /tree/main
Вот содержимое файла который это делает: auto_hide_sidebar.js и auto_hide_sidebar.css
(this.autohidesidebar = { events: ["dragenter", "drop", "dragexit", "MozLayerTreeReady"], init() { var sidebar = this.sidebar = document.querySelector("#sidebar-box"); if(!sidebar) return; ["dragenter", "drop", "dragexit", "mouseenter", "mouseleave"].forEach((type) => { sidebar.addEventListener(type, this, false); }); ucf_custom_script_win.unloadlisteners.push("autohidesidebar"); }, destructor: function() { var sidebar = this.sidebar; ["dragenter", "drop", "dragexit", "mouseenter", "mouseleave"].forEach((type) => { sidebar.removeEventListener(type, this, false); }); }, handleEvent: function(event) { this[event.type](event); }, click: function(event) { var sidebar = this.sidebar; var boxObj = sidebar.getBoundingClientRect(), boxScrn = !sidebar.boxObject ? sidebar : sidebar.boxObject; if (event.screenY < boxScrn.screenY || event.screenY > boxScrn.screenY + boxObj.height || event.screenX < boxScrn.screenX || event.screenX > boxScrn.screenX + boxObj.width) { window.removeEventListener("click", this, false); this.listener = false; if (sidebar.hasAttribute("sidebardrag")) sidebar.removeAttribute("sidebardrag"); } }, mouseenter: function() { var sidebar = this.sidebar; if (!sidebar.hasAttribute("sidebardrag") && !this.listener) { clearTimeout(this.timer); var delay = this.delay || (this.delay = +getComputedStyle(sidebar).getPropertyValue("transition-delay").replace(/[^0-9\.]/g, "") * 1000); this.timer = setTimeout(() => { sidebar.setAttribute("sidebardrag", "true"); this.listener = true; window.addEventListener("click", this, false); }, delay); } }, mouseleave: function() { clearTimeout(this.timer); }, dragenter: function() { if (!this.sidebar.hasAttribute("sidebardrag")) this.sidebar.setAttribute("sidebardrag", "true"); }, drop: function() { if (this.sidebar.hasAttribute("sidebardrag")) this.sidebar.removeAttribute("sidebardrag"); }, dragexit: function(event) { var sidebar = this.sidebar; var boxObj = sidebar.getBoundingClientRect(), boxScrn = !sidebar.boxObject ? sidebar : sidebar.boxObject; if ((!event.relatedTarget || event.screenY <= (boxScrn.screenY + 5) || event.screenY >= (boxScrn.screenY + boxObj.height - 5) || event.screenX <= (boxScrn.screenX + 5) || event.screenX >= (boxScrn.screenX + boxObj.width - 5)) && sidebar.hasAttribute("sidebardrag")) sidebar.removeAttribute("sidebardrag"); } }).init(this);
@-moz-document url("chrome://browser/content/browser.xhtml") { #sidebar-box { --v-sidebar-min-width: 2px; --v-sidebar-min-width-normal: 5px; --v-sidebar-max-width: 26em; --v-sidebar-transition-delay-show: .2s; --v-sidebar-transition-delay-hide: .0s; --v-sidebar-transition-duration: .1s; /* ********************************************** */ position: relative !important; z-index: 2 !important; min-width: var(--v-sidebar-max-width) !important; width: var(--v-sidebar-max-width) !important; max-width: var(--v-sidebar-max-width) !important; overflow: hidden !important; opacity: 0 !important; --v-sidebar-margin-max-width: calc(-1 * var(--v-sidebar-max-width)); --v-sidebar-transform-locale-dir: -1; --v-sidebar-transform-locale-dir-visible: 1; margin-inline-start: 0 !important; margin-inline-end: var(--v-sidebar-margin-max-width) !important; border: none !important; border-inline-end: 1px solid var(--sidebar-border-color, ThreeDShadow) !important; transform: translateX(calc(var(--v-sidebar-transform-locale-dir) * (var(--v-sidebar-max-width) - var(--v-sidebar-min-width)))) !important; transition-timing-function: linear, step-start !important; transition-delay: var(--v-sidebar-transition-delay-hide), calc(var(--v-sidebar-transition-delay-hide) + var(--v-sidebar-transition-duration)) !important; transition-duration: var(--v-sidebar-transition-duration), 0s !important; transition-property: transform, opacity !important; } #sidebar-box[positionend="true"] { margin-inline-start: var(--v-sidebar-margin-max-width) !important; margin-inline-end: 0 !important; border-inline-start: 1px solid var(--sidebar-border-color, ThreeDShadow) !important; border-inline-end: none !important; } #sidebar-box[positionend="true"]:-moz-locale-dir(ltr), #sidebar-box:not([positionend="true"]):-moz-locale-dir(rtl) { --v-sidebar-transform-locale-dir: 1; --v-sidebar-transform-locale-dir-visible: -1; } :root[v_vertical_bar_autohide][v_vertical_bar_sidebar="true"] #sidebar-box:not(:hover,[sidebardrag]), :root[v_vertical_bar_autohide]:not([v_vertical_bar_sidebar]) #sidebar-box:not(:hover,[sidebardrag]) { transition-delay: 0s, var(--v-sidebar-transition-duration) !important; } :root[sizemode="normal"] #sidebar-box { --v-sidebar-min-width: var(--v-sidebar-min-width-normal) !important; } #sidebar-box:hover, #sidebar-box[sidebardrag] { transform: translateX(0px) !important; opacity: 1 !important; transition-delay: var(--v-sidebar-transition-delay-show) !important; } :root[v_vertical_bar_visible][v_vertical_bar_start="true"] #sidebar-box:not([positionend="true"]), :root[v_vertical_bar_visible][v_vertical_bar_start="false"] #sidebar-box[positionend="true"] { transform: translateX(calc(var(--v-sidebar-transform-locale-dir-visible) * var(--v-vertical_bar_width, 0px))) !important; opacity: 1 !important; transition-delay: 0s !important; } #browser > #sidebar-splitter { display: none !important; } #sidebar-box > #sidebar { min-width: 0 !important; width: auto !important; max-width: none !important; -moz-box-flex: 1 !important; } }
Отредактировано vassemm (11-11-2024 23:05:47)
Отсутствует
vassemm
Попробуйте изменить z-index
Жизнь иногда такое выкидывает, что хочется подобрать...
Отсутствует
Попробуйте изменить z-index /* z-index: 2 !important; */ z-index: 3 !important;
Вы мой спаситель.
Благодарю вас.
Все работает.
Отредактировано vassemm (12-11-2024 15:39:44)
Отсутствует