Страницы: 1
Расширение возможностей дополнения 'Phrase Highlighter' - Extender for 'Phrase Highlighter' (Firefox)
Автор: Я
Описание: Небольшое расширение возможностей дополнения Phrase Highlighter. Хороший аналог/заменитель кнопки Автовыделение ++
Использование: создать новую CB кнопку или положить код в инициализацию другой кнопки
ЛКМ по кнопке дополнения - если на странице есть выделенный текст (слово или фраза), добавляет его в ячейку и активирует автовыделение. Всего в дополнении 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 ) );
Создавал для себя / под свои нужды.
Т.к. я не специалист, то наверняка можно было что-то сделать проще и оптимальней
Отредактировано Inko7 (06-12-2016 22:39:46)
Отсутствует
Остался вопрос, который хотелось бы разрешить: после нажатия СКМ, очищаются ячейки, отключается дальнейшее автовыделение, но уже помеченные слова остаются на странице. Как снять эту разноцветную подсветку без обновления страницы???
Так вроде снимает подсветку:
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) });
можно просто заменить на:
Отредактировано bunda1 (22-11-2015 14:53:27)
Отсутствует
Так вроде снимает подсветку:
Уже прогресс! Но странно как-то снимает подсветку - только у красного цвета и синего. Зеленый, оранжевый, желтый - остаются...
За оптимизацию кода спасибо, сейчас поправлю
Отсутствует
Тут проблемка, дополнение 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 = "" ); }
Отсутствует
bunda1
спасибо, так срабатывает полностью
мой код отключит какие то другие SPAN на страницах
может тогда сделать двойной код - отдельно цикл для color:white и отдельно для color:black ?
так вероятность отключения лишнего ниже?
Отсутствует
может тогда сделать двойной код - отдельно цикл для color:white и отдельно для color:black ?
так вероятность отключения лишнего ниже?
Можно и так, но всё равно что то заденет, я сейчас попробую придумать что то.
Отсутствует
Может так:
for ( var br of gBrowser.browsers ) { [...br.contentDocument.querySelectorAll('SPAN[style^="color:"]')] .forEach((m)=>{ if (m.style.backgroundColor) m.style = "" }); }
Отсутствует
добавил какую-то контрольную проверку?
Добавил if (m.style.backgroundColor), вроде у других SPAN не наблюдается backgroundColor
Отсутствует
уважаемый автор!
не знаю, как у других камрадов, но у меня эта кнопка перестала работать, начиная с FF версии 47 ((((((
пожалуйста, посмотрите, может можно подправить
а может это сам аддон Custom Buttons плохо совместим с последними версиями FF?
Отсутствует
а может это сам аддон Custom Buttons плохо совместим с последними версиями FF?
Отсутствует
спасибо, но не помогло
А если так: Многоцветное автовыделение
Отсутствует
user44
сейчас проверил у себя, вроде все работает
Не может быть! В коде кнопки есть Application который не работает на FF50.
Отсутствует
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 ) );
Отредактировано Inko7 (06-12-2016 22:38:22)
Отсутствует
упс, у меня чуть подправленный вариант:
Ну тогда понятно. Не забудь исправить 20-11-2015 22:41:56
Отсутствует
Исправлен код кнопки в первом сообщении темы с учетом последних изменений в ff
Отсутствует
Inko7
теперь заработало
большое спасибо!
bunda1
Многоцветное автовыделение - весьма приятная кнопка, тоже буду юзать
большое спасибо!
жалко только, что можно задавать только фон, а не фон+цвет текста
и кнопки, конечно, непривычные
Отсутствует
Страницы: 1