Несколько вопросов:
Как открыть некий код из буфера/страницы или из файла в scratchpad?
Как выполнить некий код при закрытии вкладки scratchpad'a (и вообще вкладки)? С окном выходит, а с вкладкой - никак. onbeforeunload не работает на вкладках?
Отсутствует
Несколько вопросов
Вопросы неподробны (непонятны). Может нажми
var некий_код_из_буфера$траницы_или_из_файла = "некий код из буфера/страницы или из файла"; var некий_код_при_закрытии_вкладки_scratchpada_и_вообще_вкладки = br => alert(` Вкладка будет закрыта ${br.currentURI.spec} `); var url = "chrome://devtools/content/scratchpad/scratchpad.xul"; var tab = gBrowser.selectedTab = gBrowser.addTab(url), br = tab.linkedBrowser; var onPageShow = e => { var win = e.target.defaultView, {top} = win; if (top.location.href == url && win.location.href.startsWith("data:")) { //br.removeEventListener("pageshow", onPageShow, false); top.Scratchpad.setText(некий_код_из_буфера$траницы_или_из_файла); } } br.addEventListener("pageshow", onPageShow, false); tab.addEventListener("TabClose", function TabClose(e) { tab.removeEventListener("TabClose", TabClose, false); br.removeEventListener("pageshow", onPageShow, false); некий_код_при_закрытии_вкладки_scratchpada_и_вообще_вкладки(br); }, false);
Отсутствует
bunda1 пишетБлокнот в вкладке( Firefox24+ ) от 27.06.2016.
а шрифт текста можно изменить? как, если можно
В вкладке Справка под:
положи
тут Безопасные шрифтовые CSS стеки для рунета можно взять список шрифтов.
Отсутствует
а можно готовый код Save + с изменением? пытался сам - кнопка не работает
// Save+, от 13.09.2016. ............. // Настройка функций кликов мыши ............. this._handleClick =()=> menuPopup.showPopup(this, -1, -1, "popup", "bottomleft", "topleft"); // Объявляем настройки и переменные для этой вкладки ............. var addSiteNameToShortcuts = false; // true => добавлять название домена к названию ярлыка var file = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile); var alertsService = Cc["@mozilla.org/alerts-service;1"].getService(Ci.nsIAlertsService); var foStream = Cc["@mozilla.org/network/file-output-stream;1"].createInstance(Ci.nsIFileOutputStream); // Создать меню для кнопки ............. 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, 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(xhtmlns, '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", self.label, "Не могу сохранить, слишком большая страница"); mainWindow.removeChild(scrollbox); } 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 = getDocTitle() + ".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); }, // Запомнить изображение на странице как 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", true, "", (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){ alert("Не удается захватить!"); 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(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; this.doc.addEventListener('mouseover', this, true); this.doc.addEventListener('click', this, true); }, uninit: function() { this.target = false; this.doc.removeEventListener('mouseover', this, true); this.doc.removeEventListener('click', this, true); }, }; // Сохранить страницу как PDF файл через сервис 'pdfmyurl.com' ............. function savePageToPDF(loc = content.location) { loc.href.startsWith("http") && loadURI("http://pdfmyurl.com?url=" + loc); }; // Сохранить ярлык страницы в указанную папку или в последнюю папку сохранения ............. function saveShortcuts( saveAs ) { // блокируем создание ярлыков для внутреных страниц FF .... if ( !getDocTitle() ) { alertsService.showAlertNotification("chrome://global/skin/icons/error-16.png", self.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 = gPrefService.getComplexValue(pref, Ci.nsISupportsString).data; 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 : self.image; alertsService.showAlertNotification( image, getDocTitle(), notification, false, "", null, "" ); }; // Установка пути и названия для сохранения ярлыка через диалог сохранения, если отмена отдаст 'false' ............. function pathToFile( pref ) { // получить предыдущий путь для сохранения из 'about:config' или диск C: .... try { var pathToFile = gPrefService.getComplexValue(pref, Ci.nsISupportsString).data } catch(e) { var pathToFile = "C:\\" }; // диалог создания и установки пути .... 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(); cbu.setPrefs(pref, convertFromUnicode("UTF-8", filePath.replace(fileName, "")) ); return fileName; }; // Сохранить в указаную папку иконку таба как .ico и без диалога сохранения ............. function saveFaviconToFolder( faviconName ) { var path = "C:\\Documents and Settings\\Favicon\\"; var favicon = gBrowser.mCurrentTab.image; var uri = Services.io.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() { 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 = (getDocTitle() ? getDocTitle() : 'Save+') + ' ' + (new Date()).toLocaleFormat("%H·%M·%S"); saveURL("data:text/plain," + encodeURIComponent((content.location.href.startsWith('http') ? (content.location.href + "\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")); // ПКМ на пункте 'Сохранить изображение как' в контекстном меню запомнинает изображение как base64 ................ document.getElementById("context-saveimage").onclick =e=> { if ( e.button !== 2 ) return; WebScreenShot.onImage(gContextMenu.target); document.getElementById("contentAreaContextMenu").hidePopup(); }; // Сохранить выделенный текст в файл на рабочем столе ............. function saveSelectionToFile() { 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 )) url = convertFromUnicode("UTF-8", url); // создать текст для записи .... var line = "............................................................................" + "\n"; var text = line + textTitle + " - " + time + "\n" + url + "\n\n" + text + "\n\n\n"; // путь к файлу и название файла .... var file = Services.dirsvc.get("Desk", Ci.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 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(); }; // Получить название домена с заглавным первым символом и без приставок( типа .ru и .com ) ............. function getSiteName() { try { var domain = Services.eTLD.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]); return val.replace(/[:.\\\/<>?*|"]+/g, " ").replace(/\s\s+/g, " "); }; /* Получить заголовк страницы или название домена если заголовка у страницы нет или название вкладки если домена нет ............. */ 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 sel = document.commandDispatcher.focusedWindow.getSelection(); // из страницы if (sel == '') { // из текстового поля var theBox = document.commandDispatcher.focusedElement; if (theBox && (theBox.type == "text" || theBox.type == "textarea")) { var startPos = theBox.selectionStart; var endPos = theBox.selectionEnd; var sel = theBox.value.substring(startPos, endPos); } } if (sel.anchorNode && sel.anchorNode.parentNode.localName == 'pre') { // из 'PRE' .... var node = sel.focusNode; var startPos = sel.anchorOffset; var endPos = sel.focusOffset; var sel = node.data.substring(startPos, endPos); } // удалить лишние пробелы и исправыть проблему с переносом текста var sel = sel.toString().replace(/^\s+|\s+$/g,""); var sel = sel.replace(/\u000A/g, "\u000D\u000A").replace(/\u000D\u000D\u000A/g, "\u000D\u000A"); return (sel == '') ? false : sel; };
Отсутствует
Dumby
Это совсем не важно, но так, если не лень будет, для общего моего развития:
var getLinks = { Links: [], get windows() { return (function*() { var ws = Services.wm.getEnumerator("navigator:browser"); while(ws.hasMoreElements()) yield ws.getNext(); })(); }, get links() { for(var w of this.windows) for(var {contentWindow: win} of w.gBrowser.browsers) { var Tabs = {}, host = win.content.document.location.origin; // window.console.log(win); // Tabs = Object.create(Object.prototype, { // title: {writable: true, configurable: true, value: win.content.document.title}, // srcEls: {writable: true, configurable: false, value: {}} // }); Tabs = {Tab: {title: win.content.document.title, srcEls: []}}; // Object.assign(Tabs.srcEls, {SrcEl: {link: 'bla'}}); for (var {localName: node, src: src, href: href, type: type} of win.content.document.querySelectorAll(':-moz-any([href],[src])')) { var link = (src || href), link = /^(\w+)?:\/\//.test(link) ? link : host + link; Tabs.Tab.srcEls.push({link,node,type}) } this.Links.push(Tabs) } return this.Links; } } window.console.log(getLinks.links);
Я постараюсь, объяснить, что требуется, чтоб без "некий_код" обойтись, но не уверен, что смогу. Так как до сих пор нихрена теорию не учу и не знаю правильную терминологию:
В общем, этот выкидыш родился из этого поста. Нужно получить массив со ссылками по вкладкам. Сортировку по типу я пока не трогал, мне бы с этим разобраться. Проблема - что все объекты только для текущей вкладки создаются. И что-то я залип. Смутно свербит, где тут собака порылась, но никак.
И еще вопрос: ни /^(\w+)?:\/\//.test(link), ни !!link.match(/^(\w+)?:\/\//) в коде - упорно не хотят признавать ссылки вида /example.com/, хотя в консоли работает.
Ну и вообще, для этого самого развития: как тут красивее и правильнее сделать?
Отсутствует
intersk
У меня нормально "горит" . Может не весь предыдущий код удалился, или новый не весь скопировался, попробуй ещё раз.
можете тогда свой код в текстовом файле отправить, может копируется как-то не правильно...
Добавлено 14-09-2016 14:25:30
разобрался - Firefox некорректно копировал код. Пришлось открыть страницу в Хроме, оттуда уже скопировать и вставить в кнопку.
Стоит плагин "Copy Plain Text" наверно из-за него
Windows 64bit
Отредактировано intersk (14-09-2016 14:27:43)
Отсутствует
Можно как-нибудь скрестить эти 2 кода (или новый код)? Чтобы сначала при закрытии текущей вкладки переключаться на правую вкладку, а когда вкладки справа заканчиваются, то на левую.
// Переключаться на правую вкладку после закрытии текущей вкладки, от 22.08.2013. ................................ function tabCloseHandler(e) { var tab = e.target; if ( tab == gBrowser.mCurrentTab ) { if ( !gBrowser.visibleTabs.length ) gBrowser.addTab("about:blank"); else if ( !tab.hasAttribute('first-visible-tab') ) { gBrowser.mTabContainer.advanceSelectedTab(+1,true) }; } } addEventListener("TabClose", tabCloseHandler, true, gBrowser.tabContainer );
// Переключаться на левую вкладку после закрытии текущей вкладки, от 22.08.2013. ................................ function tabCloseHandler(e) { var tab = e.target; if ( tab == gBrowser.mCurrentTab ) { if ( !gBrowser.visibleTabs.length ) gBrowser.addTab("about:blank"); else if ( !tab.hasAttribute('first-visible-tab') ) { gBrowser.mTabContainer.advanceSelectedTab(-1,true) }; } } addEventListener("TabClose", tabCloseHandler, true, gBrowser.tabContainer );
Отсутствует
Ребята, если возможно, пожалуйста сделайте кнопку копирования текста без запрещенных символов.
Например выделив текст в котором есть запрещенные символы для имени файла windows (\:*?"< и т.д.) при нажатии кнопки он копировался без указанных символов.
Отредактировано Stakhovsky (14-09-2016 17:38:35)
Отсутствует
Ребята, если возможно, пожалуйста сделайте кнопку копирования текста без запрещенных символов.
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.toString().replace(/^\s+|\s+$/g,""); }; gClipboard.write( getSelect().replace(/[:+.\\\/<>?*|"]+/g, " ") );
Отсутствует
Stakhovsky
Пока возился, уже опередили. Но вот готовая, с пунктом в контекстном меню:
((menu, elm, menuitem) => { menuitem.id = "cb-copy-convert"; menuitem.setAttribute("label", "Копировать без запрещенных символов"); elm.parentNode.insertBefore(menuitem, elm); var convert = str => { var chr = { '\\': '\', '/': '/', ':': ':', '*': '*', '?': '?', '"': '"', '<': '<', '>': '>', '|': '|', '+': '+' }; if (!!str) return str.replace(/[\\\/:*?"<>|+]/g, s => chr[s]); } function getSelect() { var el = document.commandDispatcher.focusedElement; try { return el.value.substring(el.selectionStart, el.selectionEnd) } catch(e) {}; var sel = document.commandDispatcher.focusedWindow.getSelection(); if (!!sel) return sel.toString().trim(); }; menuitem.onclick = e => { if (gContextMenu.onLink) { if (e.button == 2) gClipboard.write(convert(gContextMenu.linkTextStr)); else gClipboard.write(convert(gContextMenu.linkURL)); } else gClipboard.write(convert(getSelect())); } // this._handleClick = () => gClipboard.write(convert(gClipboard.read())); menu.addEventListener('popupshowing', function f() menuitem.hidden = !(gContextMenu.onLink || gContextMenu.isTextSelected)); addDestructor(()=> { menu.removeChild(menuitem); menu.removeEventListener("popupshowing", f) }) })(document.getElementById("contentAreaContextMenu"), document.getElementById("context-copy"), document.createElement("menuitem"));
Отсутствует
Stakhovsky
Ух, у меня там в коде позаменялись html-спецсимволы при публикации. По идее, это баг движка форума. Не должны в теге "код" заменятся. Может так не потрет:
custombutton://%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%0D%0A%3Ccustombutton%20xmlns%3Acb%3D%22http%3A//xsms.nm.ru/custombuttons/%22%3E%0A%20%20%3Cname/%3E%0A%20%20%3Cimage%3E%3C%21%5BCDATA%5Bcustombuttons-stdicon-1%5D%5D%3E%3C/image%3E%0A%20%20%3Cmode%3E0%3C/mode%3E%0A%20%20%3Cinitcode%3E%3C%21%5BCDATA%5B%28%28menu%2C%20elm%2C%20menuitem%29%20%3D%3E%20%7B%0A%20%20%20%20menuitem.id%20%3D%20%22cb-copy-convert%22%3B%0A%20%20%20%20menuitem.setAttribute%28%22label%22%2C%20%22%u041A%u043E%u043F%u0438%u0440%u043E%u0432%u0430%u0442%u044C%20%u0431%u0435%u0437%20%u0437%u0430%u043F%u0440%u0435%u0449%u0435%u043D%u043D%u044B%u0445%20%u0441%u0438%u043C%u0432%u043E%u043B%u043E%u0432%22%29%3B%0A%20%20%20%20elm.parentNode.insertBefore%28menuitem%2C%20elm%29%3B%0A%0A%20%20%20%20var%20convert%20%3D%20str%20%3D%3E%20%7B%0A%20%20%20%20%20%20%20%20var%20chr%20%3D%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20%27%5C%5C%27%3A%20%27%26%2392%3B%27%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%27/%27%3A%20%27%26%2347%3B%27%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%27%3A%27%3A%20%27%26%2358%3B%27%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%27*%27%3A%20%27%26%2342%3B%27%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%27%3F%27%3A%20%27%26%2363%3B%27%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%27%22%27%3A%20%27%26%2334%3B%27%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%27%3C%27%3A%20%27%26%2360%3B%27%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%27%3E%27%3A%20%27%26%2362%3B%27%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%27%7C%27%3A%20%27%26%23124%3B%27%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%27+%27%3A%20%27%26%2343%3B%27%0A%20%20%20%20%20%20%20%20%7D%3B%0A%0A%20%20%20%20%20%20%20%20if%20%28%21%21str%29%0A%20%20%20%20%20%20%20%20%20%20%20%20return%20str.replace%28/%5B%5C%5C%5C/%3A*%3F%22%3C%3E%7C+%5D/g%2C%20s%20%3D%3E%20chr%5Bs%5D%29%3B%0A%20%20%20%20%7D%0A%0A%20%20%20%20function%20getSelect%28%29%20%7B%0A%20%20%20%20%20%20%20%20var%20el%20%3D%20document.commandDispatcher.focusedElement%3B%0A%20%20%20%20%20%20%20%20try%20%7B%20return%20el.value.substring%28el.selectionStart%2C%20el.selectionEnd%29%20%7D%20catch%28e%29%20%7B%7D%3B%0A%20%20%20%20%20%20%20%20var%20sel%20%3D%20document.commandDispatcher.focusedWindow.getSelection%28%29%3B%0A%20%20%20%20%20%20%20%20if%20%28%21%21sel%29%0A%20%20%20%20%20%20%20%20%20%20%20%20return%20sel.toString%28%29.trim%28%29%3B%0A%20%20%20%20%7D%3B%0A%0A%20%20%20%20menuitem.onclick%20%3D%20e%20%3D%3E%20%7B%0A%20%20%20%20%20%20%20%20if%20%28gContextMenu.onLink%29%20%7B%0A%20%20%20%20%20%20%20%20%20%20%20%20if%20%28e.button%20%3D%3D%202%29%20gClipboard.write%28convert%28gContextMenu.linkTextStr%29%29%3B%0A%20%20%20%20%20%20%20%20%20%20%20%20else%20gClipboard.write%28convert%28gContextMenu.linkURL%29%29%3B%0A%20%20%20%20%20%20%20%20%7D%0A%20%20%20%20%20%20%20%20else%20gClipboard.write%28convert%28getSelect%28%29%29%29%3B%0A%20%20%20%20%7D%0A%0A%20%20%20%20this._handleClick%20%3D%20%28%29%20%3D%3E%20gClipboard.write%28convert%28gClipboard.read%28%29%29%29%3B%0A%0A%20%20%20%20menu.addEventListener%28%27popupshowing%27%2C%20function%20f%28%29%20menuitem.hidden%20%3D%20%21%28gContextMenu.onLink%20%7C%7C%20gContextMenu.isTextSelected%29%29%3B%0A%20%20%20%20addDestructor%28%28%29%3D%3E%20%7B%0A%20%20%20%20%20%20%20%20menu.removeChild%28menuitem%29%3B%0A%20%20%20%20%20%20%20%20menu.removeEventListener%28%22popupshowing%22%2C%20f%29%0A%20%20%20%20%7D%29%0A%7D%29%28document.getElementById%28%22contentAreaContextMenu%22%29%2C%0A%20%20%20document.getElementById%28%22context-copy%22%29%2C%0A%20%20%20document.createElement%28%22menuitem%22%29%29%3B%5D%5D%3E%3C/initcode%3E%0A%20%20%3Ccode%3E%3C%21%5BCDATA%5B/*CODE*/%5D%5D%3E%3C/code%3E%0A%20%20%3Caccelkey%3E%3C%21%5BCDATA%5B%5D%5D%3E%3C/accelkey%3E%0A%20%20%3Chelp%3E%3C%21%5BCDATA%5B%5D%5D%3E%3C/help%3E%0A%20%20%3Cattributes/%3E%0A%3C/custombutton%3E
Да, так не заменяет.
Отредактировано turbot (14-09-2016 21:05:22)
Отсутствует
Приветствую, возможно ли сделать кнопочку, чтобы Responsive Design View был постоянно для любых открывающихся табов/закладок?
Для оптимизации сайтов удобно, но постоянно жмакать ctrl-shift-m отвлекает.
Ничего другого придумать не получается что-то..
Отсутствует