>Форум Mozilla Россия http://forum.mozilla-russia.org/index.php >Сustom Buttons http://forum.mozilla-russia.org/viewforum.php?id=34 >[CB] Расширение возможностей дополнения 'Phrase Highlighter' http://forum.mozilla-russia.org/viewtopic.php?id=68801 |
Inko7 > 20-11-2015 22:41:56 |
Расширение возможностей дополнения 'Phrase Highlighter' - Extender for 'Phrase Highlighter' (Firefox) Автор: Я ЛКМ по кнопке дополнения - если на странице есть выделенный текст (слово или фраза), добавляет его в ячейку и активирует автовыделение. Всего в дополнении 5 ячеек, соответственно, при добавлении шестого объекта, появится предупреждение. Если выделенного текста нет, то - действие по умолчанию. Shift + ЛКМ по кнопке дополнения - активация варианта с заранее заданными словами. При этом, состояние активности помечается подсветкой кнопки дополнения. По аналогии, можно добавить и другие варианты предустановок, повесив их на иные сочетания клавиш. Выделить код Код:// ДОПОЛНИТЕЛЬНЫЕ ВОЗМОЖНОСТИ ДЛЯ ДОПОЛНЕНИЯ 'PHRASE HIGHLIGHTER' var buttonext = document.getElementById("phrase-highlighter-toolbar-button"); //var prefs = Application.prefs; var alertsService = Components.classes["@mozilla.org/alerts-service;1"].getService(Components.interfaces.nsIAlertsService); var red = ""; var orange = ""; var yellow = ""; var green = ""; var blue = ""; addEventListener("click", clickphr, false, buttonext); buttonext.onmouseover = function() { getcolor(); if ( !cbu.getPrefs("extensions.phrasehighlighter.enable") ) { buttonext.tooltipText = "Phrase Highlighter\nСостояние: ВЫКЛЮЧЕН"; return }; //button.tooltipText = "Phrase Highlighter\n" + sost; buttonext.tooltipText = "Phrase Highlighter\nСостояние: ВКЛЮЧЕН\nRed: "+ red + "\nOrange: " + orange + "\nYellow: " + yellow + "\nGreen: " + green + "\nBlue: " + blue; }; var css = "/*AGENT_SHEET*/\n" css = "#phrase-highlighter-toolbar-button .toolbarbutton-icon { background-color: pink !important; }\n"; css = css + "#phrase-highlighter-toolbar-button > .toolbarbutton-menubutton-dropmarker > .dropmarker-icon { background-color: pink !important; }\n"; var uri = makeURI("data:text/css," + encodeURIComponent(css)); var sss = Cc["@mozilla.org/content/style-sheet-service;1"]. getService(Ci.nsIStyleSheetService); addDestructor(function() { sss.unregisterSheet( uri, sss.AGENT_SHEET ) }); // Настройка функций кликов мыши для кнопки function clickphr(e) { // действие при клике ЛКМ if ( e.button == 0 && !e.ctrlKey && !e.shiftKey && !e.altKey && !e.metaKey ) { var text = plzSelect(); if ( text == false ) return; getcolor(); if ( red == "" ) cbu.setPrefs("extensions.phrasehighlighter.red-phrases", convertFromUnicode("UTF-8", text)); else if ( orange == "" ) cbu.setPrefs("extensions.phrasehighlighter.orange-phrases", convertFromUnicode("UTF-8", text)); else if ( yellow == "" ) cbu.setPrefs("extensions.phrasehighlighter.yellow-phrases", convertFromUnicode("UTF-8", text)); else if ( green == "" ) cbu.setPrefs("extensions.phrasehighlighter.green-phrases", convertFromUnicode("UTF-8", text)); else if ( blue == "" ) cbu.setPrefs("extensions.phrasehighlighter.blue-phrases", convertFromUnicode("UTF-8", text)); else alertsService.showAlertNotification( "", " Phrase Highlighter", "Все ячейки заполнены!", ""); setTimeout(function() { cbu.setPrefs("extensions.phrasehighlighter.enable", true); phraseHighlighter.run(); }, 300); }; // действие при клике СКМ if (e.button == 1 && !e.ctrlKey && !e.shiftKey && !e.altKey && !e.metaKey ) { cbu.setPrefs("CB.phrasehighlighter", false); cleanphrase(); toggleStyle(); // снять разноцветную подсветку на странице for ( var br of gBrowser.browsers ) { [...br.contentDocument.querySelectorAll('SPAN[style^="color:"]')] .forEach((m)=>{ if (m.style.backgroundColor) m.style = "" }); } }; // действие при клике SHIFT + ЛКМ if ( e.button == 0 && !e.ctrlKey && e.shiftKey && !e.altKey && !e.metaKey ) { cbu.setPrefs("CB.phrasehighlighter", !cbu.getPrefs("CB.phrasehighlighter") ); if ( cbu.getPrefs("CB.phrasehighlighter") ) { setphrase(); toggleStyle(); } else { cleanphrase(); toggleStyle(); } }; }; // Проверить наличие строк в about:config и создать если не существует if ( !cbu.isPref("CB.phrasehighlighter") ) { cbu.setPrefs("CB.phrasehighlighter", false); }; cbu.setPrefs("CB.phrasehighlighter", false); // Установить стиль для кнопки дополнения при включенном режиме предустановок function toggleStyle() { if ( cbu.getPrefs("CB.phrasehighlighter") ) { setTimeout(function() { sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET) }, 300); } if ( !cbu.getPrefs("CB.phrasehighlighter") ) { setTimeout(function() { sss.unregisterSheet( uri, sss.AGENT_SHEET ) }, 300); } }; // Очистка ячеек и отключение Autoload function cleanphrase() { cbu.setPrefs("extensions.phrasehighlighter.enable", false); cbu.setPrefs("extensions.phrasehighlighter.red-phrases", ""); cbu.setPrefs("extensions.phrasehighlighter.orange-phrases", ""); cbu.setPrefs("extensions.phrasehighlighter.yellow-phrases", ""); cbu.setPrefs("extensions.phrasehighlighter.green-phrases", ""); cbu.setPrefs("extensions.phrasehighlighter.blue-phrases", ""); }; // Предустановка своих значений и включение Autoload function setphrase() { cbu.setPrefs("extensions.phrasehighlighter.red-phrases", convertFromUnicode("UTF-8", "custom1")); cbu.setPrefs("extensions.phrasehighlighter.orange-phrases", convertFromUnicode("UTF-8", "custom2")); cbu.setPrefs("extensions.phrasehighlighter.yellow-phrases", convertFromUnicode("UTF-8", "custom3")); cbu.setPrefs("extensions.phrasehighlighter.green-phrases", convertFromUnicode("UTF-8", "custom4")); cbu.setPrefs("extensions.phrasehighlighter.blue-phrases", convertFromUnicode("UTF-8", "custom5")); setTimeout(function() { cbu.setPrefs("extensions.phrasehighlighter.enable", true); phraseHighlighter.run(); }, 300); }; // Функция отдаст выделенный текст из страницы или текстового поля, если текст не выделен отдаст 'false' function plzSelect() { // выделенный текст из страницы var selection = document.commandDispatcher.focusedWindow.getSelection().toString(); // выделенный текст из текстового поля if ( selection == '' ) { var theBox = document.commandDispatcher.focusedElement; if ( theBox && (theBox.type == "text" || theBox.type == "textarea") ) { var startPos = theBox.selectionStart; var endPos = theBox.selectionEnd; var selection = theBox.value.substring(startPos, endPos); } }; // убираем пробелы с обоих концов текста if ( selection !== '' ) var selection = selection.toString().replace(/^\s+|\s+$/g,""); return ( selection == '')? false: selection; }; function getcolor() { red = gPrefService.getComplexValue("extensions.phrasehighlighter.red-phrases", Ci.nsISupportsString).data; orange = gPrefService.getComplexValue("extensions.phrasehighlighter.orange-phrases", Ci.nsISupportsString).data; yellow = gPrefService.getComplexValue("extensions.phrasehighlighter.yellow-phrases", Ci.nsISupportsString).data; green = gPrefService.getComplexValue("extensions.phrasehighlighter.green-phrases", Ci.nsISupportsString).data; blue = gPrefService.getComplexValue("extensions.phrasehighlighter.blue-phrases", Ci.nsISupportsString).data; }; toggleStyle(); // Обработчик следит за загрузкой и переключением вкладки и запускают phraseHighlighter var listener = { onStateChange: function(wpr, req) { if ( gBrowser.currentURI.spec == 'chrome://global/content/console.xul') return; if ( Ci.nsIWebProgressListener.STATE_STOP ) { setTimeout(function() { if ( cbu.getPrefs("CB.phrasehighlighter")) phraseHighlighter.run(); }, 500); }; }, onLocationChange: function(wpr, req) { if ( wpr.currentURI.spec != "about:blank" && !req && wpr.document.readyState == "complete") { setTimeout(function() { if ( cbu.getPrefs("CB.phrasehighlighter")) phraseHighlighter.run(); }, 500); }; } }; gBrowser.addProgressListener( listener ); addDestructor(function() gBrowser.removeProgressListener( listener ) ); Создавал для себя / под свои нужды. |
bunda1 > 22-11-2015 13:49:45 |
Inko7 пишет
Так вроде снимает подсветку: Выделить код Код:for ( var br of gBrowser.browsers ) { [...br.contentDocument.querySelectorAll('SPAN[style^="color:white;"]')] .forEach((m)=> m.style = "" ); } но при команде назад или перёд на прошлой или следующей странице выделение остаётся. Кстати: Выделить код Код:buttonext.addEventListener("click", clickphr, false); addDestructor(function() { buttonext.removeEventListener("click", clickphr, false) }); можно просто заменить на: |
Inko7 > 22-11-2015 18:36:47 |
bunda1 пишет
Уже прогресс! Но странно как-то снимает подсветку - только у красного цвета и синего. Зеленый, оранжевый, желтый - остаются... За оптимизацию кода спасибо, сейчас поправлю |
bunda1 > 22-11-2015 19:12:49 |
Тут проблемка, дополнение Phrase Highlighter ставит цветной SPAN над текстом который выделяет, а мой код находит эти SPAN по Css селектору color:white;, но оказывается что для зеленного, оранжевого, жёлтого цвета этот Css селектор color:black;. Можно найти SPAN по селектору color: но тогда возможно мой код отключит какие то другие SPAN на страницах: Выделить код Код:for ( var br of gBrowser.browsers ) { [...br.contentDocument.querySelectorAll('SPAN[style^="color:"]')] .forEach((m)=> m.style = "" ); } |
Inko7 > 22-11-2015 19:22:13 |
bunda1 bunda1 пишет
может тогда сделать двойной код - отдельно цикл для color:white и отдельно для color:black ? |
bunda1 > 22-11-2015 19:28:26 |
Inko7 пишет
Можно и так, но всё равно что то заденет, я сейчас попробую придумать что то. |
bunda1 > 22-11-2015 20:00:18 |
Может так: Выделить код Код:for ( var br of gBrowser.browsers ) { [...br.contentDocument.querySelectorAll('SPAN[style^="color:"]')] .forEach((m)=>{ if (m.style.backgroundColor) m.style = "" }); } |
Inko7 > 22-11-2015 20:14:43 |
добавил какую-то контрольную проверку? |
bunda1 > 22-11-2015 20:39:24 |
Inko7 пишет
Добавил if (m.style.backgroundColor), вроде у других SPAN не наблюдается backgroundColor |
Inko7 > 22-11-2015 21:25:08 |
bunda1 |
user44 > 05-12-2016 16:26:45 |
уважаемый автор! а может это сам аддон Custom Buttons плохо совместим с последними версиями FF? |
bunda1 > 05-12-2016 21:18:36 |
user44 пишет
|
user44 > 06-12-2016 15:25:34 |
bunda1 пишет
спасибо, но не помогло |
bunda1 > 06-12-2016 19:58:31 |
user44 пишет
А если так: Многоцветное автовыделение |
Inko7 > 06-12-2016 20:37:57 |
user44 |
bunda1 > 06-12-2016 21:08:52 |
Inko7 пишет
Не может быть! В коде кнопки есть Application который не работает на FF50. |
Inko7 > 06-12-2016 21:28:22 |
bunda1 скрытый текст использовал выделение + ЛКМ по кнопке СКМ также нормально очищает 06-12-2016 21:36:59 скрытый текст Выделить код Код:// ДОПОЛНИТЕЛЬНЫЕ ВОЗМОЖНОСТИ ДЛЯ ДОПОЛНЕНИЯ 'PHRASE HIGHLIGHTER' var buttonext = document.getElementById("phrase-highlighter-toolbar-button"); //var prefs = Application.prefs; var alertsService = Components.classes["@mozilla.org/alerts-service;1"].getService(Components.interfaces.nsIAlertsService); var red = ""; var orange = ""; var yellow = ""; var green = ""; var blue = ""; addEventListener("click", clickphr, false, buttonext); buttonext.onmouseover = function() { getcolor(); if ( !cbu.getPrefs("extensions.phrasehighlighter.enable") ) { buttonext.tooltipText = "Phrase Highlighter\nСостояние: ВЫКЛЮЧЕН"; return }; //button.tooltipText = "Phrase Highlighter\n" + sost; buttonext.tooltipText = "Phrase Highlighter\nСостояние: ВКЛЮЧЕН\nRed: "+ red + "\nOrange: " + orange + "\nYellow: " + yellow + "\nGreen: " + green + "\nBlue: " + blue; }; var css = "/*AGENT_SHEET*/\n" css = "#phrase-highlighter-toolbar-button .toolbarbutton-icon { background-color: pink !important; }\n"; css = css + "#phrase-highlighter-toolbar-button > .toolbarbutton-menubutton-dropmarker > .dropmarker-icon { background-color: pink !important; }\n"; var uri = makeURI("data:text/css," + encodeURIComponent(css)); var sss = Cc["@mozilla.org/content/style-sheet-service;1"]. getService(Ci.nsIStyleSheetService); addDestructor(function() { sss.unregisterSheet( uri, sss.AGENT_SHEET ) }); // Настройка функций кликов мыши для кнопки function clickphr(e) { // действие при клике ЛКМ if ( e.button == 0 && !e.ctrlKey && !e.shiftKey && !e.altKey && !e.metaKey ) { var text = plzSelect(); if ( text == false ) return; getcolor(); if ( red == "" ) cbu.setPrefs("extensions.phrasehighlighter.red-phrases", convertFromUnicode("UTF-8", text)); else if ( orange == "" ) cbu.setPrefs("extensions.phrasehighlighter.orange-phrases", convertFromUnicode("UTF-8", text)); else if ( yellow == "" ) cbu.setPrefs("extensions.phrasehighlighter.yellow-phrases", convertFromUnicode("UTF-8", text)); else if ( green == "" ) cbu.setPrefs("extensions.phrasehighlighter.green-phrases", convertFromUnicode("UTF-8", text)); else if ( blue == "" ) cbu.setPrefs("extensions.phrasehighlighter.blue-phrases", convertFromUnicode("UTF-8", text)); else alertsService.showAlertNotification( "", " Phrase Highlighter", "Все ячейки заполнены!", ""); setTimeout(function() { cbu.setPrefs("extensions.phrasehighlighter.enable", true); phraseHighlighter.run(); }, 300); }; // действие при клике СКМ if (e.button == 1 && !e.ctrlKey && !e.shiftKey && !e.altKey && !e.metaKey ) { cbu.setPrefs("CB.phrasehighlighter", false); cleanphrase(); toggleStyle(); // снять разноцветную подсветку на странице for ( var br of gBrowser.browsers ) { [...br.contentDocument.querySelectorAll('SPAN[style^="color:"]')] .forEach((m)=>{ if (m.style.backgroundColor) m.style = "" }); } }; // действие при клике SHIFT + ЛКМ if ( e.button == 0 && !e.ctrlKey && e.shiftKey && !e.altKey && !e.metaKey ) { cbu.setPrefs("CB.phrasehighlighter", !cbu.getPrefs("CB.phrasehighlighter") ); if ( cbu.getPrefs("CB.phrasehighlighter") ) { setphrase(); toggleStyle(); } else { cleanphrase(); toggleStyle(); } }; }; // Проверить наличие строк в about:config и создать если не существует if ( !cbu.isPref("CB.phrasehighlighter") ) { cbu.setPrefs("CB.phrasehighlighter", false); }; cbu.setPrefs("CB.phrasehighlighter", false); // Установить стиль для кнопки дополнения при включенном режиме предустановок function toggleStyle() { if ( cbu.getPrefs("CB.phrasehighlighter") ) { setTimeout(function() { sss.loadAndRegisterSheet(uri, sss.AGENT_SHEET) }, 300); } if ( !cbu.getPrefs("CB.phrasehighlighter") ) { setTimeout(function() { sss.unregisterSheet( uri, sss.AGENT_SHEET ) }, 300); } }; // Очистка ячеек и отключение Autoload function cleanphrase() { cbu.setPrefs("extensions.phrasehighlighter.enable", false); cbu.setPrefs("extensions.phrasehighlighter.red-phrases", ""); cbu.setPrefs("extensions.phrasehighlighter.orange-phrases", ""); cbu.setPrefs("extensions.phrasehighlighter.yellow-phrases", ""); cbu.setPrefs("extensions.phrasehighlighter.green-phrases", ""); cbu.setPrefs("extensions.phrasehighlighter.blue-phrases", ""); }; // Предустановка своих значений и включение Autoload function setphrase() { cbu.setPrefs("extensions.phrasehighlighter.red-phrases", convertFromUnicode("UTF-8", "custom1")); cbu.setPrefs("extensions.phrasehighlighter.orange-phrases", convertFromUnicode("UTF-8", "custom2")); cbu.setPrefs("extensions.phrasehighlighter.yellow-phrases", convertFromUnicode("UTF-8", "custom3")); cbu.setPrefs("extensions.phrasehighlighter.green-phrases", convertFromUnicode("UTF-8", "custom4")); cbu.setPrefs("extensions.phrasehighlighter.blue-phrases", convertFromUnicode("UTF-8", "custom5")); setTimeout(function() { cbu.setPrefs("extensions.phrasehighlighter.enable", true); phraseHighlighter.run(); }, 300); }; // Функция отдаст выделенный текст из страницы или текстового поля, если текст не выделен отдаст 'false' function plzSelect() { // выделенный текст из страницы var selection = document.commandDispatcher.focusedWindow.getSelection().toString(); // выделенный текст из текстового поля if ( selection == '' ) { var theBox = document.commandDispatcher.focusedElement; if ( theBox && (theBox.type == "text" || theBox.type == "textarea") ) { var startPos = theBox.selectionStart; var endPos = theBox.selectionEnd; var selection = theBox.value.substring(startPos, endPos); } }; // убираем пробелы с обоих концов текста if ( selection !== '' ) var selection = selection.toString().replace(/^\s+|\s+$/g,""); return ( selection == '')? false: selection; }; function getcolor() { red = gPrefService.getComplexValue("extensions.phrasehighlighter.red-phrases", Ci.nsISupportsString).data; orange = gPrefService.getComplexValue("extensions.phrasehighlighter.orange-phrases", Ci.nsISupportsString).data; yellow = gPrefService.getComplexValue("extensions.phrasehighlighter.yellow-phrases", Ci.nsISupportsString).data; green = gPrefService.getComplexValue("extensions.phrasehighlighter.green-phrases", Ci.nsISupportsString).data; blue = gPrefService.getComplexValue("extensions.phrasehighlighter.blue-phrases", Ci.nsISupportsString).data; }; toggleStyle(); // Обработчик следит за загрузкой и переключением вкладки и запускают phraseHighlighter var listener = { onStateChange: function(wpr, req) { if ( gBrowser.currentURI.spec == 'chrome://global/content/console.xul') return; if ( Ci.nsIWebProgressListener.STATE_STOP ) { setTimeout(function() { if ( cbu.getPrefs("CB.phrasehighlighter")) phraseHighlighter.run(); }, 500); }; }, onLocationChange: function(wpr, req) { if ( wpr.currentURI.spec != "about:blank" && !req && wpr.document.readyState == "complete") { setTimeout(function() { if ( cbu.getPrefs("CB.phrasehighlighter")) phraseHighlighter.run(); }, 500); }; } }; gBrowser.addProgressListener( listener ); addDestructor(function() gBrowser.removeProgressListener( listener ) ); |
bunda1 > 06-12-2016 22:20:42 |
Inko7 пишет
Ну тогда понятно. Не забудь исправить 20-11-2015 22:41:56 |
Inko7 > 06-12-2016 22:43:08 |
Исправлен код кнопки в первом сообщении темы с учетом последних изменений в ff |
user44 > 07-12-2016 00:23:51 |
Inko7 bunda1 |