Skip to content

siefkenj/MailMergeP

Repository files navigation

Mail Merge P

Mail Merge P (Mail Merge with Preview) is a Thunderbird add-on to send bulk emails based off information provided in a spreadsheet.

Mail Merge P uses the nunjucks templating engine to fill email templates based on data provided by a spreadsheet.

Usage

Prepare a spreadsheet with a single header row. Any templating variable you wish to be filled, wrap in {{..}}. For example, if your spreadsheet has headers name and email, you can use {{name}} and {{email}} in the body/subject/to/cc/bcc fields of your email. Mail Merge P will then substitute data from the spreadsheet into these fields.

You can use the full power of the nunjucks templating engine, but be aware that all data from a spreadsheet is interpreted as a string.

Install

You can play around with the main ui-component in the browser: https://siefkenj.github.io/MailMerge/browser-iframe-server.html

Mail Merge P is based off of Mail Merge by Alexander Bergmann https://addons.thunderbird.net/en-US/thunderbird/addon/mail-merge/

Building

Build the entire extension, first run

npm install

then either

npm run build-and-package
npm run build
npm run build-addon
npm run package-addon

The extension will be located in the current directory and called [email protected].

Development

Mail Merge P is divided into npm workspaces located in the packages/ directory.

  • packages/interface the bulk of the UI code. This code runs in an iframe.
  • packages/iframe-service an abstraction layer so that the interface can be run in the browser or in thunderbird.
  • packages/browser-preview a browser-based implementation of the thunderbird API, so that the UI can be developed more quickly (with technology like hot-reloading)
  • packages/thunderbird-iframe-service the connection between the real thunderbird API and iframe-service.
  • packages/thunderbird-extension the actual extension's background.js script.

Most UI and backend work is handled by the html components. The thunderbird-extension runs the html component in an iframe and uses message passing to communicate with the iframe.

This split means that the bulk of Mail Merge P can be developed in the browser without Thunderbird.

To run thunderbird and force a reload of all extension content, launch thunderbird with

thunderbird -purgecaches

Developing the HTML UI

A browser-based simulation of the Mail Merge P Thunderbird API is provided by packages/browser-preview. To develop in the browser first install and build

npm install
npm run build

Then you can launch a dev server and open it in the browser.

cd packages/browser-preview
npx vite

If you want the interface code to automatically rebuild when you make a change, you can do

cd packages/interface
npx vite build --watch

The UI is developed using React and Redux with the helper EasyPeasy.

Developing the Thunderbird Extension

Copy or link the contents of thunderbird-src to [email protected] in your Thunderbird profile/extensions directory. Then restart Thunderbird and activate the extension.

You can open the Thunderbird debugging console with Ctrl+Shift+I. Once in the debugging console, you can manually open dialogs with the window.open command. For example,

dgl = window.open("chrome://mailmergep/content/iframe-wrapper.xul", "test", "chrome")

will open and run iframe-wrapper.xul, which is the main UI component of Mail Merge P. You can then poke around dgl for variables and functions stored in the extension's scope.

To access the APIs available to the browser extension, you must go to the extensions tab and click the gear icon and enable "Debug Mode". Then you can open a console in the context of mailmergep and the browser.* apis will be available. To manipulate a particular tab, you can use browser.tabs.query({}) to get a list of all tabs and use the id of the tab you want.

Packaging

Note that a version bump must take place in packages/thunderbird-extension/public/manifest.json. After that, run npm run build-and-package. The resulting [email protected] is a bundle of the extension.