mirror of
https://github.com/gryf/pentadactyl-pm.git
synced 2025-12-20 08:27:59 +01:00
372 lines
17 KiB
JavaScript
372 lines
17 KiB
JavaScript
/***** BEGIN LICENSE BLOCK ***** {{{
|
|
Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
The contents of this file are subject to the Mozilla Public License Version
|
|
1.1 (the "License"); you may not use this file except in compliance with
|
|
the License. You may obtain a copy of the License at
|
|
http://www.mozilla.org/MPL/
|
|
|
|
Software distributed under the License is distributed on an "AS IS" basis,
|
|
WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
for the specific language governing rights and limitations under the
|
|
License.
|
|
|
|
Copyright (c) 2006-2009 by Martin Stubenschrott <stubenschrott@vimperator.org>
|
|
|
|
Alternatively, the contents of this file may be used under the terms of
|
|
either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
in which case the provisions of the GPL or the LGPL are applicable instead
|
|
of those above. If you wish to allow use of your version of this file only
|
|
under the terms of either the GPL or the LGPL, and not to allow others to
|
|
use your version of this file under the terms of the MPL, indicate your
|
|
decision by deleting the provisions above and replace them with the notice
|
|
and other provisions required by the GPL or the LGPL. If you do not delete
|
|
the provisions above, a recipient may use your version of this file under
|
|
the terms of any one of the MPL, the GPL or the LGPL.
|
|
}}} ***** END LICENSE BLOCK *****/
|
|
|
|
const config = { //{{{
|
|
/*** required options, no checks done if they really exist, so be careful ***/
|
|
name: "Vimperator",
|
|
hostApplication: "Firefox",
|
|
|
|
/*** optional options, there are checked for existence and a fallback provided ***/
|
|
features: ["bookmarks", "hints", "history", "marks", "quickmarks", "session", "tabs", "tabs_undo", "windows"],
|
|
defaults: {
|
|
complete: "stlf",
|
|
guioptions: "rb",
|
|
showtabline: 2,
|
|
titlestring: "Vimperator"
|
|
},
|
|
|
|
guioptions: {
|
|
m: ["Menubar", ["toolbar-menubar"]],
|
|
T: ["Toolbar", ["nav-bar"]],
|
|
B: ["Bookmark bar", ["PersonalToolbar"]]
|
|
},
|
|
|
|
get visualbellWindow() getBrowser().mPanelContainer,
|
|
styleableChrome: "chrome://browser/content/browser.xul",
|
|
|
|
autocommands: [["BookmarkAdd", "Triggered after a page is bookmarked"],
|
|
["ColorScheme", "Triggered after a color scheme has been loaded"],
|
|
["DOMLoad", "Triggered when a page's DOM content has fully loaded"],
|
|
["DownloadPost", "Triggered when a download has completed"],
|
|
["Fullscreen", "Triggered when the browser's fullscreen state changes"],
|
|
["LocationChange", "Triggered when changing tabs or when navigation to a new location"],
|
|
["PageLoadPre", "Triggered after a page load is initiated"],
|
|
["PageLoad", "Triggered when a page gets (re)loaded/opened"],
|
|
["PrivateMode", "Triggered when private mode is activated or deactivated"],
|
|
["ShellCmdPost", "Triggered after executing a shell command with :!cmd"],
|
|
["VimperatorEnter", "Triggered after Firefox starts"],
|
|
["VimperatorLeavePre", "Triggered before exiting Firefox, just before destroying each module"],
|
|
["VimperatorLeave", "Triggered before exiting Firefox"]],
|
|
|
|
dialogs: [
|
|
["about", "About Firefox",
|
|
function () { window.openDialog("chrome://browser/content/aboutDialog.xul", "_blank", "chrome,dialog,modal,centerscreen"); }],
|
|
["addbookmark", "Add bookmark for the current page",
|
|
function () { PlacesCommandHook.bookmarkCurrentPage(true, PlacesUtils.bookmarksRootId); }],
|
|
["addons", "Manage Add-ons",
|
|
function () { window.BrowserOpenAddonsMgr(); }],
|
|
["bookmarks", "List your bookmarks",
|
|
function () { window.openDialog("chrome://browser/content/bookmarks/bookmarksPanel.xul", "Bookmarks", "dialog,centerscreen,width=600,height=600"); }],
|
|
["checkupdates", "Check for updates",
|
|
function () { window.checkForUpdates(); }],
|
|
["cleardata", "Clear private data",
|
|
function () { Cc[GLUE_CID].getService(Ci.nsIBrowserGlue).sanitize(window || null); }],
|
|
["cookies", "List your cookies",
|
|
function () { window.toOpenWindowByType("Browser:Cookies", "chrome://browser/content/preferences/cookies.xul", "chrome,dialog=no,resizable"); }],
|
|
["console", "JavaScript console",
|
|
function () { window.toJavaScriptConsole(); }],
|
|
["customizetoolbar", "Customize the Toolbar",
|
|
function () { window.BrowserCustomizeToolbar(); }],
|
|
["dominspector", "DOM Inspector",
|
|
function () { try { window.inspectDOMDocument(content.document); } catch (e) { liberator.echoerr("DOM Inspector extension not installed"); } }],
|
|
["downloads", "Manage Downloads",
|
|
function () { window.toOpenWindowByType("Download:Manager", "chrome://mozapps/content/downloads/downloads.xul", "chrome,dialog=no,resizable"); }],
|
|
["history", "List your history",
|
|
function () { window.openDialog("chrome://browser/content/history/history-panel.xul", "History", "dialog,centerscreen,width=600,height=600"); }],
|
|
["import", "Import Preferences, Bookmarks, History, etc. from other browsers",
|
|
function () { window.BrowserImport(); }],
|
|
["openfile", "Open the file selector dialog",
|
|
function () { window.BrowserOpenFileWindow(); }],
|
|
["pageinfo", "Show information about the current page",
|
|
function () { window.BrowserPageInfo(); }],
|
|
["pagesource", "View page source",
|
|
function () { window.BrowserViewSourceOfDocument(content.document); }],
|
|
["places", "Places Organizer: Manage your bookmarks and history",
|
|
function () { PlacesCommandHook.showPlacesOrganizer(ORGANIZER_ROOT_BOOKMARKS); }],
|
|
["preferences", "Show Firefox preferences dialog",
|
|
function () { window.openPreferences(); }],
|
|
["printpreview", "Preview the page before printing",
|
|
function () { PrintUtils.printPreview(onEnterPrintPreview, onExitPrintPreview); }],
|
|
["printsetup", "Setup the page size and orientation before printing",
|
|
function () { PrintUtils.showPageSetup(); }],
|
|
["print", "Show print dialog",
|
|
function () { PrintUtils.print(); }],
|
|
["saveframe", "Save frame to disk",
|
|
function () { window.saveFrameDocument(); }],
|
|
["savepage", "Save page to disk",
|
|
function () { window.saveDocument(window.content.document); }],
|
|
["searchengines", "Manage installed search engines",
|
|
function () { window.openDialog("chrome://browser/content/search/engineManager.xul", "_blank", "chrome,dialog,modal,centerscreen"); }],
|
|
["selectionsource", "View selection source",
|
|
function () { buffer.viewSelectionSource(); }]
|
|
],
|
|
|
|
hasTabbrowser: true,
|
|
|
|
// they are sorted by relevance, not alphabetically
|
|
helpFiles: [
|
|
"intro.html", "tutorial.html", "starting.html", "browsing.html",
|
|
"buffer.html", "cmdline.html", "insert.html", "options.html",
|
|
"pattern.html", "tabs.html", "hints.html", "map.html", "eval.html",
|
|
"marks.html", "repeat.html", "autocommands.html", "print.html",
|
|
"gui.html", "styling.html", "message.html", "developer.html",
|
|
"various.html", "version.html", "index.html"
|
|
],
|
|
|
|
get ignoreKeys() {
|
|
delete this.ignoreKeys;
|
|
return this.ignoreKeys = {
|
|
"<Return>": modes.NORMAL | modes.INSERT,
|
|
"<Space>": modes.NORMAL | modes.INSERT,
|
|
"<Up>": modes.NORMAL | modes.INSERT,
|
|
"<Down>": modes.NORMAL | modes.INSERT
|
|
};
|
|
},
|
|
|
|
scripts: [
|
|
"browser.js",
|
|
"bookmarks.js",
|
|
"tabs.js"
|
|
],
|
|
|
|
get tempFile() {
|
|
let prefix = this.name.toLowerCase();
|
|
|
|
try
|
|
{
|
|
prefix += "-" + window.content.document.location.hostname;
|
|
}
|
|
catch (e) {}
|
|
|
|
return prefix + ".tmp";
|
|
},
|
|
|
|
init: function ()
|
|
{
|
|
// load Vimperator specific modules
|
|
// FIXME: Why aren't these listed in config.scripts?
|
|
// FIXME: Why isn't this automatic? -> how would one know which classes to load where? --mst
|
|
// Something like:
|
|
// liberator.addModule("search", function Search() { ...
|
|
// for all modules, or something similar. For modules which
|
|
// require other modules, well, there's addObserver("load_foo",
|
|
// or we could just make sure that they're all sourced in order.
|
|
// The scripts could even just instantiate them themselves.
|
|
// --Kris
|
|
liberator.loadModule("browser", Browser);
|
|
liberator.loadModule("finder", Finder);
|
|
liberator.loadModule("bookmarks", Bookmarks);
|
|
liberator.loadModule("history", History);
|
|
liberator.loadModule("tabs", Tabs);
|
|
liberator.loadModule("marks", Marks);
|
|
liberator.loadModule("quickmarks", QuickMarks);
|
|
liberator.loadModule("hints", Hints);
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
////////////////////// STYLES //////////////////////////////////////////////////
|
|
/////////////////////////////////////////////////////////////////////////////{{{
|
|
|
|
let img = Image();
|
|
img.src = "chrome://vimperator/content/logo.png";
|
|
img.onload = function () {
|
|
styles.addSheet(true, "logo", "chrome://liberator/locale/*",
|
|
".vimperator-logo {" + <>
|
|
display: inline-block;
|
|
background: url({img.src});
|
|
width: {img.width}px;
|
|
height: {img.height}px;
|
|
</> + "}",
|
|
true);
|
|
delete img;
|
|
};
|
|
|
|
/////////////////////////////////////////////////////////////////////////////}}}
|
|
////////////////////// MAPPINGS ////////////////////////////////////////////////
|
|
/////////////////////////////////////////////////////////////////////////////{{{
|
|
|
|
/////////////////////////////////////////////////////////////////////////////}}}
|
|
////////////////////// COMMANDS ////////////////////////////////////////////////
|
|
/////////////////////////////////////////////////////////////////////////////{{{
|
|
|
|
commands.add(["pref[erences]", "prefs"],
|
|
"Show " + config.hostApplication + " preferences",
|
|
function (args)
|
|
{
|
|
if (args.bang) // open Firefox settings GUI dialog
|
|
{
|
|
liberator.open("about:config",
|
|
(options["newtab"] && options.get("newtab").has("all", "prefs"))
|
|
? liberator.NEW_TAB : liberator.CURRENT_TAB);
|
|
}
|
|
else
|
|
window.openPreferences();
|
|
},
|
|
{
|
|
argCount: "0",
|
|
bang: true
|
|
});
|
|
|
|
commands.add(["sbcl[ose]"],
|
|
"Close the sidebar window",
|
|
function ()
|
|
{
|
|
if (!document.getElementById("sidebar-box").hidden)
|
|
toggleSidebar();
|
|
},
|
|
{ argCount: "0" });
|
|
|
|
commands.add(["sideb[ar]", "sb[ar]", "sbope[n]"],
|
|
"Open the sidebar window",
|
|
function (args)
|
|
{
|
|
let arg = args.literalArg;
|
|
function compare(a, b) util.compareIgnoreCase(a, b) == 0
|
|
|
|
// focus if the requested sidebar is already open
|
|
if (compare(document.getElementById("sidebar-title").value, arg))
|
|
{
|
|
document.getElementById("sidebar-box").focus();
|
|
return;
|
|
}
|
|
|
|
let menu = document.getElementById("viewSidebarMenu");
|
|
|
|
for (let [,panel] in Iterator(menu.childNodes))
|
|
{
|
|
if (compare(panel.label, arg))
|
|
{
|
|
panel.doCommand();
|
|
return;
|
|
}
|
|
}
|
|
|
|
liberator.echoerr("No sidebar " + arg + " found");
|
|
},
|
|
{
|
|
argCount: "1",
|
|
completer: function (context)
|
|
{
|
|
context.ignoreCase = true;
|
|
return completion.sidebar(context);
|
|
},
|
|
literal: 0
|
|
});
|
|
|
|
commands.add(["wind[ow]"],
|
|
"Execute a command and tell it to output in a new window",
|
|
function (args)
|
|
{
|
|
liberator.forceNewWindow = true;
|
|
liberator.execute(args.string, null, true);
|
|
liberator.forceNewWindow = false;
|
|
},
|
|
{
|
|
argCount: "+",
|
|
completer: function (context) completion.ex(context),
|
|
literal: 0
|
|
});
|
|
|
|
commands.add(["winc[lose]", "wc[lose]"],
|
|
"Close window",
|
|
function () { window.close(); },
|
|
{ argCount: "0" });
|
|
|
|
commands.add(["wino[pen]", "wo[pen]", "wine[dit]"],
|
|
"Open one or more URLs in a new window",
|
|
function (args)
|
|
{
|
|
args = args.string;
|
|
|
|
if (args)
|
|
liberator.open(args, liberator.NEW_WINDOW);
|
|
else
|
|
liberator.open("about:blank", liberator.NEW_WINDOW);
|
|
},
|
|
{
|
|
completer: function (context) completion.url(context),
|
|
literal: 0
|
|
});
|
|
|
|
/////////////////////////////////////////////////////////////////////////////}}}
|
|
////////////////////// OPTIONS /////////////////////////////////////////////////
|
|
/////////////////////////////////////////////////////////////////////////////{{{
|
|
|
|
options.add(["online"],
|
|
"Set the 'work offline' option",
|
|
"boolean", true,
|
|
{
|
|
setter: function (value)
|
|
{
|
|
const ioService = services.get("io");
|
|
if (ioService.offline == value)
|
|
BrowserOffline.toggleOfflineStatus();
|
|
return value;
|
|
},
|
|
getter: function () !services.get("io").offline
|
|
});
|
|
|
|
/////////////////////////////////////////////////////////////////////////////}}}
|
|
////////////////////// COMPLETIONS /////////////////////////////////////////////
|
|
/////////////////////////////////////////////////////////////////////////////{{{
|
|
|
|
completion.location = function location(context) {
|
|
if (!services.get("autoCompleteSearch"))
|
|
return;
|
|
|
|
context.anchored = false;
|
|
context.title = ["Smart Completions"];
|
|
context.keys.icon = 2;
|
|
context.incomplete = true;
|
|
context.hasItems = context.completions.length > 0; // XXX
|
|
context.filterFunc = null;
|
|
context.cancel = function () services.get("autoCompleteSearch").stopSearch();
|
|
context.compare = CompletionContext.Sort.unsorted;
|
|
let timer = new Timer(50, 100, function (result) {
|
|
context.incomplete = result.searchResult >= result.RESULT_NOMATCH_ONGOING;
|
|
context.completions = [
|
|
[result.getValueAt(i), result.getCommentAt(i), result.getImageAt(i)]
|
|
for (i in util.range(0, result.matchCount))
|
|
];
|
|
});
|
|
services.get("autoCompleteSearch").stopSearch();
|
|
services.get("autoCompleteSearch").startSearch(context.filter, "", context.result, {
|
|
onSearchResult: function onSearchResult(search, result) {
|
|
context.result = result;
|
|
timer.tell(result);
|
|
if (result.searchResult <= result.RESULT_SUCCESS)
|
|
timer.flush();
|
|
}
|
|
});
|
|
};
|
|
|
|
completion.sidebar = function sidebar(context) {
|
|
let menu = document.getElementById("viewSidebarMenu");
|
|
context.title = ["Sidebar Panel"];
|
|
context.completions = Array.map(menu.childNodes, function (n) [n.label, ""]);
|
|
};
|
|
|
|
completion.addUrlCompleter("l",
|
|
"Firefox location bar entries (bookmarks and history sorted in an intelligent way)",
|
|
completion.location);
|
|
|
|
//}}}
|
|
}
|
|
}; //}}}
|
|
|
|
// vim: set fdm=marker sw=4 ts=4 et:
|