using System; using System.Collections.Generic; using System.IO; using System.Linq; using ClosedXML; using FastReport; using FastReport.Export.OoXML; using FastReport.Export.Pdf; using Microsoft.AspNetCore.Mvc; using rmutr_report.Models; using rmutr_report.Models.RoThree; using Swashbuckle.AspNetCore.Annotations; namespace rmutr_report.Controllers { [SwaggerTag("สำหรับรายงาน ร.3 คำชี้แจงงบดำเนินงาน")] public class RoThree : Controller { readonly Setting _setting; public RoThree(Setting setting) { this._setting = setting; } [HttpPost, Route("reports/operating_budget_ro_three/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetRoThreeReport([FromRoute] string type, [FromBody] operating_budget_ro_three three) { var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "operating_budget_ro_three.frx"); report.RegisterData(threes, "operating_budget_ro_three"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/compensation_head_department/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetComReport([FromRoute] string type, [FromBody] compensation_head three) { if (three.data != null) { var s = three.data.Sum(f => f.budget_amount); three.total_amount = s; } var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "compensation_head_department.frx"); report.RegisterData(threes, "compensation_head"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/compensation_head_major/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetCom2Report([FromRoute] string type, [FromBody] compensation_head three) { if (three.data != null) { var s = three.data.Sum(f => f.budget_amount); three.total_amount = s; } var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "compensation_head_major.frx"); report.RegisterData(threes, "compensation_head"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/teaching_fee_extra_ro_three/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetTeachExReport([FromRoute] string type, [FromBody] teaching_fee_ro_three three) { var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "teaching_fee_extra.frx"); report.RegisterData(threes, "teaching_fee_ro_three"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/teaching_fee_ro_three/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetTeachReport([FromRoute] string type, [FromBody] teaching_fee_ro_three three) { var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "teaching_fee.frx"); report.RegisterData(threes, "teaching_fee_ro_three"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/teaching_fee_workload/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetTeachWorkloadReport([FromRoute] string type, [FromBody] teaching_fee_ro_three three) { var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "teaching_fee_workload.frx"); report.RegisterData(threes, "teaching_fee_ro_three"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/material_office/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetMaterial1Report([FromRoute] string type, [FromBody] material_ro_three three) { if (three.data != null) { var s = three.data.Sum(f => f.material_amount); three.total_amount = s; } var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "material_office.frx"); report.RegisterData(threes, "material_ro_three"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/material_computer/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetMaterial2Report([FromRoute] string type, [FromBody] material_ro_three three) { if (three.data != null) { var s = three.data.Sum(f => f.material_amount); three.total_amount = s; } var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "material_computer.frx"); report.RegisterData(threes, "material_ro_three"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/material_education/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetMaterial3Report([FromRoute] string type, [FromBody] material_education three) { // if (three != null) // { // var suml_1 = three.data_1.Sum(d => d.semester_year_1_level_1); // var suml_2 = three.data_1.Sum(d => d.semester_year_1_level_2); // var suml_3 = three.data_1.Sum(d => d.semester_year_1_level_3); // var suml_4 = three.data_1.Sum(d => d.semester_year_1_level_4); // var suml_5 = three.data_1.Sum(d => d.semester_year_1_level_5); // var suml_6 = three.data_1.Sum(d => d.rate_semester_year_level_1); // var suml_7 = three.data_1.Sum(d => d.total_semester_year_level_1); // var suml_8 = three.data_1.Sum(d => d.material_amount_1); // var suml_9 = three.data_1.Sum(d => d.semester_year_2_level_1); // var suml_10 = three.data_1.Sum(d => d.semester_year_2_level_2); // var suml_11 = three.data_1.Sum(d => d.semester_year_2_level_3); // var suml_12 = three.data_1.Sum(d => d.semester_year_2_level_4); // var suml_13 = three.data_1.Sum(d => d.semester_year_2_level_5); // var suml_14 = three.data_1.Sum(d => d.rate_semester_year_level_2); // var suml_15 = three.data_1.Sum(d => d.total_semester_year_level_2); // var suml_16 = three.data_1.Sum(d => d.material_amount_2); // var suml_17 = three.data_1.Sum(d => d.total_material); // three.semester_year_1_level_1 = suml_1; // three.semester_year_1_level_2 = suml_2; // three.semester_year_1_level_3 = suml_3; // three.semester_year_1_level_4 = suml_4; // three.semester_year_1_level_5 = suml_5; // three.rate_semester_year_level_1 = suml_6; // three.total_semester_year_level_1 = suml_7; // three.material_amount_1 = suml_8; // three.semester_year_2_level_1 = suml_9; // three.semester_year_2_level_2 = suml_10; // three.semester_year_2_level_3 = suml_11; // three.semester_year_2_level_4 = suml_12; // three.semester_year_2_level_5 = suml_13; // three.rate_semester_year_level_2 = suml_14; // three.total_semester_year_level_2 = suml_15; // three.material_amount_2 = suml_16; // three.total_material = suml_17; // // foreach (var d1 in three.data_1) // { // if (three.data_1 != null) // { // var suml1 = d1.data_2.Sum(d => d.semester_year_1_level_1); // var suml2 = d1.data_2.Sum(d => d.semester_year_1_level_2); // var suml3 = d1.data_2.Sum(d => d.semester_year_1_level_3); // var suml4 = d1.data_2.Sum(d => d.semester_year_1_level_4); // var suml5 = d1.data_2.Sum(d => d.semester_year_1_level_5); // var suml6 = d1.data_2.Sum(d => d.rate_semester_year_level_1); // var suml7 = d1.data_2.Sum(d => d.total_semester_year_level_1); // var suml8 = d1.data_2.Sum(d => d.material_amount_1); // var suml9 = d1.data_2.Sum(d => d.semester_year_2_level_1); // var suml10 = d1.data_2.Sum(d => d.semester_year_2_level_2); // var suml11 = d1.data_2.Sum(d => d.semester_year_2_level_3); // var suml12 = d1.data_2.Sum(d => d.semester_year_2_level_4); // var suml13 = d1.data_2.Sum(d => d.semester_year_2_level_5); // var suml14 = d1.data_2.Sum(d => d.rate_semester_year_level_2); // var suml15 = d1.data_2.Sum(d => d.total_semester_year_level_2); // var suml16 = d1.data_2.Sum(d => d.material_amount_2); // var suml17 = d1.data_2.Sum(d => d.total_material); // d1.semester_year_1_level_1 = suml1; // d1.semester_year_1_level_2 = suml2; // d1.semester_year_1_level_3 = suml3; // d1.semester_year_1_level_4 = suml4; // d1.semester_year_1_level_5 = suml5; // d1.rate_semester_year_level_1 = suml6; // d1.total_semester_year_level_1 = suml7; // d1.material_amount_1 = suml8; // d1.semester_year_2_level_1 = suml9; // d1.semester_year_2_level_2 = suml10; // d1.semester_year_2_level_3 = suml11; // d1.semester_year_2_level_4 = suml12; // d1.semester_year_2_level_5 = suml13; // d1.rate_semester_year_level_2 = suml14; // d1.total_semester_year_level_2 = suml15; // d1.material_amount_2 = suml16; // d1.total_material = suml17; // } // foreach (var d2 in d1.data_2) // { // if (d1.data_2!=null) // { // var suml1 = d1.data_2.Sum(d => d.semester_year_1_level_1); // var suml2 = d1.data_2.Sum(d => d.semester_year_1_level_2); // var suml3 = d1.data_2.Sum(d => d.semester_year_1_level_3); // var suml4 = d1.data_2.Sum(d => d.semester_year_1_level_4); // var suml5 = d1.data_2.Sum(d => d.semester_year_1_level_5); // var t1 = d1.data_2.Sum(d => d.total_semester_year_level_1); // var r1 = d1.data_2.Sum(d => d.rate_semester_year_level_1); // var suml6 = d1.data_2.Sum(d => d.semester_year_2_level_1); // var suml7 = d1.data_2.Sum(d => d.semester_year_2_level_2); // var suml8 = d1.data_2.Sum(d => d.semester_year_2_level_3); // var suml9 = d1.data_2.Sum(d => d.semester_year_2_level_4); // var suml10 = d1.data_2.Sum(d => d.semester_year_2_level_5); // var t2 = d1.data_2.Sum(d => d.total_semester_year_level_2); // var r2 = d1.data_2.Sum(d => d.rate_semester_year_level_2); // d2.total_semester_year_level_1 = suml1+suml2+suml3+suml4+suml5; // d2.material_amount_1 = t1*r1; // d2.total_semester_year_level_2 = suml6+suml7+suml8+suml9+suml10; // d2.material_amount_2 = t2*r2; // d2.total_material = (t1*r1)+(t2*r2); // } // // foreach (var d3 in d2.data_3) // { // if (d2.data_3 != null) // { // // var suml1 = d2.data_3.Sum(d => d.semester_year_1_level_1); // var suml2 = d2.data_3.Sum(d => d.semester_year_1_level_2); // var suml3 = d2.data_3.Sum(d => d.semester_year_1_level_3); // var suml4 = d2.data_3.Sum(d => d.semester_year_1_level_4); // var suml5 = d2.data_3.Sum(d => d.semester_year_1_level_5); // var t1 = d2.data_3.Sum(d => d.total_semester_year_level_1); // var r1 = d2.data_3.Sum(d => d.rate_semester_year_level_1); // var suml6 = d2.data_3.Sum(d => d.semester_year_2_level_1); // var suml7 = d2.data_3.Sum(d => d.semester_year_2_level_2); // var suml8 = d2.data_3.Sum(d => d.semester_year_2_level_3); // var suml9 = d2.data_3.Sum(d => d.semester_year_2_level_4); // var suml10 = d2.data_3.Sum(d => d.semester_year_2_level_5); // var t2 = d2.data_3.Sum(d => d.total_semester_year_level_2); // var r2 = d2.data_3.Sum(d => d.rate_semester_year_level_2); // d3.total_semester_year_level_1 = suml1 + suml2 + suml3 + suml4 + suml5; // d3.material_amount_1 = t1 * r1; // d3.total_semester_year_level_2 = suml6 + suml7 + suml8 + suml9 + suml10; // d3.material_amount_2 = t2 * r2; // d3.total_material = (t1 * r1) + (t2 * r2); // } // } // } // } // } var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "material_education.frx"); report.RegisterData(threes, "material_education"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/material_book/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetMaterial4Report([FromRoute] string type, [FromBody] material_ro_three three) { if (three.data != null) { var s = three.data.Sum(f => f.material_amount); three.total_amount = s; } var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "material_book.frx"); report.RegisterData(threes, "material_ro_three"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/material_advertise/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetMaterial5Report([FromRoute] string type, [FromBody] material_ro_three three) { if (three.data != null) { var s = three.data.Sum(f => f.material_amount); three.total_amount = s; } var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "material_advertise.frx"); report.RegisterData(threes, "material_ro_three"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/material_construction/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetMaterial6Report([FromRoute] string type, [FromBody] material_ro_three three) { if (three.data != null) { var s = three.data.Sum(f => f.material_amount); three.total_amount = s; } var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "material_construction.frx"); report.RegisterData(threes, "material_ro_three"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/material_fuel_lubricant/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetMaterial7Report([FromRoute] string type, [FromBody] material_fuel_lubricant three) { // if (three.data != null) // { // var s4 = three.data.Sum(f => f.total_amount); // foreach (var data in three.data) // { // var s1 = data.data_detail.Sum(f => f.distance); // var s2 = data.data_detail.Sum(f => f.average_rate); // var s3 = data.data_detail.Sum(i => i.total_amount); // foreach (var detail in data.data_detail) // { // if (detail != null) // { // detail.total_amount = detail.distance * detail.average_rate; // } // // data.total_amount = s3; // } // // three.total_amount = data.total_amount; // } // } var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "material_fuel_lubricant.frx"); report.RegisterData(threes, "material_fuel_lubricant"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } [HttpPost, Route("reports/material_electric/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetMaterial8Report([FromRoute] string type, [FromBody] material_ro_three three) { if (three.data != null) { var s = three.data.Sum(f => f.material_amount); three.total_amount = s; } var threes = new List() { three }; Report report = new Report(); report.Load(_setting.report_path + "material_electric.frx"); report.RegisterData(threes, "material_ro_three"); report.Prepare(); MemoryStream stream = new MemoryStream(); switch (type) { case "pdf": PDFExport pdf = new PDFExport(); report.Export(pdf, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "application/pdf"); case "xls": case "xlsx": Excel2007Export excel = new Excel2007Export(); report.Export(excel, stream); stream.Seek(0, SeekOrigin.Begin); //return File(stream, "application/vnd.ms-excel"); string date = DateTime.Now.ToString("yyyyMMddHHmmss"); return File( stream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet", date + ".xlsx"); break; case "doc": case "docx": Word2007Export word = new Word2007Export(); report.Export(word, stream); stream.Seek(0, SeekOrigin.Begin); return File(stream, "appllication/vnd.ms-word"); break; } return Ok(); } } }