lan
2024-05-23 edbb3dfdc024641c81829b3ddb4af13dbcf9d9ba
WebAPI/Controllers/BaseSet/Xt_grdAlignment_WMESController.cs
@@ -1,5 +1,6 @@
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
using Pub_Control;
using System;
using System.Collections.Generic;
using System.Data;
@@ -27,7 +28,21 @@
        {
            try
            {
                ds = oCN.RunProcReturn("select * from  Xt_grdAlignment_WMES where HModName='" + HModName + "' and HUserName='" + user + "'", "Xt_grdAlignment_WMES");
                if (ds.Tables[0].Rows.Count == 0)
                {
                    ds = oCN.RunProcReturn("select * from  Xt_grdAlignment_WMES where HModName='" + HModName + "' and (HUserName='admin' or HUserName='Admin')", "Xt_grdAlignment_WMES");
                    if (ds.Tables[0].Rows.Count == 0) {
                        objJsonResult.code = "1";
                        objJsonResult.count = 1;
                        objJsonResult.Message = "Sucess!";
                        objJsonResult.data = ds.Tables[0];
                        return objJsonResult;
                    }
                }
                objJsonResult.code = "1";
                objJsonResult.count = 1;
@@ -56,7 +71,8 @@
            public string HSortFlag;
            public string HSelTotal;
            public string HColumnWidth;
            public string HPageSize;
        }
        public class grdAlignmentSub
        {
@@ -118,12 +134,15 @@
                HGridString = HGridString.Substring(0, HGridString.Length - 1);
                oCN.RunProc("Delete from Xt_grdAlignment_WMES where HUserName='" + user + "' and HModName='" + HModName + "' ");
                oCN.RunProc("insert into Xt_grdAlignment_WMES (HUserName,HModName,HGridString,HFixCols" +
                    ",HFontSize,HHeadTextHeight,HTextHeight,HSortFlag,HSelTotal,HColumnWidth" +
                string sql = "insert into Xt_grdAlignment_WMES (HUserName,HModName,HGridString,HFixCols" +
                    ",HFontSize,HHeadTextHeight,HTextHeight,HSortFlag,HSelTotal,HColumnWidth,HPageSize" +
                    ")  values('" + user + "','" + HModName + "','" + HGridString + "'," + (omdelMian.HFixCols == "" ? "0" : omdelMian.HFixCols) +
                    "," + (omdelMian.HFontSize == "" ? "0" : omdelMian.HFontSize) + ",0" +
                    ",0,'" + omdelMian.HSortFlag + "','" + omdelMian.HSelTotal + "'" +
                    ","+ (omdelMian.HColumnWidth == "" ? "0" : omdelMian.HColumnWidth) + ")");
                    "," + (omdelMian.HColumnWidth == "" ? "0" : omdelMian.HColumnWidth) + "," + ((omdelMian.HPageSize == null || omdelMian.HPageSize == "") ? "0" : omdelMian.HPageSize) + ")";
                oCN.RunProc(sql);
                objJsonResult.code = "1";
@@ -143,5 +162,440 @@
        }
        #endregion
        #region 隐藏列设置  删除
        [Route("Xt_grdAlignment_WMES/DelgrdAlignmentWMES")]
        [HttpGet]
        public object DelgrdAlignmentWMES(string HModName, string user)
        {
            try
            {
                ds = oCN.RunProcReturn("select * from  Xt_grdAlignment_WMES where HModName='" + HModName + "' and HUserName='" + user + "'", "Xt_grdAlignment_WMES");
                if (ds.Tables[0].Rows.Count == 0)
                {
                    objJsonResult.code = "0";
                    objJsonResult.count = 0;
                    objJsonResult.Message = "此人无模块数据!";
                    objJsonResult.data = null;
                    return objJsonResult;
                }
                oCN.BeginTran();
                oCN.RunProc("delete from Xt_grdAlignment_WMES where HModName='" + HModName + "' and HUserName='" + user + "'");
                oCN.Commit();
                objJsonResult.code = "1";
                objJsonResult.count = 1;
                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 按钮设置 列表
        [Route("Xt_ModuleButtonSet_WMES/moduleButtonSetWMESList")]
        [HttpGet]
        public object moduleButtonSetWMESList(string HModName, string HBillType, string HUserName)
        {
            try
            {
                ds = oCN.RunProcReturn("select * from  Xt_ModuleButtonSet where HModuleName='" + HModName + "' and HBillType='" + HBillType + "' and HUserName='" + HUserName + "'", "Xt_ModuleButtonSet");
                objJsonResult.code = "1";
                objJsonResult.count = ds.Tables[0].Rows.Count;
                objJsonResult.Message = "Sucess!";
                objJsonResult.data = ds.Tables[0];
                return objJsonResult;
            }
            catch (Exception e)
            {
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "Exception!" + e.ToString();
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
        #endregion
        #region 按钮设置  添加/修改
        public class moduleButtonSet
        {
            public string BtnID;
            public string BtnName;
            public bool IsHide;
        }
        public class noEditList
        {
            public string HBillType;
            public string HModuleName;
            public string HButtonID;
            public string HButtonName;
            public int HOrder;
            public bool HHideFlag;
            public bool HEditFlag;
        }
        [Route("Xt_ModuleButtonSet_WMES/AddModuleButtonSetWMES")]
        [HttpPost]
        public object AddModuleButtonSetWMES([FromBody] JObject sMainSub)
        {
            var _value = sMainSub["sMainSub"].ToString();
            string msg1 = _value.ToString();
            oCN.BeginTran();
            //保存主表
            objJsonResult = AddButtonMain(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 = null;
            return objJsonResult;
        }
        public json AddButtonMain(string msg1)
        {
            string[] sArray = msg1.Split(new string[] { ";" }, StringSplitOptions.RemoveEmptyEntries);
            string sTableData = sArray[0].ToString();
            string HButtonIDList = sArray[1].ToString();
            string HButtonNameList = sArray[2].ToString();
            string HOrderList = sArray[3].ToString();
            string HModuleName = sArray[4].ToString();
            string HBillType = sArray[5].ToString();
            string NoEditList = sArray[6].ToString();
            string HUserName = sArray[7].ToString();
            try
            {
                List<moduleButtonSet> button = Newtonsoft.Json.JsonConvert.DeserializeObject<List<moduleButtonSet>>(sTableData);
                List<string> HButtonIDLists = Newtonsoft.Json.JsonConvert.DeserializeObject<List<string>>(HButtonIDList);
                List<string> HButtonNameLists = Newtonsoft.Json.JsonConvert.DeserializeObject<List<string>>(HButtonNameList);
                List<int> HOrderLists = Newtonsoft.Json.JsonConvert.DeserializeObject<List<int>>(HOrderList);
                List<noEditList> noEditLists= Newtonsoft.Json.JsonConvert.DeserializeObject<List<noEditList>>(NoEditList);
                //插入可编辑按钮的信息记录
                oCN.RunProc("delete from Xt_ModuleButtonSet where HModuleName= '" + HModuleName + "' and HBillType='" + HBillType + "' and HUserName= '" + HUserName + "'");
                for (int i = 0; i < button.Count; i++)
                {
                    for(int j = 0; j < HButtonIDLists.Count; j++)
                    {
                        if (button[i].BtnID == HButtonIDLists[j])
                        {
                            int HHideFlag = 0;
                            int HEditFlag = 1;
                            string HButtonID = HButtonIDLists[j].ToString();
                            string HButtonName = HButtonNameLists[j].ToString();
                            int HOrder = HOrderLists[j];
                            if (button[i].IsHide)
                            {
                                HHideFlag = 1;
                            }
                            if(button[i].BtnID== "HideButton")                                 //用户进行第一次设置时,设置 按钮设置 按钮为不可编辑且不隐藏
                            {
                                HEditFlag = 0;
                                HHideFlag = 0;
                            }
                            string sql = "exec h_p_Xt_ModuleButtonSet '" + HBillType + "','" + HModuleName + "','" + HButtonID + "','" + HButtonName + "'," + HOrder + "," + HHideFlag + "," + HEditFlag + ",'" + HUserName + "'";
                            oCN.RunProc(sql);
                        }
                    }
                }
                //重新插入不可编辑按钮的信息记录
                for (int i = 0; i < noEditLists.Count; i++)
                {
                    for (int j = 0; j < HButtonIDLists.Count; j++)
                    {
                        if (noEditLists[i].HButtonID == HButtonIDLists[j])
                        {
                            int HHideFlag = noEditLists[i].HHideFlag?1:0;
                            int HEditFlag = 0;
                            string HButtonID = noEditLists[i].HButtonID;
                            string HButtonName = noEditLists[i].HButtonName;
                            int HOrder = HOrderLists[j];
                            string sql = "exec h_p_Xt_ModuleButtonSet '" + HBillType + "','" + HModuleName + "','" + HButtonID + "','" + HButtonName + "'," + HOrder + "," + HHideFlag + "," + HEditFlag + ",'" + HUserName + "'";
                            oCN.RunProc(sql);
                        }
                    }
                }
                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 class TreeModel
        {
            public string id { get; set; }
            public string title { get; set; }
            public List<TreeModel> children = new List<TreeModel>();
        }
        [Route("Xt_grdAlignment_WMES/Gy_QueryConditionList_F_A")]
        [HttpGet]
        public object Gy_QueryConditionList_F_A(string HModName, string user)
        {
            try
            {
                ds = oCN.RunProcReturn("Select HInterID,HName from xt_ICSchemeMain Where HName='默认方案' and HBillName='" + HModName + "'and HUserCode='" + user + "'", "xt_ICSchemeMain");
                List<TreeModel> treeModels = new List<TreeModel>();
                if (ds.Tables[0].Rows.Count > 0)
                {
                    TreeModel Second = new TreeModel();
                    Second.id = ds.Tables[0].Rows[0]["HInterID"].ToString();
                    Second.title = ds.Tables[0].Rows[0]["HName"].ToString();
                    treeModels.Add(Second);
                    ds = oCN.RunProcReturn("Select HInterID,HName from xt_ICSchemeMain Where HName!='默认方案' and  HBillName='" + HModName + "'and HUserCode='" + user + "' order by HInterID", "xt_ICSchemeMain");
                    foreach (DataRow row in ds.Tables[0].Rows)
                    {
                        TreeModel Three = new TreeModel();
                        Three.id = row["HInterID"].ToString();
                        Three.title = row["HName"].ToString();
                        treeModels.Add(Three);
                    }
                }
                else
                {
                    TreeModel first = new TreeModel();
                    first.id = "0";
                    first.title = "默认方案";
                    treeModels.Add(first);
                }
                objJsonResult.code = "1";
                objJsonResult.count = 1;
                objJsonResult.Message = "Sucess!";
                objJsonResult.data = Newtonsoft.Json.JsonConvert.SerializeObject(treeModels);
                return objJsonResult;
            }
            catch (Exception e)
            {
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "Exception!" + e.ToString();
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
        #endregion
        #region 高级过滤 字段过滤条件查询
        [Route("Xt_grdAlignment_WMES/Gy_QueryCondition_Z_D_select")]
        [HttpGet]
        public object Gy_QueryCondition_Z_D_select(string sWhere, string user, string Organization)
        {
            try
            {
                List<object> columnNameList = new List<object>();
                ////编辑权限
                //if (!DBUtility.ClsPub.Security_Log_second("Gy_Material", 1, false, user))
                //{
                //    objJsonResult.code = "0";
                //    objJsonResult.count = 0;
                //    objJsonResult.Message = "无查看权限!";
                //    objJsonResult.data = null;
                //    return objJsonResult;
                //}
                string sql1 = string.Format(@"select * from Xt_grdCondition  where 1=1 ");
                string sql = sql1 + sWhere;
                ds = oCN.RunProcReturn(sql, "Xt_grdCondition");
                //添加列名
                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 = "1";
                objJsonResult.count = 1;
                objJsonResult.Message = "Sucess!";
                objJsonResult.list = columnNameList;
                objJsonResult.data = ds.Tables[0];
                return objJsonResult;
            }
            catch (Exception e)
            {
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "Exception!" + e.ToString();
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
        #endregion
        #region 高级过滤 方案 过滤条件 删除
        [Route("Xt_grdAlignment_WMES/Del_Gy_QueryConditionList_F_A")]
        [HttpGet]
        public object Del_Gy_QueryConditionList_F_A(string HModName, string ID, string user)
        {
            try
            {
                oCN.BeginTran();
                //删除方案主表
                oCN.RunProc("Delete From xt_ICSchemeMain where HInterID=" + ID.ToString());
                //删除 过滤条件
                oCN.RunProc("Delete From Xt_grdCondition where HInterID=" + ID.ToString());
                oCN.Commit();
                objJsonResult.code = "1";
                objJsonResult.count = 1;
                objJsonResult.Message = "删除成功!";
                objJsonResult.data = null;
                return objJsonResult;
            }
            catch (Exception e)
            {
                oCN.RollBack();
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "Exception!" + e.ToString();
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
        #endregion
        #region 高级过滤 方案 过滤条件 保存
        public class xt_ICScheme
        {
            public string HFieldNameCol;
            public string HControlCol;
            public string HConditionCol;
            public string HRelationCol;
        }
        public class data
        {
            public string id;
            public string title;
        }
        [Route("Xt_grdAlignment_WMES/Add_Gy_QueryConditionList_F_A")]
        [HttpPost]
        public object Add_Gy_QueryConditionList_F_A([FromBody] JObject sMainSub)
        {
            try
            {
                var _value = sMainSub["sMainSub"].ToString();
                string msg1 = _value.ToString();
                string[] sArray = msg1.Split(new string[] { ";" }, StringSplitOptions.RemoveEmptyEntries);
                string TableData = sArray[0].ToString();//字段过滤条件
                string F_A = sArray[1].ToString();//方案
                string HModName = sArray[2].ToString();//模块
                string HUserName = sArray[3].ToString();//用户
                List<xt_ICScheme> ListTableData = Newtonsoft.Json.JsonConvert.DeserializeObject<List<xt_ICScheme>>(TableData);
                data listF_A = Newtonsoft.Json.JsonConvert.DeserializeObject<data>(F_A);
                oCN.BeginTran();
                if (listF_A.id != "0")
                {
                    //删除主表
                    oCN.RunProc("Delete From xt_ICSchemeMain where HInterID=" + listF_A.id.ToString());
                }
                else {
                    listF_A.id = Pub_Class.ClsPub.CreateBillID("0001", ref Pub_Class.ClsPub.sExeReturnInfo).ToString(); ;
                }
                //添加方案主表
                oCN.RunProc("Insert Into xt_ICSchemeMain   " +
                "(HBillType,HInterID,HName,HUserCode" +
                ",HBillName,HStopflag" +
                ") " +
                " values('0001'," + listF_A.id.ToString() + ",'" + listF_A.title + "','" + HUserName + "'" +
                ",'" + HModName.ToString() + "',0" +
                ") ");
                //删除字段表数据
                oCN.RunProc("delete Xt_grdCondition where   HInterID=" + listF_A.id.ToString());
                ds = oCN.RunProcReturn("select column_name,data_type from information_schema.columns where table_name ='" + HModName + "' order by  ORDINAL_POSITION", "information");
                //添加过滤字段表
                for (int i = 0; i < ListTableData.Count; i++)
                {
                    for (int j = 0; j < ds.Tables[0].Rows.Count; j++)
                    {
                        if (ListTableData[i].HFieldNameCol == ds.Tables[0].Rows[j]["column_name"].ToString()) {
                            oCN.RunProc("Insert Into Xt_grdCondition   " +
                            "(HInterID,HUserID,HBillName,HRow,HIDCol,HBracketLCol,HFieldNameCol,HControlCol" +
                            ",HConditionCol,HBracketRCol,HRelationCol" +
                            ") " +
                            " values(" + listF_A.id.ToString() + ",'" + HUserName + "','" + HModName.Trim() + "'," + i +
                            ",'" + Pub_Class.ClsPub.isStrNull(ds.Tables[0].Rows[j]["column_name"].ToString()) + "'" +
                            ",''" +
                            ",'" + Pub_Class.ClsPub.isStrNull(ListTableData[i].HFieldNameCol) + "'" +
                            ",'" + Pub_Class.ClsPub.isStrNull(ListTableData[i].HControlCol) + "'" +
                            ",'" + Pub_Class.ClsPub.isStrNull(ListTableData[i].HConditionCol).Replace("'", "''") + "'" +
                            ",''" +
                            ",'" + Pub_Class.ClsPub.isStrNull(ListTableData[i].HRelationCol) + "')");
                            break;
                        }
                    }
                }
                oCN.Commit();
                objJsonResult.code = "1";
                objJsonResult.count = 1;
                objJsonResult.Message = "保存成功!";
                objJsonResult.data = null;
                return objJsonResult;
            }
            catch (Exception e)
            {
                oCN.RollBack();
                objJsonResult.code = "0";
                objJsonResult.count = 0;
                objJsonResult.Message = "Exception!" + e.ToString();
                objJsonResult.data = null;
                return objJsonResult;
            }
        }
        #endregion
    }
}