Inline images in emails using MailApp in Apps Script

In this tutorial, I will show you how to send emails with inline images (i.e. embedded images) using MailApp in Apps Script.

Here is an example of an email where I've embedded a mock logo in the email body itself:

Screenshot of an email with an in-line image.

Prerequisites

This tutorial assumes that you're familiar with the following concepts:

Also, if you're new to coding with Apps Script, please refer to my tutorial on learning to code using Google Sheets and Apps Script.

How to embed inline images in emails sent using Apps Script?

First of all, if you want to inline images in your email body, you must send a HTML email. You can't embed images in plain text emails. You can, however, attach images to both HTML and plain text emails.

To embed an inline image, your HTML code must specify a placeholder for the image. Then you must supply the image to be inserted into that placeholder when you send the email.

To specify the placeholder for your image, the src attribute of the image must be set to cid:<some-unique-id>. Here <some-unique-id> is a unique identifier for every inline image in your email. For example, the HTML below specifies a placeholder for a single image that has logo as its unique identifier.

<!DOCTYPE html>
<html>
  <head>
    <base target="_top">
  </head>
  <body>
    <img src="cid:logo" alt="Spreadsheet Dev logo">
    <br>
    <p>Hello,</p>
    <p>Please find your weekly report attached.</p>
    <p>Your Analytics team</p>
  </body>
</html>

Then, when you're sending the email, you must specify an image for every placeholder. You do this by creating an object that specifies the image corresponding to each placeholder.

In the code below, the object emailImages specifies the image corresponding to the placeholder logo. Then, while sending the email, this object is included as the value of a property called inlineImages in MailApp's email configuration.

function sendEmail() {
  let image = DriveApp.getFileById("<DRIVE_FILE_ID>").getAs("image/png");
  let emailImages = {"logo": image};
  let emailBody = HtmlService.createTemplateFromFile("template").evaluate().getContent();
  MailApp.sendEmail({
    to: "<EMAIL_ADDRESS>",
    subject: "Daily analytics report",
    htmlBody: emailBody,
    inlineImages: emailImages
  });
}

When you run the sendEmail() function, the script will send an email containing inline images.

Conclusion

In this tutorial, I showed you how to send an email containing inline images using Apps Script. Hope this tutorial was helpful!

Thank you for reading!

Master Google Sheets Automation

Sign up to receive exclusive Automation tips and tutorials!
I'll send you actionable tips on automating tasks with Google Sheets and coding with Apps Script. You'll also be notified whenever new content is published.
PLUS: Get instant access to my Birthday Reminder Template! 🎂
By signing up you agree to the Privacy Policy & Terms.

Have feedback for me?

I'd appreciate any feedback you can give me regarding this post.

Was it useful? Are there any errors or was something confusing? Would you like me to write a post about a related topic? Any other feedback is also welcome. Thank you so much!