npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@lumot-eu/medusa-plugin-nodemailer

v1.0.6

Published

A notification service based on Nodemailer & Handlebars templating engine.

Downloads

783

Readme

medusa-plugin-nodemailer

A notification service based on Nodemailer & Handlebars templating engine.

Installation

To install, run the following command in your terminal:

npm install @lumot-eu/medusa-plugin-nodemailer

Add the following values to your medusa-config.js file:

const plugins = [
    // ...
    {
        resolve: "@lumot-eu/medusa-plugin-nodemailer",
        options: {
            fromAddress: process.env.MAIL_FROM_ADDRESS,

            // This object is passed directly into nodemailer.createTransport(),
            // so any configuration options supported by nodemailer will work here.
            // For more details, see: https://nodemailer.com/smtp/#1-single-connection
            transport: {
                host: process.env.MAIL_SMTP_HOST,
                port: process.env.MAIL_SMTP_PORT,
                auth: {
                    user: process.env.MAIL_SMTP_USER,
                    pass: process.env.MAIL_SMTP_PASS,
                },
                tls: {
                    // do not fail on invalid certs
                    rejectUnauthorized: false,
                },
            },

            // Path to the directory where your email templates are stored
            templatesDir: "email-templates",

            // Path to the directory where your layouts are stored
            layoutsDir: "email-templates/_layouts",

            // Path to the directory where your partials are stored
            partialsDir: "email-templates/_partials",

            // The name or file path of a template within the `layoutsDir` that will be used as the default layout.
            // To disable the use of a default layout, you can provide a falsy value
            defaultLayout: "default.hbs",

            // Maps templates to MedusaJS events
            // Only events listed here will be subscribed to.
            templateMap: {
                // "eventName": {
                //   name: "templateName"
                //   subject: "E-mail subject"
                // }
                "order.placed": {
                    name: "order.placed",
                    subject: "Order confirmation",
                }, 
            },

            // Helper functions, or "helpers" can be registered with Handlebars
            // and used within templates. Helpers provide additional functionality to templates,
            // such as transforming output, iterating over data, and more.
            hbsHelpers: {
                // Example: A helper that divides two numbers
                // divide: function (a, b, opts) {
                //     return a / b;
                // },
                // Usage in template: {{#divide 50 2}}
            },
        },
    },
];

E-mail templates

Templates for each event should be placed in a sub-directory matching the name specified in the templateMap: eg. {templatesDir}/order.placed. The sub-directory must contain two files: html.hbs for the HTML version and txt.hbs for the plain text version of the email.

If you'd like to try the example email templates, simply comment out templatesDir, layoutsDir, and partialsDir in your configuration.

Custom events

To send notifications for custom events, include to property in the event data payload. This property specifies the recipient e-mail address.