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