Такой вопрос: можно ли с помощью кнопки реализовать подобную функцию?
Отсутствует
А можете сделать кнопку для отчистки кэша в дополнении Textarea cache. а то задолбало каждый раз окно открывать
Вы ленивы, следовательно вы изобретательны (Граф Де Гиш)
Список настроек About:config на русском языке с пояснениями и рекомендациями
Отсутствует
MySh
Такой вопрос: можно ли с помощью кнопки реализовать подобную функцию?
Можно, другой вопрос - кто бы справился с Selection и Range : )
Вот для одинарного выделения, вроде работает:
var doc = gBrowser. contentDocument; var win = document. commandDispatcher. focusedWindow; var sel = win. getSelection (). QueryInterface (Components. interfaces. nsISelectionPrivate); var range = sel. getRangeAt (0). cloneRange (); sel. startBatchChanges (); sel. removeAllRanges (); var r = doc. createRange (); sel. addRange (r); r. selectNodeContents (doc. body); r. setEnd (range. startContainer, range. startOffset); r = doc. createRange (); sel. addRange (r); r. selectNodeContents (doc. body); r. setStart (range. endContainer, range. endOffset); sel. endBatchChanges (); //win. blur (); //win. focus ();
Инвертирует одинарное выделение, правда, по самому выделению после выполнения операции этого не видно (синим окрашено как попало), но если скопировать и посмотреть во внешнем редакторе, то, вроде бы выделенное не копируется.
Добавлено 20-08-2009 17:51:37
Najlus
Вот команда для открытия диалога Textarea Cache:
Добавлено 20-08-2009 17:54:05
ps:
а это, вроде, очищает кэш
Время настанет, время придет...
И лис кОнкурiентов на части порвет !!!
Отсутствует
Вот команда для открытия диалога Textarea Cache:
Это и стандартная кнопка дополнения умеет
ps:
а это, вроде, очищает кэш
Не работает
Вы ленивы, следовательно вы изобретательны (Граф Де Гиш)
Список настроек About:config на русском языке с пояснениями и рекомендациями
Отсутствует
Najlus
Попробуй добавить первой строкой перед "gPref.clearUserPref"
var gPref = Components.classes["@mozilla.org/preferences-service;1"].getService(Components.interfaces.nsIPrefBranch);
Время настанет, время придет...
И лис кОнкурiентов на части порвет !!!
Отсутствует
Спасибо это работает
Единственный минус: в статусбаре всёравно продолжает гореть иконка данного дополнения.
Отредактировано Najlus (20-08-2009 20:55:01)
Вы ленивы, следовательно вы изобретательны (Граф Де Гиш)
Список настроек About:config на русском языке с пояснениями и рекомендациями
Отсутствует
Najlus
Добавь в конце
Время настанет, время придет...
И лис кОнкурiентов на части порвет !!!
Отсутствует
Anton
Спасибо, буду пробовать
Интересно оно работает — текст инвертируется, но только в пределах одной строчки. Причём к ссылкам это не относится (они работают отдельно). Не совсем то, что мне хотелось, но для начала тоже неплохо!
Занятно, каким макаром захват выделения работает в Scrapbook — тот захватывает не только текст, но и все сопутствующие части страницы. Вот если бы ему как-то объяснить, что как раз их-то захватывать не надо… А возможно ли, условно говоря, перебрать все элементы страницы и узнать, выделены они или нет? Или так оно не сработает?
Отредактировано MySh (20-08-2009 23:27:20)
Отсутствует
MySh
текст инвертируется, но только в пределах одной строчки
Выделение инвертируется полностью, только этого не видно. Предлагаю для проверки выделить кусок текста на этой странице, выполнить код кнопки, "Правка" -> "Копировать", и вставить куда-нибудь в OO Writer - там будет видно.
Занятно, каким макаром захват выделения работает в Scrapbook
Захватывает он, кстати, только одну из частей множественного выделения (при ручном выделении - первую). У меня, по крайней мере (версия 1.3.3.10).
Если надо удалить выделение из страницы перед сохранением в Scrapbook, есть код попроще:
var sel = document. commandDispatcher. focusedWindow. getSelection (); sel. deleteFromDocument ();
Он работает и с множественным выделением.
Время настанет, время придет...
И лис кОнкурiентов на части порвет !!!
Отсутствует
Anton
Выделение инвертируется полностью, только этого не видно
Гм… А ведь верно! Работает, и работает весьма неплохо! Правда, местами всё равно подчищать приходится. Чёткой закономерности пока не вывел. Поработаю ещё, попробую, как пойдёт.
Добавлено 21-08-2009 00:51:39
Если надо удалить выделение из страницы перед сохранением в Scrapbook
Наоборот — то, что не выделено изначально.
Отредактировано MySh (21-08-2009 00:50:36)
Отсутствует
Добавь в конце
Спасибо
Вы ленивы, следовательно вы изобретательны (Граф Де Гиш)
Список настроек About:config на русском языке с пояснениями и рекомендациями
Отсутствует
MySh
Наоборот — то, что не выделено изначально.
Ну, пока только вот так:
var doc = gBrowser. contentDocument; var win = document. commandDispatcher. focusedWindow; var sel = win. getSelection (). QueryInterface (Components. interfaces. nsISelectionPrivate); var range = sel. getRangeAt (0); sel. startBatchChanges (); var docfrag = range. extractContents (); sel. removeAllRanges (); range = doc. createRange (); sel. addRange (range); range. selectNodeContents (doc. body); range. deleteContents (); sel. endBatchChanges (); doc. body. appendChild (docfrag);
только для одинарного выделения.
Время настанет, время придет...
И лис кОнкурiентов на части порвет !!!
Отсутствует
Инверсия множественного выделения:
function notNull (x) x != null; function compareRanges (r1, r2) { return r1. compareBoundaryPoints (Range. START_TO_START, r2); } var doc = gBrowser. contentDocument; var win = document. commandDispatcher. focusedWindow; var sel = win. getSelection (). QueryInterface (Components. interfaces. nsISelectionPrivate); var ranges = []; var i, j; for (i = 0; i < sel. rangeCount; i++) ranges. push (sel. getRangeAt (i). cloneRange ()); ranges. sort (compareRanges); var range1, range2; var css, cse, ces, cee; for (i = 0; i < ranges. length; i++) { range1 = ranges [i]; if (!range1) continue; if (range1. collapsed) { ranges [i] = null; continue; } for (j = i + 1; j < ranges. length; j++) { range2 = ranges [j]; if (!range2) continue; css = range1. compareBoundaryPoints (Range. START_TO_START, range2); cse = range1. compareBoundaryPoints (Range. START_TO_END, range2); ces = range1. compareBoundaryPoints (Range. END_TO_START, range2); cee = range1. compareBoundaryPoints (Range. END_TO_END, range2); if ((css <= 0) && (cee >= 0)) { ranges [j] = null; continue; } if ((css <= 0) && (cse >= 0) && (cee <= 0)) { range1. setEnd (range2. endContainer, range2. endOffset); ranges [j] = null; continue; } } if (range1. collapsed) { ranges [i] = null; continue; } } ranges = ranges. filter (notNull); sel. startBatchChanges (); sel. removeAllRanges (); var range = doc. createRange (); sel. addRange (range); range. setStartBefore (doc. body. firstChild); for (i = 0; i < ranges. length; i++) { range. setEnd (ranges [i]. startContainer, ranges [i]. startOffset); if (range. collapsed) sel. removeRange (range); range = doc. createRange (); sel. addRange (range); range. setStart (ranges [i]. endContainer, ranges [i]. endOffset); } range. setEndAfter (doc. body. lastChild); if (range. collapsed) sel. removeRange (range); if (sel. rangeCount == 0) sel. addRange (doc. createRange ()); sel. endBatchChanges (); win. blur (); win. focus (); //sel. deleteFromDocument ();
Время настанет, время придет...
И лис кОнкурiентов на части порвет !!!
Отсутствует
Anton
Спасибо, кнопка работает прекрасно. Скорость выскрапбучивания данных из интернетов выросла в разы.
Заодно у меня тут пока и пиктограммка нарисовалась, а то с этих звёздочек уже в глазах рябит:

Отсутствует
Кнопка для отмены закрытия вкладок (аналог расширения Undo Closed Tabs Button)
ЛКМ – отменить закрытие вкладки
СКМ, Ctrl+ЛКМ – очистить список закрытых вкладок
ПКМ – список закрытого
ПКМ по любому из пунктов меню – восстановить окно/вкладку без скрытия меню
Shift+ПКМ (а также ПКМ с любой другой клавишей-модификатором) – показать оригинальное меню кнопки
Скриншот:
Кнопка использует встроенную компоненту сохранения сессий, отмена закрытия окон работает в Firefox 3.5 и выше.
Используемые строки задаются в самом начале и их можно корректировать:
Иконки взяты из расширения Undo Closed Tabs Button. Часть кода, определяющая внешний вид, начинается с
Код (секция «инициализация»):
// http://infocatcher.ucoz.net/js/cb/undoCloseTabsList.js // Undo Close Tabs List button for Custom Buttons // version 0.2.0 - 2011-07-08 // (code for "initialization" section) // (c) Infocatcher 2009-2011 //= Settings begin this.settings = { menuTemplate: [ "closedWindows", "separator", "restoreClosedWindows", "clearClosedWindows", "separator", "closedTabs", "separator", "restoreClosedTabs", "clearClosedTabs", "separator", "clearAll" ], openMenuOnMouseover: false }; this._strings = { en: { // First entry used as default restoreAllTabs: "Restore all tabs", restoreAllTabsAccesskey: "t", clearTabsHistory: "Clear history of closed tabs", clearTabsHistoryAccesskey: "b", restoreAllWindows: "Restore all windows", restoreAllWindowsAccesskey: "w", clearWindowsHistory: "Clear history of closed windows", clearWindowsHistoryAccesskey: "d", clearAllHistory: "Clear all history", clearAllHistoryAccesskey: "C" }, ru: { restoreAllTabs: "Восстановить все вкладки", restoreAllTabsAccesskey: "л", clearTabsHistory: "Очистить историю закрытых вкладок", clearTabsHistoryAccesskey: "д", restoreAllWindows: "Восстановить все окна", restoreAllWindowsAccesskey: "о", clearWindowsHistory: "Очистить историю закрытых окон", clearWindowsHistoryAccesskey: "н", clearAllHistory: "Очистить всю историю", clearAllHistoryAccesskey: "ч" } }; //= Settings end this.onclick = function(e) { if(e.target != this) return; if(e.button == 1 || e.button == 0 && (e.ctrlKey || e.shiftKey || e.altKey || e.metaKey)) this.clearAllLists(); else if(e.button == 0) { if(this.closedTabCount) undoCloseTab(); else this.showMenu(e, false); // Allow use "command" section only from hotkey: e.preventDefault(); e.stopPropagation(); } }; this.defaultContextId = this.getAttribute("context") || "custombuttons-contextpopup"; this.oncontextmenu = function(e) { if(e.target != this) return; this.setAttribute( "context", e.ctrlKey || e.shiftKey || e.altKey || e.metaKey ? this.defaultContextId : this._mpId ); }; this.onmouseover = function() { this.updUI(); if(!this.settings.openMenuOnMouseover) return; var mp = this._mp; if("openPopup" in mp) mp.openPopup(this, "after_start"); else mp.showPopup(this, -1, -1, "popup", "bottomleft", "topleft"); }; var s = this._strings; for(var p in s) if(s.hasOwnProperty(p)) { this._defaultLocale = this._locale = p; break; } var currentLocale = Application.prefs.getValue("general.useragent.locale", "en"); if(s.hasOwnProperty(currentLocale)) this._locale = currentLocale; // e.g. "ru-RU" else if(/^([a-z]+)-/.test(currentLocale) && s.hasOwnProperty(RegExp.$1)) this._locale = RegExp.$1; // e.g. "ru" this._localeStrings = s[this._locale]; this._defaultStrings = s[this._defaultLocale]; delete this._strings; this._string = function(sid) { return this._localeStrings[sid] || this._defaultStrings[sid] || "(" + sid + ")"; }; this.XULNS = "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"; this.parseFromXML = function(xml) { var pp = XML.prettyPrinting; XML.prettyPrinting = false; var elt = new DOMParser().parseFromString(xml.toXMLString(), "application/xml").documentElement; XML.prettyPrinting = pp; return elt; }; this._mpId = this.id + "-context"; this._mp = this.appendChild(this.parseFromXML( <menupopup xmlns={this.XULNS} id={this._mpId} onpopupshowing="return this.parentNode.drawUndoList();" /> )); this._ss = (Components.classes["@mozilla.org/browser/sessionstore;1"] || Components.classes["@mozilla.org/suite/sessionstore;1"]) .getService(Components.interfaces.nsISessionStore); this.__defineGetter__("appInfo", function() { delete this.appInfo; return this.appInfo = Components.classes["@mozilla.org/xre/app-info;1"] .getService(Components.interfaces.nsIXULAppInfo); }); this.__defineGetter__("appVersion", function() { delete this.appVersion; return this.appVersion = parseFloat(this.appInfo.version); }); this.__defineGetter__("appName", function() { delete this.appName; return this.appName = this.appInfo.name; }); this.__defineGetter__("closedWindowCount", function() { if(!("getClosedWindowCount" in this._ss)) { delete this.closedWindowCount; return this.closedWindowCount = 0; } return this._ss.getClosedWindowCount(); }); this.__defineGetter__("closedTabCount", function() { return this._ss.getClosedTabCount(window); }); this.clearUndoTabsList = function(redrawList) { // Not works in SeaMonkey const pId = "browser.sessionstore.max_tabs_undo"; var val = Application.prefs.getValue(pId, 10); Application.prefs.setValue(pId, 0); Application.prefs.setValue(pId, val); this.updUIGlobal(); redrawList && this.drawUndoList(); }; this.clearUndoWindowsList = function(redrawList) { if(!this.closedWindowCount) return; this._ss.setWindowState(window, '{"windows":[{}],"_closedWindows":[]}', false); this.updUIGlobal(); redrawList && this.drawUndoList(); }; this.clearAllLists = function() { this.clearUndoTabsList(); this.clearUndoWindowsList(); }; this.showMenu = function(e, isContext, mp) { document.popupNode = this.ownerDocument.popupNode = this; if(!mp) mp = this._mp; if("openPopupAtScreen" in mp) mp.openPopupAtScreen(e.screenX, e.screenY, isContext); else mp.showPopup(this, e.screenX, e.screenY, isContext ? "context" : "popup", null, null); }; this.drawUndoList = function() { var mp = this._mp; while(mp.hasChildNodes()) mp.removeChild(mp.lastChild); var wc = this.closedWindowCount; var tc = this.closedTabCount; if(!wc && !tc) { mp.hidePopup(); return false; } this._undoWindowItems = wc && JSON.parse(this._ss.getClosedWindowData()); this._undoTabItems = tc && JSON.parse(this._ss.getClosedTabData(window)); this.settings.menuTemplate.forEach(function(sid, indx, arr) { switch(sid) { case "closedWindows": wc && this.addUndoWindowsList(mp); break; case "restoreClosedWindows": wc && mp.appendChild(this.parseFromXML( <menuitem xmlns={this.XULNS} label={this._string("restoreAllWindows")} accesskey={this._string("restoreAllWindowsAccesskey")} tooltiptext="" oncommand={"for (var i = 0; i < " + this._undoWindowItems.length + "; i++) undoCloseWindow();"} /> )); break; case "clearClosedWindows": wc && mp.appendChild(this.parseFromXML( <menuitem xmlns={this.XULNS} label={this._string("clearWindowsHistory")} accesskey={this._string("clearWindowsHistoryAccesskey")} tooltiptext="" oncommand="this.parentNode.parentNode.clearUndoWindowsList();" onclick="if(event.button == 1) this.parentNode.parentNode.clearUndoWindowsList(true);" /> )); break; case "closedTabs": tc && this.addUndoTabsList(mp); break; case "restoreClosedTabs": tc && mp.appendChild(this.parseFromXML( <menuitem xmlns={this.XULNS} label={this._string("restoreAllTabs")} accesskey={this._string("restoreAllTabsAccesskey")} tooltiptext="" oncommand={"for (var i = 0; i < " + this._undoTabItems.length + "; i++) undoCloseTab();"} /> )); break; case "clearClosedTabs": tc && mp.appendChild(this.parseFromXML( <menuitem xmlns={this.XULNS} label={this._string("clearTabsHistory")} accesskey={this._string("clearTabsHistoryAccesskey")} tooltiptext="" oncommand="this.parentNode.parentNode.clearUndoTabsList();" onclick="if(event.button == 1) this.parentNode.parentNode.clearUndoTabsList(true);" /> )); break; case "clearAll": (wc && tc || wc && arr.indexOf("clearClosedWindows") == -1 || tc && arr.indexOf("clearClosedTabs") == -1) && mp.appendChild(this.parseFromXML( <menuitem xmlns={this.XULNS} label={this._string("clearAllHistory")} accesskey={this._string("clearAllHistoryAccesskey")} tooltiptext="" oncommand="this.parentNode.parentNode.clearAllLists();" /> )); break; case "separator": if(mp.hasChildNodes() && mp.lastChild.localName != "menuseparator") mp.appendChild(document.createElement("menuseparator")); break; default: Components.utils.reportError("[Custom Button :: Undo Close Tabs List] Invalid template entry: \"" + sid + "\""); } }, this); while(mp.lastChild && mp.lastChild.localName == "menuseparator") mp.removeChild(mp.lastChild); this._undoWindowItems = this._undoTabItems = null; return mp.hasChildNodes(); }; this.addUndoWindowsList = function(undoPopup) { // Code from chrome://browser/content/browser.js // Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.3a1pre) Gecko/20090824 Minefield/3.7a1pre // with some improvements // populate menu let undoItems = this._undoWindowItems; for (let i = 0; i < undoItems.length; i++) { let undoItem = undoItems[i]; let menuLabel = "(%count) %title" .replace("%title", undoItem.title) .replace("%count", undoItem.tabs.length); let m = document.createElement("menuitem"); m.setAttribute("label", menuLabel); let selectedTab = undoItem.tabs[undoItem.selected - 1]; if (selectedTab.attributes.image) m.setAttribute("image", this.cachedIcon(selectedTab.attributes.image)); m.setAttribute("class", "menuitem-iconic bookmark-item"); m.setAttribute("oncommand", "undoCloseWindow(" + i + ");"); m.setAttribute("onclick", "if(event.button == 1) { undoCloseWindow(" + i + "); this.parentNode.parentNode.drawUndoList(); }"); if(selectedTab.entries && selectedTab.entries.length) // Can be [] for about:blank m.setAttribute("tooltiptext", selectedTab.entries[selectedTab.index - 1].url); if (i == 0) m.setAttribute("key", "key_undoCloseWindow"); undoPopup.appendChild(m); } }; this.addUndoTabsList = function(undoPopup) { // Code from chrome://browser/content/browser.js // Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.3a1pre) Gecko/20090824 Minefield/3.7a1pre // with some improvements // populate menu //var undoItems = eval("(" + this._ss.getClosedTabData(window) + ")"); let undoItems = this._undoTabItems; for (var i = 0; i < undoItems.length; i++) { let m = document.createElement("menuitem"); let undoItem = undoItems[i]; m.setAttribute("label", undoItem.title); if (undoItem.image) m.setAttribute("image", this.cachedIcon(undoItem.image)); m.setAttribute("class", "menuitem-iconic bookmark-item"); m.setAttribute("value", i); m.setAttribute("oncommand", "undoCloseTab(" + i + ");"); m.setAttribute("onclick", "if(event.button == 1) { undoCloseTab(" + i + "); this.parentNode.parentNode.drawUndoList(); }"); m.setAttribute("tooltiptext", undoItem.state.entries[undoItem.state.index - 1].url); if (i == 0) m.setAttribute("key", "key_undoCloseTab"); undoPopup.appendChild(m); } }; this.cachedIcon = function(src) { if( !/^https?:/.test(src) // IDN, see https://bugzilla.mozilla.org/show_bug.cgi?id=311045 || /^https?:\/\/[^.:\/]+\.[^a-z0-9-]+(?:\/|$)/.test(src) || this.appName == "SeaMonkey" && this.appVersion <= 2 || this.appName == "Firefox" && this.appVersion <= 3.5 ) return src; return "moz-anno:favicon:" + src; // https://bugzilla.mozilla.org/show_bug.cgi?id=467828 }; this.updUI = function() { if(this.closedWindowCount || this.closedTabCount) this.removeAttribute("disabled"); else this.setAttribute("disabled", "true"); }; this.updUIGlobal = function() { var ws = Components.classes["@mozilla.org/appshell/window-mediator;1"] .getService(Components.interfaces.nsIWindowMediator) .getEnumerator("navigator:browser"); const id = this.id; while(ws.hasMoreElements()) { let btn = ws.getNext().document.getElementById(id); btn && btn.updUI(); } }; this.evtHandler = { button: this, destroy: function() { window.removeEventListener("TabClose", this, false); window.removeEventListener("SSTabRestoring", this, false); window.removeEventListener("unload", this, false); this.button._mp.removeEventListener("DOMMenuItemActive", this, false); this.button._mp.removeEventListener("DOMMenuItemInactive", this, false); }, handleEvent: function(e) { switch(e.type) { case "TabClose": case "SSTabRestoring": this.button.updUI(); break; case "DOMMenuItemActive": case "DOMMenuItemInactive": if(!("XULBrowserWindow" in window)) break; XULBrowserWindow.setOverLink( e.type == "DOMMenuItemActive" && e.target.getAttribute("tooltiptext") || "", null ); break; case "unload": this.button.updUIGlobal(); this.destroy(); } } }; this.onDestroy = function() { this.evtHandler.destroy(); }; var eh = this.evtHandler; window.addEventListener("TabClose", eh, false); window.addEventListener("SSTabRestoring", eh, false); window.addEventListener("unload", eh, false); this._mp.addEventListener("DOMMenuItemActive", eh, false); this._mp.addEventListener("DOMMenuItemInactive", eh, false); this.updUIGlobal(); //=================== // Styles // Used icons from Undo Closed Tabs Button extension this.image = ""; // Styles are not applies, if button has "image" attribute var sId = "__custombuttonsStyle__" + this.id; // Unique style "id" var cssStr = <><![CDATA[ %button% { list-style-image: url("") !important; } %button%:hover { list-style-image: url("") !important; } %button%[disabled="true"] { list-style-image: url("") !important; } toolbar[iconsize="small"] %button% { list-style-image: url("") !important; } toolbar[iconsize="small"] %button%:hover { list-style-image: url("") !important; } toolbar[iconsize="small"] %button%[disabled="true"] { list-style-image: url("") !important; } ]]></> .toString() .replace(/%button%/g, "#" + this.id); function sheet(cssStr, removeFlag) { var sss = Components.classes["@mozilla.org/content/style-sheet-service;1"] .getService(Components.interfaces.nsIStyleSheetService); var ios = Components.classes["@mozilla.org/network/io-service;1"] .getService(Components.interfaces.nsIIOService); var data = "data:text/css," + encodeURIComponent(cssStr); var uri = ios.newURI(data, null, null); if(sss.sheetRegistered(uri, sss.USER_SHEET)) sss.unregisterSheet(uri, sss.USER_SHEET); if(removeFlag) return; sss.loadAndRegisterSheet(uri, sss.USER_SHEET); window[sId] = cssStr; } if(!(sId in window)) sheet(cssStr); else if(window[sId] != cssStr) { sheet(window[sId], true); sheet(cssStr); }
Добавлено 21-11-2009 19:53:33
Вместо showPopup используется метод openPopupAtScreen (если доступен).
Добавлено 04-06-2010 21:48:17
Добавлено восстановление закрытых окон и вкладок кликом средней кнопки мыши без скрытия списка.
Добавлена опция для разворачивания меню при наведении мыши («this.openOnMouseover = false;» в начале кода).
Добавлено 04-06-2010 23:53:51
Улучшено предотвращение появления оригинального контекстного меню кнопки.
Добавлено 08-07-2011 09:58:40
Изменен способ отображения контекстного меню (теперь меню в Linux должно показываться сразу после нажатия правой кнопки мыши).
Добавлено отображение ссылки в строке состояния при выделении пунктов меню с помощью клавиатуры.
Исправлено кэширование иконок (например, moz-anno:favicon:http://нигма.рф/themes/nigma/img/favicon.ico не работает).
Отредактировано Infocatcher (08-07-2011 09:59:21)
Прошлое – это локомотив, который тянет за собой будущее. Бывает, что это прошлое вдобавок чужое. Ты едешь спиной вперед и видишь только то, что уже исчезло. А чтобы сойти с поезда, нужен билет. Ты держишь его в руках. Но кому ты его предъявишь?
Виктор Пелевин. Желтая стрела
Отсутствует
Единственное - попробую ка я сменить порядок: сначала вкладки, затем окна
Заменить
if(wc) { this.addUndoWindowsList(mp); tc && mp.appendChild(document.createElement("menuseparator")); } if(tc) this.addUndoTabsList(mp);
на
if(tc) { this.addUndoTabsList(mp); wc && mp.appendChild(document.createElement("menuseparator")); } if(wc) this.addUndoWindowsList(mp);
Прошлое – это локомотив, который тянет за собой будущее. Бывает, что это прошлое вдобавок чужое. Ты едешь спиной вперед и видишь только то, что уже исчезло. А чтобы сойти с поезда, нужен билет. Ты держишь его в руках. Но кому ты его предъявишь?
Виктор Пелевин. Желтая стрела
Отсутствует
Infocatcher
Спасибо, очень полезная кнопка! А можно зделать кнопочку История (Журнал), чтобы по ЛКМ выпадал список журнала (ну скажем последние 30 посещенных ссылок), ПКМ - открытие в боковой панели, а СКМ - открытие Журнала в отдельном окне?
Кстати, извиняюсь что еще раз возвращаюсь к вопросу по поводу кнопки "Закладки", знаю что Anton много раз говорил, что к этому вопросу больше не подойдет, но все же. Есть расширение Personal Menu, оно при установке добавляет кнопку Закладок. Хочу спросить, возможно ли эту кнопку выдернуть в CB или там это сделано по другому совсем (может это не кнопка а кусок из меню переброшен )?
Отсутствует
Помогите, дайте пожалуйста CSS код для изменения фона полей ввода на белый и цвета букв на чёрный (Тема просто стоит такая ).
Вы ленивы, следовательно вы изобретательны (Граф Де Гиш)
Список настроек About:config на русском языке с пояснениями и рекомендациями
Отсутствует
Помогите, дайте пожалуйста CSS код для изменения фона полей ввода на белый и цвета букв на чёрный
Или userContent.css
input[type="text"], textarea { color: black !important; background-color: white !important; }
, или нужны подробности.
Добавлено 26-08-2009 00:39:43
P.S. Подправил удаление обработчиков при закрытии окна.
Прошлое – это локомотив, который тянет за собой будущее. Бывает, что это прошлое вдобавок чужое. Ты едешь спиной вперед и видишь только то, что уже исчезло. А чтобы сойти с поезда, нужен билет. Ты держишь его в руках. Но кому ты его предъявишь?
Виктор Пелевин. Желтая стрела
Отсутствует
Или userContent.css
Не работает
Вы ленивы, следовательно вы изобретательны (Граф Де Гиш)
Список настроек About:config на русском языке с пояснениями и рекомендациями
Отсутствует
Не работает
А так:
input[type="text"], input:not([type]), textarea { color: black !important; background-color: white !important; -moz-appearance: none !important; }
?
Прошлое – это локомотив, который тянет за собой будущее. Бывает, что это прошлое вдобавок чужое. Ты едешь спиной вперед и видишь только то, что уже исчезло. А чтобы сойти с поезда, нужен билет. Ты держишь его в руках. Но кому ты его предъявишь?
Виктор Пелевин. Желтая стрела
Отсутствует
Не пашет
Может то что на Linux, и тема стили браузера перебивает?
Вы ленивы, следовательно вы изобретательны (Граф Де Гиш)
Список настроек About:config на русском языке с пояснениями и рекомендациями
Отсутствует
(На всякий случай.)
Вниманию пользователей:
Версия 0.0.4.4, устраняющая несовместимость с Adblock Plus 1.1.1 выпущена 16.08.09
Загрузить можно со страницы http://custombuttons.mozdev.org/installation.html
На AMO выложена тоже 16.08.09, но пока ещё ожидает рецензии.
Время настанет, время придет...
И лис кОнкурiентов на части порвет !!!
Отсутствует
гм... у гугла есть прекрасная кнопка, работающая из закладок вида:
javascript:var%20b=document.body;var%20GR________bookmarklet_domain='http://www.google.com';if(b&&!document.xmlVersion){void(z=document.createElement('script'));void(z.src='http://www.google.com/reader/ui/link-bookmarklet.js');void(b.appendChild(z));}else{}
А можно как нибудть это в кнопку интегрировать? банальным
непроходит...
Отсутствует