>Форум Mozilla Россия http://forum.mozilla-russia.org/index.php >Сustom Buttons http://forum.mozilla-russia.org/viewforum.php?id=34 >[CB]Редактировать размеры диалога добавления закладок звёздочки http://forum.mozilla-russia.org/viewtopic.php?id=69566 |
bunda1 > 17-03-2016 22:06:12 |
Редактировать размеры поля выбора вкладок в диалоге добавления закладки звёздочки( Firefox45+ ) Скриншот: Использование: положите код в любую Custom Buttons кнопку, в инициализацию. Не обязательно создавать новую CB кнопку, можно использовать уже существующую. Выделить код Код:// Редактировать размеры поля выбора вкладок в окне добавления закладки звёздочки, от 28.03.2016. ............. ((h, w)=> { cbu.isPref(h, 150); cbu.isPref(w, 150); addEventListener('popupshowing', (e, el = e.target)=> { if (el !== StarUI.panel) return; var tree = document.getElementById('editBMPanel_folderTree'); tree.height = cbu.getPrefs(h); tree.width = cbu.getPrefs(w); setTimeout(()=> gEditItemOverlay.toggleFolderTreeVisibility(), 0); el.addEventListener('popuphidden', function c() { el.removeEventListener('popuphidden', c); cbu.setPrefs(h, tree.height); cbu.setPrefs(w, tree.width); }); }); var uri = makeURI('data:text/css,'+ encodeURIComponent('\ #editBMPanel_folderTree { resize: both !important; overflow: hidden !important; }\ #editBMPanel_folderTree > stack > treerows > scrollbar { display: none !important; }\ #editBMPanel_locationRow, #editBMPanel_keywordRow, #editBMPanel_loadInSidebarCheckbox { visibility: visible !important; }\ ')); var sss = Cc["@mozilla.org/content/style-sheet-service;1"].getService(Ci.nsIStyleSheetService); sss.loadAndRegisterSheet(uri, 0); addDestructor(reason => { sss.unregisterSheet(uri, 0); if (reason == "delete") cbu.clearPrefs(h), cbu.clearPrefs(w); }); })('CB.treeHeight', 'CB.treeWidth'); |
turbot > 17-03-2016 22:52:58 |
bunda1 , так как он все равно не работает (не прокрутка вообще, а именно полоса прокрутки) с этим стилем. Что с overflow: auto, что с hidden. Черт знает, почему. |
bunda1 > 17-03-2016 23:00:21 |
turbot пишет
И правда скроллбар не работает. Я изменил код так как ты предложил, спасибо. |
voqabuhe > 17-03-2016 23:09:59 |
bunda1 |
bunda1 > 17-03-2016 23:19:24 |
voqabuhe пишет
У меня вроде грузится |
turbot > 17-03-2016 23:41:55 |
bunda1 Приводит к тому, что при открытии #editBMPanel_folderMenuList дерево схлопывается/расхлопывается при повторном открытии. - то после перезапуска браузера, при первом открытии, дерево пустое открывается. |
voqabuhe > 18-03-2016 00:07:54 |
bunda1 пишет
Странно
|
Dumby > 18-03-2016 01:54:03 |
turbot пишет
Ну разумеется, если в обоих listener'ах не проверять, |
turbot > 18-03-2016 02:31:31 |
Выделить код Код:if (e.target == document.getElementById('editBookmarkPanel')) gEditItemOverlay.toggleFolderTreeVisibility(); ? Закрытие, вроде, не мешает. А я думал, что если листенер итак на нее повешен, то и уточнять не надо. Эх, видать все-таки пора уже собрать волю, да поизучать теорию, а не продолжать тыкаться наугад. |
Dumby > 18-03-2016 04:44:41 |
turbot пишет
Не мешает чему? скрытый текст Код сделан так, что если, например, открылась #editBookmarkPanel, то регистрируется новый listener на событие popuphidden ваще для окна браузера. То есть, если после этого в окне браузера, например, навести мышь на что-либо, то если tooltip появится, значит tooltip неизбежно закроется, и listener После этого такого случая уже не сработает никакой cbu.setPrefs, ведь listener удалён. Так что решай сам, мешает закрытие или не мешает. |
bunda1 > 18-03-2016 08:16:53 |
Dumby прав насчёт второго обработчика, я это исправил в коде. Спасибо. |
turbot > 18-03-2016 08:39:59 |
Dumby bunda1 впиндюрить? |
bunda1 > 18-03-2016 14:37:30 |
turbot пишет Вроде разобрался с обработчиками и проблема про которую ты писал исчезла: Вчера 22:06:12 без removeAttribute('collapsed') |
turbot > 18-03-2016 19:50:20 |
bunda1 А, похоже, проблема с папками и скроллбаром и в старом варианте есть. Мне таймаут помог: скрытый текст Выделить код Код:addEventListener('popupshown', (e)=> { document.getElementById('editBMPanel_locationRow').removeAttribute('collapsed'); var tree = document.getElementById('editBMPanel_folderTree'); tree.setAttribute('style', 'resize: both !important; overflow: auto !important;'); var h = 'CB.treeHeight', w = 'CB.treeWidth'; cbu.isPref(h, 150); cbu.isPref(w, 150); tree.height = cbu.getPrefs(h); tree.width = cbu.getPrefs(w); setTimeout(()=> { if (e.target == document.getElementById('editBookmarkPanel')) gEditItemOverlay.toggleFolderTreeVisibility(); tree.setAttribute('hidevscroll', 'true'); },100); document.getElementById('editBookmarkPanel').addEventListener('popuphidden', function() { cbu.setPrefs(h, tree.height); cbu.setPrefs(w, tree.width); }, false); }, true, document.getElementById('editBookmarkPanel')); Так нормально работает. P.S.: - это я про другое. Раскрывает строку редактирования адреса: скрытый текст Тож полезная штука. |
bunda1 > 18-03-2016 21:12:41 |
turbot пишет
Действительно полезное я его добавил в код. 18-03-2016 21:14:43 turbot пишет
Сейчас работает на Firefox48 без проблем: Вчера 22:06:12 18-03-2016 21:21:28 turbot пишет
Да работает, но может рациональней было сделать код с одним editBookmarkPanel 18-03-2016 21:25:39 |
turbot > 18-03-2016 21:27:01 |
bunda1 пишет
У меня именно с этой версией вышеописанные проблемы. Попробуйте после изменения размера, перезапустить браузер и открыть панель первый раз - размер сбрасывается на дефолтный, скролбар на месте, а папки с закладками в дереве - не реагируют на нажатия.
Я не придумал, как его один раз присобачить, если только из листенера переменную вытащить. |
bunda1 > 18-03-2016 21:36:03 |
turbot пишет
Да, папки с закладками в дереве - не реагируют на нажатия, остальное на Firefox45 без проблем. Странно. 18-03-2016 21:38:03 |
turbot > 18-03-2016 21:50:53 |
bunda1 |
bunda1 > 18-03-2016 22:01:16 |
turbot пишет
Да, но хочется что бы всё раскрывало быстрее. |
Dumby > 19-03-2016 16:46:46 |
Разрешите тоже попробовать скрытый текст Выделить код Код:(({panel}, {prefs}, pref, listener = { handleEvent(e) { this.locationRow = panel.querySelector("#editBMPanel_locationRow"); var tree = this.folderTree = panel.querySelector("#editBMPanel_folderTree"); tree.style.resize = "both"; tree.style.overflow = "hidden"; var treerows = tree.inputField.previousSibling; addEventListener("overflow", e => e.stopPropagation(), true, treerows); cbu.isPref(pref, "200 300"); addEventListener("popuphidden", this, false, panel); this.handleEvent = e => e.target == panel && this[e.type](); setTimeout(() => { treerows.setAttribute("hidevscroll", true); this.popupshowing(); }, 0); }, popupshowing() { gEditItemOverlay.toggleFolderTreeVisibility(); setTimeout(() => this.locationRow.collapsed = false, 0); var [width, height] = prefs.getCharPref(pref).split(" "); this.folderTree.width = this.width = width; this.folderTree.height = this.height = height; }, popuphidden() { var {width, height} = this.folderTree; if (width != this.width || height != this.height) prefs.setCharPref( pref, width + " " + height ); } }) => { addEventListener("popupshowing", listener, false, panel); addDestructor(reason => { reason == "delete" && prefs.clearUserPref(pref); var tree = listener.folderTree; if (!tree) return; for(var prop of ["resize", "overflow"]) tree.style.removeProperty(prop); tree.getAttribute("style") || tree.removeAttribute("style"); listener.locationRow.collapsed = true; tree.inputField.previousSibling.removeAttribute("hidevscroll"); for(var attr of ["width", "height"]) tree.removeAttribute(attr); }); })(StarUI, Services, "CB.editBMPanel_folderTree_WidthHeight"); |
voqabuhe > 19-03-2016 17:10:38 |
Dumby пишет
Вещь. Спасибо. |
turbot > 19-03-2016 18:44:28 |
Dumby (А почему querySelector? Не то чтоб разница большая, но все ж...) |
difabor > 19-03-2016 19:09:01 |
Dumby пишет
У меня на 28 этот код не компилируется (иконка - "мутная"). Что в нём надо изменить, чтоб код работал? |
bunda1 > 19-03-2016 23:08:34 |
Я изменил код, теперь окошко добавления закладки звёздочки открывается быстрее: Редактировать размеры поля выбора вкладок в диалоге добавления закладки звёздочки 19-03-2016 23:11:12 Dumby пишет
Спасибо, я опять из твоего кода узнал что то новое для себя. |
Dumby > 27-03-2016 03:33:28 |
difabor скрытый текст Выделить код Код:(({panel}, {prefs}, pref, overlay, listener = { handleEvent: function(e) { if (e.defaultPrevented) return; cbu.isPref(pref, "200 300"); this.tree = panel.querySelector("#editBMPanel_folderTree"); this.uri = makeURI("data:text/css," + encodeURIComponent('\ @namespace url(' + xulns + ');' + '\n\n\ #editBMPanel_locationRow { visibility: visible; }\n\ #editBMPanel_folderTree { resize: both; overflow: scroll; }\n\ #editBMPanel_folderTree > stack > treerows > scrollbar { display: none; }\n\ #editBMPanel_folderTree > scrollbar[orient="vertical"] { visibility: hidden; }\n\ #editBMPanel_folderTree > scrollbar[orient="horizontal"] { display: none; }\n\ #editBMPanel_folderTree, #editBMPanel_folderTreeRow, #editBookmarkPanelContent { -moz-box-flex: 1; }\n\ '.replace(/;/g, " !important;"))); this.dwu = QueryInterface(Ci.nsIInterfaceRequestor).getInterface(Ci.nsIDOMWindowUtils); this.dwu.loadSheet(this.uri, this.type = this.dwu.AGENT_SHEET); this.handleEvent = e => e.target == panel && this[e.type](); addEventListener("popuphidden", this, false, panel); overlay ? this.popupshowing() : setTimeout(() => this.popupshowing(), 0); }, popupshowing: function() { var [width, height] = prefs.getCharPref(pref).split(" "); this.tree.width = this.width = width; this.tree.height = this.height = height; gEditItemOverlay.toggleFolderTreeVisibility(); panel.adjustArrowPosition(); }, popuphidden: function() { var {width, height} = this.tree; if (width == this.width && height == this.height) return; prefs.setCharPref(pref, width + " " + height); } }) => { addEventListener("popupshowing", listener, false, panel); addDestructor(reason => { reason == "delete" && prefs.clearUserPref(pref); var {tree} = listener; if (!tree) return; tree.removeAttribute("width"); tree.height = 150; listener.dwu.removeSheet(listener.uri, listener.type); }); })(StarUI, Services, "CB.editBMPanel_folderTree_WidthHeight", StarUI._overlayLoaded); |
difabor > 27-03-2016 18:33:09 |
Dumby пишет
Большое спасибо! |
Dumby > 27-03-2016 22:20:22 |
difabor скрытый текст Находишь в коде соответствующую CSS-строку, и дописываешь id нужных row'сов, примерно так Выделить код Код:#editBMPanel_locationRow, #editBMPanel_keywordRow, #editBMPanel_descriptionRow { visibility: visible; }\n\ Поскольку текстбокс Описания многострочен, то Выделить код Код:addEventListener("keypress", e => e.key == "Enter" && e.stopPropagation(), false, panel.querySelector("#editBMPanel_descriptionField")); |
difabor > 27-03-2016 23:35:42 |
Dumby пишет
Огромнейшее спасибо! |
voqabuhe > 28-03-2016 00:21:48 |
Dumby пишет
В Stylish это работает. А как это в кнопку добавить, ничего не понял? |
Dumby > 28-03-2016 13:49:21 |
voqabuhe скрытый текст Выделить код Код:(({panel}, {prefs}, pref, listener = { handleEvent: function(e) { if (e.defaultPrevented) return; cbu.isPref(pref, "200 300"); this.tree = panel.querySelector("#editBMPanel_folderTree"); this.uri = makeURI("data:text/css," + encodeURIComponent('\ @namespace url(' + xulns + ');' + '\n\n\ #editBMPanel_locationRow, #editBMPanel_keywordRow, #editBMPanel_descriptionRow { visibility: visible; }\n\ #editBMPanel_folderTree { resize: both; overflow: hidden; }\n\ #editBMPanel_folderTree > stack > treerows > scrollbar { display: none; }\n\ '.replace(/;/g, " !important;"))); this.dwu = QueryInterface(Ci.nsIInterfaceRequestor).getInterface(Ci.nsIDOMWindowUtils); this.dwu.loadSheet(this.uri, this.type = this.dwu.AGENT_SHEET); this.handleEvent = e => e.target == panel && this[e.type](); addEventListener("popuphidden", this, false, panel); setTimeout(() => this.popupshowing(), 0); addEventListener("keypress", e => e.key == "Enter" && e.stopPropagation(), false, panel.querySelector("#editBMPanel_descriptionField")); }, popupshowing: function() { var [width, height] = prefs.getCharPref(pref).split(" "); this.tree.width = this.width = width; this.tree.height = this.height = height; gEditItemOverlay.toggleFolderTreeVisibility(); setTimeout(() => { gEditItemOverlay._initDescriptionField(); gEditItemOverlay._initKeywordField(); }, 0); }, popuphidden: function() { var {width, height} = this.tree; if (width == this.width && height == this.height) return; prefs.setCharPref(pref, width + " " + height); } }) => { addEventListener("popupshowing", listener, false, panel); addDestructor(reason => { reason == "delete" && prefs.clearUserPref(pref); var {tree} = listener; if (!tree) return; tree.removeAttribute("width"); tree.removeAttribute("height"); listener.dwu.removeSheet(listener.uri, listener.type); }); })(StarUI, Services, "CB.editBMPanel_folderTree_WidthHeight"); |
bunda1 > 28-03-2016 13:58:47 |
Редактировать размеры поля выбора вкладок в диалоге добавления закладки звёздочки |
voqabuhe > 28-03-2016 15:50:22 |
Dumby пишет
Спасибо большое. Иногда бывает нужно, но вот место занимают полезное... Пока в кнопке закомментировал, а пользоваться решил стилем №27, который отключаю твоей же кнопкой №728. За которую отдельное спасибо. ПС Ну вот что мне действительно нужно, так это №1158, просто успокоится не могу Может глянешь когда время будет? Плиз. |
Dumby > 29-03-2016 13:57:29 |
voqabuhe пишет
Вот, например, если у тебя хидер звёздочной панельки (#editBookmarkPanelHeader) скрытый текст Выделить код Код:(({panel}, {prefs}, pref, listener = { handleEvent: function(e) { if (e.defaultPrevented) return; cbu.isPref(pref, "200 300"); this.tree = panel.querySelector("#editBMPanel_folderTree"); this.uri = makeURI("data:text/css," + encodeURIComponent(`\ @namespace url(${xulns});` + `\n #editBMPanel_folderTree { resize: both; overflow: hidden; } #editBMPanel_folderTree > stack > treerows > scrollbar { display: none; } `.replace(/;/g, " !important;"))); this.dwu = QueryInterface(Ci.nsIInterfaceRequestor).getInterface(Ci.nsIDOMWindowUtils); this.dwu.loadSheet(this.uri, this.type = this.dwu.AGENT_SHEET); this.handleEvent = e => e.target == panel && this[e.type](); addEventListener("popuphidden", this, false, panel); setTimeout(() => this.popupshowing(), 0); addEventListener("keypress", e => e.key == "Enter" && e.stopPropagation(), false, panel.querySelector("#editBMPanel_descriptionField")); var data = { editBMPanel_locationRow: "", editBMPanel_keywordRow: "_initKeywordField", editBMPanel_descriptionRow: "_initDescriptionField" }; var nodes = Object.keys(data).map(id => panel.querySelector("#" + id)); addEventListener("click", e => { var state = nodes[0].collapsed; for(var node of nodes) { state ? node.removeAttribute("collapsed") : node.collapsed = true; state && data[node.id] && gEditItemOverlay[data[node.id]](); } panel.adjustArrowPosition(); }, false, panel.querySelector("#editBookmarkPanelHeader")); }, popupshowing: function() { var [width, height] = prefs.getCharPref(pref).split(" "); this.tree.width = this.width = width; this.tree.height = this.height = height; setTimeout(() => gEditItemOverlay.toggleFolderTreeVisibility() || panel.adjustArrowPosition(), 0); }, popuphidden: function() { var {width, height} = this.tree; if (width == this.width && height == this.height) return; prefs.setCharPref(pref, width + " " + height); } }) => { addEventListener("popupshowing", listener, false, panel); addDestructor(reason => { reason == "delete" && prefs.clearUserPref(pref); var {tree} = listener; if (!tree) return; tree.removeAttribute("width"); tree.removeAttribute("height"); listener.dwu.removeSheet(listener.uri, listener.type); }); })(StarUI, Services, "CB.editBMPanel_folderTree_WidthHeight"); voqabuhe пишет
Не, я не знаю как там всё разрулить. Впрочем, можно попробавать. скрытый текст Выделить код Код:(({panel}, prefName) => { cbu.isPref(prefName, PlacesUtils.unfiledBookmarksFolderId); addDestructor(reason => reason == "delete" && Services.prefs.clearUserPref(prefName)); var popupshownFolderId = Services.prefs.getIntPref(prefName); var handler = e => { if (e.target != panel) return; var id = PlacesUtils.bookmarks.getFolderIdForItem(StarUI._itemId); if (e.type == "popupshown") { popupshownFolderId = id; return; } if (StarUI._actionOnHide || popupshownFolderId == id) return; Services.prefs.setIntPref(prefName, id); } for(var type of ["popupshown", "popuphiding"]) addEventListener(type, handler, false, panel); var src = BookmarkingUI.onCommand.toString(); var showPopup = true; var res = src.replace("true", `${showPopup || "isBookmarked"}, isBookmarked ? undefined : Services.prefs.getIntPref("${prefName}")`); var func = eval(`(${res})`).bind(BookmarkingUI); BookmarkingUI.star && addEventListener("command", e => e.stopPropagation() || func(e), true, BookmarkingUI.star); addEventListener("dblclick", e => { if ( e.button || e.ctrlKey || e.shiftKey || e.altKey || e.target.nodeName != "tab" || isBlankPageURL(gBrowser.currentURI.spec) || BookmarkingUI._pendingStmt ) return; var isBookmarked = BookmarkingUI._itemIds.length > 0; var parent = isBookmarked ? undefined : Services.prefs.getIntPref(prefName); PlacesCommandHook.bookmarkCurrentPage(showPopup || isBookmarked, parent); isBookmarked || BookmarkingUI._showBookmarkedNotification(); }, false, gBrowser.tabContainer); })(StarUI, "CB.lastEditBookmarkPanelFolderId"); |
voqabuhe > 29-03-2016 17:24:07 |
Dumby пишет
Ура, он сделал это!!! Нет слов, ну просто волшебник. Тысяча благодарностей. Только если можно чтобы закладки вверх списка добавлялись, для полного счастья? Плиз. Dumby пишет
Я там скрыл это всё стилем, срабатывает, но надо тщательно целится в пустое место. Поэтому повесил на #editBMPanel_tagsRow > label. Получилось очень даже классно и удобно. Ещё раз огромное спасибо. Ну просто праздник сегодня какой-то. |
shadow_user > 07-01-2017 11:52:48 |
Dumby пишет
Кнопка №20 работает отлично, слов нет. Можно ли ярко-белый фон открывающегося меню сменить на менее светлый, а то режет глаз? На маленьком диалоге это не бросалось в глаза, а на большом очень заметно. |
xoreax > 07-01-2017 16:41:25 |
shadow_user пишет
Есть такой, себе сделал стиль. Правда у мя PaleMoon + стоит плугин для этого, для раскрытия меню Add Bookmark Here ² но вроде бы там селекторы не менялись. скрытый текст Выделить код Код:/* ======= Панель-Звездочка закладки(клик на звездочке в урл) ================== */ panel#editBookmarkPanel >.panel-arrowcontainer > .panel-arrowcontent { -moz-appearance:none !important; background: rgba(150,150,150,.6) -moz-linear-gradient(top,rgba(255, 255, 255, 0.21),rgba(255, 255, 255, 0.13) 49%,rgba(255, 255, 255, 0.094) 51%, rgba(255, 255, 255, 0.05)) !important; border: 1px solid #909090 !important; box-shadow: 0px 1px 1px rgba(255, 255, 255, 0.2) inset, 0px 1px 3px rgba(0, 0, 0, 0.5) !important; } #editBookmarkPanelHeader > vbox > #editBookmarkPanelTitle[value="Edit This Bookmark"] { color: #8A2BE2 !important; } #editBookmarkPanelStarIcon { list-style-image: url("") !important; width: 32px !important; height: 32px !important; } panel#editBookmarkPanel > * { font-family: Cambria, "Segoe UI", Arial; font-weight: 600 !important; font-stretch: condensed; text-shadow: #EEE -1px -1px 0.35em, white -1px 1px 0.35em, white 1px 1px 0.35em, white 1px -1px 0.35em; } /* общие размеры панели */ panel#editBookmarkPanel { height: 650px !important; width: 550px !important; } /* высота дерева папок с закладками */ #editBMPanel_folderTree { min-height: 400px !important; } #editBMPanel_folderTree > treechildren { background: rgba(255,240,183,.94) -moz-linear-gradient(top,rgba(255, 255, 255, 0.21),rgba(255, 255, 255, 0.13) 49%,rgba(255, 255, 255, 0.094) 51%, rgba(255, 255, 255, 0.05)) !important; font-family: "Segoe UI", Arial; } #editBMPanel_descriptionField { min-height: 100px !important; } textbox[id^="editBMPanel_"]:not([focused="true"]) { -moz-appearance: none !important; background: rgba(210,210,210,.9) -moz-linear-gradient(top,rgba(255, 255, 255, 0.21),rgba(255, 255, 255, 0.13) 49%,rgba(255, 255, 255, 0.094) 51%, rgba(255, 255, 255, 0.05)) !important; } textbox[id^="editBMPanel_"][focused="true"] { -moz-appearance:none !important; background: rgba(255,240,183,.9) -moz-linear-gradient(top,rgba(255, 255, 255, 0.21),rgba(255, 255, 255, 0.13) 49%,rgba(255, 255, 255, 0.094) 51%, rgba(255, 255, 255, 0.05)) !important; } убери, если не надо, все где есть размеры(width, height). Выглядит так: |
shadow_user > 07-01-2017 20:34:51 |
xoreax пишет
Спасибо, но не осилил. Вставил код в инициализацию существующей- не заработало. |
Dumby > 07-01-2017 21:33:42 |
shadow_user пишет
В смысле хочешь свой стиль в код пристроить? скрытый текст Выделить код Код:(({panel}, {prefs}, pref, listener = { handleEvent(e) { var style = ` #editBookmarkPanel .panel-arrowcontent { background-color: gray !important; border: 1px solid black !important; } #editBookmarkPanel .panel-arrow:-moz-any([side="top"], [side="bottom"]) { list-style-image: url('data:image/svg+xml,\\${["", '<svg xmlns="http://www.w3.org/2000/svg" width="20" height="10">\\%0A\\', ' <path d="M 0,10 L 10,0 20,10 z" fill="black"/>\\%0A\\', ' <path d="M 1,10 L 10,1 19,10 z" fill="gray"/>\\%0A\\', '</svg>'].join("\n" + " ".repeat(8))}') !important; } #editBookmarkPanel :-moz-any(textbox, listbox) { -moz-appearance: none !important; border: 1px solid black !important; } #editBookmarkPanel :-moz-any(textbox, listbox, treechildren, menupopup) { background-color: lightgray !important; } #editBookmarkPanel listitem, #editBookmarkPanel treechildren::-moz-tree-row { height: 1.6em !important; border: none !important; border-radius: 0 !important; outline: none !important; background-image: none !important; background-color: transparent !important; box-shadow: none !important; } #editBookmarkPanel treechildren::-moz-tree-row(hover) { background-color: #b4b4b4 !important; } #editBookmarkPanel treechildren::-moz-tree-row(hover, focus) { background-color: #91c8ff !important; } #editBookmarkPanel listbox listitem[selected=true], #editBookmarkPanel treechildren::-moz-tree-row(selected) { background-color: gray !important; } #editBookmarkPanel listbox:focus listitem[selected=true], #editBookmarkPanel treechildren::-moz-tree-row(selected, focus) { background-color: Highlight !important; } `.trim(); var dwu = QueryInterface(Ci.nsIInterfaceRequestor).getInterface(Ci.nsIDOMWindowUtils); var str = "data:text/css," + encodeURIComponent(style), type = dwu.AGENT_SHEET; dwu.loadSheetUsingURIString(str, type); addDestructor(() => dwu.removeSheetUsingURIString(str, type)); this.locationRow = panel.querySelector("#editBMPanel_locationRow"); var tree = this.folderTree = panel.querySelector("#editBMPanel_folderTree"); tree.style.resize = "both"; tree.style.overflow = "hidden"; var treerows = tree.inputField.previousSibling; addEventListener("overflow", e => e.stopPropagation(), true, treerows); cbu.isPref(pref, "200 300"); addEventListener("popuphidden", this, false, panel); this.handleEvent = e => e.target == panel && this[e.type](); setTimeout(() => { treerows.setAttribute("hidevscroll", true); this.popupshowing(); }, 0); }, popupshowing() { gEditItemOverlay.toggleFolderTreeVisibility(); setTimeout(() => this.locationRow.collapsed = false, 0); var [width, height] = prefs.getCharPref(pref).split(" "); this.folderTree.width = this.width = width; this.folderTree.height = this.height = height; }, popuphidden() { var {width, height} = this.folderTree; if (width != this.width || height != this.height) prefs.setCharPref( pref, width + " " + height ); } }) => { addEventListener("popupshowing", listener, false, panel); addDestructor(reason => { reason == "delete" && prefs.clearUserPref(pref); var tree = listener.folderTree; if (!tree) return; for(var prop of ["resize", "overflow"]) tree.style.removeProperty(prop); tree.getAttribute("style") || tree.removeAttribute("style"); listener.locationRow.collapsed = true; tree.inputField.previousSibling.removeAttribute("hidevscroll"); for(var attr of ["width", "height"]) tree.removeAttribute(attr); }); })(StarUI, Services, "CB.editBMPanel_folderTree_WidthHeight"); |
xoreax > 08-01-2017 07:30:57 |
shadow_user пишет
|
shadow_user > 08-01-2017 09:21:22 |
Dumby пишет
Спасибо, работает. Можно ли увеличить шрифт во всем окне или в дереве папок? xoreax пишет
Спасибо, конечно же, так работает. И тот же вопрос по размеру шрифта |
xoreax > 08-01-2017 10:19:35 |
shadow_user пишет
Можно, но это уже оффтоп, наверно. со стилями надобно в стили. скрытый текст Выделить код Код:/* увеличить шрифт в дереве папкок "Звездочки" */ #editBMPanel_folderTree > treechildren { background: rgba(255,240,183,.94) -moz-linear-gradient(top,rgba(255, 255, 255, 0.21),rgba(255, 255, 255, 0.13) 49%,rgba(255, 255, 255, 0.094) 51%, rgba(255, 255, 255, 0.05)) !important; font-family: "Segoe UI", Arial; font-size: medium !important; /* или large или конкретный размер: font-size: 16px !important; */ } shadow_user пишет
Заключить их в скобки и оформить как функцию. Работает почти всегда, но есть и достаточно исключений(когда нельзя). Примерно так: |
shadow_user > 08-01-2017 11:20:29 |
xoreax пишет
Т.е. вот так?
|
xoreax > 08-01-2017 11:26:45 |
Да. У мя так в одной кнопке 20 функций лежит и всё робит. |
shadow_user > 08-01-2017 11:53:03 |
xoreax |