AdminHumanAffairsController.cs 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. using System;
  2. using System.Collections.Generic;
  3. using System.IO;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. using ExcelDataReader;
  8. using GxPress.Common.Exceptions;
  9. using GxPress.Common.Page;
  10. using GxPress.Entity;
  11. using GxPress.Repository.Interface;
  12. using GxPress.Request.HumanAffairs;
  13. using GxPress.Request.User;
  14. using GxPress.Result.HumanAffairs;
  15. using Microsoft.AspNetCore.Authorization;
  16. using Microsoft.AspNetCore.Http;
  17. using Microsoft.AspNetCore.Mvc;
  18. using Microsoft.Extensions.Logging;
  19. namespace GxPress.Api.AdminControllers
  20. {
  21. /// <summary>
  22. /// 人事数据
  23. /// </summary>
  24. [Route("api/admin/human-affairs")]
  25. [ApiController]
  26. [Authorize]
  27. public class AdminHumanAffairsController : ControllerBase
  28. {
  29. private readonly ILogger<AdminHumanAffairsController> _logger;
  30. private readonly IHumanAffairsRepository _repository;
  31. public AdminHumanAffairsController(ILogger<AdminHumanAffairsController> logger, IHumanAffairsRepository repository)
  32. {
  33. _logger = logger;
  34. _repository = repository;
  35. }
  36. /// <summary>
  37. /// 导入人事数据Excel数据
  38. /// </summary>
  39. /// <param name="request"></param>
  40. /// <returns></returns>
  41. [HttpPost("upload")]
  42. public async Task<bool> FinanceExcelUpload([FromBody] UserExcelUploadRequest request)
  43. {
  44. var relativePath = request.ExcelUrl;
  45. Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);
  46. //获取excel分析
  47. var stream = System.IO.File.Open("wwwroot/" + relativePath, FileMode.Open, FileAccess.Read);
  48. IExcelDataReader reader = ExcelReaderFactory.CreateReader(stream);
  49. var result = reader.AsDataSet();
  50. var sheet = result.Tables["Sheet1"];
  51. var error = string.Empty;
  52. var listHumanAffairs = new List<HumanAffairs>();
  53. for (int i = 1; i < sheet.Rows.Count; i++) //行
  54. {
  55. var humanAffairs = new HumanAffairs();
  56. if (i == 1)
  57. continue;
  58. var numberPeople = sheet.Rows[i][0].ToString().Trim(); //人数
  59. if (string.IsNullOrEmpty(numberPeople))
  60. error = "入职/离职人数";
  61. humanAffairs.NumberPeople = int.Parse(numberPeople);
  62. var salary = sheet.Rows[i][1].ToString().Trim(); //工资
  63. if (string.IsNullOrEmpty(salary))
  64. error = "入职/离职工资元";
  65. humanAffairs.Salary = int.Parse(salary);
  66. var humanAffairsType = sheet.Rows[i][2].ToString().Trim(); //工资
  67. if (string.IsNullOrEmpty(humanAffairsType))
  68. error = "类型:1:入职 2:离职";
  69. humanAffairs.HumanAffairsType = int.Parse(humanAffairsType);
  70. var enteringDateTime = sheet.Rows[i][3].ToString().Trim(); //录入时间
  71. if (string.IsNullOrEmpty(enteringDateTime))
  72. error = "录入时间必填";
  73. humanAffairs.EnteringDateTime = DateTime.Parse(enteringDateTime);
  74. if (!string.IsNullOrEmpty(error))
  75. break;
  76. listHumanAffairs.Add(humanAffairs);
  77. }
  78. if (!string.IsNullOrEmpty(error)) throw new BusinessException(error);
  79. //计算
  80. var success = await _repository.InsertAsync(listHumanAffairs);
  81. if (success == false)
  82. throw new BusinessException("服务器异常");
  83. return true;
  84. }
  85. /// <summary>
  86. /// 人事数据列表
  87. /// </summary>
  88. /// <param name="request"></param>
  89. /// <returns></returns>
  90. [HttpPost("list")]
  91. public async Task<PagedList<HumanAffairs>> GetPagedList(PageParameter request)
  92. {
  93. return await _repository.GetPageListAsync(request);
  94. }
  95. /// <summary>
  96. /// 人事图像
  97. /// </summary>
  98. /// <param name="request"></param>
  99. /// <returns></returns>
  100. [HttpPost("chart")]
  101. public async Task<HumanAffairsResult> GetHumanAffairsChart(HumanAffairsRequest request)
  102. {
  103. return await _repository.GetHumanAffairsChartAsync(request);
  104. }
  105. }
  106. }