Source code

Revision control

Copy as Markdown

Other Tools

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
// List of sites we match against Topsites in order to identify sites
// that should be converted to search Topsites
export const SEARCH_SHORTCUTS = [
{ keyword: "@amazon", shortURL: "amazon", url: "https://amazon.com" },
{ keyword: "@\u767E\u5EA6", shortURL: "baidu", url: "https://baidu.com" },
{ keyword: "@google", shortURL: "google", url: "https://google.com" },
{
keyword: "@\u044F\u043D\u0434\u0435\u043A\u0441",
shortURL: "yandex",
},
];
// These can be added via the editor but will not be added organically
export const CUSTOM_SEARCH_SHORTCUTS = [
...SEARCH_SHORTCUTS,
{ keyword: "@bing", shortURL: "bing", url: "https://bing.com" },
{
keyword: "@duckduckgo",
shortURL: "duckduckgo",
},
{ keyword: "@ebay", shortURL: "ebay", url: "https://ebay.com" },
{ keyword: "@twitter", shortURL: "twitter", url: "https://twitter.com" },
{
keyword: "@wikipedia",
shortURL: "wikipedia",
},
];
// Note: you must add the activity stream branch to the beginning of this if using outside activity stream
export const SEARCH_SHORTCUTS_EXPERIMENT =
"improvesearch.topSiteSearchShortcuts";
export const SEARCH_SHORTCUTS_SEARCH_ENGINES_PREF =
"improvesearch.topSiteSearchShortcuts.searchEngines";
export const SEARCH_SHORTCUTS_HAVE_PINNED_PREF =
"improvesearch.topSiteSearchShortcuts.havePinned";
export function getSearchProvider(candidateShortURL) {
return (
SEARCH_SHORTCUTS.filter(match => candidateShortURL === match.shortURL)[0] ||
null
);
}
// Get the search form URL for a given search keyword. This allows us to pick
// different tippytop icons for the different variants. Sush as yandex.com vs. yandex.ru.
// See more details in bug 1643523.
export async function getSearchFormURL(keyword) {
const engine = await Services.search.getEngineByAlias(keyword);
return engine?.wrappedJSObject._searchForm;
}
// Check topsite against predefined list of valid search engines
export async function checkHasSearchEngine(keyword) {
try {
return !!(await Services.search.getAppProvidedEngines()).find(
e => e.aliases.includes(keyword) && !e.hidden
);
} catch {
// When the search service has not successfully initialized,
// there will be no search engines ready.
return false;
}
}