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:
71
teledactyl/config.json
Normal file
71
teledactyl/config.json
Normal 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"
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -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"
|
||||
}, {
|
||||
|
||||
@@ -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",
|
||||
|
||||
Reference in New Issue
Block a user