diff options
author | wolfbeast <mcwerewolf@gmail.com> | 2018-06-04 13:17:38 +0200 |
---|---|---|
committer | wolfbeast <mcwerewolf@gmail.com> | 2018-06-04 13:17:38 +0200 |
commit | a1be17c1cea81ebb1e8b131a662c698d78f3f7f2 (patch) | |
tree | a92f7de513be600cc07bac458183e9af40e00c06 /application/basilisk/components/webextensions/ext-omnibox.js | |
parent | bf11fdd304898ac675e39b01b280d39550e419d0 (diff) | |
download | UXP-a1be17c1cea81ebb1e8b131a662c698d78f3f7f2.tar UXP-a1be17c1cea81ebb1e8b131a662c698d78f3f7f2.tar.gz UXP-a1be17c1cea81ebb1e8b131a662c698d78f3f7f2.tar.lz UXP-a1be17c1cea81ebb1e8b131a662c698d78f3f7f2.tar.xz UXP-a1be17c1cea81ebb1e8b131a662c698d78f3f7f2.zip |
Issue #303 Part 1: Move basilisk files from /browser to /application/basilisk
Diffstat (limited to 'application/basilisk/components/webextensions/ext-omnibox.js')
-rw-r--r-- | application/basilisk/components/webextensions/ext-omnibox.js | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/application/basilisk/components/webextensions/ext-omnibox.js b/application/basilisk/components/webextensions/ext-omnibox.js new file mode 100644 index 000000000..9b2f60ca4 --- /dev/null +++ b/application/basilisk/components/webextensions/ext-omnibox.js @@ -0,0 +1,104 @@ +/* -*- Mode: indent-tabs-mode: nil; js-indent-level: 2 -*- */ +/* vim: set sts=2 sw=2 et tw=80: */ +"use strict"; + +Cu.import("resource://gre/modules/ExtensionUtils.jsm"); + +XPCOMUtils.defineLazyModuleGetter(this, "ExtensionSearchHandler", + "resource://gre/modules/ExtensionSearchHandler.jsm"); +var { + SingletonEventManager, +} = ExtensionUtils; + +// WeakMap[extension -> keyword] +let gKeywordMap = new WeakMap(); + +/* eslint-disable mozilla/balanced-listeners */ +extensions.on("manifest_omnibox", (type, directive, extension, manifest) => { + let keyword = manifest.omnibox.keyword; + try { + // This will throw if the keyword is already registered. + ExtensionSearchHandler.registerKeyword(keyword, extension); + gKeywordMap.set(extension, keyword); + } catch (e) { + extension.manifestError(e.message); + } +}); + +extensions.on("shutdown", (type, extension) => { + let keyword = gKeywordMap.get(extension); + if (keyword) { + ExtensionSearchHandler.unregisterKeyword(keyword); + gKeywordMap.delete(extension); + } +}); +/* eslint-enable mozilla/balanced-listeners */ + +extensions.registerSchemaAPI("omnibox", "addon_parent", context => { + let {extension} = context; + return { + omnibox: { + setDefaultSuggestion(suggestion) { + let keyword = gKeywordMap.get(extension); + try { + // This will throw if the keyword failed to register. + ExtensionSearchHandler.setDefaultSuggestion(keyword, suggestion); + } catch (e) { + return Promise.reject(e.message); + } + }, + + onInputStarted: new SingletonEventManager(context, "omnibox.onInputStarted", fire => { + let listener = (eventName) => { + fire(); + }; + extension.on(ExtensionSearchHandler.MSG_INPUT_STARTED, listener); + return () => { + extension.off(ExtensionSearchHandler.MSG_INPUT_STARTED, listener); + }; + }).api(), + + onInputCancelled: new SingletonEventManager(context, "omnibox.onInputCancelled", fire => { + let listener = (eventName) => { + fire(); + }; + extension.on(ExtensionSearchHandler.MSG_INPUT_CANCELLED, listener); + return () => { + extension.off(ExtensionSearchHandler.MSG_INPUT_CANCELLED, listener); + }; + }).api(), + + onInputEntered: new SingletonEventManager(context, "omnibox.onInputEntered", fire => { + let listener = (eventName, text, disposition) => { + fire(text, disposition); + }; + extension.on(ExtensionSearchHandler.MSG_INPUT_ENTERED, listener); + return () => { + extension.off(ExtensionSearchHandler.MSG_INPUT_ENTERED, listener); + }; + }).api(), + }, + + omnibox_internal: { + addSuggestions(id, suggestions) { + let keyword = gKeywordMap.get(extension); + try { + ExtensionSearchHandler.addSuggestions(keyword, id, suggestions); + } catch (e) { + // Silently fail because the extension developer can not know for sure if the user + // has already invalidated the callback when asynchronously providing suggestions. + } + }, + + onInputChanged: new SingletonEventManager(context, "omnibox_internal.onInputChanged", fire => { + let listener = (eventName, text, id) => { + fire(text, id); + }; + extension.on(ExtensionSearchHandler.MSG_INPUT_CHANGED, listener); + return () => { + extension.off(ExtensionSearchHandler.MSG_INPUT_CHANGED, listener); + }; + }).api(), + }, + }; +}); |