A Few More Email Scripting Examples

Anonymous
Not applicable

I wanted to share a few more email scripting examples with you.

Example 1: This script lowercases a string (in this case First and Last Name) and then properly capitalizes it.

(I think the previous example I gave only capitalizes the first letter, so if you had mixed case or all capitalized letters, it is not as good as this one.)

#set ($fname = ${lead.FirstName.toLowerCase()})

#set ($lname = ${lead.LastName.toLowerCase()})

$display.capitalize($fname) $display.capitalize($lname)

Example 2: This script adds a date 14 days in the future onto a token being used in an email.

## Access Velocity's calendar object

#set($x = $date.calendar)

## Format date

#set($current_date = $date.full_date)

## Add 24 hours (hours=int code 10 - see list below)

$x.add(6,14)

## Show result

$current_date

Example 3: This script gets the current date from the calendar object, converts it to a date and then reformats it to the format highlighted in yellow.

#set ( $todayCalObj = $date.toCalendar($date.toDate("yyyy-MM-dd H:m:s",$date.get('yyyy-MM-dd H:m:s'))) )

#set ( $dateObj = $date.toDate("yyyy-MM-dd", $todayCalObj) )

#set($dateFormatted = $date.format("MM/dd/yyyy", $dateObj))

$dateFormatted

4549
12
12 Comments
Benjamin_Ortiz1
Level 4

Hi Jason, can you explain how this logic works for adding 14 days? $dateInXDays.add(10,336)

I am trying to understand the math behind it. Thank you!

SanfordWhiteman
Level 10 - Community Moderator

Benjamin Ortiz this may not be the best place to follow up (especially since there's no syntax highlighting here, as opposed to on Products threads).

But while I wouldn't do it this way, the 10 and 336 represent, respectively, the Calendar class field HOUR (this is just a unique integer constant that has no intrinsic meaning) and 14 days in hours (14 days * 24 hours = 336 hours). Hence you're adding unit=HOUR, count=336.

The more readable way, if you want for some reason to use hours, is:

$Calendar.add($field.in($Calendar).HOUR, $math.mul(24,14))

but it makes more sense to use days, so you don't have to do any internal arithmetic:

$Calendar.add($field.in($Calendar).DATE, 14)