Dumby
Нарисовалась хотелка для этого скрипта, тот что под спойлером.
Пишу для истории - скрипт при поиске создает пункт "Показать в папке" в контекстном меню закладок, и в библиотеке, и в закладках сайдбара.
Но проблема в том, что после срабатывания и последующего переоткрытия сайдбара (закрыть и снова открыть) положение поиска сбрасывается. Тоже самое и с нативным пунктом, вот здесь об этом.
А вот у этого скрипта такой проблемы нет. Но к сожалению он не работает в библиотеке и не прячет свой пункт когда нет поиска, т.е. пункт торчит всегда.
Не могли бы вы свой скрипт изменить так, что бы он вел себя в сайдбаре аналогично скрипту alice0775, т.е. не сбрасывал положение поиска после переоткрытия сайдбара?
Отредактировано _zt (25-09-2022 04:05:52)
Отсутствует
Сделайте пожалуйста скрипт для авто... открытия панели загрузок при старте закачки.
Хорошо, попробую. Это в custom_script.js
Services.obs.addObserver(function brw(win, topic) { Services.obs.removeObserver(brw, topic); var {Downloads: d, BrowserWindowTracker: bwt} = win; var show = function(download) { download.newDownloadNotified || bwt.getTopWindow(this)?.DownloadsPanel.showPanel(); }; ["PUBLIC", "PRIVATE"].forEach(async (type, ind) => { var view = Object.create(null); view.private = Boolean(ind); view.onDownloadChanged = show; (await d.getList(d[type])).addView(view); }); }, "browser-delayed-startup-finished");
проблема в том, что после срабатывания и последующего переоткрытия сайдбара (закрыть и снова открыть) положение поиска сбрасывается
«положение поиска» это какие папки развёрнуты?
Если так, то можно попробовать запоминать принудительно.
/* tree.scrollByLines(Math.round(newFirst - first)); } */ tree.scrollByLines(Math.round(newFirst - first)); this.persist(tree.view); }, persist(view) { var du = document.documentURI, xs = Services.xulStore; var obf = PlacesUIUtils.obfuscateUrlForXulStore, set = obf ? u => xs.setValue(du, obf(u), "open", "true") : u => xs.setValue(du, u, "open", "true"); (this.persist = view => { for(var node of view._rows) node.containerOpen && set(node.uri) })(view); }
Отсутствует
_zt, voqabuhe
По совету умных товарищей "переполз" со "старого" UCF на "новый". Вроде, все стили и кнопки подключились, но, как оказалось, рано радовался - скрипт SidebarBookmarkSearchOpenFolder.uc.js в этом "новом" у меня не работает. Судя по постам, скрипт лучше штатной возможности "Показать в папке" (#placesContext_showInFolder).
Скрипт у меня в "старом" варианте подключался по какой-то хитрой схеме. Куда его втыкать теперь? В CustomStylesScripts.jsm этот вариант не работает.
load: [ // По событию "load" { path: "special_widgets.js", ucfobj: true, }, // <-- Special Widgets // { path: "auto_hide_sidebar.js", ucfobj: true, }, // <-- Auto Hide Sidebar { path: "cs_win/SidebarBookmarkSearchOpenFolder.uc.js", ucfobj: false, },
Отсутствует
В config.js
lockPref("browser.download.panel.shown", false);
Уже нет, при чём эта настройка уже не помню с какой версии перестала работать, как и настройка > browser.download.improvements_to_download_panel = false, отвалилась после обновления на 105.
add, этот способ тоже не работает > lockPref("browser.download.panel.shown", false); + browser.download.alwaysOpenPanel = true
Это в custom_script.js
скрытый текст
Благодарю!!!
Отредактировано kokoss (25-09-2022 14:26:39)
Win7
Отсутствует
Special Widgets
Special Widgets грузится в объект ucf_custom_script_win
окна документа браузера (browser.xhtml).
А закладки в сайдбаре — это другое окно (bookmarksSidebar.xhtml).
Надо прописывать в UcfStylesScripts.scriptsallchrome
Опусти глаза чуть пониже. Пример для Библиотеки видишь?
// { path: "example_places.js", urlregxp: /chrome:\/\/browser\/content\/places\/places\.xhtml/, ucfobj: false, },
Вот туда. Типа
{ path: "cs_win/SidebarBookmarkSearchOpenFolder.uc.js", urlregxp: /chrome:\/\/browser\/content\/places\/bookmarksSidebar\.xhtml/ },
Отсутствует
Dumby
Спасибо, все ок.
xrun1
В load: [ // По событию "load"
{ path: "cs_win/SidebarBookmarkSearchOpenFolder.uc.js", urlregxp: /chrome:\/\/browser\/content\/places\/bookmarksSidebar\.xhtml/, ucfobj: false, },
на перезагрузку с очисткой кэша особо не надейтесь. Делайте ее, закрывайте браузер и проверяйте отсутствие / удаляйте startupCache.
Только вот зачем вам этот обрубок? Только что же обсуждали.
// Пункт контекстного меню закладок "Показать в папке", от Dumby, // работает во всех документах - окно, вкладка, сайдбар. // Появляется при не пустой строке поиска. // https://forum.mozilla-russia.org/viewtopic.php?pid=799551#p799551 // + https://forum.mozilla-russia.org/viewtopic.php?pid=801732#p801732 try {({ run(func) { var topics = ["quit-application-granted", "chrome-document-loaded"]; var obs = Cc["@mozilla.org/observer-service;1"].getService(Ci.nsIObserverService); for(var t of topics) obs.addObserver(this, t, false); this.observe = (subj, topic) => this[topic[0]](subj); this.q = () => topics.forEach(t => obs.removeObserver(this, t)); this.run = async doc => { var code = `(${func})(document.getElementById("placesContext_editSeparator"));`; var ps = await doc.ownerGlobal.ChromeUtils .compileScript("data:charset=utf-8," + encodeURIComponent(code)); (this.run = ps.executeInGlobal.bind(ps))(doc); } var re = /\/(?:places|bookmarksSidebar)\.xhtml$/; this.c = doc => re.test(doc.documentURI) && this.run(doc); } }).run(sep => { var label = "Показать в папке"; var popup = sep.parentNode, listener = { handleEvent() { if (this.shouldHide) return; var menuitem = document.createXULElement("menuitem"); menuitem.setAttribute("label", label); menuitem.setAttribute("oncommand", "creator.goParentFolder();"); menuitem.creator = this; sep.before(menuitem); this.handleEvent = e => { if (e.target != popup) return; var sh = this.shouldHide; if (Boolean(menuitem.clientHeight) ^ sh) return; if ((menuitem.hidden = sh)) return; menuitem.disabled = false; } }, get shouldHide() { var node = popup._view.selectedNodes.length == 1 && popup._view.selectedNode; return !(node && PlacesUtils.nodeIsBookmark(node) && node.parent.type == node.RESULT_TYPE_QUERY); }, get goParentFolder() { var tree = popup._view; if (tree.id.startsWith("b")) { delete this.library; var func = () => this.sidebar(tree); } else { delete this.sidebar; var list = document.getElementById("placesList"); var func = () => this.library(popup._view, list); } delete this.goParentFolder; return this.goParentFolder = func; }, sidebar(tree) { var {bookmarkGuid} = tree.selectedNode; if (tree.result.root.uri.startsWith("place:terms=")) tree.place = tree.place; tree.selectItems([bookmarkGuid]); this.scroll(tree); }, async library(tree, list) { var {bookmarkGuid} = tree.selectedNode; var {parentGuid} = await PlacesUtils.bookmarks.fetch(bookmarkGuid); if (PlacesUtils.getConcreteItemGuid(list.selectedNode) == parentGuid) list.selectItems([PlacesUtils.virtualAllBookmarksGuid]); else { var rows = list.view._rows, lastRow = rows[rows.length - 1]; if (lastRow.bookmarkGuid == PlacesUtils.virtualAllBookmarksGuid) lastRow.containerOpen = true; } list.selectItems([parentGuid]); this.scroll(list); tree.selectItems([bookmarkGuid]); await new Promise(requestAnimationFrame); this.scroll(tree); }, scroll(tree) { var pos = .4, visibleRows = tree.getPageLength(); var ind = tree.view.selection.currentIndex; var first = tree.getFirstVisibleRow(); var newFirst = ind - pos*visibleRows + 1; // tree.scrollByLines(Math.round(newFirst - first)); // } tree.scrollByLines(Math.round(newFirst - first)); this.persist(tree.view); }, persist(view) { var du = document.documentURI, xs = Services.xulStore; var obf = PlacesUIUtils.obfuscateUrlForXulStore, set = obf ? u => xs.setValue(du, obf(u), "open", "true") : u => xs.setValue(du, u, "open", "true"); (this.persist = view => { for(var node of view._rows) node.containerOpen && set(node.uri) })(view); } // <<< }; popup.addEventListener("popupshowing", listener); addEventListener("unload", () => popup.removeEventListener("popupshowing", listener) , {once: true}); });} catch(ex) {Cu.reportError(ex);}
Отредактировано _zt (25-09-2022 16:54:44)
Отсутствует
Подскажите по такому вопросу:
при запуске FF открывается домашняя страница, а курсор (фокус) устанавливается в адресную строку и она выделяется голубенькой рамкой
лично по мне логично было бы установить его в строку поиска, которая посередине экрана и именно она бы подсвечивалась
Отредактировано Inko7 (25-09-2022 17:17:20)
Отсутствует
Если бы загрузки тоже отображались в Sidebar'е, окно библиотек мне вообще не нужно.
Может ещё работает в актуальной версии > https://forum.mozilla-russia.org/viewto … 24#p784824
Win7
Отсутствует
А можете еще переместить пункт в самый верх меню и добавить после него сепаратор?
Не исключено. Замена начала кода
try {({ run(func) { var topics = ["quit-application-granted", "chrome-document-loaded"]; var obs = Cc["@mozilla.org/observer-service;1"].getService(Ci.nsIObserverService); for(var t of topics) obs.addObserver(this, t, false); this.observe = (subj, topic) => this[topic[0]](subj); this.q = () => topics.forEach(t => obs.removeObserver(this, t)); this.run = async doc => { var code = `(${func})(document.getElementById("placesContext"));`; var ps = await doc.ownerGlobal.ChromeUtils .compileScript("data:charset=utf-8," + encodeURIComponent(code)); (this.run = ps.executeInGlobal.bind(ps))(doc); } var re = /\/(?:places|bookmarksSidebar)\.xhtml$/; this.c = doc => re.test(doc.documentURI) && this.run(doc); } }).run(popup => { var label = "Показать в папке", listener = { handleEvent() { if (this.shouldHide) return; var menuitem = document.createXULElement("menuitem"); menuitem.setAttribute("label", label); menuitem.setAttribute("oncommand", "creator.goParentFolder();"); menuitem.creator = this; var sep = document.createXULElement("menuseparator"); popup.prepend(menuitem, sep); this.handleEvent = e => { if (e.target != popup) return; var sh = this.shouldHide; if (!( Boolean(menuitem.clientHeight) ^ sh || (menuitem.hidden = sep.hidden = sh) )) menuitem.disabled = false; } },
Как подсказывают, стилем нельзя.
Как это сделать с помощью скрипта?
Ясен пень нельзя. Стили не занимаются отслеживанием запуска и перемещением фокуса.
Вот, весьма криво, но, возможно, сойдёт (это код для custom_script.js).
Services.obs.addObserver(function wr(win, topic) { Services.obs.removeObserver(wr, topic); var re = /^about:(?:newtab|home)$/; var fs = 'data:,content.document.getElementById("newtab-search-text").focus();'; Array.from(CustomizableUI.windows).forEach(async win => { await win.gBrowserInit.firstContentWindowPaintPromise; var br = win.gBrowser.selectedBrowser; if (re.test(br.currentURI.spec)) br.focus(), br.messageManager.loadFrameScript(fs, false); }); }, "sessionstore-windows-restored");
Отсутствует
Dumby
Спасибо. Теперь вообще замечательно.
этот способ тоже не работает > lockPref("browser.download.panel.shown", false); + browser.download.alwaysOpenPanel = true
Работает, только что проверил на 105.
Может ещё работает в актуальной версии > https://forum.mozilla-russia.org/viewtopic.php?pid=784824#p784824
Работает.
Отсутствует
Работает, только что проверил на 105.
А у меня не работает! Работает, если в настройках включена опция"Сохранять файлы", что для меня не вариант, о чём я сообщил здесь > https://forum.mozilla-russia.org/viewtopic.php?pid=801691#p801691
Отредактировано kokoss (26-09-2022 00:02:10)
Win7
Отсутствует
Интересно, что Sidebar Tabs у меня не установлен, о чём сказал выше. А вот кнопка для него стоит, как раз для загрузок (спойлер в п.2). Запасливый, однако!
Отсутствует
kokoss
Вы правы.
lockPref("browser.download.panel.shown", false); + browser.download.alwaysOpenPanel = true
это "Показывать панель загрузок при окончании загрузки", а вам надо "при старте".
Отредактировано _zt (26-09-2022 07:08:08)
Отсутствует
Dumby
Вот, весьма криво, но, возможно, сойдёт (это код для custom_script.js).
Срабатывает как надо, но только один раз при старте браузера.
При открытии новой вкладки (плюсиком) или домашней страницы (домиком) курсор остается в адресной строке.
Отсутствует
но
Это что ещё за «но»?

Отсутствует
возможно ли расширить функционал кода для вариантов открытия новой вкладки (плюсиком) или домашней страницы (домиком) ?
Даже не знаю, может подойдёт вариант "вообще всегда"?
(async fsu => { var beg = "resource:///actors/AboutNewTabParent."; try {var exp = ChromeUtils.importESModule(beg + "sys.mjs");} catch {exp = ChromeUtils.import(beg + "jsm");} var proto = exp.AboutNewTabParent.prototype; var rm = proto.receiveMessage; Object.assign(proto, {async receiveMessage(message) { if (message.name == "AboutNewTabVisible") { var br = this.browsingContext.top.embedderElement; br.focus(); br.messageManager.loadFrameScript(fsu, false); } return rm.call(this, message); }}); })("data:,content.document.getElementById('newtab-search-text').focus();");
Отсутствует
Dumby, посоветовали ваш скрипт для удаления "Панели закладок", "Меню закладок" и "Другие закладки" в боковой панели. Срабатывает отлично на версиях с 68 по 105 с небольшим побочным эффектом: на разделителях между папками появляется разрыв:
Можно это как-то исправить, кроме как удаления разделителей..? И можно ли придумать что-то подобное вашему скрипту для удаления вышеуказанного в "Библиотеке"..?
Отсутствует
скажите, пожалуйста, это осуществимо или нет..?
Да особо сказать нечего.
Заголовок это не часть документа, элемент туда не поместить.
Можно разве что текст подменить.
Например, переопределить метод gBrowser.updateTitlebar()
чтобы он устанавливал document.title со своим вставленным добром.
Ещё можно какой-нибудь <panel> поверх заголовка отобразить,
но я не знаю как по-простому сделать, чтобы за панельку можно было таскать окно,
плюс, заголовского контекстного меню у неё не будет.
Ну и настраивать код, конечно, придётся. То есть что-то типа
(async (n, id) => { var css = ` #${id} { margin-bottom: 2px; margin-right: 102px; border: 0; height: 18px; padding: 0 2px; -moz-appearance: none; background-color: transparent; } :root[sizemode=normal] #${id} { margin-bottom: 3px; } :root[sizemode=fullscreen] #${id} { visibility: collapse; } #${id} > hbox { color: white; height: 18px; font-weight: bold; background-color: red; } #${id} > hbox > box { padding: 0 4px; } `; var ucs = { esr: "ESR", beta: "Beta", release: "Release", nightly: "Nightly", aurora: "DevEdition", default: "Unbraindead", // ? }; var format = {weekday: "long", day: "numeric", month: "long", year: "numeric"}; var attrs = { id, noautohide: true, noautofocus: true, position: "before_end", consumeoutsideclicks: "never" }; css = css.replace(/;/g, " !important;"); var url = "data:text/css;charset=utf-8," + encodeURIComponent(css); windowUtils.loadSheetUsingURIString(url, windowUtils.USER_SHEET); var panel = n("panel"); var hbox = panel.appendChild(n("hbox")); for(var args of Object.entries(attrs)) panel.setAttribute(...args); document.getElementById("mainPopupSet").append(panel); var num = 3; while(num--) hbox.appendChild(n("box")).append(""); var [vers, time, date] = Array.from(hbox.children, b => b.firstChild); var arr = [ Services.appinfo.name, "v" + AppConstants.MOZ_APP_VERSION_DISPLAY, `(${Services.appinfo.is64Bit ? 64 : 32}-bit)` ]; var c = AppConstants.MOZ_UPDATE_CHANNEL, uc = ucs[c]; if (uc) { if (c == "esr") arr[1] = arr[1].slice(0, -3); arr.splice(1, 0, uc); } vers.data = arr.join(" "); var cd; var tick = () => { var dt = new Date(), d = dt.getDate(); if (d != cd) cd = d, upd(dt); time.data = dt.toLocaleTimeString("mn"); } var upd = d => date.data = d.toLocaleDateString("ru", format); tick(); window.setInterval(tick, 1e3); panel.ondblclick = e => { if (e.button) return; panel.collapsed = true; windowState == STATE_MAXIMIZED ? restore() : maximize(); panel.collapsed = false; } panel.openPopup(document.documentElement); var sr = panel.shadowRoot; if (sr) sr.firstChild.removeAttribute("part"); })(nn => document.createXULElement(nn), "vtd-info-panel");
скрипт для удаления
Скрипт ничего не удаляет.
Он меняет корневую ноду places-дерева с «Все закладки» на «Меню закладок».
Можно это как-то исправить, кроме как удаления разделителей..?
Не знаю. Ничего хорошего не придумал.
Так-то, вот этой "чёрточки слева" просто не должно быть.
Если пишу
#bookmarks-view > treechildren::-moz-tree-twisty(separator) {
padding: 0 !important;
}
то разрыв пропадает, но это сдвигает чуть влево и серараторы в субпапках.
А если пишу
#bookmarks-view > treechildren::-moz-tree-separator {
margin-right: 16px !important;
}
то слева сепараторы выглядят как надо, но теряют в продолжительности справа.
И можно ли придумать что-то подобное вашему скрипту для удаления вышеуказанного в "Библиотеке"..?
Да я пробовал раньше. И не раз. И ничего не получилось.
Отсутствует
Dumby
Ну и настраивать код, конечно, придётся.
На Win10 почти идеально выглядит без правок:
и текст не подменяется. Реально круто, спасибо!
если пишу
#bookmarks-view > treechildren::-moz-tree-separator {
margin-right: 16px !important;
}
Этот вариант мне больше понравился... сдвинутый влево почему-то глаз режет, а немного укороченный справа не напрягает совсем.
ничего не получилось
Разве такое может быть..?
Отсутствует