update
This commit is contained in:
@@ -1,7 +1,11 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Net;
|
||||
using ClosedXML.Excel;
|
||||
using FastReport;
|
||||
using FastReport.Export.OoXML;
|
||||
using FastReport.Export.Pdf;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using rmutr_report.Models;
|
||||
using Swashbuckle.AspNetCore.Annotations;
|
||||
@@ -22,133 +26,171 @@ namespace rmutr_report.Controllers
|
||||
public IActionResult GetExpensesReport([FromRoute] string type,
|
||||
[FromBody] operating_expenses _operating_expenses)
|
||||
{
|
||||
var _operating_expensess = new List<operating_expenses>() { _operating_expenses };
|
||||
|
||||
Report report = new Report();
|
||||
report.Load(_setting.report_path + "operating_expenses.frx");
|
||||
report.RegisterData(_operating_expensess, "operating_expenses");
|
||||
report.Prepare();
|
||||
|
||||
MemoryStream stream = new MemoryStream();
|
||||
switch (type)
|
||||
{
|
||||
var workbook = new XLWorkbook();
|
||||
var ws = workbook.Worksheets.Add("ค่าใช้จ่ายดำเนินงาน");
|
||||
ws.Range("A1:D1").Merge().Value = "ปีงบประมาณ " + _operating_expenses.budget_year + " แผน " + _operating_expenses.plan;
|
||||
ws.Range("A1:D1").Style.Alignment.WrapText = true;
|
||||
ws.Range("A1:D1").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
ws.Range("A1:D1").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
ws.Cell("A1").Style.Font.FontName = "TH Sarabun New";
|
||||
ws.Cell("A1").Style.Font.FontSize = 14;
|
||||
ws.Range("A1:D1").Style.Font.Bold = true;
|
||||
ws.Range("A2:D2").Merge().Value = "ผลผลิต " + _operating_expenses.product+ " หน่วยงาน " + _operating_expenses.agency + " พื้นที่ "+_operating_expenses.area;
|
||||
ws.Range("A2:D2").Style.Alignment.WrapText = true;
|
||||
ws.Range("A2:D2").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
ws.Range("A2:D2").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
ws.Cell("A2").Style.Font.FontName = "TH Sarabun New";
|
||||
ws.Cell("A2").Style.Font.FontSize = 14;
|
||||
ws.Range("A2:D2").Style.Font.Bold = true;
|
||||
ws.Cell("D3").Value = "หน่วย : "+ _operating_expenses.total_amount +" บาท";
|
||||
ws.Cell("D3").Style.Font.FontName = "TH Sarabun New";
|
||||
ws.Cell("D3").Style.Font.FontSize = 14;
|
||||
ws.Cell("D3").Style.Font.Bold = true;
|
||||
ws.Cell("D3").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Right;
|
||||
ws.Cell("D3").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
//ws.Cell("D3").DataType = XLDataType.Number;
|
||||
ws.Cell("D3").Style.NumberFormat.NumberFormatId = 2;
|
||||
ws.Cell("A4").Value = "ลำดับที่";
|
||||
ws.Cell("A4").Style.Font.FontName = "TH Sarabun New";
|
||||
ws.Cell("A4").Style.Font.FontSize = 14;
|
||||
ws.Cell("A4").Style.Font.Bold = true;
|
||||
ws.Cell("A4").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
ws.Cell("A4").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
ws.Cell("A4").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("A4").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("A5").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("A5").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("B4").Value = "งบรายจ่าย";
|
||||
ws.Cell("B4").Style.Font.FontName = "TH Sarabun New";
|
||||
ws.Cell("B4").Style.Font.FontSize = 14;
|
||||
ws.Cell("B4").Style.Font.Bold = true;
|
||||
ws.Cell("B4").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
ws.Cell("B4").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
ws.Cell("B4").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("B4").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("B5").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("B5").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("C4").Value = "คำขอตั้ง";
|
||||
ws.Cell("C4").Style.Font.FontName = "TH Sarabun New";
|
||||
ws.Cell("C4").Style.Font.FontSize = 14;
|
||||
ws.Cell("C4").Style.Font.Bold = true;
|
||||
ws.Cell("C4").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
ws.Cell("C4").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
ws.Cell("C4").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("C4").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("C5").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("C5").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("D4").Value = "สรุปคำชี้แจง";
|
||||
ws.Cell("D4").Style.Font.FontName = "TH Sarabun New";
|
||||
ws.Cell("D4").Style.Font.FontSize = 14;
|
||||
ws.Cell("D4").Style.Font.Bold = true;
|
||||
ws.Cell("D4").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
ws.Cell("D4").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
ws.Cell("D4").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("D4").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("D5").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("D5").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell("A5").Style.Border.TopBorder = XLBorderStyleValues.None;
|
||||
ws.Cell("B5").Style.Border.TopBorder = XLBorderStyleValues.None;
|
||||
ws.Cell("C5").Style.Border.TopBorder = XLBorderStyleValues.None;
|
||||
ws.Cell("D5").Style.Border.TopBorder = XLBorderStyleValues.None;
|
||||
|
||||
ws.Column(1).Width = 10;
|
||||
ws.Column(2).Width = 40;
|
||||
ws.Column(3).Width = 30;
|
||||
ws.Column(4).Width = 50;
|
||||
int row = 6;
|
||||
ws.Cell(row, 3).SetDataType(XLDataType.Number);
|
||||
if (_operating_expenses != null)
|
||||
{
|
||||
ws.Cell("C5").Value = "ปี "+_operating_expenses.request_year;
|
||||
ws.Cell("C5").Style.Alignment.WrapText = true;
|
||||
ws.Cell("C5").Style.Font.FontName = "TH Sarabun New";
|
||||
ws.Cell("C5").Style.Font.FontSize = 14;
|
||||
ws.Cell("C5").Style.Font.Bold = true;
|
||||
ws.Cell("C5").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
ws.Cell("C5").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
|
||||
foreach (var expenses in _operating_expenses.data)
|
||||
{
|
||||
ws.Cell(row, 1).Value = "'"+expenses.no;
|
||||
ws.Cell(row, 2).Value = expenses.expenditure_budget;
|
||||
ws.Cell(row, 3).Value = expenses.amount;
|
||||
ws.Cell(row, 4).Value = expenses.clarification_summary;
|
||||
|
||||
ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Font.FontName =
|
||||
"TH Sarabun New";
|
||||
ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Font.FontSize = 14;
|
||||
ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Alignment.WrapText = true;
|
||||
ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Alignment.Vertical =
|
||||
XLAlignmentVerticalValues.Center;
|
||||
ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Border.OutsideBorder = XLBorderStyleValues.Thin;
|
||||
ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
ws.Cell(row, 1).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
ws.Cell(row, 2).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Left;
|
||||
ws.Cell(row, 3).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Right;
|
||||
ws.Cell(row, 4).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Left;
|
||||
ws.Range(ws.Cell(5, 1), ws.Cell(5, 4)).Style.Font.Bold = true;
|
||||
ws.Range(ws.Cell(6, 1), ws.Cell(6, 4)).Style.Border.BottomBorder = XLBorderStyleValues.Double;
|
||||
ws.Range(ws.Cell(6, 1), ws.Cell(6, 4)).Style.Font.Bold = true;
|
||||
//ws.Cell(row, 3).Style.NumberFormat.NumberFormatId = 2;
|
||||
//ws.Cell(row, 3).DataType = XLDataType.Number;
|
||||
//ws.Cell(row,3).SetDataType(XLDataType.Number);
|
||||
ws.Cell(row,3).Style.NumberFormat.SetFormat("#,#");
|
||||
|
||||
row++;
|
||||
}
|
||||
}
|
||||
using (var stream = new MemoryStream())
|
||||
{
|
||||
workbook.SaveAs(stream);
|
||||
var content = stream.ToArray();
|
||||
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(
|
||||
content,
|
||||
stream,
|
||||
"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
|
||||
"operatingexpenses_" + date + ".xlsx");
|
||||
}
|
||||
"operating_expenses_"+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();
|
||||
}
|
||||
//{
|
||||
// var workbook = new XLWorkbook();
|
||||
// var ws = workbook.Worksheets.Add("ค่าใช้จ่ายดำเนินงาน");
|
||||
// ws.Range("A1:D1").Merge().Value = "ปีงบประมาณ " + _operating_expenses.budget_year + " แผน " + _operating_expenses.plan;
|
||||
// ws.Range("A1:D1").Style.Alignment.WrapText = true;
|
||||
// ws.Range("A1:D1").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
// ws.Range("A1:D1").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
// ws.Cell("A1").Style.Font.FontName = "TH Sarabun New";
|
||||
// ws.Cell("A1").Style.Font.FontSize = 14;
|
||||
// ws.Range("A1:D1").Style.Font.Bold = true;
|
||||
// ws.Range("A2:D2").Merge().Value = "ผลผลิต " + _operating_expenses.product+ " หน่วยงาน " + _operating_expenses.agency + " พื้นที่ "+_operating_expenses.area;
|
||||
// ws.Range("A2:D2").Style.Alignment.WrapText = true;
|
||||
// ws.Range("A2:D2").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
// ws.Range("A2:D2").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
// ws.Cell("A2").Style.Font.FontName = "TH Sarabun New";
|
||||
// ws.Cell("A2").Style.Font.FontSize = 14;
|
||||
// ws.Range("A2:D2").Style.Font.Bold = true;
|
||||
// ws.Cell("D3").Value = "หน่วย : "+ _operating_expenses.total_amount +" บาท";
|
||||
// ws.Cell("D3").Style.Font.FontName = "TH Sarabun New";
|
||||
// ws.Cell("D3").Style.Font.FontSize = 14;
|
||||
// ws.Cell("D3").Style.Font.Bold = true;
|
||||
// ws.Cell("D3").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Right;
|
||||
// ws.Cell("D3").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
// //ws.Cell("D3").DataType = XLDataType.Number;
|
||||
// ws.Cell("D3").Style.NumberFormat.NumberFormatId = 2;
|
||||
// ws.Cell("A4").Value = "ลำดับที่";
|
||||
// ws.Cell("A4").Style.Font.FontName = "TH Sarabun New";
|
||||
// ws.Cell("A4").Style.Font.FontSize = 14;
|
||||
// ws.Cell("A4").Style.Font.Bold = true;
|
||||
// ws.Cell("A4").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
// ws.Cell("A4").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
// ws.Cell("A4").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("A4").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("A5").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("A5").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("B4").Value = "งบรายจ่าย";
|
||||
// ws.Cell("B4").Style.Font.FontName = "TH Sarabun New";
|
||||
// ws.Cell("B4").Style.Font.FontSize = 14;
|
||||
// ws.Cell("B4").Style.Font.Bold = true;
|
||||
// ws.Cell("B4").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
// ws.Cell("B4").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
// ws.Cell("B4").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("B4").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("B5").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("B5").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("C4").Value = "คำขอตั้ง";
|
||||
// ws.Cell("C4").Style.Font.FontName = "TH Sarabun New";
|
||||
// ws.Cell("C4").Style.Font.FontSize = 14;
|
||||
// ws.Cell("C4").Style.Font.Bold = true;
|
||||
// ws.Cell("C4").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
// ws.Cell("C4").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
// ws.Cell("C4").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("C4").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("C5").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("C5").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("D4").Value = "สรุปคำชี้แจง";
|
||||
// ws.Cell("D4").Style.Font.FontName = "TH Sarabun New";
|
||||
// ws.Cell("D4").Style.Font.FontSize = 14;
|
||||
// ws.Cell("D4").Style.Font.Bold = true;
|
||||
// ws.Cell("D4").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
// ws.Cell("D4").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
// ws.Cell("D4").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("D4").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("D5").Style.Border.TopBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("D5").Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell("A5").Style.Border.TopBorder = XLBorderStyleValues.None;
|
||||
// ws.Cell("B5").Style.Border.TopBorder = XLBorderStyleValues.None;
|
||||
// ws.Cell("C5").Style.Border.TopBorder = XLBorderStyleValues.None;
|
||||
// ws.Cell("D5").Style.Border.TopBorder = XLBorderStyleValues.None;
|
||||
//
|
||||
// ws.Column(1).Width = 10;
|
||||
// ws.Column(2).Width = 40;
|
||||
// ws.Column(3).Width = 30;
|
||||
// ws.Column(4).Width = 50;
|
||||
// int row = 6;
|
||||
// ws.Cell(row, 3).SetDataType(XLDataType.Number);
|
||||
// if (_operating_expenses != null)
|
||||
// {
|
||||
// ws.Cell("C5").Value = "ปี "+_operating_expenses.request_year;
|
||||
// ws.Cell("C5").Style.Alignment.WrapText = true;
|
||||
// ws.Cell("C5").Style.Font.FontName = "TH Sarabun New";
|
||||
// ws.Cell("C5").Style.Font.FontSize = 14;
|
||||
// ws.Cell("C5").Style.Font.Bold = true;
|
||||
// ws.Cell("C5").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
// ws.Cell("C5").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center;
|
||||
//
|
||||
// foreach (var expenses in _operating_expenses.data)
|
||||
// {
|
||||
// ws.Cell(row, 1).Value = "'"+expenses.no;
|
||||
// ws.Cell(row, 2).Value = expenses.expenditure_budget;
|
||||
// ws.Cell(row, 3).Value = expenses.amount;
|
||||
// ws.Cell(row, 4).Value = expenses.clarification_summary;
|
||||
//
|
||||
// ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Font.FontName =
|
||||
// "TH Sarabun New";
|
||||
// ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Font.FontSize = 14;
|
||||
// ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Alignment.WrapText = true;
|
||||
// ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Alignment.Vertical =
|
||||
// XLAlignmentVerticalValues.Center;
|
||||
// ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Border.OutsideBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Range(ws.Cell(row, 1), ws.Cell(row, 4)).Style.Border.RightBorder = XLBorderStyleValues.Thin;
|
||||
// ws.Cell(row, 1).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center;
|
||||
// ws.Cell(row, 2).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Left;
|
||||
// ws.Cell(row, 3).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Right;
|
||||
// ws.Cell(row, 4).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Left;
|
||||
// ws.Range(ws.Cell(5, 1), ws.Cell(5, 4)).Style.Font.Bold = true;
|
||||
// ws.Range(ws.Cell(6, 1), ws.Cell(6, 4)).Style.Border.BottomBorder = XLBorderStyleValues.Double;
|
||||
// ws.Range(ws.Cell(6, 1), ws.Cell(6, 4)).Style.Font.Bold = true;
|
||||
// //ws.Cell(row, 3).Style.NumberFormat.NumberFormatId = 2;
|
||||
// //ws.Cell(row, 3).DataType = XLDataType.Number;
|
||||
// //ws.Cell(row,3).SetDataType(XLDataType.Number);
|
||||
// ws.Cell(row,3).Style.NumberFormat.SetFormat("#,#");
|
||||
//
|
||||
// row++;
|
||||
// }
|
||||
// }
|
||||
// using (var stream = new MemoryStream())
|
||||
// {
|
||||
// workbook.SaveAs(stream);
|
||||
// var content = stream.ToArray();
|
||||
// string date = DateTime.Now.ToString("yyyyMMddHHmmss");
|
||||
// return File(
|
||||
// content,
|
||||
// "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
|
||||
// "operatingexpenses_" + date + ".xlsx");
|
||||
// }
|
||||
//}
|
||||
//}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user