using System; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.Data; using System.Globalization; using System.IO; using System.Linq; using System.Threading.Tasks; using ClosedXML.Excel; using DocumentFormat.OpenXml.Office2010.ExcelAc; using DocumentFormat.OpenXml.Spreadsheet; using ExcelDataReader; using FastReport; using FastReport.Export.Csv; using FastReport.Export.Mht; using FastReport.Export.OoXML; using FastReport.Export.Pdf; using Microsoft.AspNetCore.Mvc; using Microsoft.VisualBasic; using rmutr_report.Models; using rmutr_report.Models.Hr; using Swashbuckle.AspNetCore.Annotations; namespace rmutr_report.Controllers { [SwaggerTag("สำหรับรายงานรายละเอียดตัวชี้วัดแผนกลยุทธ์ทางการเงิน")] public class detailkpi_finance : Controller { readonly Setting _setting; public detailkpi_finance(Setting setting) { _setting = setting; } [HttpPost, Route("reports/detail_kpi_finance/{type}")] [ApiExplorerSettings(GroupName = "reports")] public IActionResult GetDetailKpiReport([FromRoute] string type, [FromBody] detail_kpi_finance _kpi) { var workbook = new XLWorkbook(); var ws = workbook.Worksheets.Add("detailkpi"); ws.Range("A1:W1").Merge().Value = "แจ้งรายละเอียดตัวชี้วัดแผนกลยุทธ์ทางการเงิน พ.ศ. " + _kpi.year_range+" มหาวิทยาลัยเทคโนโลยีราชมงคลรัตนโกสินทร์ ประจำปีงบประมาณ พ.ศ. "+_kpi.budget_year; ws.Cell("A1").Style.Font.Bold = true; ws.Cell("A1").Style.Alignment.WrapText = true; //ws.Range("A2:A3").Column(1).Merge(); ws.Range("A2:A3").Merge().Value = "ลำดับ"; ws.Range("A2:A3").Style.Font.Bold = true; ws.Range("B2:B3").Merge().Value = "ตัวชี้วัด"; ws.Range("B2:B3").Style.Font.Bold = true; ws.Range("B2:B3").Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Range("C2:C3").Merge().Value = "หน่วยนับ"; ws.Range("C2:C3").Style.Font.Bold = true; ws.Range("C2:C3").Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Range("D2:D3").Merge().Value = "ผู้กำกับ"; ws.Range("D2:D3").Style.Font.Bold = true; ws.Range("D2:D3").Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Range("E2:E3").Merge().Value = "ผู้รับผิดชอบตัวชี้วัด"; ws.Range("E2:E3").Style.Font.Bold = true; ws.Range("E2:E3").Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Range("F2:F3").Merge().Value = "ผู้รวบรวมและรายงานผล"; ws.Range("F2:F3").Style.Font.Bold = true; ws.Range("F2:F3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Range("G2:G3").Merge().Value = "แผนปี "+_kpi.plan_year.Substring(2, 2)+" มหาวิทยาลัย"; ws.Range("G2:G3").Style.Font.Bold = true; ws.Range("G2:G3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Range("H2:W2").Merge().Value = "แผนปี "+_kpi.plan_year.Substring(2, 2)+" หน่วยงาน"; ws.Range("H2:W2").Style.Font.Bold = true; ws.Range("H2:H3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("H3").Value = _kpi.text1; ws.Cell("I3").Value = _kpi.text2; ws.Cell("J3").Value = _kpi.text3; ws.Cell("K3").Value = _kpi.text4; ws.Cell("L3").Value = _kpi.text5; ws.Cell("M3").Value = _kpi.text6; ws.Cell("N3").Value = _kpi.text7; ws.Cell("O3").Value = _kpi.text8; ws.Cell("P3").Value = _kpi.text9; ws.Cell("Q3").Value = _kpi.text10; ws.Cell("R3").Value = _kpi.text11; ws.Cell("S3").Value = _kpi.text12; ws.Cell("T3").Value = _kpi.text13; ws.Cell("U3").Value = _kpi.text14; ws.Cell("V3").Value = _kpi.text15; ws.Cell("W3").Value = _kpi.text16; ws.Range("A1:W1").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center; ws.Range("A1:W1").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center; ws.Range("H3:W3").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center; ws.Range("H3:W3").Style.Alignment.SetTextRotation(90); ws.Range("H3:W3").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center; ws.Cell("H2").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center; ws.Cell("H2").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center; ws.Range("A2:G3").Style.Alignment.Vertical = XLAlignmentVerticalValues.Center; ws.Range("A2:G3").Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center; ws.Range("A2:G3").Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Range("B2:C3").Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Range("A2:W3").Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Range("H2:W2").Style.Border.BottomBorder = XLBorderStyleValues.Thin; ws.Range("H2:H3").Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell("H3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("I3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("J3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("K3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("L3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("M3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("N3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("O3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("P3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("Q3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("R3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("S3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("T3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("U3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("V3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell("W3").Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Column(1).Width = 10; ws.Column(2).Width = 30; ws.Column(3).Width = 20; ws.Column(4).Width = 30; ws.Column(5).Width = 30; ws.Column(6).Width = 30; ws.Column(7).Width = 30; ws.Column(8).Width = 10; ws.Column(9).Width = 10; ws.Column(10).Width = 10; ws.Column(11).Width = 10; ws.Column(12).Width = 10; ws.Column(13).Width = 10; ws.Column(15).Width = 10; ws.Column(16).Width = 10; ws.Column(17).Width = 10; ws.Column(18).Width = 10; ws.Column(19).Width = 10; ws.Column(20).Width = 10; ws.Column(21).Width = 10; ws.Column(22).Width = 10; ws.Column(23).Width = 10; ws.Column(1).Style.Font.FontName = "TH Sarabun New"; ws.Column(1).Style.Font.FontSize = 16; ws.Column(2).Style.Font.FontName = "TH Sarabun New"; ws.Column(2).Style.Font.FontSize = 16; ws.Column(3).Style.Font.FontName = "TH Sarabun New"; ws.Column(3).Style.Font.FontSize = 16; ws.Column(4).Style.Font.FontName = "TH Sarabun New"; ws.Column(4).Style.Font.FontSize = 16; ws.Column(5).Style.Font.FontName = "TH Sarabun New"; ws.Column(5).Style.Font.FontSize = 16; ws.Column(6).Style.Font.FontName = "TH Sarabun New"; ws.Column(6).Style.Font.FontSize = 16; ws.Column(7).Style.Font.FontName = "TH Sarabun New"; ws.Column(7).Style.Font.FontSize = 16; ws.Range("H3:W3").Style.Font.FontName = "TH Sarabun New"; ws.Range("H3:W3").Style.Font.FontSize = 16; int col = 1; int row = 4; int no = 1; int rowno = 1; // foreach (var kpis in _kpi) // { if (_kpi != null) { // ws.Range("A1:H1").Merge().Value = // "ตัวชี้วัดและเป้าหมายตามแผนปฏิบัติราชการประจำปี พ.ศ. " + _kpi.academic_year +" มหาวิทยาลัยเทคโนโลยีราชมงคลรัตนโกสินทร์"; // ws.Range("A1:H1").Merge().Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center; // ws.Range("A1:H1").Merge().Style.Alignment.Vertical = XLAlignmentVerticalValues.Center; // ws.Cell("A1").Style.Font.Bold = true; // ws.Cell("A1").Style.Font.FontName = "TH Sarabun New"; // ws.Cell("A1").Style.Font.FontSize = 16; // ws.Range("D2:E2").Merge().Value = "ค่าเป้าหมาย ปี " + _kpi.academic_year.Substring(2, 2); // ws.Range("D2:E2").Style.Font.Bold = true; foreach (var header in _kpi.header_data) { string kpiname = "ประเด็นยุทธ์ศาสตร์ที่ " + no +" " + header.strategic_issues; no++; ws.Cell(row, 1).SetValue(kpiname).Style.Font.Bold = true; // ws.Cell(row, 2).Value = header.header_1; ws.Cell(row, 1).Style.Fill.BackgroundColor = XLColor.Bisque; ws.Cell(row, 1).Style.Border.OutsideBorder = XLBorderStyleValues.None; ws.Range(ws.Cell(row, 1), ws.Cell(row, 23)).Merge().Style.Fill.BackgroundColor = XLColor.Bisque; ws.Cell(row, 1).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Left; ws.Cell(row, 1).Style.Alignment.Vertical = XLAlignmentVerticalValues.Center; ws.Cell(row,23).Style.Border.RightBorder = XLBorderStyleValues.Thin; row++; foreach (var data1 in header.data) { // if ( rowno > 1 ) // { // ws.Range(ws.Cell(row, 1), ws.Cell(row,1)).Merge() // } ws.Cell(row, 1).Value = rowno; ws.Cell(row, 2).Value = data1.name; ws.Cell(row, 3).Value = data1.unit; ws.Cell(row, 4).Value = data1.director; ws.Cell(row, 5).Value = data1.responsible_person; ws.Cell(row, 6).Value = data1.compiler_reporter; ws.Cell(row, 7).Value = data1.plan_value; ws.Cell(row, 8).Value = data1.value1; ws.Cell(row, 9).Value = data1.value2; ws.Cell(row, 10).Value = data1.value3; ws.Cell(row, 11).Value = data1.value4; ws.Cell(row, 12).Value = data1.value5; ws.Cell(row, 13).Value = data1.value6; ws.Cell(row, 14).Value = data1.value7; ws.Cell(row, 15).Value = data1.value8; ws.Cell(row, 16).Value = data1.value9; ws.Cell(row, 17).Value = data1.value10; ws.Cell(row, 18).Value = data1.value11; ws.Cell(row, 19).Value = data1.value12; ws.Cell(row, 20).Value = data1.value13; ws.Cell(row, 21).Value = data1.value14; ws.Cell(row, 22).Value = data1.value15; ws.Cell(row, 23).Value = data1.value16; ws.Range(ws.Cell(row, 1),ws.Cell(row,23)).Style.Alignment.Horizontal = XLAlignmentHorizontalValues.Center; ws.Range(ws.Cell(row, 1),ws.Cell(row,23)).Style.Alignment.Vertical = XLAlignmentVerticalValues.Center; ws.Range(ws.Cell(row,8),ws.Cell(row,23)).Style.Alignment.SetTextRotation(90); ws.Cell(row, 1).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 1).Style.Border.LeftBorder = XLBorderStyleValues.Thin; ws.Cell(row, 1).Style.Border.RightBorder = XLBorderStyleValues.Thin; ws.Cell(row, 2).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 3).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 4).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 5).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 6).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 7).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 8).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 9).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 10).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 11).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 12).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 13).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 14).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 15).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 16).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 17).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 18).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 19).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 20).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 21).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 22).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Cell(row, 23).Style.Border.OutsideBorder = XLBorderStyleValues.Thin; ws.Range(ws.Cell(row, 1),ws.Cell(row,23)).Style.Alignment.WrapText = true; ws.Range(ws.Cell(row, 1),ws.Cell(row,23)).Style.Font.FontName = "TH Sarabun New"; ws.Range(ws.Cell(row, 1),ws.Cell(row,23)).Style.Font.FontSize = 16; row++; rowno++; } //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", date + ".xlsx"); } } } }