From 2ff9e22aa01202003c8ba2b3d7c91226e61de1f8 Mon Sep 17 00:00:00 2001
From: 小飞侠 <8277136+liaoxujun@user.noreply.gitee.com>
Date: 星期四, 09 四月 2026 09:03:07 +0800
Subject: [PATCH] no message

---
 cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs |   57 ++++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 48 insertions(+), 9 deletions(-)

diff --git a/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs b/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
index d246803..68eae2b 100644
--- a/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
+++ b/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
@@ -59,7 +59,7 @@
             Expression<Func<Order, bool>> expression = t => true;
 
             expression = expression.And(t => t.IsDeleted == false && t.IsEn == true && t.OrderStatus == 0);
-            expression = expression.And(t => t.WordStartTime >= DateTime.Now.Date.AddDays(-30));
+           // expression = expression.And(t => t.WordEndTime >= DateTime.Now.Date.AddDays(-30));
             if (!string.IsNullOrEmpty(page.OrderName))
             {
                 expression = expression.And(t => t.OrderName.Contains(page.OrderName));
@@ -193,7 +193,7 @@
                 {
                     switch (orderDto.OrderStatus)
                     {
-                        case (int)OrderStatuses.fabu: orderDto.OrderStatusName = "鍙戝竷"; break;
+                        case (int)OrderStatuses.fabu: orderDto.OrderStatusName = "鍙戝竷涓�"; break;
                         case (int)OrderStatuses.zhaogongwanbi: orderDto.OrderStatusName = "鎷涘伐瀹屾瘯"; break;
                         case (int)OrderStatuses.jiesuanwanbi: orderDto.OrderStatusName = "缁撶畻瀹屾瘯"; break;
                         default: break;
@@ -263,10 +263,14 @@
             var orderBiddingWorkPriceRepository = new BaseRepository<OrderBiddingWorkPrice>();
             var userRes = new BaseRepository<User>();
             var order = await orderRes.GetByIdAsync(orderid);
+            if (order.IsDeleted == true)
+            {
+                throw Oops.Oh("璁㈠崟宸茬粡鍒犻櫎鏃犳硶鏌ョ湅锛�");
+            }
             orderDto = _mapper.Map<OrderDto>(order);
             switch (orderDto.OrderStatus)
             {
-                case (int)OrderStatuses.fabu: orderDto.OrderStatusName = "鍙戝竷"; break;
+                case (int)OrderStatuses.fabu: orderDto.OrderStatusName = "鍙戝竷涓�"; break;
                 case (int)OrderStatuses.zhaogongwanbi: orderDto.OrderStatusName = "鎷涘伐瀹屾瘯"; break;
                 case (int)OrderStatuses.jiesuanwanbi: orderDto.OrderStatusName = "缁撶畻瀹屾瘯"; break;
                 default: break;
@@ -310,7 +314,7 @@
                 }
             }
 
-            orderBiddings = orderBiddings.Where(x => (x.IsSelected == null || x.IsSelected != false)).ToList();
+            orderBiddings = orderBiddings.Where(x => (x.IsSelected == null || x.IsSelected != false)).OrderBy(x=>x.IsSelected).ThenByDescending(x=>x.IsCollect).ToList();
             var orderBiddingDtos = _mapper.Map<List<OrderBiddingDto>>(orderBiddings);
             if(orderBiddingDtos != null&& orderBiddingDtos.Count > 0)
             {
@@ -632,16 +636,17 @@
             
             RefAsync<int> total = 0;
 
-
             var orderBiddingDetailCheckRepository = new BaseRepository<OrderBiddingDetailCheck>();
             var orderBiddingWorkPriceRepository = new BaseRepository<OrderBiddingWorkPrice>();
+            var orderBiddingRes = new BaseRepository<OrderBidding>();
+
             var data = await orderRepository.Context.Queryable<Order, OrderBidding, OrderBiddingDetail ,UserCompany>((a, b ,c ,d) =>
                  new JoinQueryInfos(JoinType.Inner, a.Id == b.OrderId ,
                  JoinType.Inner, b.Id == c.OrderBiddingId ,
                   JoinType.Inner, a.OrderUserId == d.UserId 
                 ))
-                     .Where((a, b, c, d) => a.IsEn == true && a.IsDeleted == false && b.IsEn == true && b.IsDeleted == false && c.IsEn == true && c.IsDeleted == false
-                     && b.IsSelected == true && b.WorkerUserId == userid && d.IsEn == true && d.IsDeleted == false )
+                     .Where((a, b, c, d) =>  a.IsDeleted == false && b.IsEn == true && b.IsDeleted == false && c.IsEn == true && c.IsDeleted == false
+                     && b.IsSelected == true && b.WorkerUserId == userid && d.IsEn == true && d.IsDeleted == false) //a.IsEn == true &&
                       .WhereIF(page.WordDate.HasValue, (a, b, c, d) => (c.WorkDate == page.WordDate))
                        .WhereIF(page.WordDateStart.HasValue, (a, b, c, d) => (c.WorkDate >= page.WordDateStart))
                         .WhereIF(page.WordDateEnd.HasValue, (a, b, c, d) => (c.WorkDate <= page.WordDateEnd))
@@ -662,6 +667,7 @@
                           WorkCount = c.WorkCount,
                           Suppliername = d.Suppliername,
                           OrderBiddingId = c.OrderBiddingId,
+                          IsGuding = b.IsGuding,
                       })
                      
                     .ToPageListAsync(page.PageIndex, page.PageSize, total);
@@ -692,6 +698,10 @@
                     string DakaMingxi = "";
                     int hours = 0;
                     int minutes = 0;
+
+                    int jiabanhours = 0;
+                    int jiabanminutes = 0;
+
                     for (int i = 0; i < orderBiddingDetailChecks.Count; i++)
                     {
                       
@@ -710,21 +720,49 @@
                             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;
+                            }
                         }
                     }
                     //濡傛灉褰撳ぉ杩樻病鏈夊~鍐欑敵璇凤紝鍒欒绠楀伐浣滄椂闂村拰宸ヨ祫
                     if(dakaDto.IsShenPi == 0)
                     {
+                        var orderBidding = await orderBiddingRes.GetByIdAsync(dakaDto.OrderBiddingId);
                         //褰撳墠鏈夋晥鐨勫伐浠�
                         var orderBiddingWorkPrice = (await orderBiddingWorkPriceRepository.GetListAsync(x => x.OrderBiddingId == dakaDto.OrderBiddingId && x.IsEn == true && x.IsDeleted == false && x.EffectTime <= dakaDto.WorkDate)).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;
+                            }
                         }
                         dakaDto.WorkTime = hours+(minutes/60);
                         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
                         {
@@ -812,6 +850,7 @@
             orderDakaMingxiDto.WorkPrice = order.WorkPrice;
             orderDakaMingxiDto.TodaySalary = orderBiddingDetail.TodaySalary;
             orderDakaMingxiDto.IsShenPi = orderBiddingDetail.IsShenPi;
+            orderDakaMingxiDto.ShenPitime = orderBiddingDetail.ShenPitime;
             orderDakaMingxiDto.WorkCount = orderBiddingDetail.WorkCount;
             orderDakaMingxiDto.WorkerUserId = orderBidding.WorkerUserId;
             var user = await userRes.GetByIdAsync(orderDakaMingxiDto.WorkerUserId);
@@ -918,7 +957,7 @@
             var order = await orderRes.GetByIdAsync(orderBidding.OrderId);
 
             
-            if (order == null || order.OrderStatus > 1 || order.IsDeleted == true || order.IsEn == false )
+            if (order == null || order.OrderStatus > 1 || order.IsDeleted == true)// || order.IsEn == false
             {
                 throw Oops.Oh("璇ユ嫑宸ョ姸鎬佸凡鏃犳硶鎵撳崱纭锛�");
             }

--
Gitblit v1.9.1