using DBUtility; 
 | 
using Model; 
 | 
using Newtonsoft.Json; 
 | 
using Newtonsoft.Json.Linq; 
 | 
using System; 
 | 
using System.Collections.Generic; 
 | 
using System.Data; 
 | 
using System.Linq; 
 | 
using System.Web; 
 | 
using System.Web.Http; 
 | 
using System.Windows.Forms; 
 | 
using WebAPI.Models; 
 | 
  
 | 
namespace WebAPI.Controllers.工资管理.请假申请 
 | 
{ 
 | 
    public class Pay_OutApplyBillController : ApiController 
 | 
    { 
 | 
        public DBUtility.ClsPub.Enum_BillStatus BillStatus; 
 | 
        public const string ModName = "2221";                   //单据类型 
 | 
        public const string ModCaption = "请假申请单";          //单据名称 
 | 
        public const string ModRightName = "Pay_OutApplyBill"; 
 | 
        public const string ModRightNameList = ModRightName + "List";       //列表 
 | 
        public const string ModRightNameEdit = ModRightName + "_Edit";      //编辑 
 | 
        public const string ModRightNameCheck = ModRightName + "_Check";    //审核 
 | 
        public const string ModRightNameClose = ModRightName + "_Close";    //关闭 
 | 
        public const string ModRightNameDelete = ModRightName + "_Delete";  //作废 
 | 
        public const string ModRightNameDrop = ModRightName + "_Drop";      //删除 
 | 
        public const string ModRightNameMoney = ModRightName + "_Money";    //金额 
 | 
        public const string ModRightNameQty = ModRightName + "_Qty";        //数量 
 | 
        public DataSet ds = new DataSet(); 
 | 
        private json objJsonResult = new json(); 
 | 
        SQLHelper.ClsCN oCn = new SQLHelper.ClsCN(); 
 | 
        public DAL.ClsPay_OutApplyBill oBill = new DAL.ClsPay_OutApplyBill(); 
 | 
        public DAL.ClsPay_OutApplyBill BillOld = new DAL.ClsPay_OutApplyBill(); 
 | 
  
 | 
  
 | 
        #region 请假申请单列表 
 | 
        /// <summary> 
 | 
        /// 获取请假申请单列表信息 
 | 
        /// </summary> 
 | 
        /// <returns></returns> 
 | 
        [Route("Pay_OutApplyBillController/GetPay_OutApplyBillList_Json")] 
 | 
        [HttpGet] 
 | 
        public object GetPay_OutApplyBillList_Json(string sWhere, string HMaker) 
 | 
        { 
 | 
            try 
 | 
            { 
 | 
                //判断权限 
 | 
                if (!DBUtility.ClsPub.Security_Log(ModRightNameList, 3, false, HMaker)) 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "您没有该模块权限,请与管理员联系!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
  
 | 
                //返回列表信息 
 | 
                ds = oCn.RunProcReturn("select * from h_v_Pay_OutApplyBillList where 1=1 " + sWhere + " order by hmainid desc", "h_v_Pay_OutApplyBillList"); 
 | 
                List<object> columnNameList = new List<object>(); 
 | 
                //添加列名 
 | 
                foreach (DataColumn col in ds.Tables[0].Columns) 
 | 
                { 
 | 
                    Type dataType = col.DataType; 
 | 
                    string ColmString = "{\"ColmCols\":\"" + col.ColumnName + "\",\"ColmType\":\"" + dataType.Name + "\"}"; 
 | 
                    columnNameList.Add(JsonConvert.DeserializeObject(ColmString));  //获取到DataColumn列对象的列名 
 | 
                } 
 | 
                objJsonResult.code = "0"; 
 | 
                objJsonResult.count = 1; 
 | 
                objJsonResult.Message = "成功!"; 
 | 
                objJsonResult.data = ds.Tables[0]; 
 | 
                objJsonResult.list = columnNameList; 
 | 
                return objJsonResult; 
 | 
            } 
 | 
            catch (Exception e) 
 | 
            { 
 | 
                objJsonResult.code = "0"; 
 | 
                objJsonResult.count = 0; 
 | 
                objJsonResult.Message = "查询列表信息失败!" + e.ToString(); 
 | 
                objJsonResult.data = null; 
 | 
                return objJsonResult; 
 | 
            } 
 | 
        } 
 | 
        #endregion 
 | 
  
 | 
        #region 请假申请单删除 
 | 
        /// <summary> 
 | 
        /// 删除请假申请单 
 | 
        /// </summary> 
 | 
        /// <returns></returns> 
 | 
        [Route("Pay_OutApplyBillController/GetPay_OutApplyBill_Delete_Json")] 
 | 
        [HttpGet] 
 | 
        public object GetPay_OutApplyBill_Delete_Json(Int64 HInterID, string HMaker) 
 | 
        { 
 | 
            try 
 | 
            { 
 | 
                //判断权限 
 | 
                if (!DBUtility.ClsPub.Security_Log(ModRightNameDrop, 3, false, HMaker)) 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "您没有该模块删除功能权限,请与管理员联系!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
  
 | 
                //判断存在性 
 | 
                if (oBill.ShowBill(HInterID, ref DBUtility.ClsPub.sExeReturnInfo)) 
 | 
                { 
 | 
                    //判断会计期是否合理 
 | 
                    string s = ""; 
 | 
                    int sYear = 0; 
 | 
                    int sPeriod = 0; 
 | 
                    if (DBUtility.Xt_BaseBillFun.Fun_AllowYearPeriod_Pay(oBill.omodel.HDate, ref sYear, ref sPeriod, ref s) == false) 
 | 
                    { 
 | 
                        objJsonResult.code = "0"; 
 | 
                        objJsonResult.count = 0; 
 | 
                        objJsonResult.Message = s; 
 | 
                        objJsonResult.data = null; 
 | 
                        return objJsonResult; 
 | 
                    } 
 | 
                    //删除前控制 
 | 
                    DataSet BeforeDs = oCn.RunProcReturn("Exec h_p_Pay_OutApplyBill_BeforeDelCtrl " + HInterID.ToString() + ",'" + HMaker + "'", "h_p_Pay_OutApplyBill_BeforeDelCtrl"); 
 | 
                    if (BeforeDs == null || BeforeDs.Tables[0].Rows.Count == 0) 
 | 
                    { 
 | 
                        objJsonResult.code = "0"; 
 | 
                        objJsonResult.count = 0; 
 | 
                        objJsonResult.Message = "删除前判断失败!"; 
 | 
                        objJsonResult.data = null; 
 | 
                        return objJsonResult; 
 | 
                    } 
 | 
                    else 
 | 
                    { 
 | 
                        if (DBUtility.ClsPub.isLong(BeforeDs.Tables[0].Rows[0]["HBack"]) == 1) 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "删除失败!" + DBUtility.ClsPub.isStrNull(BeforeDs.Tables[0].Rows[0]["HRemark"]); 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                    } 
 | 
                    //删除单据(包含删除后控制、写入日志) 
 | 
                    if (!oBill.DeleteBill(oBill.omodel.HInterID, oBill.omodel.HBillNo, "h_p_Pay_OutApplyBill_AfterDelCtrl", HMaker, ref ClsPub.sExeReturnInfo)) 
 | 
                    { 
 | 
                        objJsonResult.code = "0"; 
 | 
                        objJsonResult.count = 0; 
 | 
                        objJsonResult.Message = "删除失败!原因:" + ClsPub.sExeReturnInfo; 
 | 
                        objJsonResult.data = null; 
 | 
                        return objJsonResult; 
 | 
                    } 
 | 
                    else 
 | 
                    { 
 | 
                        objJsonResult.code = "0"; 
 | 
                        objJsonResult.count = 1; 
 | 
                        objJsonResult.Message = "删除请假申请单成功!"; 
 | 
                        objJsonResult.data = null; 
 | 
                        return objJsonResult; 
 | 
                    } 
 | 
                } 
 | 
                else 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "未查询到该请假申请单,请刷新数据后重新选择!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
            } 
 | 
            catch (Exception e) 
 | 
            { 
 | 
                objJsonResult.code = "0"; 
 | 
                objJsonResult.count = 0; 
 | 
                objJsonResult.Message = "删除请假申请单失败!" + e.ToString(); 
 | 
                objJsonResult.data = null; 
 | 
                return objJsonResult; 
 | 
            } 
 | 
        } 
 | 
        #endregion 
 | 
  
 | 
        #region 请假申请单审核/反审核 
 | 
        /// <summary> 
 | 
        /// 审核/反审核请假申请单 
 | 
        /// </summary> 
 | 
        /// <param name="HInterID">单据ID</param> 
 | 
        /// <param name="Type">审核(1),反审核(2)</param> 
 | 
        /// <param name="HMaker">审核人</param> 
 | 
        /// <returns></returns> 
 | 
        [Route("Pay_OutApplyBillController/GetPay_OutApplyBill_Check_Json")] 
 | 
        [HttpGet] 
 | 
        public object GetPay_OutApplyBill_Check_Json(Int64 HInterID, int Type, string HMaker) 
 | 
        { 
 | 
            try 
 | 
            { 
 | 
                //判断权限 
 | 
                if (!DBUtility.ClsPub.Security_Log(ModRightNameCheck, 3, false, HMaker)) 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "您没有该模块审核/反审核功能权限,请与管理员联系!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
  
 | 
                //判断存在性 
 | 
                if (oBill.ShowBill(HInterID, ref DBUtility.ClsPub.sExeReturnInfo)) 
 | 
                { 
 | 
                    //判断会计期是否合理 
 | 
                    string s = ""; 
 | 
                    int sYear = 0; 
 | 
                    int sPeriod = 0; 
 | 
                    if (DBUtility.Xt_BaseBillFun.Fun_AllowYearPeriod_Pay(oBill.omodel.HDate, ref sYear, ref sPeriod, ref s) == false) 
 | 
                    { 
 | 
                        objJsonResult.code = "0"; 
 | 
                        objJsonResult.count = 0; 
 | 
                        objJsonResult.Message = s; 
 | 
                        objJsonResult.data = null; 
 | 
                        return objJsonResult; 
 | 
                    } 
 | 
  
 | 
                    //Type 1 审核  2  反审核 
 | 
                    if (Type == 1) 
 | 
                    { 
 | 
                        if (oBill.omodel.HChecker.Trim() != "") 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "单据已审核,不能再次审核!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        if (oBill.omodel.HCloseMan.Trim() != "") 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "单据已关闭,不能再次审核!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        if (oBill.omodel.HDeleteMan.Trim() != "") 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "单据已作废,不能再次审核!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        //审核前控制 
 | 
                        DataSet BeforeDs = oCn.RunProcReturn("Exec h_p_Pay_OutApplyBill_BeforeCheckCtrl " + HInterID.ToString() + ",'" + HMaker + "'", "h_p_Pay_OutApplyBill_BeforeCheckCtrl"); 
 | 
                        if (BeforeDs == null || BeforeDs.Tables[0].Rows.Count == 0) 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "审核前判断失败!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        else 
 | 
                        { 
 | 
                            if (DBUtility.ClsPub.isLong(BeforeDs.Tables[0].Rows[0]["HBack"]) == 1) 
 | 
                            { 
 | 
                                objJsonResult.code = "0"; 
 | 
                                objJsonResult.count = 0; 
 | 
                                objJsonResult.Message = "审核失败!" + DBUtility.ClsPub.isStrNull(BeforeDs.Tables[0].Rows[0]["HRemark"]); 
 | 
                                objJsonResult.data = null; 
 | 
                                return objJsonResult; 
 | 
                            } 
 | 
                        } 
 | 
                        //审核单据 
 | 
                        if (!oBill.CheckBill(HInterID, oBill.omodel.HBillNo, "h_p_Pay_OutApplyBill_AfterCheckCtrl", HMaker, ref ClsPub.sExeReturnInfo)) 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "审核失败!原因:" + ClsPub.sExeReturnInfo; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        else 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 1; 
 | 
                            objJsonResult.Message = "单据号:" + oBill.omodel.HBillNo + " 审核成功!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; ; 
 | 
                        } 
 | 
                    } 
 | 
                    else 
 | 
                    { 
 | 
                        if (oBill.omodel.HChecker.Trim() == "") 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "单据未审核,不需要反审核!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        //反审核前控制 
 | 
                        DataSet BeforeDs = oCn.RunProcReturn("Exec h_p_Pay_OutApplyBill_BeforeUnCheckCtrl " + HInterID.ToString() + ",'" + HMaker + "'", "h_p_Pay_OutApplyBill_BeforeUnCheckCtrl"); 
 | 
                        if (BeforeDs == null || BeforeDs.Tables[0].Rows.Count == 0) 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "反审核前判断失败!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        else 
 | 
                        { 
 | 
                            if (DBUtility.ClsPub.isLong(BeforeDs.Tables[0].Rows[0]["HBack"]) == 1) 
 | 
                            { 
 | 
                                objJsonResult.code = "0"; 
 | 
                                objJsonResult.count = 0; 
 | 
                                objJsonResult.Message = "反审核失败!" + DBUtility.ClsPub.isStrNull(BeforeDs.Tables[0].Rows[0]["HRemark"]); 
 | 
                                objJsonResult.data = null; 
 | 
                                return objJsonResult; 
 | 
                            } 
 | 
                        } 
 | 
  
 | 
                        //反审核单据 
 | 
                        if (!oBill.AbandonCheck(HInterID, oBill.omodel.HBillNo, "h_p_Pay_OutApplyBill_AfterUnCheckCtrl", HMaker, ref ClsPub.sExeReturnInfo)) 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "反审核失败!原因:" + ClsPub.sExeReturnInfo; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        else 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 1; 
 | 
                            objJsonResult.Message = "单据号:" + oBill.omodel.HBillNo + " 反审核成功!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; ; 
 | 
                        } 
 | 
                    } 
 | 
                } 
 | 
                else 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "未查询到该请假申请单,请刷新数据后重新选择!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
            } 
 | 
            catch (Exception e) 
 | 
            { 
 | 
                objJsonResult.code = "0"; 
 | 
                objJsonResult.count = 0; 
 | 
                objJsonResult.Message = "审核或反审核请假申请单失败!" + e.ToString(); 
 | 
                objJsonResult.data = null; 
 | 
                return objJsonResult; 
 | 
            } 
 | 
        } 
 | 
        #endregion 
 | 
  
 | 
        #region 请假申请单关闭/反关闭 
 | 
        /// <summary> 
 | 
        /// 关闭/反关闭请假申请单 
 | 
        /// </summary> 
 | 
        /// <param name="HInterID">单据ID</param> 
 | 
        /// <param name="Type">关闭(1),反关闭(2)</param> 
 | 
        /// <param name="HMaker">关闭人</param> 
 | 
        /// <returns></returns> 
 | 
        [Route("Pay_OutApplyBillController/GetPay_OutApplyBill_Close_Json")] 
 | 
        [HttpGet] 
 | 
        public object GetPay_OutApplyBill_Close_Json(Int64 HInterID, int Type, string HMaker) 
 | 
        { 
 | 
            try 
 | 
            { 
 | 
                //判断权限 
 | 
                if (!DBUtility.ClsPub.Security_Log(ModRightNameClose, 3, false, HMaker)) 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "您没有该模块关闭/反关闭功能权限,请与管理员联系!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
  
 | 
                //判断存在性 
 | 
                if (oBill.ShowBill(HInterID, ref DBUtility.ClsPub.sExeReturnInfo)) 
 | 
                { 
 | 
                    //判断会计期是否合理 
 | 
                    string s = ""; 
 | 
                    int sYear = 0; 
 | 
                    int sPeriod = 0; 
 | 
                    if (DBUtility.Xt_BaseBillFun.Fun_AllowYearPeriod_Pay(oBill.omodel.HDate, ref sYear, ref sPeriod, ref s) == false) 
 | 
                    { 
 | 
                        objJsonResult.code = "0"; 
 | 
                        objJsonResult.count = 0; 
 | 
                        objJsonResult.Message = s; 
 | 
                        objJsonResult.data = null; 
 | 
                        return objJsonResult; 
 | 
                    } 
 | 
  
 | 
                    //Type 1 关闭  2  反关闭 
 | 
                    if (Type == 1) 
 | 
                    { 
 | 
                        if (oBill.omodel.HCloseMan.Trim() != "") 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "单据已关闭,不能再次关闭!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        //关闭单据 
 | 
                        if (!oBill.CloseBill(HInterID, oBill.omodel.HBillNo, HMaker, ref ClsPub.sExeReturnInfo)) 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "关闭失败!原因:" + ClsPub.sExeReturnInfo; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        else 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 1; 
 | 
                            objJsonResult.Message = "单据号:" + oBill.omodel.HBillNo + " 关闭成功!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; ; 
 | 
                        } 
 | 
                    } 
 | 
                    else 
 | 
                    { 
 | 
                        if (oBill.omodel.HCloseMan.Trim() == "") 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "单据未关闭,不需要反关闭!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        //反关闭单据 
 | 
                        if (!oBill.CancelClose(HInterID, oBill.omodel.HBillNo, HMaker, ref ClsPub.sExeReturnInfo)) 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "反关闭失败!原因:" + ClsPub.sExeReturnInfo; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        else 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 1; 
 | 
                            objJsonResult.Message = "单据号:" + oBill.omodel.HBillNo + " 反关闭成功!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; ; 
 | 
                        } 
 | 
                    } 
 | 
                } 
 | 
                else 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "未查询到该请假申请单,请刷新数据后重新选择!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
            } 
 | 
            catch (Exception e) 
 | 
            { 
 | 
                objJsonResult.code = "0"; 
 | 
                objJsonResult.count = 0; 
 | 
                objJsonResult.Message = "关闭或反关闭请假申请单失败!" + e.ToString(); 
 | 
                objJsonResult.data = null; 
 | 
                return objJsonResult; 
 | 
            } 
 | 
        } 
 | 
        #endregion 
 | 
  
 | 
        #region 请假申请单作废/反作废 
 | 
        /// <summary> 
 | 
        /// 作废/反作废请假申请单 
 | 
        /// </summary> 
 | 
        /// <param name="HInterID">单据ID</param> 
 | 
        /// <param name="Type">作废(1),反作废(2)</param> 
 | 
        /// <param name="HMaker">作废人</param> 
 | 
        /// <returns></returns> 
 | 
        [Route("Pay_OutApplyBillController/GetPay_OutApplyBill_Cancelltion_Json")] 
 | 
        [HttpGet] 
 | 
        public object GetPay_OutApplyBill_Cancelltion_Json(Int64 HInterID, int Type, string HMaker) 
 | 
        { 
 | 
            try 
 | 
            { 
 | 
                //判断权限 
 | 
                if (!DBUtility.ClsPub.Security_Log(ModRightNameDelete, 3, false, HMaker)) 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "您没有该模块作废/反作废功能权限,请与管理员联系!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
  
 | 
                //判断存在性 
 | 
                if (oBill.ShowBill(HInterID, ref DBUtility.ClsPub.sExeReturnInfo)) 
 | 
                { 
 | 
                    //判断会计期是否合理 
 | 
                    string s = ""; 
 | 
                    int sYear = 0; 
 | 
                    int sPeriod = 0; 
 | 
                    if (DBUtility.Xt_BaseBillFun.Fun_AllowYearPeriod_Pay(oBill.omodel.HDate, ref sYear, ref sPeriod, ref s) == false) 
 | 
                    { 
 | 
                        objJsonResult.code = "0"; 
 | 
                        objJsonResult.count = 0; 
 | 
                        objJsonResult.Message = s; 
 | 
                        objJsonResult.data = null; 
 | 
                        return objJsonResult; 
 | 
                    } 
 | 
  
 | 
                    //Type 1 作废  2  反作废 
 | 
                    if (Type == 1) 
 | 
                    { 
 | 
                        if (oBill.omodel.HDeleteMan.Trim() != "") 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "单据已作废,不能再次作废!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        //作废单据 
 | 
                        if (!oBill.Cancelltion(HInterID, oBill.omodel.HBillNo, HMaker, ref ClsPub.sExeReturnInfo)) 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "作废失败!原因:" + ClsPub.sExeReturnInfo; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        else 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 1; 
 | 
                            objJsonResult.Message = "单据号:" + oBill.omodel.HBillNo + " 作废成功!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; ; 
 | 
                        } 
 | 
                    } 
 | 
                    else 
 | 
                    { 
 | 
                        if (oBill.omodel.HDeleteMan.Trim() == "") 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "单据未作废,不需要反作废!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        //反作废单据 
 | 
                        if (!oBill.AbandonCancelltion(HInterID, oBill.omodel.HBillNo, HMaker, ref ClsPub.sExeReturnInfo)) 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 0; 
 | 
                            objJsonResult.Message = "反作废失败!原因:" + ClsPub.sExeReturnInfo; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; 
 | 
                        } 
 | 
                        else 
 | 
                        { 
 | 
                            objJsonResult.code = "0"; 
 | 
                            objJsonResult.count = 1; 
 | 
                            objJsonResult.Message = "单据号:" + oBill.omodel.HBillNo + " 反作废成功!"; 
 | 
                            objJsonResult.data = null; 
 | 
                            return objJsonResult; ; 
 | 
                        } 
 | 
                    } 
 | 
                } 
 | 
                else 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "未查询到该请假申请单,请刷新数据后重新选择!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
            } 
 | 
            catch (Exception e) 
 | 
            { 
 | 
                objJsonResult.code = "0"; 
 | 
                objJsonResult.count = 0; 
 | 
                objJsonResult.Message = "作废或反作废请假申请单失败!" + e.ToString(); 
 | 
                objJsonResult.data = null; 
 | 
                return objJsonResult; 
 | 
            } 
 | 
        } 
 | 
        #endregion 
 | 
  
 | 
  
 | 
  
 | 
  
 | 
  
 | 
  
 | 
  
 | 
  
 | 
        #region 请假申请单 新增/编辑 
 | 
        #region 请假申请单 表头数据 
 | 
        public class Pay_OutApplyBillMain 
 | 
        { 
 | 
            public int HInterID; 
 | 
            public string HBillNo; 
 | 
            public string HDate; 
 | 
            public string HInnerBillNo; 
 | 
            public int HGroupID; 
 | 
            public string HGroupName; 
 | 
            public int HDeptID; 
 | 
            public string HDeptName; 
 | 
            public int HMangerID; 
 | 
            public string HMangerName; 
 | 
            public int HLeaveID; 
 | 
            public string HLeaveName; 
 | 
            public string HExplanation; 
 | 
            public string HRemark; 
 | 
  
 | 
            public string HMaker; 
 | 
            public string HMakerDate; 
 | 
            public string HUpdater; 
 | 
            public string HUpdaterDate; 
 | 
            public string HChecker; 
 | 
            public string HCheckerDate; 
 | 
            public string HCloseMan; 
 | 
            public string HCloseManDate; 
 | 
            public string HDeleteMan; 
 | 
            public string HDeleteManDate; 
 | 
            public string HBacker; 
 | 
            public string HBackerDate; 
 | 
            public string HBackRemark; 
 | 
        } 
 | 
        #endregion 
 | 
        #region 请假申请单 子表数据 
 | 
        public class Pay_OutApplyBillSub 
 | 
        { 
 | 
            public int HEmpID; 
 | 
            public string HEmpNumber; 
 | 
            public string HEmpName; 
 | 
            public int HShiftsID; 
 | 
            public string HShiftsNumber; 
 | 
            public string HShiftsName; 
 | 
            public string HBTimes; 
 | 
            public string HETimes; 
 | 
            public bool HRestFlag; 
 | 
            public double HRestTimes; 
 | 
            public double HTimes; 
 | 
            public double HRelTimes; 
 | 
            public string HRemark; 
 | 
        } 
 | 
        #endregion 
 | 
  
 | 
        #region 请假申请单 新增/编辑 
 | 
        /// <summary> 
 | 
        /// 新增单据-保存按钮 
 | 
        ///参数:string sql。 
 | 
        ///返回值:object。 
 | 
        /// </summary> 
 | 
        [Route("Pay_OutApplyBill/AddPay_OutApplyBill")] 
 | 
        [HttpPost] 
 | 
        public object AddBill_Pay_OutApplyBill([FromBody] JObject sMainSub) 
 | 
        { 
 | 
            //获取参数 
 | 
            var _value = sMainSub["sMainSub"].ToString(); 
 | 
            string msg1 = _value.ToString(); 
 | 
            //开始事务 
 | 
            oCn.BeginTran(); 
 | 
            //保存主表 
 | 
            objJsonResult = AddBillMain_Pay_OutApplyBill(msg1); 
 | 
            if (objJsonResult.code == "0") 
 | 
            { 
 | 
                oCn.RollBack(); 
 | 
                objJsonResult.code = "0"; 
 | 
                objJsonResult.count = 0; 
 | 
                objJsonResult.Message = objJsonResult.Message; 
 | 
                objJsonResult.data = null; 
 | 
                return objJsonResult; 
 | 
            } 
 | 
            oCn.Commit(); 
 | 
            objJsonResult.code = "1"; 
 | 
            objJsonResult.count = 1; 
 | 
            objJsonResult.Message = "新增单据成功!"; 
 | 
            objJsonResult.data = ds.Tables[0]; 
 | 
            return objJsonResult; 
 | 
        } 
 | 
        #endregion 
 | 
        #region 添加 请假申请单 主表 
 | 
        public json AddBillMain_Pay_OutApplyBill(string msg1) 
 | 
        { 
 | 
            string[] sArray = msg1.Split(new string[] { ";" }, StringSplitOptions.RemoveEmptyEntries); 
 | 
            string msg2 = sArray[0].ToString(); 
 | 
            string msg3 = sArray[1].ToString(); 
 | 
            int OperationType = int.Parse(sArray[2].ToString());//数据类型 1添加 3修改 2 复制 
 | 
            string user = sArray[3].ToString();//用户名 
 | 
            string HComputerName = SystemInformation.ComputerName; //设备名称 
 | 
  
 | 
            try 
 | 
            { 
 | 
                if (OperationType == 1) 
 | 
                { 
 | 
                    //判断是否有编辑权限 
 | 
                    if (!DBUtility.ClsPub.Security_Log("Pay_OutApplyBill_Edit", 1, false, user)) 
 | 
                    { 
 | 
                        objJsonResult.code = "0"; 
 | 
                        objJsonResult.count = 0; 
 | 
                        objJsonResult.Message = "无新增权限!"; 
 | 
                        objJsonResult.data = null; 
 | 
                        return objJsonResult; 
 | 
                    } 
 | 
                } 
 | 
                else if (OperationType == 3) 
 | 
                { 
 | 
                    //判断是否有编辑权限 
 | 
                    if (!DBUtility.ClsPub.Security_Log("Pay_OutApplyBill_Edit", 1, false, user)) 
 | 
                    { 
 | 
                        objJsonResult.code = "0"; 
 | 
                        objJsonResult.count = 0; 
 | 
                        objJsonResult.Message = "无编辑权限!"; 
 | 
                        objJsonResult.data = null; 
 | 
                        return objJsonResult; 
 | 
                    } 
 | 
                } 
 | 
  
 | 
                msg2 = "[" + msg2.ToString() + "]"; 
 | 
                List<Pay_OutApplyBillMain> mainList = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Pay_OutApplyBillMain>>(msg2); 
 | 
  
 | 
  
 | 
                int HYear = int.Parse(mainList[0].HDate.Split('-')[0]); 
 | 
                int HPeriod = int.Parse(mainList[0].HDate.Split('-')[1]); 
 | 
                string HBillType = "2221"; 
 | 
                string HBillSubType = ""; 
 | 
                int HBillStatus = 1; 
 | 
  
 | 
  
 | 
                int HInterID = mainList[0].HInterID; 
 | 
                string HBillNo = mainList[0].HBillNo; 
 | 
                string HDate = mainList[0].HDate; 
 | 
                string HInnerBillNo = mainList[0].HInnerBillNo; 
 | 
                int HDeptID = mainList[0].HDeptID; 
 | 
                string HDeptName = mainList[0].HDeptName; 
 | 
                int HGroupID = mainList[0].HGroupID; 
 | 
                string HGroupName = mainList[0].HGroupName; 
 | 
                int HMangerID = mainList[0].HMangerID; 
 | 
                string HMangerName = mainList[0].HMangerName; 
 | 
                int HLeaveID = mainList[0].HLeaveID; 
 | 
                string HLeaveName = mainList[0].HLeaveName; 
 | 
                string HExplanation = mainList[0].HExplanation; 
 | 
                string HRemark = mainList[0].HRemark; 
 | 
  
 | 
  
 | 
                string HMaker = mainList[0].HMaker; 
 | 
                string HMakerDate = mainList[0].HMakerDate; 
 | 
                string HUpdater = mainList[0].HUpdater; 
 | 
                string HUpdaterDate = mainList[0].HUpdaterDate; 
 | 
                string HChecker = mainList[0].HChecker; 
 | 
                string HCheckerDate = mainList[0].HCheckerDate; 
 | 
                string HCloseMan = mainList[0].HCloseMan; 
 | 
                string HCloseManDate = mainList[0].HCloseManDate; 
 | 
                string HDeleteMan = mainList[0].HDeleteMan; 
 | 
                string HDeleteManDate = mainList[0].HDeleteManDate; 
 | 
                string HBacker = mainList[0].HBacker; 
 | 
                string HBackerDate = mainList[0].HBackerDate; 
 | 
                string HBackRemark = mainList[0].HBackRemark; 
 | 
  
 | 
  
 | 
                //if (OperationType == 2) 
 | 
                //{ 
 | 
                //    ds = oCn.RunProcReturn("select * from PM_ProjectBillMain where HBillNo ='" + HBillNo + "'", "PM_ProjectBillMain"); 
 | 
                //    if (ds.Tables[0].Rows.Count > 0) 
 | 
                //    { 
 | 
                //        objJsonResult.code = "0"; 
 | 
                //        objJsonResult.count = 0; 
 | 
                //        objJsonResult.Message = "单据号重复,请重新输入!"; 
 | 
                //        objJsonResult.data = null; 
 | 
                //        return objJsonResult; 
 | 
                //    } 
 | 
                //} 
 | 
  
 | 
                ds = oCn.RunProcReturn("select * from Pay_OutApplyBillMain where HInterID = " + HInterID + " and HBillNo = '" + HBillNo + "'", "Pay_OutApplyBillMain"); 
 | 
  
 | 
                if ((OperationType == 1 || OperationType == 2) && ds.Tables[0].Rows.Count == 0)//新增 
 | 
                { 
 | 
                    string sql = "insert into Pay_OutApplyBillMain" + 
 | 
                        "(HYear,HPeriod,HBillType,HBillSubType,HBillStatus,HInterID,HBillNo,HDate,HInnerBillNo,HDeptID,HGroupID,HMangerID,HLeaveID,HExplanation,HRemark, HMaker,HMakeDate) " + 
 | 
                        "values(" + 
 | 
                        "" + HYear + 
 | 
                        "," + HPeriod + 
 | 
                        ",'" + HBillType + 
 | 
                        "','" + HBillSubType + 
 | 
                        "'," + HBillStatus + 
 | 
                        "," + HInterID + 
 | 
                        ",'" + HBillNo + 
 | 
                        "','" + HDate + 
 | 
                        "','" + HInnerBillNo + 
 | 
                        "'," + HDeptID + 
 | 
                        "," + HGroupID + 
 | 
                        "," + HMangerID + 
 | 
                        "," + HLeaveID + 
 | 
                        ",'" + HExplanation + 
 | 
                        "','" + HRemark + 
 | 
                        "','" + HMaker + 
 | 
                        "','" + HMakerDate + 
 | 
                        "')"; 
 | 
  
 | 
                    //主表 
 | 
                    oCn.RunProc(sql); 
 | 
                    LogService.Write("用户:" + user + ",日期:" + DateTime.Now + ",新增请假申请单:" + HBillNo); 
 | 
                    oCn.RunProc("Insert into System_log (GeginDate, userid, WorkstationName, WorkList, SystemName, NetuserName, State) select GETDATE(),'" + user + "','" + HComputerName + "','" + "新增请假申请单:" + HBillNo + "','LMES-请假申请单模块','" + DBUtility.ClsPub.IPAddress + "','新增单据'", ref DBUtility.ClsPub.sExeReturnInfo); 
 | 
                } 
 | 
                else if (OperationType == 3 || ds.Tables[0].Rows.Count != 0)                    //编辑 
 | 
                { 
 | 
                    string sql = "update Pay_OutApplyBillMain set " + 
 | 
                        "HYear = " + HYear + 
 | 
                        ", HPeriod = " + HPeriod + 
 | 
                        ", HBillNo = '" + HBillNo + 
 | 
                        "', HDate = '" + HDate + 
 | 
                        "', HInnerBillNo = '" + HInnerBillNo + 
 | 
                        "', HGroupID = " + HGroupID + 
 | 
                        ", HDeptID = " + HDeptID + 
 | 
                        ", HMangerID = " + HMangerID + 
 | 
                        ", HLeaveID = " + HLeaveID +  
 | 
                        ", HExplanation = '" + HExplanation + 
 | 
                        "', HRemark = '" + HRemark + 
 | 
                        "', HUpdater = '" + HUpdater + 
 | 
                        "', HUpdateDate = '" + HUpdaterDate + 
 | 
                        "' where HInterID = " + HInterID; 
 | 
  
 | 
                    oCn.RunProc(sql); 
 | 
  
 | 
                    //删除子表 
 | 
                    oCn.RunProc("delete from Pay_OutApplyBillSub where HInterID= " + HInterID); 
 | 
                    //记录日志 
 | 
                    LogService.Write("用户:" + user + ",日期:" + DateTime.Now + ",修改请假申请单:" + HBillNo); 
 | 
                    oCn.RunProc("Insert into System_log (GeginDate, userid, WorkstationName, WorkList, SystemName, NetuserName, State) select GETDATE(),'" + user + "','" + HComputerName + "','" + "修改请假申请单:" + HBillNo + "','LMES-请假申请单模块','" + DBUtility.ClsPub.IPAddress + "','修改单据'", ref DBUtility.ClsPub.sExeReturnInfo); 
 | 
                } 
 | 
                //保存子表 
 | 
                objJsonResult = AddBillSub1_Pay_OutApplyBill(msg3, HInterID, HBillNo, OperationType); 
 | 
  
 | 
                if (objJsonResult.code == "0") 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = objJsonResult.Message; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
  
 | 
                objJsonResult.code = "1"; 
 | 
                objJsonResult.count = 1; 
 | 
                objJsonResult.Message = null; 
 | 
                objJsonResult.data = null; 
 | 
                return objJsonResult; 
 | 
            } 
 | 
            catch (Exception e) 
 | 
            { 
 | 
                objJsonResult.code = "0"; 
 | 
                objJsonResult.count = 0; 
 | 
                objJsonResult.Message = "Exception!" + e.ToString(); 
 | 
                objJsonResult.data = null; 
 | 
                return objJsonResult; 
 | 
            } 
 | 
        } 
 | 
        #endregion 
 | 
        #region 添加 请假申请单 子表 
 | 
        public json AddBillSub1_Pay_OutApplyBill(string msg3, long HInterID, string HBillNo, int OperationType) 
 | 
        { 
 | 
            List<Pay_OutApplyBillSub> DetailColl = Newtonsoft.Json.JsonConvert.DeserializeObject<List<Pay_OutApplyBillSub>>(msg3); 
 | 
            int i = 0;                                          //作为子表内码 
 | 
            foreach (Pay_OutApplyBillSub oSub in DetailColl) 
 | 
            { 
 | 
                i++;                                            //同一个主表下的子表的内码自增 
 | 
  
 | 
                int HEntryID = i; 
 | 
  
 | 
                int HEmpID = oSub.HEmpID; 
 | 
                string HEmpName = oSub.HEmpName; 
 | 
                int HShiftsID = oSub.HShiftsID; 
 | 
                string HShiftsName = oSub.HShiftsName; 
 | 
                string HBTimes = oSub.HBTimes; 
 | 
                string HETimes = oSub.HETimes; 
 | 
                int HRestFlag = oSub.HRestFlag ? 1 : 0; 
 | 
                double HRestTimes = oSub.HRestTimes; 
 | 
                double HTimes = oSub.HTimes; 
 | 
                double HRelTimes = oSub.HRelTimes; 
 | 
                string HRemark = oSub.HRemark; 
 | 
  
 | 
  
 | 
                string sql = "insert into Pay_OutApplyBillSub" + 
 | 
                            "(HInterID,HEntryID,HEmpID,HShiftsID,HBTimes,HETimes,HRestFlag,HRestTimes,HTimes,HRelTimes,HRemark) " + 
 | 
                            "values(" + 
 | 
                            "" + HInterID + 
 | 
                            "," + HEntryID + 
 | 
                            "," + HEmpID + 
 | 
                            "," + HShiftsID + 
 | 
                            ",'" + HBTimes + 
 | 
                            "','" + HETimes + 
 | 
                            "'," + HRestFlag + 
 | 
                            "," + HRestTimes + 
 | 
                            "," + HTimes + 
 | 
                            "," + HRelTimes + 
 | 
                            ",'" + HRemark + 
 | 
                            "')"; 
 | 
                oCn.RunProc(sql); 
 | 
            } 
 | 
  
 | 
            objJsonResult.code = "1"; 
 | 
            objJsonResult.count = 1; 
 | 
            objJsonResult.Message = null; 
 | 
            objJsonResult.data = null; 
 | 
            return objJsonResult; 
 | 
        } 
 | 
        #endregion 
 | 
        #endregion 
 | 
  
 | 
        #region 请假工资单 编辑-页面赋值 
 | 
        /// <summary> 
 | 
        ///参数:string HInterID。 
 | 
        ///返回值:object。 
 | 
        /// </summary> 
 | 
        [Route("Pay_OutApplyBill/editInit")] 
 | 
        [HttpGet] 
 | 
        public object getOutApplyBilleditInit(string HInterID, string user) 
 | 
        { 
 | 
            try 
 | 
            { 
 | 
                List<DataTable> tableList = new List<DataTable>(); 
 | 
  
 | 
                //查看权限 
 | 
                if (!DBUtility.ClsPub.Security_Log("Pay_OutApplyBill_Edit", 1, false, user)) 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "无编辑权限!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
  
 | 
                if (HInterID == null || HInterID.Equals("")) 
 | 
                { 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "HInterID不能为空!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
  
 | 
                ds = oCn.RunProcReturn("select * from Pay_OutApplyBillMain where HInterID = " + HInterID, "Pay_OutApplyBillMain"); 
 | 
                string[] HBillStatusList = { "", "未审", "审核通过", "关闭", "作废", "审核退回", "审核中", "已阅", "已回复", "结案", "验证", "下达", "开工", "申请审批", "", "申请检验", "判定合格", "判定不合格" }; 
 | 
                if (ds.Tables[0].Rows.Count > 0 && int.Parse(ds.Tables[0].Rows[0]["HBillStatus"].ToString()) > 1) 
 | 
                { 
 | 
                    int HBillStatus = int.Parse(ds.Tables[0].Rows[0]["HBillStatus"].ToString()); 
 | 
                    objJsonResult.code = "0"; 
 | 
                    objJsonResult.count = 0; 
 | 
                    objJsonResult.Message = "编辑失败,单据当前状态为\"" + HBillStatusList[HBillStatus] + "\"!"; 
 | 
                    objJsonResult.data = null; 
 | 
                    return objJsonResult; 
 | 
                } 
 | 
  
 | 
  
 | 
                ds = oCn.RunProcReturn("exec h_p_Pay_OutApplyBill_EditInit " + HInterID, "h_p_Pay_OutApplyBill_EditInit"); 
 | 
                tableList.Add(ds.Tables[0]); 
 | 
                tableList.Add(ds.Tables[1]); 
 | 
  
 | 
                objJsonResult.code = "1"; 
 | 
                objJsonResult.count = 1; 
 | 
                objJsonResult.Message = "Sucess!"; 
 | 
                objJsonResult.data = tableList; 
 | 
                return objJsonResult; 
 | 
            } 
 | 
            catch (Exception e) 
 | 
            { 
 | 
                objJsonResult.code = "0"; 
 | 
                objJsonResult.count = 0; 
 | 
                objJsonResult.Message = "Exception!" + e.ToString(); 
 | 
                objJsonResult.data = null; 
 | 
                return objJsonResult; 
 | 
            } 
 | 
        } 
 | 
        #endregion 
 | 
  
 | 
  
 | 
    } 
 | 
} 
 |