Hi mahesh213,
Check this example. Now please take its reference and correct your code.
Change the design as per your need with the help of html tag using StringBuilder.
Namespaces
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Web.Mvc;
using iTextSharp.text;
using iTextSharp.text.pdf;
using iTextSharp.tool.xml;
Controller
public class HomeController : Controller
{
// GET: /Home/
public ActionResult Index()
{
return View();
}
public JsonResult getAll()
{
return Json(GetEmployees(), JsonRequestBehavior.AllowGet);
}
[HttpPost]
public ActionResult GenerateReport(int eId)
{
string html = "";
Employee employee = GetEmployees().Where(x => x.EId == eId).FirstOrDefault();
StringBuilder sb = new StringBuilder();
// Company Logo and Name.
html += "<div style='text-align:center;'>" +
"<img src='" + GetUrl("Files/Logo.png") + "' height='50px' width='100px' />" +
"<br/><h2>Excelasoft Solutions</h2><hr/>" +
"</div>";
// Employee Data.
html += "<table>" +
"<tr><th>Id</th><td colspan='2'> : " + employee.EId + "</td></tr>" +
"<tr><th>Name</th><td colspan='2'> : " + employee.EName + "</td></tr>" +
"<tr><th>Gender</th><td colspan='2'> : " + employee.Gender + "</td></tr>" +
"<tr><th>Phone No</th><td colspan='2'> : " + employee.PNo + "</td></tr>" +
"<tr><th>Location</th><td colspan='2'> : " + employee.Location + "</td></tr>" +
"<tr><th>Company</th><td colspan='2'> : " + employee.Company + "</td></tr>" +
"</table>";
using (MemoryStream stream = new MemoryStream())
{
StringReader sr = new StringReader(html);
Document pdfDoc = new Document(PageSize.A4, 50f, 10f, 30f, 10f);
PdfWriter writer = PdfWriter.GetInstance(pdfDoc, stream);
pdfDoc.Open();
XMLWorkerHelper.GetInstance().ParseXHtml(writer, pdfDoc, sr);
pdfDoc.Close();
TempData["Data"] = stream.ToArray();
}
return new JsonResult() { Data = new { FileName = employee.EName.Trim().Replace(" ", "_") + ".pdf" } };
}
[HttpGet]
public virtual ActionResult Download(string filename)
{
if (TempData["Data"] != null)
{
byte[] data = TempData["Data"] as byte[];
return File(data, "application/pdf", filename);
}
else
{
return new EmptyResult();
}
}
private string GetUrl(string imagePath)
{
string appUrl = System.Web.HttpRuntime.AppDomainAppVirtualPath;
if (appUrl != "/")
{
appUrl = "/" + appUrl;
}
string url = string.Format("{0}://{1}{2}", Request.Url.Scheme, Request.Url.Authority, appUrl);
return url + imagePath;
}
private List<Employee> GetEmployees()
{
List<Employee> employees = new List<Employee>();
employees.Add(new Employee { EId = 1, EName = "Maria", Gender = "Female", PNo = "030-0074321", Location = "Austria", Company = "Alfreds Futterkiste" });
employees.Add(new Employee { EId = 2, EName = "Antonio Moreno", Gender = "Male", PNo = "(5) 555-3932", Location = "Brazil", Company = "Antonio Moreno Taquería" });
employees.Add(new Employee { EId = 3, EName = "Thomas Hardy ", Gender = "Male", PNo = "(5) 555-3932", Location = "Ireland", Company = "Around the Horn" });
return employees;
}
public class Employee
{
public int EId { get; set; }
public string EName { get; set; }
public string Gender { get; set; }
public string PNo { get; set; }
public string Location { get; set; }
public string Company { get; set; }
}
}
View
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Index</title>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" />
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.5.5/angular.js"></script>
<script type="text/javascript">
var app = angular.module('MyApp', []);
app.controller('MyController', ['$scope', '$http', function ($scope, $http) {
$http({
method: 'GET',
url: '/Home/getAll/'
}).success(function (data) {
$scope.items = data;
});
$scope.GenerateReport = function (id) {
$http({
method: 'POST',
url: '/Home/GenerateReport/',
params: { eId: id }
}).success(function (data) {
window.location = '/Home/Download?filename=' + data.FileName;
});;
};
} ]);
</script>
</head>
<body ng-app="MyApp" ng-controller="MyController">
<div class="container" id="printarea">
<table class="table table-bordered">
<tr class="success">
<th>EId</th>
<th>EName</th>
<th>Gender</th>
<th>PNo</th>
<th>Location</th>
<th>Company</th>
<th>Ation</th>
</tr>
<tr ng-repeat="item in items">
<td>{{item.EId}}</td>
<td>{{item.EName}}</td>
<td>{{item.Gender}}</td>
<td>{{item.PNo}}</td>
<td>{{item.Location}}</td>
<td>{{item.Company}}</td>
<td>
<button class="btn btn-success btn-sm" ng-click="GenerateReport(item.EId)">
<span class="glyphicon glyphicon-print"></span> PDF
</button>
</td>
</tr>
</table>
</div>
</body>
</html>
Screenshot