From d4a6d65f5e449c3e5464aa18ae97bf8953987217 Mon Sep 17 00:00:00 2001
From: LR-20210131IOQH\Administrator <jackcold@163.com>
Date: 星期二, 10 八月 2021 15:44:14 +0800
Subject: [PATCH] Merge branch 'master' of http://47.108.235.38:8080/r/zhengcaioa

---
 zhengcaioa/zhengcaioa/Timer/TimedBackgroundService.cs | 1620 ++++++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 1,424 insertions(+), 196 deletions(-)

diff --git a/zhengcaioa/zhengcaioa/Timer/TimedBackgroundService.cs b/zhengcaioa/zhengcaioa/Timer/TimedBackgroundService.cs
index 0865bfa..253e624 100644
--- a/zhengcaioa/zhengcaioa/Timer/TimedBackgroundService.cs
+++ b/zhengcaioa/zhengcaioa/Timer/TimedBackgroundService.cs
@@ -1,12 +1,17 @@
 锘縰sing DTO;
 using IServices;
+using Microsoft.Extensions.Configuration;
 using Microsoft.Extensions.DependencyInjection;
 using Microsoft.Extensions.Hosting;
 using Microsoft.Extensions.Logging;
+using Newtonsoft.Json;
+using Newtonsoft.Json.Linq;
 using System;
 using System.Collections.Generic;
 using System.IO;
 using System.Linq;
+using System.Net.Http;
+using System.Net.Http.Headers;
 using System.Threading;
 using System.Threading.Tasks;
 using System.Transactions;
@@ -35,6 +40,16 @@
         private readonly ICooperatecustomCustomerService _cooperatecustomCustomerService;
         private readonly IGroupTopicService _groupTopicService;
         private readonly ICooperVisitService _cooperVisitService;
+        private readonly IIntentionCustomerService _intentionCustomerService;
+        private readonly IIntentionVisitService _intentionVisitService;
+        private readonly IProjectService _projectService;
+        private readonly ICusFangwenjiluService _cusFangwenjiluService;
+        private readonly ILiaotianService _liaotianService;
+        private readonly IDtChannelArticleNewsService _dtChannelArticleNewsService;
+        private readonly IConfiguration _configuration;
+        private readonly IHttpClientFactory _clientFactory;
+        private readonly IAskService _askService;
+        private readonly IAdmEvaluateService _admEvaluateService;
 
         private readonly decimal jiabangongzibiaozhun = new decimal(21.5);
         public TimedBackgroundService(ILogger<TimedBackgroundService> logger, IServiceScopeFactory factory)
@@ -57,6 +72,17 @@
             _cooperatecustomCustomerService = factory.CreateScope().ServiceProvider.GetRequiredService<ICooperatecustomCustomerService>();
             _groupTopicService = factory.CreateScope().ServiceProvider.GetRequiredService<IGroupTopicService>();
             _cooperVisitService = factory.CreateScope().ServiceProvider.GetRequiredService<ICooperVisitService>();
+            _intentionCustomerService = factory.CreateScope().ServiceProvider.GetRequiredService<IIntentionCustomerService>();
+            _intentionVisitService = factory.CreateScope().ServiceProvider.GetRequiredService<IIntentionVisitService>();
+
+            _projectService = factory.CreateScope().ServiceProvider.GetRequiredService<IProjectService>();
+            _cusFangwenjiluService = factory.CreateScope().ServiceProvider.GetRequiredService<ICusFangwenjiluService>();
+            _liaotianService = factory.CreateScope().ServiceProvider.GetRequiredService<ILiaotianService>();
+            _dtChannelArticleNewsService = factory.CreateScope().ServiceProvider.GetRequiredService<IDtChannelArticleNewsService>();
+            _configuration = factory.CreateScope().ServiceProvider.GetRequiredService<IConfiguration>();
+            _clientFactory = factory.CreateScope().ServiceProvider.GetRequiredService<IHttpClientFactory>();
+            _askService= factory.CreateScope().ServiceProvider.GetRequiredService<IAskService>();
+            _admEvaluateService = factory.CreateScope().ServiceProvider.GetRequiredService<IAdmEvaluateService>();
         }
         protected override async Task ExecuteAsync(CancellationToken stoppingToken)
         {
@@ -64,15 +90,19 @@
 
             //stoppingToken.Register(() => File.Create($"E:\\dotnetCore\\Practice\\Practice\\{DateTime.Now.Millisecond}.txt"));
 
+            DateTime datenow = DateTime.Now.Date;
             while (!stoppingToken.IsCancellationRequested)
             {
                 _logger.LogInformation("MyServiceA 寮�濮嬫墽琛�");
+                _logger.LogInformation(datenow.ToString("yyyy-MM-dd HH:mm:ss"));
                 //姣忓ぉ鐨�0鐐瑰紑濮嬭绠�
-                if (DateTime.Now.Hour == 0)
+                if (datenow <= DateTime.Now.Date && DateTime.Now.Hour == 0)
                 //if (true)
                 {
+
                     try
                     {
+                        _logger.LogInformation("鍒ゆ柇鏄惁鏄浜斾釜宸ヤ綔鏃ョ粨鏉�");
                         DateTime diwutian = this.diwugongzuori();
                         //绗簲涓伐浣滄棩缁撴潫鍚庡紑濮嬭绠�
                         if (DateTime.Now.Date == diwutian.AddDays(1))
@@ -80,10 +110,11 @@
                         {
                             try
                             {
+                                _logger.LogInformation("璁$畻鑰冨嫟宸ヨ祫");
                                 //using (TransactionScope scope = new TransactionScope())
                                 //{
-                                    this.jisuankaoqin();
-                                    this.jisuangongzi();
+                                this.jisuankaoqin();
+                                 await   this.jisuangongziAsync();
                                     //scope.Complete();
                                 //}
 
@@ -93,17 +124,25 @@
                                 _logger.LogInformation(ex.ToString());
                             }
                         }
+
+
+                        _logger.LogInformation("鍒ゆ柇鏄惁璁$畻宸ラ緞宸ヨ祫");
+                        if (DateTime.Now.Date.Month==1 && DateTime.Now.Date.Day == 31)
+                        //if (true)
+                        {
+                            jisuangonglinggongzi();
+                        }
                     }
                     catch (Exception ex)
                     {
                         _logger.LogInformation(ex.ToString());
                     }
-                   
 
+                    datenow = DateTime.Now.Date.AddDays(1);
                 }
 
 
-                await Task.Delay(TimeSpan.FromMinutes(59), stoppingToken);
+                await Task.Delay(TimeSpan.FromMinutes(10), stoppingToken);
 
                 _logger.LogInformation("缁х画鎵ц");
             }
@@ -173,6 +212,7 @@
             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();
 
             //姣忓ぉ鐨勮�冨嫟鏃堕棿鐐�
             string[] WorkingStart = admAttendanceRuleDTO.WorkingStart.Split('.');
@@ -702,26 +742,426 @@
                         //璁$畻鍔犵彮鏃堕棿
                         if (admSignInDTO != null && admSignInDTO.OvertimeIn.HasValue && admSignInDTO.OvertimeOut.HasValue)
                         {
-                            DateTime overdate = admSignInDTO.OvertimeIn.Value;
-                            if (admSignInDTO.OvertimeIn.Value< StratTimeOffworkEnd)
+                            var admAskovertimeDTO  = _askService.GetAskovertimeByUeridAndjiabantime(userList[a].Id, dateminkaoqin);
+                            if(admAskovertimeDTO!=null&& !string.IsNullOrEmpty(admAskovertimeDTO.Id))
                             {
-                                overdate = StratTimeOffworkEnd;
+                                DateTime overdate = admSignInDTO.OvertimeIn.Value;
+                                if (admSignInDTO.OvertimeIn.Value < StratTimeOffworkEnd)
+                                {
+                                    overdate = StratTimeOffworkEnd;
+                                }
+                                TimeSpan jiaban = admSignInDTO.OvertimeOut.Value.Subtract(overdate);
+                                decimal jiabanshijian = jiaban.Hours;
+                                if(new decimal(jiaban.Hours) > admAskovertimeDTO.Overtime.Value)
+                                {
+                                    jiabanshijian = admAskovertimeDTO.Overtime.Value;
+                                }
+
+
+
+
+                                Jiaban += Math.Round(jiabanshijian * 60 / shangbanshijian, 2);
                             }
-                            TimeSpan jiaban = admSignInDTO.OvertimeOut.Value.Subtract(overdate);
-                          
-                            Jiaban += Math.Round((decimal)(jiaban.Hours * 60) / (decimal)shangbanshijian, 2);
+                            
+
+                           
                         }
                     }
                     else
                     {
+                        //鍒ゆ柇浠婂ぉ鏄惁鍏徃瑕佹眰鍔犵彮
+                        var shifoujiaban = jiabanri.Exists(x => x.ValueStart <= dateminkaoqin && x.ValueEnd >= dateminkaoqin);
+                        if (shifoujiaban)
+                        {
+
+                            //鍒ゆ柇鑰冨嫟鏃堕棿鐨勮繛缁��
+
+                            //鍒ゆ柇鏃╀笂鏄惁杩熷埌,鍒ゆ柇鏃╀笂鏄惁鏃╅��锛屾棭閫�鐭垮伐澶勭悊
+                            DateTime? starttime = null;
+                            DateTime? endttime = null;
+                            bool kuanggong = false;
+                            List<DateBiJiaoDTO> dateBiJiaoDTOs = new List<DateBiJiaoDTO>();
+                            if (admSignInDTO != null && admSignInDTO.MorningIn.HasValue && admSignInDTO.MorningOut.HasValue)
+                            {
+                                DateBiJiaoDTO dateBiJiaoDTO = new DateBiJiaoDTO();
+                                dateBiJiaoDTO.StartTime = admSignInDTO.MorningIn;
+                                dateBiJiaoDTO.EndTime = admSignInDTO.MorningOut;
+                                dateBiJiaoDTOs.Add(dateBiJiaoDTO);
+                            }
+                            foreach (var admAskLeave in admAskLeaveDTOMin)
+                            {
+                                if (admAskLeave.StratTime < StratTimeWorkingEnd)
+                                {
+                                    DateBiJiaoDTO dateBiJiaoDTO = new DateBiJiaoDTO();
+                                    dateBiJiaoDTO.StartTime = admAskLeave.StratTime;
+                                    dateBiJiaoDTO.EndTime = admAskLeave.EndTime;
+                                    dateBiJiaoDTOs.Add(dateBiJiaoDTO);
+                                }
+
+                            }
+
+                            foreach (var admAskLeaveOff in admAskLeaveOffDTOMin)
+                            {
+                                if (admAskLeaveOff.StratTime < StratTimeWorkingEnd)
+                                {
+                                    DateBiJiaoDTO dateBiJiaoDTO = new DateBiJiaoDTO();
+                                    dateBiJiaoDTO.StartTime = admAskLeaveOff.StratTime;
+                                    dateBiJiaoDTO.EndTime = admAskLeaveOff.EndTime;
+                                    dateBiJiaoDTOs.Add(dateBiJiaoDTO);
+                                }
+
+                            }
+
+
+                            dateBiJiaoDTOs = dateBiJiaoDTOs.OrderBy(x => x.StartTime).ToList();
+                            if (dateBiJiaoDTOs.Count == 0)
+                            {
+                                Kuanggong += new decimal(0.5);
+                                Kuanggongtianshu += new decimal(0.5);
+                            }
+                            else
+                            {
+                                //鍒ゆ柇涓婂崍鑰冨嫟鏃堕棿鏄惁鍏ㄨ鐩�
+                                for (int i = 0; i < dateBiJiaoDTOs.Count; i++)
+                                {
+                                    if (i == 0)
+                                    {
+                                        starttime = dateBiJiaoDTOs[i].StartTime;
+                                        endttime = dateBiJiaoDTOs[i].EndTime;
+                                    }
+                                    else
+                                    {
+                                        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 (kuanggong)
+                                {
+                                    Kuanggong += new decimal(0.5);
+                                    Kuanggongtianshu += new decimal(0.5);
+                                }
+                                else
+                                {
+                                    decimal shangwukuanggong = 0;
+                                    if (starttime > StratTimeWorkingStart)
+                                    {
+                                        TimeSpan chidao = starttime.Value.Subtract(StratTimeWorkingStart);
+                                        if (chidao.Days > 0 || (chidao.Hours * 60 + chidao.Minutes) > admAttendanceRuleDTO.Absenteeism)
+                                        {
+                                            if (shangwukuanggong == 0)
+                                            {
+                                                shangwukuanggong += new decimal(0.5);
+                                                Kuanggong += new decimal(0.5);
+                                            }
+
+                                        }
+                                        else
+                                        {
+                                            Chidao += 1;
+                                            Shangwuchidaofenzhong = chidao.Hours * 60 + chidao.Minutes;
+                                        }
+                                    }
+                                    if (shangwukuanggong == 0 && endttime < StratTimeWorkingEnd)
+                                    {
+                                        TimeSpan zaotui = StratTimeWorkingEnd.Subtract(endttime.Value);
+                                        if (zaotui.Days > 0 || (zaotui.Hours * 60 + zaotui.Minutes) > admAttendanceRuleDTO.Absenteeism)
+                                        {
+                                            if (shangwukuanggong == 0)
+                                            {
+                                                shangwukuanggong += new decimal(0.5);
+                                                Kuanggong += new decimal(0.5);
+                                            }
+
+                                        }
+                                        else
+                                        {
+                                            Zaotui += 1;
+                                            Shangwuzaotuifenzhong = zaotui.Hours * 60 + zaotui.Minutes;
+                                        }
+
+                                    }
+                                    Kuanggongtianshu += shangwukuanggong;
+                                }
+                            }
+
+
+
+                            //鍒ゆ柇涓嬪崍鏄惁杩熷埌,鍒ゆ柇涓嬪崍鏄惁鏃╅��锛屾棭閫�鐭垮伐澶勭悊
+
+
+                            starttime = null;
+                            endttime = null;
+                            kuanggong = false;
+                            dateBiJiaoDTOs = new List<DateBiJiaoDTO>();
+                            if (admSignInDTO != null && admSignInDTO.AfternoonIn.HasValue && admSignInDTO.AfternoonOut.HasValue)
+                            {
+                                DateBiJiaoDTO dateBiJiaoDTO = new DateBiJiaoDTO();
+                                dateBiJiaoDTO.StartTime = admSignInDTO.AfternoonIn;
+                                dateBiJiaoDTO.EndTime = admSignInDTO.AfternoonOut;
+                                dateBiJiaoDTOs.Add(dateBiJiaoDTO);
+                            }
+                            foreach (var admAskLeave in admAskLeaveDTOMin)
+                            {
+                                if (admAskLeave.EndTime > StratTimeOffworkStart)
+                                {
+                                    DateBiJiaoDTO dateBiJiaoDTO = new DateBiJiaoDTO();
+                                    dateBiJiaoDTO.StartTime = admAskLeave.StratTime;
+                                    dateBiJiaoDTO.EndTime = admAskLeave.EndTime;
+                                    dateBiJiaoDTOs.Add(dateBiJiaoDTO);
+                                }
+
+                            }
+                            foreach (var admAskLeaveOff in admAskLeaveOffDTOMin)
+                            {
+                                if (admAskLeaveOff.EndTime > StratTimeOffworkStart)
+                                {
+                                    DateBiJiaoDTO dateBiJiaoDTO = new DateBiJiaoDTO();
+                                    dateBiJiaoDTO.StartTime = admAskLeaveOff.StratTime;
+                                    dateBiJiaoDTO.EndTime = admAskLeaveOff.EndTime;
+                                    dateBiJiaoDTOs.Add(dateBiJiaoDTO);
+                                }
+
+                            }
+
+                            dateBiJiaoDTOs = dateBiJiaoDTOs.OrderBy(x => x.StartTime).ToList();
+                            if (dateBiJiaoDTOs.Count == 0)
+                            {
+                                Kuanggong += new decimal(0.5);
+                                Kuanggongtianshu += new decimal(0.5);
+                            }
+                            else
+                            {
+                                //鍒ゆ柇涓婂崍鑰冨嫟鏃堕棿鏄惁鍏ㄨ鐩�
+                                for (int i = 0; i < dateBiJiaoDTOs.Count; i++)
+                                {
+                                    if (i == 0)
+                                    {
+                                        starttime = dateBiJiaoDTOs[i].StartTime;
+                                        endttime = dateBiJiaoDTOs[i].EndTime;
+                                    }
+                                    else
+                                    {
+                                        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 (kuanggong)
+                                {
+                                    Kuanggong += new decimal(0.5);
+                                    Kuanggongtianshu += new decimal(0.5);
+                                }
+                                else
+                                {
+                                    decimal xiawuwukuanggong = 0;
+                                    if (starttime > StratTimeOffworkStart)
+                                    {
+                                        TimeSpan chidao = starttime.Value.Subtract(StratTimeOffworkStart);
+                                        if (chidao.Days > 0 || (chidao.Hours * 60 + chidao.Minutes) > admAttendanceRuleDTO.Absenteeism)
+                                        {
+                                            if (xiawuwukuanggong == 0)
+                                            {
+                                                xiawuwukuanggong += new decimal(0.5);
+                                                Kuanggong += new decimal(0.5);
+                                            }
+
+                                        }
+                                        else
+                                        {
+                                            Chidao += 1;
+                                            Xiawuchidaofenzhong = chidao.Hours * 60 + chidao.Minutes;
+                                        }
+                                    }
+                                    if (xiawuwukuanggong == 0 && endttime < StratTimeOffworkEnd)
+                                    {
+                                        TimeSpan zaotui = StratTimeOffworkEnd.Subtract(endttime.Value);
+                                        if (zaotui.Days > 0 || (zaotui.Hours * 60 + zaotui.Minutes) > admAttendanceRuleDTO.Absenteeism)
+                                        {
+                                            if (xiawuwukuanggong == 0)
+                                            {
+                                                xiawuwukuanggong += new decimal(0.5);
+                                                Kuanggong += new decimal(0.5);
+                                            }
+
+                                        }
+                                        else
+                                        {
+                                            Zaotui += 1;
+                                            Xiawuzaotuifenzhong = zaotui.Hours * 60 + zaotui.Minutes;
+                                        }
+
+                                    }
+                                    Kuanggongtianshu += xiawuwukuanggong;
+                                }
+                            }
+
+
+                            //璁$畻褰撳ぉ璇峰亣
+                            List<DateBiJiaoDTO> qingjias = new List<DateBiJiaoDTO>();
+
+                            var feichuqinjia = admAskLeaveDTOMin.Where(x => x.Lavetype != "4").ToList();
+                            foreach (var admAskLeave in feichuqinjia)
+                            {
+
+                                DateBiJiaoDTO dateBiJiaoDTO = new DateBiJiaoDTO();
+                                dateBiJiaoDTO.StartTime = admAskLeave.StratTime;
+                                dateBiJiaoDTO.EndTime = admAskLeave.EndTime;
+                                qingjias.Add(dateBiJiaoDTO);
+
+                            }
+
+                            var feichuqinxiaojia = admAskLeaveOffDTOMin.Where(x => x.Lavetype == "2").ToList();
+                            foreach (var admAskLeaveOff in feichuqinxiaojia)
+                            {
+
+                                DateBiJiaoDTO dateBiJiaoDTO = new DateBiJiaoDTO();
+                                dateBiJiaoDTO.StartTime = admAskLeaveOff.StratTime;
+                                dateBiJiaoDTO.EndTime = admAskLeaveOff.EndTime;
+                                qingjias.Add(dateBiJiaoDTO);
+
+                            }
+
+
+                            foreach (var qingjia in qingjias)
+                            {
+                                if (qingjia.StartTime < StratTimeWorkingStart)
+                                {
+                                    qingjia.StartTime = StratTimeWorkingStart;
+                                }
+                                if (qingjia.StartTime > StratTimeWorkingEnd && qingjia.StartTime < StratTimeOffworkStart)
+                                {
+                                    qingjia.StartTime = StratTimeOffworkStart;
+                                }
+
+
+                                if (qingjia.EndTime > StratTimeWorkingEnd && qingjia.EndTime < StratTimeOffworkStart)
+                                {
+                                    qingjia.EndTime = StratTimeWorkingEnd;
+                                }
+
+
+                                if (qingjia.EndTime > StratTimeOffworkEnd)
+                                {
+                                    qingjia.EndTime = StratTimeOffworkEnd;
+                                }
+                                TimeSpan qingjiashiijan = qingjia.EndTime.Value.Subtract(qingjia.StartTime.Value);
+                                if (qingjia.StartTime <= StratTimeWorkingEnd && qingjia.EndTime >= StratTimeOffworkStart)
+                                {
+                                    TimeSpan wuxiushijian = StratTimeOffworkStart.Subtract(StratTimeWorkingEnd);
+                                    dangtianqingjia += Math.Round(((decimal)(qingjiashiijan.Hours * 60 + qingjiashiijan.Minutes - wuxiushijian.Hours * 60 - wuxiushijian.Minutes)) / ((decimal)shangbanshijian), 2);
+                                }
+                                else
+                                {
+                                    dangtianqingjia += Math.Round(((decimal)(qingjiashiijan.Hours * 60 + qingjiashiijan.Minutes)) / ((decimal)shangbanshijian), 2);
+                                }
+
+
+
+                            }
+
+                            Qingjia += dangtianqingjia;
+                            //璁$畻褰撳ぉ鍑哄嫟澶╂暟
+                            Jiaban += (1 - Kuanggongtianshu - dangtianqingjia);
+
+
+                            //璁$畻閿�鍋囷紙鍑哄樊锛岃ˉ鍗★級
+                            List<DateBiJiaoDTO> xiaojias = new List<DateBiJiaoDTO>();
+
+                            var xiaojiala = admAskLeaveOffDTOMin.Where(x => x.Lavetype != "2").ToList();
+                            foreach (var admAskLeaveOff in xiaojiala)
+                            {
+
+                                DateBiJiaoDTO dateBiJiaoDTO = new DateBiJiaoDTO();
+                                dateBiJiaoDTO.StartTime = admAskLeaveOff.StratTime;
+                                dateBiJiaoDTO.EndTime = admAskLeaveOff.EndTime;
+                                xiaojias.Add(dateBiJiaoDTO);
+
+                            }
+
+                            foreach (var xiaojia in xiaojias)
+                            {
+                                if (xiaojia.StartTime < StratTimeWorkingStart)
+                                {
+                                    xiaojia.StartTime = StratTimeWorkingStart;
+                                }
+                                if (xiaojia.StartTime > StratTimeWorkingEnd && xiaojia.StartTime < StratTimeOffworkStart)
+                                {
+                                    xiaojia.StartTime = StratTimeOffworkStart;
+                                }
+
+
+                                if (xiaojia.EndTime > StratTimeWorkingEnd && xiaojia.EndTime < StratTimeOffworkStart)
+                                {
+                                    xiaojia.EndTime = StratTimeWorkingEnd;
+                                }
+
+
+                                if (xiaojia.EndTime > StratTimeOffworkEnd)
+                                {
+                                    xiaojia.EndTime = StratTimeOffworkEnd;
+                                }
+                                TimeSpan qingjiashiijan = xiaojia.EndTime.Value.Subtract(xiaojia.StartTime.Value);
+                                if (xiaojia.StartTime <= StratTimeWorkingEnd && xiaojia.EndTime >= StratTimeOffworkStart)
+                                {
+                                    TimeSpan wuxiushijian = StratTimeOffworkStart.Subtract(StratTimeWorkingEnd);
+                                    dangtianxiaojia += Math.Round(((decimal)(qingjiashiijan.Hours * 60 + qingjiashiijan.Minutes - wuxiushijian.Hours * 60 - wuxiushijian.Minutes)) / ((decimal)shangbanshijian), 2);
+                                }
+                                else
+                                {
+                                    dangtianxiaojia += Math.Round(((decimal)(qingjiashiijan.Hours * 60 + qingjiashiijan.Minutes)) / ((decimal)shangbanshijian), 2);
+                                }
+
+
+
+                            }
+
+                            Xiaojia += dangtianxiaojia;
+                        }
+                           
+
+
+
                         //鍔犵彮
                         //璁$畻鍔犵彮鏃堕棿
                         if (admSignInDTO != null && admSignInDTO.OvertimeIn.HasValue && admSignInDTO.OvertimeOut.HasValue)
                         {
-                            TimeSpan jiaban = admSignInDTO.OvertimeOut.Value.Subtract(admSignInDTO.OvertimeIn.Value);
+                            var admAskovertimeDTO = _askService.GetAskovertimeByUeridAndjiabantime(userList[a].Id, dateminkaoqin);
+                            if (admAskovertimeDTO != null && !string.IsNullOrEmpty(admAskovertimeDTO.Id))
+                            {
+                                //濡傛灉褰撳ぉ鏄叕鍙歌姹傚姞鐝�,鍒欒嚜宸辩敵璇风殑鍔犵彮浠庝笅鐝紑濮嬬畻
+                                DateTime overdate = admSignInDTO.OvertimeIn.Value;
+                                if (shifoujiaban && admSignInDTO.OvertimeIn.Value < StratTimeOffworkEnd)
+                                {
+                                    overdate = StratTimeOffworkEnd;
+                                }
+                                TimeSpan jiaban = admSignInDTO.OvertimeOut.Value.Subtract(overdate);
+                                decimal jiabanshijian = jiaban.Hours;
+                                if (new decimal(jiaban.Hours) > admAskovertimeDTO.Overtime.Value)
+                                {
+                                    jiabanshijian = admAskovertimeDTO.Overtime.Value;
+                                }
 
-                            Jiaban += Math.Round((decimal)(jiaban.Hours * 60+ jiaban.Minutes) / (decimal)shangbanshijian, 2);
+
+
+
+                                Jiaban += Math.Round(jiabanshijian * 60 / shangbanshijian, 2);
+                            }
                         }
+
+                        
                     }
 
 
@@ -846,7 +1286,7 @@
 
 
         //璁$畻宸ヨ祫
-        public void jisuangongzi()
+        public async Task jisuangongziAsync()
         {
             //鏌ヨ鎵�鏈夌殑鏈夋晥浜哄憳
             DateTime dateminkaoqin = new DateTime(DateTime.Now.Year, DateTime.Now.Month - 1, 1);
@@ -898,8 +1338,10 @@
                 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); 
+                decimal chuqinlv = Math.Round((admAttendanceDTO.Shijichuqin- admEvaluateDTOs.Count) / admAttendanceDTO.Yingchuqin,4); 
 
                 //鏌ヨ褰撳墠鍛樺伐鑱屽姟鐨勫熀鏈伐璧勯厤缃�
 
@@ -954,7 +1396,12 @@
                                     }
                             }
                         }
-                        shiyongqichuqinlv = Math.Round(shiyongqichuqintianshu / admAttendanceDTO.Yingchuqin, 4);
+
+                        //鏌ヨ鏄惁鏈変笉绉拌亴鐨勫伐浣滆�冭瘎
+                        var admEvaluateDTOsshiyongqi = _admEvaluateService.GetListsalary(userList[i].Id, dateminkaoqin, userList[i].ShiyongDateEnd.Value.AddDays(1)).Where(x => x.EvaluateValue == "03").ToList();
+
+
+                        shiyongqichuqinlv = Math.Round((shiyongqichuqintianshu- admEvaluateDTOsshiyongqi.Count) / admAttendanceDTO.Yingchuqin, 4);
                     }
                     else
                     {
@@ -1281,9 +1728,16 @@
                     hrSalaryDTO.Dianhuafei = SimCost.bill_amount;
                 }
               
+                if(admAttendanceDTO.Shijichuqin>=admAttendanceDTO.Yingchuqin)
+                {
+                    hrSalaryDTO.Quanqinjiang = hrJibengongzi.Quanqingjiang;
+                }
+                else
+                {
+                    hrSalaryDTO.Quanqinjiang = 0;
+                }
 
-
-                hrSalaryDTO.Quanqinjiang = hrJibengongzi.Quanqingjiang;
+               
                 if ("A".Equals(userList[i].Istravelsubsidy))
                 {
                     hrSalaryDTO.Jiaotngbutie = hrJibengongzi.Jiaotongbutie;
@@ -1323,7 +1777,7 @@
                     }
                 }
 
-                //hrSalaryDTO.Jiucuo
+                hrSalaryDTO.Jiucuo = 0;
 
                 //璁$畻缁╂晥鎻愭垚
                 hrSalaryDTO.Jixiaoticheng = 0;
@@ -1335,12 +1789,12 @@
                     //var feijijiandengji = fiPiecerateDTOs.Where(x => x.Standard == "A");
                     //var  jijiandengji =    fiPiecerateDTOs.Where(x => x.Standard == "A");
 
-                    #region 涓婇棬鎷滆瀹㈡埛
+                    #region 閲囪喘椤圭洰褰曞叆
 
-                    var cooperVisitDTOs = _cooperVisitService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
-                    if (cooperVisitDTOs != null && cooperVisitDTOs.Count > 0)
+                    var projectDTOsyue = _projectService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    if (projectDTOsyue!=null && projectDTOsyue.Count > 0 )
                     {
-                        var jijianidddd = fiPiecerateDTOs.Where(x => x.Standard == "D" && 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();
@@ -1351,7 +1805,7 @@
                                     decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                     if (jixiaotichengfangan.Tichengstandard == "01")
                                     {
-                                        decimal youxiaojijian = cooperVisitDTOs.Count - renwujishu;
+                                        decimal youxiaojijian = projectDTOsyue.Count - renwujishu;
                                         if (youxiaojijian > 0)
                                         {
                                             hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
@@ -1365,51 +1819,7 @@
                                     decimal renwujishu = jixiaotichengfangan.Renwu.Value;
                                     if (jixiaotichengfangan.Tichengstandard == "01")
                                     {
-                                        decimal youxiaojijian = cooperVisitDTOs.Count - renwujishu;
-                                        if (youxiaojijian > 0)
-                                        {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
-
-                                    }
-                                }
-                            }
-
-                        }
-                    }
-                    #endregion
-
-                    #region 鏂板姞缇ょ粍
-
-                    var groupTopicDTOs = _groupTopicService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
-                    if (groupTopicDTOs != null && groupTopicDTOs.Count > 0)
-                    {
-                        var jijianidddd = fiPiecerateDTOs.Where(x => x.Standard == "D" && 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")
-                                {
-                                    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")
-                                {
-                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
-                                    {
-                                        decimal youxiaojijian = groupTopicDTOs.Count - renwujishu;
+                                        decimal youxiaojijian = projectDTOsyue.Count - renwujishu;
                                         if (youxiaojijian > 0)
                                         {
                                             hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
@@ -1424,54 +1834,11 @@
                     #endregion
 
                     #region 瀹㈡埛璧勬枡褰曞叆
-                    var cooperatecustomCustomerDTOs = _cooperatecustomCustomerService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
-                    if (cooperatecustomCustomerDTOs != null && cooperatecustomCustomerDTOs.Count > 0)
-                    {
-                        var jijianidddd = fiPiecerateDTOs.Where(x => x.Standard == "D" && 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")
-                                {
-                                    decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
-                                    if (jixiaotichengfangan.Tichengstandard == "01")
-                                    {
-                                        decimal youxiaojijian = cooperatecustomCustomerDTOs.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 = cooperatecustomCustomerDTOs.Count - renwujishu;
-                                        if (youxiaojijian > 0)
-                                        {
-                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
-                                        }
-
-                                    }
-                                }
-                            }
-                        }     
-                    }
-                    #endregion
-
-
-                    #region 褰曞叆瀹㈡埛绛惧崟
                     
-                   var cooperatecustomCustomers = _cooperatecustomCustomerService.GetListsalaryqiandan(userList[i].Id, dateminkaoqin, datemaxkaoqin);
-                    if (cooperatecustomCustomers != null && cooperatecustomCustomers.Count > 0)
+                    var _intentionCustomerDTOs = _intentionCustomerService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    if (_intentionCustomerDTOs!=null && _intentionCustomerDTOs.Count > 0)
                     {
-                        var jijianidddd = fiPiecerateDTOs.Where(x => x.Standard == "D" && 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();
@@ -1482,7 +1849,7 @@
                                     decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
                                     if (jixiaotichengfangan.Tichengstandard == "01")
                                     {
-                                        decimal youxiaojijian = cooperatecustomCustomers.Count - renwujishu;
+                                        decimal youxiaojijian = _intentionCustomerDTOs.Count   - renwujishu;
                                         if (youxiaojijian > 0)
                                         {
                                             hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
@@ -1496,7 +1863,7 @@
                                     decimal renwujishu = jixiaotichengfangan.Renwu.Value;
                                     if (jixiaotichengfangan.Tichengstandard == "01")
                                     {
-                                        decimal youxiaojijian = cooperatecustomCustomers.Count - renwujishu;
+                                        decimal youxiaojijian = _intentionCustomerDTOs.Count   - renwujishu;
                                         if (youxiaojijian > 0)
                                         {
                                             hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
@@ -1507,6 +1874,689 @@
                             }
                         }
                     }
+
+
+
+                    #endregion
+
+                    #region 鏂板姞缇ょ粍
+
+                    var groupTopicDTOs = _groupTopicService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    if (groupTopicDTOs != null && groupTopicDTOs.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = groupTopicDTOs.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+                    #region 鐢佃瘽鎺ㄥ箍
+
+                    var intentionVisitDTOs = _intentionVisitService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin).Where(x => x.VisType == "01").ToList();
+                    if (intentionVisitDTOs != null && intentionVisitDTOs.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = intentionVisitDTOs.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+                    #region 缇ゅ彂鐭俊
+
+                    var duanxinsyue = _cusFangwenjiluService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin).Where(x => x.Fasongfangshi == "01").ToList();
+                    if (duanxinsyue != null && duanxinsyue.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = duanxinsyue.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();
+                    if (youjiansyue != null && youjiansyue.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = youjiansyue.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+                    #region 鏂板鎰忓悜瀹㈡埛锛堣鍗曪級
+
+                    var yixiangsyue = _intentionCustomerService.GetListsalaryyixiang(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    if (yixiangsyue != null && yixiangsyue.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = yixiangsyue.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+
+                    #region 鏂板娉ㄥ唽浼氬憳
+
+                    //鏈湀鏁伴噺
+                    List<YaoQingYongHuDTO> zhucehuiyuansyue = new List<YaoQingYongHuDTO>();
+                    try
+                    {
+                        //var pltUserDTO = _userService.GetPltUserEntity(userList[i].Id);
+                        string huiyuanurl = _configuration.GetSection("huiyuanurl").Value;
+                        string GetYGYaoQingYonghu = _configuration.GetSection("GetYGYaoQingYonghu").Value;
+                        Uri postUrl2 = new Uri(huiyuanurl + GetYGYaoQingYonghu);
+
+                        JObject questions2 = new JObject();
+                        questions2.Add("UserID", userList[i].Id);
+                        questions2.Add("StartTime", dateminkaoqin.ToString("yyyy-MM-dd HH:mm:ss"));
+                        questions2.Add("EndTime", datemaxkaoqin.ToString("yyyy-MM-dd HH:mm:ss"));
+
+                        string requestJson2 = questions2.ToString();
+                        string result2 = string.Empty;
+
+                        using (HttpContent httpContent = new StringContent(requestJson2))
+                        {
+                            httpContent.Headers.ContentType = new MediaTypeHeaderValue("application/json");
+
+                            var httpClient2 = _clientFactory.CreateClient();
+                            httpClient2.Timeout = new TimeSpan(0, 0, 10);
+                            var Result2 = await httpClient2.PostAsync(postUrl2, httpContent);
+                            result2 = Result2.Content.ReadAsStringAsync().Result;
+                        }
+
+                        _logger.LogInformation("result2:" + result2);
+                        JObject jobjectresult = (JObject)JsonConvert.DeserializeObject(result2);
+
+                        if (jobjectresult["code"] != null && jobjectresult["code"].ToString() == "1")
+                        {
+                            
+                            zhucehuiyuansyue = JsonConvert.DeserializeObject<List<YaoQingYongHuDTO>>(jobjectresult["data"].ToString());
+
+                        }
+                        
+                    }
+                    catch (Exception ex)
+                    {
+
+                    }
+
+
+                    //var qianyueDTOsyue = _cooperatecustomCustomerService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    if (zhucehuiyuansyue != null && zhucehuiyuansyue.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = zhucehuiyuansyue.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+
+                    #region 鏂板绛剧害瀹㈡埛
+
+                    var qianyueDTOsyue = _cooperatecustomCustomerService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    if (qianyueDTOsyue != null && qianyueDTOsyue.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = qianyueDTOsyue.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+                    #region 涓婇棬鎷滆瀹㈡埛
+
+                    var cooperVisitDTOs = _cooperVisitService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin).Where(x => x.VisType == "02").ToList();
+                    var intentionVisitDTOsshangmen = _intentionVisitService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin).Where(x => x.VisType == "02").ToList();
+                    if (  cooperVisitDTOs.Count > 0 || intentionVisitDTOsshangmen.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = 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);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+                    #region 鏂伴椈璧勮
+                    //鏈湀鏁伴噺
+                    DtChannelArticleNewsDTOSearch searchEntity1 = new DtChannelArticleNewsDTOSearch();
+                    searchEntity1.EndTime = datemaxkaoqin;
+                    searchEntity1.AddTime = dateminkaoqin;
+                    searchEntity1.UserName = userList[i].UserSn;
+                    searchEntity1.CategoryId = 3;
+                    var dtChannelArticleNewsDTOs = _dtChannelArticleNewsService.GetList(searchEntity1);
+
+                    if (dtChannelArticleNewsDTOs != null && dtChannelArticleNewsDTOs.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = dtChannelArticleNewsDTOs.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+                    #region 鍏稿瀷妗堜緥
+                    //鏈湀鏁伴噺
+                    searchEntity1 = new DtChannelArticleNewsDTOSearch();
+                    searchEntity1.EndTime = datemaxkaoqin;
+                    searchEntity1.AddTime = dateminkaoqin;
+                    searchEntity1.UserName = userList[i].UserSn;
+                    searchEntity1.CategoryId = 85;
+                    var dianxinanDTOs = _dtChannelArticleNewsService.GetList(searchEntity1);
+
+                    if (dianxinanDTOs != null && dianxinanDTOs.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = dianxinanDTOs.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+                    #region 鏀块噰鐭ヨ瘑
+                    //鏈湀鏁伴噺
+                    searchEntity1 = new DtChannelArticleNewsDTOSearch();
+                    searchEntity1.EndTime = datemaxkaoqin;
+                    searchEntity1.AddTime = dateminkaoqin;
+                    searchEntity1.UserName = userList[i].UserSn;
+                    searchEntity1.CategoryId = 73;
+                    var zhengcaizhishiDTOs = _dtChannelArticleNewsService.GetList(searchEntity1);
+
+                    if (zhengcaizhishiDTOs != null && zhengcaizhishiDTOs.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = zhengcaizhishiDTOs.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+                    #region 鏂板灏忛噰闂
+
+                    var xinzengwendaDTOsyue = _liaotianService.GetListsalary(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    if (xinzengwendaDTOsyue != null && xinzengwendaDTOsyue.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = xinzengwendaDTOsyue.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+                    #region 瀹℃牳灏忛噰绛旈棶
+
+                    var shenhewendaDTOsyue = _liaotianService.GetListsalaryshenhe(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    if (shenhewendaDTOsyue != null && shenhewendaDTOsyue.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")
+                                {
+                                    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")
+                                {
+                                    decimal renwujishu = jixiaotichengfangan.Renwu.Value;
+                                    if (jixiaotichengfangan.Tichengstandard == "01")
+                                    {
+                                        decimal youxiaojijian = shenhewendaDTOsyue.Count - renwujishu;
+                                        if (youxiaojijian > 0)
+                                        {
+                                            hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                                        }
+
+                                    }
+                                }
+                            }
+
+                        }
+                    }
+                    #endregion
+
+                    #region 褰曞叆瀹㈡埛绛惧崟
+
+                    //var cooperatecustomCustomers = _cooperatecustomCustomerService.GetListsalaryqiandan(userList[i].Id, dateminkaoqin, datemaxkaoqin);
+                    // if (cooperatecustomCustomers != null && cooperatecustomCustomers.Count > 0)
+                    // {
+                    //     var jijianidddd = fiPiecerateDTOs.Where(x => x.Standard == "D" && 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")
+                    //             {
+                    //                 decimal renwujishu = admAttendanceDTO.Yingchuqin * jixiaotichengfangan.Renwu.Value;
+                    //                 if (jixiaotichengfangan.Tichengstandard == "01")
+                    //                 {
+                    //                     decimal youxiaojijian = cooperatecustomCustomers.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 = cooperatecustomCustomers.Count - renwujishu;
+                    //                     if (youxiaojijian > 0)
+                    //                     {
+                    //                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian, 2);
+                    //                     }
+
+                    //                 }
+                    //             }
+                    //         }
+                    //     }
+                    // }
                     #endregion
 
 
@@ -1529,7 +2579,7 @@
 
                     #region 鍥句功閿�鍞�
                     var cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "01").ToList();
-                    var jijianid = fiPiecerateDTOs.Where(x => x.Standard == "D" && x.Project == "鍥句功閿�鍞�").FirstOrDefault();
+                    var jijianid = fiPiecerateDTOs.Where(x =>   x.Project == "鍥句功閿�鍞�").FirstOrDefault();
                     if (jijianid != null && cooperOrdertushu.Count>0)
                     {
                       var jixiaotichengfangan =    hrJixiaotichengThis.Where(x => x.PiecerateId == jijianid.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
@@ -1569,10 +2619,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian* new decimal(0.01), 2);
@@ -1587,10 +2637,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -1603,7 +2653,7 @@
 
                     #region   鏀块噰鍜ㄨ
                     cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "02").ToList();
-                    jijianid = fiPiecerateDTOs.Where(x => x.Standard == "D" && x.Project == "鏀块噰鍜ㄨ").FirstOrDefault();
+                    jijianid = fiPiecerateDTOs.Where(x =>   x.Project == "鏀块噰鍜ㄨ").FirstOrDefault();
                     if (jijianid != null && cooperOrdertushu.Count > 0)
                     {
                         var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianid.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
@@ -1643,10 +2693,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -1661,10 +2711,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -1678,7 +2728,7 @@
 
                     #region   鏍囦功鍒朵綔璁㈠崟
                     cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "03").ToList();
-                    jijianid = fiPiecerateDTOs.Where(x => x.Standard == "D" && x.Project == "鏍囦功鍒朵綔璁㈠崟").FirstOrDefault();
+                    jijianid = fiPiecerateDTOs.Where(x =>   x.Project == "鏍囦功鍒朵綔璁㈠崟").FirstOrDefault();
                     if (jijianid != null && cooperOrdertushu.Count > 0)
                     {
                         var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianid.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
@@ -1718,10 +2768,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -1736,10 +2786,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -1753,7 +2803,7 @@
 
                     #region   鍩硅
                     cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "04").ToList();
-                    jijianid = fiPiecerateDTOs.Where(x => x.Standard == "D" && x.Project == "鍩硅").FirstOrDefault();
+                    jijianid = fiPiecerateDTOs.Where(x =>   x.Project == "鍩硅").FirstOrDefault();
                     if (jijianid != null && cooperOrdertushu.Count > 0)
                     {
                         var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianid.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
@@ -1793,10 +2843,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -1811,10 +2861,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -1827,8 +2877,8 @@
                     #endregion
 
                     #region  濂楅浼氬憳
-                    cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "05").ToList();
-                    jijianid = fiPiecerateDTOs.Where(x => x.Standard == "D" && x.Project == "濂楅浼氬憳").FirstOrDefault();
+                    cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "05").OrderBy(x=>x.Createtime).ToList();
+                    jijianid = fiPiecerateDTOs.Where(x =>  x.Project == "濂楅浼氬憳").FirstOrDefault();
                     if (jijianid != null && cooperOrdertushu.Count > 0)
                     {
                         var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianid.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
@@ -1860,6 +2910,21 @@
                                     }
 
                                 }
+                                else if (jixiaotichengfangan.Tichengstandard == "02")
+                                {
+
+                                    if (cooperOrdertushu.Count > renwujishu)
+                                    {
+                                        List<CooperOrderDTO> cooperOrdertushuyouxiao = new List<CooperOrderDTO>();
+                                        for (int j = Convert.ToInt32(renwujishu); j < cooperOrdertushu.Count; j++)
+                                        {
+                                            cooperOrdertushuyouxiao.Add(cooperOrdertushu[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);
+                                    }
+                                }
                             }
                             else if (jixiaotichengfangan.Renwustandard == "03")
                             {
@@ -1868,10 +2933,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -1886,15 +2951,15 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
                                     }
-                                }
+                                } 
                             }
                         }
                     }
@@ -1903,7 +2968,7 @@
 
                     #region 涓撳鐢宠
                     cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "06").ToList();
-                    jijianid = fiPiecerateDTOs.Where(x => x.Standard == "D" && x.Project == "涓撳鐢宠").FirstOrDefault();
+                    jijianid = fiPiecerateDTOs.Where(x =>   x.Project == "涓撳鐢宠").FirstOrDefault();
                     if (jijianid != null && cooperOrdertushu.Count > 0)
                     {
                         var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianid.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
@@ -1943,10 +3008,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -1961,10 +3026,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -1978,7 +3043,7 @@
 
                     #region 灞ョ害绾犵悍
                     cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "07").ToList();
-                    jijianid = fiPiecerateDTOs.Where(x => x.Standard == "D" && x.Project == "灞ョ害绾犵悍").FirstOrDefault();
+                    jijianid = fiPiecerateDTOs.Where(x =>  x.Project == "灞ョ害绾犵悍").FirstOrDefault();
                     if (jijianid != null && cooperOrdertushu.Count > 0)
                     {
                         var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianid.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
@@ -2018,10 +3083,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -2036,10 +3101,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -2053,7 +3118,7 @@
 
                     #region 椋庨櫓浠g悊
                     cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "08").ToList();
-                    jijianid = fiPiecerateDTOs.Where(x => x.Standard == "D" && x.Project == "椋庨櫓浠g悊").FirstOrDefault();
+                    jijianid = fiPiecerateDTOs.Where(x =>  x.Project == "椋庨櫓浠g悊").FirstOrDefault();
                     if (jijianid != null && cooperOrdertushu.Count > 0)
                     {
                         var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianid.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
@@ -2093,10 +3158,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -2111,10 +3176,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -2128,7 +3193,7 @@
 
                     #region 杞欢閿�鍞彁鎴�
                     cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "09").ToList();
-                    jijianid = fiPiecerateDTOs.Where(x => x.Standard == "D" && x.Project == "杞欢閿�鍞彁鎴�").FirstOrDefault();
+                    jijianid = fiPiecerateDTOs.Where(x =>   x.Project == "杞欢閿�鍞彁鎴�").FirstOrDefault();
                     if (jijianid != null && cooperOrdertushu.Count > 0)
                     {
                         var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianid.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
@@ -2168,10 +3233,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -2186,10 +3251,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -2203,7 +3268,7 @@
 
                     #region 鍏朵粬涓氬姟
                     cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "10").ToList();
-                    jijianid = fiPiecerateDTOs.Where(x => x.Standard == "D" && x.Project == "鍏朵粬涓氬姟").FirstOrDefault();
+                    jijianid = fiPiecerateDTOs.Where(x =>   x.Project == "鍏朵粬涓氬姟").FirstOrDefault();
                     if (jijianid != null && cooperOrdertushu.Count > 0)
                     {
                         var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianid.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
@@ -2243,10 +3308,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -2261,10 +3326,10 @@
                                 {
                                     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;
+                                    //var dingdanyouhui = cooperOrdertushu.Sum(x => x.Youhui);
+                                    //var dingdanyouhuizhenshi = dingdanyouhui.HasValue ? dingdanyouhui.Value : 0;
 
-                                    decimal youxiaojijian = dingdanjinezhenshi - dingdanyouhuizhenshi - renwujishu;
+                                    decimal youxiaojijian = dingdanjinezhenshi - renwujishu;
                                     if (youxiaojijian > 0)
                                     {
                                         hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
@@ -2275,6 +3340,82 @@
                     }
 
                     #endregion
+
+                    #region 鏁版嵁鍒嗘瀽
+                    cooperOrdertushu = cooperOrderDTOs.Where(x => x.OrderType == "11").ToList();
+                    jijianid = fiPiecerateDTOs.Where(x => x.Project == "鏁版嵁鍒嗘瀽").FirstOrDefault();
+                    if (jijianid != null && cooperOrdertushu.Count > 0)
+                    {
+                        var jixiaotichengfangan = hrJixiaotichengThis.Where(x => x.PiecerateId == jijianid.Id).OrderByDescending(x => x.Effecttime).FirstOrDefault();
+                        if (jixiaotichengfangan != null && jixiaotichengfangan.Ticheng.HasValue && jixiaotichengfangan.Renwu.HasValue)
+                        {
+                            if (jixiaotichengfangan.Renwustandard == "01")
+                            {
+                                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")
+                            {
+                                decimal renwujishu = 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 == "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)
+                                    {
+                                        hrSalaryDTO.Jixiaoticheng += Math.Round(jixiaotichengfangan.Ticheng.Value * youxiaojijian * new decimal(0.01), 2);
+                                    }
+                                }
+
+                            }
+                            else if (jixiaotichengfangan.Renwustandard == "04")
+                            {
+                                decimal renwujishu = 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);
+                                    }
+                                }
+                            }
+                        }
+                    }
+
+                    #endregion
+
                 }
 
 
@@ -2300,7 +3441,59 @@
                 decimal peichang = hrSalaryDTO.Peichang.HasValue ? hrSalaryDTO.Peichang.Value : 0;
                 decimal jiucuo = hrSalaryDTO.Jiucuo.HasValue ? hrSalaryDTO.Jiucuo.Value : 0;
 
-                yingnashuie = jibengongzi + baomifei + gongzuobutie + jiabangongzi + shebao + dianhuabutie + quanqinjiang + jiaotngbutie + jixiaoticheng + jiangjin + bufagongzi - shebaokou  - dianhuafei - queqin - fakuan - peichang + jiucuo - geshuiqizheng;
+                //璁$畻淇濆簳骞磋柂
+                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)
+                    {
+                        jixinue = new DateTime(userList[i].Indate.Value.AddMonths(1).Year, userList[i].Indate.Value.AddMonths(1).Month, 1);
+                    }
+                    int months = ((datemaxkaoqin.Year - jixinue.Year) * 12) + datemaxkaoqin.Month - jixinue.Month;
+
+                    if(months % 12>=1 && months % 12 == 0)
+                    {
+                        decimal baodinianxin = 0;
+                        //鏌ヨ杩囧幓12涓湀鐨勫伐璧�
+                        for(int z = 1; z <= 12; z++)
+                        {
+                            var hrSalaryDTO1 = _hrSalaryService.GetListByUser(userList[i].Id, dateminkaoqin.AddMonths(-z).Year, dateminkaoqin.AddMonths(-z).Month);
+                            if (hrSalaryDTO1 != null)
+                            {
+                                decimal jibengongzi1 = hrSalaryDTO1.Jibengongzi.HasValue ? hrSalaryDTO1.Jibengongzi.Value : 0;
+                                decimal baomifei1 = hrSalaryDTO1.Baomifei.HasValue ? hrSalaryDTO1.Baomifei.Value : 0;
+                                decimal gongzuobutie1 = hrSalaryDTO1.Gongzuobutie.HasValue ? hrSalaryDTO1.Gongzuobutie.Value : 0;
+                                decimal jiabangongzi1 = hrSalaryDTO1.Jiabangongzi.HasValue ? hrSalaryDTO1.Jiabangongzi.Value : 0;
+                                decimal shebao1 = hrSalaryDTO1.Shebao.HasValue ? hrSalaryDTO1.Shebao.Value : 0;
+                                decimal dianhuabutie1 = hrSalaryDTO1.Dianhuabutie.HasValue ? hrSalaryDTO1.Dianhuabutie.Value : 0;
+                                decimal quanqinjiang1 = hrSalaryDTO1.Quanqinjiang.HasValue ? hrSalaryDTO1.Quanqinjiang.Value : 0;
+                                decimal jiaotngbutie1 = hrSalaryDTO1.Jiaotngbutie.HasValue ? hrSalaryDTO1.Jiaotngbutie.Value : 0;
+                                decimal jixiaoticheng1 = hrSalaryDTO1.Jixiaoticheng.HasValue ? hrSalaryDTO1.Jixiaoticheng.Value : 0;
+                                decimal jiangjin1 = hrSalaryDTO1.Jiangjin.HasValue ? hrSalaryDTO1.Jiangjin.Value : 0;
+                                decimal bufagongzi1 = hrSalaryDTO1.Bufagongzi.HasValue ? hrSalaryDTO1.Bufagongzi.Value : 0;
+                                decimal shebaokou1 = hrSalaryDTO1.Shebaokou.HasValue ? hrSalaryDTO1.Shebaokou.Value : 0;
+
+                                decimal dianhuafei1 = hrSalaryDTO1.Dianhuafei.HasValue ? hrSalaryDTO1.Dianhuafei.Value : 0;
+                                decimal queqin1 = hrSalaryDTO1.Queqin.HasValue ? hrSalaryDTO1.Queqin.Value : 0;
+                                decimal fakuan1 = hrSalaryDTO1.Fakuan.HasValue ? hrSalaryDTO1.Fakuan.Value : 0;
+                                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 += jibengongzi + baomifei + gongzuobutie + jiabangongzi + shebao + quanqinjiang + jiaotngbutie + jixiaoticheng + jiangjin + bufagongzi + jiucuo;
+                        if(baodinianxin < userList[i].miniyearsalary.Value)
+                        {
+                            jiucuo = userList[i].miniyearsalary.Value - baodinianxin;
+                        }
+                    }    
+                }
+
+
+
+
+                yingnashuie = jibengongzi + baomifei + gongzuobutie + jiabangongzi + shebao  + quanqinjiang + jiaotngbutie + jixiaoticheng + jiangjin + bufagongzi - shebaokou + ( (dianhuabutie - dianhuafei)<=0? (dianhuabutie - dianhuafei) : 0) - queqin - fakuan - peichang + jiucuo - geshuiqizheng;
 
 
                 hrSalaryDTO.Geshui = 0;
@@ -2389,13 +3582,13 @@
                 }
                 decimal geshui = hrSalaryDTO.Geshui.HasValue ? hrSalaryDTO.Geshui.Value : 0;
 
-                hrSalaryDTO.Daozhanggongzi += jibengongzi + baomifei + gongzuobutie + jiabangongzi + shebao + dianhuabutie + quanqinjiang + jiaotngbutie + jixiaoticheng + jiangjin + bufagongzi - shebaokou - geshui - dianhuafei - queqin - fakuan - peichang + jiucuo;
+                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.Yufagongzi = userList[i].advancewages;
 
-                if (userList[i].advancewages.HasValue)
+                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);
@@ -2405,6 +3598,10 @@
                     }
 
                     hrSalaryDTO.Yufagongziheji += (hrSalaryDTO.Daozhanggongzi- hrSalaryDTO.Yufagongzi);
+                    if (hrSalaryDTO.Daozhanggongzi < hrSalaryDTO.Yufagongzi)
+                    {
+                        hrSalaryDTO.Daozhanggongzi = hrSalaryDTO.Yufagongzi;
+                    }
                 }
                 hrSalaryDTO.RecStatus = "A";
                 hrSalaryDTO.Islock = "D";
@@ -2418,6 +3615,30 @@
 
 
 
+        //璁$畻鏄惁娑ㄥ伐榫勫伐璧�
+        public void jisuangonglinggongzi()
+        {
+            _logger.LogInformation("璁$畻鏄惁娑ㄥ伐榫勫伐璧�");
+            List<PltUserDTO> userList = _userService.GetList();//.Where(x => x.UserSn == "yang").ToList();
+            foreach(var userDTO in userList)
+            {
+                if (userDTO.senioritywages.HasValue && userDTO.Indate.HasValue)
+                {
+                    int year =  DateTime.Now.Year - (userDTO.Indate.Value.Year+1);
+                    if (userDTO.Indate.Value.Month==1 && userDTO.Indate.Value.Day == 1)
+                    {
+                          year =  DateTime.Now.Year - userDTO.Indate.Value.Year ;
+                    }
+                    if ( year >= 1)
+                    {
+                        userDTO.BasicPrice += userDTO.senioritywages.Value;
+                        _userService.savePltUser(userDTO);
+                        _logger.LogInformation(userDTO.Name +"娑ㄥ伐榫勫伐璧�"+ userDTO.senioritywages.HasValue +" 涔嬪悗鏈堣柂" + userDTO.BasicPrice);
+                    }
+                }
+            }
+        }
+
         public AdmAskLeaveDTO jisianChecktime(DateTime StratTime, DateTime EndTime)
         {
             //string dateDiff = null;
@@ -2428,6 +3649,8 @@
             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();
 
             //姣忓ぉ鐨勮�冨嫟鏃堕棿鐐�
             string[] WorkingStart = admAttendanceRuleDTO.WorkingStart.Split('.');
@@ -2537,9 +3760,11 @@
                     }
                     else
                     {
+                        
 
                         //鏄惁璋冧紤鏃�  璋冧紤鏃ラ渶瑕佷笂鐝�
-                        if (tiaoxiuri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date))
+                        if (tiaoxiuri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date) 
+                            || jiabanri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date))
                         {
                             if (StratTime <= StratTimeWorkingStart)
                             {
@@ -2635,7 +3860,8 @@
                     {
 
                         //鏄惁璋冧紤鏃�  璋冧紤鏃ラ渶瑕佷笂鐝�
-                        if (tiaoxiuri.Exists(x => x.ValueStart <= EndTime.Date && x.ValueEnd >= EndTime.Date))
+                        if (tiaoxiuri.Exists(x => x.ValueStart <= EndTime.Date && x.ValueEnd >= EndTime.Date)
+                            || jiabanri.Exists(x => x.ValueStart <= EndTime.Date && x.ValueEnd >= EndTime.Date))
                         {
                             if (EndTime >= EndTimeOffworkEnd)
                             {
@@ -2697,7 +3923,8 @@
                     {
 
                         //鏄惁璋冧紤鏃�  璋冧紤鏃ラ渶瑕佷笂鐝�
-                        if (tiaoxiuri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date))
+                        if (tiaoxiuri.Exists(x => x.ValueStart <= dateTimenow.Date && x.ValueEnd >= dateTimenow.Date)
+                            || jiabanri.Exists(x => x.ValueStart <= dateTimenow.Date && x.ValueEnd >= dateTimenow.Date))
                         {
                             LavehTime += shangbanshijian;
                         }
@@ -2726,7 +3953,8 @@
                     else
                     {
                         //鏄惁璋冧紤鏃�  璋冧紤鏃ラ渶瑕佷笂鐝�
-                        if (tiaoxiuri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date))
+                        if (tiaoxiuri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date)
+                            || jiabanri.Exists(x => x.ValueStart <= StratTime.Date && x.ValueEnd >= StratTime.Date))
                         {
                             LavehTime -= shangbanshijian;
                         }

--
Gitblit v1.9.1