using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Collections;
namespace BLL
{
    /// 
    /// 专项检查
    /// 
    public static class Check_CheckSpecialService
    {
        /// 
        /// 根据专项检查ID获取专项检查信息
        /// 
        /// 
        /// 
        public static Model.Check_CheckSpecial GetCheckSpecialByCheckSpecialId(string checkSpecialId)
        {
            return Funs.DB.Check_CheckSpecial.FirstOrDefault(e => e.CheckSpecialId == checkSpecialId);
        }
        /// 
        /// 根据时间段获取专项检查信息集合
        /// 
        /// 
        /// 
        /// 
        /// 
        public static int GetCountByCheckTime(DateTime startTime, DateTime endTime, string projectId)
        {
            return (from x in Funs.DB.Check_CheckSpecial where x.CheckTime >= startTime && x.CheckTime < endTime && x.ProjectId == projectId select x).Count();
        }
        /// 
        /// 根据时间段获取专项检查集合
        /// 
        /// 开始时间
        /// 结束时间
        /// 项目号
        /// 专项检查集合
        public static List GetListByCheckTime(DateTime startTime, DateTime endTime, string projectId)
        {
            return (from x in Funs.DB.Check_CheckSpecial where x.CheckTime >= startTime && x.CheckTime < endTime && x.ProjectId == projectId select x).ToList();
        }
        /// 
        /// 根据时间段获取已完成的专项检查整改数量
        /// 
        /// 开始时间
        /// 结束时间
        /// 项目号
        /// 已完成的专项检查整改数量
        public static int GetIsOKViolationCountByCheckTime(DateTime startTime, DateTime endTime, string projectId)
        {
            using (Model.SUBQHSEDB db = new Model.SUBQHSEDB(Funs.ConnString))
            {
                return (from x in db.Check_CheckSpecial
                        join y in db.Check_CheckSpecialDetail on x.CheckSpecialId equals y.CheckSpecialId
                        where x.CheckTime >= startTime && x.CheckTime <= endTime && x.ProjectId == projectId && y.CompleteStatus != null && y.CompleteStatus == true
                        select y).Count();
            }
        }
        /// 
        /// 添加安全专项检查
        /// 
        /// 
        public static void AddCheckSpecial(Model.Check_CheckSpecial checkSpecial)
        {
            using (Model.SUBQHSEDB db = new Model.SUBQHSEDB(Funs.ConnString))
            {
                Model.Check_CheckSpecial newCheckSpecial = new Model.Check_CheckSpecial
                {
                    CheckSpecialId = checkSpecial.CheckSpecialId,
                    CheckSpecialCode = checkSpecial.CheckSpecialCode,
                    ProjectId = checkSpecial.ProjectId,
                    CheckPerson = checkSpecial.CheckPerson,
                    CheckTime = checkSpecial.CheckTime,
                    ScanUrl = checkSpecial.ScanUrl,
                    DaySummary = checkSpecial.DaySummary,
                    PartInUnits = checkSpecial.PartInUnits,
                    PartInPersons = checkSpecial.PartInPersons,
                    PartInPersonIds = checkSpecial.PartInPersonIds,
                    PartInPersonNames = checkSpecial.PartInPersonNames,
                    CheckAreas = checkSpecial.CheckAreas,
                    States = checkSpecial.States,
                    CompileMan = checkSpecial.CompileMan,
                    CheckType = checkSpecial.CheckType,
                    CheckItemSetId = checkSpecial.CheckItemSetId,
                };
                db.Check_CheckSpecial.InsertOnSubmit(newCheckSpecial);
                db.SubmitChanges();
            }
            ////增加一条编码记录
            BLL.CodeRecordsService.InsertCodeRecordsByMenuIdProjectIdUnitId(BLL.Const.ProjectCheckSpecialMenuId, checkSpecial.ProjectId, null, checkSpecial.CheckSpecialId, checkSpecial.CheckTime);         
        }
        /// 
        /// 修改安全专项检查
        /// 
        /// 
        public static void UpdateCheckSpecial(Model.Check_CheckSpecial checkSpecial)
        {
            using (Model.SUBQHSEDB db = new Model.SUBQHSEDB(Funs.ConnString))
            {
                Model.Check_CheckSpecial newCheckSpecial = db.Check_CheckSpecial.FirstOrDefault(e => e.CheckSpecialId == checkSpecial.CheckSpecialId);
                if (newCheckSpecial != null)
                {
                    newCheckSpecial.CheckSpecialCode = checkSpecial.CheckSpecialCode;
                    //newCheckSpecial.ProjectId = checkSpecial.ProjectId;
                    newCheckSpecial.CheckPerson = checkSpecial.CheckPerson;
                    newCheckSpecial.CheckTime = checkSpecial.CheckTime;
                    newCheckSpecial.ScanUrl = checkSpecial.ScanUrl;
                    newCheckSpecial.DaySummary = checkSpecial.DaySummary;
                    newCheckSpecial.PartInUnits = checkSpecial.PartInUnits;
                    newCheckSpecial.PartInPersons = checkSpecial.PartInPersons;
                    newCheckSpecial.PartInPersonIds = checkSpecial.PartInPersonIds;
                    newCheckSpecial.PartInPersonNames = checkSpecial.PartInPersonNames;
                    newCheckSpecial.CheckAreas = checkSpecial.CheckAreas;
                    newCheckSpecial.States = checkSpecial.States;
                    newCheckSpecial.CheckType = checkSpecial.CheckType;
                    newCheckSpecial.CheckItemSetId = checkSpecial.CheckItemSetId;
                    db.SubmitChanges();
                }
            }
        }
        /// 
        /// 根据专项检查ID 更新专项检查状态
        /// 
        /// 
        public static void UpdateCheckSpecialStates(string checkSpecialId)
        {
            using (Model.SUBQHSEDB db = new Model.SUBQHSEDB(Funs.ConnString))
            {
                var getS = db.Check_CheckSpecial.FirstOrDefault(x => x.CheckSpecialId == checkSpecialId);
                if (getS != null && getS.States == Const.State_1)
                {
                    var getNCDetail = Funs.DB.Check_CheckSpecialDetail.FirstOrDefault(x => x.CheckSpecialId == getS.CheckSpecialId && x.CompleteStatus == false);
                    if (getNCDetail == null)
                    {
                        getS.States = Const.State_2;
                        db.SubmitChanges();
                    }
                }
            }
        }
        /// 
        /// 根据专项检查ID删除对应专项检查记录信息
        /// 
        /// 
        public static void DeleteCheckSpecial(string checkSpecialId)
        {
            using (Model.SUBQHSEDB db = new Model.SUBQHSEDB(Funs.ConnString))
            {
                var q = (from x in db.Check_CheckSpecial where x.CheckSpecialId == checkSpecialId select x).FirstOrDefault();
                if (q != null)
                {
                    ///删除编码表记录
                    BLL.CodeRecordsService.DeleteCodeRecordsByDataId(q.CheckSpecialId);
                    ////删除附件表
                    BLL.CommonService.DeleteAttachFileById(q.CheckSpecialId);
                    ////删除审核流程表
                    BLL.CommonService.DeleteFlowOperateByID(q.CheckSpecialId);
                    db.Check_CheckSpecial.DeleteOnSubmit(q);
                    db.SubmitChanges();
                }
            }
        }
        /// 
        /// 
        /// 
        /// 
        /// 
        public static string ConvertHandleStep(object CheckSpecialDetailId)
        {
            string name = string.Empty;
            if (CheckSpecialDetailId != null)
            {
                var getDetail = BLL.Check_CheckSpecialDetailService.GetCheckSpecialDetailByCheckSpecialDetailId(CheckSpecialDetailId.ToString());
                if (getDetail != null)
                {
                    if (getDetail.DataType == "1")
                    {
                        name = "下发整改单:";
                        var getRe = RectifyNoticesService.GetRectifyNoticesById(getDetail.DataId);
                        if (getRe != null)
                        {
                            name += getRe.RectifyNoticesCode;
                        }
                    }
                    else if (getDetail.DataType == "2")
                    {
                        name = "下发处罚单:";
                        var getRe = PunishNoticeService.GetPunishNoticeById(getDetail.DataId);
                        if (getRe != null)
                        {
                            name += getRe.PunishNoticeCode;
                        }
                    }
                    else if (getDetail.DataType == "3")
                    {
                        name = "下发暂停令:";
                        var getRe = Check_PauseNoticeService.GetPauseNoticeByPauseNoticeId(getDetail.DataId);
                        if (getRe != null)
                        {
                            name += getRe.PauseNoticeCode;
                        }
                    }
                }
            }
            return name;
        }
        /// 
        /// 
        /// 
        /// 
        /// 
        /// 
        public static string IssueRectification(List detailLists, Model.Check_CheckSpecial checkSpecial)
        {
            string info = string.Empty;
            if (detailLists.Count() > 0 && checkSpecial != null)
            {
                ////隐患整改单
                var getDetail1 = detailLists.Where(x => x.CompleteStatus==false);
                if (getDetail1.Count() > 0)
                {
                    var getUnitList = getDetail1.Select(x => x.UnitId).Distinct();
                    foreach (var unitItem in getUnitList)
                    {
                        var getUnitItemList = getDetail1.Where(x => x.UnitId == unitItem);
                        foreach (var item in getUnitItemList)
                        {
                            Model.HSSE_Hazard_HazardRegister register = Funs.DB.HSSE_Hazard_HazardRegister.FirstOrDefault(x => x.CheckItemDetailId == item.CheckSpecialDetailId);
                            if (register == null)
                            {
                                register = new Model.HSSE_Hazard_HazardRegister();
                            }
                            register.ProjectId = checkSpecial.ProjectId;
                            register.CheckItemDetailId = item.CheckSpecialDetailId;
                            register.ProblemTypes = "2";    //1 安全问题  2 专项巡检
                            register.RegisterTypesId = item.CheckItem;
                            // register.CheckCycle = this.ckType.SelectedValue;
                            register.IsEffective = "1";
                            register.RegisterDate = checkSpecial.CheckTime;
                            register.CheckTime = checkSpecial.CheckTime;
                            register.ResponsibleUnit = item.UnitId;
                            
                            register.Place = item.WorkArea;
                            register.RegisterDef = item.Unqualified;
                           // register.HandleIdea = item.Suggestions;
                            register.ResponsibleMan = item.HSEManage;
                            register.Risk_Level = item.RiskLevel;
                            register.Requirements = item.Suggestions;
                            register.CheckSpecialId = item.CheckSpecialId;
                            register.RectificationPeriod = item.LimitedDate;
                            register.CheckManId = checkSpecial.CompileMan;
                            //register.CutPayment = Funs.GetNewIntOrZero(this.txtCutPayment.Text.Trim());
                            register.States = "1";    //待整改
                            if (string.IsNullOrEmpty(register.HazardRegisterId))
                            {
                                register.HazardRegisterId = Guid.NewGuid().ToString();
                                var url = AttachFileService.getFileUrl(item.CheckSpecialDetailId);
                                register.ImageUrl = url;
                                SaveAttachFile(register.HazardRegisterId, BLL.Const.HSSE_HiddenRectificationListMenuId, url);
                                BLL.HSSE_Hazard_HazardRegisterService.AddHazardRegister(register);
                            }
                            else
                            { 
                                var url = AttachFileService.getFileUrl(item.CheckSpecialDetailId);
                                register.ImageUrl = url;
                                SaveAttachFile(register.HazardRegisterId, BLL.Const.HSSE_HiddenRectificationListMenuId, url);
                                BLL.HSSE_Hazard_HazardRegisterService.UpdateHazardRegister(register);
                            }
                        }
                    }
                    info += "整改已下发。";
                }
                Check_CheckSpecialService.UpdateCheckSpecial(checkSpecial);
            }
            if (!string.IsNullOrEmpty(info))
            {
                info += "请在相应办理页面提交!";
            }
            return info;
        }
        public static void SaveAttachFile(string dataId, string menuId, string url)
        {
            Model.ToDoItem toDoItem = new Model.ToDoItem
            {
                MenuId = menuId,
                DataId = dataId,
                UrlStr = url,
            };
            APIUpLoadFileService.SaveAttachUrl(toDoItem);
        }
    }
}