diff options
Diffstat (limited to 'src/background/shared')
-rw-r--r-- | src/background/shared/completions/bookmarks.js | 15 | ||||
-rw-r--r-- | src/background/shared/completions/index.js | 22 |
2 files changed, 36 insertions, 1 deletions
diff --git a/src/background/shared/completions/bookmarks.js b/src/background/shared/completions/bookmarks.js new file mode 100644 index 0000000..aedaccf --- /dev/null +++ b/src/background/shared/completions/bookmarks.js @@ -0,0 +1,15 @@ +const getCompletions = (keywords) => { + return browser.bookmarks.search({ query: keywords }).then((items) => { + return items.filter((item) => { + let url = undefined; + try { + url = new URL(item.url); + } catch (e) { + return false; + } + return item.type === 'bookmark' && url.protocol !== 'place:'; + }); + }); +}; + +export { getCompletions }; diff --git a/src/background/shared/completions/index.js b/src/background/shared/completions/index.js index 5bfdbfb..8ecdcfc 100644 --- a/src/background/shared/completions/index.js +++ b/src/background/shared/completions/index.js @@ -1,5 +1,6 @@ import * as tabs from './tabs'; import * as histories from './histories'; +import * as bookmarks from './bookmarks'; const getSearchCompletions = (command, keywords, searchConfig) => { let engineNames = Object.keys(searchConfig.engines); @@ -23,11 +24,24 @@ const getHistoryCompletions = (command, keywords) => { }); }; +const getBookmarksCompletions = (command, keywords) => { + return bookmarks.getCompletions(keywords).then((items) => { + return items.map((item) => { + return { + caption: item.title, + content: command + ' ' + item.url, + url: item.url, + }; + }); + }); +}; + const getOpenCompletions = (command, keywords, searchConfig) => { return Promise.all([ getSearchCompletions(command, keywords, searchConfig), getHistoryCompletions(command, keywords), - ]).then(([engineItems, historyItems]) => { + getBookmarksCompletions(command, keywords), + ]).then(([engineItems, historyItems, bookmarkItems]) => { let completions = []; if (engineItems.length > 0) { completions.push({ @@ -41,6 +55,12 @@ const getOpenCompletions = (command, keywords, searchConfig) => { items: historyItems }); } + if (bookmarkItems.length > 0) { + completions.push({ + name: 'Bookmarks', + items: bookmarkItems + }); + } return completions; }); }; |