ExamDataReportService.cs 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. using Furion.DatabaseAccessor.Extensions;
  2. using Furion.JsonSerialization;
  3. using YBEE.EQM.Core;
  4. namespace YBEE.EQM.Application;
  5. /// <summary>
  6. /// 监测数据上报类型管理服务
  7. /// </summary>
  8. public class ExamDataReportService(IRepository<ExamDataReport> rep, IResourceFileService resourceFileService) : IExamDataReportService, ITransient
  9. {
  10. #region 创建更新
  11. /// <summary>
  12. /// 添加上报类型
  13. /// </summary>
  14. /// <param name="input"></param>
  15. /// <returns></returns>
  16. public async Task Add(AddExamDataReportInput input)
  17. {
  18. if (await rep.AnyAsync(t => t.ExamPlanId == input.ExamPlanId && t.Type == input.Type))
  19. {
  20. throw Oops.Oh(ErrorCode.E2002, "该类型");
  21. }
  22. var item = input.Adapt<ExamDataReport>();
  23. await item.InsertAsync();
  24. }
  25. /// <summary>
  26. /// 更新上报类型
  27. /// </summary>
  28. /// <param name="input"></param>
  29. /// <returns></returns>
  30. public async Task Update(UpdateExamDataReportInput input)
  31. {
  32. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  33. item.Remark = input.Remark;
  34. await item.UpdateIncludeAsync([nameof(item.BeginTime), nameof(item.EndTime), nameof(item.Remark)]);
  35. }
  36. /// <summary>
  37. /// 删除上报类型
  38. /// </summary>
  39. /// <param name="input"></param>
  40. /// <returns></returns>
  41. public async Task Del(BaseId input)
  42. {
  43. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  44. if (item.Status != ExamStatus.READY)
  45. {
  46. throw Oops.Oh(ErrorCode.E3001);
  47. }
  48. await item.DeleteAsync();
  49. }
  50. #endregion
  51. #region 状态处理
  52. /// <summary>
  53. /// 开始
  54. /// </summary>
  55. /// <param name="input"></param>
  56. /// <returns></returns>
  57. public async Task Start(BaseId input)
  58. {
  59. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  60. if (item.Status != ExamStatus.READY)
  61. {
  62. throw Oops.Oh(ErrorCode.E2006);
  63. }
  64. item.Status = ExamStatus.ACTIVE;
  65. item.BeginTime = DateTime.Now;
  66. await item.UpdateIncludeAsync([nameof(item.Status), nameof(item.BeginTime)]);
  67. }
  68. /// <summary>
  69. /// 结束
  70. /// </summary>
  71. /// <param name="input"></param>
  72. /// <returns></returns>
  73. public async Task Stop(BaseId input)
  74. {
  75. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  76. if (item.Status != ExamStatus.ACTIVE)
  77. {
  78. throw Oops.Oh(ErrorCode.E2006);
  79. }
  80. item.Status = ExamStatus.STOPPED;
  81. item.EndTime = DateTime.Now;
  82. await item.UpdateIncludeAsync([nameof(item.Status), nameof(item.EndTime)]);
  83. }
  84. /// <summary>
  85. /// 取消
  86. /// </summary>
  87. /// <param name="input"></param>
  88. /// <returns></returns>
  89. public async Task Cancel(BaseId input)
  90. {
  91. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  92. if (item.Status == ExamStatus.ACTIVE)
  93. {
  94. throw Oops.Oh(ErrorCode.E2006);
  95. }
  96. item.Status = ExamStatus.CANCELLED;
  97. item.EndTime = DateTime.Now;
  98. await item.UpdateIncludeAsync([nameof(item.Status), nameof(item.EndTime)]);
  99. }
  100. /// <summary>
  101. /// 添加附件
  102. /// </summary>
  103. /// <param name="input"></param>
  104. /// <returns></returns>
  105. public async Task AddAttachment(AddAttachmentInput input)
  106. {
  107. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.SourceId) ?? throw Oops.Oh(ErrorCode.E2001);
  108. item.Attachments = AttachmentUtil.InsertInto(item.Attachments, input.Adapt<AttachmentItem>());
  109. await item.UpdateIncludeAsync([nameof(item.Attachments)]);
  110. }
  111. /// <summary>
  112. /// 删除附件
  113. /// </summary>
  114. /// <param name="input"></param>
  115. /// <returns></returns>
  116. public async Task DelAttachment(DeleteAttachmentInput input)
  117. {
  118. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.SourceId) ?? throw Oops.Oh(ErrorCode.E2001);
  119. var attachments = AttachmentUtil.GetList(item.Attachments);
  120. var a = attachments.FirstOrDefault(t => t.FileId == input.FileId);
  121. if (a != null)
  122. {
  123. attachments.Remove(a);
  124. item.Attachments = JSON.Serialize(attachments);
  125. await item.UpdateIncludeAsync([nameof(item.Attachments)]);
  126. await resourceFileService.Del(new() { Id = a.FileId });
  127. if (a.ThumbFileId.HasValue && a.ThumbFileId > 0)
  128. {
  129. await resourceFileService.Del(new() { Id = a.ThumbFileId.Value });
  130. }
  131. }
  132. }
  133. #endregion
  134. #region 查询
  135. /// <summary>
  136. /// 根据ID获取监测数据上报类型
  137. /// </summary>
  138. /// <param name="id"></param>
  139. /// <returns></returns>
  140. public async Task<ExamDataReportOutput> GetById(int id)
  141. {
  142. var item = await rep.DetachedEntities.FirstOrDefaultAsync(t => t.Id == id) ?? throw Oops.Oh(ErrorCode.E2001);
  143. return item.Adapt<ExamDataReportOutput>();
  144. }
  145. /// <summary>
  146. /// 根据监测计划ID获取数据上报类型列表
  147. /// </summary>
  148. /// <param name="examPlanId"></param>
  149. /// <returns></returns>
  150. public async Task<List<ExamDataReportOutput>> GetListByExamPlanId(int examPlanId)
  151. {
  152. var items = await rep.DetachedEntities.Where(t => t.ExamPlanId == examPlanId).ProjectToType<ExamDataReportOutput>().OrderBy(t => t.Type).ToListAsync();
  153. var orgCount = await rep.Change<ExamOrg>().DetachedEntities.Where(t => t.ExamPlanId == examPlanId).CountAsync();
  154. foreach (var item in items)
  155. {
  156. var reportedCount = await rep.Change<ExamOrgDataReport>().DetachedEntities.Where(t => t.Type == item.Type && t.ExamOrg.ExamPlanId == examPlanId && t.Status == DataReportStatus.REPORTED).CountAsync();
  157. item.ReportedCount = reportedCount;
  158. item.Count = orgCount;
  159. }
  160. return items;
  161. }
  162. /// <summary>
  163. /// 获取数据上报计划列表
  164. /// </summary>
  165. /// <param name="input"></param>
  166. /// <returns></returns>
  167. public async Task<PageResult<ExamDataReportPlanOutput>> QueryPlanPageList(ExamDataReportPageInput input)
  168. {
  169. var _rep = rep.Change<ExamDataReport>();
  170. var name = !string.IsNullOrEmpty(input.Name?.Trim());
  171. var ret = await _rep.DetachedEntities
  172. .Where(input.Type.HasValue, t => t.Type == input.Type)
  173. .Where(input.EducationStage.HasValue, t => t.ExamPlan.EducationStage == input.EducationStage)
  174. .Where(input.SemesterId.HasValue, t => t.ExamPlan.SemesterId == input.SemesterId)
  175. .Where(input.Status.HasValue, t => t.ExamPlan.Status == input.Status)
  176. .Where(name, t => EF.Functions.Like(t.ExamPlan.Name, $"%{input.Name.ClearWhitespace()}%") || EF.Functions.Like(t.ExamPlan.FullName, $"%{input.Name.ClearWhitespace()}%") || EF.Functions.Like(t.ExamPlan.ShortName, $"%{input.Name.ClearWhitespace()}%"))
  177. .ProjectToType<ExamDataReportPlanOutput>()
  178. .OrderByDescending(t => t.ExamPlan.CreateTime).ThenByDescending(t => t.CreateTime)
  179. .ToADPagedListAsync(input.PageIndex, input.PageSize);
  180. return ret;
  181. }
  182. #endregion
  183. }