ExamDataPublishService.cs 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  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 ExamDataPublishService(IRepository<ExamDataPublish> rep, IExamSampleService examSampleService, IResourceFileService resourceFileService) : IExamDataPublishService, ITransient
  9. {
  10. #region 创建更新
  11. /// <summary>
  12. /// 添加发布内容
  13. /// </summary>
  14. /// <param name="input"></param>
  15. /// <returns></returns>
  16. public async Task Add(AddExamDataPublishInput 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<ExamDataPublish>();
  23. await item.InsertAsync();
  24. }
  25. /// <summary>
  26. /// 更新发布内容
  27. /// </summary>
  28. /// <param name="input"></param>
  29. /// <returns></returns>
  30. public async Task Update(UpdateExamDataPublishInput input)
  31. {
  32. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  33. item.Name = input.Name;
  34. item.Remark = input.Remark;
  35. await item.UpdateIncludeAsync([nameof(item.Name), nameof(item.Remark)]);
  36. }
  37. /// <summary>
  38. /// 删除发布内容
  39. /// </summary>
  40. /// <param name="input"></param>
  41. /// <returns></returns>
  42. public async Task Del(BaseId input)
  43. {
  44. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  45. if (item.Status != PublishStatus.UNPUBLISH)
  46. {
  47. throw Oops.Oh(ErrorCode.E3001);
  48. }
  49. await item.DeleteAsync();
  50. }
  51. /// <summary>
  52. /// 添加附件
  53. /// </summary>
  54. /// <param name="input"></param>
  55. /// <returns></returns>
  56. public async Task AddAttachment(AddAttachmentInput input)
  57. {
  58. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.SourceId) ?? throw Oops.Oh(ErrorCode.E2001);
  59. item.Attachments = AttachmentUtil.InsertInto(item.Attachments, input.Adapt<AttachmentItem>());
  60. await item.UpdateIncludeAsync([nameof(item.Attachments)]);
  61. }
  62. /// <summary>
  63. /// 删除附件
  64. /// </summary>
  65. /// <param name="input"></param>
  66. /// <returns></returns>
  67. public async Task DelAttachment(DeleteAttachmentInput input)
  68. {
  69. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.SourceId) ?? throw Oops.Oh(ErrorCode.E2001);
  70. var attachments = AttachmentUtil.GetList(item.Attachments);
  71. var a = attachments.FirstOrDefault(t => t.FileId == input.FileId);
  72. if (a != null)
  73. {
  74. attachments.Remove(a);
  75. item.Attachments = JSON.Serialize(attachments);
  76. await item.UpdateIncludeAsync([nameof(item.Attachments)]);
  77. await resourceFileService.Del(new() { Id = a.FileId });
  78. if (a.ThumbFileId.HasValue && a.ThumbFileId > 0)
  79. {
  80. await resourceFileService.Del(new() { Id = a.ThumbFileId.Value });
  81. }
  82. }
  83. }
  84. #endregion
  85. #region 状态处理
  86. /// <summary>
  87. /// 发布
  88. /// </summary>
  89. /// <param name="input"></param>
  90. /// <returns></returns>
  91. public async Task Publish(BaseId input)
  92. {
  93. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  94. if (item.Status == PublishStatus.PUBLISHED)
  95. {
  96. throw Oops.Oh(ErrorCode.E2006);
  97. }
  98. if (item.Type == DataPublishType.STUDENT_SAMPLE_LIST || item.Type == DataPublishType.STUDENT_SAMPLE_COUNT_LIST)
  99. {
  100. var selected = await examSampleService.CheckSelectedByExamPlanId(item.ExamPlanId);
  101. // 未选定抽样方案不能发布
  102. if (!selected)
  103. {
  104. throw Oops.Oh(ErrorCode.E3008);
  105. }
  106. }
  107. item.Status = PublishStatus.PUBLISHED;
  108. item.PublishTime = DateTime.Now;
  109. item.PublishSysUserId = CurrentSysUserInfo.SysUserId;
  110. await item.UpdateIncludeAsync([nameof(item.Status), nameof(item.PublishTime), nameof(item.PublishSysUserId)]);
  111. }
  112. /// <summary>
  113. /// 取消
  114. /// </summary>
  115. /// <param name="input"></param>
  116. /// <returns></returns>
  117. public async Task Unpublish(BaseId input)
  118. {
  119. var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
  120. if (item.Status != PublishStatus.PUBLISHED)
  121. {
  122. throw Oops.Oh(ErrorCode.E2006);
  123. }
  124. item.Status = PublishStatus.UNPUBLISH; // 设置为未发布
  125. await item.UpdateIncludeAsync([nameof(item.Status)]);
  126. }
  127. #endregion
  128. #region 查询
  129. /// <summary>
  130. /// 根据ID获取监测数据发布内容
  131. /// </summary>
  132. /// <param name="id"></param>
  133. /// <returns></returns>
  134. public async Task<ExamDataPublishOutput> GetById(int id)
  135. {
  136. var item = await rep.DetachedEntities.FirstOrDefaultAsync(t => t.Id == id) ?? throw Oops.Oh(ErrorCode.E2001);
  137. return item.Adapt<ExamDataPublishOutput>();
  138. }
  139. /// <summary>
  140. /// 根据监测计划ID获取数据发布内容列表
  141. /// </summary>
  142. /// <param name="examPlanId">监测计划ID</param>
  143. /// <param name="type">发布类型</param>
  144. /// <returns></returns>
  145. public async Task<List<ExamDataPublishOutput>> GetListByExamPlanId(int examPlanId, DataPublishType? type)
  146. {
  147. var items = await rep.DetachedEntities
  148. .Where(t => t.ExamPlanId == examPlanId)
  149. .Where(type.HasValue, t => t.Type == type)
  150. .ProjectToType<ExamDataPublishOutput>()
  151. .OrderBy(t => t.Type)
  152. .ToListAsync();
  153. return items;
  154. }
  155. /// <summary>
  156. /// 分页查询面向机构发布的内容列表
  157. /// </summary>
  158. /// <param name="input"></param>
  159. /// <returns></returns>
  160. public async Task<PageResult<ExamDataPublishOrgOutput>> QueryOrgPageList(ExamDataPublishOrgPageInput input)
  161. {
  162. 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";
  163. if (input.SemesterId.HasValue)
  164. {
  165. where = $"{where} AND T3.semester_id = {input.SemesterId.Value}";
  166. }
  167. if (!string.IsNullOrEmpty(input.Name?.Trim()))
  168. {
  169. where = $"{where} AND T3.full_name LIKE '%{input.Name.Trim()}%'";
  170. }
  171. var p = new
  172. {
  173. CurrentSysUserInfo.SysOrgId,
  174. input.PageSize,
  175. PageOffset = (input.PageIndex - 1) * input.PageSize,
  176. input.Type,
  177. input.Name,
  178. input.SemesterId,
  179. };
  180. var totalCount = await rep.SqlScalarAsync<int>($@"
  181. SELECT COUNT(1) AS total_count
  182. FROM exam_org AS T1
  183. JOIN exam_data_publish AS T2 ON T1.exam_plan_id = T2.exam_plan_id
  184. JOIN exam_plan AS T3 ON T1.exam_plan_id = T3.id
  185. JOIN base_semester AS T4 ON T3.semester_id = T4.id
  186. WHERE {where}
  187. ", p);
  188. var items = await rep.SqlQueriesAsync<ExamDataPublishOrgOutput>($@"
  189. SELECT ROW_NUMBER() OVER (ORDER BY T1.exam_plan_id DESC, T2.type) AS `row_number`,
  190. T1.exam_plan_id,
  191. T1.sys_org_id,
  192. T2.id AS exam_data_publish_id,
  193. T2.type,
  194. T2.`name` AS exam_data_publish_name,
  195. T3.full_name AS exam_plan_full_name,
  196. T3.`name` AS exam_plan_name,
  197. T3.short_name AS exam_plan_short_name,
  198. T3.`status` AS exam_plan_status,
  199. T3.education_stage,
  200. T3.semester_id,
  201. T4.nick_short_name AS semesterNickShortName
  202. FROM exam_org AS T1
  203. JOIN exam_data_publish AS T2 ON T1.exam_plan_id = T2.exam_plan_id
  204. JOIN exam_plan AS T3 ON T1.exam_plan_id = T3.id
  205. JOIN base_semester AS T4 ON T3.semester_id = T4.id
  206. WHERE {where}
  207. LIMIT @pageSize OFFSET @pageOffset;
  208. ", p);
  209. PageResult<ExamDataPublishOrgOutput> ret = new()
  210. {
  211. PageIndex = input.PageIndex,
  212. PageSize = input.PageSize,
  213. TotalCount = totalCount,
  214. Items = items
  215. };
  216. return ret;
  217. }
  218. #endregion
  219. #region 上传匹配
  220. #endregion
  221. }