134 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C#
		
	
	
	
		
		
			
		
	
	
			134 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			C#
		
	
	
	
| 
								 | 
							
								using System.Collections.Generic;
							 | 
						|||
| 
								 | 
							
								using System.Linq;
							 | 
						|||
| 
								 | 
							
								using System;
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								namespace BLL
							 | 
						|||
| 
								 | 
							
								{
							 | 
						|||
| 
								 | 
							
								    public static class APIPageDataService
							 | 
						|||
| 
								 | 
							
								    {
							 | 
						|||
| 
								 | 
							
								        #region 获取当前人数
							 | 
						|||
| 
								 | 
							
								        /// <summary>
							 | 
						|||
| 
								 | 
							
								        /// 获取当前人数
							 | 
						|||
| 
								 | 
							
								        /// </summary>
							 | 
						|||
| 
								 | 
							
								        /// <param name="projectId">项目ID</param>
							 | 
						|||
| 
								 | 
							
								        /// <returns></returns>
							 | 
						|||
| 
								 | 
							
								        public static List<Model.PageDataPersonInOutItem> getPersonNum(string projectId, DateTime dateValue)
							 | 
						|||
| 
								 | 
							
								        {
							 | 
						|||
| 
								 | 
							
								            using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
							 | 
						|||
| 
								 | 
							
								            {
							 | 
						|||
| 
								 | 
							
								                List<Model.PageDataPersonInOutItem> getSiteInOutList = new List<Model.PageDataPersonInOutItem>();
							 | 
						|||
| 
								 | 
							
								                var getDayAll = from x in db.SitePerson_PersonInOutNow
							 | 
						|||
| 
								 | 
							
								                                where x.ProjectId == projectId && x.ChangeTime.Value.Year == dateValue.Year && x.ChangeTime.Value.Month == dateValue.Month
							 | 
						|||
| 
								 | 
							
								                                && x.ChangeTime.Value.Day == dateValue.Day
							 | 
						|||
| 
								 | 
							
								                                select x;
							 | 
						|||
| 
								 | 
							
								                if (getDayAll.Count() > 0)
							 | 
						|||
| 
								 | 
							
								                {
							 | 
						|||
| 
								 | 
							
								                    var getInMaxs = from x in getDayAll
							 | 
						|||
| 
								 | 
							
								                                    group x by x.PersonId into g
							 | 
						|||
| 
								 | 
							
								                                    select new Model.PageDataPersonInOutItem
							 | 
						|||
| 
								 | 
							
								                                    {
							 | 
						|||
| 
								 | 
							
								                                        PersonId = g.First().PersonId,
							 | 
						|||
| 
								 | 
							
								                                        ChangeTime = g.Max(x => x.ChangeTime),
							 | 
						|||
| 
								 | 
							
								                                        IsIn = g.First().IsIn,
							 | 
						|||
| 
								 | 
							
								                                        PostType = g.First().PostType
							 | 
						|||
| 
								 | 
							
								                                    };
							 | 
						|||
| 
								 | 
							
								                    if (getInMaxs.Count() > 0)
							 | 
						|||
| 
								 | 
							
								                    {
							 | 
						|||
| 
								 | 
							
								                        getSiteInOutList = getInMaxs.Where(x => x.IsIn == true).ToList();
							 | 
						|||
| 
								 | 
							
								                    }
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								                return getSiteInOutList;
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								        #endregion
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								        #region 获取当前人工时
							 | 
						|||
| 
								 | 
							
								        /// <summary>
							 | 
						|||
| 
								 | 
							
								        /// 获取当前人工时
							 | 
						|||
| 
								 | 
							
								        /// </summary>
							 | 
						|||
| 
								 | 
							
								        /// <param name="projectId">项目ID</param>
							 | 
						|||
| 
								 | 
							
								        /// <returns></returns>
							 | 
						|||
| 
								 | 
							
								        public static int getSafeHours(string projectId)
							 | 
						|||
| 
								 | 
							
								        {
							 | 
						|||
| 
								 | 
							
								            using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
							 | 
						|||
| 
								 | 
							
								            {
							 | 
						|||
| 
								 | 
							
								                int safeHours = 0;
							 | 
						|||
| 
								 | 
							
								                var getPersonInOutNumber = db.SitePerson_PersonInOutNumber.FirstOrDefault(x => x.ProjectId == projectId && x.InOutDate.Year == DateTime.Now.Year
							 | 
						|||
| 
								 | 
							
								                     && x.InOutDate.Month == DateTime.Now.Month && x.InOutDate.Day == DateTime.Now.Day);
							 | 
						|||
| 
								 | 
							
								                if (getPersonInOutNumber != null)
							 | 
						|||
| 
								 | 
							
								                {                    //// 获取工时                        
							 | 
						|||
| 
								 | 
							
								                    safeHours = getPersonInOutNumber.WorkHours ?? 0;
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								                else
							 | 
						|||
| 
								 | 
							
								                {
							 | 
						|||
| 
								 | 
							
								                    safeHours = getSafeWorkTime(projectId);
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								                return safeHours;
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								        #endregion
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								        /// <summary>
							 | 
						|||
| 
								 | 
							
								        ///  获取当前人工时
							 | 
						|||
| 
								 | 
							
								        /// </summary>
							 | 
						|||
| 
								 | 
							
								        /// <returns></returns>
							 | 
						|||
| 
								 | 
							
								        public static int getSafeWorkTime(string projectId)
							 | 
						|||
| 
								 | 
							
								        {
							 | 
						|||
| 
								 | 
							
								            Model.SGGLDB db = Funs.DB;
							 | 
						|||
| 
								 | 
							
								           int SafeHours = 0;
							 | 
						|||
| 
								 | 
							
								            //// 查找当前项目 最新的人工时数量记录
							 | 
						|||
| 
								 | 
							
								            int getMaxWorkHours = db.SitePerson_PersonInOutNumber.Where(x => x.ProjectId == projectId).Max(x => x.WorkHours) ?? 0;
							 | 
						|||
| 
								 | 
							
								            var getAllPersonInOutList = from x in db.SitePerson_PersonInOutNow
							 | 
						|||
| 
								 | 
							
								                                        where x.ProjectId == projectId && x.ChangeTime.Value.Year == DateTime.Now.Year && x.ChangeTime.Value.Month == DateTime.Now.Month
							 | 
						|||
| 
								 | 
							
								                                        && x.ChangeTime.Value.Day == DateTime.Now.Day
							 | 
						|||
| 
								 | 
							
								                                        select x;
							 | 
						|||
| 
								 | 
							
								            var getPersonOutTimes = getAllPersonInOutList.Where(x => x.IsIn == false);
							 | 
						|||
| 
								 | 
							
								            var getInLists = getAllPersonInOutList.Where(x => x.IsIn == true);
							 | 
						|||
| 
								 | 
							
								            if (getPersonOutTimes.Count() > 0)
							 | 
						|||
| 
								 | 
							
								            {
							 | 
						|||
| 
								 | 
							
								                List<string> personIdList = new List<string>();
							 | 
						|||
| 
								 | 
							
								                foreach (var item in getPersonOutTimes)
							 | 
						|||
| 
								 | 
							
								                {
							 | 
						|||
| 
								 | 
							
								                    var getMaxInTime = getInLists.Where(x => x.ChangeTime < item.ChangeTime
							 | 
						|||
| 
								 | 
							
								                                && x.PersonId == item.PersonId && x.ChangeTime.Value.AddDays(1) >= item.ChangeTime).Max(x => x.ChangeTime);
							 | 
						|||
| 
								 | 
							
								                    if (getMaxInTime.HasValue)
							 | 
						|||
| 
								 | 
							
								                    {
							 | 
						|||
| 
								 | 
							
								                        SafeHours += Convert.ToInt32((item.ChangeTime - getMaxInTime).Value.TotalMinutes);
							 | 
						|||
| 
								 | 
							
								                    }
							 | 
						|||
| 
								 | 
							
								                    else
							 | 
						|||
| 
								 | 
							
								                    {
							 | 
						|||
| 
								 | 
							
								                        personIdList.Add(item.PersonId);
							 | 
						|||
| 
								 | 
							
								                    }
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								                if (personIdList.Count() > 0)
							 | 
						|||
| 
								 | 
							
								                {
							 | 
						|||
| 
								 | 
							
								                    SafeHours += (personIdList.Distinct().Count() * 8 * 60);
							 | 
						|||
| 
								 | 
							
								                }
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								            SafeHours = Convert.ToInt32((SafeHours) * 1.0 / 60) + getMaxWorkHours;
							 | 
						|||
| 
								 | 
							
								            return SafeHours;
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								
							 | 
						|||
| 
								 | 
							
								        #region 获取日进场人数
							 | 
						|||
| 
								 | 
							
								        /// <summary>
							 | 
						|||
| 
								 | 
							
								        /// 获取当前人数
							 | 
						|||
| 
								 | 
							
								        /// </summary>
							 | 
						|||
| 
								 | 
							
								        /// <param name="projectId">项目ID</param>
							 | 
						|||
| 
								 | 
							
								        /// <returns></returns>
							 | 
						|||
| 
								 | 
							
								        public static int getPersonInNowNum(string projectId, DateTime dateValue)
							 | 
						|||
| 
								 | 
							
								        {
							 | 
						|||
| 
								 | 
							
								            using (Model.SGGLDB db = new Model.SGGLDB(Funs.ConnString))
							 | 
						|||
| 
								 | 
							
								            {
							 | 
						|||
| 
								 | 
							
								                var getDayAll = from x in db.SitePerson_PersonInOutNow
							 | 
						|||
| 
								 | 
							
								                                where x.ProjectId == projectId && x.ChangeTime.Value.Year == dateValue.Year && x.ChangeTime.Value.Month == dateValue.Month
							 | 
						|||
| 
								 | 
							
								                                && x.ChangeTime.Value.Day == dateValue.Day && x.IsIn == true
							 | 
						|||
| 
								 | 
							
								                                select x;
							 | 
						|||
| 
								 | 
							
								                return getDayAll.Select(x=>x.PersonId).Distinct().Count(); ;
							 | 
						|||
| 
								 | 
							
								            }
							 | 
						|||
| 
								 | 
							
								        }
							 | 
						|||
| 
								 | 
							
								        #endregion
							 | 
						|||
| 
								 | 
							
								    }
							 | 
						|||
| 
								 | 
							
								}
							 |