1
0
mirror of https://github.com/gryf/pentadactyl-pm.git synced 2026-01-08 07:34:11 +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

71
teledactyl/config.json Normal file
View File

@@ -0,0 +1,71 @@
{
"name": "teledactyl",
"appName": "Teledactyl",
"idName": "TELEDACTYL",
"host": "Thunderbird",
"hostbin": "thunderbird",
"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"
},
"guioptions": {
"m": ["MenuBar", ["mail-toolbar-menubar2"]],
"T": ["Toolbar", ["mail-bar2"]]
},
"option-defaults": {
"complete": "f",
"showtabline": 1,
"titlestring": "Teledactyl"
},
"overlays": {
"chrome://messenger/content/messenger.xul": {
"features": [
"hints",
"mail",
"marks",
"addressbook",
"tabs"
],
"guioptions": {
"f": ["Folder list", ["folderPaneBox", "folderpane_splitter"]],
"F": ["Folder list header", ["folderPaneHeader"]]
},
"option-defaults": {
"guioptions": "bCfrs"
},
"scripts": [
"addressbook",
"mail",
"tabs"
]
},
"chrome://messenger/content/messengercompose/messengercompose.xul": {
"is-compose-window": true,
"features": [
"addressbook"
],
"option-defaults": {
"guioptions": "bCrs"
},
"scripts": [
"compose/compose"
]
}
}
}

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",