bunda1
Хочется что бы отображалась фавиконка сайта с которого будут удалены куки
Отображается везде иконка нашего форума, а так очень удобно в контекстном меню
Исправил: Сегодня 21:20:04
Отсутствует
Ещё одна просьба-хотелочка. Переделать код готовой кнопки "Удалить куки текущего сайта" для отображения "Удалить куки текущего сайта" в контекстное меню
bunda1 Спасибо большое, работает отлично. Можно добавить в код функцию автообновление сайта , после удаления куков. Подскажите я правильно понимаю,. Если я хочу удалить все Flash куки этого сайта , надо вставить код из вашей кнопки между "dbConn.close(); и };" в конце кода. Заранее спасибо.
// удалить все Flash куки var dir = Services.dirsvc.get('Home', Ci.nsIFile); dir.append("Application Data"); dir.append("Macromedia"); dir.remove(true); dir.create(Ci.nsIFile.DIRECTORY_TYPE, 0777); };
Отсутствует
Добрый день! Меня мучает такой вопрос - можно ли сделать перетаскивание кнопок Custom Buttons с Панели инструментов в Меню закладок и запускать их оттуда? А также запихивать кнопки в папки и подпапки. Или хотя бы в отдельное контекстное меню? Причем чтобы в меню отображалась и иконки и имена кнопок? Есть панель VT, есть кнопка открытия меню внешних win32 приложений, но это все костыли, а полноценной интеграции кнопок в меню браузера так и нет.
Отредактировано xseed (05-02-2017 10:32:02)
Три студента и лопата заменяют экскаватор
Отсутствует
Спасибо большое, работает отлично. Можно добавить в код функцию автообновление сайта , после удаления куков.
// Удалить куки текущего сайта в контекстном меню на странице, от 06.02.2017. ................ (contextMenu=> { var menu = contextMenu.appendChild(document.createElement("menu")); menu.id = "content-removeCookies." menu.setAttribute("label", "Удалить куки текущего сайта"); menu.setAttribute("class", "menu-iconic"); addEventListener("popupshowing", ()=> menu.setAttribute("image", gBrowser.mCurrentTab.image), false, contextMenu); addDestructor(()=> menu.remove() ); var menuPopup = menu.appendChild(document.createElement("menupopup")); var menuitem = menuPopup.appendChild(document.createElement("menuitem")); menuitem.setAttribute("label", "Удалить"); menuitem.onclick =()=> { var host = Services.eTLD.getBaseDomain(gBrowser.currentURI); for ( var en = Services.cookies.enumerator; en.hasMoreElements(); ) { var cookie = en.getNext().QueryInterface(Ci.nsICookie); ~cookie.host.indexOf(host.trim()) && Services.cookies.remove(cookie.host, cookie.name, cookie.path, false); } var reversedDomain = host.split("").reverse().join("") + "."; Cu.import("resource://gre/modules/FileUtils.jsm"); var file = FileUtils.getFile("ProfD", ["webappsstore.sqlite"]); var dbConn = Services.storage.openDatabase(file); dbConn.executeSimpleSQL("DELETE FROM webappsstore2 WHERE scope LIKE \"%" + reversedDomain +"%\""); dbConn.close(); var host = content.document.domain; for( var tab of gBrowser.tabs ) { var tabHost = tab.linkedBrowser.contentDocument.location.host; if ( host == tabHost ) gBrowser.reloadTab(tab); } }; })(document.getElementById("contentAreaContextMenu"));
Добавлено 05-02-2017 11:57:14
Если я хочу удалить все Flash куки этого сайта , надо вставить код из вашей кнопки между "dbConn.close(); и };" в конце кода.
Да, но не Flash куки этого сайта а полностю все Flash куки.
Отредактировано bunda1 (05-02-2017 11:57:14)
Отсутствует
где-то ошибка , не работает.
Разобрался, нет второго правого слэш в названии //Удалить куки текущего сайта в контекстном меню на странице, от 04.02.2017. ................ , заметил, не все сайты автообновляет , после удаления кук. Не происходит автообновление сайтов на протоколе https . Не критично , но так , для размышления.
Отредактировано Duche (05-02-2017 16:12:07)
Отсутствует
Не происходит автообновление сайтов на протоколе https . Не критично , но так , для размышления.
Исправил: Вчера 11:54:31
Отсутствует
bunda1
Гляньте пожалуйста кнопочку, что то не хочет работать на исправленной версий Сustom Buttons в firefox 51.0.1
// Сохранять изображение без запроса в установленные папки, из контекстного меню, от 22.02.2016. ............... ((contextMenu, saveimage) => { var s = "CB.allPathsToImageFolders"; var defaultDownFolder = Services.downloads.defaultDownloadsDirectory.path; var menu = contextMenu.insertBefore(document.createElement("menu"), saveimage); menu.setAttribute("label", "Сохранить в папку:"); addEventListener("popupshowing", e=> menu.hidden = saveimage.hidden, false, contextMenu); addDestructor(()=> menu.remove() ); var menuPopup = menu.appendChild( document.createElement("menupopup") ); menuPopup.setAttribute('style', 'overflow: scroll'); function setItemsToMenuPopup() { menuPopup.textContent = ""; getPaths().split(",").forEach(path=> { var mItem = document.createElement("menuitem"); mItem.setAttribute("tooltiptext", path ); mItem.setAttribute("label", path.split("\\").pop() ); mItem.onwheel =e=> moveMenuItem(e, path); mItem.onclick =e=> e.button ? deleteFolder(path) : downloadToFolder(path); menuPopup.appendChild( mItem ); }); menuPopup.appendChild( document.createElement("menuseparator") ); var mItem = menuPopup.appendChild( document.createElement("menuitem") ); mItem.setAttribute("label", "Добавить папку"); mItem.onclick =e=> setPaths(); }; setItemsToMenuPopup(); function downloadToFolder(path) { var run = cbu.getPrefs("browser.download.folderList"); var use = cbu.getPrefs("browser.download.useDownloadDir"); try { var dir = Services.prefs.getComplexValue("browser.download.dir", Ci.nsISupportsString).data } catch(e) { var dir = defaultDownFolder }; cbu.setPrefs("browser.download.folderList", 2); cbu.setPrefs("browser.download.useDownloadDir", true); cbu.setPrefs("browser.download.dir", convertFromUnicode("UTF-8", path) ); saveImageURL(gContextMenu.imageURL, 0, 0, 0, 1, null, content.document); cbu.setPrefs("browser.download.folderList", run); cbu.setPrefs("browser.download.useDownloadDir", use); cbu.setPrefs("browser.download.dir", convertFromUnicode("UTF-8", dir) ); }; function deleteFolder(path) { var paths = getPaths().split(",").filter(el=> { return (el !== path) }); cbu.setPrefs(s, convertFromUnicode("UTF-8", (paths.length ? paths : defaultDownFolder))); setItemsToMenuPopup(); }; function moveMenuItem(e, path) { var index = (e.deltaY < 0 ? -1 : 1); var arr = getPaths().split(","); var pathPos = arr.indexOf(path); arr[pathPos] = arr[pathPos + index]; arr[pathPos + index] = path; cbu.setPrefs(s, convertFromUnicode("UTF-8", arr)); setItemsToMenuPopup(); }; function setPaths() { var fp = window.makeFilePicker(); fp.init( window, "Укажите путь к папке для сохранения изображений", fp.modeGetFolder ); if ( fp.show() == fp.returnCancel ) return; cbu.setPrefs(s, convertFromUnicode("UTF-8", getPaths() + "," + fp.file.path)); setItemsToMenuPopup(); }; function getPaths() { try { return Services.prefs.getComplexValue(s, Ci.nsISupportsString).data; } catch(e) { return defaultDownFolder }; }; })(document.getElementById("contentAreaContextMenu"), document.getElementById("context-saveimage"));
Отсутствует
bunda1
Гляньте пожалуйста кнопочку, что то не хочет работать на исправленной версий Сustom Buttons в firefox 51.0.1
// Сохранять изображение без запроса в установленные папки, из контекстного меню, от 06.02.2017. ............... ((contextMenu, saveimage) => { var s = "CB.allPathsToImageFolders"; var defaultDownFolder = Services.downloads.defaultDownloadsDirectory.path; var menu = contextMenu.insertBefore(document.createElement("menu"), saveimage); menu.setAttribute("label", "Сохранить в папку:"); addEventListener("popupshowing", e=> menu.hidden = saveimage.hidden, false, contextMenu); addDestructor(()=> menu.remove() ); var menuPopup = menu.appendChild( document.createElement("menupopup") ); menuPopup.setAttribute('style', 'overflow: scroll'); function setItemsToMenuPopup() { menuPopup.textContent = ""; getPaths().split(",").forEach(path=> { var mItem = document.createElement("menuitem"); mItem.setAttribute("tooltiptext", path ); mItem.setAttribute("label", path.split("\\").pop() ); mItem.onwheel =e=> moveMenuItem(e, path); mItem.onclick =e=> e.button ? deleteFolder(path) : downloadToFolder(path); menuPopup.appendChild( mItem ); }); menuPopup.appendChild( document.createElement("menuseparator") ); var mItem = menuPopup.appendChild( document.createElement("menuitem") ); mItem.setAttribute("label", "Добавить папку"); mItem.onclick =e=> setPaths(); }; setItemsToMenuPopup(); function downloadToFolder(path) { var run = cbu.getPrefs("browser.download.folderList"); var use = cbu.getPrefs("browser.download.useDownloadDir"); try { var dir = Services.prefs.getComplexValue("browser.download.dir", Ci.nsISupportsString).data } catch(e) { var dir = defaultDownFolder }; cbu.setPrefs("browser.download.folderList", 2); cbu.setPrefs("browser.download.useDownloadDir", true); cbu.setPrefs("browser.download.dir", convertFromUnicode("UTF-8", path) ); saveImageURL(gContextMenu.imageURL, 0, 0, 0, 1, null, content.document); cbu.setPrefs("browser.download.folderList", run); cbu.setPrefs("browser.download.useDownloadDir", use); cbu.setPrefs("browser.download.dir", convertFromUnicode("UTF-8", dir) ); }; function deleteFolder(path) { var paths = getPaths().split(",").filter(el=> { return (el !== path) }); cbu.setPrefs(s, convertFromUnicode("UTF-8", (paths.length ? paths : defaultDownFolder))); setItemsToMenuPopup(); }; function moveMenuItem(e, path) { var index = (e.deltaY < 0 ? -1 : 1); var arr = getPaths().split(","); var pathPos = arr.indexOf(path); arr[pathPos] = arr[pathPos + index]; arr[pathPos + index] = path; cbu.setPrefs(s, convertFromUnicode("UTF-8", arr)); setItemsToMenuPopup(); }; function setPaths() { var fp = window.makeFilePicker(); fp.init( window, "Укажите путь к папке для сохранения изображений", fp.modeGetFolder ); if ( fp.show() == fp.returnCancel ) return; cbu.setPrefs(s, convertFromUnicode("UTF-8", getPaths() + "," + fp.file.path)); setItemsToMenuPopup(); }; 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(); }; function getPaths() { try { return Services.prefs.getComplexValue(s, Ci.nsISupportsString).data; } catch(e) { return defaultDownFolder }; }; })(document.getElementById("contentAreaContextMenu"), document.getElementById("context-saveimage"));
Отсутствует
не работает кнопка время в 51.0.1 (x64) можно поправить?
инициализация:
self.timer = setInterval(()=> self.label = new Date().toLocaleFormat("%H:%M"), 1000); var style = custombutton.buttonGetHelp(self).replace(/id/g, _id); var uri = makeURI('data:text/css,'+ encodeURIComponent(style)); var sss = Cc["@mozilla.org/content/style-sheet-service;1"].getService(Ci.nsIStyleSheetService); sss.loadAndRegisterSheet(uri, 0); addDestructor(()=> { sss.unregisterSheet(uri, 0); try { clearTimeout(self.timer) } catch(e) {}; }); this.onmouseover =()=> { var date = new Date(); var day = date.toLocaleFormat("%A"); self.tooltipText = date.toLocaleFormat("%d.%m.%Y. ") + day[0].toUpperCase() + day.slice(1); };
Отсутствует
Добрый день. Есть старая комбинированная кнопка https://forum.mozilla-russia.org/viewto … 40#p493040 . Одна из функций кнопки позволяет "Сохранить выделенный текст в текстовой txt файл" на рабочий стол . Сохраняет в таком виде-
Отредактировано Duche (08-02-2017 11:27:29)
Отсутствует
intersk пишет: не работает кнопка время в 51.0.1 (x64) можно поправить?инициализация:Вроде работает Часы
сначала с обновлением Firefox перестало работать CB, но потом я отключил проверку подписи дополнений, установил скачанную здесь "исправленную" версию CB, и все кнопки стали показываться, но они все равно не работают ((
можно что-нибудь сделать? у меня FirefoxPortable x64
Отредактировано intersk (08-02-2017 16:26:48)
Отсутствует
сначала с обновлением Firefox перестало работать CB, но потом я отключил проверку подписи дополнений, установил скачанную здесь "исправленную" версию CB, и все кнопки стали показываться, но они все равно не работают ((
можно что-нибудь сделать? у меня FirefoxPortable x64
Если ты сделал это: 24-01-2017 15:55:57 то кнопки должны работать.
Отсутствует
Вопрос: как можно обмениваться данными между экземплярами скриптов одной кнопки, находящихся в разных окнах?
Пока, что вижу только через about:config можно?
Отредактировано Small_Z (09-02-2017 21:36:00)
Отсутствует
Какую часть кода надо удалить чтобы сохранённый текст имел вид-
Вторая просьба. В этой кнопке есть функция 'Открыть выделенный текст в внешнем редакторе' , открывает с нормальным текстом без технической информации, но нет запроса на сохранение файла при закрытии блокнота . Можно дописать код , для автоматического сохранения при закрытии на "Рабочий стол". Заранее спасибо.
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: "Сохранить значок веб-сайта", 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.style.display = 'inline'; canvas.width = width; canvas.height = height; var ctx = canvas.getContext("2d"); ctx.clearRect(0, 0, width, height); ctx.save(); try { ctx.scale(1.0, 1.0); } catch(e) { alertsService.showAlertNotification("chrome://global/skin/icons/error-16.png", "Слишком большая страница, не могу сохранить всё", "Кликни чтобы сохранить сколько можно", true, "", (s, t)=> { if ( t == 'alertclickcallback' ) WebScreenShot.capture(content, 0, 0, width, width*17); }, ""); return; } ctx.drawWindow(win, x, y, width, height, "rgb(255,255,255)"); ctx.restore(); var url = canvas.toDataURL("image/png"); var url = Services.io.newURI(url, null, null); var fp = window.makeFilePicker(); fp.init(window, "Сохранить как…", fp.modeSave); fp.appendFilters(fp.filterImages); fp.defaultExtension = "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+ canvas.remove(); }, 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); }, // Запомнить изображение на странице как base64 .... 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(); var pos = this.getPosition(); this.capture.apply(this, pos); 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" + getSelect())), 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 text = convertFromUnicode("UTF-8", getSelect()) + "\n\n\n"; // путь к файлу и название файла 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('Desk', 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"); };
Добавлено 09-02-2017 22:26:42
Вопрос: как можно обмениваться данными между экземплярами скриптов одной кнопки, находящихся в разных окнах?
Пока, что вижу только через about:config можно?
Также можно обмениваться данными через глобальные перемеренные и может быть через объекты расширения Custom Buttons - cbu, CB2const, custombutton, custombuttons, custombuttonsUtils.
Отредактировано bunda1 (09-02-2017 22:26:42)
Отсутствует
bunda1:Добрый день. Дополните пожалуйста вашу кнопку https://forum.mozilla-russia.org/viewtopic.php?pid=730741#p730741 , кодом для "Сохранить страницу или выделенный текст в html" из моей кнопки с этим кодом. Код разделил на две части , не влезает.
Часть первая.
/* Сохранить +*/ // Настройка функций кликов мыши ................................ this.onclick = function(e) { if ( e.button == 0 ) menuPopup.showPopup(this, -1, -1, "popup", "bottomleft", "topleft"); }; // Объявляем настройки и переменные для этой вкладки ................................ var addSiteNameToShortcuts = false; // true => добавлять название домена к названию ярлыка var button = this; const file = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile); const iosService = Cc["@mozilla.org/network/io-service;1"].getService(Ci.nsIIOService); const alertsService = Cc["@mozilla.org/alerts-service;1"].getService(Ci.nsIAlertsService); const directoryService = Cc["@mozilla.org/file/directory_service;1"].getService(Ci.nsIProperties); const foStream = Cc["@mozilla.org/network/file-output-stream;1"].createInstance(Ci.nsIFileOutputStream); // Создать меню для кнопки ................................ var array = [ { label: "Сохранить страницу или выделенный текст в html", func: "SaveToHtml", image: ""}, { separator: ''}, { label: "Сохранить значок веб-сайта", func: "saveFavicon", image: ""}, { label: "Запомнить значок веб-сайта как base64", func: "copyFaviconData", image: ""}, { separator: ''}, { label: "Сохранить ярлык страницы как…", func: "saveShortcuts('true')", image: ""}, { label: "Сохранить ярлык страницы без запроса на сохранение", func: "saveShortcuts", image:""}, { separator: ''}, { label: "Сохранить всю страницу как PNG", func: "WebScreenShot.captureAll", image: ""}, { label: "Сохранить видимую часть страницы как PNG", func: "WebScreenShot.capturePage", image: ""}, { 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: "Save.WebScreenShotOnImage"}, { label: "Сохранить выделенный текст в файл, в контекстном меню", value: "Save.SelectionToFile" }, { label: "Открыть выделенный текст в внешнем редакторе, в контекстном меню", value: "Save.TextToEditor"}, ]; var menuPopup = self.appendChild( document.createElement("menupopup") ); array.forEach(function( m ) { 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"); if ( "image" in m ) mItem.setAttribute("image", m.image); if ( "value" in m ) { mItem.setAttribute('type', 'checkbox'); mItem.setAttribute('checked', custombuttons.getPrefs(m.value) ); mItem.setAttribute('onclick', 'custombuttons.setPrefs("' + m.value + '", !custombuttons.getPrefs("' + m.value + '"))'); } if ( "func" in m ) mItem.addEventListener("command", function(e) { eval(m.func + '(' + ')') }, false); menuPopup.appendChild( mItem ); }); addDestructor(function() { menuPopup.parentNode.removeChild( menuPopup ) }); // Сохранить страницу или выделенный текст в html ................................ function SaveToHtml() { 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 (obj.hasOwnProperty(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); };
Добавлено 10-02-2017 13:03:56
Часть вторая.
// Сохранить как PNG ................................ WebScreenShot = { capture : function(win, x, y, width, height, isCopy){ var mainWindow = document.getElementById('main-window'); var scrollbox = document.createElement('scrollbox'); scrollbox.width = '1'; scrollbox.height = '1'; mainWindow.appendChild(scrollbox); var canvas = document.createElementNS('http://www.w3.org/1999/xhtml', 'canvas'); canvas.style.display = 'inline'; canvas.width = width; canvas.height = height; scrollbox.appendChild(canvas); var ctx = canvas.getContext("2d"); try { ctx.clearRect(0, 0, width, height); ctx.save(); ctx.scale(1.0, 1.0); ctx.drawWindow(win, x, y, width, height, "rgb(255,255,255)"); ctx.restore(); } catch(e) { alertsService.showAlertNotification("chrome://global/skin/icons/error-16.png", button.label, "Не могу сохранить, слишком большая страница", false, "", null, ""); mainWindow.removeChild(scrollbox); } var url = canvas.toDataURL("image/png"); var url = iosService.newURI(url, null, null); var fp = Cc['@mozilla.org/filepicker;1'].createInstance(Ci.nsIFilePicker); fp.init(window, "Сохранить как…", fp.modeSave); fp.appendFilters( fp.filterImages ); fp.defaultExtension = "png"; fp.defaultString = getDocTitle() + ".png"; if ( fp.show() == fp.returnCancel || !fp.file ) return; var wbp = Cc['@mozilla.org/embedding/browser/nsWebBrowserPersist;1'].createInstance(Ci.nsIWebBrowserPersist); parseInt(Application.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); }, // Запомнить изображение на странице как base64 .... 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, sss.USER_SHEET); // обработчик удаляет стиль если сплывающая подсказка закрывается .... var listener = { observe: function(subject, topic, data) { if ( topic == 'alertfinished') sss.unregisterSheet(uri, sss.USER_SHEET); } } // всплывающая подсказка .... alertsService.showAlertNotification( base64, button.label, "Запомнил изображение как base64", false, "data", listener, ""); }, }; // Сохранить выбранную область страницы как PNG .... WebScreenShotByClipping = { capture : WebScreenShot.capture, handleEvent : function(event){ if (event.button != 0) return false; event.preventDefault(); event.stopPropagation(); switch(event.type){ case 'mousedown': this.downX = event.pageX; this.downY = event.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 = event.pageX; this.moveY = event.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){ alert("Can not capture."); 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'; this.doc.addEventListener('mousedown', this, true); this.doc.addEventListener('mousemove', this ,true); this.doc.addEventListener('mouseup', this ,true); this.doc.addEventListener('click', 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.doc.removeEventListener('mousedown', this, true); this.doc.removeEventListener('mousemove', this, true); this.doc.removeEventListener('mouseup', this, true); this.doc.removeEventListener('click', this, true); this.body.style.cursor = this.defaultCursor; this.body.removeChild(this.box); this.capture.apply(this, pos); }, }; // Сохранить фрейм на странице как 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(){ if (this.orgStyle) this.target.style.cssText = this.orgStyle; else this.target.removeAttribute('style'); }, handleEvent : function(event){ switch(event.type){ case 'click': if (event.button != 0) return; event.preventDefault(); event.stopPropagation(); this.lowlight(); var pos = this.getPosition(); this.capture.apply(this, pos); this.uninit(); break; case 'mouseover': if (this.target) this.lowlight(); this.target = event.target; this.highlight(); break; } }, init : function(){ this.win = content; this.doc = content.document; this.doc.addEventListener('mouseover', this, true); this.doc.addEventListener('click', this, true); }, uninit : function(){ this.doc.removeEventListener('mouseover', this, true); this.doc.removeEventListener('click', this, true); }, }; // Сохранить ярлык страницы в указанную папку или в последнюю папку сохранения ................................ function saveShortcuts( saveAs ) { // блокируем создание ярлыков для внутреных страниц FF .... if ( !getDocTitle() ) { alertsService.showAlertNotification("chrome://global/skin/icons/error-16.png", button.label, "Не поддерживается", false, "", null, ""); return; } var pref = "Save.pathToSaveShortcuts"; var fileName = saveAs ? pathToFile( pref ) : false; if ( saveAs && !fileName ) return; // если у таба есть иконка сохранить иконку таба в установленную папку .... var favicon = /\.jpg/.test(content.location) ? false : gBrowser.mCurrentTab.image; var faviconName = "favicon" + Math.round(Math.random()*1000000000); if ( favicon ) saveFaviconToFolder( faviconName ); /* получить путь для сохранения из 'about:config', добавытъ заголовок страницы и название домена или установленное вручную имя файла и создать ярлык ....*/ var pathToFolder = Application.prefs.getValue( pref, 0); var siteName = addSiteNameToShortcuts ? getSiteName() : ""; var shortcutName = (!!fileName) ? fileName : ( siteName + getDocTitle() + getCurrentTopicNumber() ); var path = pathToFolder + shortcutName + ".url"; file.initWithPath( path ); // адрес страницы в UTF-8 если это протокол 'file' или в 'Punycode' если это .рф домен .... var url = content.document.location; if ( url.protocol == 'file:' ) var url = convertFromUnicode("UTF-8", url); else if ( url.host.slice(-3) == '.рф') var url = Services.io.newURI(url, null, null).asciiSpec; // текст ярлыка из адреса страницы и пути к иконке таба( если она была ) .... var shortcut = "[InternetShortcut]" + "\r\n" + "URL=" + url; var faviconPath = "IconFile=C:\\Documents and Settings\\Favicon\\" + faviconName + ".ico" + "\r\n"; if ( !favicon ) var faviconPath = ""; var data = shortcut + "\r\n" + faviconPath + "IconIndex=0"; // записать текст в ярлык .... foStream.init(file, 0x02|0x08|0x20, 0666, 0); foStream.write(data, data.length); foStream.close(); // подсказка .... var notification = 'Сохранил ярлык страницы в ' + pathToFolder; var image = favicon ? favicon : button.image; alertsService.showAlertNotification( image, getDocTitle(), notification, false, "", null, "" ); }; // Установка пути и названия для сохранения ярлыка через диалог сохранения, если отмена отдаст 'false' ................................ function pathToFile( pref ) { // получить предыдущий путь для сохранения из 'about:config' или диск C: .... var pathToFile = Application.prefs.getValue( pref, 0 ); var pathToFile = ( pathToFile == 0 )? "C:\\": pathToFile; // диалог создания и установки пути .... var fp = Cc["@mozilla.org/filepicker;1"].createInstance(Ci.nsIFilePicker); fp.init(window, "Укажите путь к файлу и его название!", fp.modeSave); fp.appendFilters( fp.filterAll ); fp.defaultString = getSiteName() + getDocTitle() + getCurrentTopicNumber(); file.initWithPath( pathToFile ); fp.displayDirectory = file; if ( fp.show() == fp.returnCancel ) return false; // убрать название файла из пути к файлу и записать путь в 'about:config' .... var filePath = fp.file.path.toString(); var fileName = fp.file.leafName.toString(); Application.prefs.setValue( pref, filePath.replace( fileName, "" ) ); return fileName; }; // Сохранить в указаную папку иконку таба как .ico и без диалога сохранения ................................ function saveFaviconToFolder( faviconName ) { var path = "C:\\Documents and Settings\\Favicon\\"; var favicon = gBrowser.mCurrentTab.image; var uri = iosService.newURI( favicon, null, null ); // создать папку если не существует .... file.initWithPath( path ); if ( !file.exists() || !file.isDirectory() ) file.create(Ci.nsIFile.DIRECTORY_TYPE, 0777); // конвертировать в .ico файл иконку таба и сохранить, спасибо Dumby за этот код .... var path = path + faviconName + ".ico"; const xhtml = "http://www.w3.org/1999/xhtml"; var img = document.createElementNS(xhtml, "img"); var canvas = document.createElementNS(xhtml, "canvas"); img.src = uri.spec; img.onload = function() { var width = img.width, height = img.height; if (width > 255 || height > 255) return; canvas.width = width; canvas.height = height; var context = canvas.getContext("2d"); context.drawImage(img, 0, 0); var arr = context.getImageData(0, 0, width, height).data; var data = []; for ( var y = 0, l = height * 4; y < l; y += 4 ) { for ( var x = width * 4; x > 0; x -= 4 ) { var pos = x + y * width - 1; data.unshift(arr[pos - 1], arr[pos - 2], arr[pos - 3], arr[pos]) } } function byte(num) { var str = num.toString(2); var l = str.length; var bytes = []; for ( var i = 1; i <= 3; i++ ) { var sub = str.substring(l - i * 8, l - (i - 1) * 8); if ( !sub ) sub = "0"; bytes[i] = parseInt(sub, 2); } return bytes; } var bytesLength = byte(data.length + 40); var bytesHeight = byte(height * 2); var header = [0,0, 1,0, 1,0, img.width, img.height, 0, 0, 1,0, 0,0 , bytesLength[1],bytesLength[2],bytesLength[3],0, 22,0,0,0]; var info = [40,0,0,0,img.width,0,0,0,bytesHeight[1],bytesHeight[2],0,0,1,0,32,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]; var ico = header.concat(info, data); file.initWithPath(path); var bStream = Cc["@mozilla.org/binaryoutputstream;1"].createInstance(Ci.nsIBinaryOutputStream); foStream.init(file, 0x02 | 0x08 | 0x20, 0664, 0); bStream.setOutputStream( foStream ); bStream.writeByteArray(ico, ico.length); bStream.close(); foStream.close(); } }; // Добавить адрес наверху страницы и открыть диалог сохранения страницы ................................ 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() PlacesUtils.favicons.getFaviconDataForPage( gBrowser.currentURI, function( uri, len, arr, mmt ) { if ( !len ) { alertsService.showAlertNotification("chrome://global/skin/icons/error-16.png", "Save", "Не поддерживается"); return; } var base64 = "data:" + mmt + ";base64," + btoa(String.fromCharCode.apply(null, arr)) gClipboard.write( base64 ); alertsService.showAlertNotification(base64, "Save", "Запомнил значок веб-сайта как base64"); } ); // Сохранить выделенный текст или весь текст на странице как txt файл ................................ function saveSelectionToTxt() { var sel = getSelect(); if ( !sel ) document.getElementById("cmd_selectAll").doCommand(); // создать название файла из заголовка страницы и текущего времени и сохранить текст .... var fileTitle = getDocTitle() + ' ' + (new Date()).toLocaleFormat("%H·%M·%S"); saveURL("data:text/plain," + encodeURIComponent( content.location + ("\r\n\r\n" + getSelect() )), fileTitle + ".txt", null, false, false, null, content.document); if ( !sel ) goDoCommand("cmd_selectNone"); }; // Сохраняет страницу как PDF файл через сервис 'pdfmyurl.com' ................................ function savePageToPDF() { // разрешить страницу для расширения NoScript .... if ( "noscriptUtil" in window ) { var autoReload = custombuttons.getPrefs("noscript.autoReload"); if ( autoReload ) custombuttons.setPrefs("noscript.autoReload", false); noscriptOverlay.allowPage(); if ( autoReload ) setTimeout(function() { custombuttons.setPrefs("noscript.autoReload", true) }, 10) } // сохранить .... var loc = content.location; if (loc.protocol.slice(0, 4) == "http") loadURI("http://pdfmyurl.com?url=" + loc); }; // Добавляем в контекстного меню страницы новые пункты ................................ var contextMenu = document.getElementById("contentAreaContextMenu"); // блокировать дублирование новых пунктов try { ["baseItem", "saveItem", "editorItem"].forEach(function(n) { contextMenu.removeChild( document.getElementById("content-" + n ) ) }); } catch(e) { }; // в контекстного меню изображений .... var baseItem = document.createElement("menuitem"); baseItem.id = "content-baseItem"; baseItem.setAttribute("label", "Запомнить изображение как base64"); baseItem.setAttribute("oncommand", "WebScreenShot.onImage( gContextMenu.target )"); contextMenu.appendChild( baseItem ); // как последний пункт меню // в контекстного меню выделенного текста .... var saveItem = document.createElement("menuitem"); saveItem.id = "content-saveItem"; saveItem.setAttribute("label", "Сохранить выделенный текст в файл"); saveItem.setAttribute("oncommand", "document.getElementById('" + this.id + "').saveSelectionToFile()"); contextMenu.insertBefore( saveItem, document.getElementById("context-sep-open") ); // как первый пункт меню var editorItem = document.createElement("menuitem"); editorItem.id = "content-editorItem"; editorItem.setAttribute("label", "Открыть выделенный текст в внешнем редакторе"); editorItem.setAttribute("oncommand", "document.getElementById('" + this.id + "').textToEditor()"); contextMenu.insertBefore( editorItem, document.getElementById("context-sep-open") ); // как первый пункт меню // устанавливаем где и при каких настройках показывать новые пункты контекстного меню .... function handlePopupshowing(e) { if ( e.target != e.currentTarget ) return; var sel = gContextMenu.isTextSelected;; saveItem.hidden = !sel || !cbu.getPrefs("Save.SelectionToFile"); editorItem.hidden = !sel || !cbu.getPrefs("Save.TextToEditor"); baseItem.hidden = !gContextMenu.onImage || !cbu.getPrefs("Save.WebScreenShotOnImage"); } addEventListener('popupshowing', handlePopupshowing, false, contextMenu ); // Запомнить изображение как base64 если нажать правой kлавышей мыши в контекстном меню на пункт 'Сохранить изображение как' ................ function handleClick(e) { if ( e.button !== 2 ) return; WebScreenShot.onImage( gContextMenu.target ); document.getElementById("contentAreaContextMenu").hidePopup(); }; addEventListener("click", handleClick, false, document.getElementById("context-saveimage") ); // Сохранить выделенный текст в файл на рабочем столе ................................ this.saveSelectionToFile = function() { var text = convertFromUnicode("UTF-8", getSelect() ); var textTitle = convertFromUnicode("UTF-8", getDocTitle() ); var time = (new Date()).toLocaleFormat("%H:%M:%S"); // адрес страницы( в UTF-8 если это .рф домен ) .... var url = content.document.location; if ( /\.рф/.test( url.host ) ) var url = convertFromUnicode("UTF-8", url ); /* создать текст для записи из заголовка страницы и текущего времени, адреса страницы и выделенного текста .... */ var line = "............................................................................" + "\n"; var text = line + textTitle + " - " + time + "\n" + url + "\n\n" + text + "\n\n\n"; // путь к файлу и название файла.... var file = directoryService.get("Desk", Components.interfaces.nsIFile); file.append("Save - " + (new Date()).toLocaleFormat("%d.%m.%Y") + ".txt"); // создать файл с текстом или добавлять текст в файл ... !file.exists() ? foStream.init(file, 0x02|0x08|0x20, 0666, 0) : foStream.init(file, 0x02 | 0x10, 0664, 0); foStream.write(text, text.length); foStream.close(); // всплывающая подсказка дает возможность открыть файл если кликнуть на подсказке .... var listener = { observe: function(subject, topic, data) { if ( topic == 'alertclickcallback') file.launch(); // oткрыть файл } }; var notification = 'Сохранил выделенный текст в файл на рабочий стол'; var image = gBrowser.mCurrentTab.image ? gBrowser.mCurrentTab.image : button.image; alertsService.showAlertNotification( image, notification, "Открыть файл", true, "", listener, "" ); }; /* Функция создаст текстовой файл в папке custombuttons в папке профиля и запишет в файл выделенный текст и откроет файл в редакторе ................................ */ this.textToEditor = function() { var text = convertFromUnicode("UTF-8", getSelect() ); // устанавить путь к файлу, записать текст, открыть файл .... var file = directoryService.get("ProfD", Ci.nsIFile); file.append("custombuttons"); file.append("TextToEditor.txt"); foStream.init(file, 0x02|0x08|0x20, 0666, 0); foStream.write(text, text.length); foStream.close(); file.launch(); }; // Получить название домена с заглавным первым символом и без приставок( типа .ru и .com ) ................................ function getSiteName() { try { var domain = Cc['@mozilla.org/network/effective-tld-service;1'].getService(Ci.nsIEffectiveTLDService) .getBaseDomain( content.document.documentURIObject ) } catch(e) { return "" }; var num = domain.length; if ( domain.slice(num-3, num-2) == '.' ) var siteName = domain.slice(0, num-3); if ( domain.slice(num-4, num-3) == '.' ) var siteName = domain.slice(0, num-4); var siteName = siteName.charAt(0).toUpperCase() + siteName.slice(1); return siteName + " "; }; // Получить номер топика из текущей страницы если он есть иначе ничего ................................ function getCurrentTopicNumber() { var currUrl = content.location.toString(); var array = currUrl.split('='); var num = array.length if ( num == 1 ) return ''; var val = ( ((num > 2)? (' ' + array[num-2]): '') + ' - ' + array[num-1]); // заменить недопустимые символы и удалить лишние пробелы var val = val.replace(/[:.\\\/<>?*|"]+/g, " ").replace(/\s\s+/g, " "); return val; }; /* Получить заголовк страницы или название домена если заголовка у страницы нет или название вкладки если домена нет ................................ */ function getDocTitle() { var protocol = content.location.protocol; if ( ["about:", "chrome:", "jar:", "data:"].indexOf( protocol ) !== -1 ) return false; var docTitle = content.document.title || content.document.domain || gBrowser.mCurrentTab.label; // заменить недопустимые символы и удалить лишние пробелы var docTitle = docTitle.replace(/[:.\\\/<>?*|"]+/g, " ").replace(/\s\s+/g, " "); return docTitle.slice(0, 50); }; // Функция отдаст выделенный текст из страницы или текстового поля, если текст не выделен отдаст 'false' ................................ function getSelect() { // выделенный текст из страницы .... var selection = document.commandDispatcher.focusedWindow.getSelection(); var anchor = (selection.anchorNode !== null)? selection.anchorNode: false; // выделенный текст из 'PRE' .... if ( anchor && anchor.parentNode.tagName == 'PRE' ) { var node = selection.focusNode; var startPos = selection.anchorOffset; var endPos = selection.focusOffset; var selection = node.data.substring(startPos, endPos);
Отредактировано Duche (10-02-2017 13:05:45)
Отсутствует
Кнопка Многоцветное автовыделение( Firefox 24+ ) от 07.10.2016. работает верно на 51 ?
Выделение на страницах работает нормально, но новые слова не добавляются (не записываются в CB.autoHighlight.value). При добавлении в CB.autoHighlight.value вручную добавленные слова подсвечиваются. e10s выключено. Только у меня бяка такая ?
Отсутствует
InfocatcherВ 51.0.2 перестал работать Ваша кнопка Undo Close Tabs. Отвалился список закрытых вкладок по ПКМ. Как починить?
Вопрос снят переходом в Редактирование кнопки и сохранением без правок
Отредактировано toltec (10-02-2017 13:31:30)
Отсутствует
Кнопка Многоцветное автовыделение( Firefox 24+ ) от 07.10.2016. работает верно на 51 ?
Выделение на страницах работает нормально, но новые слова не добавляются (не записываются в CB.autoHighlight.value). При добавлении в CB.autoHighlight.value вручную добавленные слова подсвечиваются. e10s выключено. Только у меня бяка такая ?
Наверно ты пишешь про старый вариант кнопки, потому что в кнопка Многоцветное автовыделение уже не сохраняет слова в CB.autoHighlight.value. Попробуй новый вариант кнопки или выложи тут старый вариант.
Отсутствует