1 // Copyright (c) 2006-2009 by Martin Stubenschrott <stubenschrott@vimperator.org>
2 // Copyright (c) 2007-2011 by Doug Kearns <dougkearns@gmail.com>
3 // Copyright (c) 2008-2011 by Kris Maglione <maglione.k at Gmail>
5 // This work is licensed for reuse under an MIT license. Details are
6 // given in the LICENSE.txt file included with this file.
9 var Config = Module("config", ConfigBase, {
10 Local: function Local(dactyl, modules, window)
11 let ({ config } = modules) ({
14 about: ["About Firefox",
15 function () { window.openDialog("chrome://browser/content/aboutDialog.xul", "_blank", "chrome,dialog,modal,centerscreen"); }],
16 addbookmark: ["Add bookmark for the current page",
17 function () { window.PlacesCommandHook.bookmarkCurrentPage(true, window.PlacesUtils.bookmarksRootId); }],
18 addons: ["Manage Add-ons",
19 function () { window.BrowserOpenAddonsMgr(); }],
20 bookmarks: ["List your bookmarks",
21 function () { window.openDialog("chrome://browser/content/bookmarks/bookmarksPanel.xul", "Bookmarks", "dialog,centerscreen,width=600,height=600"); }],
22 checkupdates: ["Check for updates",
23 function () { window.checkForUpdates(); },
24 () => "checkForUpdates" in window],
25 cookies: ["List your cookies",
26 function () { window.toOpenWindowByType("Browser:Cookies", "chrome://browser/content/preferences/cookies.xul", "chrome,dialog=no,resizable"); }],
27 console: ["Browser console",
28 function () { window.HUDService.toggleBrowserConsole(); }],
29 customizetoolbar: ["Customize the Toolbar",
30 function () { window.BrowserCustomizeToolbar(); }],
31 dominspector: ["DOM Inspector",
32 function () { window.inspectDOMDocument(window.content.document); },
33 () => "inspectDOMDocument" in window],
34 downloads: ["Manage Downloads",
35 function () { window.BrowserDownloadsUI(); }],
36 history: ["List your history",
37 function () { window.openDialog("chrome://browser/content/history/history-panel.xul", "History", "dialog,centerscreen,width=600,height=600"); }],
38 openfile: ["Open the file selector dialog",
39 function () { window.BrowserOpenFileWindow(); }],
40 pageinfo: ["Show information about the current page",
41 function () { window.BrowserPageInfo(); }],
42 pagesource: ["View page source",
43 function () { window.BrowserViewSourceOfDocument(window.content.document); }],
44 passwords: ["Passwords dialog",
45 function () { window.openDialog("chrome://passwordmgr/content/passwordManager.xul"); }],
46 places: ["Places Organizer: Manage your bookmarks and history",
47 function () { window.PlacesCommandHook.showPlacesOrganizer(window.ORGANIZER_ROOT_BOOKMARKS); }],
48 preferences: ["Show Firefox preferences dialog",
49 function () { window.openPreferences(); }],
50 printpreview: ["Preview the page before printing",
51 function () { window.PrintUtils.printPreview(window.PrintPreviewListener || window.onEnterPrintPreview, window.onExitPrintPreview); }],
52 printsetup: ["Setup the page size and orientation before printing",
53 function () { window.PrintUtils.showPageSetup(); }],
54 print: ["Show print dialog",
55 function () { window.PrintUtils.print(); }],
56 saveframe: ["Save frame to disk",
57 function () { window.saveFrameDocument(); }],
58 savepage: ["Save page to disk",
59 function () { window.saveDocument(window.content.document); }],
60 searchengines: ["Manage installed search engines",
61 function () { window.openDialog("chrome://browser/content/search/engineManager.xul", "_blank", "chrome,dialog,modal,centerscreen"); }],
62 selectionsource: ["View selection source",
63 function () { modules.buffer.viewSelectionSource(); }],
64 venkman: ["The JavaScript debugger",
65 function () { dactyl.assert("start_venkman" in window, "Venkman is not installed"); window.start_venkman() },
66 () => "start_venkman" in window]
69 removeTab: function removeTab(tab) {
70 if (window.gInPrintPreviewMode)
71 window.PrintUtils.exitPrintPreview();
72 else if (this.tabbrowser.mTabs.length > 1)
73 this.tabbrowser.removeTab(tab);
75 if (modules.buffer.uri.spec !== "about:blank" || window.getWebNavigation().sessionHistory.count > 0) {
76 dactyl.open("about:blank", dactyl.NEW_BACKGROUND_TAB);
77 this.tabbrowser.removeTab(tab);
87 commands: function initCommands(dactyl, modules, window) {
88 const { commands, completion, config } = modules;
89 const { document } = window;
91 commands.add(["winon[ly]"],
92 "Close all other windows",
94 dactyl.windows.forEach(function (win) {
101 commands.add(["pref[erences]", "prefs"],
102 "Show " + config.host + " preferences",
104 if (args.bang) // open Firefox settings GUI dialog
105 dactyl.open("about:config", { from: "prefs" });
107 window.openPreferences();
114 commands.add(["sbcl[ose]"],
115 "Close the sidebar window",
117 if (!document.getElementById("sidebar-box").hidden)
118 window.toggleSidebar();
122 commands.add(["sideb[ar]", "sb[ar]", "sbop[en]"],
123 "Open the sidebar window",
125 function compare(a, b) util.compareIgnoreCase(a, b) == 0
126 let title = document.getElementById("sidebar-title");
128 dactyl.assert(args.length || title.value || args.bang && config.lastSidebar,
129 _("error.argumentRequired"));
132 return window.toggleSidebar(title.value ? null : config.lastSidebar);
134 // focus if the requested sidebar is already open
135 if (compare(title.value, args[0])) {
137 return window.toggleSidebar();
138 return dactyl.focus(document.getElementById("sidebar-box"));
141 let menu = document.getElementById("viewSidebarMenu");
143 for (let [, panel] in Iterator(menu.childNodes))
144 if (compare(panel.getAttribute("label"), args[0])) {
145 let elem = document.getElementById(panel.observes);
151 return dactyl.echoerr(_("error.invalidArgument", args[0]));
156 completer: function (context) {
157 context.ignoreCase = true;
158 return completion.sidebar(context);
163 commands.add(["wind[ow]"],
164 "Execute a command and tell it to output in a new window",
166 dactyl.withSavedValues(["forceTarget"], function () {
167 this.forceTarget = dactyl.NEW_WINDOW;
168 this.execute(args[0], null, true);
173 completer: function (context) completion.ex(context),
178 commands.add(["winc[lose]", "wc[lose]"],
180 function () { window.close(); },
183 commands.add(["wino[pen]", "wo[pen]"],
184 "Open one or more URLs in a new window",
187 dactyl.open(args[0], dactyl.NEW_WINDOW);
189 dactyl.open("about:blank", dactyl.NEW_WINDOW);
192 completer: function (context) completion.url(context),
193 domains: function (args) commands.get("open").domains(args),
198 completion: function initCompletion(dactyl, modules, window) {
199 const { CompletionContext, bookmarkcache, completion } = modules;
200 const { document } = window;
202 completion.location = function location(context) {
203 completion.autocomplete("history", context);
204 context.title = ["Smart Completions"];
207 completion.addUrlCompleter("location",
208 "Firefox location bar entries (bookmarks and history sorted in an intelligent way)",
209 completion.location);
211 completion.sidebar = function sidebar(context) {
212 let menu = document.getElementById("viewSidebarMenu");
213 context.title = ["Sidebar Panel"];
214 context.completions = Array.filter(menu.childNodes, n => n.hasAttribute("label"))
215 .map(n => [n.getAttribute("label"), ""]);
218 events: function initEvents(dactyl, modules, window) {
219 modules.events.listen(window, "SidebarFocused", function (event) {
220 modules.config.lastSidebar = window.document.getElementById("sidebar-box")
221 .getAttribute("sidebarcommand");
224 mappings: function initMappings(dactyl, modules, window) {
225 const { Events, mappings, modes } = modules;
226 mappings.add([modes.NORMAL],
227 ["<Return>", "<Up>", "<Down>"],
228 "Handled by " + config.host,
229 () => Events.PASS_THROUGH);
231 options: function initOptions(dactyl, modules, window) {
232 modules.options.add(["online"],
233 "Enables or disables offline mode",
236 setter: function (value) {
237 if (services.io.offline == value)
238 window.BrowserOffline.toggleOfflineStatus();
241 getter: function () !services.io.offline
246 // vim: set fdm=marker sw=4 sts=4 ts=8 et: