From 72e4a4d81cb1b9776ffb7287e0c5ed67592eda8b Mon Sep 17 00:00:00 2001
From: username@email.com <yzy2002yzy@163.com>
Date: 星期一, 11 十二月 2023 15:20:28 +0800
Subject: [PATCH] 试用期工资计算

---
 zhengcaioa/zhengcaioa/Timer/TimedBackgroundService.cs | 2724 +++++++++++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 2,346 insertions(+), 378 deletions(-)

diff --git a/zhengcaioa/zhengcaioa/Timer/TimedBackgroundService.cs b/zhengcaioa/zhengcaioa/Timer/TimedBackgroundService.cs
index 1444423..80469f1 100644
--- a/zhengcaioa/zhengcaioa/Timer/TimedBackgroundService.cs
+++ b/zhengcaioa/zhengcaioa/Timer/TimedBackgroundService.cs
@@ -48,7 +48,11 @@
         private readonly IDtChannelArticleNewsService _dtChannelArticleNewsService;
         private readonly IConfiguration _configuration;
         private readonly IHttpClientFactory _clientFactory;
-        private readonly IAskService _askService; 
+        private readonly IAskService _askService;
+        private readonly IAdmEvaluateService _admEvaluateService;
+        private readonly IExpertService _expertService;
+        private readonly zhengcaioaContext _context;
+        private readonly zcUserInfoN_dbContext _zcUsercontext;
 
         private readonly decimal jiabangongzibiaozhun = new decimal(21.5);
         public TimedBackgroundService(ILogger<TimedBackgroundService> logger, IServiceScopeFactory factory)
@@ -81,13 +85,17 @@
             _configuration = factory.CreateScope().ServiceProvider.GetRequiredService<IConfiguration>();
             _clientFactory = factory.CreateScope().ServiceProvider.GetRequiredService<IHttpClientFactory>();
             _askService= factory.CreateScope().ServiceProvider.GetRequiredService<IAskService>();
+            _admEvaluateService = factory.CreateScope().ServiceProvider.GetRequiredService<IAdmEvaluateService>();
+            _expertService = factory.CreateScope().ServiceProvider.GetRequiredService<IExpertService>();
+            _context = factory.CreateScope().ServiceProvider.GetRequiredService<zhengcaioaContext>();
+            _zcUsercontext = factory.CreateScope().ServiceProvider.GetRequiredService<zcUserInfoN_dbContext>();
         }
         protected override async Task ExecuteAsync(CancellationToken stoppingToken)
         {
             _logger.LogInformation("MyServiceA is starting.");
 
             //stoppingToken.Register(() => File.Create($"E:\\dotnetCore\\Practice\\Practice\\{DateTime.Now.Millisecond}.txt"));
-
+          
             DateTime datenow = DateTime.Now.Date;
             while (!stoppingToken.IsCancellationRequested)
             {
@@ -130,6 +138,14 @@
                         {
                             jisuangonglinggongzi();
                         }
+
+                        _logger.LogInformation("鎶婁細鍛樼郴缁熷拰oa绯荤粺鎵嬫満鍙风浉鍚岀殑瀹㈡埛鍏宠仈璧锋潵");
+                        this.huiyuanguanlian();
+                        _logger.LogInformation("鎶婁細鍛樼郴缁熷拰oa绯荤粺鎵嬫満鍙风浉鍚岀殑瀹㈡埛鍏宠仈璧锋潵鎵ц缁撴潫");
+
+                        _logger.LogInformation("鎶婅秴杩�90澶╄繕娌℃湁杞寲鐨勬。妗堝鎴风殑涓氬姟缁忕悊褰掍负鏃�");
+                        this.ywjlguiling();
+                        _logger.LogInformation("鎶婅秴杩�90澶╄繕娌℃湁杞寲鐨勬。妗堝鎴风殑涓氬姟缁忕悊褰掍负鏃犳墽琛岀粨鏉�"); 
                     }
                     catch (Exception ex)
                     {
@@ -203,6 +219,167 @@
             return diwutian;
         }
 
+
+        //璁$畻褰撳墠鏃ユ湡鏄惁鏄伐浣滄棩
+        public Boolean shifougongzuori(DateTime workdate)
+        {
+            var admAttendanceRulesDtlDTOs = _attendanceRuleService.GetDtlList("");
+            AdmAttendanceRuleDTO admAttendanceRuleDTO = _attendanceRuleService.Get("");
+            var jiejiari = admAttendanceRulesDtlDTOs.Where(x => x.Name == "jiejiari").ToList();
+            var tiaoxiuri = admAttendanceRulesDtlDTOs.Where(x => x.Name == "tiaoxiuri").ToList();
+            var jiabanri = admAttendanceRulesDtlDTOs.Where(x => x.Name == "jiabanri").ToList();
+            ////鑾峰彇鏈湀鐨勭浜斾釜宸ヤ綔鏃ユ棩鏈熴��
+            //DateTime datemin = new DateTime(DateTime.Now.Year, DateTime.Now.Month, 1);
+            //DateTime datemax = datemin.AddMonths(1);
+            //_logger.LogInformation("datemin" + datemin);
+            //_logger.LogInformation("datemax" + datemax);
+            Boolean shifoushangban = false;
+
+            //鏄惁涓婄彮鏃ユ湡
+            if ((int)workdate.DayOfWeek >= admAttendanceRuleDTO.WeekStart && (int)workdate.DayOfWeek <= admAttendanceRuleDTO.WeekEnd)
+            {
+                //鏄惁鑺傚亣鏃�
+                if (jiejiari.Exists(x => x.ValueStart <= workdate && x.ValueEnd >= workdate))
+                {
+                    shifoushangban = false;
+                }
+                else
+                {
+                    shifoushangban = true;
+                }
+
+            }
+            else
+            {
+                //鏄惁璋冧紤鏃�  璋冧紤鏃ラ渶瑕佷笂鐝�
+                if (tiaoxiuri.Exists(x => x.ValueStart <= workdate && x.ValueEnd >= workdate))
+                {
+                    shifoushangban = true;
+                }
+                //鏄惁鍔犵彮鏃�  鍔犵彮鏃ラ渶瑕佷笂鐝�
+                if (jiabanri.Exists(x => x.ValueStart <= workdate && x.ValueEnd >= workdate))
+                {
+                    shifoushangban = true;
+                }
+            }
+
+          
+            
+            return shifoushangban;
+        }
+
+
+        //鑾峰彇鏃ユ湡鎵�鍦ㄥ懆鐨勮捣姝㈡棩鏈�
+        /// <summary>
+        /// 璁$畻鏈懆璧峰鏃ユ湡锛堟槦鏈熶竴锛�
+        /// </summary>
+        /// <param name="dateTime">璇ュ懆涓换鎰忎竴澶�</param>
+        /// <returns>杩斿洖绀兼嫓涓�鏃ユ湡锛屽悗闈㈢殑鍏蜂綋鏃躲�佸垎銆佺鍜屼紶鍏ュ�肩浉绛�</returns>
+        public  DateTime CalculateFirstDateOfWeek(DateTime dateTime)
+        {
+            int i = dateTime.DayOfWeek - DayOfWeek.Monday;
+            if (i == -1)
+                i = 6;
+            TimeSpan ts = new TimeSpan(i, 0, 0, 0);
+            return dateTime.Subtract(ts);
+        }
+
+        /// <summary>
+        /// 璁$畻鏈懆缁撴潫鏃ユ湡锛堢ぜ鎷滄棩鐨勬棩鏈燂級
+        /// </summary>
+        /// <param name="dateTime"> 璇ュ懆涓换鎰忎竴澶�</param>
+        /// <returns>杩斿洖绀兼嫓鏃ユ棩鏈燂紝鍚庨潰鐨勫叿浣撴椂銆佸垎銆佺鍜屼紶鍏ュ�肩浉绛� </returns>
+        public  DateTime CalculateLastDateOfWeek(DateTime dateTime)
+        {
+            int i = dateTime.DayOfWeek - DayOfWeek.Sunday;
+            if (i != 0) i = 7 - i; // 鍥犱负鏋氫妇鍘熷洜锛孲unday鎺掑湪鏈�鍓嶏紝鐩稿噺闂撮殧瑕佽7鍑忋��
+            TimeSpan ts = new TimeSpan(i, 0, 0, 0);
+            return dateTime.Add(ts);
+        }
+
+
+
+        //鎶婅秴杩�90澶╄繕娌℃湁杞寲鐨勬。妗堝鎴风殑涓氬姟缁忕悊褰掍负鏃�
+        public void ywjlguiling()
+        {
+          var intentionCustomerDTOs  =  _intentionCustomerService.GetList().Where(x=>x.Ywjltime < DateTime.Now.AddDays(-90)).ToList();
+
+            foreach(var intentionCustomerDTO in intentionCustomerDTOs)
+            {
+                intentionCustomerDTO.Ywjl = null;
+                intentionCustomerDTO.Ywjltime = null;
+                _intentionCustomerService.save(intentionCustomerDTO);
+            }
+        }
+
+
+        //鎶婁細鍛樼郴缁熷拰oa绯荤粺鎵嬫満鍙风浉鍚岀殑瀹㈡埛鍏宠仈璧锋潵
+        public void huiyuanguanlian()
+        {
+            var cooperatecustomCustomers = _context.CooperatecustomCustomers.Where(x => x.RecStatus == "A" && x.HuiyuanId == null).ToList();
+            var frameworkUsers = _zcUsercontext.FrameworkUsers.Where(x => x.IsValid == true).ToList();
+            if (cooperatecustomCustomers != null && cooperatecustomCustomers.Count > 0)
+            {
+                foreach (var cooperatecustomCustomer in cooperatecustomCustomers)
+                {
+                    if (!string.IsNullOrEmpty(cooperatecustomCustomer.Tel))
+                    {
+                        var frameworkUser = frameworkUsers.Where(x => x.Itcode == cooperatecustomCustomer.Tel).FirstOrDefault();
+                        if (frameworkUser != null)
+                        {
+                            cooperatecustomCustomer.HuiyuanId = frameworkUser.Id.ToString();
+                            //2023-03-23 娣诲姞鍦ㄨ亴浼佷笟
+                            var customerGuanlianhuiyuan1 = _context.CustomerGuanlianhuiyuans.Where(x => x.Huiyuanid == cooperatecustomCustomer.HuiyuanId && x.Customerid == cooperatecustomCustomer.Id).FirstOrDefault();
+                            if (customerGuanlianhuiyuan1 == null)
+                            {
+                                CustomerGuanlianhuiyuan customerGuanlianhuiyuan = new CustomerGuanlianhuiyuan();
+                                customerGuanlianhuiyuan.Id = Guid.NewGuid().ToString();
+                                customerGuanlianhuiyuan.Huiyuanid = cooperatecustomCustomer.HuiyuanId;
+                                customerGuanlianhuiyuan.Customerid = cooperatecustomCustomer.Id;
+                                customerGuanlianhuiyuan.Customertype = "鍚堜綔瀹㈡埛";
+                                _context.CustomerGuanlianhuiyuans.Add(customerGuanlianhuiyuan);
+                            }
+
+                        }
+                    }
+
+                }
+                _context.SaveChanges();
+            }
+
+
+
+            var intentionCustomers = _context.IntentionCustomers.Where(x => x.RecStatus == "A" && x.HuiyuanId == null).ToList();
+            if (intentionCustomers != null && intentionCustomers.Count > 0)
+            {
+                foreach (var intentionCustomer in intentionCustomers)
+                {
+                    if (!string.IsNullOrEmpty(intentionCustomer.Tel))
+                    {
+                        var frameworkUser = frameworkUsers.Where(x => x.Itcode == intentionCustomer.Tel).FirstOrDefault();
+                        if (frameworkUser != null)
+                        {
+                            intentionCustomer.HuiyuanId = frameworkUser.Id.ToString();
+                            //2023-03-23 娣诲姞鍦ㄨ亴浼佷笟
+                            var customerGuanlianhuiyuan1 = _context.CustomerGuanlianhuiyuans.Where(x => x.Huiyuanid == intentionCustomer.HuiyuanId && x.Customerid == intentionCustomer.Id).FirstOrDefault();
+                            if (customerGuanlianhuiyuan1 == null)
+                            {
+                                CustomerGuanlianhuiyuan customerGuanlianhuiyuan = new CustomerGuanlianhuiyuan();
+                                customerGuanlianhuiyuan.Id = Guid.NewGuid().ToString();
+                                customerGuanlianhuiyuan.Huiyuanid = intentionCustomer.HuiyuanId;
+                                customerGuanlianhuiyuan.Customerid = intentionCustomer.Id;
+                                customerGuanlianhuiyuan.Customertype = "妗f瀹㈡埛";
+                                _context.CustomerGuanlianhuiyuans.Add(customerGuanlianhuiyuan);
+                            }      
+                        }
+                    }
+
+                }
+                _context.SaveChanges();
+            }
+
+        }
+
         //璁$畻鑰冨嫟
         public void jisuankaoqin()
         {
@@ -234,14 +411,20 @@
 
             ResultEntity resultEntity = new ResultEntity();
             resultEntity.Result = false;
-
+            var Month = DateTime.Now.Month - 1;
+            var Year = DateTime.Now.Year;
+            if (Month == 0)
+            {
+                Month = 12;
+                Year = Year - 1;
+            }
             //鏌ヨ鎵�鏈夌殑鏈夋晥浜哄憳
-            List<PltUserDTO> userList = _userService.GetListjisuankaoqin(new DateTime(DateTime.Now.Year, DateTime.Now.Month - 1, 1), new DateTime(DateTime.Now.Year, DateTime.Now.Month - 1, 1).AddMonths(1));//.Where(x => x.UserSn == "yang").ToList();
+            List<PltUserDTO> userList = _userService.GetListjisuankaoqin(new DateTime(Year, Month, 1), new DateTime(Year, Month, 1).AddMonths(1));//.Where(x => x.UserSn == "yang").ToList();
             for (int a = 0; a < userList.Count; a++)
             {
                 _logger.LogInformation("寮�濮嬭绠�" + userList[a].UserName + "鑰冨嫟");
                 //寮�濮嬭绠楄�冨嫟
-                DateTime dateminkaoqin = new DateTime(DateTime.Now.Year, DateTime.Now.Month - 1, 1);
+                DateTime dateminkaoqin = new DateTime(Year, Month, 1);
                 DateTime datemaxkaoqin = dateminkaoqin.AddMonths(1);
                 List<AdmAskLeaveDTO> admAskLeaveDTOs = _signinService.GetAskLeaveByUserId(userList[a].Id);
                 List<AdmAskLeaveOffDTO> admAskLeaveOffDTOs = _signinService.GetAskLeaveOffByUserId(userList[a].Id);
@@ -259,6 +442,7 @@
                     admAttendanceDTO.Qingjia = 0;
                     admAttendanceDTO.Jiaban = 0;
                     admAttendanceDTO.Xiaojia = 0;
+                    admAttendanceDTO.Daixinjia = 0;
                     admAttendanceDTO.Chidao = 0;
                     admAttendanceDTO.Zaotui = 0;
                     admAttendanceDTO.Kuanggong = 0;
@@ -284,6 +468,7 @@
                 decimal Zaotui = 0;
                 decimal Kuanggong = 0;
                 decimal Xiaojia = 0;
+                decimal Daixinjia = 0;
 
                 while (dateminkaoqin < datemaxkaoqin)
                 {
@@ -317,8 +502,8 @@
                             Offdays += 1;
                         }
                     }
-
-                    if(userList[a].Outdate.HasValue && dateminkaoqin >=userList[a].Outdate   )
+                    //绂昏亴褰撳ぉ璁$畻鑰冨嫟
+                    if(userList[a].Zhiwustatus == "D" && userList[a].Outdate.HasValue && dateminkaoqin >userList[a].Outdate   )
                     {
                         dateminkaoqin = dateminkaoqin.AddDays(1);
                         continue;
@@ -337,7 +522,7 @@
                         admSignInDTO = new AdmSignInDTO();
                     }
                     //鏌ヨ璇峰亣   璇峰亣鏃堕棿涓嶈兘閲嶅彔
-                    List<AdmAskLeaveDTO> admAskLeaveDTOMin = admAskLeaveDTOs.Where(x =>x.Lavetype != "2" &&  x.StratTime < dateminkaoqin.AddDays(1) && x.EndTime > dateminkaoqin).OrderByDescending(x=>x.Createtime).ToList();
+                    List<AdmAskLeaveDTO> admAskLeaveDTOMin = admAskLeaveDTOs.Where(x => x.Lavetype != "2" && x.StratTime < dateminkaoqin.AddDays(1) && x.EndTime > dateminkaoqin).OrderByDescending(x=>x.Createtime).ToList();
                     //鏌ヨ閿�鍋�   閿�鍋囨椂闂翠笉鑳介噸鍙�
                     List<AdmAskLeaveOffDTO> admAskLeaveOffDTOMin = admAskLeaveOffDTOs.Where(x => x.StratTime < dateminkaoqin.AddDays(1) && x.EndTime > dateminkaoqin).OrderByDescending(x => x.Createtime).ToList();
                    
@@ -371,6 +556,8 @@
                     decimal Kuanggongtianshu = 0;
                     decimal dangtianqingjia = 0;
                     decimal dangtianxiaojia = 0;
+                    decimal dangtiandaixinjia = 0;
+
                     string Iswork = "D";
                     if (iswork)
                     {
@@ -436,15 +623,24 @@
                                 }
                                 else
                                 {
-                                    if (dateBiJiaoDTOs[i].StartTime > dateBiJiaoDTOs[i - 1].EndTime)
-                                    {
-                                        kuanggong = true;
-                                        break;
-                                    }
-                                    else if (dateBiJiaoDTOs[i].EndTime > dateBiJiaoDTOs[i - 1].EndTime)
+                                    //if (dateBiJiaoDTOs[i].StartTime > dateBiJiaoDTOs[i - 1].EndTime)
+                                    //{
+                                    //    //kuanggong = true;
+                                    //    break;
+                                    //}
+                                    //else 
+                                    if (dateBiJiaoDTOs[i].EndTime > dateBiJiaoDTOs[i - 1].EndTime)
                                     {
                                         endttime = dateBiJiaoDTOs[i].EndTime;
                                     }
+                                    if (!starttime.HasValue)
+                                    {
+                                        starttime = dateBiJiaoDTOs[i].StartTime;
+                                    }
+                                }
+                                if (endttime >= StratTimeWorkingEnd && starttime.HasValue)
+                                {
+                                    break;
                                 }
                             }
                             if (kuanggong)
@@ -553,15 +749,24 @@
                                 }
                                 else
                                 {
-                                    if (dateBiJiaoDTOs[i].StartTime > dateBiJiaoDTOs[i - 1].EndTime)
-                                    {
-                                        kuanggong = true;
-                                        break;
-                                    }
-                                    else if (dateBiJiaoDTOs[i].EndTime > dateBiJiaoDTOs[i - 1].EndTime)
+                                    //if (dateBiJiaoDTOs[i].StartTime > dateBiJiaoDTOs[i - 1].EndTime)
+                                    //{
+                                    //    //kuanggong = true;
+                                    //    break;
+                                    //}
+                                    //else 
+                                    if (dateBiJiaoDTOs[i].EndTime > dateBiJiaoDTOs[i - 1].EndTime)
                                     {
                                         endttime = dateBiJiaoDTOs[i].EndTime;
                                     }
+                                    if (!starttime.HasValue)
+                                    {
+                                        starttime = dateBiJiaoDTOs[i].StartTime;
+                                    }
+                                }
+                                if (endttime >= StratTimeOffworkEnd && starttime.HasValue)
+                                {
+                                    break;
                                 }
                             }
                             if (kuanggong)
@@ -617,7 +822,7 @@
                         //璁$畻褰撳ぉ璇峰亣
                         List<DateBiJiaoDTO> qingjias = new List<DateBiJiaoDTO>();
 
-                        var feichuqinjia = admAskLeaveDTOMin.Where(x => x.Lavetype != "4").ToList();
+                        var feichuqinjia = admAskLeaveDTOMin.Where(x => x.Lavetype != "4" && x.Lavetype != "7" && x.Lavetype != "3" && x.Lavetype != "9").ToList();
                         foreach (var admAskLeave in feichuqinjia)
                         {
                             
@@ -678,6 +883,63 @@
                         }
 
                         Qingjia += dangtianqingjia;
+
+
+
+                        //璁$畻褰撳ぉ甯﹁柂鍋�
+                        List<DateBiJiaoDTO> daixinjias = new List<DateBiJiaoDTO>();
+
+                        var chauxndaixinjias = admAskLeaveDTOMin.Where(x => x.Lavetype == "4" || x.Lavetype == "7" || x.Lavetype == "3" || x.Lavetype == "9").ToList();
+                        foreach (var admAskLeave in chauxndaixinjias)
+                        {
+
+                            DateBiJiaoDTO dateBiJiaoDTO = new DateBiJiaoDTO();
+                            dateBiJiaoDTO.StartTime = admAskLeave.StratTime;
+                            dateBiJiaoDTO.EndTime = admAskLeave.EndTime;
+                            daixinjias.Add(dateBiJiaoDTO);
+
+                        }
+
+                        foreach (var daixinjia in daixinjias)
+                        {
+                            if (daixinjia.StartTime < StratTimeWorkingStart)
+                            {
+                                daixinjia.StartTime = StratTimeWorkingStart;
+                            }
+                            if (daixinjia.StartTime > StratTimeWorkingEnd && daixinjia.StartTime < StratTimeOffworkStart)
+                            {
+                                daixinjia.StartTime = StratTimeOffworkStart;
+                            }
+
+
+                            if (daixinjia.EndTime > StratTimeWorkingEnd && daixinjia.EndTime < StratTimeOffworkStart)
+                            {
+                                daixinjia.EndTime = StratTimeWorkingEnd;
+                            }
+
+
+                            if (daixinjia.EndTime > StratTimeOffworkEnd)
+                            {
+                                daixinjia.EndTime = StratTimeOffworkEnd;
+                            }
+                            TimeSpan daixinjiashiijan = daixinjia.EndTime.Value.Subtract(daixinjia.StartTime.Value);
+                            if (daixinjia.StartTime <= StratTimeWorkingEnd && daixinjia.EndTime >= StratTimeOffworkStart)
+                            {
+                                TimeSpan wuxiushijian = StratTimeOffworkStart.Subtract(StratTimeWorkingEnd);
+                                dangtiandaixinjia += Math.Round(((decimal)(daixinjiashiijan.Hours * 60 + daixinjiashiijan.Minutes - wuxiushijian.Hours * 60 - wuxiushijian.Minutes)) / ((decimal)shangbanshijian), 2);
+                            }
+                            else
+                            {
+                                dangtiandaixinjia += Math.Round(((decimal)(daixinjiashiijan.Hours * 60 + daixinjiashiijan.Minutes)) / ((decimal)shangbanshijian), 2);
+                            }
+
+
+
+                        }
+
+                        Daixinjia += dangtiandaixinjia;
+
+
                         //璁$畻褰撳ぉ鍑哄嫟澶╂暟
                         Shijichuqin += (1 - Kuanggongtianshu - dangtianqingjia);
 
@@ -754,10 +1016,10 @@
                                 {
                                     jiabanshijian = admAskovertimeDTO.Overtime.Value;
                                 }
-
-
-
-
+                                if (jiabanshijian > new decimal(shangbanshijian) / 60)
+                                {
+                                    jiabanshijian = new decimal(shangbanshijian) /60;
+                                }
                                 Jiaban += Math.Round(jiabanshijian * 60 / shangbanshijian, 2);
                             }
                             
@@ -829,14 +1091,19 @@
                                     }
                                     else
                                     {
-                                        if (dateBiJiaoDTOs[i].StartTime > dateBiJiaoDTOs[i - 1].EndTime)
-                                        {
-                                            kuanggong = true;
-                                            break;
-                                        }
-                                        else if (dateBiJiaoDTOs[i].EndTime > dateBiJiaoDTOs[i - 1].EndTime)
+                                        //if (dateBiJiaoDTOs[i].StartTime > dateBiJiaoDTOs[i - 1].EndTime)
+                                        //{
+                                        //    //kuanggong = true;
+                                        //    break;
+                                        //}
+                                        //else 
+                                        if (dateBiJiaoDTOs[i].EndTime > dateBiJiaoDTOs[i - 1].EndTime)
                                         {
                                             endttime = dateBiJiaoDTOs[i].EndTime;
+                                        }
+                                        if (!starttime.HasValue)
+                                        {
+                                            starttime = dateBiJiaoDTOs[i].StartTime;
                                         }
                                     }
                                 }
@@ -946,14 +1213,19 @@
                                     }
                                     else
                                     {
-                                        if (dateBiJiaoDTOs[i].StartTime > dateBiJiaoDTOs[i - 1].EndTime)
-                                        {
-                                            kuanggong = true;
-                                            break;
-                                        }
-                                        else if (dateBiJiaoDTOs[i].EndTime > dateBiJiaoDTOs[i - 1].EndTime)
+                                        //if (dateBiJiaoDTOs[i].StartTime > dateBiJiaoDTOs[i - 1].EndTime)
+                                        //{
+                                        //    //kuanggong = true;
+                                        //    break;
+                                        //}
+                                        //else 
+                                        if (dateBiJiaoDTOs[i].EndTime > dateBiJiaoDTOs[i - 1].EndTime)
                                         {
                                             endttime = dateBiJiaoDTOs[i].EndTime;
+                                        }
+                                        if (!starttime.HasValue)
+                                        {
+                                            starttime = dateBiJiaoDTOs[i].StartTime;
                                         }
                                     }
                                 }
@@ -1010,7 +1282,7 @@
                             //璁$畻褰撳ぉ璇峰亣
                             List<DateBiJiaoDTO> qingjias = new List<DateBiJiaoDTO>();
 
-                            var feichuqinjia = admAskLeaveDTOMin.Where(x => x.Lavetype != "4").ToList();
+                            var feichuqinjia = admAskLeaveDTOMin.Where(x => x.Lavetype != "4" && x.Lavetype != "7" && x.Lavetype != "3" && x.Lavetype != "9").ToList();
                             foreach (var admAskLeave in feichuqinjia)
                             {
 
@@ -1071,6 +1343,64 @@
                             }
 
                             Qingjia += dangtianqingjia;
+
+
+
+                            //璁$畻褰撳ぉ甯﹁柂鍋�
+                            List<DateBiJiaoDTO> daixinjias = new List<DateBiJiaoDTO>();
+
+                            var chauxndaixinjias = admAskLeaveDTOMin.Where(x => x.Lavetype == "4" || x.Lavetype == "7" || x.Lavetype == "3" || x.Lavetype == "9").ToList();
+                            foreach (var admAskLeave in chauxndaixinjias)
+                            {
+
+                                DateBiJiaoDTO dateBiJiaoDTO = new DateBiJiaoDTO();
+                                dateBiJiaoDTO.StartTime = admAskLeave.StratTime;
+                                dateBiJiaoDTO.EndTime = admAskLeave.EndTime;
+                                daixinjias.Add(dateBiJiaoDTO);
+
+                            }
+
+                            foreach (var daixinjia in daixinjias)
+                            {
+                                if (daixinjia.StartTime < StratTimeWorkingStart)
+                                {
+                                    daixinjia.StartTime = StratTimeWorkingStart;
+                                }
+                                if (daixinjia.StartTime > StratTimeWorkingEnd && daixinjia.StartTime < StratTimeOffworkStart)
+                                {
+                                    daixinjia.StartTime = StratTimeOffworkStart;
+                                }
+
+
+                                if (daixinjia.EndTime > StratTimeWorkingEnd && daixinjia.EndTime < StratTimeOffworkStart)
+                                {
+                                    daixinjia.EndTime = StratTimeWorkingEnd;
+                                }
+
+
+                                if (daixinjia.EndTime > StratTimeOffworkEnd)
+                                {
+                                    daixinjia.EndTime = StratTimeOffworkEnd;
+                                }
+                                TimeSpan daixinjiashiijan = daixinjia.EndTime.Value.Subtract(daixinjia.StartTime.Value);
+                                if (daixinjia.StartTime <= StratTimeWorkingEnd && daixinjia.EndTime >= StratTimeOffworkStart)
+                                {
+                                    TimeSpan wuxiushijian = StratTimeOffworkStart.Subtract(StratTimeWorkingEnd);
+                                    dangtiandaixinjia += Math.Round(((decimal)(daixinjiashiijan.Hours * 60 + daixinjiashiijan.Minutes - wuxiushijian.Hours * 60 - wuxiushijian.Minutes)) / ((decimal)shangbanshijian), 2);
+                                }
+                                else
+                                {
+                                    dangtiandaixinjia += Math.Round(((decimal)(daixinjiashiijan.Hours * 60 + daixinjiashiijan.Minutes)) / ((decimal)shangbanshijian), 2);
+                                }
+
+
+
+                            }
+
+                            Daixinjia += dangtiandaixinjia;
+
+
+
                             //璁$畻褰撳ぉ鍑哄嫟澶╂暟
                             Jiaban += (1 - Kuanggongtianshu - dangtianqingjia);
 
@@ -1151,10 +1481,10 @@
                                 {
                                     jiabanshijian = admAskovertimeDTO.Overtime.Value;
                                 }
-
-
-
-
+                                if (jiabanshijian > new decimal(shangbanshijian) / 60)
+                                {
+                                    jiabanshijian = new decimal(shangbanshijian) / 60;
+                                }
                                 Jiaban += Math.Round(jiabanshijian * 60 / shangbanshijian, 2);
                             }
                         }
@@ -1182,7 +1512,7 @@
                         admAttendanceDtlDTO.OvertimeOut = admSignInDTO.OvertimeOut;
                         admAttendanceDtlDTO.Qingjia = dangtianqingjia;
                         admAttendanceDtlDTO.Xiaojia = dangtianxiaojia;
-                       
+                        admAttendanceDtlDTO.Daixinjia = dangtiandaixinjia;
 
 
 
@@ -1218,6 +1548,7 @@
                         admAttendanceDtlDTO.OvertimeIn = admSignInDTO.OvertimeIn;
                         admAttendanceDtlDTO.OvertimeOut = admSignInDTO.OvertimeOut;
                         admAttendanceDtlDTO.Qingjia = dangtianqingjia;
+                        admAttendanceDtlDTO.Daixinjia = dangtiandaixinjia;
                         admAttendanceDtlDTO.Xiaojia = dangtianxiaojia;
                         
 
@@ -1269,6 +1600,7 @@
 
 
                 admAttendanceDTO.Qingjia = Qingjia;
+                admAttendanceDTO.Daixinjia = Daixinjia;
                 admAttendanceDTO.Xiaojia = Xiaojia;
                 admAttendanceDTO.Chidao = Chidao;
                 admAttendanceDTO.Islock = "A";
@@ -1286,8 +1618,15 @@
         //璁$畻宸ヨ祫
         public async Task jisuangongziAsync()
         {
+            var Month = DateTime.Now.Month - 1;
+            var Year = DateTime.Now.Year;
+            if (Month == 0)
+            {
+                Month = 12;
+                Year = Year - 1;
+            }
             //鏌ヨ鎵�鏈夌殑鏈夋晥浜哄憳
-            DateTime dateminkaoqin = new DateTime(DateTime.Now.Year, DateTime.Now.Month - 1, 1);
+            DateTime dateminkaoqin = new DateTime(Year, Month, 1);
             DateTime datemaxkaoqin = dateminkaoqin.AddMonths(1);
             List<PltUserDTO> userList = _userService.GetListjisuankaoqin(dateminkaoqin, datemaxkaoqin);//.Where(x => x.UserSn == "yang").ToList();
             List<HrJibengongziDTO> hrJibengongziDTOs = _JibengongziService.GetList().Where(x=>  x.Effecttime < datemaxkaoqin).ToList();
@@ -1336,18 +1675,27 @@
                 searchEntity.AttendanceId = admAttendanceDTO.Id;
                 List<AdmAttendanceDtlDTO> admAttendanceDtlDTOs = _admAttendanceDtlService.GetList(searchEntity).OrderBy(x => x.SgninDate).ToList();
 
+                //鏌ヨ鏄惁鏈変笉绉拌亴鐨勫伐浣滆�冭瘎
+               var admEvaluateDTOs = _admEvaluateService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin).Where(x=>x.EvaluateValue == "03").ToList();
                 //褰撴湀鍑哄嫟鐜�
                 decimal chuqinlv = Math.Round(admAttendanceDTO.Shijichuqin / admAttendanceDTO.Yingchuqin,4); 
 
                 //鏌ヨ褰撳墠鍛樺伐鑱屽姟鐨勫熀鏈伐璧勯厤缃�
 
                var hrJibengongzi = hrJibengongziDTOs.Where(x=>x.PostId == userList[i].HrPosition ).OrderByDescending(x=>x.Effecttime).FirstOrDefault();
-
+               
                 if (hrJibengongzi == null)
                 {
                     _logger.LogInformation(userList[i].UserName + ": 鑱屽姟鎵�灞炶祫鏈伐璧勪负绌�");
                     continue;
                 }
+                var shebaoDTO = _JibengongziService.GetListShebao().FirstOrDefault();
+                if (shebaoDTO == null)
+                {
+                    _logger.LogInformation(userList[i].UserName + ": 绀句繚缁存姢涓虹┖");
+                    continue;
+                }
+             
                 hrSalaryDTO.Jibengongzi = Math.Round( hrJibengongzi.Jibengongzi.Value * chuqinlv, 2);
                 hrSalaryDTO.Baomifei = Math.Round(hrJibengongzi.Baomifei.Value * chuqinlv, 2);
                 //鏄惁鍦ㄨ瘯鐢ㄦ湡
@@ -1356,22 +1704,46 @@
                 {
                     geshuiqizheng = userList[i].geshuiqizheng.Value;
                 }
-                var Shebaodanwei = hrJibengongzi.Shebaodanwei.HasValue ? hrJibengongzi.Shebaodanwei.Value : 0;
-                var Shebaogeren = hrJibengongzi.Shebaogeren.HasValue ? hrJibengongzi.Shebaogeren.Value : 0;
+                var Shebaodanwei = shebaoDTO.Shebaodanwei.HasValue ? shebaoDTO.Shebaodanwei.Value : 0;
+                var Shebaogeren = shebaoDTO.Shebaogeren.HasValue ? shebaoDTO.Shebaogeren.Value : 0;
                 decimal yingnashuie = 0;
                 hrSalaryDTO.Queqin = 0;
+                hrSalaryDTO.Fakuan = 0;
                 hrSalaryDTO.Gongzuobutie = 0;
                 hrSalaryDTO.Jiabangongzi = 0;
                 decimal shiyongqichuqintianshu = 0;
                 decimal shiyongqichuqinlv = 0;
-                
-                if (userList[i].ShiyongDate.HasValue && userList[i].ShiyongDateEnd.HasValue && dateminkaoqin>= userList[i].ShiyongDate.Value && dateminkaoqin <= userList[i].ShiyongDateEnd.Value)
+                decimal yingfaheji = 0;
+
+
+                decimal BasicPrice = 0;
+                if (!decimal.TryParse(userList[i].BasicPrice, out BasicPrice))
                 {
+                    _logger.LogInformation(userList[i].UserName + ": 鍛樺伐娌℃湁缁存姢宸ヨ祫");
+                    continue;
+                }
+
+
+
+                if (userList[i].ShiyongDate.HasValue && userList[i].ShiyongDateEnd.HasValue && datemaxkaoqin> userList[i].ShiyongDate.Value && dateminkaoqin <= userList[i].ShiyongDateEnd.Value)
+                {
+                    hrSalaryDTO.Jibengongzi = Math.Round(hrJibengongzi.Jibengongzi.Value * chuqinlv * new decimal(0.8), 2) ;
+                    hrSalaryDTO.Baomifei = Math.Round(hrJibengongzi.Baomifei.Value * chuqinlv * new decimal(0.8), 2) ;
+                    decimal ShiyongPrice = 0;
                     if (!userList[i].ShiyongPrice.HasValue)
                     {
-                        _logger.LogInformation(userList[i].UserName + ": 鍛樺伐澶勪簬璇曠敤鏈燂紝浣嗘槸璇曠敤鏈熷伐璧勪负绌�");
-                        continue;
+                        ShiyongPrice = BasicPrice * new decimal(0.8);
+                        _logger.LogInformation(userList[i].UserName + ": 鍛樺伐澶勪簬璇曠敤鏈燂紝浣嗘槸璇曠敤鏈熷伐璧勪负绌�,瀹氫负姝e紡宸ヨ祫鐨�0.8鍊�");
+
                     }
+                    else
+                    {
+                        ShiyongPrice = userList[i].ShiyongPrice.Value;
+                    }
+                    //鏌ヨ鏄惁鏈変笉绉拌亴鐨勫伐浣滆�冭瘎
+                    var admEvaluateDTOsshiyongqi = _admEvaluateService.GetListsalary(userList[i].Id, dateminkaoqin, userList[i].ShiyongDateEnd.Value.AddDays(1)).Where(x => x.EvaluateValue == "03").ToList();
+
+
                     //璇曠敤鏈熺殑鍑哄嫟鐜�
                     shiyongqichuqinlv = chuqinlv;
                     if(userList[i].ShiyongDateEnd.Value< datemaxkaoqin.AddDays(-1))
@@ -1384,7 +1756,7 @@
                                     shiyongqichuqintianshu += (1 - admAttendanceDtlDTO.Qingjia - admAttendanceDtlDTO.Kuanggongtianshu);
                                     if (admAttendanceDtlDTO.Kuanggongtianshu > 0)
                                     {
-                                        var queqingkoukuan = Math.Round(userList[i].ShiyongPrice.Value / jiabangongzibiaozhun * admAttendanceDtlDTO.Kuanggongtianshu * (admAttendanceRuleDTO.AbsenteeismPayment1 - 1), 2);
+                                        var queqingkoukuan = Math.Round(ShiyongPrice / jiabangongzibiaozhun * admAttendanceDtlDTO.Kuanggongtianshu * (admAttendanceRuleDTO.AbsenteeismPayment1 - 1), 2);
                                         if (queqingkoukuan > 0)
                                         {
                                             hrSalaryDTO.Queqin += queqingkoukuan;
@@ -1392,44 +1764,59 @@
                                     }
                             }
                         }
+
+                      
+
+
                         shiyongqichuqinlv = Math.Round(shiyongqichuqintianshu / admAttendanceDTO.Yingchuqin, 4);
+
+                        //宸ヤ綔璇勪环涓嶅悎鏍肩綒娆�
+                        hrSalaryDTO.Fakuan += Math.Round(ShiyongPrice * admEvaluateDTOsshiyongqi.Count / admAttendanceDTO.Yingchuqin + BasicPrice * (admEvaluateDTOs.Count - admEvaluateDTOsshiyongqi.Count) / admAttendanceDTO.Yingchuqin, 2);
+                        
                     }
                     else
                     {
                         if (admAttendanceDTO.Kuanggong > 0)
                         {
-                            var queqingkoukuan = Math.Round(userList[i].ShiyongPrice.Value / jiabangongzibiaozhun * admAttendanceDTO.Kuanggong * (admAttendanceRuleDTO.AbsenteeismPayment1 - 1), 2);
+                            var queqingkoukuan = Math.Round(ShiyongPrice / jiabangongzibiaozhun * admAttendanceDTO.Kuanggong * (admAttendanceRuleDTO.AbsenteeismPayment1 - 1), 2);
                             if (queqingkoukuan > 0)
                             {
                                 hrSalaryDTO.Queqin += queqingkoukuan;
                             }
                         }
-                        hrSalaryDTO.Jiabangongzi += Math.Round((admAttendanceDTO.Jiaban / jiabangongzibiaozhun) * userList[i].ShiyongPrice.Value, 2);
+                        if (hrJibengongzi.Jiabangongzi.HasValue)
+                        {
+                            hrSalaryDTO.Jiabangongzi += Math.Round(admAttendanceDTO.Jiaban * hrJibengongzi.Jiabangongzi.Value, 2);  //(admAttendanceDTO.Jiaban / jiabangongzibiaozhun) * userList[i].ShiyongPrice.Value
+                        }
+
+                       
+
+                        //宸ヤ綔璇勪环涓嶅悎鏍肩綒娆�
+                        hrSalaryDTO.Fakuan += Math.Round(ShiyongPrice * admEvaluateDTOs.Count / admAttendanceDTO.Yingchuqin, 2);
                     }
 
 
 
 
-                    hrSalaryDTO.Gongzuobutie += Math.Round( (userList[i].ShiyongPrice.Value - hrJibengongzi.Baomifei.Value- hrJibengongzi.Jibengongzi.Value ) * shiyongqichuqinlv, 2);
+                    hrSalaryDTO.Gongzuobutie += Math.Round( (ShiyongPrice * shiyongqichuqinlv - hrSalaryDTO.Baomifei.Value- hrSalaryDTO.Jibengongzi.Value ) , 2);
 
-                   
 
-                    //yingnashuie = userList[i].ShiyongPrice.Value - Shebaogeren - geshuiqizheng;
+
+                    
 
 
 
 
                 }
+                else
+                {
+                    //宸ヤ綔璇勪环缃氭
+                    hrSalaryDTO.Fakuan += Math.Round(BasicPrice * admEvaluateDTOs.Count/ admAttendanceDTO.Yingchuqin , 2);
+                }
                 
 
                 if(true)
                 {
-                    decimal BasicPrice = 0;
-                    if(!decimal.TryParse(userList[i].BasicPrice,out BasicPrice))
-                    {
-                        _logger.LogInformation(userList[i].UserName + ": 鍛樺伐娌℃湁缁存姢宸ヨ祫");
-                        continue;
-                    }
                     //杞鍚庣殑鍑哄嫟鐜�
                     decimal zhuanzhengchuqinlv = chuqinlv- shiyongqichuqinlv;
                     if (userList[i].ShiyongDate.HasValue && userList[i].ShiyongDateEnd.HasValue && userList[i].ShiyongDateEnd.Value >= dateminkaoqin && userList[i].ShiyongDateEnd.Value <= datemaxkaoqin.AddDays(-1))
@@ -1480,16 +1867,26 @@
                                 hrSalaryDTO.Queqin += queqingkoukuan;
                             }
                         }
-                        hrSalaryDTO.Jiabangongzi += Math.Round((admAttendanceDTO.Jiaban / jiabangongzibiaozhun) * BasicPrice, 2);
+                        if (hrJibengongzi.Jiabangongzi.HasValue)
+                        {
+                            hrSalaryDTO.Jiabangongzi += Math.Round(admAttendanceDTO.Jiaban * hrJibengongzi.Jiabangongzi.Value, 2);  //   hrSalaryDTO.Jiabangongzi += Math.Round((admAttendanceDTO.Jiaban / jiabangongzibiaozhun) * BasicPrice, 2);
+                        }
+                     
+                    }
+
+                    if(shiyongqichuqinlv>0 ||  hrSalaryDTO.Gongzuobutie != new decimal(0))
+                    {
+                        hrSalaryDTO.Gongzuobutie += Math.Round((BasicPrice * zhuanzhengchuqinlv ), 2);
+                    }
+                    else
+                    {
+                        hrSalaryDTO.Gongzuobutie += Math.Round((BasicPrice * zhuanzhengchuqinlv - hrSalaryDTO.Baomifei.Value - hrSalaryDTO.Jibengongzi.Value), 2);
                     }
 
 
-
-                    hrSalaryDTO.Gongzuobutie += Math.Round((BasicPrice - hrJibengongzi.Baomifei.Value - hrJibengongzi.Jibengongzi.Value) * zhuanzhengchuqinlv, 2);
-
                   
 
-                    //yingnashuie = BasicPrice - Shebaogeren - geshuiqizheng;
+                   
 
                     
                 }
@@ -1719,9 +2116,17 @@
                     hrSalaryDTO.Dianhuafei = SimCost.bill_amount;
                 }
               
+                if(admAttendanceDTO.Shijichuqin>=admAttendanceDTO.Yingchuqin
+                    && hrSalaryDTO.Queqin <=0)
+                {
+                    hrSalaryDTO.Quanqinjiang = hrJibengongzi.Quanqingjiang;
+                }
+                else
+                {
+                    hrSalaryDTO.Quanqinjiang = 0;
+                }
 
-
-                hrSalaryDTO.Quanqinjiang = hrJibengongzi.Quanqingjiang;
+               
                 if ("A".Equals(userList[i].Istravelsubsidy))
                 {
                     hrSalaryDTO.Jiaotngbutie = hrJibengongzi.Jiaotongbutie;
@@ -1733,7 +2138,6 @@
 
 
 
-                hrSalaryDTO.Fakuan = 0;
                 //宸ヤ綔瀹夋帓缃氭
                 List<AdmMemoBookDTO> admMemoBookDTOs =  _DailyManageService.GetRemindsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin,"2");
                 if (admMemoBookDTOs.Count > 0)
@@ -1773,12 +2177,12 @@
                     //var feijijiandengji = fiPiecerateDTOs.Where(x => x.Standard == "A");
                     //var  jijiandengji =    fiPiecerateDTOs.Where(x => x.Standard == "A");
 
-                    #region 閲囪喘椤圭洰褰曞叆
+                    #region 閲囪喘鍏憡褰曞叆
 
-                    var projectDTOsyue = _projectService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
-                    if (projectDTOsyue!=null && projectDTOsyue.Count > 0 )
+                    var caigougonggaoDTOsyue = _projectService.GetcaigougonggaoListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    if (caigougonggaoDTOsyue != null && caigougonggaoDTOsyue.Count > 0)
                     {
-                        var jijianidddd = fiPiecerateDTOs.Where(x =>  x.Project == "閲囪喘椤圭洰褰曞叆").FirstOrDefault();
+                        var jijianidddd = fiPiecerateDTOs.Where(x => x.Project == "閲囪喘鍏憡褰曞叆").FirstOrDefault();
                         if (jijianidddd != null)
                         {
                             var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianidddd.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
@@ -1786,16 +2190,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while(kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = projectDTOsyue.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var caigougonggaoDTOsri = caigougonggaoDTOsyue.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = caigougonggaoDTOsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
+                                           
                                         }
-
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = caigougonggaoDTOsyue.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -1803,7 +2234,7 @@
                                     decimal renwujishu = jixiaotichengfangan.Renwu.Value;
                                     if (jixiaotichengfangan.Tichengstandard == "01")
                                     {
-                                        decimal youxiaojijian = projectDTOsyue.Count - renwujishu;
+                                        decimal youxiaojijian = caigougonggaoDTOsyue.Count - renwujishu;
                                         if (youxiaojijian > 0)
                                         {
                                             hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
@@ -1817,8 +2248,85 @@
                     }
                     #endregion
 
+                    #region 閲囪喘椤圭洰褰曞叆
+
+                    var projectDTOsyue = _projectService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    var zhengfuprojectDTOsyue = _projectService.GetListsalaryzhengfu(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    if ((projectDTOsyue!=null && projectDTOsyue.Count > 0 ) || (zhengfuprojectDTOsyue != null && zhengfuprojectDTOsyue.Count > 0))
+                    {
+                        var jijianidddd = fiPiecerateDTOs.Where(x =>  x.Project == "閲囪喘椤圭洰褰曞叆").FirstOrDefault();
+                        if (jijianidddd != null)
+                        {
+                            var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianidddd.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
+                            if (jixiaotichengfangan != null && jixiaotichengfangan.Ticheng.HasValue && jixiaotichengfangan.Renwu.HasValue)
+                            {
+                                if (jixiaotichengfangan.Renwustandard == "01")
+                                {
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
+                                    {
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var projectDTOri = projectDTOsyue.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var zhengfuprojectDTOri = zhengfuprojectDTOsyue.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList();
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = projectDTOri.Count + zhengfuprojectDTOri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
+                                    }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = projectDTOsyue.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
+
+                                }
+                                else if (jixiaotichengfangan.Renwustandard == "02")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = projectDTOsyue.Count + zhengfuprojectDTOsyue.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+
+
+                 
+
                     #region 瀹㈡埛璧勬枡褰曞叆
-                    
+
                     var _intentionCustomerDTOs = _intentionCustomerService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
                     if (_intentionCustomerDTOs!=null && _intentionCustomerDTOs.Count > 0)
                     {
@@ -1830,16 +2338,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = _intentionCustomerDTOs.Count   - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var _intentionCustomerDTOsri = _intentionCustomerDTOs.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = _intentionCustomerDTOsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = _intentionCustomerDTOs.Count   - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -1876,16 +2411,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = groupTopicDTOs.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var groupTopicDTOsri = groupTopicDTOs.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = groupTopicDTOsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = groupTopicDTOs.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -1920,16 +2482,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = intentionVisitDTOs.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var intentionVisitDTOsri = intentionVisitDTOs.Where(x => x.Vistime >= kaishijisuan && x.Vistime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = intentionVisitDTOsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = intentionVisitDTOs.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -1964,16 +2553,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = duanxinsyue.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var duanxinsri = duanxinsyue.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = duanxinsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = duanxinsyue.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -1995,6 +2611,80 @@
                     }
                     #endregion
 
+
+                    #region 娣诲姞寰俊瀹㈡埛
+                    TongjiBaoBiaoDTO weixnDTO = new TongjiBaoBiaoDTO();
+                    weixnDTO.gongzuo = "娣诲姞寰俊瀹㈡埛";
+                    //鏈湀鏁伴噺
+                    var cooperweixinDTOsyue = _cooperatecustomCustomerService.GetListsalaryweixin(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    var intentionweixinDTOsyue = _intentionCustomerService.GetListsalaryweixin(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    var jijianiweixn = fiPiecerateDTOs.Where(x => x.Project == "娣诲姞寰俊瀹㈡埛").FirstOrDefault();
+                    if (jijianiweixn != null)
+                    {
+                        var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianiweixn.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
+                        if (jixiaotichengfangan != null && jixiaotichengfangan.Ticheng.HasValue && jixiaotichengfangan.Renwu.HasValue)
+                        {
+                            if (jixiaotichengfangan.Renwustandard == "01")
+                            {
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
+                                {
+                                    try
+                                    {
+                                        var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                        if (gongzuoshijian)
+                                        {
+                                            var cooperweixinDTOsri = cooperweixinDTOsyue.Where(x => x.Weixintime >= kaishijisuan && x.Weixintime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            var intentionweixinDTOsri = intentionweixinDTOsyue.Where(x => x.Weixintime >= kaishijisuan && x.Weixintime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            if (jixiaotichengfangan.Tichengstandard == "01")
+                                            {
+                                                decimal youxiaojijian = cooperweixinDTOsri.Count + intentionweixinDTOsri.Count - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                }
+                                            }
+                                        }
+
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = kaishijisuan.AddDays(1);
+                                }
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //if (jixiaotichengfangan.Tichengstandard == "01")
+                                //{
+                                //    decimal youxiaojijian = cooperweixinDTOsyue.Count+ intentionweixinDTOsyue.Count - renwujishu;
+                                //    if (youxiaojijian > 0)
+                                //    {
+                                //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                //    }
+
+                                //}
+
+                            }
+                            else if (jixiaotichengfangan.Renwustandard == "02")
+                            {
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                {
+                                    decimal youxiaojijian = cooperweixinDTOsyue.Count + intentionweixinDTOsyue.Count - renwujishu;
+                                    if (youxiaojijian > 0)
+                                    {
+                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    }
+
+                                }
+                            }
+                        }
+
+                    }
+
+                    #endregion
+
                     #region 缇ゅ彂閭欢
 
                     var youjiansyue = _cusFangwenjiluService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin).Where(x => x.Fasongfangshi == "02").ToList();
@@ -2008,16 +2698,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = youjiansyue.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var youjiansri = youjiansyue.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = youjiansri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = youjiansyue.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2052,16 +2769,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = yixiangsyue.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var yixiangsri = yixiangsyue.Where(x => x.Yixiangtime >= kaishijisuan && x.Yixiangtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = yixiangsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = yixiangsyue.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2141,16 +2885,44 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = zhucehuiyuansyue.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var zhucehuiyuansyueri = zhucehuiyuansyue.Where(x => x.CreatTime >= kaishijisuan && x.CreatTime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = zhucehuiyuansyueri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = zhucehuiyuansyue.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2186,16 +2958,44 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = qianyueDTOsyue.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var qianyueDTOsri = qianyueDTOsyue.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = qianyueDTOsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = qianyueDTOsyue.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2231,16 +3031,44 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = intentionVisitDTOsshangmen.Count + cooperVisitDTOs.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperVisitDTOsri = cooperVisitDTOs.Where(x => x.Vistime >= kaishijisuan && x.Vistime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var intentionVisitDTOsshangmenri = intentionVisitDTOsshangmen.Where(x => x.Vistime >= kaishijisuan && x.Vistime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = cooperVisitDTOsri.Count + intentionVisitDTOsshangmenri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = intentionVisitDTOsshangmen.Count + cooperVisitDTOs.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2254,6 +3082,42 @@
                                             hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
                                         }
 
+                                    }
+                                }
+
+                                else if (jixiaotichengfangan.Renwustandard == "05")
+                                {
+
+                                    var cooperVisitDTOszhou = _cooperVisitService.GetListsalary(userList[i].Id, dateminkaoqin.AddMonths(-1), datemaxkaoqin).Where(x => x.VisType == "02").ToList();
+                                    var intentionVisitDTOsshangmenzhou = _intentionVisitService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin).Where(x => x.VisType == "02").ToList();
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
+                                    {
+                                        var zhoukaishidate = CalculateFirstDateOfWeek(kaishijisuan);
+                                        var zhoujieshudate = CalculateLastDateOfWeek(kaishijisuan);
+
+                                        try
+                                        {
+                                            if(zhoujieshudate < datemaxkaoqin)
+                                            {
+                                                var cooperVisitDTOsri = cooperVisitDTOszhou.Where(x => x.Vistime >= zhoukaishidate && x.Vistime < zhoujieshudate.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var intentionVisitDTOsshangmenri = intentionVisitDTOsshangmenzhou.Where(x => x.Vistime >= zhoukaishidate && x.Vistime < zhoujieshudate.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = cooperVisitDTOsri.Count + intentionVisitDTOsshangmenri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = zhoujieshudate.AddDays(1);
                                     }
                                 }
                             }
@@ -2281,16 +3145,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = dtChannelArticleNewsDTOs.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var dtChannelArticleNewsDTOsri = dtChannelArticleNewsDTOs.Where(x => x.AddTime >= kaishijisuan && x.AddTime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = dtChannelArticleNewsDTOsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = dtChannelArticleNewsDTOs.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2331,16 +3222,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = dianxinanDTOs.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var dianxinanDTOsri = dianxinanDTOs.Where(x => x.AddTime >= kaishijisuan && x.AddTime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = dianxinanDTOsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = dianxinanDTOs.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2381,16 +3299,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = zhengcaizhishiDTOs.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var zhengcaizhishiDTOsri = zhengcaizhishiDTOs.Where(x => x.AddTime >= kaishijisuan && x.AddTime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = zhengcaizhishiDTOsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = zhengcaizhishiDTOs.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2425,16 +3370,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = xinzengwendaDTOsyue.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var xinzengwendaDTOsri = xinzengwendaDTOsyue.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = xinzengwendaDTOsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = xinzengwendaDTOsyue.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2469,16 +3441,43 @@
                             {
                                 if (jixiaotichengfangan.Renwustandard == "01")
                                 {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        decimal youxiaojijian = shenhewendaDTOsyue.Count - renwujishu;
-                                        if (youxiaojijian > 0)
+                                        try
                                         {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var shenhewendaDTOsri = shenhewendaDTOsyue.Where(x => x.Shenhetime >= kaishijisuan && x.Shenhetime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = shenhewendaDTOsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
 
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = shenhewendaDTOsyue.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
 
                                 }
                                 else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2560,6 +3559,7 @@
                     #endregion
                     //鍚堜綔瀹㈡埛璁㈠崟
                     List<CooperOrderDTO> cooperOrderDTOs =  _cooperOrderService.GetList(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    List<CooperOrderDTO> cooperOrderDTOszhouyue = _cooperOrderService.GetList(userList[i].Id, dateminkaoqin.AddMinutes(-1), datemaxkaoqin);
 
                     #region 鍥句功閿�鍞�
                     var cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "01").ToList();
@@ -2571,17 +3571,44 @@
                         {
                             if(jixiaotichengfangan.Renwustandard == "01")
                             {
-                              decimal renwujishu =   admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                if(jixiaotichengfangan.Tichengstandard == "01")
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
                                 {
-                                decimal youxiaojijian =     cooperOrdertushu.Count - renwujishu ;
-                                    if (youxiaojijian>0)
+                                    try
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                        if (gongzuoshijian)
+                                        {
+                                            var cooperOrdertushusri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            if (jixiaotichengfangan.Tichengstandard == "01")
+                                            {
+                                                decimal youxiaojijian = cooperOrdertushusri.Count - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                }
+                                            }
+                                        }
+
                                     }
-                                     
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = kaishijisuan.AddDays(1);
                                 }
-                                
+                                //decimal renwujishu =   admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //  if(jixiaotichengfangan.Tichengstandard == "01")
+                                //  {
+                                //  decimal youxiaojijian =     cooperOrdertushu.Count - renwujishu ;
+                                //      if (youxiaojijian>0)
+                                //      {
+                                //          hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                //      }
+
+                                //  }
+
                             }
                             else if (jixiaotichengfangan.Renwustandard == "02")
                             {
@@ -2598,19 +3625,49 @@
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                               
                                 if (jixiaotichengfangan.Tichengstandard == "02")
                                 {
-                                    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
-                                    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
-                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
-                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
-
-                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian* new decimal(0.01), 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushusri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var dingdanjine = cooperOrdertushusri.Sum(x => x.Money);
+                                                var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                                if (jixiaotichengfangan.Tichengstandard == "02")
+                                                {
+                                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
+                                    //var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                    ////var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    ////var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
+
+                                    //decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian* new decimal(0.01), 2);
+                                    //}
                                 }
 
                             }
@@ -2629,6 +3686,44 @@
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
                                     }
+                                }
+                            }
+                            else if (jixiaotichengfangan.Renwustandard == "06")
+                            {
+
+                                var cooperOrderDTOszhou = cooperOrderDTOszhouyue.Where(x => x.OrderType == "01").ToList();
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
+                                {
+                                    var zhoukaishidate = CalculateFirstDateOfWeek(kaishijisuan);
+                                    var zhoujieshudate = CalculateLastDateOfWeek(kaishijisuan);
+
+                                    try
+                                    {
+                                        if (zhoujieshudate < datemaxkaoqin)
+                                        {
+                                            var cooperOrdertushusri = cooperOrderDTOszhou.Where(x => x.Createtime >= zhoukaishidate && x.Createtime < zhoujieshudate.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            var dingdanjine = cooperOrdertushusri.Sum(x => x.Money);
+                                            var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                            if (jixiaotichengfangan.Tichengstandard == "02")
+                                            {
+                                                decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                }
+                                            }
+
+
+
+                                        }
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = zhoujieshudate.AddDays(1);
                                 }
                             }
                         }
@@ -2645,16 +3740,44 @@
                         {
                             if (jixiaotichengfangan.Renwustandard == "01")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
                                 {
-                                    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    try
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                    }
+                                        var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                        if (gongzuoshijian)
+                                        {
+                                            var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            if (jixiaotichengfangan.Tichengstandard == "01")
+                                            {
+                                                decimal youxiaojijian = cooperOrdertushuri.Count - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                }
+                                            }
+                                        }
 
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = kaishijisuan.AddDays(1);
                                 }
+
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //if (jixiaotichengfangan.Tichengstandard == "01")
+                                //{
+                                //    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
+                                //    if (youxiaojijian > 0)
+                                //    {
+                                //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                //    }
+
+                                //}
 
                             }
                             else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2672,19 +3795,49 @@
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                               
                                 if (jixiaotichengfangan.Tichengstandard == "02")
                                 {
-                                    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
-                                    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
-                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
-                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
-
-                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var dingdanjine = cooperOrdertushuri.Sum(x => x.Money);
+                                                var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                                if (jixiaotichengfangan.Tichengstandard == "02")
+                                                {
+                                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
+                                    //var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                    ////var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    ////var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
+
+                                    //decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                    //}
                                 }
 
                             }
@@ -2703,6 +3856,44 @@
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
                                     }
+                                }
+                            }
+                            else if (jixiaotichengfangan.Renwustandard == "06")
+                            {
+
+                                var cooperOrderDTOszhou = cooperOrderDTOszhouyue.Where(x => x.OrderType == "02").ToList();
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
+                                {
+                                    var zhoukaishidate = CalculateFirstDateOfWeek(kaishijisuan);
+                                    var zhoujieshudate = CalculateLastDateOfWeek(kaishijisuan);
+
+                                    try
+                                    {
+                                        if (zhoujieshudate < datemaxkaoqin)
+                                        {
+                                            var cooperOrdertushusri = cooperOrderDTOszhou.Where(x => x.Createtime >= zhoukaishidate && x.Createtime < zhoujieshudate.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            var dingdanjine = cooperOrdertushusri.Sum(x => x.Money);
+                                            var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                            if (jixiaotichengfangan.Tichengstandard == "02")
+                                            {
+                                                decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                }
+                                            }
+
+
+
+                                        }
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = zhoujieshudate.AddDays(1);
                                 }
                             }
                         }
@@ -2720,16 +3911,44 @@
                         {
                             if (jixiaotichengfangan.Renwustandard == "01")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
                                 {
-                                    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    try
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                    }
+                                        var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                        if (gongzuoshijian)
+                                        {
+                                            var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            if (jixiaotichengfangan.Tichengstandard == "01")
+                                            {
+                                                decimal youxiaojijian = cooperOrdertushuri.Count - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                }
+                                            }
+                                        }
 
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = kaishijisuan.AddDays(1);
                                 }
+
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //if (jixiaotichengfangan.Tichengstandard == "01")
+                                //{
+                                //    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
+                                //    if (youxiaojijian > 0)
+                                //    {
+                                //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                //    }
+
+                                //}
 
                             }
                             else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2747,19 +3966,49 @@
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                 if (jixiaotichengfangan.Tichengstandard == "02")
                                 {
-                                    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
-                                    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
-                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
-                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
-
-                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var dingdanjine = cooperOrdertushuri.Sum(x => x.Money);
+                                                var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                                if (jixiaotichengfangan.Tichengstandard == "02")
+                                                {
+                                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+
+                                    //var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
+                                    //var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                    ////var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    ////var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
+
+                                    //decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                    //}
                                 }
 
                             }
@@ -2780,6 +4029,44 @@
                                     }
                                 }
                             }
+                            else if (jixiaotichengfangan.Renwustandard == "06")
+                            {
+
+                                var cooperOrderDTOszhou = cooperOrderDTOszhouyue.Where(x => x.OrderType == "03").ToList();
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
+                                {
+                                    var zhoukaishidate = CalculateFirstDateOfWeek(kaishijisuan);
+                                    var zhoujieshudate = CalculateLastDateOfWeek(kaishijisuan);
+
+                                    try
+                                    {
+                                        if (zhoujieshudate < datemaxkaoqin)
+                                        {
+                                            var cooperOrdertushusri = cooperOrderDTOszhou.Where(x => x.Createtime >= zhoukaishidate && x.Createtime < zhoujieshudate.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            var dingdanjine = cooperOrdertushusri.Sum(x => x.Money);
+                                            var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                            if (jixiaotichengfangan.Tichengstandard == "02")
+                                            {
+                                                decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                }
+                                            }
+
+
+
+                                        }
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = zhoujieshudate.AddDays(1);
+                                }
+                            }
                         }
                     }
 
@@ -2795,16 +4082,43 @@
                         {
                             if (jixiaotichengfangan.Renwustandard == "01")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
                                 {
-                                    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    try
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                    }
+                                        var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                        if (gongzuoshijian)
+                                        {
+                                            var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            if (jixiaotichengfangan.Tichengstandard == "01")
+                                            {
+                                                decimal youxiaojijian = cooperOrdertushuri.Count - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                }
+                                            }
+                                        }
 
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = kaishijisuan.AddDays(1);
                                 }
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //if (jixiaotichengfangan.Tichengstandard == "01")
+                                //{
+                                //    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
+                                //    if (youxiaojijian > 0)
+                                //    {
+                                //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                //    }
+
+                                //}
 
                             }
                             else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2822,19 +4136,49 @@
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                 if (jixiaotichengfangan.Tichengstandard == "02")
                                 {
-                                    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
-                                    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
-                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
-                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
-
-                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var dingdanjine = cooperOrdertushuri.Sum(x => x.Money);
+                                                var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                                if (jixiaotichengfangan.Tichengstandard == "02")
+                                                {
+                                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+
+                                    //var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
+                                    //var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                    ////var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    ////var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
+
+                                    //decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                    //}
                                 }
 
                             }
@@ -2870,16 +4214,43 @@
                         {
                             if (jixiaotichengfangan.Renwustandard == "01")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
                                 {
-                                    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    try
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                    }
+                                        var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                        if (gongzuoshijian)
+                                        {
+                                            var cooperOrdertushusri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            if (jixiaotichengfangan.Tichengstandard == "01")
+                                            {
+                                                decimal youxiaojijian = cooperOrdertushusri.Count - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                }
+                                            }
+                                        }
 
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = kaishijisuan.AddDays(1);
                                 }
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //if (jixiaotichengfangan.Tichengstandard == "01")
+                                //{
+                                //    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
+                                //    if (youxiaojijian > 0)
+                                //    {
+                                //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                //    }
+
+                                //}
 
                             }
                             else if (jixiaotichengfangan.Renwustandard == "02")
@@ -2912,19 +4283,48 @@
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                 if (jixiaotichengfangan.Tichengstandard == "02")
                                 {
-                                    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
-                                    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
-                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
-                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
-
-                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var dingdanjine = cooperOrdertushuri.Sum(x => x.Money);
+                                                var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                                if (jixiaotichengfangan.Tichengstandard == "02")
+                                                {
+                                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
+                                    //var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                    ////var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    ////var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
+
+                                    //decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                    //}
                                 }
 
                             }
@@ -2945,6 +4345,47 @@
                                     }
                                 } 
                             }
+
+                            else if (jixiaotichengfangan.Renwustandard == "05")
+                            {
+
+                                var cooperOrderDTOszhou = cooperOrderDTOszhouyue.Where(x => x.OrderType == "05").OrderBy(x => x.Createtime).ToList();
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
+                                {
+                                    var zhoukaishidate = CalculateFirstDateOfWeek(kaishijisuan);
+                                    var zhoujieshudate = CalculateLastDateOfWeek(kaishijisuan);
+
+                                    try
+                                    {
+                                        if (zhoujieshudate < datemaxkaoqin)
+                                        {
+                                            var cooperOrdertushusri = cooperOrderDTOszhou.Where(x => x.Createtime >= zhoukaishidate && x.Createtime < zhoujieshudate.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            //if (jixiaotichengfangan.Tichengstandard == "02")
+                                            if (cooperOrdertushusri.Count > renwujishu)
+                                            {
+                                                List<CooperOrderDTO> cooperOrdertushuyouxiao = new List<CooperOrderDTO>();
+                                                for (int j = Convert.ToInt32(renwujishu); j < cooperOrdertushusri.Count; j++)
+                                                {
+                                                    cooperOrdertushuyouxiao.Add(cooperOrdertushusri[j]);
+                                                }
+                                                var dingdanjine = cooperOrdertushuyouxiao.Sum(x => x.Money);
+                                                var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                                hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * dingdanjinezhenshi * new decimal(0.01), 2);
+                                            }
+
+
+
+                                        }
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = zhoujieshudate.AddDays(1);
+                                }
+                            }
                         }
                     }
 
@@ -2960,14 +4401,41 @@
                         {
                             if (jixiaotichengfangan.Renwustandard == "01")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                 if (jixiaotichengfangan.Tichengstandard == "01")
                                 {
-                                    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = cooperOrdertushuri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //}
 
                                 }
 
@@ -2987,19 +4455,48 @@
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                 if (jixiaotichengfangan.Tichengstandard == "02")
                                 {
-                                    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
-                                    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
-                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
-                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
-
-                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var dingdanjine = cooperOrdertushuri.Sum(x => x.Money);
+                                                var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                                if (jixiaotichengfangan.Tichengstandard == "02")
+                                                {
+                                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
+                                    //var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                    ////var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    ////var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
+
+                                    //decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                    //}
                                 }
 
                             }
@@ -3035,14 +4532,42 @@
                         {
                             if (jixiaotichengfangan.Renwustandard == "01")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                 if (jixiaotichengfangan.Tichengstandard == "01")
                                 {
-                                    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = cooperOrdertushuri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+
+                                    //decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //}
 
                                 }
 
@@ -3062,19 +4587,50 @@
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                 if (jixiaotichengfangan.Tichengstandard == "02")
                                 {
-                                    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
-                                    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
-                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
-                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
-
-                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var dingdanjine = cooperOrdertushuri.Sum(x => x.Money);
+                                                var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                                if (jixiaotichengfangan.Tichengstandard == "02")
+                                                {
+                                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+
+
+                                    //var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
+                                    //var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                    ////var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    ////var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
+
+                                    //decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                    //}
                                 }
 
                             }
@@ -3110,16 +4666,44 @@
                         {
                             if (jixiaotichengfangan.Renwustandard == "01")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
                                 {
-                                    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    try
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                    }
+                                        var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                        if (gongzuoshijian)
+                                        {
+                                            var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Wangongtime >= kaishijisuan && x.Wangongtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            if (jixiaotichengfangan.Tichengstandard == "01")
+                                            {
+                                                decimal youxiaojijian = cooperOrdertushuri.Count - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                }
+                                            }
+                                        }
 
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = kaishijisuan.AddDays(1);
                                 }
+
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //if (jixiaotichengfangan.Tichengstandard == "01")
+                                //{
+                                //    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
+                                //    if (youxiaojijian > 0)
+                                //    {
+                                //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                //    }
+
+                                //}
 
                             }
                             else if (jixiaotichengfangan.Renwustandard == "02")
@@ -3137,19 +4721,48 @@
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                 if (jixiaotichengfangan.Tichengstandard == "02")
                                 {
-                                    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
-                                    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
-                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
-                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
-
-                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Wangongtime >= kaishijisuan && x.Wangongtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var dingdanjine = cooperOrdertushuri.Sum(x => x.Money);
+                                                var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                                if (jixiaotichengfangan.Tichengstandard == "02")
+                                                {
+                                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
+                                    //var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                    ////var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    ////var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
+
+                                    //decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                    //}
                                 }
 
                             }
@@ -3185,16 +4798,43 @@
                         {
                             if (jixiaotichengfangan.Renwustandard == "01")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
                                 {
-                                    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    try
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                    }
+                                        var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                        if (gongzuoshijian)
+                                        {
+                                            var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            if (jixiaotichengfangan.Tichengstandard == "01")
+                                            {
+                                                decimal youxiaojijian = cooperOrdertushuri.Count - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                }
+                                            }
+                                        }
 
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = kaishijisuan.AddDays(1);
                                 }
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //if (jixiaotichengfangan.Tichengstandard == "01")
+                                //{
+                                //    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
+                                //    if (youxiaojijian > 0)
+                                //    {
+                                //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                //    }
+
+                                //}
 
                             }
                             else if (jixiaotichengfangan.Renwustandard == "02")
@@ -3212,19 +4852,48 @@
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                 if (jixiaotichengfangan.Tichengstandard == "02")
                                 {
-                                    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
-                                    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
-                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
-                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
-
-                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var dingdanjine = cooperOrdertushuri.Sum(x => x.Money);
+                                                var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                                if (jixiaotichengfangan.Tichengstandard == "02")
+                                                {
+                                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
+                                    //var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                    ////var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    ////var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
+
+                                    //decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                    //}
                                 }
 
                             }
@@ -3260,16 +4929,43 @@
                         {
                             if (jixiaotichengfangan.Renwustandard == "01")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
                                 {
-                                    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    try
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                    }
+                                        var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                        if (gongzuoshijian)
+                                        {
+                                            var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            if (jixiaotichengfangan.Tichengstandard == "01")
+                                            {
+                                                decimal youxiaojijian = cooperOrdertushuri.Count - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                }
+                                            }
+                                        }
 
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = kaishijisuan.AddDays(1);
                                 }
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //if (jixiaotichengfangan.Tichengstandard == "01")
+                                //{
+                                //    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
+                                //    if (youxiaojijian > 0)
+                                //    {
+                                //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                //    }
+
+                                //}
 
                             }
                             else if (jixiaotichengfangan.Renwustandard == "02")
@@ -3287,19 +4983,48 @@
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                 if (jixiaotichengfangan.Tichengstandard == "02")
                                 {
-                                    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
-                                    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
-                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
-                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
-
-                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                var dingdanjine = cooperOrdertushuri.Sum(x => x.Money);
+                                                var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                                if (jixiaotichengfangan.Tichengstandard == "02")
+                                                {
+                                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
                                     }
+                                    //var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
+                                    //var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                    ////var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    ////var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
+
+                                    //decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                    //if (youxiaojijian > 0)
+                                    //{
+                                    //    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                    //}
                                 }
 
                             }
@@ -3335,16 +5060,43 @@
                         {
                             if (jixiaotichengfangan.Renwustandard == "01")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
                                 {
-                                    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    try
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                    }
+                                        var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                        if (gongzuoshijian)
+                                        {
+                                            var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            if (jixiaotichengfangan.Tichengstandard == "01")
+                                            {
+                                                decimal youxiaojijian = cooperOrdertushuri.Count - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                }
+                                            }
+                                        }
 
+                                    }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = kaishijisuan.AddDays(1);
                                 }
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //if (jixiaotichengfangan.Tichengstandard == "01")
+                                //{
+                                //    decimal youxiaojijian = cooperOrdertushu.Count - renwujishu;
+                                //    if (youxiaojijian > 0)
+                                //    {
+                                //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                //    }
+
+                                //}
 
                             }
                             else if (jixiaotichengfangan.Renwustandard == "02")
@@ -3362,20 +5114,50 @@
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
-                                decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                if (jixiaotichengfangan.Tichengstandard == "02")
+                                DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                while (kaishijisuan < datemaxkaoqin)
                                 {
-                                    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
-                                    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
-                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
-                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
-
-                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
-                                    if (youxiaojijian > 0)
+                                    try
                                     {
-                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                        var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                        if (gongzuoshijian)
+                                        {
+                                            var cooperOrdertushuri = cooperOrdertushu.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                            var dingdanjine = cooperOrdertushuri.Sum(x => x.Money);
+                                            var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                            if (jixiaotichengfangan.Tichengstandard == "02")
+                                            {
+                                                decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                                if (youxiaojijian > 0)
+                                                {
+                                                    hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                                }
+                                            }
+                                        }
+
                                     }
+                                    catch (Exception ex)
+                                    {
+                                        _logger.LogInformation(ex.ToString());
+                                    }
+                                    kaishijisuan = kaishijisuan.AddDays(1);
                                 }
+
+                                //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                //if (jixiaotichengfangan.Tichengstandard == "02")
+                                //{
+                                //    var dingdanjine = cooperOrdertushu.Sum(x => x.Money);
+                                //    var dingdanjinezhenshi = dingdanjine.HasValue ? dingdanjine.Value : 0;
+                                //    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                //    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
+
+                                //    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
+                                //    if (youxiaojijian > 0)
+                                //    {
+                                //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                //    }
+                                //}
 
                             }
                             else if (jixiaotichengfangan.Renwustandard == "04")
@@ -3400,9 +5182,105 @@
 
                     #endregion
 
+
+
+
+                    #region 涓撳褰曞叆
+
+                    var zhuanjialuruDTOsyue = _expertService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    if (zhuanjialuruDTOsyue != null && zhuanjialuruDTOsyue.Count > 0)
+                    {
+                        var jijianidddd = fiPiecerateDTOs.Where(x => x.Project == "涓撳褰曞叆").FirstOrDefault();
+                        if (jijianidddd != null)
+                        {
+                            var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianidddd.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
+                            if (jixiaotichengfangan != null && jixiaotichengfangan.Ticheng.HasValue && jixiaotichengfangan.Renwu.HasValue)
+                            {
+                                if (jixiaotichengfangan.Renwustandard == "01")
+                                {
+                                    DateTime kaishijisuan = new DateTime(Year, Month, 1);
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    while (kaishijisuan < datemaxkaoqin)
+                                    {
+                                        try
+                                        {
+                                            var gongzuoshijian = shifougongzuori(kaishijisuan);
+                                            if (gongzuoshijian)
+                                            {
+                                                var zhuanjialuruDTOsri = zhuanjialuruDTOsyue.Where(x => x.Createtime >= kaishijisuan && x.Createtime < kaishijisuan.AddDays(1)).ToList(); //_projectService.GetcaigougonggaoListsalary(userList[i].Id, kaishijisuan, kaishijisuan.AddDays(1));
+                                                if (jixiaotichengfangan.Tichengstandard == "01")
+                                                {
+                                                    decimal youxiaojijian = zhuanjialuruDTOsri.Count - renwujishu;
+                                                    if (youxiaojijian > 0)
+                                                    {
+                                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                                    }
+                                                }
+                                            }
+
+                                        }
+                                        catch (Exception ex)
+                                        {
+                                            _logger.LogInformation(ex.ToString());
+                                        }
+                                        kaishijisuan = kaishijisuan.AddDays(1);
+                                    }
+
+                                    //decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                                    //if (jixiaotichengfangan.Tichengstandard == "01")
+                                    //{
+                                    //    decimal youxiaojijian = zhuanjialuruDTOsyue.Count - renwujishu;
+                                    //    if (youxiaojijian > 0)
+                                    //    {
+                                    //        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                    //    }
+
+                                    //}
+
+                                }
+                                else if (jixiaotichengfangan.Renwustandard == "02")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = zhuanjialuruDTOsyue.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
                 }
 
+                //璇曠敤鏈熺哗鏁堜负0.8鍊�
+                if (hrSalaryDTO.Jixiaoticheng.HasValue)
+                {
+                    if (userList[i].ShiyongDate.HasValue && userList[i].ShiyongDateEnd.HasValue && dateminkaoqin >= userList[i].ShiyongDate.Value && dateminkaoqin <= userList[i].ShiyongDateEnd.Value)
+                    {
 
+                        if (userList[i].ShiyongDateEnd.Value < datemaxkaoqin.AddDays(-1))
+                        {
+                            var a = userList[i].ShiyongDateEnd.Value.Day;
+                            var b = datemaxkaoqin.AddDays(-1).Day;
+                            var shiyongqijixiao = new decimal(a) / new decimal(b) * hrSalaryDTO.Jixiaoticheng.Value * new decimal(0.8);
+                            var zhengshijixiao =(new decimal(1) - new decimal(a) / new decimal(b)) * hrSalaryDTO.Jixiaoticheng.Value;
+                            hrSalaryDTO.Jixiaoticheng = Math.Round(shiyongqijixiao + zhengshijixiao, 2);
+
+                        }
+                        else
+                        {
+                            hrSalaryDTO.Jixiaoticheng = Math.Round(hrSalaryDTO.Jixiaoticheng.Value * new decimal(0.8), 2);
+                        }
+                    }
+                }
+               
 
 
                 hrSalaryDTO.Daozhanggongzi = 0;
@@ -3426,7 +5304,7 @@
                 decimal jiucuo = hrSalaryDTO.Jiucuo.HasValue ? hrSalaryDTO.Jiucuo.Value : 0;
 
                 //璁$畻淇濆簳骞磋柂
-                if (userList[i].Indate.HasValue && userList[i].miniyearsalary.HasValue)
+                if (userList[i].Indate.HasValue && userList[i].miniyearsalary.HasValue && userList[i].miniyearsalary.Value>0)
                 {
                     DateTime jixinue = userList[i].Indate.Value;
                     if (userList[i].Indate.Value.Day != 1)
@@ -3463,21 +5341,90 @@
                                 decimal peichang1 = hrSalaryDTO1.Peichang.HasValue ? hrSalaryDTO1.Peichang.Value : 0;
                                 decimal jiucuo1 = hrSalaryDTO1.Jiucuo.HasValue ? hrSalaryDTO1.Jiucuo.Value : 0;
 
-                                baodinianxin += jibengongzi1 + baomifei1 + gongzuobutie1 + jiabangongzi1 + shebao1 + quanqinjiang1 + jiaotngbutie1 + jixiaoticheng1 + jiangjin1 + bufagongzi1 + jiucuo1;
+                                baodinianxin += jibengongzi1 + baomifei1 + gongzuobutie1 + jiabangongzi1 + shebao1 + quanqinjiang1 + jiaotngbutie1 + jixiaoticheng1 + jiangjin1 + bufagongzi1 + jiucuo1+ peichang1;
                             }
                         }
-                        baodinianxin += jibengongzi + baomifei + gongzuobutie + jiabangongzi + shebao + quanqinjiang + jiaotngbutie + jixiaoticheng + jiangjin + bufagongzi + jiucuo;
-                        if(baodinianxin < userList[i].miniyearsalary.Value)
+                        baodinianxin += jibengongzi + baomifei + gongzuobutie + jiabangongzi + shebao + quanqinjiang + jiaotngbutie + jixiaoticheng + jiangjin + bufagongzi + jiucuo + peichang;
+                        if (baodinianxin < userList[i].miniyearsalary.Value)
                         {
                             jiucuo = userList[i].miniyearsalary.Value - baodinianxin;
                         }
                     }    
                 }
 
+                yingfaheji = jibengongzi + baomifei + gongzuobutie + jiabangongzi + shebao + quanqinjiang + jiaotngbutie + jixiaoticheng + jiangjin + bufagongzi - shebaokou + ((dianhuabutie - dianhuafei) <= 0 ? (dianhuabutie - dianhuafei) : 0) - queqin - fakuan + peichang + jiucuo;
+
+
+                hrSalaryDTO.Yufagongzi = userList[i].advancewages;
+
+                if (userList[i].advancewages.HasValue && userList[i].advancewages.Value > 0)
+                {
+                    hrSalaryDTO.Yufagongziheji = 0;
+                    HrSalaryDTO hrSalaryDTOlast = _hrSalaryService.GetListByUser(userList[i].Id, dateminkaoqin.AddMonths(-1).Year, dateminkaoqin.AddMonths(-1).Month);
+                    if (hrSalaryDTOlast != null && hrSalaryDTOlast.Yufagongziheji.HasValue)
+                    {
+                        hrSalaryDTO.Yufagongziheji = hrSalaryDTOlast.Yufagongziheji;
+                    }
+
+                    if (hrSalaryDTO.Yufagongziheji > 0)
+                    {
+                        if (yingfaheji < (hrSalaryDTO.Yufagongzi+shebao- shebaokou))
+                        {
+                            hrSalaryDTO.Yufagongziheji += (hrSalaryDTO.Yufagongzi + shebao - shebaokou - yingfaheji);
+                            yingfaheji = (hrSalaryDTO.Yufagongzi.Value + shebao - shebaokou);
+                        }
+                        else if (yingfaheji > (hrSalaryDTO.Yufagongzi + shebao - shebaokou))
+                        {
+                            if (hrSalaryDTO.Yufagongziheji >= (yingfaheji - (hrSalaryDTO.Yufagongzi + shebao - shebaokou)))
+                            {
+                                hrSalaryDTO.Yufagongziheji += ((hrSalaryDTO.Yufagongzi + shebao - shebaokou) - yingfaheji);
+                                yingfaheji = (hrSalaryDTO.Yufagongzi.Value + shebao - shebaokou);
+                            }
+                            else
+                            {
+                                yingfaheji -= hrSalaryDTO.Yufagongziheji.Value;
+                                hrSalaryDTO.Yufagongziheji = 0;
+                            }
+
+
+                        }
+
+                    }
+                    else if (hrSalaryDTO.Yufagongziheji == 0)
+                    {
+                        hrSalaryDTO.Yufagongziheji += ((hrSalaryDTO.Yufagongzi + shebao - shebaokou) - yingfaheji);
+                        if (yingfaheji < (hrSalaryDTO.Yufagongzi + shebao - shebaokou))
+                        {
+                            yingfaheji = (hrSalaryDTO.Yufagongzi.Value + shebao - shebaokou);
+                        }
+                    }
+                    else if (hrSalaryDTO.Yufagongziheji < 0)
+                    {
+                        if (yingfaheji < (hrSalaryDTO.Yufagongzi.Value + shebao - shebaokou))
+                        {
+                            if (-hrSalaryDTO.Yufagongziheji >= ((hrSalaryDTO.Yufagongzi.Value + shebao - shebaokou) - yingfaheji))
+                            {
+                                hrSalaryDTO.Yufagongziheji += ((hrSalaryDTO.Yufagongzi.Value + shebao - shebaokou) - yingfaheji);
+                                yingfaheji = (hrSalaryDTO.Yufagongzi.Value + shebao - shebaokou);
+                            }
+                            else
+                            {
+                                yingfaheji += hrSalaryDTO.Yufagongziheji.Value;
+                                hrSalaryDTO.Yufagongziheji = 0;
+                            }
+                        }
+
+                    }
+
+                }
 
 
 
-                yingnashuie = jibengongzi + baomifei + gongzuobutie + jiabangongzi + shebao  + quanqinjiang + jiaotngbutie + jixiaoticheng + jiangjin + bufagongzi - shebaokou + ( (dianhuabutie - dianhuafei)<=0? (dianhuabutie - dianhuafei) : 0) - queqin - fakuan - peichang + jiucuo - geshuiqizheng;
+
+
+
+
+                yingnashuie = yingfaheji - geshuiqizheng;
 
 
                 hrSalaryDTO.Geshui = 0;
@@ -3488,32 +5435,53 @@
                     decimal yingnashuie3 = 0;
                     decimal yingnashuie4 = 0;
                     decimal yingnashuie5 = 0;
-                    if (yingnashuie > 39250)
+                    decimal yingnashuie6 = 0;
+                    decimal yingnashuie7 = 0;
+                    if (yingnashuie > 80000)
                     {
-                        yingnashuie1 = 4750;
-                        yingnashuie2 = (9250 - 4750);
-                        yingnashuie3 = (25250 - 9250);
-                        yingnashuie4 = (39250 - 25250);
-                        yingnashuie5 = (yingnashuie - 39250);
+                        yingnashuie1 = 3000;
+                        yingnashuie2 = (12000 - 3000);
+                        yingnashuie3 = (25000 - 12000);
+                        yingnashuie4 = (35000 - 25000);
+                        yingnashuie5 = (55000 - 35000);
+                        yingnashuie6 = (80000 - 55000);
+                        yingnashuie7 = (yingnashuie - 55000);
                     }
-                    else if (yingnashuie > 25250)
+                    if (yingnashuie > 55000)
                     {
-                        yingnashuie1 = 4750;
-                        yingnashuie2 = (9250 - 4750);
-                        yingnashuie3 = (25250 - 9250);
-                        yingnashuie4 = (yingnashuie - 25250);
+                        yingnashuie1 = 3000;
+                        yingnashuie2 = (12000 - 3000);
+                        yingnashuie3 = (25000 - 12000);
+                        yingnashuie4 = (35000 - 25000);
+                        yingnashuie5 = (55000 - 35000);
+                        yingnashuie6 = (yingnashuie - 55000);
+                    }
+                    if (yingnashuie > 35000)
+                    {
+                        yingnashuie1 = 3000;
+                        yingnashuie2 = (12000 - 3000);
+                        yingnashuie3 = (25000 - 12000);
+                        yingnashuie4 = (35000 - 25000);
+                        yingnashuie5 = (yingnashuie - 35000);
+                    }
+                    else if (yingnashuie > 25000)
+                    {
+                        yingnashuie1 = 3000;
+                        yingnashuie2 = (12000 - 3000);
+                        yingnashuie3 = (25000 - 12000);
+                        yingnashuie4 = (yingnashuie - 25000);
 
                     }
-                    else if (yingnashuie > 9250)
+                    else if (yingnashuie > 12000)
                     {
-                        yingnashuie1 = 4750;
-                        yingnashuie2 = (9250 - 4750);
-                        yingnashuie3 = (yingnashuie - 9250);
+                        yingnashuie1 = 3000;
+                        yingnashuie2 = (12000 - 3000);
+                        yingnashuie3 = (yingnashuie - 12000);
                     }
-                    else if (yingnashuie > 4750)
+                    else if (yingnashuie > 3000)
                     {
-                        yingnashuie1 = 4750;
-                        yingnashuie2 = (yingnashuie - 4750);
+                        yingnashuie1 = 3000;
+                        yingnashuie2 = (yingnashuie - 3000);
                     }
                     else
                     {
@@ -3521,7 +5489,7 @@
                     }
                     if (yingnashuie1 > 0)
                     {
-                        var yingjiao1 = Math.Round(yingnashuie1 * new decimal(0.05) - 0, 2);
+                        var yingjiao1 = Math.Round(yingnashuie1 * new decimal(0.03) - 0, 2);
                         if (yingjiao1 > 0)
                         {
                             hrSalaryDTO.Geshui += yingjiao1;
@@ -3530,7 +5498,7 @@
                     }
                     if (yingnashuie2 > 0)
                     {
-                        var yingjiao2 = Math.Round(yingnashuie2 * new decimal(0.1) - 250, 2);
+                        var yingjiao2 = Math.Round(yingnashuie2 * new decimal(0.1) - 0, 2);
                         if (yingjiao2 > 0)
                         {
                             hrSalaryDTO.Geshui += yingjiao2;
@@ -3538,7 +5506,7 @@
                     }
                     if (yingnashuie3 > 0)
                     {
-                        var yingjiao3 = Math.Round(yingnashuie3 * new decimal(0.2) - 1250, 2);
+                        var yingjiao3 = Math.Round(yingnashuie3 * new decimal(0.2) - 0, 2);
                         if (yingjiao3 > 0)
                         {
                             hrSalaryDTO.Geshui += yingjiao3;
@@ -3546,7 +5514,7 @@
                     }
                     if (yingnashuie4 > 0)
                     {
-                        var yingjiao4 = Math.Round(yingnashuie4 * new decimal(0.3) - 4250, 2);
+                        var yingjiao4 = Math.Round(yingnashuie4 * new decimal(0.25) - 0, 2);
                         if (yingjiao4 > 0)
                         {
                             hrSalaryDTO.Geshui += yingjiao4;
@@ -3554,39 +5522,39 @@
                     }
                     if (yingnashuie5 > 0)
                     {
-                        var yingjiao5 = Math.Round(yingnashuie5 * new decimal(0.35) - 6750, 2);
+                        var yingjiao5 = Math.Round(yingnashuie5 * new decimal(0.30) - 0, 2);
                         if (yingjiao5 > 0)
                         {
                             hrSalaryDTO.Geshui += yingjiao5;
                         }
                     }
-
-
+                    if (yingnashuie6 > 0)
+                    {
+                        var yingjiao6 = Math.Round(yingnashuie6 * new decimal(0.35) - 0, 2);
+                        if (yingjiao6 > 0)
+                        {
+                            hrSalaryDTO.Geshui += yingjiao6;
+                        }
+                    }
+                    if (yingnashuie7 > 0)
+                    {
+                        var yingjiao7 = Math.Round(yingnashuie7 * new decimal(0.45) - 0, 2);
+                        if (yingjiao7 > 0)
+                        {
+                            hrSalaryDTO.Geshui += yingjiao7;
+                        }
+                    }
 
                 }
                 decimal geshui = hrSalaryDTO.Geshui.HasValue ? hrSalaryDTO.Geshui.Value : 0;
 
-                hrSalaryDTO.Daozhanggongzi += jibengongzi + baomifei + gongzuobutie + jiabangongzi + shebao  + quanqinjiang + jiaotngbutie + jixiaoticheng + jiangjin + bufagongzi - shebaokou - geshui + ((dianhuabutie - dianhuafei) <= 0 ? (dianhuabutie - dianhuafei) : 0) - queqin - fakuan - peichang + jiucuo;
+
+                             
+                hrSalaryDTO.Daozhanggongzi = yingfaheji - geshui;
 
 
 
-                hrSalaryDTO.Yufagongzi = userList[i].advancewages;
-
-                if (userList[i].advancewages.HasValue)
-                {
-                    hrSalaryDTO.Yufagongziheji = 0;
-                    HrSalaryDTO hrSalaryDTOlast = _hrSalaryService.GetListByUser(userList[i].Id, dateminkaoqin.AddMonths(-1).Year, dateminkaoqin.AddMonths(-1).Month);
-                    if(hrSalaryDTOlast!=null && hrSalaryDTOlast.Yufagongziheji.HasValue)
-                    {
-                        hrSalaryDTO.Yufagongziheji = hrSalaryDTOlast.Yufagongziheji;
-                    }
-
-                    hrSalaryDTO.Yufagongziheji += (hrSalaryDTO.Daozhanggongzi- hrSalaryDTO.Yufagongzi);
-                    if (hrSalaryDTO.Daozhanggongzi < hrSalaryDTO.Yufagongzi)
-                    {
-                        hrSalaryDTO.Daozhanggongzi = hrSalaryDTO.Yufagongzi;
-                    }
-                }
+               
                 hrSalaryDTO.RecStatus = "A";
                 hrSalaryDTO.Islock = "D";
                 hrSalaryDTO.Creater = "1";

--
Gitblit v1.9.1