bunda1
У кнопки "Индикация текущей раскладки фоном поля ввода" - как у старого варианта, так и у недавно опубликованного исправленного - имеется проблема со строкой поиска по странице (Ctrl-F): в оригинале, когда после очередной набранной буквы текст перестаёт находиться на странице, в этой строке цвет меняется на "белым по красному". Из-за действия кнопки получается "белым по почти белому".
Отсутствует
bunda1
у кнопки Переключить JavaScript для сайтов отвалилась перезагрузка страницы.
Поправь, пожалуйста
Отсутствует
У меня ещё просьба, видимо с переустановкой что-то напутал. Раньше у меня стояла кнопка которая делала код установки кликабельным и сразу с иконкой. Сейчас приходится самому копировать. Не могу найти что это делало, а без этого отвык. Поделитесь.
Отсутствует
Раньше у меня стояла кнопка которая
addEventListener( "DOMContentLoaded", function(e) { var doc = e.target; var win = doc.defaultView; if(win != win.top) // Ignore frames return; if (doc.location.host=="forum.mozilla-russia.org"){ var boxes = []; var pres = doc.getElementsByTagName("pre"); for(var i = 0, l = pres.length; i < l; ++i) { var pre = pres[i]; if(pre.parentNode.parentNode.parentNode.className == "codebox") boxes.push(pre); } for(var i = 0, l = boxes.length; i < l; ++i) { var box = boxes[i]; if(box.hasAttribute("data-highlight-js-parsed")) continue; box.setAttribute("data-highlight-js-parsed", "true"); // Special "codes" var tc = box.textContent; if( /^custombutton:\/\/\S+%3C\/custombutton%3E\s*$/.test(tc) || /^data:[\w-]+\/[\w-]+;base64,\S+\s*$/.test(tc) ) { tc = tc.replace(/\s+$/, ""); var a = doc.createElement("a"); a.href = tc; var icon; if(/^data:image\//.test(tc)) icon = tc; else if( /^custombutton:\/\//.test(tc) && /%3Cimage%3E%3C%21%5BCDATA%5B(data%3A\S+)%5D%5D%3E%3C\/image%3E/.test(tc) ) try { icon = decodeURIComponent(RegExp.$1); } catch(e) {} if(icon) { var img = doc.createElement("img"); img.src = icon; img.alt = ""; var s = img.style; s.marginRight = "4px"; s.verticalAlign = "middle"; a.appendChild(img); } a.appendChild(doc.createTextNode(tc)); var s = a.style; s.background = "none"; s.margin = s.padding = 0; box.innerHTML = ""; box.appendChild(a); continue; } } } }, true, document.getElementById("appcontent") );
Отсутствует
bunda1
у кнопки Переключить JavaScript для сайтов отвалилась перезагрузка страницы.
А e10 включен?
Отсутствует
В кнопке Загружать изображения на страницах перезагрузка работает.
Может, позаимствовать можно?
В кнопке Загружать изображения на страницах и Переключить JavaScript для сайтов одинаковые коды перезагрузки страницы - BrowserReload() и у меня на FF52 + Переключить JavaScript для сайтов перегрузка страницы работает. Может так попробуй:
// Настройка функций кликов мыши для кнопки .............. this._handleClick =()=> { var scriptEnabled = gBrowser.docShell.allowJavascript; // текущее состояние JavaScript на странице var currHost = content.document.domain; if ( !currHost ) return; saveTextToHelp(currHost, scriptEnabled); tabsReload(false, currHost, !scriptEnabled); }; // Получаем из вкладки 'Справка' массив с доменами .............. var hosts = self.getAttribute('Help').split('\n').filter((host)=> /\S/.test(host)).map((host)=> host.trim()); // Перегрузить и переключить JavaScript для текущей вкладки или вкладок сайта или всех сайтов из массива .............. function tabsReload( reason, currHost, scriptEnabled ) { if ( reason == 'destructor' ) return; if ( reason ) scriptEnabled = reason != 'update'; // переключить текущую вкладку если левый клик на кнопке if ( !reason ) { gBrowser.docShell.allowJavascript = scriptEnabled; setTimeout(()=> BrowserReload(), 500); }; // Сплывающая подсказка .... var notification = reason ? 'Перегрузить все вкладки сайтов из списка' : 'Перегрузить все вкладки сайта'; var alertsService = Cc["@mozilla.org/alerts-service;1"].getService(Ci.nsIAlertsService) alertsService.showAlertNotification(self.image, self.label, notification, true, "", listener, ""); // стиль сплывающей подсказки var sss = Cc["@mozilla.org/content/style-sheet-service;1"].getService(Ci.nsIStyleSheetService); var uri = makeURI('data:text/css,'+ encodeURIComponent('\ #alertImage { height: 35px !important; width: 35px !important; }\ #alertNotification:hover { cursor: pointer !important; }\ #alertTextLabel { color: #0000FF !important; text-decoration: underline; }\ ')); sss.loadAndRegisterSheet(uri, 0); // удалить стиль и подсказку через указанное время setTimeout(()=> { sss.unregisterSheet(uri, 0); alertsService.closeAlert(); }, 4000); // переключить вкладки сайта или всех сайтов из массива если кликнуть на подсказке function listener(subject, topic, data) { if ( topic !== 'alertclickcallback' ) return; var currTab = gBrowser.mCurrentTab; for( var tab of gBrowser.tabs ) { var uri = tab.linkedBrowser.currentURI; if ( !uri.scheme.startsWith("http") ) continue; var tabHost = tab.linkedBrowser.contentDocument.location.host; if ( tabHost == '' ) return; var tabReload = reason ? hosts.indexOf(tabHost) !== -1 : tab !== currTab && tabHost == currHost; if ( tabReload ) { tab.linkedBrowser.docShell.allowJavascript = scriptEnabled; gBrowser.reloadTab(tab); } } } }; addDestructor(tabsReload); // Записать текст в вкладку 'Справка' .............. function saveTextToHelp(currHost, addHost) { // удалить или добавить текущий сайт в массив с доменами addHost ? hosts.push(currHost) : hosts = hosts.filter((host)=> { return (host !== currHost) }) var value = hosts.join("\n"); // записать массив var dir = Services.dirsvc.get("ProfD", Ci.nsIFile); dir.initWithPath(dir.path + "\\extensions\\custombuttons@xsms.org\\components\\CustomButtonsService.js"); var url = Services.io.newFileURI(dir).spec, cbs = {}; Services.scriptloader.loadSubScript(url, cbs); var AO = new cbs.AppObject(), btn = AO.getButton(_id); self.setAttribute("Help", value); btn.setAttribute("Help", value); AO.overlay.saveOverlayToProfile(); }; // Обработчик следит за изменениями табов и запускают нужные коды и функции .............. addEventListener("TabAttrModified", e=> { var browser = e.target.linkedBrowser; // отключить JavaScript для сайта если домен сайта совпадает с массивом 'hosts' var specifiedSite = hosts.indexOf( browser.contentDocument.location.host ) !== -1; browser.docShell.allowJavascript = !specifiedSite; // если на странице отключен JavaScript меняем иконку if ( browser == gBrowser.selectedBrowser ) { self.style.filter = specifiedSite || !cbu.getPrefs("javascript.enabled") ? grayscale : ''; } }, true, gBrowser.tabContainer); var grayscale = parseInt(Services.appinfo.version) < 36 ? 'url("chrome://mozapps/skin/extensions/extensions.svg#greyscale")' : 'grayscale(1)';
Отсутствует
bunda1
Извиняюсь за панику, похоже, это косяк Cyberfox.
Версия 52.0.1 работает стабильно.
Но сегодня обновил Cyberfox до 52.0.2 и они там чего-то наулучшали.
Откатился и все заработало.
Отсутствует
Добрый день!
Давно пользуюсь незаменимым и замечательным Save snapshot to html. Но на некоторых сайтах он не сохраняет картинки, либо обрезает их. При этом в pdf или mht все норм. Подозреваю что это из-за кривизны рук сайтописателя, но тем не менее. Как пример, если сохранить вот эту страницу, то часть верхнего рисунка отрезается на 70%. Можно что-то сделать с этим?
Отсутствует
А из за чего такое может быть? FF Exp Imp CB перестала перезаписывать путь каталога сохранения в настройках. Пришлось в ручную исправлять. Проверил и на 3 и 4 фиксе CB. На чистом профиле то же самое, но она хотя бы предлагает сохранять на C:, а вот на старом, где был прописан уже не существующий путь, постоянно выводит сообщение, что нужно установить путь, ну а при установке пути он не перезаписывается.
Можно это дело пофиксить?
Добавлено 13-04-2017 00:42:26
ARG
Вот смотрите, я сделал фотку и в архив ее запаковал, так как слишком большая получилась, сравните со своей.
FREESCALE 2 X BLF188XR HF AMPLIFIER 1 8-54MHZ 1 5K 13.04.2017. 00-36-23.rar
Если у вас работает не так, то ищите фиксы которые недавно делались для этой кнопки, буквально в прошлом месяце вроде. Их было штук пять разных, но где они лежат я не помню.
Хотя, вот вариант который у меня:
// Save, от 08.03.2017. ............. self.label = "Save"; self._handleClick =()=> menuPopup.showPopup(this, -1, -1, "popup", "bottomleft", "topleft"); self.image = ""; var pref = "CB.Shortcuts.pathToSaveShortcuts"; var faviconFolder = "C:\\Documents and Settings\\Favicon\\"; // папка для сохранения иконок для ярлыков и ярлыков сайтов var alertsService = Cc["@mozilla.org/alerts-service;1"].getService(Ci.nsIAlertsService); // Создать меню для кнопки ............. var array = [ { label: "Сохранить страницу в html одним файлом", func: "runSaveSnapshotToHtml()", image: ""}, { separator: ''}, { label: "Сохранить значок веб-сайта", func: "saveFavicon()", image: ""}, { label: "Запомнить значок веб-сайта как base64", func: "copyFaviconData()", image: ""}, { separator: ''}, { label: "Сохранить ярлык страницы как…", func: "saveShortcuts('true')", image: ""}, { label: "Сохранить ярлык страницы без запроса на сохранение", func: "saveShortcuts()", image: false}, { separator: ''}, { label: "Сохранить всю страницу как PNG", func: "WebScreenShot.captureAll()", image: ""}, { label: "Сохранить видимую часть страницы как PNG", func: "WebScreenShot.capturePage()", image: false}, { label: "Сохранить выбранный элемент страницы как PNG", func: "WebScreenShotByClick.init()", image: ""}, { label: "Сохранить выбранную область страницы как PNG", func: "WebScreenShotByClipping.init()", image: ""}, { separator: ''}, { label: "Сохранить всю страницу как PDF", func: "savePageToPDF()", image: ""}, { label: "Добавить url и сохранить страницу", func: "savePage()", image: ""}, { label: "Сохранить выделенный текст как txt файл", func: "saveSelectionToTxt()", image: ""}, { separator: ''}, { label: "Запомнить изображение как base64, в контекстном меню", value: "CB.Save.WebScreenShotOnImage"}, { label: "Сохранить выделенный текст в файл, в контекстном меню", value: "CB.Save.SelectionToFile" }, { label: "Открыть выделенный текст в внешнем редакторе, в контекстном меню", value: "CB.Save.TextToEditor"}, ]; var menuPopup = self.appendChild(document.createElement("menupopup")); array.forEach((m,i)=> { if ("separator" in m) { menuPopup.appendChild(document.createElement("menuseparator")); return }; var mItem = menuPopup.appendChild(document.createElement("menuitem")); mItem.setAttribute("label", m.label); mItem.setAttribute("class", "menuitem-iconic"); if ("image" in m) mItem.setAttribute("image", m.image || array[i-1].image); if ("value" in m) { mItem.setAttribute('type', 'checkbox'); mItem.setAttribute('checked', cbu.getPrefs(m.value) ); mItem.onclick =()=> cbu.setPrefs(m.value, !cbu.getPrefs(m.value)); } if ("func" in m) mItem.addEventListener("command", ()=> eval(m.func.toString())); }); menuPopup.setAttribute("onclick", "event.stopPropagation()"); // Сохранить как PNG страницу или части страницы ............. WebScreenShot = { capture: function(win, x, y, width, height) { var canvas = document.createElementNS(xhtmlns, 'canvas'); canvas.width = width; canvas.height = height; var ctx = canvas.getContext("2d"); ((i = 17)=> { try { ctx.drawWindow(win, x, y, canvas.width, canvas.height, "white") } catch(e) { canvas.height = canvas.width*i; arguments.callee(--i) }; })(); var url = makeURI(canvas.toDataURL("image/png")); var fp = window.makeFilePicker(); fp.init(window, "Сохранить как…", fp.modeSave); fp.appendFilter("", "*.png"); fp.defaultString = getTabLabel() + " " + (new Date().toLocaleFormat("%d.%m.%Y. %H:%M:%S")) + ".png"; if (fp.show() == fp.returnCancel || !fp.file) return; var wbp = window.makeWebBrowserPersist(); parseInt(Services.appinfo.version) < 36 ? wbp.saveURI(url, null, null, null, null, fp.file, null) : wbp.saveURI(url, null, null, null, null, null, fp.file, null); // если FF36+ }, captureAll: function() { var win = content; WebScreenShot.capture(win, 0, 0, win.innerWidth + win.scrollMaxX, win.innerHeight + win.scrollMaxY); }, capturePage: function() { var win = content, doc = win.document, body = doc.body, html = doc.documentElement; var scrX = (body.scrollLeft || html.scrollLeft) - html.clientLeft; var scrY = (body.scrollTop || html.scrollTop) - html.clientTop; WebScreenShot.capture(win, scrX, scrY, win.innerWidth, win.innerHeight); }, onImage: function(image) { var canvas = document.createElementNS(xhtmlns, 'canvas'); canvas.width = image.naturalWidth; canvas.height = image.naturalHeight; var ctx = canvas.getContext('2d'); ctx.drawImage(image, 0, 0); var base64 = canvas.toDataURL(); gClipboard.write(base64); // стиль для изображение в сплывающей подсказке .... var sss = Cc["@mozilla.org/content/style-sheet-service;1"].getService(Ci.nsIStyleSheetService); var uri = makeURI('data:text/css,'+ encodeURIComponent('#alertImage { height: 25px !important; width: 25px !important; }')); sss.loadAndRegisterSheet(uri, 0); alertsService.showAlertNotification(base64, self.label, "Запомнил изображение как base64", false, "", (s, t)=> { if (t == 'alertfinished') sss.unregisterSheet(uri, 0); // удалить стиль когда подсказка закрывается }, ""); } }; // Сохранить выбранную область страницы как PNG .... WebScreenShotByClipping = { capture: WebScreenShot.capture, handleEvent: function(e) { if (e.button) return false; e.preventDefault(); e.stopPropagation(); switch(e.type){ case 'mousedown': this.downX = e.pageX; this.downY = e.pageY; this.bs.left = this.downX + 'px'; this.bs.top = this.downY + 'px'; this.body.appendChild(this.box); this.flag = true; break; case 'mousemove': if (!this.flag) return; this.moveX = e.pageX; this.moveY = e.pageY; if (this.downX > this.moveX) this.bs.left = this.moveX + 'px'; if (this.downY > this.moveY) this.bs.top = this.moveY + 'px'; this.bs.width = Math.abs(this.moveX - this.downX) + 'px'; this.bs.height = Math.abs(this.moveY - this.downY) + 'px'; break; case 'mouseup': this.uninit(); break; } }, init: function() { this.win = document.commandDispatcher.focusedWindow; if (this.win == window) this.win = content; this.doc = this.win.document; this.body = this.doc.body; if (!this.body instanceof HTMLBodyElement){ alertsService.showAlertNotification(self.image, self.label, "Не удается захватить!"); return false; } this.flag = null; this.box = this.doc.createElement('div'); this.bs = this.box.style; this.bs.border = '#0f0 dashed 2px'; this.bs.position = 'absolute'; this.bs.zIndex = '2147483647'; this.defaultCursor = getComputedStyle(this.body, '').cursor; this.body.style.cursor = 'crosshair'; ["click", "mouseup", "mousemove", "mousedown"].forEach(type=> this.doc.addEventListener(type, this, true)); }, uninit: function() { var pos = [this.win, parseInt(this.bs.left), parseInt(this.bs.top), parseInt(this.bs.width), parseInt(this.bs.height)]; this.body.style.cursor = this.defaultCursor; this.body.removeChild(this.box); this.capture.apply(this, pos); ["click", "mouseup", "mousemove", "mousedown"].forEach(type=> this.doc.removeEventListener(type, this, true)); }, }; // Сохранить выбранный элемент на странице как PNG .... WebScreenShotByClick = { capture: WebScreenShot.capture, getPosition: function() { var html = this.doc.documentElement; var body = this.doc.body; var rect = this.target.getBoundingClientRect(); return [ this.win ,Math.round(rect.left) + (body.scrollLeft || html.scrollLeft) - html.clientLeft ,Math.round(rect.top) + (body.scrollTop || html.scrollTop) - html.clientTop ,parseInt(rect.width) ,parseInt(rect.height) ]; }, highlight: function() { this.orgStyle = this.target.hasAttribute('style') ? this.target.style.cssText : false; this.target.style.cssText += 'outline: red 2px solid; outline-offset: 2px; -moz-outline-radius: 2px;'; }, lowlight: function(e) { if (this.orgStyle) this.target.style.cssText = this.orgStyle; else this.target.removeAttribute('style'); }, handleEvent: function(e) { switch(e.type){ case 'click': if (e.button) return; e.preventDefault(); e.stopPropagation(); this.lowlight(); this.capture.apply(this, this.getPosition()); this.uninit(); break; case 'mouseover': if (this.target) this.lowlight(); this.target = e.target; this.highlight(); break; } }, init: function() { this.win = content; this.doc = content.document; ["click", "mouseover"].forEach(type=> this.doc.addEventListener(type, this, true)); }, uninit: function() { this.target = false; ["click", "mouseover"].forEach(type=> this.doc.removeEventListener(type, this, true)); }, }; // Сохранить страницу как PDF файл через сервис 'pdfmyurl.com' ............. function savePageToPDF(loc = content.location) { loc.href.startsWith("http") && loadURI("http://pdfmyurl.com?url=" + loc); }; // Сохранить ярлык страницы в указанную папку или в последнюю папку сохранения .............. function saveShortcuts(saveAs, shortcutName) { var url = content.document.location; cbu.isPref(pref, "C:\\"); // блокируем создание ярлыков для внутренних страниц FF if ( ["about:", "chrome:", "jar:", "data:"].indexOf(url.protocol) !== -1 ) { alertsService.showAlertNotification("chrome://global/skin/icons/error-16.png", self.label, "Не поддерживается"); return; } // получить название ярлыка if ( saveAs ) shortcutName = setPathToShortcut(shortcutName) else shortcutName = shortcutName ? shortcutName : getSiteName() + getTabLabel() + " " + Date.now(); if ( saveAs && shortcutName == false ) return; // сохранить иконку таба в установленную папку var faviconName = "favicon" + Date.now(); var favicon = saveFaviconToFolder(faviconName); // получить путь для сохранения ярлыка из 'about:config' var pathToFolder = gPrefService.getComplexValue(pref, Ci.nsISupportsString).data; var pathToShortcut = pathToFolder + shortcutName + ".url"; // адрес страницы в UTF-8 если это протокол 'file' или в 'Punycode' если это .рф домен if ( url.protocol == 'file:' ) url = convertFromUnicode("UTF-8", url); if ( url.host.slice(-3) == '.рф') url = Services.io.newURI(url, null, null).asciiSpec; // текст ярлыка из адреса страницы и пути к иконке таба var text = "[InternetShortcut]" + "\r\n" + "URL=" + url; var pathToFavicon = "IconFile=" + faviconFolder + faviconName + ".ico" + "\r\n"; if ( favicon == false ) var pathToFavicon = ""; var data = text + "\r\n" + pathToFavicon + "IconIndex=0"; // записать текст в ярлык var file = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile); var foStream = Cc["@mozilla.org/network/file-output-stream;1"].createInstance(Ci.nsIFileOutputStream); file.initWithPath(pathToShortcut); foStream.init(file, 0x02|0x08|0x20, 0666, 0); foStream.write(data, data.length); foStream.close(); // подсказка var notification = 'Сохранил в: ' + pathToFolder; var image = (favicon == false) ? self.image : gBrowser.selectedBrowser.mIconURL; alertsService.showAlertNotification(image, shortcutName, notification); }; // Установка пути и названия для сохранения ярлыка через диалог сохранения, отмена отдаст 'false' .............. function setPathToShortcut(shortcutName) { var pathToFile = gPrefService.getComplexValue(pref, Ci.nsISupportsString).data; var shortcutName = shortcutName ? shortcutName : getSiteName() + getTabLabel() + " " + Date.now(); // диалог создания и установки пути var fp = window.makeFilePicker(); fp.init(window, "Укажите где сохранить ярлык страницы!", fp.modeSave); fp.appendFilters(fp.filterAll); fp.defaultString = shortcutName; if ( fp.show() == fp.returnCancel ) return false; // убрать название файла из пути к файлу и записать путь в 'about:config' var filePath = fp.file.path.toString(); var fileName = fp.file.leafName.toString(); cbu.setPrefs(pref, convertFromUnicode("UTF-8", filePath.replace(fileName, "")) ); return fileName; }; // Сохранить в указанную папку иконку таба как .ico и без диалога сохранения .............. function saveFaviconToFolder(faviconName) { var url = gBrowser.mCurrentTab.image.replace("#-moz-resolution=16,16",""); if ( !url || content.document.mozSyntheticDocument ) return false; if ( url.startsWith("http") ) url = "moz-anno:favicon:" + url; var img = new Image(); img.onload = function() { var tools = Cc["@mozilla.org/image/tools;1"].getService(Ci.imgITools); var stream = Cc["@mozilla.org/scriptableinputstream;1"].createInstance(Ci.nsIScriptableInputStream); var file = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile); var request = img.QueryInterface(Ci.nsIImageLoadingContent).getRequest(img.CURRENT_REQUEST); var istrm = tools.encodeImage(request.image, "image/vnd.microsoft.icon", "format=bmp;bpp=32"); stream.init(istrm); var data = stream.readBytes(stream.available()); istrm.close(); stream.close(); var path = faviconFolder + faviconName + ".ico"; file.initWithPath(path); file.exists() && file.remove(false); try { file.create(file.NORMAL_FILE_TYPE, 448) } catch(e) { setTimeout(()=> { alertsService.showAlertNotification("chrome://global/skin/icons/error-16.png", self.label, "Не могу сохранить иконку вкладки в " + faviconFolder + "\n" + "Укажите в начале кода кнопки другой диск!"); }, 2500); }; cbu.writeFile(path, data); } img.setAttribute("src", url); }; // Добавить адрес наверху страницы и открыть диалог сохранения страницы ............. function savePage() { var sURL = gURLBar.value; content.document.body.innerHTML = "<table width=100%><tr><td align=left><small><a target=_blank href=" + sURL + ">"+ sURL + "</a></small>\n</td></tr></table>" + content.document.body.innerHTML; saveDocument(window.content.document); }; // Сохранить иконку текущего сайта с диалогом сохранения ............. function saveFavicon() { saveImageURL(gBrowser.mCurrentTab.image, "save", null, false, false, null, content.document) }; // Скопировать иконку текущего сайта как base64 код ............. function copyFaviconData() { var img = new Image(); img.src = gBrowser.mCurrentTab.image; WebScreenShot.onImage(img); }; // Сохранить выделенный текст или весь текст на странице как txt файл ............. function saveSelectionToTxt() { var sel = getSelect(); !sel && document.getElementById("cmd_selectAll").doCommand(); // создать название файла из заголовка страницы и текущего времени и сохранить текст .... var fileTitle = getTabLabel() + ' ' + (new Date()).toLocaleFormat("%H·%M·%S"); saveURL("data:text/plain," + encodeURIComponent(content.location + ("\r\n\r\n" + sel)), fileTitle + ".txt", null, false, false, null, content.document); !sel && goDoCommand("cmd_selectNone"); }; // Добавляем в контекстного меню страницы новые пункты ............. ((contextMenu, el)=> { // в контекстного меню изображений .... var baseItem = contextMenu.appendChild(document.createElement("menuitem")); baseItem.id = "content-baseItem"; baseItem.setAttribute("label", "Запомнить изображение как base64"); baseItem.onclick =()=> WebScreenShot.onImage(gContextMenu.target); // в контекстного меню выделенного текста .... var saveItem = contextMenu.insertBefore(document.createElement("menuitem"), el); saveItem.id = "content-saveItem"; saveItem.setAttribute("label", "Сохранить выделенный текст в файл"); saveItem.onclick =()=> saveSelectionToFile(); var editorItem = contextMenu.insertBefore(document.createElement("menuitem"), el); editorItem.id = "content-editorItem"; editorItem.setAttribute("label", "Открыть выделенный текст в внешнем редакторе"); editorItem.onclick =()=> textToEditor(); // устанавливаем где и при каких настройках показывать новые пункты .... addEventListener('popupshowing', e=> { if (e.target != e.currentTarget) return; var sel = gContextMenu.isTextSelected; saveItem.hidden = !sel || !cbu.getPrefs("CB.Save.SelectionToFile"); editorItem.hidden = !sel || !cbu.getPrefs("CB.Save.TextToEditor"); baseItem.hidden = !gContextMenu.onImage || !cbu.getPrefs("CB.Save.WebScreenShotOnImage"); }, false, contextMenu); // удалять новые пункти при изминениях .... addDestructor(()=> { baseItem.remove(); saveItem.remove(); editorItem.remove(); }); })(document.getElementById("contentAreaContextMenu"), document.getElementById("context-sep-open")); // Сохранить выделенный текст в файл на рабочем столе ............. function saveSelectionToFile() { // создать текст для записи var url = content.document.location; if (/\.рф/.test(url.host)) url = convertFromUnicode("UTF-8", url); var time = new Date().toLocaleFormat("%H:%M:%S"); var text = convertFromUnicode("UTF-8", getSelect()); var title = convertFromUnicode("UTF-8", getTabLabel()); var text = "..............................................................\n" + title + " - " + time + "\n" + url + "\n\n" + text + "\n\n\n"; var text = text.replace(/\u000A/g, "\u000D\u000A").replace(/\u000D\u000D\u000A/g, "\u000D\u000A"); // путь к файлу и название файла var file = Services.dirsvc.get("Desk", Ci.nsIFile); file.append("Save - " + (new Date()).toLocaleFormat("%d.%m.%Y") + ".txt"); // создать файл с текстом или добавлять текст в файл var foStream = Cc["@mozilla.org/network/file-output-stream;1"].createInstance(Ci.nsIFileOutputStream); file.exists() ? foStream.init(file, 0x02 | 0x10, 0664, 0) : foStream.init(file, 0x02|0x08|0x20, 0666, 0); foStream.write(text, text.length); foStream.close(); // всплывающая подсказка дает возможность открыть файл если кликнуть на подсказке var notification = 'Сохранил выделенный текст в файл на рабочий стол'; var image = gBrowser.mCurrentTab.image || self.image; alertsService.showAlertNotification(image, notification, "Кликни чтобы открыть файл", true, "", (s, t)=> { if (t == 'alertclickcallback') file.launch(); }, ""); }; // Создать текстовой файл с выделенным текстом в папке профиля и открыть в редакторе ............. function textToEditor() { var text = convertFromUnicode("UTF-16", getSelect()); var file = Services.dirsvc.get('ProfD', Ci.nsIFile); file.append("TextToEditor.txt"); custombuttonsUtils.writeFile(file.path, text); file.launch(); }; // Конвертировать текст в юникод ............. function convertFromUnicode(charset, str) { var converter = Cc["@mozilla.org/intl/scriptableunicodeconverter"].createInstance(Ci.nsIScriptableUnicodeConverter); converter.charset = charset; str = converter.ConvertFromUnicode(str); return str + converter.Finish(); }; // Получить название домена с заглавным первым символом и без приставок( типа .ru и .com ) .............. function getSiteName() { try { var domain = content.document.domain.split('.') } catch(e) { return "" }; domain = (domain.length == 2) ? domain[0] : domain[1] return domain[0].toUpperCase() + domain.slice(1).split('.')[0] + " "; }; // Получить название вкладки без не сохраняемых символов и лишних пробелов .............. function getTabLabel() { var label = gBrowser.mCurrentTab.label; var label = label.replace(/[:+.\\\/<>?*|"]+/g, " ").replace(/\s\s+/g, " "); return label.substring(0, 50); }; // Получить выделенный текст из страницы или 'false' .............. function getSelect() { var el = document.commandDispatcher.focusedElement; try { return el.value.substring(el.selectionStart, el.selectionEnd) } catch(e) {}; var sel = document.commandDispatcher.focusedWindow.getSelection(); return (sel == '') ? false : sel.toString().replace(/^\s+|\s+$/g,"").replace(/\u000A/g, "\u000D\u000A").replace(/\u000D\u000D\u000A/g, "\u000D\u000A"); }; function runSaveSnapshotToHtml() { var saveToFile = function (fileContent, fileName) { var uc = Components.classes['@mozilla.org/intl/scriptableunicodeconverter'].createInstance(Components.interfaces.nsIScriptableUnicodeConverter); uc.charset = 'utf-8'; fileContent = uc.ConvertFromUnicode(fileContent); var nsIFilePicker = Components.interfaces.nsIFilePicker; var fp = Components.classes['@mozilla.org/filepicker;1'].createInstance(nsIFilePicker); fp.init(window, '', fp.modeSave); fp.defaultString = fileName; fp.appendFilters(fp.filterHTML); fp.appendFilters(fp.filterAll); if(fp.show() == fp.returnCancel) return; var stream = Components.classes['@mozilla.org/network/file-output-stream;1'].createInstance(Components.interfaces.nsIFileOutputStream); stream.init(fp.file, 0x02|0x20|0x08, 0666, 0); stream.write(fileContent, fileContent.length); stream.close(); }; var resolveURL = function (url, base) { try { var ioService = Components.classes['@mozilla.org/network/io-service;1'].getService(Components.interfaces.nsIIOService); var baseURI = ioService.newURI(base, null, null); var absURI = ioService.newURI(url, null, baseURI); return absURI.spec; } catch (e) {} }; var getSelWin = function (w) { if (w.getSelection().toString()) return w; for (var i = 0, f, r; f = w.frames[i]; i++) { try { if (r = getSelWin(f)) return r; } catch(e) {} } }; var encodeImg = function (src, obj) { var canvas, img, ret = src; if (/^https?:\/\//.test(src)) { canvas = doc.createElement('canvas'); if (!obj || obj.nodeName.toLowerCase() != 'img') { img = doc.createElement('img'); img.src = src; } else { img = obj; }; if (img.complete) try{ canvas.width = img.width; canvas.height = img.height; canvas.getContext('2d').drawImage(img, 0, 0); ret = canvas.toDataURL((/\.jpe?g/i.test(src) ? 'image/jpeg' : 'image/png')); } catch (e) {}; if (img != obj) img.src = 'about:blank'; }; return ret; }; var toSrc = function (obj) { var strToSrc = function (str) { var chr, ret = '', i = 0, meta = {'\b': '\\b', '\t': '\\t', '\n': '\\n', '\f': '\\f', '\r': '\\r', '\x22' : '\\\x22', '\\': '\\\\'}; while (chr = str.charAt(i++)) { ret += meta[chr] || chr; }; return '\x22' + ret + '\x22'; }, arrToSrc = function (arr) { var ret = []; for (var i = 0; i < arr.length; i++) { ret[i] = toSrc(arr[i]) || 'null'; }; return '[' + ret.join(',') + ']'; }, objToSrc = function (obj) { var val, ret = []; for (var prop in obj) { if (Object.prototype.hasOwnProperty.call(obj, prop) && (val = toSrc(obj[prop]))) ret.push(strToSrc(prop) + ': ' + val); }; return '{' + ret.join(',') + '}'; }; switch (Object.prototype.toString.call(obj).slice(8, -1)) { case 'Array': return arrToSrc(obj); case 'Boolean': case 'Function': case 'RegExp': return obj.toString(); case 'Date': return 'new Date(' + obj.getTime() + ')'; case 'Math': return 'Math'; case 'Number': return isFinite(obj) ? String(obj) : 'null'; case 'Object': return objToSrc(obj); case 'String': return strToSrc(obj); default: return obj ? (obj.nodeType == 1 && obj.id ? 'document.getElementById(' + strToSrc(obj.id) + ')' : '{}') : 'null'; } }; var mainWin = document.commandDispatcher.focusedWindow.top == content ? document.commandDispatcher.focusedWindow : content; var selWin = getSelWin(mainWin), win = selWin || mainWin, doc = win.document, loc = win.location; var ele, pEle, clone, reUrl = /(url\(\x22)(.+?)(\x22\))/g; if (selWin) { var rng = win.getSelection().getRangeAt(0); pEle = rng.commonAncestorContainer; ele = rng.cloneContents(); } else { pEle = doc.documentElement; ele = (doc.body || doc.getElementsByTagName('body')[0]).cloneNode(true); }; while (pEle) { if (pEle.nodeType == 1) { clone = pEle.cloneNode(false); clone.appendChild(ele); ele = clone; }; pEle = pEle.parentNode }; var sel = doc.createElement('div'); sel.appendChild(ele); for (var el, all = sel.getElementsByTagName('*'), i = all.length; i--;) { el = all[i]; if (el.style && el.style.backgroundImage) el.style.backgroundImage = el.style.backgroundImage.replace(reUrl, function (a, prev, url, next) { if (!/^[a-z]+:/.test(url)) url = resolveURL(url, loc.href); return prev + encodeImg(url) + next; }); switch (el.nodeName.toLowerCase()) { case 'link': case 'style': case 'script': el.parentNode.removeChild(el); break; case 'a': case 'area': if (el.hasAttribute('href') && el.getAttribute('href').charAt(0) != '#') el.href = el.href; break; case 'img': case 'input': if (el.hasAttribute('src')) el.src = encodeImg(el.src, el); break; case 'audio': case 'video': case 'embed': case 'frame': case 'iframe': if (el.hasAttribute('src')) el.src = el.src; break; case 'object': if (el.hasAttribute('data')) el.data = el.data; break; case 'form': if (el.hasAttribute('action')) el.action = el.action; break; } }; var head = ele.insertBefore(doc.createElement('head'), ele.firstChild); var meta = doc.createElement('meta'); meta.httpEquiv = 'content-type'; meta.content = 'text/html; charset=utf-8'; head.appendChild(meta); var title = doc.getElementsByTagName('title')[0]; if (title) head.appendChild(title.cloneNode(true)); head.copyScript = function (unsafeWin) { if ('$' in unsafeWin) return; var f = doc.createElement('iframe'); f.src = 'about:blank'; f.setAttribute('style', 'position:fixed;left:0;top:0;visibility:hidden;width:0;height:0;'); doc.documentElement.appendChild(f); var str, script = doc.createElement('script'); script.type = 'text/javascript'; for (var name in unsafeWin) { if (name in f.contentWindow || !/^[a-zA-Z_$][0-9a-zA-Z_$]*$/.test(name)) continue; try { str = toSrc(unsafeWin[name]); if (!/\{\s*\[native code\]\s*\}/.test(str)) { script.appendChild(doc.createTextNode('var ' + name + ' = ' + str.replace(/<\/(script>)/ig, '<\\/$1') + ';\n')); } } catch (e) {}; }; f.parentNode.removeChild(f); if (script.childNodes.length) this.nextSibling.appendChild(script); }; head.copyScript(win.wrappedJSObject || win); head.copyStyle = function (s) { if (!s) return; var style = doc.createElement('style'); style.type = 'text/css'; if (s.media && s.media.mediaText) style.media = s.media.mediaText; try { for (var i = 0, rule; rule = s.cssRules[i]; i++) { if (rule.type != 3) { if((!rule.selectorText || rule.selectorText.indexOf(':') != -1) || (!sel.querySelector || sel.querySelector(rule.selectorText))) { var css = !rule.cssText ? '' : rule.cssText.replace(reUrl, function (a, prev, url, next) { if (!/^[a-z]+:/.test(url)) url = resolveURL(url, s.href || loc.href); if(rule.type == 1 && rule.style && rule.style.backgroundImage) url = encodeImg(url); return prev + url + next; }); style.appendChild(doc.createTextNode(css + '\n')); } } else { this.copyStyle(rule.styleSheet); } } } catch(e) { if (s.ownerNode) style = s.ownerNode.cloneNode(false); }; this.appendChild(style); }; var sheets = doc.styleSheets; for (var j = 0; j < sheets.length; j++) head.copyStyle(sheets[j]); head.appendChild(doc.createTextNode('\n')); var doctype = '', dt = doc.doctype; if (dt && dt.name) { doctype += '<!DOCTYPE ' + dt.name; if (dt.publicId) doctype += ' PUBLIC \x22' + dt.publicId + '\x22'; if (dt.systemId) doctype += ' \x22' + dt.systemId + '\x22'; doctype += '>\n'; }; var fileName = selWin ? win.getSelection().toString() : (title && title.text ? title.text : loc.pathname.split('/').pop()); fileName = fileName.replace(/[:\\\/<>?*|"]+/g, '_').replace(/\s+/g, ' ').slice(0, 100).replace(/^\s+|\s+$/g, ''); fileName += (function () { var d = new Date(), z = function(n){return '_' + (n < 10 ? '0' : '') + n}; return z(d.getHours()) + z(d.getMinutes()) + z(d.getSeconds()); })(); if(!/\.html?$/.test(fileName))fileName += '.html'; saveToFile(doctype + sel.innerHTML + '\n<!-- This document saved from ' + (loc.protocol != 'data:' ? loc.href : 'data:uri') + ' -->', fileName); };
Отредактировано _zt (13-04-2017 00:51:22)
Отсутствует
Есть кнопка "Открыть страницу или выделенную ссылку в другом браузере":
// Настройка функций кликов мыши ................. this.onclick = function(e) { if ( e.button == 0 ) menuPopup.showPopup(this, -1, -1, "popup", "bottomleft", "topleft"); }; // Объявляем настройки и переменные для этой вкладки ................. var autoClose = true; // true => автоматически закрывать меню var dropmarker = false; // true => добавлять дропмаркер у кнопки const pref = Application.prefs; if ( dropmarker ) this.type = "menu"; const alertsService = Cc["@mozilla.org/alerts-service;1"].getService(Ci.nsIAlertsService); // Проверить наличие строки в about:config и если не существует записать пути к браузерам по умолчанию ................. const allPath = "C:\\Program Files\\Internet Explorer\\iexplore.exe,C:\\Documents and Settings\\Администратор\\Local Settings\\Application Data\\Google\\Chrome\\Application\\chrome.exe,C:\\Program Files\\Opera\\Opera.exe,C:\\Program Files\\Maxthon\\Bin\\Maxthon.exe,C:\\Program Files\\SeaMonkey\\seamonkey.exe"; if ( !pref.getValue("CB.OpenWith.pathToBrowser", 0) ) { pref.setValue("CB.OpenWith.pathToBrowser", allPath ); pref.setValue("CB.OpenWith.removeMenuitem", ""); }; // Создать меню для кнопки ................. var array = [ { label: "Internet Explorer", image: "" }, { label: "Google Chrome", image: "" }, { label: "Opera", image: "" }, { label: "Maxthon", image: "" }, { label: "SeaMonkey", image: "" }, ]; // получить массив с ненужными пунктами меню и восстановливать меню при обнавлении кнопки var hideItems = pref.getValue("CB.OpenWith.removeMenuitem", 0).split(","); addDestructor(function(reason) { if (reason == 'update') pref.setValue("CB.OpenWith.removeMenuitem", "") }); var menuPopup = self.appendChild( document.createElement("menupopup") ); array.forEach(function( m, i ) { if ( "separator" in m ) { menuPopup.appendChild( document.createElement("menuseparator") ); return }; var mItem = document.createElement("menuitem"); mItem.setAttribute("label", m.label); mItem.setAttribute("class", "menuitem-iconic"); mItem.setAttribute("image", m.image ); mItem.setAttribute("value", i++ ); mItem.hidden = hideItems.indexOf(m.label) !== -1; // прятать ненужные пункты меню menuPopup.appendChild( mItem ); }); menuPopup.addEventListener("click", setMenuClick, false); // Настройка функций кликов мыши для пунктов меню ................. function setMenuClick(e) { var mItem = e.target; var value = mItem.getAttribute("value"); var label = mItem.getAttribute("label"); var image = mItem.getAttribute("image"); // ЛКМ запускает другой браузер .... if ( e.button == 0) openWith( value ); // СКМ удаляет пункты меню и записывает выбор в 'about:config' .... if ( e.button == 1 ) { e.preventDefault(); mItem.hidden = true; pref.setValue("CB.OpenWith.removeMenuitem", pref.getValue("CB.OpenWith.removeMenuitem", 0) + label +',' ); } // ПКМ устанавливает новый путь к нужному браузеру .... if ( e.button == 2 ) { e.preventDefault(); menuPopup.hidePopup(); setPathToBrowser( value, image, label ); } }; // Получить выделенную ссылку, иначе отдаст 'false' ................. function getSelectLink() { var links = window.content.document.links; if ( !(document.commandDispatcher.focusedWindow.getSelection() == '') ) { for ( i=0; i<links.length; ++i ) { if ( window.content.getSelection().containsNode(links[i], true) ) { var link = links[i]; } } return ( link == undefined ) ? false : link; } else { return false }; }; // Открыть страницу или ссылку в другом браузере, аргумент 'value' определяет нужный элемент массива с путями ................. function openWith( value ) { // получить адрес ссылки или страницы, в 'Punycode' если это .рф домен .... var loc = content.document.location; var link = getSelectLink(); var loc = link ? link : loc; var url = ( loc.host.slice(-3) == '.рф') ? Services.io.newURI( loc.href, null, null).asciiSpec : loc; var path = pref.getValue("CB.OpenWith.pathToBrowser", 0); var pathToBrowser = path.split(",")[value]; // получить путь из 'about:config' var file = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile); file.initWithPath( pathToBrowser ); if ( !file.exists() ) { alertsService.showAlertNotification("chrome://global/skin/icons/error-16.png", pathToBrowser, 'Файл не существует', false, "", null, ""); return; } var process = Cc["@mozilla.org/process/util;1"].createInstance(Ci.nsIProcess); try { var args = [url]; process.init( file ); process.run( false, args, args.length ); } catch(e) { alertsService.showAlertNotification("chrome://global/skin/icons/error-16.png", pathToBrowser, 'Не удалось выполнить', false, "", null, "") }; }; // Установить новый путь к браузеру, и записать выбор в 'about:config' ................. function setPathToBrowser( value, image, label ) { var fp = Cc["@mozilla.org/filepicker;1"].createInstance(Ci.nsIFilePicker); fp.init( window, "Укажите путь к нужному браузеру!", fp.modeOpen ); fp.appendFilters( fp.filterApps ); if ( fp.show() == fp.returnCancel ) return; else { // получить из 'about:config' массив с путями к браузерам var arr = pref.getValue("CB.OpenWith.pathToBrowser", 0).split(","); // заменить нужный элемент массива на новый путь и записать var newPath = fp.file.path; arr[value] = newPath; pref.setValue("CB.OpenWith.pathToBrowser", arr.toString() ); alertsService.showAlertNotification( image, "Путь к браузеру: " + label, newPath, false, "", null, ""); } }; // Автоматически закрывать меню при ухода курсора с меню ................. if ( autoClose ) { menuPopup.setAttribute("onmouseleave", "this.mo = false; setTimeout(function(mp) { if ( !mp.mo ) mp.hidePopup() }, 800, this)"); menuPopup.setAttribute("onmouseover", "this.mo = true"); }; // Подсказка кнопки ................. this.tooltipText = "Открыть страницу или выделенную ссылку в другом браузере" +"\n"+"\n"+ "Функции кликов мыши для пунктов меню" +"\n"+ "Л: Открыть страницу или ссылку" +"\n"+ "С: Удалить пункт меню" +"\n"+ "П: Изменить путь к нужному браузеру";
Хорошо, когда у человека есть выбор, но плохо, когда он перед ним стоит ©
Отсутствует
Есть кнопка "Открыть страницу или выделенную ссылку в другом браузере":
Я уже обновил эту кнопку и теперь в меню кнопки новые программы можно добавить по СКМ на кнопке: Открыть страницу в другом браузере
Добавлено 17-04-2017 16:02:33
Как добавить туда Microsoft Edge? Я не могу найти путь к этому браузеру
Где в windows 10 находится edge
Отредактировано bunda1 (17-04-2017 16:02:33)
Отсутствует
Спасибо!
Я нашёл путь к Microsoft Edge, но всё равно он не запускается. Причём не запускается даже с Файл Эксплорера дабл кликом...
Так что дело не в кнопке... Пункт меню создаётся...
Хорошо, когда у человека есть выбор, но плохо, когда он перед ним стоит ©
Отсутствует
Ну тогда не знаю.
var link = "https://forum.mozilla-russia.org"; var explorer = Services.dirsvc.get("WinD", Ci.nsIFile); explorer.append("explorer.exe"); var process = Cc["@mozilla.org/process/util;1"].createInstance(Ci.nsIProcess); process.init(explorer); process.runw(false, ["microsoft-edge:" + link], 1);
Отсутствует
Привет, bunda1
А можно прикрутить редактирование имени браузера?
А то бывают не очень читабельные, особенно в портативных версиях.
Можно, конечно, сам экзешник переименовать, но лучше бы в кнопке была такая возможность.
Отсутствует
С этим ни кто не пожет?
FF Exp Imp CB перестала перезаписывать путь каталога сохранения в настройках. Пришлось в ручную исправлять. Проверил и на 3 и 4 фиксе CB. На чистом профиле то же самое, но она хотя бы предлагает сохранять на C:, а вот на старом, где был прописан уже не существующий путь, постоянно выводит сообщение, что нужно установить путь, ну а при установке пути он не перезаписывается.
Можно это дело пофиксить?
Отсутствует
Спасибо Dumby. Попробую интегрировать твой код в свою кнопку.
Добавлено 18-04-2017 12:19:30
А можно прикрутить редактирование имени браузера?
А то бывают не очень читабельные, особенно в портативных версиях.
Можно, конечно, сам экзешник переименовать, но лучше бы в кнопке была такая возможность.
Сделаю, это не трудно.
Отредактировано bunda1 (18-04-2017 12:19:30)
Отсутствует
FF Exp Imp CB перестала перезаписывать путь каталога сохранения в настройках. Пришлось в ручную исправлять. Проверил и на 3 и 4 фиксе CB. На чистом профиле то же самое, но она хотя бы предлагает сохранять на C:, а вот на старом, где был прописан уже не существующий путь, постоянно выводит сообщение, что нужно установить путь, ну а при установке пути он не перезаписывается.
Можно это дело пофиксить?
Вроде всё работает: FF Exp Imp CB
Отсутствует
Спасибо Dumby. Попробую интегрировать твой код в свою кнопку.
У меня иногда вместо некоторых сайтов открывается файл эксплорер
/*CODE*/ var link = content.document.location; var explorer = Services.dirsvc.get("WinD", Ci.nsIFile); explorer.append("explorer.exe"); var process = Cc["@mozilla.org/process/util;1"].createInstance(Ci.nsIProcess); process.init(explorer); process.runw(false, ["microsoft-edge:" + link], 1);
Отредактировано difabor (19-04-2017 04:38:00)
Хорошо, когда у человека есть выбор, но плохо, когда он перед ним стоит ©
Отсутствует
bunda1
Конечно работает, автор же обновил ее вчера. Как же неудобно сделано, нет возможности узнавать об обновлениях. Может кнопку напишите, что бы проверяла обновления постов в той теме?
Отредактировано _zt (19-04-2017 15:39:18)
Отсутствует