using Furion.DatabaseAccessor.Extensions; using YBEE.EQM.Core; namespace YBEE.EQM.Application; /// /// 监测发布内容管理服务 /// public class ExamDataPublishService(IRepository rep, IExamSampleService examSampleService) : IExamDataPublishService, ITransient { #region 创建更新 /// /// 添加发布内容 /// /// /// public async Task Add(AddExamDataPublishInput input) { //if (await _rep.AnyAsync(t => t.ExamPlanId == input.ExamPlanId && t.Type == input.Type)) //{ // throw Oops.Oh(ErrorCode.E2002, "该类型"); //} var item = input.Adapt(); await item.InsertAsync(); } /// /// 更新发布内容 /// /// /// public async Task Update(UpdateExamDataPublishInput input) { var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001); item.Name = input.Name; item.Remark = input.Remark; await item.UpdateIncludeAsync([nameof(item.Name), nameof(item.Remark)]); } /// /// 删除发布内容 /// /// /// public async Task Del(BaseId input) { var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001); if (item.Status != PublishStatus.UNPUBLISH) { throw Oops.Oh(ErrorCode.E3001); } await item.DeleteAsync(); } #endregion #region 状态处理 /// /// 发布 /// /// /// public async Task Publish(BaseId input) { var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001); if (item.Status == PublishStatus.PUBLISHED) { throw Oops.Oh(ErrorCode.E2006); } if (item.Type == DataPublishType.STUDENT_SAMPLE_LIST || item.Type == DataPublishType.STUDENT_SAMPLE_COUNT_LIST) { var selected = await examSampleService.CheckSelectedByExamPlanId(item.ExamPlanId); // 未选定抽样方案不能发布 if (!selected) { throw Oops.Oh(ErrorCode.E3008); } } item.Status = PublishStatus.PUBLISHED; item.PublishTime = DateTime.Now; item.PublishSysUserId = CurrentSysUserInfo.SysUserId; await item.UpdateIncludeAsync([nameof(item.Status), nameof(item.PublishTime), nameof(item.PublishSysUserId)]); } /// /// 取消 /// /// /// public async Task Unpublish(BaseId input) { var item = await rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001); if (item.Status != PublishStatus.PUBLISHED) { throw Oops.Oh(ErrorCode.E2006); } item.Status = PublishStatus.UNPUBLISH; // 设置为未发布 await item.UpdateIncludeAsync([nameof(item.Status)]); } #endregion #region 查询 /// /// 根据ID获取监测数据发布内容 /// /// /// public async Task GetById(int id) { var item = await rep.DetachedEntities.FirstOrDefaultAsync(t => t.Id == id) ?? throw Oops.Oh(ErrorCode.E2001); return item.Adapt(); } /// /// 根据监测计划ID获取数据发布内容列表 /// /// 监测计划ID /// 发布类型 /// public async Task> GetListByExamPlanId(int examPlanId, DataPublishType? type) { var items = await rep.DetachedEntities .Where(t => t.ExamPlanId == examPlanId) .Where(type.HasValue, t => t.Type == type) .ProjectToType() .OrderBy(t => t.Type) .ToListAsync(); return items; } /// /// 分页查询面向机构发布的内容列表 /// /// /// public async Task> QueryOrgPageList(ExamDataPublishOrgPageInput input) { 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"; if (input.SemesterId.HasValue) { where = $"{where} AND T3.semester_id = {input.SemesterId.Value}"; } if (!string.IsNullOrEmpty(input.Name?.Trim())) { where = $"{where} AND T3.full_name LIKE '%{input.Name.Trim()}%'"; } var p = new { CurrentSysUserInfo.SysOrgId, input.PageSize, PageOffset = (input.PageIndex - 1) * input.PageSize, input.Type, input.Name, input.SemesterId, }; var totalCount = await rep.SqlScalarAsync($@" SELECT COUNT(1) AS total_count FROM exam_org AS T1 JOIN exam_data_publish AS T2 ON T1.exam_plan_id = T2.exam_plan_id JOIN exam_plan AS T3 ON T1.exam_plan_id = T3.id JOIN base_semester AS T4 ON T3.semester_id = T4.id WHERE {where} ", p); var items = await rep.SqlQueriesAsync($@" SELECT ROW_NUMBER() OVER (ORDER BY T1.exam_plan_id DESC, T2.type) AS `row_number`, T1.exam_plan_id, T1.sys_org_id, T2.id AS exam_data_publish_id, T2.type, T2.`name` AS exam_data_publish_name, T3.full_name AS exam_plan_full_name, T3.`name` AS exam_plan_name, T3.short_name AS exam_plan_short_name, T3.`status` AS exam_plan_status, T3.education_stage, T3.semester_id, T4.nick_short_name AS semesterNickShortName FROM exam_org AS T1 JOIN exam_data_publish AS T2 ON T1.exam_plan_id = T2.exam_plan_id JOIN exam_plan AS T3 ON T1.exam_plan_id = T3.id JOIN base_semester AS T4 ON T3.semester_id = T4.id WHERE {where} LIMIT @pageSize OFFSET @pageOffset; ", p); PageResult ret = new() { PageIndex = input.PageIndex, PageSize = input.PageSize, TotalCount = totalCount, Items = items }; return ret; } #endregion #region 上传匹配 #endregion }