How to: Send the Mail-Merge Document as an E-Mail
- 4 minutes to read
The following example describes how to send the mail merge result as an e-mail.
Refer to the Mail Merge topic for an example on how to create a mail-merge document. Follow the steps below to export the result as a Microsoft® Outlook® mail item.
Create an Exporter Class
- Add a reference to the Microsoft.Office.Interop.Outlook assembly.
Create an exporter class that implements the IUriProvider interface. Declare the class constructor as follows:
using DevExpress.Office.Services; using Outlook = Microsoft.Office.Interop.Outlook; public class RichEditMailMessageExporter : IUriProvider { readonly RichEditControl control; readonly Outlook.MailItem mailItem; public RichEditMailMessageExporter(RichEditControl control, Outlook.MailItem mailItem) { Guard.ArgumentNotNull(control, "control"); Guard.ArgumentNotNull(mailItem, "mailItem"); this.control = control; this.mailItem = mailItem; } }
Implement the Export method to retrieve the document text in HTML format and convert it into the message body. Subscribe to the RichEditControl.BeforeExport event.
string tempFiles = Path.Combine(Directory.GetCurrentDirectory(), "TempFiles"); public virtual void Export() { if (!Directory.Exists(tempFiles)) Directory.CreateDirectory(tempFiles); control.BeforeExport += OnBeforeExport; string htmlBody = control.Document.GetHtmlText(control.Document.Range, this); control.BeforeExport -= OnBeforeExport; mailItem.BodyFormat = Outlook.OlBodyFormat.olFormatHTML; mailItem.HTMLBody = htmlBody; }
Specify the HtmlDocumentExporterOptions.Encoding property in the BeforeExport event handler.
Implement the interface’s IUriProvider.CreateCssUri and IUriProvider.CreateImageUri methods. In this example, the IUriProvider.CreateImageUri method retains the document images and attaches them to the mail message.
int imageId; public string CreateCssUri(string rootUri, string styleText, string relativeUri) { return String.Empty; } public string CreateImageUri(string rootUri, OfficeImage image, string relativeUri) { string imageName = String.Format("image{0}.png", imageId); imageId++; string imagePath = Path.Combine(tempFiles, imageName); image.NativeImage.Save(imagePath, ImageFormat.Png); mailItem.Attachments.Add(imagePath, Outlook.OlAttachmentType.olByValue, 0, Type.Missing); return "cid:" + imageName; }
Send the result to the Microsoft® Outlook® application
Declare a new Outlook application object and create a new mail item in the main class. Create a new RichEditMailMessageExporter instance and pass the RichEditControl and the MailItem objects as parameters. Call the Export method.
In this example, the document is sent as a mail item on a “Send Mail” button click.
private void btnSend_Click(object sender, EventArgs e)
{
if ((edtTo.Text.Trim() == "") || (edtSubject.Text.Trim() == ""))
{
MessageBox.Show("Fill in required fields");
return;
}
try
{
Outlook.Application application = new Outlook.Application();
Outlook.MailItem mailItem = (Outlook.MailItem)application.CreateItem(Outlook.OlItemType.olMailItem);
mailItem.To = edtTo.Text;
mailItem.Subject = edtSubject.Text;
RichEditMailMessageExporter exporter = new RichEditMailMessageExporter(richEdit, mailItem);
exporter.Export();
mailItem.Display(false);
}
catch (Exception exc)
{
MessageBox.Show(exc.Message);
}
}