-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathProgram.vb
45 lines (40 loc) · 1.85 KB
/
Program.vb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
Imports DevExpress.Office.Services
Imports DevExpress.XtraRichEdit
Imports DevExpress.XtraRichEdit.API.Native
Imports System.Windows.Forms
Namespace RichEditImageMailMerge
Friend Module Program
''' <summary>
''' The main entry point for the application.
''' </summary>
<STAThread>
Sub Main()
Using wordProcessor As New RichEditDocumentServer()
RegisterUriStreamService(wordProcessor)
wordProcessor.LoadDocument(Application.StartupPath & "\MailMergeTemplate.rtf")
wordProcessor.Options.MailMerge.DataSource = NorthwindDataProvider.Categories
wordProcessor.Options.MailMerge.ViewMergedData = True
MergeToNewDocument(wordProcessor)
End Using
End Sub
#Region "registerprovider"
Private Sub RegisterUriStreamService(richEditDocumentServer As RichEditDocumentServer)
Dim uriStreamService As IUriStreamService = richEditDocumentServer.GetService(Of IUriStreamService)()
uriStreamService.RegisterProvider(New ImageStreamProvider(NorthwindDataProvider.Categories, "Picture"))
End Sub
#End Region
#Region "Mail-merge the document"
Private Sub MergeToNewDocument(richEditDocumentServer As RichEditDocumentServer)
Dim options As MailMergeOptions = richEditDocumentServer.Document.CreateMailMergeOptions()
options.MergeMode = MergeMode.NewSection
Dim fileName As String = System.IO.Directory.GetCurrentDirectory() & "\MailMergeResult.rtf"
richEditDocumentServer.Document.MailMerge(options, fileName, DocumentFormat.Rtf)
Dim p As New Process()
p.StartInfo = New ProcessStartInfo(fileName) With {
.UseShellExecute = True
}
p.Start()
End Sub
#End Region
End Module
End Namespace