From d77f3d84ce7cd4e06dcc98653b38370bac2b4926 Mon Sep 17 00:00:00 2001
From: sunpengfei <i@angelzzz.com>
Date: 星期二, 12 八月 2025 10:10:39 +0800
Subject: [PATCH] fix:bug

---
 FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs |   15 ++++++++++++---
 1 files changed, 12 insertions(+), 3 deletions(-)

diff --git a/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs b/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs
index 016884a..5b1b297 100644
--- a/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs
+++ b/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs
@@ -34,13 +34,22 @@
         /// <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.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()
+                    .Where(it => it.TaskInfoId == model.Id && it.UserId == logier.Id)
+                    .Select(it => it.HireStatus)
+                    .FirstOrDefaultAsync();
+            }
             return model;
         }
 
@@ -139,7 +148,7 @@
                         AddressDetail = t.AddressDetail,
                         Latitude = t.Latitude,
                         Longitude = t.Longitude,
-                        UserCount = t.TaskInfoUsers.Count(tu => tu.SignContractStatus == EnumTaskUserSignContractStatus.Pass),
+                        UserCount = t.TaskInfoUsers.Count(),
                         Status = t.Status,
                         BeginTime = t.BeginTime,
                         EndTime = t.EndTime,

--
Gitblit v1.9.1