using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace BLL
{
    /// 
    /// 四不放过
    /// 
    public static class NoFourLetoffService
    {
        public static Model.CNPCDB db = Funs.DB;
        /// 
        /// 根据主键获取四不放过
        /// 
        /// 
        /// 
        public static Model.Accident_NoFourLetoff GetNoFourLetoffById(string noFourLetoffId)
        {
            return Funs.DB.Accident_NoFourLetoff.FirstOrDefault(e => e.NoFourLetoffId == noFourLetoffId);
        }
        /// 
        /// 根据事故Id获取一个四不放过信息
        /// 
        /// 事故Id
        /// 一个四不放过实体
        public static Model.Accident_NoFourLetoff GetNoFourLetoffByAccidentHandleId(string accidentHandleId)
        {
            return Funs.DB.Accident_NoFourLetoff.FirstOrDefault(x => x.AccidentHandleId == accidentHandleId);
        }
        /// 
        /// 添加四不放过
        /// 
        /// 
        public static void AddNoFourLetoff(Model.Accident_NoFourLetoff noFourLetoff)
        {
            Model.CNPCDB db = Funs.DB;
            Model.Accident_NoFourLetoff newNoFourLetoff = new Model.Accident_NoFourLetoff
            {
                NoFourLetoffId = noFourLetoff.NoFourLetoffId,
                ProjectId = noFourLetoff.ProjectId,
                AccidentHandleId = noFourLetoff.AccidentHandleId,
                NoFourLetoffCode = noFourLetoff.NoFourLetoffCode,
                UnitId = noFourLetoff.UnitId,
                AccidentDate = noFourLetoff.AccidentDate,
                FileContents = noFourLetoff.FileContents,
                RegistUnitId = noFourLetoff.RegistUnitId,
                HeadMan = noFourLetoff.HeadMan,
                RegistDate = noFourLetoff.RegistDate
            };
            db.Accident_NoFourLetoff.InsertOnSubmit(newNoFourLetoff);
            db.SubmitChanges();
        }
        /// 
        /// 修改四不放过
        /// 
        /// 
        public static void UpdateNoFourLetoff(Model.Accident_NoFourLetoff noFourLetoff)
        {
            Model.CNPCDB db = Funs.DB;
            Model.Accident_NoFourLetoff newNoFourLetoff = db.Accident_NoFourLetoff.FirstOrDefault(e => e.NoFourLetoffId == noFourLetoff.NoFourLetoffId);
            if (newNoFourLetoff != null)
            {
                newNoFourLetoff.ProjectId = noFourLetoff.ProjectId;
                newNoFourLetoff.AccidentHandleId = noFourLetoff.AccidentHandleId;
                newNoFourLetoff.NoFourLetoffCode = noFourLetoff.NoFourLetoffCode;
                newNoFourLetoff.UnitId = noFourLetoff.UnitId;
                newNoFourLetoff.AccidentDate = noFourLetoff.AccidentDate;
                newNoFourLetoff.FileContents = noFourLetoff.FileContents;
                newNoFourLetoff.RegistUnitId = noFourLetoff.RegistUnitId;
                newNoFourLetoff.HeadMan = noFourLetoff.HeadMan;
                newNoFourLetoff.RegistDate = noFourLetoff.RegistDate;
                db.SubmitChanges();
            }
        }
        /// 
        /// 根据主键删除四不放过
        /// 
        /// 
        public static void DeleteNoFourLetoffByNoFourLetoffId(string noFourLetoffId)
        {
            Model.CNPCDB db = Funs.DB;
            Model.Accident_NoFourLetoff noFourLetoff = db.Accident_NoFourLetoff.FirstOrDefault(e => e.NoFourLetoffId == noFourLetoffId);
            if (noFourLetoff != null)
            {
                CommonService.DeleteAttachFileById(noFourLetoffId);
                ////删除审核流程表
                BLL.CommonService.DeleteFlowOperateByID(noFourLetoff.NoFourLetoffId);
                db.Accident_NoFourLetoff.DeleteOnSubmit(noFourLetoff);
                db.SubmitChanges();
            }
        }
        /// 
        /// 根据HSSE事故(含未遂)处理删除所相关的四不放过
        /// 
        /// 
        public static void DeleteNoFourLetoffByAccidentHandleId(string accidentHandleId)
        {
            Model.CNPCDB db = Funs.DB;
            var q = (from x in db.Accident_NoFourLetoff where x.AccidentHandleId == accidentHandleId select x).ToList();
            if (q!=null)
            {
                db.Accident_NoFourLetoff.DeleteAllOnSubmit(q);
                db.SubmitChanges();
            }
        }
    }
}