In this tutorial we will be showing how to use the sc_call_api macro with the Mandrill API.
data:image/s3,"s3://crabby-images/2531f/2531f72432a6200760bacfc4d420f4824e46779c" alt=""
Note:
To use the Mandrill API, you must create an account on the website and obtain your access key. More information on the Mandrill website:https://mandrillapp.com/login
Creating the Control application
data:image/s3,"s3://crabby-images/4a31e/4a31e08b2b33bf314b3442f0924c91c72d5b1ff0" alt=""
1.We create the necessary fields for the mail submission form.
data:image/s3,"s3://crabby-images/2e06a/2e06ace61667a8e5199933b81284a7e38a263c41" alt=""
data:image/s3,"s3://crabby-images/2d795/2d7953077433560ca70c77cce0fb0be26f83e30f" alt=""
- api_key : Mandrill API Key
- from_email : Sender’s Email
- from_name: Sender’s Name
- mail_to: Recipient email
- to_cc: Copy of the email for another recipient
- to_bcc: Blind copy of the email for another recipient
1.1. Next, we need to create a radio type field for the message type and subject.
data:image/s3,"s3://crabby-images/9ec73/9ec73f9ab2bed1cee003dfb6f540e88a09d59f49" alt=""
In the lookup edition of the Radio field “msg_type” we select the Manual lookup method with the values ”template” and “message”
data:image/s3,"s3://crabby-images/1a22c/1a22cb00c4bc03531d3177daa722ad446e01d1db" alt=""
1.2. We create other fields used for the Selection of the Template.
- template_name: The name or immutable slug of a model that exists in the user’s account.
- template_editable: The name of the editable region “mcedit” to inject content into the email.
- template_injection: The content to be injected into the body of the email
- msg : HTML Edit field used to create the body of the email
2. Now we must create a code that hides the unnecessary fields according to the type of Message that is selected, and for that we will create the hide_fields method
data:image/s3,"s3://crabby-images/3138d/3138dc02820c6bbe51fd7c7ab2e19de404e0e199" alt=""
Code:
if ({msg_type} == 'template') {
sc_field_display({template_name}, 'on');
sc_field_display({template_editable}, 'on');
sc_field_display({template_injection}, 'on');
sc_field_display({msg}, 'off');
} else {
sc_field_display({template_name}, 'off');
sc_field_display({template_editable}, 'off');
sc_field_display({template_injection}, 'off');
sc_field_display({msg}, 'on');
}
3. This function will be called in an Ajax onClick event of the msg_type field and also in the OnLoad event of the Control Form.
data:image/s3,"s3://crabby-images/420a7/420a7442a1b3f9ac48a9b14f370fb8b1127505fb" alt=""
data:image/s3,"s3://crabby-images/bb7dc/bb7dcda9a9554974ef07933190c572cfa4176d2f" alt=""
4. In the onValidateSuccess event we will include the following code.
function explodeMail($str, $type)
{
$arr = explode(',', $str);
$arr_return = [];
foreach ($arr as $item) {
$arr_return[] = array(
'name' => '',
'type' => $type,
'email' => $item
);
}
return $arr_return;
}
$arr_to = explodeMail({mail_to}, 'to');
$arr_cc = (!empty({to_cc})) ? explodeMail({to_cc}, 'cc') : $arr_cc = array();
$arr_bcc = (!empty({to_bcc})) ? explodeMail({to_bcc}, 'bcc') : $arr_bcc = array();
$arr_merge = array_merge($arr_to, $arr_cc, $arr_bcc);
$txt_no_tags = strip_tags({msg});
$var_profile = ''; // Enter your profile if you have created it on "Tool >> API menu" or leave it blank
$var_config = array( 'settings' => ['gateway' => 'mandrill', 'api_key'=> {api_key}] );
$mandrill = sc_call_api($var_profile, $var_config);
$template_name = {template_name}; // the immutable name or slug of a template that exists in the user's account.
$template_content = array(
// an array of template content to send. Each item in the array should be a struct with two keys - name: the name of the content block to set the content for, and content: the actual content to put into the block
array(
'name' => {template_editable}, // the name of the mc:edit editable region to inject into
'content' => {template_injection} // the content to inject
)
);
$var_msg = array(
'from_email' => {from_email},
'from_name' => {from_name},
'html' => {msg},
'text' => $txt_no_tags,
'to' => $arr_merge,
'subject' => {subject},
'important' => true,
//'attachments' => array('/var/www/arquivo.txt','/var/www/arquivo2.txt'),
//'headers' => array('Reply-To' => 'message.reply@example.com'),
//'track_opens' => null,
//'track_clicks' => null,
'auto_text' => null,
'auto_html' => null,
'inline_css' => null,
//'url_strip_qs' => null,
//'tags' => array('password-resets'),
//'subaccount' => 'customer-123',
//'google_analytics_domains' => array('example.com'),
//'google_analytics_campaign' => 'message.from_email@example.com',
'metadata' => array('website' => 'www.scriptcase.net')
// Check another settings at https://mandrillapp.com/api/docs/messages.php.html#method=send
);
$async = false;
//$ip_pool = 'Main Pool';
//$send_at = 'example send_at';
if( {msg_type} == 'template' ) {
$retorno = $mandrill->messages->sendTemplate($template_name, $template_content, $var_msg, $async);
}else{
$retorno = $mandrill->messages->send($var_msg, $async);
}
//echo"<pre>";
//print_r($retorno);
//echo"</pre>";
sc_alert({lang_othr_grid_export_email_sent});
Configuring the Layout
5. In Layout >> Blocks create a new block and configure it according to the image below
data:image/s3,"s3://crabby-images/e00f9/e00f90659690290492e3cefdd3ce5c2c99301fa0" alt=""
In Positioning of the Fields we configure it as follows.
data:image/s3,"s3://crabby-images/c849c/c849c2a69d03c25e006f1136ecb15132f830911a" alt=""
6. Save the changes and run the Application.
data:image/s3,"s3://crabby-images/74f13/74f133d836164e75abfd2915a8bcbdf23b197f90" alt=""
To see more examples created with Scriptcase, go to: Examples: Complete systems and applications with Scriptcase
Comment this post