333 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			333 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
using APT.BaseData.Domain.Entities;
 | 
						|
using APT.BaseData.Domain.Entities.FM;
 | 
						|
using APT.BaseData.Domain.Enums;
 | 
						|
using APT.BaseData.Domain.Enums.PF;
 | 
						|
using APT.BaseData.Domain.IServices;
 | 
						|
using APT.BaseData.Domain.IServices.FM;
 | 
						|
using APT.Infrastructure.Core;
 | 
						|
using APT.MS.Domain.Entities.HM;
 | 
						|
using APT.MS.Domain.Enums;
 | 
						|
using APT.Utility;
 | 
						|
using InfluxData.Net.InfluxDb.Models.Responses;
 | 
						|
using Microsoft.AspNetCore.Mvc;
 | 
						|
using System;
 | 
						|
using System.Collections.Generic;
 | 
						|
using System.Linq;
 | 
						|
 | 
						|
namespace APT.HM.WebApi.Controllers.Api
 | 
						|
{
 | 
						|
    [Route("api/HM/HMRiskRecord")]
 | 
						|
    public partial class RiskRecordController : AuthorizeApiController<T_HM_RISK_RECORD>
 | 
						|
    {
 | 
						|
        IFMNotificationTaskService NotificationTaskService { get; set; }
 | 
						|
 | 
						|
        IPFCodeRuleService CodeRuleService { get; set; }
 | 
						|
        IFMFlowPermitService MFlowPermitService { get; set; }
 | 
						|
        IPFApproveCallBackService ApproveCallBackService { get; set; }
 | 
						|
        /// <summary>
 | 
						|
        /// 作业任务分析
 | 
						|
        /// </summary>
 | 
						|
        public RiskRecordController(IPFCodeRuleService codeRuleService, IFMNotificationTaskService notificationTaskService, IFMFlowPermitService mFlowPermitService, IPFApproveCallBackService approveCallBackService)
 | 
						|
        {
 | 
						|
            NotificationTaskService = notificationTaskService;
 | 
						|
            CodeRuleService = codeRuleService;
 | 
						|
            MFlowPermitService = mFlowPermitService;
 | 
						|
            ApproveCallBackService = approveCallBackService;
 | 
						|
        }
 | 
						|
        /// <summary>
 | 
						|
        /// 更新
 | 
						|
        /// </summary>
 | 
						|
        /// <param name="entity"></param>
 | 
						|
        /// <returns></returns>
 | 
						|
        [HttpPost, Route("FullUpdate")]
 | 
						|
        public JsonActionResult<bool> FullUpdate([FromBody] T_HM_RISK_RECORD entity)
 | 
						|
        {
 | 
						|
            return SafeExecute<bool>(() =>
 | 
						|
            {
 | 
						|
                var details = entity.Nav_Details;
 | 
						|
                var allAreas = details.Select(t => t.AREA_ID);
 | 
						|
                var users = GetEntities<T_HM_RISK_RECORD_USER>(t => t.RECORD_ID == entity.ID && allAreas.Contains(t.AREA_ID), new BaseFilter(entity.ORG_ID));
 | 
						|
                var identifyings = entity.Nav_Identifyings;
 | 
						|
                var files = entity.Nav_Files;
 | 
						|
                entity.Nav_Users = null;
 | 
						|
                entity.Nav_Identifyings = null;
 | 
						|
                entity.Nav_Files = null;
 | 
						|
                entity.Nav_Details = null;
 | 
						|
                List<T_HM_RISK_RECORD_DETAIL_WORKDUTY> workdutys = new List<T_HM_RISK_RECORD_DETAIL_WORKDUTY>();
 | 
						|
                List<T_HM_RISK_RECORD_DETAIL_EQUIPMENT> equipments = new List<T_HM_RISK_RECORD_DETAIL_EQUIPMENT>();
 | 
						|
                List<T_HM_RISK_RECORD_DETAIL_FACILITIES> facilities = new List<T_HM_RISK_RECORD_DETAIL_FACILITIES>();
 | 
						|
                details.ForEach(detail =>
 | 
						|
                {
 | 
						|
                    if (detail.Nav_EvaluateRiskRecordWorkduty != null)
 | 
						|
                    {
 | 
						|
                        workdutys.AddRange(detail.Nav_EvaluateRiskRecordWorkduty);
 | 
						|
                        detail.Nav_EvaluateRiskRecordWorkduty = null;
 | 
						|
                    }
 | 
						|
                    if (detail.Nav_EvaluateRiskRecordEquipment != null)
 | 
						|
                    {
 | 
						|
                        equipments.AddRange(detail.Nav_EvaluateRiskRecordEquipment);
 | 
						|
                        detail.Nav_EvaluateRiskRecordEquipment = null;
 | 
						|
                    }
 | 
						|
                    if (detail.Nav_EvaluateRiskRecordFacilities != null)
 | 
						|
                    {
 | 
						|
                        facilities.AddRange(detail.Nav_EvaluateRiskRecordFacilities);
 | 
						|
                        detail.Nav_EvaluateRiskRecordFacilities = null;
 | 
						|
                    }
 | 
						|
                    if(detail.LIABLE_USER_ID == null)
 | 
						|
                    {
 | 
						|
                        var liableUser = GetEntity<T_FM_USER>(t => t.DEPARTMENT_ID == detail.DEPARTMENT_LIABLE_ID && t.APPROVE_ROLE_ID == detail.POST_LIABLE_ID);
 | 
						|
                        if(liableUser != null)
 | 
						|
                        {
 | 
						|
                            detail.LIABLE_USER_ID=liableUser.ID;
 | 
						|
                        }
 | 
						|
                        else
 | 
						|
                        {
 | 
						|
                            throw new Exception("未能找到对应责任人!");
 | 
						|
                        }
 | 
						|
                    }
 | 
						|
                });
 | 
						|
                List<T_FM_NOTIFICATION_TASK> sendNotices = null;
 | 
						|
                T_FM_NOTIFICATION_TASK finishNotice = null;
 | 
						|
                if (entity.PUBLISH != null && entity.PUBLISH.Equals("SaveAndNotify"))
 | 
						|
                {
 | 
						|
                    entity.STATUS = FOPreMeetingStatusEnum.签到中;
 | 
						|
                    var noticeTitles = new List<string>();
 | 
						|
                    var noticeUserIds = new List<Guid>();
 | 
						|
                    var noticeUserNames = new List<string>();
 | 
						|
                    var noticeDataIds = new List<Guid>();
 | 
						|
                    var userDeal = users.DistinctBy(t=>t.USER_ID).Where(t => t.DEAL_STATUS == FOUserShiftStatusEnum.待处理);
 | 
						|
                    if (userDeal.Count() > 0)
 | 
						|
                    {
 | 
						|
                        var allusers = GetEntities<T_FM_USER>(null, new BaseFilter(entity.ORG_ID));
 | 
						|
                        //var allareas = GetEntities<T_HM_RISK_AREA>(null, new BaseFilter(entity.ORG_ID));
 | 
						|
                        foreach (var user in userDeal)
 | 
						|
                        {
 | 
						|
                            if (user.DEAL_STATUS != FOUserShiftStatusEnum.已处理)
 | 
						|
                            {
 | 
						|
                                var userName = allusers.Where(t => t.ID == user.USER_ID).FirstOrDefault();
 | 
						|
                                //var userArea = allareas.Where(t => t.ID == user.AREA_ID).FirstOrDefault();
 | 
						|
                                noticeUserIds.Add(user.USER_ID);
 | 
						|
                                noticeUserNames.Add(userName.NAME);
 | 
						|
                                noticeTitles.Add("危险源辨识记录待确认");
 | 
						|
                                noticeDataIds.Add(entity.ID);
 | 
						|
                            }
 | 
						|
                        }
 | 
						|
                        sendNotices = NotificationTaskService.InsertUserNoticeTaskModels(noticeTitles, noticeDataIds, entity.ORG_ID, noticeUserIds, noticeUserNames, DateTime.Now, DateTime.Parse(DateTime.Now.AddDays(1).ToShortDateString() + " 23:59:59"), 1, "HM063_SHOWPRINT");
 | 
						|
                        finishNotice = NotificationTaskService.FOGetTaskFinishModel(entity.TaskID,entity.ID, "HM063_SHOWPRINT");
 | 
						|
                    }
 | 
						|
                    else
 | 
						|
                    {
 | 
						|
                        entity.STATUS = FOPreMeetingStatusEnum.审核中;
 | 
						|
                        entity.APPROVECODE = DateTime.Now.ToString("yyyyMMddHHmmss");
 | 
						|
                        MFlowPermitService.InsertApprove(entity.APPROVECODE, "HM064", "", entity.ID, "HM063_SHOWPRINT", entity.TaskID, true, () =>
 | 
						|
                        {
 | 
						|
                        }, null, entity.NOTE_TAKER_ID,null,null,null, "HM063_SHOWPRINT");
 | 
						|
                    }
 | 
						|
                }
 | 
						|
                this.UnifiedCommit(() =>
 | 
						|
                {
 | 
						|
                    if (entity != null)
 | 
						|
                        UpdateEntityNoCommit(entity);   //保存主表
 | 
						|
                    if (users != null && users.Any())
 | 
						|
                        BantchSaveEntityNoCommit(users);    //保存子表
 | 
						|
                    if (identifyings != null && identifyings.Any())
 | 
						|
                        BantchSaveEntityNoCommit(identifyings);     //保存子表
 | 
						|
                    if (files != null && files.Any())
 | 
						|
                        BantchSaveEntityNoCommit(files);        //保存子表
 | 
						|
                    if (details != null && details.Any())
 | 
						|
                        BantchSaveEntityNoCommit(details);      //保存子表
 | 
						|
                    if (workdutys != null && workdutys.Any())
 | 
						|
                        BantchSaveEntityNoCommit(workdutys);      //保存孙表
 | 
						|
                    if (equipments != null && equipments.Any())
 | 
						|
                        BantchSaveEntityNoCommit(equipments);      //保存孙表
 | 
						|
                    if (facilities != null && facilities.Any())
 | 
						|
                        BantchSaveEntityNoCommit(facilities);      //保存孙表
 | 
						|
                    if (sendNotices != null && sendNotices.Any())
 | 
						|
                        BantchSaveEntityNoCommit(sendNotices);
 | 
						|
                    if (finishNotice != null)
 | 
						|
                        UpdateEntityNoCommit(finishNotice);
 | 
						|
                });
 | 
						|
                return true;
 | 
						|
            });
 | 
						|
        }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// 获取个人的风险记录
 | 
						|
        /// </summary>
 | 
						|
        /// <param name="pageFilter"></param>
 | 
						|
        /// <returns></returns>
 | 
						|
        [HttpPost, Route("GetRiskRecord")]
 | 
						|
        public JsonActionResult<bool> GetRiskRecord([FromBody] T_HM_RISK_RECORD entity)
 | 
						|
        {
 | 
						|
            return SafeExecute<bool>(() =>
 | 
						|
            {
 | 
						|
                var model = GetEntity<T_HM_RISK_RECORD>(entity.ID.ToString());
 | 
						|
                //if (model.STATUS != FOPreMeetingStatusEnum.签到中)
 | 
						|
                //    return false;
 | 
						|
                var orgId = APT.Infrastructure.Api.AppContext.CurrentSession.OrgId;
 | 
						|
                var userId = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
 | 
						|
                var count = GetCount<T_HM_RISK_RECORD_USER>(t => t.RECORD_ID == entity.ID && t.USER_ID == userId && t.DEAL_STATUS == 0, new BaseFilter());
 | 
						|
                if (count > 0)  //该用户在该记录中是否参与且未同意则显示同意按钮
 | 
						|
                {
 | 
						|
                    return true;
 | 
						|
                }
 | 
						|
                else
 | 
						|
                {
 | 
						|
                    return false;
 | 
						|
                }
 | 
						|
            });
 | 
						|
        }
 | 
						|
 | 
						|
        /// <summary>
 | 
						|
        /// 获得单条实体数据
 | 
						|
        /// </summary>
 | 
						|
        /// <param name="filter">过滤实体</param>
 | 
						|
        /// <returns></returns>
 | 
						|
        [HttpPost, Route("FullGet")]
 | 
						|
        public JsonActionResult<T_HM_RISK_RECORD> FullGet([FromBody] KeywordFilter filter)
 | 
						|
        {
 | 
						|
            if (filter.Parameter1 == null)
 | 
						|
            {
 | 
						|
                filter.Include = new string[] { "Nav_Request", "Nav_InitiatingDepartment",
 | 
						|
                "Nav_Identifyings.Nav_Identifying", "Nav_Files.Nav_ImgFile.Nav_File","Nav_NoteTaker"
 | 
						|
                };
 | 
						|
            }
 | 
						|
            var result = WitEntity(null, filter);
 | 
						|
            var ID = new Guid(filter.FilterGroup.Rules.ToList()[0].Value.ToString());
 | 
						|
            var filter1 = new BaseFilter(filter.GetOrgId());
 | 
						|
            filter1.SelectField = new string[] { "Nav_EvaluateRiskRecordEquipment.Nav_Equipment.NAME", "Nav_EvaluateRiskRecordWorkduty.Nav_Workduty.NAME", "Nav_Area.NAME", "Nav_Identifying.NAME", "Nav_Type.NAME", "Nav_OperationStep.NAME", "Nav_LiableUser.NAME", "Nav_DepartmentLiable.NAME", "Nav_PostLiable.NAME","RISK_NAME", "RISK_PLACE" };
 | 
						|
            var detailData = GetEntities<T_HM_RISK_RECORD_DETAIL>(t => t.RECORD_ID == ID, filter1);
 | 
						|
            var record = GetEntity<T_HM_RISK_RECORD>(ID);
 | 
						|
            var filter2 = new BaseFilter(filter.GetOrgId());
 | 
						|
            filter2.SelectField = new string[] { "Nav_Area.NAME","Nav_Users.Nav_User.NAME", "Nav_Users.DEAL_STATUS", "Nav_Users.Nav_User.Nav_UserSignFiles.Nav_ImgFile.Nav_File" };
 | 
						|
            var riskUsers = GetEntities<T_HM_RISK_TASK_DETAIL>(t => t.TASK_ID == record.TASK_ID && t.RECORD_USER_ID == record.NOTE_TAKER_ID,filter2);
 | 
						|
            List<T_HM_RISK_RECORD_USER> Nav_Users = new List<T_HM_RISK_RECORD_USER>();
 | 
						|
            result.Data.Nav_Users= Nav_Users;
 | 
						|
            foreach ( var riskUser in riskUsers)
 | 
						|
            {
 | 
						|
                var userNames = "";
 | 
						|
                List<T_FM_USER_SIGN_FILE> signfile = new List<T_FM_USER_SIGN_FILE>();
 | 
						|
                foreach (var user in riskUser.Nav_Users)
 | 
						|
                {
 | 
						|
                    userNames += user.Nav_User.NAME+" ";
 | 
						|
                    signfile= user.Nav_User.Nav_UserSignFiles;
 | 
						|
                }
 | 
						|
                T_HM_RISK_AREA area = new T_HM_RISK_AREA();
 | 
						|
                T_FM_USER fmuser = new T_FM_USER();
 | 
						|
                T_HM_RISK_RECORD_USER item =new T_HM_RISK_RECORD_USER()
 | 
						|
                {
 | 
						|
                    Nav_Area = area,
 | 
						|
                    Nav_User = fmuser,
 | 
						|
                };
 | 
						|
                item.Nav_Area.NAME = riskUser.Nav_Area.NAME;
 | 
						|
                item.Nav_User.NAME = userNames;
 | 
						|
                item.Nav_User.Nav_UserSignFiles = signfile;
 | 
						|
                item.DEAL_STATUS = FOUserShiftStatusEnum.已处理;
 | 
						|
                result.Data.Nav_Users.Add(item);
 | 
						|
            }
 | 
						|
            result.Data.Nav_Details = detailData.ToList();
 | 
						|
            if (result.Data != null)
 | 
						|
            {
 | 
						|
                result.Data.Nav_Details = result.Data.Nav_Details.OrderBy(t => t.AREA_ID).ThenBy(n=>n.IDENTIFYING_ID).ThenBy(x=>x.TYPE_ID).ThenBy(c=>c.RISK_NAME).ToList();
 | 
						|
            }
 | 
						|
            return result;
 | 
						|
        }
 | 
						|
        /// <summary>
 | 
						|
        /// 同意
 | 
						|
        /// </summary>
 | 
						|
        /// <param name="id"></param>
 | 
						|
        /// <returns></returns>
 | 
						|
        [HttpPost, Route("PersonalAgree")]
 | 
						|
        public JsonActionResult<bool> PersonalAgree([FromBody] T_HM_RISK_RECORD entity)
 | 
						|
        {
 | 
						|
            return SafeExecute<bool>(() =>
 | 
						|
            {
 | 
						|
                var orgId = APT.Infrastructure.Api.AppContext.CurrentSession.OrgId;
 | 
						|
                var userId = APT.Infrastructure.Api.AppContext.CurrentSession.UserID;
 | 
						|
                var userAll = GetEntities<T_HM_RISK_RECORD_USER>(t => t.RECORD_ID == entity.ID, new BaseFilter(orgId));
 | 
						|
                var users = userAll.Where(t => t.USER_ID == userId);
 | 
						|
                foreach (var user in users)
 | 
						|
                {
 | 
						|
                    user.DEAL_STATUS = FOUserShiftStatusEnum.已处理;
 | 
						|
                }
 | 
						|
                var todoCount = userAll.Where(t => t.DEAL_STATUS == 0).Count();
 | 
						|
                #region 判断是否全部人员同意
 | 
						|
                if (todoCount == 0)
 | 
						|
                {
 | 
						|
                    var riskRecord = GetEntity<T_HM_RISK_RECORD>(entity.ID);
 | 
						|
                    riskRecord.STATUS = FOPreMeetingStatusEnum.审核中;
 | 
						|
                    MFlowPermitService.InsertApprove(DateTime.Now.ToString("yyyyMMddHHmmss"), "HM064", "", entity.ID, "HM063_SHOWPRINT", entity.TaskID, true, () =>
 | 
						|
                    {
 | 
						|
                        UpdateEntityNoCommit(riskRecord, "STATUS");
 | 
						|
                        if (users != null && users.Any())
 | 
						|
                            BantchUpdateEntityNoCommit(users, "DEAL_STATUS");
 | 
						|
                    }, null, userId);
 | 
						|
                }
 | 
						|
                else
 | 
						|
                {
 | 
						|
                    NotificationTaskService.NotificationTaskFinish(entity.TaskID, () =>
 | 
						|
                    {
 | 
						|
                        if (users != null && users.Any())
 | 
						|
                            BantchUpdateEntityNoCommit(users, "DEAL_STATUS");
 | 
						|
                    });
 | 
						|
                }
 | 
						|
                #endregion
 | 
						|
                return true;
 | 
						|
            });
 | 
						|
        }
 | 
						|
        /// <summary>
 | 
						|
        /// 审批流回调
 | 
						|
        /// </summary>
 | 
						|
        /// <param name="id"></param>
 | 
						|
        /// <returns></returns>
 | 
						|
        [HttpGet, Route("PersonalApprove")]
 | 
						|
        public JsonActionResult<bool> PersonalApprove(string id)
 | 
						|
        {
 | 
						|
            return SafeExecute<bool>(() =>
 | 
						|
            {
 | 
						|
                return ApproveCallBackService.CallBack("HM/HMRiskRecord/PersonalApprove", id);
 | 
						|
            });
 | 
						|
        }
 | 
						|
        /// <summary>
 | 
						|
        /// 审批流回调
 | 
						|
        /// </summary>
 | 
						|
        /// <param name="id"></param>
 | 
						|
        /// <returns></returns>
 | 
						|
        [HttpPost, Route("RejectUpdate")]
 | 
						|
        public JsonActionResult<bool> RejectUpdate([FromBody] T_PF_APPROVE entity)
 | 
						|
        {
 | 
						|
            return SafeExecute<bool>(() =>
 | 
						|
            {
 | 
						|
                T_PF_APPROVE modelApp = null;
 | 
						|
                List<T_PF_APPROVE_DETAIL> listAppDetail = null;
 | 
						|
                T_FM_NOTIFICATION_TASK taskFinish = null;
 | 
						|
                string Msg = string.Empty;
 | 
						|
                var record = GetEntity<T_HM_RISK_RECORD>(entity.DATA_ID, new string[] { "Nav_NoteTaker" });
 | 
						|
                var recordUsers = GetEntities<T_HM_RISK_RECORD_USER>(t => t.RECORD_ID == entity.DATA_ID && t.USER_ID != record.NOTE_TAKER_ID, new BaseFilter(record.ORG_ID));
 | 
						|
                bool ResultGetInfo = ApproveCallBackService.GetApproject(entity, ref modelApp, ref listAppDetail, ref taskFinish, ref Msg);
 | 
						|
                if (!ResultGetInfo)
 | 
						|
                    throw new Exception("驳回失败!");
 | 
						|
                foreach (var user in recordUsers)
 | 
						|
                {
 | 
						|
                    user.DEAL_STATUS = 0;
 | 
						|
                }
 | 
						|
                record.STATUS = FOPreMeetingStatusEnum.审批拒绝;
 | 
						|
                var sendNotice = NotificationTaskService.InsertUserNoticeTaskModel("风险源辨识记录-驳回", entity.DATA_ID, record.ORG_ID, (Guid)record.NOTE_TAKER_ID, record.Nav_NoteTaker.NAME, DateTime.Now, DateTime.Now.AddHours(24), 0, "HM064");
 | 
						|
                UnifiedCommit(() =>
 | 
						|
                {
 | 
						|
                    if (record != null)
 | 
						|
                        UpdateEntityNoCommit(record);   //保存主表
 | 
						|
                    if (sendNotice != null)
 | 
						|
                        AddEntityNoCommit(sendNotice);
 | 
						|
                    if (recordUsers.Any())
 | 
						|
                        BantchSaveEntityNoCommit(recordUsers);
 | 
						|
                });
 | 
						|
 | 
						|
                return true;
 | 
						|
 | 
						|
 | 
						|
            });
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |