npm

Bring the best of OSS JavaScript development to your projects with npm Orgs - private packages & team management tools.Learn more »

bulk-mail-cli

1.0.1 • Public • Published

bulk-mail-cli by Kumar Abhirup

Type stage npm Version Prefers Twitter



📦 bulk-mail-cli

Do quick, hassle-free email marketing with this small but very powerful tool! 🔥

It sends automated, dynamic and beautifully designed HTML emails to your mailing list via your terminal! 😎


Ever felt a quick need to shoot a fabulous mail to your subscribers? Without any inconvenience of creating complex campaigns with MailChimp and MailGun? Just open your terminal, input the CSV and HTML file with dynamic text, and just shoot the mails with bulk-mail-cli!



🦋 Introduction

Following YouTube video is a tutorial of using bulk-mail-cli like a PRO!

Introduction to bulk-mail-cli



👌 Use it in just 3 steps!...

bulk-mail-cli upcoming features

Note: This project is yet an MVP (Minimum Viable Product). Right now, it doesn't work on Windows machines. Working to make it cross-platform. SORRY TO KEEP YOU WAITING!



💃 Documentation

Install bulk-mail-cli

Assuming that you have node and npm installed... Run the following in your terminal.

$ npm i -g --only=prod bulk-mail-cli

Get help

Just run bulkmail in your terminal to see what commands and flags you can use to do awesome things.


Generate demo Mail Templates and a CSV file

To generate demo files, paste the following command.

$ bulkmail demo

Writing data in CSV

List emails the right way!

If you use WordPress, you may just import the CSV file of users by using this plugin.

  • When you use that plugin, just change the user-email column name of the CSV file to just email so that to ensure no errors.

If you are feeding data from any other source or by manual means, please for the GOD's SAKE ensure that you list emails only under the email column.

If the CSV file has emails fed in some other coulumn name (such as user-email, allEmails, etc)... bulk-mail-cli would simply throw an error to not work at all.

Dynamic data 🎉

This feature was introduced in v0.9.0

You may add any other column featuring custom data. Namely fname, lname, address, etc... to use in the Subject and Body of your campaign mail.


Making custom dynamic HTML Mail Templates

Grab the sample templates

  • For most use cases, the bulkmail demo served HTML templates will do the work. But if they don't satisfy your needs, you may check for more designs online!
  • When using a bulkmail demo served HTML template, ensure that you edit and tailor the email template file according to your needs.

Display custom CSV data (Dynamic) 🎉

  • Wanna display the fname field of the user you listed in CSV file? Just add ({#fname#}) anywhere you want in the HTML template!
  • You may add any fieldname that exists in the CSV file, or else the dynamic text won't render.

Correct use of Dynamic Text

❌     ({# customfield#})
❌     ({#customfield #})
❌     ({# customfield #})
❌     ({customfield})
✅     ({#customfield#})


Shoot the mails after you curate data

If you are to send mails using Gmail, just turn on the less secure apps option here...

Done tweaking with Templates and CSV file? Done doing those configurations? It is time to send the mails!

$ bulkmail mail

Wait, bulkmail mail is not all. The CLI will then ask you for Service Credentials that you need to fill in order to complete the process. It will also ask for the path of the HTML email template and the CSV file.

Somewhat similar to what you see below:

$ bulkmail mail

Service credentials...
service: gmail/yahoo/custom
email: johndoe@example.com
password: •••••••••••••••••

Connection successful! 😀

Path to CSV: <you can use bash's auto navigating feature>
Path to Mail Template: <you can use bash's auto navigating feature>

From text: John Doe <johndoe@example.com>
Subject: Hi ({#fname#})! Here's your mail.

Mass Mailer started 👻
[-------------------------------------------------->] 100%

Mails sent to everyone successfully in 9.43 seconds.

Thank you for using bulk-mail-cli 😀

Credentials are asked only for the first time.


Change your Service Credentials

Just type in the given command and see bulk-mail-cli automatically asking for the credentials again!

$ bulkmail config --auth

Upcoming

  • Time Interval after every mail.
  • Internationalization. Will soon be available in 4-5 major languages.
  • UX and Performance improvement.

LET US DEVELOP THIS PROJECT TOGETHER. WANNA CONTRIBUTE?



👮 Wanna contribute?

bulk-mail-cli upcoming features

Step 1 🍴

Fork this project.

Step 2 🔁

Clone the forked project on your local machine.

Step 3 🗽

Create a new branch in cloned project named PR/{whatever} and work there.

️️️️️️Step 4 ✏️

Run npm i in the project directory.

Step 5 🎩

Do the magic you wanted to.

Step 6 ✏️

Run npm run build to check if everything works good so far.

Step 7 🏹

And if you are done, just shoot a Pull Request at development branch of bulk-mail-cli...

The hurray kinda step 😉 🎉

Get your Pull Request merged...



📝 License

GPL © Kumar Abhirup
Follow me 👋 on Twitter → Twitter

install

npm i bulk-mail-cli

Downloadsweekly downloads

13

version

1.0.1

license

GPL-3.0

homepage

github.com

repository

Gitgithub

last publish

collaborators

  • avatar
Report a vulnerability