bunda1
Буду пробовать. Только поставил, вроде, нормально.
эта кнопка Context Search добавляет в контекстное меню свой пункт два раза:
У меня так было, когда я кнопку поместил в строку заголовка (на самый верх). Но когда переместил эту кнопку вниз (панель дополнений), то всё стало как надо - один пункт в меню.
Отсутствует
Не работает. В меню присутствует, но по клику на поисковике ничего не происходит. firefox 35.0.1
Сейчас проверил и всё работает, возможно конфликт с установленными расширениями, попробуй их отключать по одному и проверять работу кода.
Отсутствует
2k1dmg
что-то не работает поиск по картинкам в яндексе, пишет пустой поисковой запрос.
// Скрыть кнопку с панели. self.style.display = 'none'; (function () { // Context Search mini 2013-11-22 var options = { loadInBackground: true, // true - открывать вкладки в фоне pinnedEngineName: "", // оставить пустым если не нужно закреплять // определенный поисковик // примеры pinnedEngineName: "Google" или pinnedEngineName: "Яндекс" или pinnedEngineName: "" hideDefaultEngineInPopupSubMenu: true, // true - не добавлять поисковик по умолчанию в выпадающий список (подменю) поисковиков campactMenu: false, // true - поисковики в выпадающем списке (подменю) без назаваний campactMenuLengthPerLine: 5, // максимальное количество элементов в одной строке // от 3 до 10, по умолчанию 5 searchBySite: { enable: true, // true - добавить поисковики по сайту iconsOn: true, // true - добавить иконки для поисковиков по сайту useDefaultNamesList: true, // true - использовать список поисковиков по умолчанию addCustomNames: false, // true - добавить свои поисковики по сайту customNamesList: [ ["Rambler", ["Rambler", "Рамблер"]] ] // например ["Rambler", ["Rambler", "Рамблер"]] // первая ячека название на английском // вторая ячека массив с предполагаемыми именами поисковика // может состоять из нескольких значений // ["Name1", ["Name1"]], // ["Name2", ["Name2", "Имя2"]], // ["Name3", ["Name3", "Имя3", "Név3"]] }, searchImageByText: { enable: true, // true - добавить поиск изображения по тексту useDefaultNamesList: true, addCustomNames: false, customNamesList: [ [ "name", "link", "image" ] ] }, searchByImage: { enable: true, // true - добавить поиск по изображению useDefaultNamesList: true, addCustomNames: false, customNamesList: [ [ "name", "link", "image" ] ] }, searchInCache: { enable: true, // true - добавить поиск в кэше // нужно доработать useDefaultNamesList: true, addCustomNames: false, customNamesList: [ [ "name", "link", "image" ] ] } }; function _localize(sid) { let strings = { en: { searchBySite: "Search this site", searchImageByText: "Search image by text", searchByImage: "Search by image", searchInCache: "Search this page in cache" }, ru: { searchBySite: "Поиск по этому сайту", searchImageByText: "Поиск изображения по тексту", searchByImage: "Поиск по изображению", searchInCache: "Поиск этой страницы в кэше" } }; //let locale = (Application.prefs.getValue("general.useragent.locale", false) || "en").match(/^[a-z]*/)[0]; function getBrowserUILocale() { let gPrefService = Services.prefs; // SeaMonkey if (!gPrefService.getBoolPref("intl.locale.matchOS")) { try { var locale = gPrefService.getCharPref("general.useragent.locale"); if (locale.substr(0, 9) == "chrome://") { return gPrefService.getComplexValue("general.useragent.locale", Components.interfaces.nsIPrefLocalizedString).data; } return locale; } catch (ex) {} } try { return Components.classes["@mozilla.org/chrome/chrome-registry;1"] .getService(Components.interfaces.nsIXULChromeRegistry) .getSelectedLocale("global"); } catch (ex) { return "en-US"; } } let locale = ""; // ru, en if (!locale) locale = getBrowserUILocale().match(/^[a-z]*/)[0]; _localize = function (sid) { return strings[locale] && strings[locale][sid] || strings.en[sid] || sid; }; return _localize.apply(this, arguments); } let XULNS = "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"; let XHTMLNS = "http://www.w3.org/1999/xhtml"; var contextSearcherObj = { initialized: false, init: function() { if(this.initialized) return; this.initialized = true; this.nodeIds = { searchMenu: "contextSearchMiniByBunda1-menu", searchMenuPopup: "contextSearchMiniByBunda1-popup", searchByImageMenu: "contextSearchMiniByBunda1-image-search-menu", searchByImageMenuPopup: "contextSearchMiniByBunda1-image-search-popup" }; if (document.getElementById(this.nodeIds.searchMenu)) return; var searchService = Cc["@mozilla.org/browser/search-service;1"].getService(Ci.nsIBrowserSearchService); var contextMenu = document.getElementById("contentAreaContextMenu"); var searchSelect = document.getElementById("context-searchselect"); searchSelect.style.display = "none"; var searchMenu = contextMenu.insertBefore(document.createElementNS(XULNS, "menu"), searchSelect); this.searchService = searchService; this.contextMenu = contextMenu; this.searchSelect = searchSelect; this.searchMenu = searchMenu; this.param = { isPinnedEngine: false, pinnedEngineName: "" }; try { this.createSearchMenu(); if (options.searchByImage.enable) this.createSearchByImageMenu(); } catch (ex) { this.destroy(); Components.utils.reportError(ex); return; } if (options.campactMenu) this.loadStyles(); var observeStatus = new MutationObserver(function () { searchMenu.hidden = searchSelect.hidden; }); observeStatus.observe(searchSelect, { attributes: true, attributeFilter: ["hidden"] }); /*var prefService = Components.classes["@mozilla.org/preferences-service;1"] .getService(Components.interfaces.nsIPrefService); this.branch = prefService.getBranch("browser.search."); if (!("addObserver" in this.branch)) this.branch.QueryInterface(Components.interfaces.nsIPrefBranch2); this.branch.addObserver("", this, false);*/ /* var searchPref = "browser.search."; gPrefService.addObserver(searchPref, this, false);*/ /*let os = Cc["@mozilla.org/observer-service;1"]. getService(Ci.nsIObserverService); os.addObserver(this, "browser-search-engine-modified", false);*/ Services.obs.addObserver(this, "browser-search-engine-modified", false); Services.ww.registerNotification(this); addEventListener("popupshowing", this, false, contextMenu); addDestructor(function (reason) { observeStatus.disconnect(); Services.ww.unregisterNotification(this); //this.branch.removeObserver("", this); //gPrefService.removeObserver(searchPref, this, false); //os.removeObserver(this, "browser-search-engine-modified", false); Services.obs.removeObserver(this, "browser-search-engine-modified", false); this.destroy(); if (reason != "destructor") this.unloadStyles(); }, this); }, destroy: function() { if(!this.initialized) return; this.initialized = false; var contextMenu = this.contextMenu; if (!contextMenu) return; if (this.searchMenu) contextMenu.removeChild(this.searchMenu); if (this.searchByImageMenu) contextMenu.removeChild(this.searchByImageMenu); if (this.searchSelect) this.searchSelect.style.removeProperty("display"); }, update: function() { this.searchMenu.textContent = ""; this.createSearchMenu(); delete this.updateTimeoutID; }, get isSeaMonkey() { delete this.isSeaMonkey; return this.isSeaMonkey = Services.appinfo.name == "SeaMonkey"; }, observe: function(subject, topic, data) { switch (topic) { /*case "domwindowclosed": if (subject.document.documentElement.getAttribute("windowtype") == "Browser:SearchManager") { this.update(); } break;*/ /*case "nsPref:changed": switch (data) { case "defaultenginename": case "browser.search.defaultenginename": this.update(); break; } break;*/ case "browser-search-engine-modified": /*switch (data) { case "engine-default": case "engine-current": // engine-default case "engine-changed": case "engine-removed":*/ if (typeof this.updateTimeoutID == "number") { window.clearTimeout(this.updateTimeoutID); delete this.updateTimeoutID; } let _this = this; this.updateTimeoutID = window.setTimeout(function () { _this.update(); }, 1000); /*break; }*/ break; } }, handleEvent: function(e) { //var contextMenu = this.contextMenu; //var menu = this.menu; //var imageMenu = this.imageMenu; switch (e.type) { case "popupshowing": this.popupshowingEvent(e); break; } }, popupshowingEvent: function(e) { var trgId = e.target.id; if (trgId) { if (trgId == "contentAreaContextMenu") { this.contextMenuPopup(e); if (this.searchByImageMenu) this.searchByImageMenuPopup(e); } else if (trgId == this.nodeIds.searchMenuPopup) this.searchMenuPopup(e); } }, _stylesLoaded: false, loadStyles: function() { if(this._stylesLoaded) return; this._stylesLoaded = true; var sss = this.sss; var cssURI = this.cssURI = this.makeCSSURI(); if(!sss.sheetRegistered(cssURI, sss.USER_SHEET)) sss.loadAndRegisterSheet(cssURI, sss.USER_SHEET); }, unloadStyles: function() { if(!this._stylesLoaded) return; this._stylesLoaded = false; var sss = this.sss; if(sss.sheetRegistered(this.cssURI, sss.USER_SHEET)) sss.unregisterSheet(this.cssURI, sss.USER_SHEET); }, get sss() { delete this.sss; return this.sss = Components.classes["@mozilla.org/content/style-sheet-service;1"] .getService(Components.interfaces.nsIStyleSheetService); }, makeCSSURI: function() { var cssStr = '\ @namespace url("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul");\n\ @-moz-document url("' + window.location.href + '") {\n\ #' + this.nodeIds.searchMenuPopup + ' > hbox > .menuitem-iconic[campactMenu="true"] {\n\ /*width: 2em !important;*/\n\ }\n\ #' + this.nodeIds.searchMenuPopup + ' > hbox > .menuitem-iconic[campactMenu="true"] * {\n\ /*padding-left: 0 !important;\n\ padding-right: 0 !important;\n\ margin-left: 0 !important;\n\ margin-right: 0 !important;*/\n\ }\n\ #' + this.nodeIds.searchMenuPopup + ' > hbox > spacer[campactMenu="true"] {\n\ width: /*2em*/26px !important;\n\ @media (min-resolution: 2dppx) {\n\ #' + this.nodeIds.searchMenuPopup + ' > hbox > spacer[campactMenu="true"] {\n\ width: 52px !important;\n\ }\n\ }\n\ }\n\ #' + this.nodeIds.searchMenuPopup + ' > hbox > .menuitem-iconic[campactMenu="true"] {\n\ /*width: 3em !important;\n\ height: 2em !important;*/\n\ width: 36px !important;\n\ height: 26px !important;\n\ -moz-box-pack: center !important;\n\ @media (min-resolution: 2dppx) {\n\ #' + this.nodeIds.searchMenuPopup + ' > hbox > .menuitem-iconic[campactMenu="true"] {\n\ width: 72px !important;\n\ height: 52px !important;\n\ }\n\ }\n\ }\n\ #' + this.nodeIds.searchMenuPopup + ' > hbox >.menuitem-iconic[campactMenu="true"] > image {\n\ /*margin-left: .8em !important;*/\n\ }\n\ }\n\ '; return Services.io.newURI("data:text/css," + encodeURIComponent(cssStr), null, null); }, searchCommandHandler: function(event, trg) { var inBg = options.loadInBackground || false; if (event.type == "click" && event.button && event.button == 1) { inBg = !inBg; } var searchBySite = ""; if (event.target.hasAttribute("searchBySite")) { searchBySite = " site:" + gBrowser.currentURI.host; } else if (event.target.hasAttribute("searchInCache")) { searchBySite = content.location.href; } let selectedText = this.isSeaMonkey ? content.getSelection().toString() : getBrowserSelection(); if (event.target.engine.imageLink) { gBrowser.loadOneTab(event.target.engine.imageLink + /*getBrowserSelection()*/ selectedText, { relatedToCurrent: true, inBackground: inBg }); } else if (event.target.engine.cacheLink) { gBrowser.loadOneTab(event.target.engine.cacheLink + /*getBrowserSelection()*/ searchBySite, { relatedToCurrent: true, inBackground: inBg }); } else { let submission = event.target.engine.getSubmission(/*getBrowserSelection()*/ selectedText + searchBySite, null); gBrowser.loadOneTab(submission.uri.spec, { relatedToCurrent: true, postData: submission.postData, inBackground: inBg }); } if (trg == "menu") { setTimeout(function () { document.getElementById("contentAreaContextMenu").hidePopup(); }, 0); } }, contextMenuPopup: function(e) { var searchService = this.searchService; var contextMenu = this.contextMenu; var menu = this.searchMenu; //var selectedText = getBrowserSelection(16); var selectedText = this.isSeaMonkey ? content.getSelection(16).toString() : getBrowserSelection(16); if (!selectedText) return; var ellipsis = "\u2026"; try { ellipsis = gPrefService.getComplexValue("intl.ellipsis", Ci.nsIPrefLocalizedString).data; } catch (ex) { } if (selectedText.length > 15) selectedText = selectedText.substr(0,15) + ellipsis; let rEngine = this.isSeaMonkey ? "currentEngine" : "defaultEngine"; var engineName = this.param.isPinnedEngine ? this.param.pinnedEngineName : searchService[rEngine].name; var menuLabel; var searchFormattedString = [ "contextMenuSearch", "contextMenuSearchText", "searchSelected" ]; var thisIsSM = this.isSeaMonkey; function getMenuLabel(str) { try { if (thisIsSM) { let bundle = document.getElementById("contentAreaCommandsBundle"); return bundle.getFormattedString(str, [engineName, selectedText]); } else return gNavigatorBundle.getFormattedString(str, [engineName, selectedText]); } catch (ex) { return false; } } for(let i in searchFormattedString) { menuLabel = getMenuLabel(searchFormattedString[i]); if (menuLabel) break; else if (!menuLabel && i == searchFormattedString.length-1) menuLabel = engineName; } menu.label = menuLabel; }, searchMenuPopup: function(e) { var popup = e.target; var items; if (!popup.items) { var itemsObj = popup.getElementsByTagName("menuitem"); popup.items = []; Array.slice(itemsObj).forEach(function(elem) { if (typeof elem == "object" && elem.nodeName == "menuitem" && elem.hasAttribute("searchBySite") || elem.hasAttribute("searchInCache")) popup.items.push(elem); }); items = popup.items; } else { items = popup.items; } var menus; if (!popup.menus) { var itemsObj = popup.getElementsByTagName("menu"); popup.menus = []; Array.slice(itemsObj).forEach(function(elem) { if (typeof elem == "object" && elem.nodeName == "menu" && elem.hasAttribute("searchBySite") || elem.hasAttribute("searchInCache")) popup.menus.push(elem); }); menus = popup.menus; } else { menus = popup.menus; } var siteSearchDomain; var gBrowser = gBrowser || getBrowser(); function isDomain() { try { siteSearchDomain = gBrowser.currentURI.host; } catch (ex) { return false; } return true; } if (isDomain()) { items.forEach(function(elem) { //if (elem.hasAttribute("searchBySite")) // elem.setAttribute("tooltiptext", siteSearchDomain); elem.removeAttribute("disabled"); }); menus.forEach(function(elem) { if (elem.hasAttribute("searchBySite")) elem.setAttribute("tooltiptext", siteSearchDomain); else if (elem.hasAttribute("searchInCache")) elem.setAttribute("tooltiptext", content.document.title); elem.removeAttribute("disabled"); }); } else { items.forEach(function(elem) { //if (elem.hasAttribute("searchBySite")) // elem.removeAttribute("tooltiptext"); elem.setAttribute("disabled", "true"); }); menus.forEach(function(elem) { if (elem.hasAttribute("searchBySite") || elem.hasAttribute("searchInCache")) elem.removeAttribute("tooltiptext"); elem.setAttribute("disabled", "true"); }); } }, createSearchMenu: function() { var searchService = this.searchService; var contextMenu = this.contextMenu; var menu = this.searchMenu; var engines = searchService.getVisibleEngines({}); menu.setAttribute("id", this.nodeIds.searchMenu); menu.setAttribute("class", "menu-iconic"); this.param.isPinnedEngine = false; this.param.pinnedEngineName = ""; var pinnedEngineName = options.pinnedEngineName; if (pinnedEngineName != "") { for (let i in engines) { if (engines[i].name != pinnedEngineName) continue; menu.setAttribute("label", engines[i].name); menu.setAttribute("image", engines[i].iconURI.spec); menu.engine = engines[i]; this.param.isPinnedEngine = true; this.param.pinnedEngineName = pinnedEngineName; break; } } let rEngine = this.isSeaMonkey ? "currentEngine" : "defaultEngine"; if (!this.param.isPinnedEngine) { menu.setAttribute("label", searchService[rEngine].name); menu.setAttribute("image", searchService[rEngine].iconURI.spec); menu.engine = searchService[rEngine]; } menu.gObj = this; menu.setAttribute("onclick", "if (event.target == this && event.target.engine) this.gObj.searchCommandHandler(event, 'menu');"); menu.popup = menu.appendChild(document.createElementNS(XULNS, "menupopup")); var popup = this.searchMenu.popup; popup.setAttribute("id", this.nodeIds.searchMenuPopup); var counterMaxLength = options.campactMenuLengthPerLine; if (typeof counterMaxLength != "number" || 3 > counterMaxLength || counterMaxLength > 10) counterMaxLength = 5; var counter = 0; var hBox; function itemCreateCampact(engine, last) { if(counter == 0) { hBox = document.createElementNS(XULNS, "hbox"); let item = document.createElementNS(XULNS, "spacer"); //item.setAttribute("style", "width: 2em"); item.setAttribute("campactMenu", "true"); hBox.appendChild(item); } counter++; var item = document.createElementNS(XULNS, "menuitem"); item.engine = engine; item.setAttribute("class", "menuitem-iconic"); item.setAttribute("tooltiptext", engine.name); //item.setAttribute("src", engine.iconURI.spec); var image = document.createElementNS(XULNS, "image"); image.setAttribute("src", engine.iconURI.spec); item.appendChild(image); //item.setAttribute("style", "max-width: 2em"); item.setAttribute("campactMenu", "true"); hBox.appendChild(item); if (counter == counterMaxLength || last) { popup.appendChild(hBox); counter = 0; } } var separator = {}; function itemCreate(engine, reason) { var item = document.createElementNS(XULNS, "menuitem"); item.setAttribute("class", "menuitem-iconic"); item.engine = engine; if (reason && !separator[reason]) { /*let sep = separator[reason] = document.createElementNS(XULNS, "menuseparator"); sep.setAttribute(reason, "true"); popup.appendChild(sep); let item = document.createElementNS(XULNS, "label"); //item.setAttribute("class", "menuitem-iconic"); item.setAttribute("value", _localize(reason) + ":"); item.setAttribute("style", "padding-left: 2em"); popup.appendChild(item);*/ if (!separator["menuseparator"]) { let sep = separator["menuseparator"] = document.createElementNS(XULNS, "menuseparator"); popup.appendChild(sep); } let subMenu = separator[reason] = document.createElementNS(XULNS, "menu"); subMenu.setAttribute("class", "menu-iconic"); subMenu.setAttribute("label", _localize(reason)); subMenu.setAttribute(reason, "true"); subMenu.popup = subMenu.appendChild(document.createElementNS(XULNS, "menupopup")); popup.appendChild(subMenu); } if (reason == "searchBySite") { item.setAttribute("label", engine.name); if (options.searchBySite.iconsOn) { item.setAttribute("src", engine.iconURI.spec); } item.setAttribute(reason, "true"); } else if (reason == "searchImageByText" || reason == "searchInCache") { item.setAttribute("label", engine.name); item.setAttribute("src", engine.iconURI_spec); item.setAttribute(reason, "true"); } else { item.setAttribute("label", engine.name); item.setAttribute("src", engine.iconURI.spec); } //popup.appendChild(item); if (reason) { let subMenu = separator[reason]; subMenu.popup.appendChild(item); } else popup.appendChild(item); } for (let i in engines) { if (options.hideDefaultEngineInPopupSubMenu && this.param.isPinnedEngine && engines[i].name == pinnedEngineName || options.hideDefaultEngineInPopupSubMenu && !this.param.isPinnedEngine && engines[i].name == searchService[rEngine].name) { continue; } if (options.campactMenu) itemCreateCampact(engines[i], i == engines.length-1); else itemCreate(engines[i]); } function searchBySite_itemCreate() { var namesList = []; if (options.searchBySite.useDefaultNamesList) { let defaultNamesList = [ ["Google", ["Google"]], ["Yandex", ["Yandex", "Яндекс"]], ["Yahoo", ["Yahoo"]], ["Bing", ["Bing"]], ["DuckDuckGo", ["DuckDuckGo"]] ]; namesList = namesList.concat(defaultNamesList); } if (options.searchBySite.addCustomNames && Array.isArray(options.searchBySite.customNamesList)) { namesList = namesList.concat(options.searchBySite.customNamesList); } //let i_skips = []; function isNameExist(names, engine) { for (let i in names) { if (names[i] != engine && i != names.length-1) continue; else if (names[i] == engine) return true; return false; } } namesList.forEach(function(elem) { for (let i in engines) { if (/*i_skips.indexOf(i) != -1 ||*/ !(elem[1].some(function(listName) listName == engines[i].name)) /*!isNameExist(elem[1], engines[i].name)*/ /*elem[1].indexOf(engines[i].name) == -1*/) continue; itemCreate(engines[i], "searchBySite"); //i_skips.push(i); break; } }); } if (options.searchBySite.enable) { searchBySite_itemCreate(); } function searchImageByText_itemCreate() { var namesList = []; if (options.searchImageByText.useDefaultNamesList) { let defaultNamesList = [ [ "Google", "https://www.google.ru/search?tbm=isch&q=", "" ], [ "Yandex", "http://images.yandex.ru/yandsearch?text=", "" ] ]; namesList = namesList.concat(defaultNamesList); } if (options.searchImageByText.addCustomNames && Array.isArray(options.searchImageByText.customNamesList)) { namesList = namesList.concat(options.searchImageByText.customNamesList); } namesList.forEach(function(elem) { let engine = {}; engine.name = elem[0]; engine.imageLink = elem[1]; engine.iconURI_spec = elem[2]; itemCreate(engine, "searchImageByText"); }); } if (options.searchImageByText.enable) { searchImageByText_itemCreate(); } function searchInCache() { var namesList = []; if (options.searchInCache.useDefaultNamesList) { let defaultNamesList = [ [ "Google", "https://www.google.com/search?q=cache:", "" ], [ "Archive.org", "http://web.archive.org/web/*/", "" ] ]; namesList = namesList.concat(defaultNamesList); } if (options.searchInCache.addCustomNames && Array.isArray(options.searchInCache.customNamesList)) { namesList = namesList.concat(options.searchInCache.customNamesList); } namesList.forEach(function(elem) { let engine = {}; engine.name = elem[0]; engine.cacheLink = elem[1]; engine.iconURI_spec = elem[2]; itemCreate(engine, "searchInCache"); }); } if (options.searchInCache.enable) { searchInCache(); } popup.gObj = this; //popup.setAttribute("oncommand", "if (!event.target.engine) return; var csObj = this.gObj || document.getElementById('contextSearchMiniByBunda1-context-popup').gObj; csObj.searchCommandHandler(event);"); popup.setAttribute("oncommand", "if (!event.target.engine || event.target.nodeName == 'menu') return; this.gObj.searchCommandHandler(event);"); popup.setAttribute("onclick", "checkForMiddleClick(this, event);"); }, searchByImageCommandHandler: function(event) { var inBg = options.loadInBackground || false; if (event.type == "click" && event.button && event.button == 1) { inBg = !inBg; } var searchByImageMenu = this.searchByImageMenu; var link = event.target.link; var imageLink = searchByImageMenu.imageSrc; if (imageLink.indexOf("data:") == 0) { this.searchByImageByData(imageLink, inBg); return; } else if (imageLink.indexOf("file:") == 0) { this.searchByImageByFile(imageLink, inBg); return; } else { imageLink = encodeURIComponent(imageLink) } var gBrowser = gBrowser || getBrowser(); gBrowser.loadOneTab(link + imageLink, { relatedToCurrent: true, inBackground: inBg }); }, // searchByImageByData() and searchByImageByFile() based on // Google Image Search 0.5 by Nishan Naseer // https://addons.mozilla.org/ru/firefox/addon/google-similar-images searchByImageByData: function(src, inBg) { var gBrowser = gBrowser || getBrowser(); //var tab = gBrowser.addTab(this.searchByImageMenu.popup.googleURL); var tab = gBrowser.loadOneTab(this.searchByImageMenu.popup.googleURL, { relatedToCurrent: true }); var newTabBrowser = gBrowser.getBrowserForTab(tab); newTabBrowser.addEventListener("load", function byData(e) { newTabBrowser.removeEventListener(e.type, byData, true); if (src) { try { var image_url; var sub; var form = newTabBrowser.contentDocument.getElementById("qbf"); var inputs = form.getElementsByTagName("input"); for (var k = 0; k < inputs.length; k++) { var i = inputs[k]; if (i.name && i.name == "image_url") { image_url = i; } if (i.type && i.type == "submit") { sub = i; } } image_url.value = src; sub.click(); src = null; } catch (ex) { } } }, true); if (!inBg) { getBrowser().selectedTab = tab; } }, searchByImageByFile: function(src, inBg) { //Canvas to get contents in base-64 var canvas = gContextMenu.target.ownerDocument.createElementNS(XHTMLNS, "canvas"); var image = new Image(); image.src = src; canvas.width = image.width; canvas.height = image.height; var ctx = canvas.getContext("2d"); ctx.drawImage(image, 0, 0); var dataURL = canvas.toDataURL("image/png"); var gBrowser = gBrowser || getBrowser(); //var tab = gBrowser.addTab(this.searchByImageMenu.popup.googleURL); var tab = gBrowser.loadOneTab(this.searchByImageMenu.popup.googleURL, { relatedToCurrent: true }); var newTabBrowser = gBrowser.getBrowserForTab(tab); newTabBrowser.addEventListener("load", function byFile(e) { newTabBrowser.removeEventListener(e.type, byFile, true); if (src) { try { var image_url; var sub; var form = newTabBrowser.contentDocument.getElementById("qbf"); var inputs = form.getElementsByTagName("input"); for (var k = 0; k < inputs.length; k++) { var i = inputs[k]; if (i.name && i.name == "image_url") { image_url = i; } if (i.type && i.type == "submit") { sub = i; } } image_url.value = dataURL; sub.click(); src = null; } catch (ex) { } } }, true); if (!inBg) { getBrowser().selectedTab = tab; } }, searchByImageMenuPopup: function(e) { var searchByImageMenu = this.searchByImageMenu; searchByImageMenu.hidden = !gContextMenu.onImage; var src = gContextMenu.mediaURL || gContextMenu.imageURL || gContextMenu.bgImageURL; if (!src || !(/^((ht|f)tps?:\/\/|data:image|file:)/.test(src))) { searchByImageMenu.hidden = true; return; } //var popup = document.getElementById("contextSearchMiniByBunda1-context-image-search-popup"); var popup = searchByImageMenu.popup; var items; if (!popup.items) { var itemsObj = popup.getElementsByTagName("menuitem"); popup.items = []; Array.slice(itemsObj).forEach(function(elem) { if (typeof elem == "object" && elem.nodeName == "menuitem" && elem.getAttribute("label") != "Google") popup.items.push(elem); }); items = popup.items; } else { items = popup.items; } if (/^(data:image|file:)/.test(src)) { items.forEach(function(elem) { elem.setAttribute("disabled", "true"); }); } else { items.forEach(function(elem) { elem.removeAttribute("disabled"); }); } searchByImageMenu.imageSrc = src; }, createSearchByImageMenu: function() { var menu = document.createElement("menu"); var insertMenu = document.getElementById("context-sep-copyimage"); insertMenu.parentNode.insertBefore(menu, insertMenu); this.searchByImageMenu = menu; menu.setAttribute("id", this.nodeIds.searchByImageMenu); menu.setAttribute("class", "menu-iconic"); menu.setAttribute("label", _localize("searchByImage")); menu.setAttribute("image", ""); this.searchByImageMenu.popup = menu.appendChild(document.createElementNS(XULNS, "menupopup")); var popup = this.searchByImageMenu.popup; popup.setAttribute("id", this.nodeIds.searchByImageMenuPopup); popup.googleURL = "https://www.google.com/searchbyimage"; var namesList = []; if (options.searchByImage.useDefaultNamesList) { let defaultNamesList = [ [ "Google", "https://www.google.com/searchbyimage?image_url=", "" ], [ "Yandex", "http://images.yandex.ru/yandsearch?rpt=imagedups&text=&img_url=", "" ], [ "TinEye", "http://www.tineye.com/search/?pluginver=firefox-1.0&url=", "" ] ]; namesList = namesList.concat(defaultNamesList); } if (options.searchByImage.addCustomNames && Array.isArray(options.searchByImage.customNamesList)) { namesList = namesList.concat(options.searchByImage.customNamesList); } function itemCreate(name, link, image) { var item = document.createElementNS(XULNS, "menuitem"); item.setAttribute("class", "menuitem-iconic"); item.setAttribute("src", image); item.setAttribute("label", name); item.link = link; popup.appendChild(item); } namesList.forEach(function(elem) { itemCreate(elem[0], elem[1], elem[2]); }); var contextMenu = this.contextMenu; popup.gObj = this; popup.setAttribute("oncommand", "this.gObj.searchByImageCommandHandler(event);"); popup.setAttribute("onclick", "checkForMiddleClick(this, event);"); } } contextSearcherObj.init(); })();
Отсутствует
Northtech
Замени в коде:
на:
https://yandex.ru/images/search?uinfo=sw-1024-sh-768-ww-1024-wh-612-pd-1-wp-4x3_1024x768&viewport=wide&_=1433085221683&rpt=imageview&img_url=
Отсутствует
bunda1
А у меня в Яндексе ищет, зато в Гугле нет.
А мне на FF38 без проблем, попробуй искать изображения в Гугле на FF41 не используя код Context Search mini и если поиск работает скопируй правильный адрес из адресной строки браузера в код Context Search mini. И все дела.
Отсутствует
Проверил Context Search на SeaMonkey, работает.
Очень благодарен, тоже заработало!
SeaMonkey 2.39 forever
Отсутствует
bunda1
Спасибо - отличная кнопка! Хочу слезть с аддона Select Search и посему вопрос - реально ли сделать в Вашей кнопке компактный вид в 5 - 6 рядов, как Context Search mini, а то у меня высота чуть менее, чем полностью на весь экран
Отсутствует
bunda1, вы как всегда радуете, уже не один аддон вашими кнопками заменил. Ну и конечно просьба,
Клики на пункте контекстного меню или на пункте подменю:
ЛКМ => Открыть поиск в новой активной вкладке,
ПКМ => Открыть поиск в новой фоновой вкладке.
Как кнопки поменять? Не могу привыкнуть, мне бы ЛКМ в фоне, а ПКМ - активная.
Отсутствует
Уважаемый bunda1, нельзя ли добавить в кнопку следующие возможности:
1. Поиск по вводимому тексту (а не только выделенному):
Например, если открыт find-bar, то в главном контекстном меню чтоб тоже присутствовал этот менюитем (ещё лучше, чтобы по правому клику на find-barе вызывалось бы сразу контекстное меню поиска) - тогда можно было бы и набирать нужный текст в find-barе - и искать по нему
2. Делать несколько меню-списков поисковых машин, чтобы избегать скроллинг
3. Длинный ЛКМ или ПКМ на менюитем (поисковую машину) делает то же, что обычный ЛКМ или ПКМ, но меню не исчезает - чтобы делать поиск по нескольким машинам
Спасибо
Отредактировано difabor (21-12-2015 17:12:50)
Хорошо, когда у человека есть выбор, но плохо, когда он перед ним стоит ©
Отсутствует
просьба,
Как кнопки поменять? Не могу привыкнуть, мне бы ЛКМ в фоне, а ПКМ - активная.
В:
// установить действие для клика на меню и подменю menu.onmouseup =e=> { var background = (e.button == 0) ? false : true;
поменяй false и true местами.
Отсутствует
bunda1
Спасибо - отличная кнопка! Хочу слезть с аддона Select Search и посему вопрос - реально ли сделать в Вашей кнопке компактный вид в 5 - 6 рядов, как Context Search mini, а то у меня высота чуть менее, чем полностью на весь экран
Сделаем.
Отсутствует
Context Search 2 (mini)
(function() { // Context Search 2 2015-12-28v2 'use strict'; let options = { loadInBackground: false, // true - открывать вкладки в фоне pinnedEngineName: '', // оставить пустым если не нужно закреплять // определенный поисковик // примеры pinnedEngineName: 'Google' или pinnedEngineName: 'Яндекс' или pinnedEngineName: '' hideDefaultEngineInPopupSubMenu: false, // true - не добавлять поисковик по умолчанию в выпадающий список (подменю) поисковиков campactMenu: true, // true - поисковики в выпадающем списке (подменю) без назаваний campactMenuLengthPerLine: 5, // максимальное количество элементов в одной строке // от 3 до 10, по умолчанию 5 searchBySite: { enable: true, // true - добавить поисковики по сайту iconsOn: true, // true - добавить иконки для поисковиков по сайту useDefaultNamesList: true, // true - использовать список поисковиков по умолчанию addCustomNames: false, // true - добавить свои поисковики по сайту customNamesList: [ ['Rambler', ['Rambler', 'Рамблер']] ] // например ['Rambler', ['Rambler', 'Рамблер']] // первая ячека название на английском // вторая ячека массив с предполагаемыми именами поисковика // может состоять из нескольких значений // ['Name1', ['Name1']], // ['Name2', ['Name2', 'Имя2']], // ['Name3', ['Name3', 'Имя3', 'Nev3']] }, searchImageByText: { enable: true, // true - добавить поиск изображения по тексту useDefaultNamesList: true, addCustomNames: false, customNamesList: [ [ 'name', 'link', 'image' ] ] }, searchByImage: { enable: true, // true - добавить поиск по изображению useDefaultNamesList: true, addCustomNames: false, customNamesList: [ [ 'name', 'link', 'image' ] ] }, searchInCache: { enable: true, // true - добавить поиск в кэше // нужно доработать useDefaultNamesList: true, addCustomNames: false, customNamesList: [ [ 'name', 'link', 'image' ] ] }, defaultIcon: 'chrome://mozapps/skin/places/defaultFavicon.png' }; if (Services.appinfo.OS == 'Darwin' && devicePixelRatio >= 2) { options.defaultIcon = 'chrome://mozapps/skin/places/defaultFavicon@2x.png'; } function _localize(sid) { let strings = { en: { searchBySite: 'Search this site', searchImageByText: 'Search image by text', searchByImage: 'Search by image', searchInCache: 'Search this page in cache' }, ru: { searchBySite: 'Поиск по этому сайту', searchImageByText: 'Поиск изображения по тексту', searchByImage: 'Поиск по изображению', searchInCache: 'Поиск этой страницы в кэше' } }; let getBrowserUILocale = function() { let gPrefService = Services.prefs; // SeaMonkey if (!gPrefService.getBoolPref('intl.locale.matchOS')) { try { let locale = gPrefService.getCharPref('general.useragent.locale'); if (locale.substr(0, 9) == 'chrome://') { return gPrefService.getComplexValue('general.useragent.locale', Components.interfaces.nsIPrefLocalizedString).data; } return locale; } catch (ex) {} } try { return Components.classes['@mozilla.org/chrome/chrome-registry;1'] .getService(Components.interfaces.nsIXULChromeRegistry) .getSelectedLocale('global'); } catch (ex) { return 'en-US'; } }; let locale = ''; // ru, en if (!locale) locale = getBrowserUILocale().match(/^[a-z]*/)[0]; _localize = function(sid) { return strings[locale] && strings[locale][sid] || strings.en[sid] || sid; }; return _localize(sid); } let XULNS = 'http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul'; let XHTMLNS = 'http://www.w3.org/1999/xhtml'; let contextSearcherObj = { initialized: false, init: function() { if (this.initialized) return; this.initialized = true; this.nodeIds = { searchMenu: 'context-search-2-by-2k1dmg-menu', searchMenuPopup: 'context-search-2-by-2k1dmg-popup', searchByImageMenu: 'context-search-2-by-2k1dmg-image-search-menu', searchByImageMenuPopup: 'context-search-2-by-2k1dmg-image-search-popup' }; if (document.getElementById(this.nodeIds.searchMenu)) return; let searchService = Cc['@mozilla.org/browser/search-service;1'] .getService(Ci.nsIBrowserSearchService); let contextMenu = document.getElementById('contentAreaContextMenu'); let searchSelect = document.getElementById('context-searchselect'); searchSelect.style.display = 'none'; let searchMenu = contextMenu .insertBefore(document.createElementNS(XULNS, 'menu'), searchSelect); this.searchService = searchService; this.contextMenu = contextMenu; this.searchSelect = searchSelect; this.searchMenu = searchMenu; this.param = { isPinnedEngine: false, pinnedEngineName: '' }; try { this.createSearchMenu(); if (options.searchByImage.enable) this.createSearchByImageMenu(); } catch (ex) { this.destroy(); Components.utils.reportError(ex); return; } if (options.campactMenu) this.loadSheet(window, this.makeCSS()); let observeStatus = this.observeStatus = new MutationObserver(function() { searchMenu.hidden = searchSelect.hidden; }); observeStatus.observe(searchSelect, { attributes: true, attributeFilter: ['hidden'] }); Services.obs.addObserver(this, 'browser-search-engine-modified', false); contextMenu.addEventListener('popupshowing', this, false); if (typeof addDestructor == 'function' && // userChromeJS/uc addDestructor != ('addDestructor' in window && window.addDestructor)) { addDestructor(function(reason) { this.destroy(reason); }, this); } }, destroy: function(reason) { if (!this.initialized) return; this.initialized = false; if (this.observeStatus) this.observeStatus.disconnect(); Services.obs.removeObserver(this, 'browser-search-engine-modified', false); let contextMenu = this.contextMenu; if (!contextMenu) return; contextMenu.removeEventListener('popupshowing', this, false); if (this.searchMenu) contextMenu.removeChild(this.searchMenu); if (this.searchByImageMenu) contextMenu.removeChild(this.searchByImageMenu); if (this.searchSelect) this.searchSelect.style.removeProperty('display'); this.removeSheet(window, this.makeCSS()); }, update: function() { this.searchMenu.textContent = ''; this.createSearchMenu(); this.updateTimeoutID = null; }, get isSeaMonkey() { delete this.isSeaMonkey; return this.isSeaMonkey = Services.appinfo.name == 'SeaMonkey'; }, observe: function(subject, topic, data) { switch (topic) { case 'browser-search-engine-modified': if (typeof this.updateTimeoutID == 'number') { window.clearTimeout(this.updateTimeoutID); this.updateTimeoutID = null; } this.updateTimeoutID = window.setTimeout(function() { this.update(); }.bind(this), 1000); break; } }, handleEvent: function(e) { switch (e.type) { case 'popupshowing': this.popupshowingEvent(e); break; } }, popupshowingEvent: function(e) { let trgId = e.target.id; if (trgId) { if (trgId == 'contentAreaContextMenu') { this.contextMenuPopup(e); if (this.searchByImageMenu) this.searchByImageMenuPopup(e); } else if (trgId == this.nodeIds.searchMenuPopup) this.searchMenuPopup(e); } }, makeCSS: function() { return '@namespace url("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul");\n' + '#' + this.nodeIds.searchMenuPopup + ' > hbox > spacer[campactMenu="true"] {\n' + ' width: 26px !important;\n' + '}\n' + '@media (min-resolution: 2dppx) {\n' + ' #' + this.nodeIds.searchMenuPopup + ' > hbox > spacer[campactMenu="true"] {\n' + ' width: 52px !important;\n' + ' }\n' + '}\n' + '#' + this.nodeIds.searchMenuPopup + ' > hbox > .menuitem-iconic[campactMenu="true"] {\n' + ' width: 36px !important;\n' + ' height: 26px !important;\n' + ' -moz-box-pack: center !important;\n' + '}\n' + '@media (min-resolution: 2dppx) {\n' + ' #' + this.nodeIds.searchMenuPopup + ' > hbox > .menuitem-iconic[campactMenu="true"] {\n' + ' width: 72px !important;\n' + ' height: 52px !important;\n' + ' }\n' + '}\n' + '#' + this.nodeIds.searchMenuPopup + ' > hbox > .menuitem-iconic > image {\n' + ' width: 16px !important;\n' + ' height: 16px !important;\n' + '}\n' + '@media (min-resolution: 2dppx) {\n' + ' #' + this.nodeIds.searchMenuPopup + ' > hbox > .menuitem-iconic > image {\n' + ' width: 32px !important;\n' + ' height: 32px !important;\n' + ' }\n' + '}\n' + '#' + this.nodeIds.searchMenuPopup + ' > hbox > .menuitem-iconic > *:not(image) {\n' + ' display: none !important;\n' + '}'; }, SHEET_TYPE: { 'agent': 'AGENT_SHEET', 'user': 'USER_SHEET', 'author': 'AUTHOR_SHEET' }, isTypeValid: function(type) { return type in SHEET_TYPE; }, makeCSSURI: function(url) { if (!/css$/.test(url)) url = 'data:text/css,' + encodeURIComponent(url); return this.ios.newURI(url, null, null); }, get ios() { delete this.ios; return this.ios = Cc['@mozilla.org/network/io-service;1']. getService(Ci.nsIIOService); }, getDOMWindowUtils: function(window) { return window.QueryInterface(Ci.nsIInterfaceRequestor). getInterface(Ci.nsIDOMWindowUtils); }, loadSheet: function(window, url, type) { if (!(type && type in SHEET_TYPE)) type = 'author'; type = this.SHEET_TYPE[type]; if (!(url instanceof Ci.nsIURI)) url = this.makeCSSURI(url); let winUtils = this.getDOMWindowUtils(window); try { winUtils.loadSheet(url, winUtils[type]); } catch (e) {}; }, removeSheet: function(window, url, type) { if (!(type && type in SHEET_TYPE)) type = 'author'; type = this.SHEET_TYPE[type]; if (!(url instanceof Ci.nsIURI)) url = this.makeCSSURI(url); let winUtils = this.getDOMWindowUtils(window); try { winUtils.removeSheet(url, winUtils[type]); } catch (e) {}; }, searchCommandHandler: function(event, trg) { let inBg = options.loadInBackground || false; if (event.type == 'click' && event.button && event.button == 1) { inBg = !inBg; } let searchBySite = ''; let _gBrowser = gBrowser || getBrowser(); if (event.target.hasAttribute('searchBySite')) { searchBySite = ' site:' + _gBrowser.currentURI.host; } else if (event.target.hasAttribute('searchInCache')) { searchBySite = content.location.href; } let selectedText = this.isSeaMonkey ? content.getSelection().toString() : getBrowserSelection(); if (event.target.engine.imageLink) { _gBrowser.loadOneTab(event.target.engine.imageLink + selectedText, { relatedToCurrent: true, inBackground: inBg }); } else if (event.target.engine.cacheLink) { _gBrowser.loadOneTab(event.target.engine.cacheLink + searchBySite, { relatedToCurrent: true, inBackground: inBg }); } else { let submission = event.target.engine.getSubmission(selectedText + searchBySite, null); _gBrowser.loadOneTab(submission.uri.spec, { relatedToCurrent: true, postData: submission.postData, inBackground: inBg }); } if (trg == 'menu') { setTimeout(function() { document.getElementById('contentAreaContextMenu').hidePopup(); }, 0); } }, contextMenuPopup: function(e) { let searchService = this.searchService; let contextMenu = this.contextMenu; let menu = this.searchMenu; let selectedText = this.isSeaMonkey ? content.getSelection(16).toString() : getBrowserSelection(16); if (!selectedText) return; let ellipsis = '\u2026'; try { ellipsis = gPrefService.getComplexValue('intl.ellipsis', Ci.nsIPrefLocalizedString).data; } catch (ex) {} if (selectedText.length > 15) selectedText = selectedText.substr(0, 15) + ellipsis; let currentBrowserEngine = this.isSeaMonkey ? 'currentEngine' : 'defaultEngine'; let engineName = this.param.isPinnedEngine ? this.param.pinnedEngineName : searchService[currentBrowserEngine].name; let menuLabel; let searchFormattedString = [ 'contextMenuSearch', 'contextMenuSearchText', 'searchSelected' // SeaMonkey ]; let thisIsSM = this.isSeaMonkey; let getMenuLabel = function(str) { try { if (thisIsSM) { let bundle = document.getElementById('contentAreaCommandsBundle'); return bundle.getFormattedString(str, [engineName, selectedText]); } else return gNavigatorBundle.getFormattedString(str, [engineName, selectedText]); } catch (ex) { return false; } }; for (let i = 0, len = searchFormattedString.length; i < len; i++) { menuLabel = getMenuLabel(searchFormattedString[i]); if (menuLabel) break; else if (!menuLabel && i == searchFormattedString.length - 1) menuLabel = engineName; } menu.label = menuLabel; }, searchMenuPopup: function(e) { let popup = e.target; let items; if (!popup.items) { let itemsObj = popup.getElementsByTagName('menuitem'); popup.items = []; Array.slice(itemsObj).forEach(function(elem) { if (typeof elem == 'object' && elem.nodeName == 'menuitem' && elem.hasAttribute('searchBySite') || elem.hasAttribute('searchInCache')) popup.items.push(elem); }); items = popup.items; } else { items = popup.items; } let menus; if (!popup.menus) { let itemsObj = popup.getElementsByTagName('menu'); popup.menus = []; Array.slice(itemsObj).forEach(function(elem) { if (typeof elem == 'object' && elem.nodeName == 'menu' && elem.hasAttribute('searchBySite') || elem.hasAttribute('searchInCache')) popup.menus.push(elem); }); menus = popup.menus; } else { menus = popup.menus; } let siteSearchDomain; let _gBrowser = gBrowser || getBrowser(); let isDomain = function() { try { siteSearchDomain = _gBrowser.currentURI.host; } catch (ex) { return false; } return true; }; if (isDomain()) { items.forEach(function(elem) { elem.removeAttribute('disabled'); }); menus.forEach(function(elem) { if (elem.hasAttribute('searchBySite')) elem.setAttribute('tooltiptext', siteSearchDomain); else if (elem.hasAttribute('searchInCache')) elem.setAttribute('tooltiptext', content.document.title); elem.removeAttribute('disabled'); }); } else { items.forEach(function(elem) { elem.setAttribute('disabled', 'true'); }); menus.forEach(function(elem) { if (elem.hasAttribute('searchBySite') || elem.hasAttribute('searchInCache')) elem.removeAttribute('tooltiptext'); elem.setAttribute('disabled', 'true'); }); } }, createSearchMenu: function() { let searchService = this.searchService; let contextMenu = this.contextMenu; let menu = this.searchMenu; let engines = searchService.getVisibleEngines({}); menu.setAttribute('id', this.nodeIds.searchMenu); menu.setAttribute('class', 'menu-iconic'); this.param.isPinnedEngine = false; this.param.pinnedEngineName = ''; let pinnedEngineName = options.pinnedEngineName; if (pinnedEngineName != '') { for (let i in engines) { if (engines[i].name != pinnedEngineName) continue; menu.setAttribute('label', engines[i].name); menu.setAttribute('image', engines[i].iconURI.spec); menu.engine = engines[i]; this.param.isPinnedEngine = true; this.param.pinnedEngineName = pinnedEngineName; break; } } let currentBrowserEngine = this.isSeaMonkey ? 'currentEngine' : 'defaultEngine'; if (!this.param.isPinnedEngine) { menu.setAttribute('label', searchService[currentBrowserEngine].name); menu.setAttribute('image', (searchService[currentBrowserEngine].iconURI ? searchService[currentBrowserEngine].iconURI.spec : options.defaultIcon)); menu.engine = searchService[currentBrowserEngine]; } menu.gObj = this; menu.setAttribute('onclick', 'if (event.target == this && event.target.engine) this.gObj.searchCommandHandler(event, "menu");'); menu.popup = menu.appendChild(document.createElementNS(XULNS, 'menupopup')); let popup = this.searchMenu.popup; popup.setAttribute('id', this.nodeIds.searchMenuPopup); let counterMaxLength = options.campactMenuLengthPerLine; if (typeof counterMaxLength != 'number' || 3 > counterMaxLength || counterMaxLength > 10) counterMaxLength = 5; let counter = 0; let hBox; let itemCreateCampact = function(engine, last) { if (counter == 0) { hBox = document.createElementNS(XULNS, 'hbox'); let item = document.createElementNS(XULNS, 'spacer'); item.setAttribute('campactMenu', 'true'); hBox.appendChild(item); } counter++; let item = document.createElementNS(XULNS, 'menuitem'); item.engine = engine; item.setAttribute('class', 'menuitem-iconic'); item.setAttribute('tooltiptext', engine.name); let image = document.createElementNS(XULNS, 'image'); image.setAttribute('src', (engine.iconURI ? engine.iconURI.spec : options.defaultIcon)); item.appendChild(image); item.setAttribute('campactMenu', 'true'); hBox.appendChild(item); if (counter == counterMaxLength || last) { popup.appendChild(hBox); counter = 0; } }; let separator = {}; let itemCreate = function(engine, reason) { let item = document.createElementNS(XULNS, 'menuitem'); item.setAttribute('class', 'menuitem-iconic'); item.engine = engine; if (reason && !separator[reason]) { if (!separator['menuseparator']) { let sep = separator['menuseparator'] = document.createElementNS(XULNS, 'menuseparator'); popup.appendChild(sep); } let subMenu = separator[reason] = document.createElementNS(XULNS, 'menu'); subMenu.setAttribute('class', 'menu-iconic'); subMenu.setAttribute('label', _localize(reason)); subMenu.setAttribute(reason, 'true'); subMenu.popup = subMenu.appendChild(document.createElementNS(XULNS, 'menupopup')); popup.appendChild(subMenu); } if (reason == 'searchBySite') { item.setAttribute('label', engine.name); if (options.searchBySite.iconsOn) { item.setAttribute('src', (engine.iconURI ? engine.iconURI.spec : options.defaultIcon)); } item.setAttribute(reason, 'true'); } else if (reason == 'searchImageByText' || reason == 'searchInCache') { item.setAttribute('label', engine.name); item.setAttribute('src', (engine.iconURI_spec != '' ? engine.iconURI_spec : options.defaultIcon)); item.setAttribute(reason, 'true'); } else { item.setAttribute('label', engine.name); item.setAttribute('src', (engine.iconURI ? engine.iconURI.spec : options.defaultIcon)); } if (reason) { let subMenu = separator[reason]; subMenu.popup.appendChild(item); } else popup.appendChild(item); }; for (let i in engines) { if (options.hideDefaultEngineInPopupSubMenu && this.param.isPinnedEngine && engines[i].name == pinnedEngineName || options.hideDefaultEngineInPopupSubMenu && !this.param.isPinnedEngine && engines[i].name == searchService[currentBrowserEngine].name) { continue; } if (options.campactMenu) itemCreateCampact(engines[i], i == engines.length - 1); else itemCreate(engines[i]); } let itemCreateSearchBySite = function() { let namesList = []; if (options.searchBySite.useDefaultNamesList) { let defaultNamesList = [ ['Google', ['Google']], ['Yandex', ['Yandex', 'Яндекс']], ['Yahoo', ['Yahoo']], ['Bing', ['Bing']], ['DuckDuckGo', ['DuckDuckGo']] ]; namesList = namesList.concat(defaultNamesList); } if (options.searchBySite.addCustomNames && Array.isArray(options.searchBySite.customNamesList)) { namesList = namesList.concat(options.searchBySite.customNamesList); } namesList.forEach(function(elem) { for (let i in engines) { if (!(elem[1].some(function(listName) { return listName == engines[i].name }) ) ) continue; itemCreate(engines[i], 'searchBySite'); break; } }); }; if (options.searchBySite.enable) { itemCreateSearchBySite(); } let itemCreateSearchImageByText = function() { let namesList = []; if (options.searchImageByText.useDefaultNamesList) { let defaultNamesList = [ [ 'Google', 'https://www.google.ru/search?tbm=isch&q=', '' ], [ 'Yandex', 'http://images.yandex.ru/yandsearch?text=', '' ] ]; namesList = namesList.concat(defaultNamesList); } if (options.searchImageByText.addCustomNames && Array.isArray(options.searchImageByText.customNamesList)) { namesList = namesList.concat(options.searchImageByText.customNamesList); } namesList.forEach(function(elem) { let engine = {}; engine.name = elem[0]; engine.imageLink = elem[1]; engine.iconURI_spec = elem[2]; // itemCreate(engine, 'searchImageByText'); }); }; if (options.searchImageByText.enable) { itemCreateSearchImageByText(); } let itemCreateSearchInCache = function() { let namesList = []; if (options.searchInCache.useDefaultNamesList) { let defaultNamesList = [ [ 'Google', 'https://www.google.com/search?q=cache:', '' ], [ 'Archive.org', 'http://web.archive.org/web/*/', '' ] ]; namesList = namesList.concat(defaultNamesList); } if (options.searchInCache.addCustomNames && Array.isArray(options.searchInCache.customNamesList)) { namesList = namesList.concat(options.searchInCache.customNamesList); } namesList.forEach(function(elem) { let engine = {}; engine.name = elem[0]; engine.cacheLink = elem[1]; engine.iconURI_spec = elem[2]; // !!! это не engine.iconURI.spec itemCreate(engine, 'searchInCache'); }); }; if (options.searchInCache.enable) { itemCreateSearchInCache(); } popup.gObj = this; popup.setAttribute('oncommand', 'if (!event.target.engine || event.target.nodeName == "menu") return; this.gObj.searchCommandHandler(event);'); popup.setAttribute('onclick', 'checkForMiddleClick(this, event);'); }, searchByImageCommandHandler: function(event) { let inBg = options.loadInBackground || false; if (event.type == 'click' && event.button && event.button == 1) { inBg = !inBg; } let searchByImageMenu = this.searchByImageMenu; let link = event.target.link; let imageLink = searchByImageMenu.imageSrc; if (imageLink.indexOf('data:') == 0) { this.searchByImageByData(imageLink, inBg); return; } else if (imageLink.indexOf('file:') == 0) { this.searchByImageByFile(imageLink, inBg); return; } else { imageLink = encodeURIComponent(imageLink) } let _gBrowser = gBrowser || getBrowser(); _gBrowser.loadOneTab(link + imageLink, { relatedToCurrent: true, inBackground: inBg }); }, // searchByImageByData() and searchByImageByFile() based on // Google Image Search 0.5 by Nishan Naseer // https://addons.mozilla.org/ru/firefox/addon/google-similar-images searchByImageByData: function(src, inBg) { let _gBrowser = gBrowser || getBrowser(); //let tab = gBrowser.addTab(this.searchByImageMenu.popup.googleURL); let tab = _gBrowser.loadOneTab(this.searchByImageMenu.popup.googleURL, { relatedToCurrent: true }); let newTabBrowser = _gBrowser.getBrowserForTab(tab); newTabBrowser.addEventListener('load', function byData(e) { newTabBrowser.removeEventListener(e.type, byData, true); if (src) { try { let image_url; let sub; let form = newTabBrowser.contentDocument.getElementById('qbf'); let inputs = form.getElementsByTagName('input'); for (let k = 0; k < inputs.length; k++) { let i = inputs[k]; if (i.name && i.name == 'image_url') { image_url = i; } if (i.type && i.type == 'submit') { sub = i; } } image_url.value = src; sub.click(); src = null; } catch (ex) {} } }, true); if (!inBg) { getBrowser().selectedTab = tab; } }, searchByImageByFile: function(src, inBg) { //Canvas to get contents in base-64 let canvas = gContextMenu.target.ownerDocument.createElementNS(XHTMLNS, 'canvas'); let image = new Image(); image.src = src; canvas.width = image.width; canvas.height = image.height; let ctx = canvas.getContext('2d'); ctx.drawImage(image, 0, 0); let dataURL = canvas.toDataURL('image/png'); let _gBrowser = gBrowser || getBrowser(); //let tab = gBrowser.addTab(this.searchByImageMenu.popup.googleURL); let tab = _gBrowser.loadOneTab(this.searchByImageMenu.popup.googleURL, { relatedToCurrent: true }); let newTabBrowser = _gBrowser.getBrowserForTab(tab); newTabBrowser.addEventListener('load', function byFile(e) { newTabBrowser.removeEventListener(e.type, byFile, true); if (src) { try { let image_url; let sub; let form = newTabBrowser.contentDocument.getElementById('qbf'); let inputs = form.getElementsByTagName('input'); for (let k = 0; k < inputs.length; k++) { let i = inputs[k]; if (i.name && i.name == 'image_url') { image_url = i; } if (i.type && i.type == 'submit') { sub = i; } } image_url.value = dataURL; sub.click(); src = null; } catch (ex) {} } }, true); if (!inBg) { getBrowser().selectedTab = tab; } }, searchByImageMenuPopup: function(e) { let searchByImageMenu = this.searchByImageMenu; searchByImageMenu.hidden = !gContextMenu.onImage; let src = gContextMenu.mediaURL || gContextMenu.imageURL || gContextMenu.bgImageURL; if (!src || !(/^((ht|f)tps?:\/\/|data:image|file:)/.test(src))) { searchByImageMenu.hidden = true; return; } let popup = searchByImageMenu.popup; let items; if (!popup.items) { let itemsObj = popup.getElementsByTagName('menuitem'); popup.items = []; Array.slice(itemsObj).forEach(function(elem) { if (typeof elem == 'object' && elem.nodeName == 'menuitem' && elem.getAttribute('label') != 'Google') popup.items.push(elem); }); items = popup.items; } else { items = popup.items; } if (/^(data:image|file:)/.test(src)) { items.forEach(function(elem) { elem.setAttribute('disabled', 'true'); }); } else { items.forEach(function(elem) { elem.removeAttribute('disabled'); }); } searchByImageMenu.imageSrc = src; }, createSearchByImageMenu: function() { let menu = document.createElement('menu'); let insertMenu = document.getElementById('context-sep-copyimage'); insertMenu.parentNode.insertBefore(menu, insertMenu); this.searchByImageMenu = menu; menu.setAttribute('id', this.nodeIds.searchByImageMenu); menu.setAttribute('class', 'menu-iconic'); menu.setAttribute('label', _localize('searchByImage')); menu.setAttribute('image', ''); this.searchByImageMenu.popup = menu.appendChild(document.createElementNS(XULNS, 'menupopup')); let popup = this.searchByImageMenu.popup; popup.setAttribute('id', this.nodeIds.searchByImageMenuPopup); popup.googleURL = 'https://www.google.com/searchbyimage'; let namesList = []; if (options.searchByImage.useDefaultNamesList) { let defaultNamesList = [ [ 'Google', 'https://www.google.com/searchbyimage?image_url=', '' ], [ 'Yandex', 'http://images.yandex.ru/yandsearch?rpt=imageview&&img_url=', '' ], [ 'TinEye', 'http://www.tineye.com/search/?pluginver=firefox-1.0&url=', '' ] ]; namesList = namesList.concat(defaultNamesList); } if (options.searchByImage.addCustomNames && Array.isArray(options.searchByImage.customNamesList)) { namesList = namesList.concat(options.searchByImage.customNamesList); } let itemCreate = function(name, link, image) { let item = document.createElementNS(XULNS, 'menuitem'); item.setAttribute('class', 'menuitem-iconic'); item.setAttribute('src', image); item.setAttribute('label', name); item.link = link; popup.appendChild(item); }; namesList.forEach(function(elem) { itemCreate(elem[0], elem[1], elem[2]); }); let contextMenu = this.contextMenu; popup.gObj = this; popup.setAttribute('oncommand', 'this.gObj.searchByImageCommandHandler(event);'); popup.setAttribute('onclick', 'checkForMiddleClick(this, event);'); } }; contextSearcherObj.init(); }());
Отредактировано 2k1dmg (28-12-2015 14:57:08)
Отсутствует
2k1dmg
alert( Cc['@mozilla.org/network/io-service;1'].getService(Ci.nsIIOService) == Services.io ); //== true
Кстати, красивый код у тебя получился.
Отсутствует
Как в этой кнопке сделать чтобы убрать надпись "Поиск <бла-бла> в Google, оставив только Google.
https://forum.mozilla-russia.org/viewto … 50#p703450
Отредактировано villa7 (01-01-2016 14:31:13)
Лучше спросить у знающих - чем лезть не зная.
Отсутствует
Отсутствует