Work Smarter with creative solutions/hacks/narratives using technologies like Salesforce/Google
Wednesday, August 16, 2017
Friday, July 7, 2017
Sunday, May 28, 2017
Sunday, April 30, 2017
Saturday, February 4, 2017
Productivity: Google spreadsheet plugin hack sending mass emails with dynamic template
How this hack is going to help?
- If you have a list of email address to which you want to one email with custom message/email body then this hack will help with that.
- Mass email campaign is a good example of this
- Single email notifications to a group of email addresses
1. 1st sheet (Sheet Name: EmailList): have the following columns: (export the email data and store in the below format)
-- Email Address
-- First Name
-- Last Name
and
2nd sheet (Sheet Name: SendEmail): have the following columns:
-- Email (Formula: =EmailList!A2)
-- Message (Formula: =CONCATENATE(C2, CHAR(10),CHAR(10), G2, CHAR(10),CHAR(10), "Thanks,",CHAR(10),H2))
-- Sub Message (Formula: =CONCATENATE("Hello ",E2, ", "))
-- Full Name (Formula: =CONCATENATE(E2," ", F2))
-- First Name (Formula: =EmailList!B2)
-- Last Name (Formula: =EmailList!C2)
-- Email Template Content (Store Email body/template)
-- From Name (Store from name)
STEP-2: Copy paste the formula to multiple rows
STEP-3: Go to menu->Tools->Script Editor and paste the following code snippet
/**STEP-4: Save the script with "BulkEmail" project name.
* @description Google Spreadsheets plugin to bulk email
*/
function onInstall(){
onOpen();
}
function onOpen() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var menuEntries = [ {name: "Send Bulk Emails", functionName: "sendbulkEmails"},
];
ss.addMenu("Send Bulk Email", menuEntries);
}
function sendbulkEmails() {
var sheet = SpreadsheetApp.getActiveSheet();
var startRow = 2; // First row of data to process
var numRows = 2; // Number of rows to process
// Fetch the range of cells A2:B5
var dataRange = sheet.getRange(startRow, 1, numRows, 5)
// Fetch values for each row in the Range.
var data = dataRange.getValues();
for (i in data) {
var row = data[i];
var emailAddress = row[0]; // First column
var message = row[1]; // Second column
var subject = "Sending emails from a Spreadsheet";
MailApp.sendEmail(emailAddress, subject, message);
}
}
STEP-5: Come back to spreadsheet refresh the page and you will see the "Send Bulk Email" menu. Clicking the menu link will send the mass emails to the all the rows selected in the script.
Screenshots:
Sunday, January 8, 2017
Productivity: Case email bounce back analysis by querying, parsing result and printing to CSV from Salesforce.com Developer console
Use-case: Case email bounce back analysis by querying, parsing the result and printing to CSV using a single code snippet from Salesforce.com Developer console #Productivity
What the following sample script does?: 1) Queries for the undelivered emails resulted in cases created via "Email to case".
2) Parses the bounced emails from the result
3) Prints the modified results on CSV which will be stored in Salesforce.com Files.
4) The code can be run from salesforce.com developer console in a short time and does not need to be maintained on the salesforce.com platform.
Sample script:
Pattern myPattern = Pattern.compile(regex );
What the following sample script does?: 1) Queries for the undelivered emails resulted in cases created via "Email to case".
2) Parses the bounced emails from the result
3) Prints the modified results on CSV which will be stored in Salesforce.com Files.
4) The code can be run from salesforce.com developer console in a short time and does not need to be maintained on the salesforce.com platform.
Sample script:
String csv = 'Id,Description,EmailAddress\n';String regex = '>>> ([a-zA-Z0-9_\\-\\.]+)@(((\\[a-z]{1,3}\\.[a-z]{1,3}\\.[a-z]{1,3}\\.)|(([a-zA-Z0-9\\-]+\\.)+))([a-zA-Z]{2,4}|[0-9]{1,3}))';
Pattern myPattern = Pattern.compile(regex );
for ( Case cas : [ Select Id,Description
from Case
where <<filter conditions>>
order by createddate asc limit 10] ) {
Matcher myMatcher = myPattern.matcher(acct.description.escapeCsv());
if (myMatcher.find())
csv += cas.id + ',' + cas.description.escapeCsv() + ',' + myMatcher.group().split('>>> ')[1].trim() + '\n';
else
csv += cas.id + ',' + cas.description.escapeCsv() + ',' + '' + '\n';
}
ContentVersion file = new ContentVersion(
title = 'cases.csv',
versionData = Blob.valueOf( csv ),
pathOnClient = '/cases.csv'
);
insert file;
System.debug('this is file:' + file );
Subscribe to:
Posts (Atom)