From e49c42ad641fa7ddaa4250ffd408666b087d1d48 Mon Sep 17 00:00:00 2001
From: sunpengfei <i@angelzzz.com>
Date: 星期五, 29 八月 2025 13:25:26 +0800
Subject: [PATCH] feat:开发

---
 FlexJobApi.UserServer.Application/EnterpriseEmployees/Queries/EnterpriseEmployeeQueryHandler.cs |   36 ++++++++++++++++++++++++++++++++----
 1 files changed, 32 insertions(+), 4 deletions(-)

diff --git a/FlexJobApi.UserServer.Application/EnterpriseEmployees/Queries/EnterpriseEmployeeQueryHandler.cs b/FlexJobApi.UserServer.Application/EnterpriseEmployees/Queries/EnterpriseEmployeeQueryHandler.cs
index 2a300aa..0201ebb 100644
--- a/FlexJobApi.UserServer.Application/EnterpriseEmployees/Queries/EnterpriseEmployeeQueryHandler.cs
+++ b/FlexJobApi.UserServer.Application/EnterpriseEmployees/Queries/EnterpriseEmployeeQueryHandler.cs
@@ -65,9 +65,30 @@
             {
                 q = q.Where(it => (it.UserId.HasValue && it.User.IsReal) == request.IsReal.Value);
             }
-            if (request.UserSignContractStatus.HasValue)
+            if (request.UserSignContractStatus.HasValue && logier.ClientType == EnumClientType.Wxmp)
             {
-                q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus);
+                if (logier.ClientType == EnumClientType.Wxmp)
+                {
+                    switch (request.UserSignContractStatus.Value)
+                    {
+                        case EnumTaskUserSignContractStatus.Wait:
+                            q = q.Where(it => it.UserSignContractStatus == null || it.UserSignContractStatus == request.UserSignContractStatus);
+                            break;
+                        case EnumTaskUserSignContractStatus.Pass:
+                            q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus && it.EnterpriseSignContractStatus == EnumTaskUserSignContractStatus.Pass);
+                            break;
+                        case EnumTaskUserSignContractStatus.Stop:
+                            q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus);
+                            break;
+                        default:
+                            q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus);
+                            break;
+                    }
+                }
+                else
+                {
+                    q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus);
+                }
             }
             if (request.EnterpriseSignContractStatus.HasValue)
             {
@@ -154,13 +175,20 @@
                 .Where(it => it.UserId == logier.Id);
             if (request.UserSignContractStatus.HasValue)
             {
-                q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus.Value);
+                if (request.UserSignContractStatus == EnumTaskUserSignContractStatus.Pass)
+                {
+                    q = q.Where(it => it.UserSignContractStatus == EnumTaskUserSignContractStatus.Pass && it.EnterpriseSignContractStatus == EnumTaskUserSignContractStatus.Pass);
+                }
+                else
+                {
+                    q = q.Where(it => it.UserSignContractStatus == request.UserSignContractStatus.Value);
+                }
             }
             else
             {
                 q = q.Where(it =>
                     it.UserSignContractStatus == EnumTaskUserSignContractStatus.Wait
-                    || it.UserSignContractStatus == EnumTaskUserSignContractStatus.Effect
+                    || it.UserSignContractStatus == EnumTaskUserSignContractStatus.Pass && it.EnterpriseSignContractStatus == EnumTaskUserSignContractStatus.Pass
                     || it.UserSignContractStatus == EnumTaskUserSignContractStatus.Stop);
             }
             var s = q.Select(it => new GetPersonalUserElectronSignsQueryResultItem

--
Gitblit v1.9.1