Skip to main content

asp.net mvc generate rdlc/Excel to pdf report

You can follow the code:


  public ActionResult GenerateReport(CustomerPackageReportViewModel CustomerPackageReportViewModel)  
     {  
       List<CustomerPackageDetailsReportViewModel> _customerList = (List<CustomerPackageDetailsReportViewModel>)Session["CustomerPackageInfo"];  
       DataTable tableObj = new DataTable();  
       if (_customerList!=null)  
       {  
         tableObj = Converter.ToDataTable(_customerList);  
       }  
       else  
       {  
         tableObj = Converter.ToDataTable(ArchitectureList);  
       }  
       ReportDataSource rds = new ReportDataSource("dsCustomerPackageInfo", tableObj);  
       ReportViewer localReport = new ReportViewer();  
       localReport.ProcessingMode = ProcessingMode.Local;  
       localReport.LocalReport.ReportPath = Server.MapPath("~/Reports/Billing/rdlc/rptCustomerPackageInfo.rdlc");  
       localReport.LocalReport.DataSources.Add(rds); // Add datasource here  
       string reportType = "PDF";  // You can change type
       string mimeType;  
       string encoding;  
       string fileNameExtension;  
       //The DeviceInfo settings should be changed based on the reportType  
       //http://msdn2.microsoft.com/en-us/library/ms155397.aspx  
       string deviceInfo =  
       "<DeviceInfo>" +  
       " <OutputFormat>PDF</OutputFormat>" +  
       " <PageWidth>8.5in</PageWidth>" +  
       " <PageHeight>11in</PageHeight>" +  
       " <MarginTop>0.5in</MarginTop>" +  
       " <MarginLeft>1in</MarginLeft>" +  
       " <MarginRight>1in</MarginRight>" +  
       " <MarginBottom>0.5in</MarginBottom>" +  
       "</DeviceInfo>";  
       Warning[] warnings;  
       string[] streams;  
       byte[] renderedBytes;  
       renderedBytes = localReport.LocalReport.Render(  
         reportType,  
         null,  
         out mimeType,  
         out encoding,  
         out fileNameExtension,  
         out streams,  
         out warnings);  
       Response.Clear();  
       Response.ContentType = mimeType;  
       Response.AddHeader("content-disposition", "attachment; filename=CustomerPackageInformation." + fileNameExtension);  
       Response.BinaryWrite(renderedBytes);  
       Response.End();  
       Response.Flush();  
       return View(CustomerPackageReportViewModel);  
     }  


Comments

Popular posts from this blog

WPF datagrid cell textbox change event

Entity/Class: public class FeesDetails : INotifyPropertyChanged { public int Id { get; set; } public string FeesName { get; set;} public string FeesDetailsName { get; set; } public int? PaidAmount { get; set; } public event PropertyChangedEventHandler PropertyChanged; private void NotifyPropertyChanged(System.String info) { if (PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(info)); } } public int feesAmount { get; set; } public int FeesAmount { get { return this.feesAmount; } set { if (value != this.feesAmount) { this.feesAmount = value; NotifyPropertyChanged("FeesAmount"); } } } } XAML: <DataGrid AutoGenerateColumns="False" Height="21...

mvc razor textboxfor change event change another textboxfor value

Based on value of Weight, Rate , CNF & AWB it will change the value of Freight , TTLCNF anfd TTLFright . Freight= Weight*Rate; TTLCNF  = Weight*CNF; TTLFright=  Freight+ TTLCNF  + AWB; @Html.TextBoxFor(model => model.Weight, new { onChange="return GetWight(this);"}) @Html.TextBoxFor(model => model.Rate, new { onChange="return GetWight(this);"})/Kg @Html.TextBoxFor(model => model.Freight, new {disabled = "disabled" , @readonly = "readonly" ,onChange="return GetTTLFright(this);"}) @Html.TextBoxFor(model => model.CNFPK, new { onChange="return GetCNFPK(this);"}) @Html.TextBoxFor(model => model.TTLCNF, new {disabled = "disabled" , @readonly = "readonly",onChange="return GetTTLFright(this);" }) @Html.TextBoxFor(model => model.AWB, new { onChange="return GetTTLFright(this);"}) and script <script> function GetW...

mvvm double click event in listview

If you want to get the double click event on a listview item you can try with this code; <ListView Grid.Row="0" Grid.RowSpan="3" Grid.Column="0" Width="250" Height="200" HorizontalAlignment="Stretch" VerticalAlignment="Top" AlternationCount="2" BorderBrush="#FFA8CC7B" ItemContainerStyle="{StaticResource alternatingStyle}" ItemsSource="{Binding FromPayerNameList}" SelectedItem="{Binding SelectedFromPayer, Mode=TwoWay}"> <ListView.ItemTemplate> <DataTemplate> <TextBlock Width="{Binding Path=ActualWidth, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type ListView}}}" Text=...