private void Lr_SubreportProcessing(object sender, SubreportProcessingEventArgs e) { EmployeeModelService objEmpModelService = new EmployeeModelService(); var ID = Convert.ToInt32(e.Parameters[0].Values[0]); var StartDate = Convert.ToDateTime(e.Parameters[1].Values[0]); var EndDate = Convert.ToDateTime(e.Parameters[2].Values[0]); e.DataSources.Add(new ReportDataSource("DataSet1", objEmpModelService.GetEmployeeAttendanceInfo(ID, StartDate, EndDate))); }
public void GenerateReport(ReportParam rp) { LocalReport lr = new LocalReport(); string path = Path.Combine(Server.MapPath("~/Report"), "mainreport.rdlc"); if (System.IO.File.Exists(path)) { lr.ReportPath = path; } EmployeeModelService objEmpModelService = new EmployeeModelService(); var cm = objEmpModelService.GetEmployeeInfo(rp.EmpListID); var data = cm.FirstOrDefault(x => x.Id == rp.EmpListID); var employeename = data == null ? "All" : data.Name; string filename = employeename + "_" + rp.StartDate.ToString("yyyyMMdd") + "_" + rp.EndDate.ToString("yyyyMMdd") + ".zip"; using (var compressedFileStream = new MemoryStream()) { //Create an archive and store the stream in memory. using (var zipArchive = new ZipArchive(compressedFileStream, ZipArchiveMode.Update, false)) { foreach (var user in cm.Select(x => new { id = x.Id, name = x.Name }).Distinct()) { //Create a zip entry for each attachment var zipEntry = zipArchive.CreateEntry(user.name + ".pdf"); var dataset = cm.Where(x => x.Id == user.id).ToList(); ReportDataSource rd = new ReportDataSource("DataSet1", dataset); lr.SetParameters(new ReportParameter("startdate", rp.StartDate.ToString())); lr.SetParameters(new ReportParameter("enddate", rp.EndDate.ToString())); lr.DataSources.Clear(); lr.DataSources.Add(rd); lr.SubreportProcessing += new SubreportProcessingEventHandler(Lr_SubreportProcessing);; string reportType = "PDF"; string mimeType; string encoding; string fileNameExtension; Warning[] warning; string[] streams; byte[] renderedBytes; renderedBytes = lr.Render( reportType, null, out mimeType, out encoding, out fileNameExtension, out streams, out warning); //Get the stream of the attachment using (var originalFileStream = new MemoryStream(renderedBytes)) { using (var zipEntryStream = zipEntry.Open()) { //Copy the attachment stream to the zip entry stream originalFileStream.CopyTo(zipEntryStream); } } } } sendOutZIP(compressedFileStream.ToArray(), filename); } }