Meteor - How to Create and Send an iCal Invitation Email
In this tutorial I will show you how to send an iCal invitation email using basic Meteor packages and an iCal generator smart package. iCal files are useful because they allow the email recipient to instantly add the invitation or event to their calendar program directly form their email client. If you send emails with any sort of event information you should be sending an iCal file! The full source code for this tutorial is available on my GitHub page.
There are a few packages you need to get started
meteor add email meteor add quackware:ical-generator
The email package is pretty straightforward, it’s the basic email package provided by Meteor. The ical-generator is the npm package ical-generator that has been wrapped as a meteor smart package. You can check out the source code of the smart package here.
You also need to sign up for some sort of 3rd party email service (sendgrid, mandrill, etc) so that you can set your
MAIL_URL variable in the server, allowing you to send emails. For this tutorial I used a mandrill account, but they are all very similar to use.
The client side code for this tutorial is very basic. We just need to have a few fields in a form that we can submit to the server. You can see the
send-invitation.js files below:
These fields are just a sample of what you can include in an ical file. You can check out the documentation for ical-generator here which should give you a good idea of additional fields you might want to add.
The first part of the server side code is setting up the
MAIL_URL variable. I am setting it based on the user and password variables I have stored in my
You can read a more in depth discussion of setting up the
MAIL_URL variable and the
settings.json file in my send template emails from the server tutorial. That tutorial uses mailgun, but mandrill works the exact same way.
We also need to implement the
sendInvitation Meteor method we referenced in the client side code. This code uses our
quackware:ical-generator package we already added.
As you can see we create an empty ical object and then add an event to the calendar object populated with the data from the client side. We can then use
cal.toString() to attach the ical file as an attachment using the built in
Email.send function provided by Meteor. That’s it! Once you test it out and send an email you should see an email similar to the one below:
Thats it! Meteor makes it very easy to both send emails and include additional packages like the ical-generator to add additional functionality to our application. Again the full source code for this tutorial is available on my GitHub page. If you have any improvements or suggestions make sure to leave a comment!
Curtis Larson is a LA based freelance software developer. Follow him on Twitter or send him an email if you're looking for a talented developer.