832 lines
37 KiB
C#
832 lines
37 KiB
C#
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<operating_budget_ro_three>() { 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<compensation_head>() { 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<compensation_head>() { 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<teaching_fee_ro_three>() { 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<teaching_fee_ro_three>() { 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<teaching_fee_ro_three>() { 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<material_ro_three>() { 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<material_ro_three>() { 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<material_education>() { 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<material_ro_three>() { 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<material_ro_three>() { 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<material_ro_three>() { 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<material_fuel_lubricant>() { 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<material_ro_three>() { 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();
|
|
}
|
|
}
|
|
} |