aboutsummaryrefslogtreecommitdiffstats
path: root/content_scripts/vomnibar.coffee
blob: c23a4e6fa5809c2ba899e9a4120fd3bb40a1f7b1 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#
# This wraps the vomnibar iframe, which we inject into the page to provide the vomnibar.
#
Vomnibar =
  vomnibarUI: null

  # Parse any additional options from the command's registry entry.  Currently, this only includes a flag of
  # the form "keyword=X", for direct activation of a custom search engine.
  parseRegistryEntry: (registryEntry = { options: [] }, callback = null) ->
    searchEngines = Settings.get("searchEngines") ? ""
    SearchEngines.refreshAndUse searchEngines, (engines) ->
      callback? registryEntry.options

  # sourceFrameId here (and below) is the ID of the frame from which this request originates, which may be different
  # from the current frame.

  activate: (sourceFrameId, registryEntry) ->
    @parseRegistryEntry registryEntry, (options) =>
      @open sourceFrameId, extend options, completer:"omni"

  activateInNewTab: (sourceFrameId, registryEntry) ->
    @parseRegistryEntry registryEntry, (options) =>
      @open sourceFrameId, extend options, completer:"omni", newTab: true

  activateTabSelection: (sourceFrameId) -> @open sourceFrameId, {
    completer: "tabs"
    selectFirst: true
  }
  activateBookmarks: (sourceFrameId) -> @open sourceFrameId, {
    completer: "bookmarks"
    selectFirst: true
  }
  activateBookmarksInNewTab: (sourceFrameId) -> @open sourceFrameId, {
    completer: "bookmarks"
    selectFirst: true
    newTab: true
  }
  activateEditUrl: (sourceFrameId) -> @open sourceFrameId, {
    completer: "omni"
    selectFirst: false
    query: window.location.href
  }
  activateEditUrlInNewTab: (sourceFrameId) -> @open sourceFrameId, {
    completer: "omni"
    selectFirst: false
    query: window.location.href
    newTab: true
  }

  init: ->
    unless @vomnibarUI?
      @vomnibarUI = new UIComponent "pages/vomnibar.html", "vomnibarFrame", (event) =>
        @vomnibarUI.hide() if event.data == "hide"
      # Whenever the window receives the focus, we tell the Vomnibar UI that it has been hidden (regardless of
      # whether it was previously visible).
      window.addEventListener "focus", (event) =>
        @vomnibarUI.postMessage "hidden" if event.target == window; true


  # This function opens the vomnibar. It accepts options, a map with the values:
  #   completer   - The completer to fetch results from.
  #   query       - Optional. Text to prefill the Vomnibar with.
  #   selectFirst - Optional, boolean. Whether to select the first entry.
  #   newTab      - Optional, boolean. Whether to open the result in a new tab.
  open: (sourceFrameId, options) ->
    @init()
    if @vomnibarUI?.uiComponentIsReady
      @vomnibarUI.activate extend options, { sourceFrameId }

root = exports ? window
root.Vomnibar = Vomnibar