sunpengfei
2025-08-08 bf5084b9bd44ba20ace6107536cba6955e94ceaf
FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs
@@ -16,13 +16,15 @@
    /// 任务查询处理器
    /// </summary>
    public class TaskInfoQueryHandler(
            IRepository<TaskInfo> rep
            IRepository<TaskInfo> rep,
            IRepository<DictionaryData> repDictionaryData
        ) :
        IRequestHandler<GetTaskInfoQuery, GetTaskInfoQueryResult>,
        IRequestHandler<GetTaskInfosQuery, PagedListQueryResult<GetTaskInfosQueryResultItem>>
        IRequestHandler<GetTaskInfosQuery, GetTaskInfosQueryResult>
    {
        private readonly IRepository<TaskInfo> rep = rep;
        private readonly IRepository<DictionaryData> repDictionaryData = repDictionaryData;
        /// <summary>
        /// 查询任务详情
@@ -48,16 +50,20 @@
        /// <param name="request"></param>
        /// <param name="cancellationToken"></param>
        /// <returns></returns>
        public Task<PagedListQueryResult<GetTaskInfosQueryResultItem>> Handle(GetTaskInfosQuery request, CancellationToken cancellationToken)
        public async Task<GetTaskInfosQueryResult> Handle(GetTaskInfosQuery request, CancellationToken cancellationToken)
        {
            var q = TaskInfoRepository.GetQueryable(rep);
            if (request.Keywords.IsNotNull())
            {
                q = q.Where(it => it.Name.Contains(request.Keywords));
            }
            if (request.Time.HasValue)
            if (request.EnterpriseId.HasValue)
            {
                q = q.Where(it => it.BeginTime <= request.Time && request.Time <= it.EndTime);
                q = q.Where(it => it.EnterpriseId == request.EnterpriseId);
            }
            if (request.BeginTime.HasValue && request.EndTime.HasValue)
            {
                q = q.Where(it => request.BeginTime <= it.BeginTime && it.BeginTime <= request.EndTime);
            }
            if (request.CityCode.IsNotNull())
            {
@@ -75,6 +81,15 @@
            {
                q = q.Where(it => it.GenderLimit == request.GenderLimit);
            }
            var count = new GetTaskInfosQueryResultCount
            {
                WaitAssignCount = await q.CountAsync(it => it.Status == EnumTaskStatus.Wait),
                CompletedAssignCount = await q.CountAsync(it => it.Status == EnumTaskStatus.Complete),
                InProcessReleaseCount = await q.CountAsync(it => it.ReleaseStatus == EnumTaskReleaseStatus.InProcess),
                StoppedReleaseCount = await q.CountAsync(it => it.ReleaseStatus == EnumTaskReleaseStatus.Stopped),
            };
            if (request.Status.HasValue)
            {
                q = q.Where(it => it.Status == request.Status);
@@ -88,7 +103,6 @@
                q = q.Where(it => it.RecommendStatus == request.RecommendStatus);
            }
            var s = from t in q
                    join tu in rep.Change<TaskInfoUser>().AsQueryable().AsNoTracking() on t.Id equals tu.TaskInfoId into tug
                    select new GetTaskInfosQueryResultItem
                    {
                        Id = t.Id,
@@ -97,14 +111,36 @@
                        BillingMethod = t.BillingMethod,
                        ServiceFee = t.ServiceFee,
                        SettlementCycle = t.SettlementCycle,
                        Benefits = t.Benefits.Select(it => new GetTaskInfoQueryResultBenefit
                        {
                            BenefitCode = it.BenefitCode,
                            BenefitContent = it.Benefit.Content
                        }).ToList(),
                        GenderLimit = t.GenderLimit,
                        UserCount = tug.Count(),
                        CredentialLimits = t.CredentialLimits.Select(it => new GetTaskInfoQueryResultCredentialLimit
                        {
                            TypeCode = it.TypeCode,
                            TypeContent = it.Type.Content
                        }).ToList(),
                        ProvinceCode = t.ProvinceCode,
                        ProvinceContent = t.Province.Content,
                        CityCode = t.CityCode,
                        CityContent = t.City.Content,
                        AddressName = t.AddressName,
                        AddressDetail = t.AddressDetail,
                        Latitude = t.Latitude,
                        Longitude = t.Longitude,
                        UserCount = t.Users.Count(),
                        Status = t.Status,
                        BeginTime = t.BeginTime,
                        EndTime = t.EndTime,
                        ReleaseStatus = t.ReleaseStatus
                        ReleaseStatus = t.ReleaseStatus,
                        CheckReceiveStatus = t.CheckReceiveStatus,
                        CreatedTime = t.CreatedTime,
                        RecommendStatus = t.RecommendStatus,
                        SettlementStatus = t.SettlementStatus
                    };
            return request.PageModel.GetPagedListAsync(s, cancellationToken);
            var result = await request.PageModel.GetPagedListAsync<GetTaskInfosQueryResult, GetTaskInfosQueryResultItem>(s, cancellationToken);
        }
    }
}