Reputation: 647
I have a script that is using the following script:
MailApp.sendEmail(row.shiftManager, "Holiday Approval Request", "", {htmlBody: message});
row.state = STATE_PENDING;
Howeverm I would like to also send the same mail to row.shiftSupervisor
, this is probably something really simple that I've overlooked, but I figured someone here would know straight away what it was.
Cheers for your help :)
Edit - I tried to use:
MailApp.sendEmail(row.shiftManager, row.shiftSupervisor, "Holiday Approval Request", "", {htmlBody: message});
row.state = STATE_PENDING;
But no joy.
Edit 2 - I got it working with:
MailApp.sendEmail(row.shiftManager, "Holiday Approval Request", "", {htmlBody: message});
MailApp.sendEmail(row.shiftSupervisor, "Holiday Approval Request", "", {htmlBody: message});
row.state = STATE_PENDING;
Not the most graceful looking piece of code, but it does the job...
Upvotes: 23
Views: 77605
Reputation: 4182
Here is how I'm doing it:
//check quota and log
const emailsLeft = MailApp.getRemainingDailyQuota();
console.log( emailsLeft + " emails left in quota");
//get list of emails from spreadsheet itself
//filter out empty rows
const emails = getTab("Config").getRange("D2:D").getValues().map(function(el){ return el[0]; }).filter(function(el){ return el != '' });
//send emails from NO_REPLY email, subject and HTML body
MailApp.sendEmail({
to: emails.join(","),
subject: subject,
htmlBody: html,
noReply: true
});
function getTab(name) {
var sheet = SpreadsheetApp.getActiveSpreadsheet();
return sheet.getSheetByName(name);
}
getTab() and other helper functions can be found here https://github.com/tim-kozak/google-spreadsheet-helpers
Upvotes: 5
Reputation: 31310
The email addresses can be concatenated (joined together) using the plus sign with a comma in between each email address. In JavaScript the plus sign can be used for addition OR joining strings. The plus sign is both an addition operator and a string operator in JavaScript. Strings are text, and if you use the plus sign to concatenate text strings then it's a string formula.
One solution would be:
var recipient = row.shiftManager + "," + row.shiftSupervisor;
MailApp.sendEmail(recipient, "Holiday Approval Request", "", {htmlBody: message});
In the above example, there are 4 parameters. But MailApp.sendEmail()
has multiple possible parameter structures. The following example shows all of the settings put into an object, where the "to" key in the object is for the recipient.
MailApp.sendEmail({
to: recipient,
cc: recipientsCC,
subject: Subject,
htmlBody: html
});
A complete example:
function sendToMultiple() {
var message = "This is a test of HTML <br><br> Line two";
var recipientsTO = "[email protected]" + "," + "[email protected]";
var recipientsCC = "[email protected]";
var Subject = "Vacation Approval Request";
var html = message;
MailApp.sendEmail({
to: recipientsTO,
cc: recipientsCC,
subject: Subject,
htmlBody: html
});
}
Documentation with an example is at the following link:
Google Documentation - MailApp.sendEmail
Upvotes: 35