ExamDataPublishService.cs 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. using Furion.DatabaseAccessor.Extensions;
  2. using YBEE.EQM.Core;
  3. namespace YBEE.EQM.Application;
  4. /// <summary>
  5. /// 监测发布内容管理服务
  6. /// </summary>
  7. public class ExamDataPublishService(IRepository<ExamDataPublish> rep, IExamSampleService examSampleService) : IExamDataPublishService, ITransient
  8. {
  9. #region 创建更新
  10. /// <summary>
  11. /// 添加发布内容
  12. /// </summary>
  13. /// <param name="input"></param>
  14. /// <returns></returns>
  15. public async Task Add(AddExamDataPublishInput input)
  16. {
  17. //if (await _rep.AnyAsync(t => t.ExamPlanId == input.ExamPlanId && t.Type == input.Type))
  18. //{
  19. // throw Oops.Oh(ErrorCode.E2002, "该类型");
  20. //}
  21. var item = input.Adapt<ExamDataPublish>();
  22. await item.InsertAsync();
  23. }
  24. /// <summary>
  25. /// 更新发布内容
  26. /// </summary>
  27. /// <param name="input"></param>
  28. /// <returns></returns>
  29. public async Task Update(UpdateExamDataPublishInput input)
  30. {
  31. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  32. item.Name = input.Name;
  33. item.Remark = input.Remark;
  34. await item.UpdateIncludeAsync([nameof(item.Name), 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 != PublishStatus.UNPUBLISH)
  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 Publish(BaseId input)
  58. {
  59. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  60. if (item.Status == PublishStatus.PUBLISHED)
  61. {
  62. throw Oops.Oh(ErrorCode.E2006);
  63. }
  64. if (item.Type == DataPublishType.STUDENT_SAMPLE_LIST || item.Type == DataPublishType.STUDENT_SAMPLE_COUNT_LIST)
  65. {
  66. var selected = await examSampleService.CheckSelectedByExamPlanId(item.ExamPlanId);
  67. // 未选定抽样方案不能发布
  68. if (!selected)
  69. {
  70. throw Oops.Oh(ErrorCode.E3008);
  71. }
  72. }
  73. item.Status = PublishStatus.PUBLISHED;
  74. item.PublishTime = DateTime.Now;
  75. item.PublishSysUserId = CurrentSysUserInfo.SysUserId;
  76. await item.UpdateIncludeAsync([nameof(item.Status), nameof(item.PublishTime), nameof(item.PublishSysUserId)]);
  77. }
  78. /// <summary>
  79. /// 取消
  80. /// </summary>
  81. /// <param name="input"></param>
  82. /// <returns></returns>
  83. public async Task Unpublish(BaseId input)
  84. {
  85. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  86. if (item.Status != PublishStatus.PUBLISHED)
  87. {
  88. throw Oops.Oh(ErrorCode.E2006);
  89. }
  90. item.Status = PublishStatus.UNPUBLISH; // 设置为未发布
  91. await item.UpdateIncludeAsync([nameof(item.Status)]);
  92. }
  93. #endregion
  94. #region 查询
  95. /// <summary>
  96. /// 根据ID获取监测数据发布内容
  97. /// </summary>
  98. /// <param name="id"></param>
  99. /// <returns></returns>
  100. public async Task<ExamDataPublishOutput> GetById(int id)
  101. {
  102. var item = await rep.DetachedEntities.FirstOrDefaultAsync(t => t.Id == id) ?? throw Oops.Oh(ErrorCode.E2001);
  103. return item.Adapt<ExamDataPublishOutput>();
  104. }
  105. /// <summary>
  106. /// 根据监测计划ID获取数据发布内容列表
  107. /// </summary>
  108. /// <param name="examPlanId">监测计划ID</param>
  109. /// <param name="type">发布类型</param>
  110. /// <returns></returns>
  111. public async Task<List<ExamDataPublishOutput>> GetListByExamPlanId(int examPlanId, DataPublishType? type)
  112. {
  113. var items = await rep.DetachedEntities
  114. .Where(t => t.ExamPlanId == examPlanId)
  115. .Where(type.HasValue, t => t.Type == type)
  116. .ProjectToType<ExamDataPublishOutput>()
  117. .OrderBy(t => t.Type)
  118. .ToListAsync();
  119. return items;
  120. }
  121. /// <summary>
  122. /// 分页查询面向机构发布的内容列表
  123. /// </summary>
  124. /// <param name="input"></param>
  125. /// <returns></returns>
  126. public async Task<PageResult<ExamDataPublishOrgOutput>> QueryOrgPageList(ExamDataPublishOrgPageInput input)
  127. {
  128. string where = $"T1.sys_org_id = @sysOrgId AND T2.type = @type AND T2.`status` = {(int)PublishStatus.PUBLISHED} AND T2.is_deleted = 0 AND T3.is_deleted = 0";
  129. if (input.SemesterId.HasValue)
  130. {
  131. where = $"{where} AND T3.semester_id = {input.SemesterId.Value}";
  132. }
  133. if (!string.IsNullOrEmpty(input.Name?.Trim()))
  134. {
  135. where = $"{where} AND T3.full_name LIKE '%{input.Name.Trim()}%'";
  136. }
  137. var p = new
  138. {
  139. CurrentSysUserInfo.SysOrgId,
  140. input.PageSize,
  141. PageOffset = (input.PageIndex - 1) * input.PageSize,
  142. input.Type,
  143. input.Name,
  144. input.SemesterId,
  145. };
  146. var totalCount = await rep.SqlScalarAsync<int>($@"
  147. SELECT COUNT(1) AS total_count
  148. FROM exam_org AS T1
  149. JOIN exam_data_publish AS T2 ON T1.exam_plan_id = T2.exam_plan_id
  150. JOIN exam_plan AS T3 ON T1.exam_plan_id = T3.id
  151. JOIN base_semester AS T4 ON T3.semester_id = T4.id
  152. WHERE {where}
  153. ", p);
  154. var items = await rep.SqlQueriesAsync<ExamDataPublishOrgOutput>($@"
  155. SELECT ROW_NUMBER() OVER (ORDER BY T1.exam_plan_id DESC, T2.type) AS `row_number`,
  156. T1.exam_plan_id,
  157. T1.sys_org_id,
  158. T2.id AS exam_data_publish_id,
  159. T2.type,
  160. T2.`name` AS exam_data_publish_name,
  161. T3.full_name AS exam_plan_full_name,
  162. T3.`name` AS exam_plan_name,
  163. T3.short_name AS exam_plan_short_name,
  164. T3.`status` AS exam_plan_status,
  165. T3.education_stage,
  166. T3.semester_id,
  167. T4.nick_short_name AS semesterNickShortName
  168. FROM exam_org AS T1
  169. JOIN exam_data_publish AS T2 ON T1.exam_plan_id = T2.exam_plan_id
  170. JOIN exam_plan AS T3 ON T1.exam_plan_id = T3.id
  171. JOIN base_semester AS T4 ON T3.semester_id = T4.id
  172. WHERE {where}
  173. LIMIT @pageSize OFFSET @pageOffset;
  174. ", p);
  175. PageResult<ExamDataPublishOrgOutput> ret = new()
  176. {
  177. PageIndex = input.PageIndex,
  178. PageSize = input.PageSize,
  179. TotalCount = totalCount,
  180. Items = items
  181. };
  182. return ret;
  183. }
  184. #endregion
  185. #region 上传匹配
  186. #endregion
  187. }