123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- using Furion.DatabaseAccessor.Extensions;
- using YBEE.EQM.Core;
- namespace YBEE.EQM.Application;
- /// <summary>
- /// 监测数据上报类型管理服务
- /// </summary>
- public class ExamDataReportService : IExamDataReportService, ITransient
- {
- private readonly IRepository<ExamDataReport> _rep;
- public ExamDataReportService(IRepository<ExamDataReport> rep)
- {
- _rep = rep;
- }
- #region 创建更新
- /// <summary>
- /// 添加上报类型
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- public async Task Add(AddExamDataReportInput input)
- {
- if (await _rep.AnyAsync(t => t.ExamPlanId == input.ExamPlanId && t.Type == input.Type))
- {
- throw Oops.Oh(ErrorCode.E2002, "该类型");
- }
- var item = input.Adapt<ExamDataReport>();
- await item.InsertAsync();
- }
- /// <summary>
- /// 更新上报类型
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- public async Task Update(UpdateExamDataReportInput input)
- {
- var item = await _rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
- item.Remark = input.Remark;
- await item.UpdateIncludeAsync(new[] { nameof(item.BeginTime), nameof(item.EndTime), nameof(item.Remark) });
- }
- /// <summary>
- /// 删除上报类型
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- public async Task Del(BaseId input)
- {
- var item = await _rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
- if (item.Status != ExamStatus.READY)
- {
- throw Oops.Oh(ErrorCode.E3001);
- }
- await item.DeleteAsync();
- }
- #endregion
- #region 状态处理
- /// <summary>
- /// 开始
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- public async Task Start(BaseId input)
- {
- var item = await _rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
- if (item.Status != ExamStatus.READY)
- {
- throw Oops.Oh(ErrorCode.E2006);
- }
- item.Status = ExamStatus.ACTIVE;
- item.BeginTime = DateTime.Now;
- await item.UpdateIncludeAsync(new[] { nameof(item.Status), nameof(item.BeginTime) });
- }
- /// <summary>
- /// 结束
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- public async Task Stop(BaseId input)
- {
- var item = await _rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
- if (item.Status != ExamStatus.ACTIVE)
- {
- throw Oops.Oh(ErrorCode.E2006);
- }
- item.Status = ExamStatus.STOPPED;
- item.EndTime = DateTime.Now;
- await item.UpdateIncludeAsync(new[] { nameof(item.Status), nameof(item.EndTime) });
- }
- /// <summary>
- /// 取消
- /// </summary>
- /// <param name="input"></param>
- /// <returns></returns>
- public async Task Cancel(BaseId input)
- {
- var item = await _rep.FirstOrDefaultAsync(t => t.Id == input.Id) ?? throw Oops.Oh(ErrorCode.E2001);
- if (item.Status == ExamStatus.ACTIVE)
- {
- throw Oops.Oh(ErrorCode.E2006);
- }
- item.Status = ExamStatus.CANCELLED;
- item.EndTime = DateTime.Now;
- await item.UpdateIncludeAsync(new[] { nameof(item.Status), nameof(item.EndTime) });
- }
- #endregion
- #region 查询
- /// <summary>
- /// 根据ID获取监测数据上报类型
- /// </summary>
- /// <param name="id"></param>
- /// <returns></returns>
- public async Task<ExamDataReportOutput> GetById(int id)
- {
- var item = await _rep.DetachedEntities.FirstOrDefaultAsync(t => t.Id == id) ?? throw Oops.Oh(ErrorCode.E2001);
- return item.Adapt<ExamDataReportOutput>();
- }
- /// <summary>
- /// 根据监测计划ID获取数据上报类型列表
- /// </summary>
- /// <param name="examPlanId"></param>
- /// <returns></returns>
- public async Task<List<ExamDataReportOutput>> GetListByExamPlanId(int examPlanId)
- {
- var items = await _rep.DetachedEntities.Where(t => t.ExamPlanId == examPlanId).ProjectToType<ExamDataReportOutput>().OrderBy(t => t.Type).ToListAsync();
- var orgCount = await _rep.Change<ExamOrg>().DetachedEntities.Where(t => t.ExamPlanId == examPlanId).CountAsync();
- foreach (var item in items)
- {
- var reportedCount = await _rep.Change<ExamOrgDataReport>().DetachedEntities.Where(t => t.Type == item.Type && t.ExamOrg.ExamPlanId == examPlanId && t.Status == DataReportStatus.REPORTED).CountAsync();
- item.ReportedCount = reportedCount;
- item.Count = orgCount;
- }
- return items;
- }
- #endregion
- }
|