From 5b86cd10f893872da68c040adea52953eb25c4a0 Mon Sep 17 00:00:00 2001
From: sunpengfei <i@angelzzz.com>
Date: 星期二, 09 九月 2025 15:08:22 +0800
Subject: [PATCH] feat:开发

---
 FlexJobApi.Core/Models/FlexJobServer/TaskUsers/Queries/GetSettlementTaskUsersQuery.cs          |    6 ++
 FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Queries/TaskCheckReceiveQueryHandler.cs |   71 ++++++++++++++++++++++-
 FlexJobApi.FlexJobServer.Application/FlexJobApi.FlexJobServer.Application.xml                  |    2 
 FlexJobApi.FlexJobServer.Application/TaskUsers/Queries/TaskUserQueryHandler.cs                 |   16 +++++
 FlexJobApi.Core/FlexJobApi.Core.xml                                                            |   10 +++
 FlexJobApi.Web.Entry/appsettings.json                                                          |   16 +++--
 6 files changed, 108 insertions(+), 13 deletions(-)

diff --git a/FlexJobApi.Core/FlexJobApi.Core.xml b/FlexJobApi.Core/FlexJobApi.Core.xml
index 022b215..4ac2ebe 100644
--- a/FlexJobApi.Core/FlexJobApi.Core.xml
+++ b/FlexJobApi.Core/FlexJobApi.Core.xml
@@ -8712,6 +8712,11 @@
             鏌ヨ缁撶畻浠诲姟鍒嗛〉鍒楄〃鏁版嵁
             </summary>
         </member>
+        <member name="P:FlexJobApi.Core.GetSettlementTaskUsersQueryResult.Detail">
+            <summary>
+            璇︽儏
+            </summary>
+        </member>
         <member name="P:FlexJobApi.Core.GetSettlementTaskUsersQueryResult.Data">
             <summary>
             缁撶畻鍚嶅崟
@@ -10191,6 +10196,11 @@
             Id
             </summary>
         </member>
+        <member name="P:FlexJobApi.Core.SendInviteElectronSignSmsCommand.ContractTemplateId">
+            <summary>
+            鍚堝悓妯℃澘Id
+            </summary>
+        </member>
         <member name="T:FlexJobApi.Core.StopElectronSignCommand">
             <summary>
             鐏靛伐瑙g害
diff --git a/FlexJobApi.Core/Models/FlexJobServer/TaskUsers/Queries/GetSettlementTaskUsersQuery.cs b/FlexJobApi.Core/Models/FlexJobServer/TaskUsers/Queries/GetSettlementTaskUsersQuery.cs
index 910a179..ada8d75 100644
--- a/FlexJobApi.Core/Models/FlexJobServer/TaskUsers/Queries/GetSettlementTaskUsersQuery.cs
+++ b/FlexJobApi.Core/Models/FlexJobServer/TaskUsers/Queries/GetSettlementTaskUsersQuery.cs
@@ -31,9 +31,15 @@
     public class GetSettlementTaskUsersQueryResult
     {
         /// <summary>
+        /// 璇︽儏
+        /// </summary>
+        public GetSettlementTaskQueryResult Detail { get; set; }
+
+        /// <summary>
         /// 缁撶畻鍚嶅崟
         /// </summary>
         public List<GetSettlementTaskUsersQueryResultItem> Data { get; set; }
+
         /// <summary>
         /// 閿欒淇℃伅
         /// </summary>
diff --git a/FlexJobApi.FlexJobServer.Application/FlexJobApi.FlexJobServer.Application.xml b/FlexJobApi.FlexJobServer.Application/FlexJobApi.FlexJobServer.Application.xml
index be372e2..d0e445d 100644
--- a/FlexJobApi.FlexJobServer.Application/FlexJobApi.FlexJobServer.Application.xml
+++ b/FlexJobApi.FlexJobServer.Application/FlexJobApi.FlexJobServer.Application.xml
@@ -43,7 +43,7 @@
             浠诲姟楠屾敹鏌ヨ澶勭悊鍣�
             </summary>
         </member>
-        <member name="M:FlexJobApi.FlexJobServer.Application.TaskCheckReceiveQueryHandler.#ctor(Furion.DatabaseAccessor.IRepository{FlexJobApi.Core.TaskInfo},Furion.DatabaseAccessor.IRepository{FlexJobApi.Core.TaskInfoUser},Furion.DatabaseAccessor.IRepository{FlexJobApi.Core.TaskInfoUserSubmit})">
+        <member name="M:FlexJobApi.FlexJobServer.Application.TaskCheckReceiveQueryHandler.#ctor(Furion.DatabaseAccessor.IRepository{FlexJobApi.Core.TaskInfo},Furion.DatabaseAccessor.IRepository{FlexJobApi.Core.TaskInfoUser},Furion.DatabaseAccessor.IRepository{FlexJobApi.Core.User},Furion.DatabaseAccessor.IRepository{FlexJobApi.Core.TaskInfoUserSubmit})">
             <summary>
             浠诲姟楠屾敹鏌ヨ澶勭悊鍣�
             </summary>
diff --git a/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Queries/TaskCheckReceiveQueryHandler.cs b/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Queries/TaskCheckReceiveQueryHandler.cs
index 32fea4c..9fdf689 100644
--- a/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Queries/TaskCheckReceiveQueryHandler.cs
+++ b/FlexJobApi.FlexJobServer.Application/TaskCheckReceives/Queries/TaskCheckReceiveQueryHandler.cs
@@ -1,5 +1,7 @@
-锘縰sing FlexJobApi.Core;
+锘縰sing Aop.Api.Domain;
+using FlexJobApi.Core;
 using Furion.DatabaseAccessor;
+using Furion.DistributedIDGenerator;
 using Furion.FriendlyException;
 using Mapster;
 using MediatR;
@@ -9,6 +11,7 @@
 using System.Linq;
 using System.Text;
 using System.Threading.Tasks;
+using TaskInfo = FlexJobApi.Core.TaskInfo;
 
 namespace FlexJobApi.FlexJobServer.Application
 {
@@ -18,6 +21,7 @@
     public class TaskCheckReceiveQueryHandler(
         IRepository<TaskInfo> repTaskInfo,
         IRepository<TaskInfoUser> repTaskInfoUser,
+        IRepository<User> repUser,
         IRepository<TaskInfoUserSubmit> repTaskInfoUserSubmit) :
         IRequestHandler<GetCheckReceiveTasksQuery, GetCheckReceiveTasksQueryResult>,
         IRequestHandler<GetCheckReceiveTaskQuery, GetCheckReceiveTaskQueryResult>,
@@ -256,20 +260,77 @@
         /// <returns></returns>
         public async Task<GetCheckReceiveTaskUserSubmitQueryResult> Handle(GetCheckReceiveTaskUserSubmitQuery request, CancellationToken cancellationToken)
         {
-            var q = repTaskInfoUserSubmit.AsQueryable().AsNoTracking();
+            var logier = JwtUtils.GetCurrentLogier();
+            TaskInfoUserSubmit? entity = null;
+            var q = repTaskInfoUserSubmit.AsQueryable();
             if (request.SubmitId.HasValue)
             {
                 q = q.Where(it => it.Id == request.SubmitId.Value);
+                entity = await q.FirstOrDefaultAsync();
+                if (entity == null)
+                {
+                    throw Oops.Oh(EnumErrorCodeType.s404, "鎻愪氦淇℃伅");
+                }
             }
             else if (request.Date.HasValue && request.TaskInfoId.HasValue)
             {
-                q = q.Where(it => it.Date.Date == request.Date.Value.Date && it.TaskInfoUser.TaskInfoId == request.TaskInfoId.Value);
+                var taskUser = await repTaskInfoUser.AsQueryable().AsNoTracking()
+                    .Where(it =>
+                        it.EnterpriseEmployee.UserId == logier.Id
+                        && it.TaskInfoId == request.TaskInfoId)
+                    .FirstOrDefaultAsync();
+                if (taskUser == null) throw Oops.Oh(EnumErrorCodeType.s404, "浠诲姟");
+                q = q.Where(it =>
+                    it.Date.Date == request.Date.Value.Date
+                    && it.TaskInfoUserId == taskUser.Id);
+                entity = await q.FirstOrDefaultAsync();
+                if (entity == null)
+                {
+                    entity = new TaskInfoUserSubmit
+                    {
+                        Id = IDGen.NextID(),
+                        TaskInfoUserId = taskUser.Id,
+                        Date = request.Date.Value.Date,
+                        CheckReceiveStatus = EnumTaskUserSubmitCheckReceiveStatus.WaitSubmit,
+                        CreatedTime = DateTime.Now
+                    };
+                    await repTaskInfoUserSubmit.InsertAsync(entity);
+                }
             }
             else if (request.Date.HasValue && request.TaskInfoUserId.HasValue)
             {
-                q = q.Where(it => it.Date.Date == request.Date.Value.Date && it.TaskInfoUserId == request.TaskInfoUserId.Value);
+                q = q.Where(it =>
+                    it.Date.Date == request.Date.Value.Date
+                    && it.TaskInfoUserId == request.TaskInfoUserId.Value);
+                entity = await q.FirstOrDefaultAsync();
+                if (entity == null)
+                {
+                    entity = new TaskInfoUserSubmit
+                    {
+                        Id = IDGen.NextID(),
+                        TaskInfoUserId = request.TaskInfoUserId.Value,
+                        Date = request.Date.Value.Date,
+                        CheckReceiveStatus = EnumTaskUserSubmitCheckReceiveStatus.WaitSubmit,
+                        CreatedTime = DateTime.Now
+                    };
+                    await repTaskInfoUserSubmit.InsertAsync(entity);
+                }
             }
-            var model = await q.GetDetail<TaskInfoUserSubmit, GetCheckReceiveTaskUserSubmitQueryResult>();
+            if (entity == null)
+            {
+                throw Oops.Oh(EnumErrorCodeType.s404, "鎻愪氦淇℃伅");
+            }
+
+            var model = new GetCheckReceiveTaskUserSubmitQueryResult
+            {
+                Id = entity.Id,
+                Date = entity.Date,
+                CreatedTime = entity.CreatedTime,
+            };
+            model.TaskInfoUserEnterpriseEmployeeUser = await repUser.AsQueryable().AsNoTracking()
+                .Where(it => it.EnterpriseEmployees.Any(ee => ee.TaskInfoUsers.Any(tu => tu.Id == entity.TaskInfoUserId)))
+                .ProjectToType<GetCheckReceiveTaskUserSubmitsQueryResultObjectDataEnterpriseEmployeeUser>()
+                .FirstOrDefaultAsync();
             model.Files = await repTaskInfoUserSubmit.Change<TaskInfoUserSubmitFile>().AsQueryable().AsNoTracking()
                 .Where(it => it.SubmitId == model.Id)
                 .Select(it => it.File)
diff --git a/FlexJobApi.FlexJobServer.Application/TaskUsers/Queries/TaskUserQueryHandler.cs b/FlexJobApi.FlexJobServer.Application/TaskUsers/Queries/TaskUserQueryHandler.cs
index 2ee2a19..2cdd47e 100644
--- a/FlexJobApi.FlexJobServer.Application/TaskUsers/Queries/TaskUserQueryHandler.cs
+++ b/FlexJobApi.FlexJobServer.Application/TaskUsers/Queries/TaskUserQueryHandler.cs
@@ -173,6 +173,11 @@
         {
             var logier = JwtUtils.GetCurrentLogier();
             var list = new GetSettlementTaskUsersQueryResult();
+
+            list.Detail = await TaskInfoRepository.GetQueryable(repTaskInfo, true, logier)
+                .Where(it => it.Id == request.TaskInfoId)
+                .GetDetail<TaskInfo, GetSettlementTaskQueryResult>();
+
             var q = rep.AsQueryable().AsNoTracking()
                 .Where(it => it.TaskInfoId == request.TaskInfoId);
             list.Data = q
@@ -266,6 +271,10 @@
                         item.Bank = model.Bank;
                         item.BankBranch = model.BankBranch;
                     }
+                    if (model.TaskName != list.Detail.Name)
+                    {
+                        errors.Add("浠诲姟鍚嶇О涓嶄竴鑷�");
+                    }
 
                     if (errors.IsNotNull())
                     {
@@ -289,6 +298,13 @@
                         .Where(it => successList.Any(s => s.Identity == it.Identity))
                         .ToList();
                 }
+
+                list.Detail.SettlementOrderStatus = EnumTaskSettlementOrderStatus.Wait;
+                list.Detail.SettlementOrderName = request.SettlementOrderUrl.Substring(request.SettlementOrderUrl.LastIndexOf("/") + 1);
+                list.Detail.SettlementOrderTime = DateTime.Now;
+                list.Detail.SettlementStatus = EnumTaskSettlementStatus.Wait;
+                list.Detail.SettlementAmount = list.Data.Sum(it => it.SettlementAmount ?? 0);
+                list.Detail.ActualSettlementAmount = list.Data.Sum(it => it.ActualSettlementAmount ?? 0);
             }
             else
             {
diff --git a/FlexJobApi.Web.Entry/appsettings.json b/FlexJobApi.Web.Entry/appsettings.json
index 74973ad..736cf9c 100644
--- a/FlexJobApi.Web.Entry/appsettings.json
+++ b/FlexJobApi.Web.Entry/appsettings.json
@@ -2,15 +2,17 @@
   "$schema": "https://gitee.com/dotnetchina/Furion/raw/v4/schemas/v4/furion-schema.json",
   "Environment": "Local",
   "ConnectionStrings": {
-    //"FlexJobApi": "Server=120.26.58.240; Database=Dev_FlexJobApi; User=bole;Password=Bole1472589;Encrypt=false;",
-    //"FlexJobApiLog": "Server=120.26.58.240; Database=Dev_FlexJobApiLog; User=bole;Password=Bole1472589;Encrypt=false;",
-    //"HumanResources": "Server=120.26.58.240; Database=Dev_12333; User=bole;Password=Bole1472589;Encrypt=false;",
+
+    "FlexJobApi": "Server=120.26.58.240; Database=Dev_FlexJobApi; User=bole;Password=Bole1472589;Encrypt=false;",
+    "FlexJobApiLog": "Server=120.26.58.240; Database=Dev_FlexJobApiLog; User=bole;Password=Bole1472589;Encrypt=false;",
+    "HumanResources": "Server=120.26.58.240; Database=Dev_12333; User=bole;Password=Bole1472589;Encrypt=false;",
+    "SyncTarget": "Server=rm-bp1mt744021h1s6dg4o.sqlserver.rds.aliyuncs.com,2333; Database=Pro_FlexJobApi; User=bole;Password=Blcs20@%27;Encrypt=false;"
+
+    //"FlexJobApi": "Server=rm-bp1mt744021h1s6dg4o.sqlserver.rds.aliyuncs.com,2333; Database=Pro_FlexJobApi; User=bole;Password=Blcs20@%27;Encrypt=false;",
+    //"FlexJobApiLog": "Server=rm-bp1mt744021h1s6dg4o.sqlserver.rds.aliyuncs.com,2333; Database=Pro_FlexJobApiLog; User=bole;Password=Blcs20@%27;Encrypt=false;",
+    //"HumanResources": "Server=rm-bp1mt744021h1s6dg4o.sqlserver.rds.aliyuncs.com,2333; Database=Pro_12333; User=bole;Password=Blcs20@%27;Encrypt=false;",
     //"SyncTarget": "Server=rm-bp1mt744021h1s6dg4o.sqlserver.rds.aliyuncs.com,2333; Database=Pro_FlexJobApi; User=bole;Password=Blcs20@%27;Encrypt=false;"
 
-    "FlexJobApi": "Server=rm-bp1mt744021h1s6dg4o.sqlserver.rds.aliyuncs.com,2333; Database=Pro_FlexJobApi; User=bole;Password=Blcs20@%27;Encrypt=false;",
-    "FlexJobApiLog": "Server=rm-bp1mt744021h1s6dg4o.sqlserver.rds.aliyuncs.com,2333; Database=Pro_FlexJobApiLog; User=bole;Password=Blcs20@%27;Encrypt=false;",
-    "HumanResources": "Server=rm-bp1mt744021h1s6dg4o.sqlserver.rds.aliyuncs.com,2333; Database=Pro_12333; User=bole;Password=Blcs20@%27;Encrypt=false;",
-    "SyncTarget": "Server=rm-bp1mt744021h1s6dg4o.sqlserver.rds.aliyuncs.com,2333; Database=Pro_FlexJobApi; User=bole;Password=Blcs20@%27;Encrypt=false;"
   },
   "Consul": {
     "Address": "http://localhost:8500/",

--
Gitblit v1.9.1