Files
rmutr_report/Controllers/RoThree.Controller.cs
kamonwan taengsuk 79dbb95213
All checks were successful
continuous-integration/drone/push Build is passing
bug fixed
2023-11-20 16:32:59 +07:00

1162 lines
49 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;
}
[SwaggerOperation("ร.3 คำชี้แจงงบดำเนินงาน")]
[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();
}
[SwaggerOperation("รายงาน ค่าตอบแทนหัวหน้าภาควิชา")]
[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();
}
[SwaggerOperation("รายงาน ค่าตอบแทนหัวหน้าสาขาวิชา")]
[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();
}
[SwaggerOperation("รายงานค่าสอนพิเศษ")]
[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();
}
[SwaggerOperation("รายงานค่าสอน")]
[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();
}
[SwaggerOperation("รายงานค่าสอนเกินภาระงาน")]
[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();
}
// [SwaggerOperation("รายงานค่าวัสดุสำนักงาน")]
// [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();
// }
// [SwaggerOperation("รายงานวัสดุคอมพิวเตอร์")]
// [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();
// }
[SwaggerOperation("รายงานวัสดุการศึกษา")]
[HttpPost, Route("reports/material_education/{type}")]
[ApiExplorerSettings(GroupName = "reports")]
public IActionResult GetMaterial3Report([FromRoute] string type, [FromBody] material_education three)
{
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();
}
// [SwaggerOperation("รายงานวัสดุหนังสือ")]
// [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();
// }
// [SwaggerOperation("รายงานวัสดุโฆษณาและเผยแพร่")]
// [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();
// }
// [SwaggerOperation("รายงานวัสดุงานสิ่งก่อสร้าง")]
// [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();
// }
[SwaggerOperation("รายงานวัสดุเชื้อเพลิงและหล่อลื่น")]
[HttpPost, Route("reports/material_fuel_lubricant/{type}")]
[ApiExplorerSettings(GroupName = "reports")]
public IActionResult GetMaterial7Report([FromRoute] string type, [FromBody] material_fuel_lubricant three)
{
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();
}
// [SwaggerOperation("รายงานวัสดุไฟฟ้าและวิทยุ")]
// [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();
// }
// [SwaggerOperation("รายงานวัสดุการเกษตร")]
// [HttpPost, Route("reports/material_agricultural/{type}")]
// [ApiExplorerSettings(GroupName = "reports")]
// public IActionResult GetMaterial9Report([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_agricultural.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();
// }
// [SwaggerOperation("รายงานวัสดุงานบ้านงานครัว")]
// [HttpPost, Route("reports/material_housework/{type}")]
// [ApiExplorerSettings(GroupName = "reports")]
// public IActionResult GetMaterial10Report([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_housework.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();
// }
// [SwaggerOperation("รายงานวัสดุวิทยาศาสตร์หรือการแพทย์")]
// [HttpPost, Route("reports/material_science_medical/{type}")]
// [ApiExplorerSettings(GroupName = "reports")]
// public IActionResult GetMaterial11Report([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_science_medical.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();
// }
// [SwaggerOperation("รายงานวัสดุกีฬา")]
// [HttpPost, Route("reports/material_sport/{type}")]
// [ApiExplorerSettings(GroupName = "reports")]
public IActionResult GetMaterial12Report([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_sport.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();
}
[SwaggerOperation("รายงานวัสดุ ร3")]
[HttpPost, Route("reports/material_ro_three/{type}")]
[ApiExplorerSettings(GroupName = "reports")]
public IActionResult GetMaterialRoThreeReport([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_ro_three.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();
}
[SwaggerOperation("ค่าตอบแทนอื่นๆ")]
[HttpPost, Route("reports/other_compensation/{type}")]
[ApiExplorerSettings(GroupName = "reports")]
public IActionResult GetCompensationReport([FromRoute] string type,
[FromBody] parcel_inspection_committee committee)
{
int no = 1;
foreach (var data in committee.data)
{
data.list = "รายการ " + no;
no++;
foreach (var detail in data.data_detail)
{
if (detail != null)
{
detail.total_amount = ( detail.quantity_person *
detail.amount);
}
}
data.total_amount = data.data_detail.Sum(f => f.total_amount);
var s = committee.data.Sum(d => d.total_amount);
committee.total_all_amount = s;
}
var expenses = new List<parcel_inspection_committee>() { committee };
Report report = new Report();
report.Load(_setting.report_path + "other_compensation.frx");
report.RegisterData(expenses, "parcel_inspection_committee");
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.openxmlformats-officedocument.spreadsheetml.sheet",
"other_compensation" + ".xlsx");
}
return Ok();
}
[SwaggerOperation("ค่าตอบแทน_ค่าเช่าบ้าน")]
[HttpPost, Route("reports/house_rent_ro_three/{type}")]
[ApiExplorerSettings(GroupName = "reports")]
public IActionResult GetHouseRentReport([FromRoute] string type,
[FromBody] house_rent_ro_three houseRent)
{
if (houseRent.topic_type == 1)
{
houseRent.topic_name = "ค่าเช่าบ้านชาวต่างประเทศ";
}
if (houseRent.topic_type == 2)
{
houseRent.topic_name = "ค่าเช่าบ้านครูอาสาสมัคร(ชาวจีน)";
}
if (houseRent.topic_type == 3)
{
houseRent.topic_name = "ค่าเช่าบ้านที่ปรึกษาชาวต่างประเทศ";
}
var house = new List<house_rent_ro_three>() { houseRent };
Report report = new Report();
report.Load(_setting.report_path + "house_rent_ro_three.frx");
report.RegisterData(house, "house_rent_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.openxmlformats-officedocument.spreadsheetml.sheet",
"house_rent_ro_three" + ".xlsx");
}
return Ok();
}
[SwaggerOperation("ค่าตอบแทนพิเศษรายเดือน_ค่าตอบแทนเงินประจำตำแหน่ง")]
[HttpPost, Route("reports/compensation_ro_three/{type}")]
[ApiExplorerSettings(GroupName = "reports")]
public IActionResult GetCompensationMoneyReport([FromRoute] string type,
[FromBody] compensation_ro_three compensationRoThree)
{
var compensation = compensationRoThree.data.ToList();
if (compensationRoThree.topic_type == 1)
{
compensationRoThree.topic_name = "ค่าตอบแทนพิเศษรายเดือน อาจารย์ชาวต่างประเทศ";
}
if (compensationRoThree.topic_type == 2)
{
compensationRoThree.topic_name = "ค่าตอบแทนเงินประจำตำแหน่ง";
}
foreach (var detail in compensationRoThree.data)
{
detail.budget_amount = (detail.salary_rate * 12);
}
compensationRoThree.total_amount = compensation.Sum(f => f.budget_amount);
var compensationRoThrees = new List<compensation_ro_three>() { compensationRoThree };
Report report = new Report();
report.Load(_setting.report_path + "compensation_ro_three.frx");
report.RegisterData(compensationRoThrees, "compensation_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.openxmlformats-officedocument.spreadsheetml.sheet",
"compensation_ro_three" + ".xlsx");
}
return Ok();
}
[SwaggerOperation("เงินสมทบกองทุนประกันสังคม_เงินสมทบกองทุนเงินทดแทน")]
[HttpPost, Route("reports/contributions/{type}")]
[ApiExplorerSettings(GroupName = "reports")]
public IActionResult GetContributionsReport([FromRoute] string type,
[FromBody] contributions contributions)
{
var compensation = contributions.data.ToList();
if (contributions.topic_type == 1)
{
contributions.topic_name = "เงินสมทบกองทุนประกันสังคม";
foreach (var detail in contributions.data)
{
detail.amount = (detail.salary * 5)/100;
detail.per_year = (detail.amount * 12);
}
}
if (contributions.topic_type == 2)
{
contributions.topic_name = "เงินสมทบกองทุนเงินทดแทน";
foreach (var detail in contributions.data)
{
detail.amount = (detail.salary * (decimal?)0.2)/100;
detail.per_year = (detail.amount * 12);
}
}
contributions.total_amount = compensation.Sum(f => f.per_year);
var _contributions = new List<contributions>() { contributions };
Report report = new Report();
report.Load(_setting.report_path + "contributions.frx");
report.RegisterData(_contributions, "contributions");
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.openxmlformats-officedocument.spreadsheetml.sheet",
"contributions" + ".xlsx");
}
return Ok();
}
}
}