From b53678eec74cadc4d8d5773343b10ffa2adc5330 Mon Sep 17 00:00:00 2001
From: username@email.com <yzy2002yzy@163.com>
Date: 星期二, 03 九月 2024 09:50:27 +0800
Subject: [PATCH] 最新代码

---
 cylsg/cylsg.Application/Orders/Dtos/OrderDto.cs          |  111 +++++++++++++++++++++
 cylsg/cylsg.Application/Users/UserAppService.cs          |   56 +++++++++++
 cylsg/cylsg.Model/OrderModel/Order.cs                    |   19 +++
 cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs |    2 
 cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs  |   42 +++++--
 cylsg/cylsg.Application/Timers/TimedBackgroundService.cs |   59 +++++++++++
 cylsg/cylsg.Web.Core/Startup.cs                          |    5 
 7 files changed, 272 insertions(+), 22 deletions(-)

diff --git a/cylsg/cylsg.Application/Orders/Dtos/OrderDto.cs b/cylsg/cylsg.Application/Orders/Dtos/OrderDto.cs
index e98d7c7..93cef3f 100644
--- a/cylsg/cylsg.Application/Orders/Dtos/OrderDto.cs
+++ b/cylsg/cylsg.Application/Orders/Dtos/OrderDto.cs
@@ -29,14 +29,106 @@
         public string OrderName { get; set; }
 
         /// <summary>
-        /// 宸ヤ綔寮�濮嬫椂闂�
+        /// 宸ヤ綔寮�濮嬫棩鏈�
         /// </summary>
         public DateTime? WordStartTime { get; set; }
 
         /// <summary>
-        /// 宸ヤ綔缁撴潫鏃堕棿
+        /// 宸ヤ綔寮�濮嬫棩鏈熷悕绉�
+        /// </summary>
+        public string WordStartTimeName {
+            get
+            {
+                if (this.WordStartTime.HasValue)
+                {
+                    // 鍙互娣诲姞鑷繁鐨勯�昏緫
+                    return this.WordStartTime.Value.ToString("yyyy-MM-dd");
+                }
+                else
+                {
+                    return "";
+                }
+
+                
+            }}
+
+        /// <summary>
+        /// 宸ヤ綔缁撴潫鏃ユ湡
         /// </summary>
         public DateTime? WordEndTime { get; set; }
+
+        /// <summary>
+        /// 宸ヤ綔缁撴潫鏃ユ湡鍚嶇О
+        /// </summary>
+        public string WordEndTimeName
+        {
+            get
+            {
+                if (this.WordEndTime.HasValue)
+                {
+                    // 鍙互娣诲姞鑷繁鐨勯�昏緫
+                    return this.WordEndTime.Value.ToString("yyyy-MM-dd");
+                }
+                else
+                {
+                    return "";
+                }
+
+
+            }
+        }
+
+        /// <summary>
+        /// 宸ヤ綔寮�濮嬫椂闂�
+        /// </summary>
+        public DateTime? StartTime { get; set; }
+
+        /// <summary>
+        /// 宸ヤ綔寮�濮嬫椂闂村悕绉�
+        /// </summary>
+        public string StartTimeName
+        {
+            get
+            {
+                if (this.StartTime.HasValue)
+                {
+                    // 鍙互娣诲姞鑷繁鐨勯�昏緫
+                    return this.StartTime.Value.ToString("HH:mm");
+                }
+                else
+                {
+                    return "";
+                }
+
+
+            }
+        }
+
+        /// <summary>
+        /// 宸ヤ綔缁撴潫鏃堕棿
+        /// </summary>
+        public DateTime? EndTime { get; set; }
+
+        /// <summary>
+        /// 宸ヤ綔缁撴潫鏃ユ湡鍚嶇О
+        /// </summary>
+        public string EndTimeName
+        {
+            get
+            {
+                if (this.EndTime.HasValue)
+                {
+                    // 鍙互娣诲姞鑷繁鐨勯�昏緫
+                    return this.EndTime.Value.ToString("HH:mm");
+                }
+                else
+                {
+                    return "";
+                }
+
+
+            }
+        }
 
         /// <summary>
         /// 闇�姹�
@@ -214,9 +306,9 @@
     {
 
         /// <summary>
-        /// 鎷涘伐鏄庣粏OrderBiddingId
+        /// 鎷涘伐OrderId
         /// </summary>
-        public int OrderBiddingId { get; set; }
+        public int OrderId { get; set; }
 
 
         /// <summary>
@@ -290,6 +382,17 @@
 
 
         /// <summary>
+        /// 鐢ㄦ埛id
+        /// </summary>
+        public int WorkerUserId { get; set; }
+
+        /// <summary>
+        /// 鐢ㄦ埛鏄电О
+        /// </summary>
+        public string WorkerName { get; set; }
+
+
+        /// <summary>
         /// 鎵撳崱鏄庣粏
         /// </summary>
         public List<OrderBiddingDetailCheckDto> orderBiddingDetailCheck { get; set; }
diff --git a/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs b/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs
index 86db772..1a2bb2c 100644
--- a/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs
+++ b/cylsg/cylsg.Application/Orders/OrderCompanyAppService.cs
@@ -159,6 +159,8 @@
                 order.OrderName = orderDto.OrderName;
                 order.WordStartTime = orderDto.WordStartTime;
                 order.WordEndTime = orderDto.WordEndTime;
+                order.StartTime = orderDto.StartTime;
+                order.EndTime = orderDto.EndTime;
                 order.Demand = orderDto.Demand;
                 order.WorderCount = orderDto.WorderCount;
                 order.WorderAddress = orderDto.WorderAddress;
diff --git a/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs b/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
index 61b287c..76f27a1 100644
--- a/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
+++ b/cylsg/cylsg.Application/Orders/OrderWorkerAppService.cs
@@ -359,6 +359,7 @@
             var orderRes = new BaseRepository<Order>();
             var orderBiddingDetailRes = new BaseRepository<OrderBiddingDetail>();
             var OrderBiddingDetailCheckRes = new BaseRepository<OrderBiddingDetailCheck>();
+            var userWorkerRes = new BaseRepository<UserWorker>();
             var order = await orderRes.GetByIdAsync(baoMingDto.OrderId);
             if (order == null || order.OrderStatus > 1)
             {
@@ -378,6 +379,11 @@
                     throw Oops.Oh("褰撳ぉ鐨勬墦鍗″凡缁忔彁浜わ紝涓嶈兘鎵撳崱锛�");
                 }
                 orderBiddingDetailDto = _mapper.Map<OrderBiddingDetailDto>(orderBiddingDetail);
+                orderBiddingDetailDto.WorkerUserId = orderBidding.WorkerUserId;
+                var worker  = await  userWorkerRes.GetFirstAsync(x => x.UserId == orderBidding.WorkerUserId);
+                if(worker != null)
+                    orderBiddingDetailDto.WorkerName = worker.name;
+
                 var orderBiddingDetailChecks = await OrderBiddingDetailCheckRes.GetListAsync(x => x.OrderBiddingDetailId == orderBiddingDetail.Id  && x.IsDeleted == false && x.IsEn == true);
                 orderBiddingDetailDto.orderBiddingDetailCheck = _mapper.Map<List<OrderBiddingDetailCheckDto>>(orderBiddingDetailChecks); 
             }
@@ -407,19 +413,25 @@
             var orderBiddingDetailRes = new BaseRepository<OrderBiddingDetail>();
             var OrderBiddingDetailCheckRes = new BaseRepository<OrderBiddingDetailCheck>();
 
-            var orderBidding = await orderBiddingRes.GetByIdAsync(dakaDto.OrderBiddingId);
+            var order = await orderRes.GetByIdAsync(dakaDto.OrderId);
+            if (order == null || order.OrderStatus > 1)
+            {
+                throw Oops.Oh("璇ユ嫑宸ョ姸鎬佸凡鏃犳硶鎵撳崱锛�");
+            }
+
+            var orderBidding = await orderBiddingRes.GetFirstAsync(x => x.OrderId == dakaDto.OrderId && x.WorkerUserId == userid && x.IsSelected == true && x.IsEn == true && x.IsDeleted == false );//GetByIdAsync(dakaDto.OrderBiddingId);
             if (orderBidding == null || orderBidding.IsDeleted ==true || orderBidding.IsEn == false || orderBidding.IsSelected !=true )
             {
                 throw Oops.Oh("璇ユ姇閫掔姸鎬佹棤娉曟墦鍗★紒");
             }
 
-            var order = await orderRes.GetByIdAsync(orderBidding.OrderId);
-            if (order == null || order.OrderStatus > 1)
-            {
-                throw Oops.Oh("璇ユ嫑宸ョ姸鎬佸凡鏃犳硶鎵撳崱锛�");
-            }
+           
             bool res;
             var dateTime = DateTime.Now.Date;
+            if ( dateTime < order.WordStartTime.Value && dateTime > order.WordEndTime.Value )
+            {
+                throw Oops.Oh("涓嶅湪鍏佽鎵撳崱鐨勬椂闂磋寖鍥达紒");
+            }
             var orderBiddingDetail = await orderBiddingDetailRes.GetFirstAsync(x => x.OrderBiddingId == orderBidding.Id && x.WorkDate == dateTime && x.IsDeleted == false && x.IsEn == true);
             if (orderBiddingDetail!=null && orderBiddingDetail.IsShenPi>0)
             {
@@ -438,7 +450,7 @@
                 {
                     throw Oops.Oh("鍛樺伐鏈敞鍐屾垚宸ヤ汉");
                 }
-                var faseres = _tencentCloudService.VerifyFace(dakaDto.FaceImg, UserWorkRes.IAIPersonId);
+                var faseres =  _tencentCloudService.VerifyFace(dakaDto.FaceImg, UserWorkRes.IdCode);
 
                 if (faseres.IsMatch != true)
                 {
@@ -740,21 +752,23 @@
             //var OrderBiddingDetailCheckRes = new BaseRepository<OrderBiddingDetailCheck>();
 
             var orderBiddingDetail = await orderBiddingDetailRes.GetByIdAsync(dakaDto.OrderBiddingDetailId);
+            if (orderBiddingDetail == null || orderBiddingDetail.IsShenPi > 1 || orderBiddingDetail.IsDeleted == true || orderBiddingDetail.IsEn == false)
+            {
+                throw Oops.Oh("璇ユ墦鍗$姸鎬佸凡鏃犳硶鎵撳崱纭锛�");
+            }
             var orderBidding = await orderBiddingRes.GetByIdAsync(orderBiddingDetail.OrderBiddingId);
-            var order = await orderRes.GetByIdAsync(orderBidding.OrderId);
-
             if (orderBidding == null || orderBidding.IsDeleted == true || orderBidding.IsEn == false || orderBidding.IsSelected != true)
             {
                 throw Oops.Oh("璇ユ姇閫掔姸鎬佹棤娉曟墦鍗$‘璁わ紒");
             }
-            if (order == null || order.OrderStatus > 1)
+            var order = await orderRes.GetByIdAsync(orderBidding.OrderId);
+
+            
+            if (order == null || order.OrderStatus > 1 || order.IsDeleted == true || order.IsEn == false )
             {
                 throw Oops.Oh("璇ユ嫑宸ョ姸鎬佸凡鏃犳硶鎵撳崱纭锛�");
             }
-            if (orderBiddingDetail == null || orderBiddingDetail.IsShenPi > 1)
-            {
-                throw Oops.Oh("璇ユ墦鍗$姸鎬佸凡鏃犳硶鎵撳崱纭锛�");
-            }
+            
 
 
             orderBiddingDetail.WorkTime = dakaDto.WorkTime;
diff --git a/cylsg/cylsg.Application/Timers/TimedBackgroundService.cs b/cylsg/cylsg.Application/Timers/TimedBackgroundService.cs
new file mode 100644
index 0000000..882b35e
--- /dev/null
+++ b/cylsg/cylsg.Application/Timers/TimedBackgroundService.cs
@@ -0,0 +1,59 @@
+锘縰sing cylsg.Core;
+using cylsg.Model.OrderModel;
+using Microsoft.Extensions.DependencyInjection;
+using Microsoft.Extensions.Hosting;
+using SqlSugar;
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace cylsg.Application.Timers
+{
+    public class TimedBackgroundService : IHostedService, IDisposable
+    {
+        private Timer _timer;
+        public Task StartAsync(CancellationToken cancellationToken)
+        {
+            _timer = new Timer(DoWork, null, TimeSpan.Zero, TimeSpan.FromSeconds(60*60));
+
+            return Task.CompletedTask;
+        }
+
+        private async void DoWork(object? state)
+        {
+            var orderBiddingRes = new BaseRepository<OrderBidding>();
+            var orderRes = new BaseRepository<Order>();
+            var orderBiddingDetailRes = new BaseRepository<OrderBiddingDetail>();
+            var orders = await orderRes.GetListAsync(x => x.OrderStatus < 2 && x.IsEn == true && x.IsDeleted == false && x.WordEndTime <= DateTime.Now.AddDays(-1));
+            foreach (var order in orders)
+            {
+                var sss = await orderBiddingRes.GetListAsync(x => x.OrderId == order.Id && x.IsEn == true && x.IsDeleted == false && x.IsSelected == true);
+                var bbb = sss.Select(x => x.Id).ToList();
+                var oCount = await orderBiddingDetailRes.CountAsync(x => bbb.Contains(x.OrderBiddingId) && x.IsEn == true && x.IsDeleted == false && x.IsShenPi != (int)IsShenPis.yishenpi);
+                if (oCount == 0)
+                {
+                    order.OrderStatus = (int)OrderStatuses.jiesuanwanbi;
+                    var res = await orderRes.UpdateAsync(order);
+
+                }
+            }
+        }
+
+        public Task StopAsync(CancellationToken cancellationToken)
+        {
+            Console.WriteLine("StopAsync");
+
+            return Task.CompletedTask;
+        }
+
+        public void Dispose()
+        {
+            _timer?.Dispose();
+        }
+
+ 
+        
+    }
+}
diff --git a/cylsg/cylsg.Application/Users/UserAppService.cs b/cylsg/cylsg.Application/Users/UserAppService.cs
index bac83be..a3f0c08 100644
--- a/cylsg/cylsg.Application/Users/UserAppService.cs
+++ b/cylsg/cylsg.Application/Users/UserAppService.cs
@@ -285,6 +285,60 @@
         }
 
 
-      
+
+
+        /// <summary>
+        /// 淇濆瓨鐢ㄦ埛淇℃伅
+        /// </summary>
+        /// <returns></returns>
+        public async Task<bool> saveUser(UserDto userDto)
+        {
+
+            var UserID = App.User?.FindFirstValue("UserID");
+            int userid = 0;
+            string NickName = App.User?.FindFirstValue("NickName");
+            if (!string.IsNullOrEmpty(UserID))
+            {
+                userid = int.Parse(UserID);
+            }
+            if (!string.IsNullOrEmpty(userDto.Nickname) && userDto.Nickname.Length > 100)
+            {
+                throw Oops.Oh("鏄电О闀垮害杩囬暱锛�");
+            }
+            if (!string.IsNullOrEmpty(userDto.Avatar) && userDto.Avatar.Length > 500)
+            {
+                throw Oops.Oh("澶村儚闀垮害杩囬暱锛�");
+            }
+            
+
+            var userRes = new BaseRepository<User>();
+            bool res;
+
+            var user = await userRes.GetByIdAsync(userid);
+
+            if (!string.IsNullOrEmpty(userDto.Nickname))
+                user.Nickname = userDto.Nickname;
+            if (!string.IsNullOrEmpty(userDto.Avatar))
+                user.Avatar = userDto.Avatar;
+
+
+            user.UpDataBy = NickName;
+            user.UpDataTime = DateTime.Now;
+            res = await userRes.UpdateAsync(user);
+
+
+
+
+
+
+
+
+
+
+            return res;
+        }
+
+
+
     }
 }
diff --git a/cylsg/cylsg.Model/OrderModel/Order.cs b/cylsg/cylsg.Model/OrderModel/Order.cs
index bad6fe3..d901ab2 100644
--- a/cylsg/cylsg.Model/OrderModel/Order.cs
+++ b/cylsg/cylsg.Model/OrderModel/Order.cs
@@ -37,18 +37,33 @@
         public string OrderName { get; set; }
 
         /// <summary>
+        /// 宸ヤ綔寮�濮嬫棩鏈�
+        /// </summary>
+        [Display(Name = "宸ヤ綔寮�濮嬫棩鏈�")]
+        [SugarColumn(ColumnDescription = "宸ヤ綔寮�濮嬫棩鏈�", IsNullable = true)]
+        public DateTime? WordStartTime { get; set; }
+
+        /// <summary>
+        /// 宸ヤ綔缁撴潫鏃堕棿
+        /// </summary>
+        [Display(Name = "宸ヤ綔缁撴潫鏃ユ湡")]
+        [SugarColumn(ColumnDescription = "宸ヤ綔缁撴潫鏃ユ湡", IsNullable = true)]
+        public DateTime? WordEndTime { get; set; }
+
+
+        /// <summary>
         /// 宸ヤ綔寮�濮嬫椂闂�
         /// </summary>
         [Display(Name = "宸ヤ綔寮�濮嬫椂闂�")]
         [SugarColumn(ColumnDescription = "宸ヤ綔寮�濮嬫椂闂�", IsNullable = true)]
-        public DateTime? WordStartTime { get; set; }
+        public DateTime? StartTime { get; set; }
 
         /// <summary>
         /// 宸ヤ綔缁撴潫鏃堕棿
         /// </summary>
         [Display(Name = "宸ヤ綔缁撴潫鏃堕棿")]
         [SugarColumn(ColumnDescription = "宸ヤ綔缁撴潫鏃堕棿", IsNullable = true)]
-        public DateTime? WordEndTime { get; set; }
+        public DateTime? EndTime { get; set; }
 
         /// <summary>
         /// 闇�姹�
diff --git a/cylsg/cylsg.Web.Core/Startup.cs b/cylsg/cylsg.Web.Core/Startup.cs
index 9bda758..17e5e41 100644
--- a/cylsg/cylsg.Web.Core/Startup.cs
+++ b/cylsg/cylsg.Web.Core/Startup.cs
@@ -1,7 +1,9 @@
-锘縰sing cylsg.Core;
+锘縰sing cylsg.Application.Timers;
+using cylsg.Core;
 using cylsg.Web.Core.Handlers;
 using Furion;
 using Furion.VirtualFileServer;
+using InitQ;
 using Microsoft.AspNetCore.Builder;
 using Microsoft.AspNetCore.Hosting;
 using Microsoft.Extensions.DependencyInjection;
@@ -28,6 +30,7 @@
             return DbContext.Instance;
         }
         );
+        services.AddHostedService<TimedBackgroundService>();
         services.AddJsonOptions(options =>
            {
                //鏇存敼杈撳嚭杈撳叆鏋氫妇灞炴�т负 瀛楁鍚�

--
Gitblit v1.9.1