diff options
author | wolfbeast <mcwerewolf@gmail.com> | 2018-06-04 15:50:03 +0200 |
---|---|---|
committer | wolfbeast <mcwerewolf@gmail.com> | 2018-06-04 15:50:03 +0200 |
commit | e3b7744bee37c3d4a026d2193bed5e9439c40ff3 (patch) | |
tree | f3f7b07ca9bd78bf7ac2d76dd55b61b2a8bb549e /application/basilisk/components/newtab/NewTabSearchProvider.jsm | |
parent | cbce4f0b6a337f8250b62cae028f1c6d4cce51df (diff) | |
parent | 031afcafe288bf0f46c0c5caae20dd3db8bd0297 (diff) | |
download | UXP-e3b7744bee37c3d4a026d2193bed5e9439c40ff3.tar UXP-e3b7744bee37c3d4a026d2193bed5e9439c40ff3.tar.gz UXP-e3b7744bee37c3d4a026d2193bed5e9439c40ff3.tar.lz UXP-e3b7744bee37c3d4a026d2193bed5e9439c40ff3.tar.xz UXP-e3b7744bee37c3d4a026d2193bed5e9439c40ff3.zip |
Merge branch 'move-basilisk'
Diffstat (limited to 'application/basilisk/components/newtab/NewTabSearchProvider.jsm')
-rw-r--r-- | application/basilisk/components/newtab/NewTabSearchProvider.jsm | 103 |
1 files changed, 103 insertions, 0 deletions
diff --git a/application/basilisk/components/newtab/NewTabSearchProvider.jsm b/application/basilisk/components/newtab/NewTabSearchProvider.jsm new file mode 100644 index 000000000..a50d8c706 --- /dev/null +++ b/application/basilisk/components/newtab/NewTabSearchProvider.jsm @@ -0,0 +1,103 @@ +/* global XPCOMUtils, ContentSearch, Task, Services, EventEmitter */ +/* exported NewTabSearchProvider */ + +"use strict"; + +this.EXPORTED_SYMBOLS = ["NewTabSearchProvider"]; + +const {utils: Cu, interfaces: Ci} = Components; +const CURRENT_ENGINE = "browser-search-engine-modified"; + +Cu.import("resource://gre/modules/XPCOMUtils.jsm"); +Cu.import("resource://gre/modules/Task.jsm"); +Cu.import("resource://gre/modules/Services.jsm"); + +XPCOMUtils.defineLazyModuleGetter(this, "ContentSearch", + "resource:///modules/ContentSearch.jsm"); + +XPCOMUtils.defineLazyGetter(this, "EventEmitter", function() { + const {EventEmitter} = Cu.import("resource://devtools/shared/event-emitter.js", {}); + return EventEmitter; +}); + +function SearchProvider() { + EventEmitter.decorate(this); +} + +SearchProvider.prototype = { + + observe(subject, topic, data) { // jshint unused:false + // all other topics are not relevant to content searches and can be + // ignored by NewTabSearchProvider + if (data === "engine-current" && topic === CURRENT_ENGINE) { + Task.spawn(function* () { + try { + let state = yield ContentSearch.currentStateObj(true); + let engine = state.currentEngine; + this.emit(CURRENT_ENGINE, engine); + } catch (e) { + Cu.reportError(e); + } + }.bind(this)); + } + }, + + init() { + try { + Services.obs.addObserver(this, CURRENT_ENGINE, true); + } catch (e) { + Cu.reportError(e); + } + }, + + QueryInterface: XPCOMUtils.generateQI([Ci.nsIObserver, + Ci.nsISupportsWeakReference + ]), + + uninit() { + try { + Services.obs.removeObserver(this, CURRENT_ENGINE, true); + } catch (e) { + Cu.reportError(e); + } + }, + + get searchSuggestionUIStrings() { + return ContentSearch.searchSuggestionUIStrings; + }, + + removeFormHistory({browser}, suggestion) { + ContentSearch.removeFormHistoryEntry({target: browser}, suggestion); + }, + + manageEngines(browser) { + const browserWin = browser.ownerGlobal; + browserWin.openPreferences("paneSearch"); + }, + + asyncGetState: Task.async(function*() { + let state = yield ContentSearch.currentStateObj(true); + return state; + }), + + asyncPerformSearch: Task.async(function*({browser}, searchData) { + ContentSearch.performSearch({target: browser}, searchData); + yield ContentSearch.addFormHistoryEntry({target: browser}, searchData.searchString); + }), + + asyncCycleEngine: Task.async(function*(engineName) { + Services.search.currentEngine = Services.search.getEngineByName(engineName); + let state = yield ContentSearch.currentStateObj(true); + let newEngine = state.currentEngine; + this.emit(CURRENT_ENGINE, newEngine); + }), + + asyncGetSuggestions: Task.async(function*(engineName, searchString, target) { + let suggestions = ContentSearch.getSuggestions(engineName, searchString, target.browser); + return suggestions; + }), +}; + +const NewTabSearchProvider = { + search: new SearchProvider(), +}; |