1
0
mirror of https://github.com/gryf/pentadactyl-pm.git synced 2026-02-21 23:05:46 +01:00

More cleanup. Fix some Teledactyl bugginess.

This commit is contained in:
Kris Maglione
2011-09-29 21:25:17 -04:00
parent acd13342a4
commit 0cf1151e0a
21 changed files with 813 additions and 716 deletions

View File

@@ -5,12 +5,6 @@
"use strict";
var Config = Module("config", ConfigBase, {
name: "teledactyl",
appName: "Teledactyl",
idName: "TELEDACTYL",
host: "Thunderbird",
hostbin: "thunderbird",
Local: function Local(dactyl, modules, window)
let ({ config } = modules, { document } = window) {
init: function init() {
@@ -27,8 +21,6 @@ var Config = Module("config", ConfigBase, {
tabmail && tabmail.tabInfo.length ? tabmail.getBrowserForSelectedTab()
: document.getElementById("messagepane"),
get commandContainer() document.documentElement.id,
tabbrowser: {
__proto__: Class.makeClosure.call(window.document.getElementById("tabmail")),
get mTabContainer() this.tabContainer,
@@ -47,16 +39,12 @@ var Config = Module("config", ConfigBase, {
}
},
get hasTabbrowser() !this.isComposeWindow,
get tabStip() this.tabbrowser.tabContainer,
get isComposeWindow() window.wintype == "msgcompose",
get mainWidget() this.isComposeWindow ? document.getElementById("content-frame") : window.GetThreadTree(),
get mainWindowId() this.isComposeWindow ? "msgcomposeWindow" : "messengerWindow",
get browserModes() [modules.modes.MESSAGE],
get mailModes() [modules.modes.NORMAL],
// NOTE: as I don't use TB I have no idea how robust this is. --djk
@@ -115,8 +103,13 @@ var Config = Module("config", ConfigBase, {
focusChange: function focusChange(win) {
const { modes } = modules;
if (win.top == window)
return;
// we switch to -- MESSAGE -- mode for Teledactyl when the main HTML widget gets focus
if (win && win.document instanceof Ci.nsIHTMLDocument || dactyl.focus instanceof Ci.nsIHTMLAnchorElement) {
if (win && win.document instanceof Ci.nsIDOMHTMLDocument
|| dactyl.focusedElement instanceof Ci.nsIDOMHTMLAnchorElement) {
if (this.isComposeWindow)
modes.set(modes.INSERT, modes.TEXT_EDIT);
else if (dactyl.mode != modes.MESSAGE)
@@ -125,54 +118,6 @@ var Config = Module("config", ConfigBase, {
}
},
autocommands: {
DOMLoad: "Triggered when a page's DOM content has fully loaded",
FolderLoad: "Triggered after switching folders in Thunderbird",
PageLoadPre: "Triggered after a page load is initiated",
PageLoad: "Triggered when a page gets (re)loaded/opened",
Enter: "Triggered after Thunderbird starts",
Leave: "Triggered before exiting Thunderbird",
LeavePre: "Triggered before exiting Thunderbird"
},
defaults: {
guioptions: "bCfrs",
complete: "f",
showtabline: 1,
titlestring: "Teledactyl"
},
/*** optional options, there are checked for existence and a fallback provided ***/
features: Class.Memoize(function () Set(
this.isComposeWindow ? ["addressbook"]
: ["hints", "mail", "marks", "addressbook", "tabs"])),
guioptions: {
m: ["MenuBar", ["mail-toolbar-menubar2"]],
T: ["Toolbar" , ["mail-bar2"]],
f: ["Folder list", ["folderPaneBox", "folderpane_splitter"]],
F: ["Folder list header", ["folderPaneHeader"]]
},
// they are sorted by relevance, not alphabetically
helpFiles: ["intro.html", "version.html"],
modes: [
["MESSAGE", { char: "m" }],
["COMPOSE"]
],
get scripts() this.isComposeWindow ? ["compose/compose"] : [
"addressbook",
"mail",
"tabs",
],
overlayChrome: ["chrome://messenger/content/messenger.xul",
"chrome://messenger/content/messengercompose/messengercompose.xul"],
styleableChrome: ["chrome://messenger/content/messenger.xul",
"chrome://messenger/content/messengercompose/messengercompose.xul"],
// to allow Vim to :set ft=mail automatically
tempFile: "teledactyl.eml"
}, {

View File

@@ -179,9 +179,7 @@ var Mail = Module("mail", {
params.type = Ci.nsIMsgCompType.New;
const msgComposeService = Cc["@mozilla.org/messengercompose;1"].getService();
msgComposeService = msgComposeService.QueryInterface(Ci.nsIMsgComposeService);
msgComposeService.OpenComposeWindowWithParams(null, params);
services.compose.OpenComposeWindowWithParams(null, params);
},
// returns an array of nsIMsgFolder objects
@@ -861,8 +859,8 @@ var Mail = Module("mail", {
},
services: function initServices(dactyl, modules, window) {
services.add("smtp", "@mozilla.org/messengercompose/smtp;1", Ci.nsISmtpService);
services.add("compose", "@mozilla.org/messengercompose;1", "nsIMsgComposeService");
},
modes: function initModes(dactyl, modules, window) {
modes.addMode("MESSAGE", {
char: "m",