From d9a1f2e7ffce03e84a9548d7c99c81e1d34ac474 Mon Sep 17 00:00:00 2001
From: username@email.com <yzy2002yzy@163.com>
Date: 星期二, 08 十月 2024 15:56:41 +0800
Subject: [PATCH] 区间工价,历史工价

---
 cylsg/cylsg.Application/Orders/Dtos/OrderDto.cs          |   51 ++++++++++++
 cylsg/cylsg.Model/OrderModel/Order.cs                    |    6 +
 cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs |   86 +++++++++++++++++++++
 cylsg/cylsg.Model/OrderModel/OrderBiddingWorkPrice.cs    |   45 +++++++++++
 cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs  |   52 ++++++++++++
 5 files changed, 236 insertions(+), 4 deletions(-)

diff --git a/cylsg/cylsg.Application/Orders/Dtos/OrderDto.cs b/cylsg/cylsg.Application/Orders/Dtos/OrderDto.cs
index 01dab91..830710c 100644
--- a/cylsg/cylsg.Application/Orders/Dtos/OrderDto.cs
+++ b/cylsg/cylsg.Application/Orders/Dtos/OrderDto.cs
@@ -173,6 +173,11 @@
         /// </summary>
         public decimal? WorkPrice { get; set; }
 
+        /// <summary>
+        /// 宸ヤ环
+        /// </summary>
+        public decimal? WorkPriceMax { get; set; }
+
 
         /// <summary>
         /// 鎷涘伐鐘舵��
@@ -194,9 +199,19 @@
         public string IsSelectedName { get; set; }
 
         /// <summary>
+        /// 褰撳墠宸ヤ环
+        /// </summary>
+        public decimal? WorkPriceDangqian { get; set; }
+
+        /// <summary>
         /// 鎷涘伐鏄庣粏
         /// </summary>
         public List<OrderBiddingDto> orderBidding { get; set; }
+
+        /// <summary>
+        /// 鍘嗗彶宸ヤ环
+        /// </summary>
+        public List<OrderBiddingWorkPrice> orderBiddingWorkPrices { get; set; }
 
 
 
@@ -315,6 +330,16 @@
         /// </summary>
         public decimal? Salary { get; set; }
 
+
+        /// <summary>
+        /// 宸ヤ环
+        /// </summary>
+        public decimal? WorkPrice { get; set; }
+
+        /// <summary>
+        /// 鍘嗗彶宸ヤ环
+        /// </summary>
+        public List<OrderBiddingWorkPrice> orderBiddingWorkPrices { get; set; }
     }
 
 
@@ -345,6 +370,24 @@
 
          
 
+
+
+    }
+
+
+    public class WorkPriceDto
+    {
+
+        /// <summary>
+        /// 鎷涘伐鏄庣粏OrderBiddingId
+        /// </summary>
+        public int OrderBiddingId { get; set; }
+
+
+        /// <summary>
+        /// 宸ヤ环
+        /// </summary>
+        public decimal? WorkPrice { get; set; }
 
 
     }
@@ -499,7 +542,13 @@
         /// </summary>
         public int OrderBiddingDetailId { get; set; }
 
-         
+
+        /// <summary>
+        /// 鎷涘伐Id
+        /// </summary>
+        public int OrderBiddingId { get; set; }
+
+
 
         /// <summary>
         /// 鎷涘伐鍚嶇О
diff --git a/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs b/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs
index ef87818..9523d94 100644
--- a/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs
+++ b/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs
@@ -205,6 +205,7 @@
                 order.ContactPhone = orderDto.ContactPhone;
                 order.WorkerType = orderDto.WorkerType;
                 order.WorkPrice = orderDto.WorkPrice;
+                order.WorkPriceMax = orderDto.WorkPriceMax;
                 order.OrderStatus = 0;
                 order.IsEn = true;
                 order.UpDataBy = NickName;
@@ -259,6 +260,7 @@
 
             var orderBiddingRes = new BaseRepository<OrderBidding>();
             var orderRes = new BaseRepository<Order>();
+            var orderBiddingWorkPriceRes = new BaseRepository<OrderBiddingWorkPrice>();
 
             var orderBidding = await orderBiddingRes.GetByIdAsync(queRenDto.OrderBiddingId);
             if (orderBidding == null || orderBidding.IsEn != true || orderBidding.IsDeleted == true )
@@ -300,9 +302,82 @@
                 res = await orderRes.UpdateAsync(order);
             }
 
+
+            //add   瀛樺偍宸ヤ汉鐨勫伐浠�
+            var orderBiddingWorkPrice = new OrderBiddingWorkPrice();
+            orderBiddingWorkPrice.OrderBiddingId = queRenDto.OrderBiddingId;
+            orderBiddingWorkPrice.WorkPrice = order.WorkPrice;
+            orderBiddingWorkPrice.EffectTime = DateTime.Now.Date;
+
+
+            orderBiddingWorkPrice.UpDataBy = NickName;
+            orderBiddingWorkPrice.UpDataTime = DateTime.Now;
+            orderBiddingWorkPrice.CreateBy = NickName;
+            orderBiddingWorkPrice.CreateTime = DateTime.Now;
+            res = await orderBiddingWorkPriceRes.InsertAsync(orderBiddingWorkPrice);
+
             return res;
         }
 
+
+
+
+
+        /// <summary>
+        /// 鍏徃淇敼宸ヤ汉宸ヤ环
+        /// </summary>
+        /// <returns></returns>
+        [Authorize]
+        [HttpPost]
+        public async Task<bool> saveWorkPrice(WorkPriceDto workPriceDto)
+        {
+
+            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 orderRes = new BaseRepository<Order>();
+            var orderBiddingWorkPriceRes = new BaseRepository<OrderBiddingWorkPrice>();
+
+            var orderBidding = await orderBiddingRes.GetByIdAsync(workPriceDto.OrderBiddingId);
+            if (orderBidding == null || orderBidding.IsEn != true || orderBidding.IsDeleted == true)
+            {
+                throw Oops.Oh("璇ユ姇閫掑凡缁忔棤鏁堬紒");
+            }
+            if (orderBidding.IsSelected != true)
+            {
+                throw Oops.Oh("璇ユ姇閫掓病鏈夌‘璁わ紝涓嶈兘淇敼宸ヤ环锛�");
+            }
+
+            
+
+            
+
+
+            bool res;
+
+           
+
+            //add   瀛樺偍宸ヤ汉鐨勫伐浠�
+            var orderBiddingWorkPrice = new OrderBiddingWorkPrice();
+            orderBiddingWorkPrice.OrderBiddingId = workPriceDto.OrderBiddingId;
+            orderBiddingWorkPrice.WorkPrice = workPriceDto.WorkPrice;
+            orderBiddingWorkPrice.EffectTime = DateTime.Now.Date.AddDays(1);
+
+
+            orderBiddingWorkPrice.UpDataBy = NickName;
+            orderBiddingWorkPrice.UpDataTime = DateTime.Now;
+            orderBiddingWorkPrice.CreateBy = NickName;
+            orderBiddingWorkPrice.CreateTime = DateTime.Now;
+            res = await orderBiddingWorkPriceRes.InsertAsync(orderBiddingWorkPrice);
+
+            return res;
+        }
 
 
         /// <summary>
@@ -455,7 +530,7 @@
 
             RefAsync<int> total = 0;
 
-
+            var orderBiddingWorkPriceRepository = new BaseRepository<OrderBiddingWorkPrice>();
             var orderBiddingDetailCheckRepository = new BaseRepository<OrderBiddingDetailCheck>();
             var userWorkerRes = new BaseRepository<UserWorker>();
             var data = await orderRepository.Context.Queryable<Order, OrderBidding, OrderBiddingDetail, UserWorker>((a, b, c, d) =>
@@ -486,6 +561,7 @@
                           WorkCount = c.WorkCount,
                           WorkerUserId = b.WorkerUserId,
                           WorkerUserName = d.name,
+                          OrderBiddingId = c.OrderBiddingId,
                       })
                       
                     .ToPageListAsync(page.PageIndex, page.PageSize, total);
@@ -539,6 +615,14 @@
                     //濡傛灉褰撳ぉ杩樻病鏈夊~鍐欑敵璇凤紝鍒欒绠楀伐浣滄椂闂村拰宸ヨ祫
                     if (dakaDto.IsShenPi == 0)
                     {
+                        //褰撳墠鏈夋晥鐨勫伐浠�
+                       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;
+                        }
+
                         dakaDto.WorkTime = hours + (minutes / 60);
                         if (dakaDto.WorkerType == 0)
                         {
diff --git a/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs b/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
index a9a3a13..732f88e 100644
--- a/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
+++ b/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
@@ -223,6 +223,7 @@
             var orderRes = new BaseRepository<Order>();
             var orderBiddingRes = new BaseRepository<OrderBidding>();
             var userWorkerRes = new BaseRepository<UserWorker>();
+            var orderBiddingWorkPriceRepository = new BaseRepository<OrderBiddingWorkPrice>();
             var userRes = new BaseRepository<User>();
             var order = await orderRes.GetByIdAsync(orderid);
             orderDto = _mapper.Map<OrderDto>(order);
@@ -240,6 +241,23 @@
            var orderBidding = orderBiddings.Where(x => x.WorkerUserId == userid).FirstOrDefault();
             if (orderBidding != null)
             {
+                var dangqianshijian = DateTime.Now.Date;
+                //褰撳墠鏈夋晥鐨勫伐浠�
+                var orderBiddingWorkPrices = await orderBiddingWorkPriceRepository.GetListAsync(x => x.OrderBiddingId == orderBidding.Id && x.IsEn == true && x.IsDeleted == false );
+
+                orderBiddingWorkPrices = orderBiddingWorkPrices.OrderByDescending(x => x.Id).ToList();
+                orderDto.orderBiddingWorkPrices = orderBiddingWorkPrices;
+                var orderBiddingWorkPrice = orderBiddingWorkPrices.Where(x => x.EffectTime <= DateTime.Now.Date).FirstOrDefault();
+                if (orderBiddingWorkPrice != null)
+                {
+                    orderDto.WorkPriceDangqian = orderBiddingWorkPrice.WorkPrice;
+                }
+                else
+                {
+                    orderDto.WorkPriceDangqian = orderDto.WorkPrice;
+                }
+
+
                 orderDto.IsSelected = orderBidding.IsSelected;
                 if (!orderDto.IsSelected.HasValue)
                 {
@@ -286,6 +304,23 @@
                     {
                         orderBiddingDto.WorkerName = userWorker.name;
                     }
+                     
+                        //褰撳墠鏈夋晥鐨勫伐浠�
+                        var orderBiddingWorkPrices = await orderBiddingWorkPriceRepository.GetListAsync(x => x.OrderBiddingId == orderBiddingDto.Id && x.IsEn == true && x.IsDeleted == false);
+                        orderBiddingWorkPrices = orderBiddingWorkPrices.OrderByDescending(x => x.Id).ToList();
+                        orderBiddingDto.orderBiddingWorkPrices = orderBiddingWorkPrices;
+                        var orderBiddingWorkPrice = orderBiddingWorkPrices.Where(x => x.EffectTime <= DateTime.Now.Date).FirstOrDefault();
+                        if (orderBiddingWorkPrice != null)
+                        {
+
+                            orderBiddingDto.WorkPrice = orderBiddingWorkPrice.WorkPrice;
+                        }
+                        else
+                        {
+                            orderBiddingDto.WorkPrice = orderDto.WorkPrice;
+                        }
+                    
+                   
 
                 }
             }
@@ -551,7 +586,7 @@
 
 
             var orderBiddingDetailCheckRepository = new BaseRepository<OrderBiddingDetailCheck>();
-
+            var orderBiddingWorkPriceRepository = new BaseRepository<OrderBiddingWorkPrice>();
             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 ,
@@ -578,6 +613,7 @@
                           IsShenPi = c.IsShenPi,
                           WorkCount = c.WorkCount,
                           Suppliername = d.Suppliername,
+                          OrderBiddingId = c.OrderBiddingId,
                       })
                      
                     .ToPageListAsync(page.PageIndex, page.PageSize, total);
@@ -631,6 +667,12 @@
                     //濡傛灉褰撳ぉ杩樻病鏈夊~鍐欑敵璇凤紝鍒欒绠楀伐浣滄椂闂村拰宸ヨ祫
                     if(dakaDto.IsShenPi == 0)
                     {
+                        //褰撳墠鏈夋晥鐨勫伐浠�
+                        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;
+                        }
                         dakaDto.WorkTime = hours+(minutes/60);
                         if(dakaDto.WorkerType == 0)
                         {
@@ -703,6 +745,7 @@
             var orderRes = new BaseRepository<Order>();
             var orderBiddingDetailRes = new BaseRepository<OrderBiddingDetail>();
             var OrderBiddingDetailCheckRes = new BaseRepository<OrderBiddingDetailCheck>();
+            var orderBiddingWorkPriceRepository = new BaseRepository<OrderBiddingWorkPrice>();
             var userRes = new BaseRepository<User>();
             var userWorkerRes = new BaseRepository<UserWorker>();
 
@@ -766,7 +809,12 @@
 
                     }
                 }
-
+                //褰撳墠鏈夋晥鐨勫伐浠�
+                var orderBiddingWorkPrice = (await orderBiddingWorkPriceRepository.GetListAsync(x => x.OrderBiddingId == orderBidding.Id && x.IsEn == true && x.IsDeleted == false && x.EffectTime <= orderDakaMingxiDto.WorkDate)).OrderByDescending(x => x.Id).FirstOrDefault();
+                if (orderBiddingWorkPrice != null)
+                {
+                    orderDakaMingxiDto.WorkPrice = orderBiddingWorkPrice.WorkPrice;
+                }
                 orderDakaMingxiDto.WorkTime = hours + (minutes / 60);
                 if (orderDakaMingxiDto.WorkerType == 0)
                 {
diff --git a/cylsg/cylsg.Model/OrderModel/Order.cs b/cylsg/cylsg.Model/OrderModel/Order.cs
index 11195c5..6e14730 100644
--- a/cylsg/cylsg.Model/OrderModel/Order.cs
+++ b/cylsg/cylsg.Model/OrderModel/Order.cs
@@ -104,6 +104,12 @@
         [SugarColumn(ColumnDescription = "宸ヤ环", Length = 18, DecimalDigits = 2, IsNullable = true)]
         public decimal? WorkPrice { get; set; }
 
+        /// <summary>
+        /// 宸ヤ环涓婇檺
+        /// </summary>
+        [SugarColumn(ColumnDescription = "宸ヤ环涓婇檺", Length = 18, DecimalDigits = 2, IsNullable = true)]
+        public decimal? WorkPriceMax { get; set; }
+
 
         /// <summary>
         /// 鎷涘伐鐘舵��
diff --git a/cylsg/cylsg.Model/OrderModel/OrderBiddingWorkPrice.cs b/cylsg/cylsg.Model/OrderModel/OrderBiddingWorkPrice.cs
new file mode 100644
index 0000000..ddd028f
--- /dev/null
+++ b/cylsg/cylsg.Model/OrderModel/OrderBiddingWorkPrice.cs
@@ -0,0 +1,45 @@
+锘縰sing cylsg.Core.Attributes;
+using cylsg.Core;
+using System;
+using System.Collections.Generic;
+using System.ComponentModel;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using SqlSugar;
+
+namespace cylsg.Model.OrderModel
+{
+    /// <summary>
+    /// 鎷涘伐宸ヤ汉鍘嗗彶宸ヤ环
+    /// </summary>
+    [Description("鎷涘伐宸ヤ汉鍘嗗彶宸ヤ环")]
+    [CoderFirst]
+    public class OrderBiddingWorkPrice : BaseModel
+    {
+        /// <summary>
+        /// 鎷涘伐Id
+        /// </summary>
+        [SugarColumn(ColumnDescription = "鎷涘伐Id", IsPrimaryKey = true, IsIdentity = true)]
+        public int Id { get; set; }
+
+        /// <summary>
+        /// 宸ヤ汉鎶曢�抜d
+        /// </summary>
+        [SugarColumn(ColumnDescription = "宸ヤ汉鎶曢�抜d")]
+        public int OrderBiddingId { get; set; }
+
+        /// <summary>
+        /// 宸ヤ环
+        /// </summary>
+        [SugarColumn(ColumnDescription = "宸ヤ环", Length = 18, DecimalDigits = 2, IsNullable = true)]
+        public decimal? WorkPrice { get; set; }
+
+        /// <summary>
+        /// 鐢熸晥鏃堕棿
+        /// </summary>
+        [SugarColumn(ColumnDescription = "鐢熸晥鏃堕棿", IsNullable = true)]
+        public DateTime? EffectTime { get; set; }
+
+    }
+}

--
Gitblit v1.9.1