From 20af9888642273b5ff389f1fd8e80582083ef0b5 Mon Sep 17 00:00:00 2001
From: sunpengfei <i@angelzzz.com>
Date: 星期四, 11 九月 2025 15:52:17 +0800
Subject: [PATCH] feat:开发

---
 FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs |   34 ++++++++++++++++++++++++++++++----
 1 files changed, 30 insertions(+), 4 deletions(-)

diff --git a/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs b/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs
index 3a770be..e237a65 100644
--- a/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs
+++ b/FlexJobApi.FlexJobServer.Application/Tasks/Queries/TaskInfoQueryHandler.cs
@@ -26,7 +26,8 @@
         IRequestHandler<GetPersonalHireTaskInfosQuery, GetPersonalHireTaskInfosQueryResult>,
         IRequestHandler<GetPersonalCancelTaskInfosQuery, GetPersonalCancelTaskInfosQueryResult>,
         IRequestHandler<GetSettlementTasksQuery, GetSettlementTasksQueryResult>,
-        IRequestHandler<GetSettlementTaskQuery, GetSettlementTaskQueryResult>
+        IRequestHandler<GetSettlementTaskQuery, GetSettlementTaskQueryResult>,
+        IRequestHandler<GetTaskSelectQuery, List<SelectOption<Guid, GetTaskSelectQueryOption>>>
 
     {
         private readonly IRepository<TaskInfo> rep = rep;
@@ -393,7 +394,7 @@
         {
             var logier = JwtUtils.GetCurrentLogier();
             var q = TaskInfoRepository.GetQueryable(rep, true, logier)
-                .Where(it => it.SettlementOrderStatus.HasValue && it.SettlementStatus.HasValue);
+                .Where(it => it.SettlementOrderStatus.HasValue);
             if (request.Keywords.IsNotNull())
             {
                 q = q.Where(it =>
@@ -409,8 +410,8 @@
                 q = q.Where(it => it.SettlementStatus == request.SettlementStatus);
             }
             var s = q
-                .Select(it=>new GetSettlementTasksQueryResultItem
-                { 
+                .Select(it => new GetSettlementTasksQueryResultItem
+                {
                     Id = it.Id,
                     Name = it.Name,
                     Code = it.Code,
@@ -441,5 +442,30 @@
                 .GetDetail<TaskInfo, GetSettlementTaskQueryResult>();
             return model;
         }
+
+        /// <summary>
+        /// 鏌ヨ浠诲姟閫夋嫨鍣ㄦ暟鎹�
+        /// </summary>
+        /// <param name="request"></param>
+        /// <param name="cancellationToken"></param>
+        /// <returns></returns>
+        public async Task<List<SelectOption<Guid, GetTaskSelectQueryOption>>> Handle(GetTaskSelectQuery request, CancellationToken cancellationToken)
+        {
+            return await request.GetSelect<TaskInfo, Guid, GetTaskSelectQueryOption>(
+                it => it.Id,
+                it => it.Name,
+                q =>
+                {
+                    q = TaskInfoRepository.GetQueryable(rep, true);
+                    if (request.Keywords.IsNotNull())
+                    {
+                        q = q.Where(it =>
+                            it.Code.Contains(request.Keywords)
+                            || it.Name.Contains(request.Keywords));
+                    }
+                    return q;
+                },
+                cancellationToken);
+        }
     }
 }

--
Gitblit v1.9.1