-
Notifications
You must be signed in to change notification settings - Fork 204
/
Copy pathNestedMailMerge.cs
106 lines (92 loc) · 3.76 KB
/
NestedMailMerge.cs
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
#region Copyright Syncfusion Inc. 2001-2016.
// Copyright Syncfusion Inc. 2001-2016. All rights reserved.
// Use of this code is subject to the terms of our license.
// A copy of the current license can be obtained at any time by e-mailing
// [email protected]. Any infringement will be prosecuted under
// applicable laws.
#endregion
using Syncfusion.DocIO;
using Syncfusion.DocIO.DLS;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;
using Android.Content;
using Android.Views;
using Android.Widget;
using Android.Graphics;
using System.Data;
using System.Collections;
namespace SampleBrowser
{
public partial class NestedMailMerge : SamplePage
{
private Context m_context;
public override View GetSampleContent (Context con)
{
LinearLayout linear = new LinearLayout(con);
linear.SetBackgroundColor(Color.White);
linear.Orientation = Orientation.Vertical;
linear.SetPadding(10, 10, 10, 10);
TextView text1 = new TextView(con);
text1.TextSize = 17;
text1.TextAlignment = TextAlignment.Center;
text1.SetTextColor(Color.ParseColor("#262626"));
text1.Text = "This sample demonstrates how to perform Mail merge for nested groups in Word document using Essential DocIO.";
text1.SetPadding(5, 10, 10, 5);
linear.AddView(text1);
TextView space1 = new TextView (con);
space1.TextSize = 10;
linear.AddView (space1);
m_context = con;
TextView space2 = new TextView (con);
space2.TextSize = 10;
linear.AddView (space2);
Button button1 = new Button (con);
button1.Text = "Generate Word";
button1.Click += OnButtonClicked;
linear.AddView (button1);
return linear;
}
void OnButtonClicked(object sender, EventArgs e)
{
Assembly assembly = Assembly.GetExecutingAssembly();
// Creating a new document.
WordDocument document = new WordDocument();
Stream inputStream = assembly.GetManifestResourceStream("SampleBrowser.Samples.DocIO.Templates.Template_Letter.doc");
//Open Template document
document.Open(inputStream, FormatType.Word2013);
inputStream.Dispose();
inputStream = assembly.GetManifestResourceStream("SampleBrowser.Samples.DocIO.Templates.Employees.xml");
DataSet ds = new DataSet();
ds.ReadXml(inputStream);
ArrayList commands = new ArrayList();
//DictionaryEntry contain "Source table" (KEY) and "Command" (VALUE)
DictionaryEntry entry = new DictionaryEntry("Employees", string.Empty);
commands.Add(entry);
// To retrive customer details
DataTable table = ds.Tables["Customers"];
string relation = table.ParentRelations[0].ChildColumns[0].ColumnName + " = %Employees." + table.ParentRelations[0].ParentColumns[0].ColumnName + "%";
entry = new DictionaryEntry("Customers", relation);
commands.Add(entry);
// To retrieve order details
table = ds.Tables["Orders"];
relation = table.ParentRelations[0].ChildColumns[0].ColumnName + " = %Customers." + table.ParentRelations[0].ParentColumns[0].ColumnName + "%";
entry = new DictionaryEntry("Orders", relation);
commands.Add(entry);
//Executes nested Mail merge using explicit relational data.
document.MailMerge.ExecuteNestedGroup(ds, commands);
MemoryStream stream = new MemoryStream();
document.Save(stream, FormatType.Word2013);
document.Close();
if (stream != null)
{
SaveAndroid androidSave = new SaveAndroid ();
androidSave.Save ("NestedMailMerge.docx", "application/msword", stream, m_context);
}
}
}
}