Si está intentando enviar los correos a través de su módulo personalizado, puede seguir la guía mencionada a continuación. Digamos que tenía un módulo llamado "Commerce Canvas (commerce_canvas)" 1. Primero modifique la función de correo de Drupal para admitir enlaces y agregar otros tipos de codificación
/**
* Implements hook_mail_alter()
* @param string $message
*/
function commerce_canvas_mail_alter(&$message) {
$headers = array(
'MIME-Version' => '1.0',
'Content-Type' => 'text/html; charset=iso-8859-1; format=flowed',
'Content-Transfer-Encoding' => '8Bit',
'X-Mailer' => 'Drupal',
);
foreach ($headers as $key => $value) {
$message['headers'][$key] = $value;
}
}
- Luego, enganche el HOOK_mail en su módulo como
/**
* Implements hook_mail()
* @param string $key
* @param string $message
* @param unknown_type $params
*/
function commerce_canvas_mail($key, &$message, $params) {
//Language Selection
$options = array(
'langcode' => $message['language']->language,
);
switch($key) {
case "user_payment_notification" :
$message['subject'] = isset($params['subject']) ? $params['subject'] : $message['subject'] = t('Payment recieved @site-name', array('@site-name' => variable_get('site_name', 'Express Canvas')), $options);
$message['body'][] = isset($params['body']) ? $params['body'] : NULL;
if (isset($params['headers']) && is_array($params['headers'])) {
$message['headers'] += $params['headers'];
}
break;
}
}
- Luego debe crear una función de contenedor para invocar el correo desde su módulo.
function commerce_canvas_mail_send(array $values = array()) {
$module = $values['module'];
$key = $values['key'];
$to = $values['to'];
$from = $values['form'];
$language = isset($values['lang']) ? $values['lang'] : language_default();
$params = array(
'subject' => $values['subject'],
'body' => $values['body'],
);
if(array_key_exists('headers', $values)) {
$params['headers'] = $values['headers']; //Assumed as an array
}
$send = TRUE;
$mail = drupal_mail($module, $key, $to, $language, $params, $from, $send);
if($mail['result']) {
return TRUE;
} else {
$error_msg = 'Failed to send the email in commerce_canvas Module';
watchdog('canvas-email', $error_msg, array(), WATCHDOG_ALERT);
return FALSE;
}
}
Esta función enviará el correo electrónico y creará mensajes de depuración si algo sucede mal. Pero aún así no podrá enviar el correo HTML porque necesita extender el DefaultMailSystem predeterminado de Drupal 7 con el suyo. Entonces necesito hacer lo siguiente,
class CommerceCanvasMailSystem extends DefaultMailSystem {
/**
* Concatenate and wrap the e-mail body for plain-text mails.
*
* @param $message
* A message array, as described in hook_mail_alter().
*
* @return
* The formatted $message.
*/
public function format(array $message) {
$message['body'] = implode("\n\n", $message['body']);
return $message;
}
/**
* Send an e-mail message, using Drupal variables and default settings.
*
* @see http://php.net/manual/en/function.mail.php
* @see drupal_mail()
*
* @param $message
* A message array, as described in hook_mail_alter().
* @return
* TRUE if the mail was successfully accepted, otherwise FALSE.
*/
public function mail(array $message) {
$mimeheaders = array();
foreach ($message['headers'] as $name => $value) {
$mimeheaders[] = $name . ': ' . mime_header_encode($value);
}
$line_endings = variable_get('mail_line_endings', MAIL_LINE_ENDINGS);
return mail(
$message['to'],
mime_header_encode($message['subject']),
// Note: e-mail uses CRLF for line-endings. PHP's API requires LF
// on Unix and CRLF on Windows. Drupal automatically guesses the
// line-ending format appropriate for your system. If you need to
// override this, adjust $conf['mail_line_endings'] in settings.php.
preg_replace('@\r?\n@', $line_endings, $message['body']),
// For headers, PHP's API suggests that we use CRLF normally,
// but some MTAs incorrectly replace LF with CRLF. See #234403.
join("\n", $mimeheaders)
);
}
}
A continuación, debe registrar una nueva función de tema que llamará a su archivo de plantilla personalizada en su hook_theme ().
/**
* Implements hook_theme();
*/
function commerce_canvas_theme($existing, $type, $theme, $path) {
if($type == 'module') {
return array(
'tracking_code_email' => array(
'variables' => array(
'image_path' => NULL,
'user' => NULL,
'page' => NULL,
),
'template' => 'commerce-canvas-tracking-code',
'path' => drupal_get_path('module', 'commerce_canvas').'/theme',
),
);
}
}
Por último, debe llamar a esta función de tema a la hora de enviar el correo electrónico como,
function a_custom_function($params) {
$email_text_user = theme('tracking_code_email', array(
'image_path' => $base_url . '/' . drupal_get_path('module', 'commerce_canvas') . '/images',
'user' => null,
'page' => array(
'greet_text' => t('Thank you for your order at Express Canvas. Your order is ready and has shipped. You may track your order using FedEx tracking with your tracking number: '.$order->field_tracking_number['und']['0']['value'].''),
),
));
$sent_to_user = commerce_canvas_mail_send($email_values_user);
}
Estos son los fragmentos completos para manejar el correo electrónico HTML correctamente en Drupal 7, por lo tanto, en el hook_theme puede dar su plantilla personalizada.
But still you won't be able to send the HTML mail..., Derecha.Si desea crear un tema para los correos salientes con la ayuda de plantillas personalizadas, debe usar el módulo de correo HTML .
Funciona bien con otros módulos, como Print , Mail mime , etc.
Debe instalar el módulo del sistema de correo para utilizar el correo HTML.
fuente
Ejemplo de uso:
fuente
drupal_mail()lugar de$system->mail(..usar lahook_mail_alterfunción (que solo funciona para los correos enviados usandodrupal_mail().drupal_mailetc., pero gracias de todos modosPara enviar correo electrónico HTML, puede usar el módulo Mimemail . Una vez que está configurado y configurado, simplemente puede preparar la plantilla, nombrarla
mimemail-message.tpl.php, soltarla en su directorio de temas y se aplicará automáticamente a todos los correos electrónicos salientes (suponiendo que haya configurado todo el correo para que Mimemail lo envíe) .Configurar el módulo es probablemente más fácil que anularlo
drupal_mail().fuente