From 327a841a996e9e727d854baa449b5253035c4cf4 Mon Sep 17 00:00:00 2001
From: username@email.com <yzy2002yzy@163.com>
Date: 星期二, 07 四月 2026 15:34:45 +0800
Subject: [PATCH] 增加灵活用工

---
 cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs |   87 ++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 85 insertions(+), 2 deletions(-)

diff --git a/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs b/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs
index 72105d6..09ec7e8 100644
--- a/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs
+++ b/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs
@@ -307,7 +307,8 @@
             orderBidding.Selectedtime = DateTime.Now;
             orderBidding.UpDataBy = NickName;
             orderBidding.UpDataTime = DateTime.Now;
-
+            //鏄惁鏄崐鍥哄畾涓存椂宸�
+            orderBidding.IsGuding = queRenDto.IsGuding;
 
             res = await orderBiddingRes.UpdateAsync(orderBidding);
 
@@ -330,6 +331,51 @@
             orderBiddingWorkPrice.CreateBy = NickName;
             orderBiddingWorkPrice.CreateTime = DateTime.Now;
             res = await orderBiddingWorkPriceRes.InsertAsync(orderBiddingWorkPrice);
+
+            return res;
+        }
+
+
+        /// <summary>
+        /// 璁剧疆鍛樺伐鏄崐鍥哄畾涓存椂宸ユ槸鍚︽槸
+        /// </summary>
+        /// <returns></returns>
+        [Authorize]
+        [HttpPost]
+        public async Task<bool> GudingGongren(BangudingDto bangudingDto)
+        {
+
+            var UserID = App.User?.FindFirstValue("UserID");
+            int userid = 0;
+            string NickName = App.User?.FindFirstValue("NickName");
+            if (!string.IsNullOrEmpty(UserID))
+            {
+                userid = int.Parse(UserID);
+            }
+
+            var orderBiddingRes = new BaseRepository<OrderBidding>();
+
+            var orderBidding = await orderBiddingRes.GetByIdAsync(bangudingDto.OrderBiddingId);
+            if (orderBidding == null || orderBidding.IsEn != true || orderBidding.IsDeleted == true)
+            {
+                throw Oops.Oh("璇ユ姇閫掑凡缁忔棤鏁堬紒");
+            }
+
+
+
+
+
+            bool res;
+
+            orderBidding.IsGuding = bangudingDto.IsGuding;
+
+            orderBidding.UpDataBy = NickName;
+            orderBidding.UpDataTime = DateTime.Now;
+
+
+            res = await orderBiddingRes.UpdateAsync(orderBidding);
+
+
 
             return res;
         }
@@ -651,6 +697,8 @@
             var orderBiddingWorkPriceRepository = new BaseRepository<OrderBiddingWorkPrice>();
             var orderBiddingDetailCheckRepository = new BaseRepository<OrderBiddingDetailCheck>();
             var userWorkerRes = new BaseRepository<UserWorker>();
+            var orderBiddingRes = new BaseRepository<OrderBidding>();
+
             var data = await orderRepository.Context.Queryable<Order, OrderBidding, OrderBiddingDetail, UserWorker>((a, b, c, d) =>
                  new JoinQueryInfos(JoinType.Inner, a.Id == b.OrderId,
                  JoinType.Inner, b.Id == c.OrderBiddingId,
@@ -681,6 +729,7 @@
                           WorkerUserId = b.WorkerUserId,
                           WorkerUserName = d.name,
                           OrderBiddingId = c.OrderBiddingId,
+                          IsGuding = b.IsGuding,
                       })
                       
                     .ToPageListAsync(page.PageIndex, page.PageSize, total);
@@ -709,6 +758,10 @@
                 {
                     int hours = 0;
                     int minutes = 0;
+
+                    int jiabanhours = 0;
+                    int jiabanminutes = 0;
+
                     var orderBiddingDetailChecks = await orderBiddingDetailCheckRepository.GetListAsync(x => x.OrderBiddingDetailId == dakaDto.OrderBiddingDetailId && x.IsEn == true && x.IsDeleted == false);
                     string DakaMingxi = "";
                     for (int i = 0; i < orderBiddingDetailChecks.Count; i++)
@@ -728,14 +781,37 @@
                             hours += timeDifference.Hours;
                             minutes += timeDifference.Minutes;
 
+
+                            // 鑾峰彇褰撳墠鏃堕棿
+                            DateTime now = DateTime.Now;
+
+                            // 鍒涘缓涓�涓〃绀烘櫄涓�8鐐圭殑鏃堕棿锛堝亣瀹氫粖澶╋級
+                            DateTime eveningTime = new DateTime(now.Year, now.Month, now.Day, 20, 0, 0); // 20:00:0
+                            //璁$畻鏄惁涓烘櫄涓�8鐐瑰悗鐨勫姞鐝椂闂�
+                            if (orderBiddingDetailChecks[i].Checktime.Value > eveningTime )
+                            {
+                                var timeDifferencejiaban = orderBiddingDetailChecks[i].Checktime.Value - eveningTime;
+                                jiabanhours += timeDifferencejiaban.Hours;
+                                jiabanminutes += timeDifferencejiaban.Minutes;
+                            }
+
                         }
                     }
+                    var orderBidding = await orderBiddingRes.GetByIdAsync(dakaDto.OrderBiddingId);
                     //褰撳墠鏈夋晥鐨勫伐浠�
                     var orderBiddingWorkPrices = await orderBiddingWorkPriceRepository.GetListAsync(x => x.OrderBiddingId == dakaDto.OrderBiddingId && x.IsEn == true && x.IsDeleted == false && x.EffectTime <= dakaDto.WorkDate);
                     var orderBiddingWorkPrice = orderBiddingWorkPrices.OrderByDescending(x => x.Id).FirstOrDefault();
                     if (orderBiddingWorkPrice != null)
                     {
-                        dakaDto.WorkPrice = orderBiddingWorkPrice.WorkPrice;
+                        //濡傛灉涓哄崐鍥哄畾鐨勪复鏃跺伐锛屽伐浠峰浐瀹�11鍧�
+                        if (orderBidding != null && orderBidding.IsGuding.HasValue && orderBidding.IsGuding.Value == true)
+                        {
+                            dakaDto.WorkPrice = 11;
+                        }
+                        else
+                        {
+                            dakaDto.WorkPrice = orderBiddingWorkPrice.WorkPrice;
+                        }       
                     }
                     //濡傛灉褰撳ぉ杩樻病鏈夊~鍐欑敵璇凤紝鍒欒绠楀伐浣滄椂闂村拰宸ヨ祫
                     if (dakaDto.IsShenPi == 0)
@@ -746,6 +822,13 @@
                         if (dakaDto.WorkerType == 0)
                         {
                             dakaDto.TodaySalary = dakaDto.WorkTime * dakaDto.WorkPrice;
+
+                            //濡傛灉涓哄崐鍥哄畾鐨勪复鏃跺伐锛屽姞鐝瘡涓皬鏃跺鍔�4鍧楅挶
+                            if (orderBidding != null && orderBidding.IsGuding.HasValue && orderBidding.IsGuding.Value == true)
+                            {
+                                var jiabanshijian = jiabanhours + (jiabanminutes / 60);
+                                dakaDto.TodaySalary += (jiabanshijian * 4);
+                            }
                         }
                         else
                         {

--
Gitblit v1.9.1