-
Notifications
You must be signed in to change notification settings - Fork 3
/
ExcelExport.aspx.cs
101 lines (81 loc) · 4.09 KB
/
ExcelExport.aspx.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
using DotNetNuke.Data;
using OPSI.UManage.Entities;
using System;
using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace UManage
{
public partial class ExcelExport : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
string v_Current_Portal_ID = Request["pid"];
string ResultsPerPage = Request["rpp"];
string CurrentPage = Request["cp"];
string key = Request["key"];
string roles = Request["roles"];
string deleted = Request["deleted"];
string unauth = Request["unauth"];
string orderby = Request["orderby"];
string orderclause = Request["orderclause"];
string attachment = "attachment; filename=UManage_Exported_Users_" + DateTime.UtcNow.Ticks.ToString() + ".xls";
HttpContext.Current.Response.Clear();
HttpContext.Current.Response.ClearHeaders();
HttpContext.Current.Response.ClearContent();
HttpContext.Current.Response.AddHeader("content-disposition", attachment);
HttpContext.Current.Response.ContentType = "application/vnd.ms-excel";
var sb = new System.Text.StringBuilder();
List<User_Info> v_List_Users;
string sql;
sql = "OPSI_UManage_UsersSearch";
using (IDataContext ctx = DataContext.Instance())
{
v_List_Users = (List<User_Info>)ctx.ExecuteQuery<User_Info>(CommandType.StoredProcedure, sql, v_Current_Portal_ID,
ResultsPerPage,
CurrentPage,
key,
roles,
deleted,
unauth,
orderby,
orderclause);
}
string _Content = "";
sb.Append("<table>");
sb.Append("<tr>");
sb.Append("<td><b>DNN User Name</b></td>");
sb.Append("<td><b>Name</b></td>");
sb.Append("<td><b>Surname</b></td>");
sb.Append("<td><b>Email</b></td>");
sb.Append("<td><b>Display Name</b></td>");
sb.Append("<td><b>Creation Date</b></td>");
sb.Append("<td><b>Last Access</b></td>");
sb.Append("</tr>");
foreach (User_Info _Info in v_List_Users)
{
_Content = AddLine(_Info);
sb.AppendLine(_Content);
}
sb.Append("</table>");
HttpContext.Current.Response.Write(sb.ToString());
HttpContext.Current.Response.End();
}
public string AddLine(User_Info info)
{
string _result = "<tr>";
_result += "<td>" + info.Username + "</td>";
_result += "<td>" + info.FirstName + "</td>";
_result += "<td>" + info.LastName + "</td>";
_result += "<td>" + info.Email + "</td>";
_result += "<td>" + info.DisplayName + "</td>";
_result += "<td>" + info.CreatedOnDate + "</td>";
_result += "<td>" + info.LastLoginDate + "</td>";
_result += "</tr>";
return _result;
}
}
}