From 860e1fe5396005cfcc3dd68e1b20cd3b35010e83 Mon Sep 17 00:00:00 2001
From: sunpengfei <i@angelzzz.com>
Date: 星期二, 12 八月 2025 14:33:21 +0800
Subject: [PATCH] feat:开发

---
 FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs |   57 ++++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 48 insertions(+), 9 deletions(-)

diff --git a/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs b/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs
index 4a45d2e..11634cb 100644
--- a/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs
+++ b/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs
@@ -20,7 +20,7 @@
             IRepository<DictionaryData> repDictionaryData
         ) :
         IRequestHandler<GetTaskInfoQuery, GetTaskInfoQueryResult>,
-        IRequestHandler<GetTaskInfosQuery, PagedListQueryResult<GetTaskInfosQueryResultItem>>
+        IRequestHandler<GetTaskInfosQuery, GetTaskInfosQueryResult>
 
     {
         private readonly IRepository<TaskInfo> rep = rep;
@@ -34,13 +34,25 @@
         /// <returns></returns>
         public async Task<GetTaskInfoQueryResult> Handle(GetTaskInfoQuery request, CancellationToken cancellationToken)
         {
+            var logier = JwtUtils.GetCurrentLogier();
             var model = await TaskInfoRepository.GetQueryable(rep)
                 .Where(it => it.Id == request.Id)
-                .ProjectToType<GetTaskInfoQueryResult>()
-                .FirstOrDefaultAsync(cancellationToken);
+                .GetDetail<TaskInfo, GetTaskInfoQueryResult>(cancellationToken);
             model.TaskCount = await rep.AsQueryable().AsNoTracking()
-                .Where(it => it.EnterpriseId == model.EnterpriseId && it.ReleaseStatus == EnumTaskReleaseStatus.Stopped)
+                .Where(it => it.EnterpriseId == model.EnterpriseId && it.ReleaseStatus == EnumTaskReleaseStatus.InProcess)
                 .CountAsync();
+            model.ApplyCount = await rep.Change<TaskInfoUser>().AsQueryable().AsNoTracking()
+                .CountAsync(it => it.TaskInfoId == model.Id);
+            if (logier != null && logier.Type == EnumUserType.Personal)
+            {
+                model.HireStatus = await rep.Change<TaskInfoUser>().AsQueryable().AsNoTracking()
+                    .Include(it => it.EnterpriseEmployee)
+                    .Where(it => it.TaskInfoId == model.Id && it.EnterpriseEmployee.UserId == logier.Id)
+                    .Select(it => it.EnterpriseEmployee.HireStatus)
+                    .FirstOrDefaultAsync();
+                model.IsCollected = await rep.Change<UserTaskCollect>().AsQueryable().AsNoTracking()
+                    .AnyAsync(it => it.TaskInfoId == request.Id && it.UserId == logier.Id);
+            }
             return model;
         }
 
@@ -50,12 +62,17 @@
         /// <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);
+            var logier = JwtUtils.GetCurrentLogier();
+            var q = TaskInfoRepository.GetQueryable(rep, true, logier);
             if (request.Keywords.IsNotNull())
             {
                 q = q.Where(it => it.Name.Contains(request.Keywords));
+            }
+            if (request.EnterpriseId.HasValue)
+            {
+                q = q.Where(it => it.EnterpriseId == request.EnterpriseId);
             }
             if (request.BeginTime.HasValue && request.EndTime.HasValue)
             {
@@ -77,6 +94,19 @@
             {
                 q = q.Where(it => it.GenderLimit == request.GenderLimit);
             }
+            if (request.HireStatus.IsNotNull() && logier.Type == EnumUserType.Personal)
+            {
+                q = q.Where(it => it.TaskInfoUsers.Any(u => request.HireStatus.Contains(u.EnterpriseEmployee.HireStatus)));
+            }
+
+            var count = new GetTaskInfosQueryResultObjectData
+            {
+                WaitAssignCount = await q.CountAsync(it => it.ReleaseStatus == EnumTaskReleaseStatus.InProcess && 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,6 +118,10 @@
             if (request.RecommendStatus.HasValue)
             {
                 q = q.Where(it => it.RecommendStatus == request.RecommendStatus);
+            }
+            if (request.CheckReceiveStatus.HasValue)
+            {
+                q = q.Where(it => it.CheckReceiveStatus == request.CheckReceiveStatus);
             }
             var s = from t in q
                     select new GetTaskInfosQueryResultItem
@@ -117,7 +151,7 @@
                         AddressDetail = t.AddressDetail,
                         Latitude = t.Latitude,
                         Longitude = t.Longitude,
-                        UserCount = t.Users.Count(),
+                        UserCount = t.TaskInfoUsers.Count(),
                         Status = t.Status,
                         BeginTime = t.BeginTime,
                         EndTime = t.EndTime,
@@ -125,9 +159,14 @@
                         CheckReceiveStatus = t.CheckReceiveStatus,
                         CreatedTime = t.CreatedTime,
                         RecommendStatus = t.RecommendStatus,
-                        SettlementStatus = t.SettlementStatus
+                        SettlementStatus = t.SettlementStatus,
+                        HireStatus = logier != null
+                            ? t.TaskInfoUsers.Where(it => it.EnterpriseEmployee.UserId == logier.Id).Select(u => u.EnterpriseEmployee.HireStatus).FirstOrDefault()
+                            : null
                     };
-            return request.PageModel.GetPagedListAsync(s, cancellationToken);
+            var result = await request.PageModel.GetPagedListAsync<GetTaskInfosQueryResult, GetTaskInfosQueryResultItem>(s, cancellationToken);
+            result.ObjectData = count;
+            return result;
         }
     }
 }

--
Gitblit v1.9.1