| using Newtonsoft.Json; | 
| using Newtonsoft.Json.Linq; | 
| using Pub_Class; | 
| using System; | 
| using System.Collections; | 
| using System.Collections.Generic; | 
| using System.Data; | 
| using System.Data.SqlClient; | 
| using System.Web.Http; | 
| using WebAPI.Models; | 
| namespace WebAPI.Controllers | 
| { | 
|     public class Xt_BillTypeController : ApiController | 
|     { | 
|         public DBUtility.ClsPub.Enum_BillStatus BillStatus; | 
|         private json objJsonResult = new json(); | 
|         SQLHelper.ClsCN oCN = new SQLHelper.ClsCN(); | 
|         DataSet ds; | 
|   | 
|         /// <summary> | 
|         /// 返回单据类型列表 | 
|         ///参数:string sql。 | 
|         ///返回值:object。 | 
|         /// </summary> | 
|         [Route("Xt_BillType/list")] | 
|         [HttpGet] | 
|         public object list(string sWhere) | 
|         { | 
|             try | 
|             { | 
|                 List<object> columnNameList = new List<object>(); | 
|                 if (sWhere == null || sWhere.Equals("")) | 
|                 { | 
|                     ds = oCN.RunProcReturn("select * from h_v_Xt_BillTypeList " + sWhere+ "  order by hitemid desc", "h_v_Xt_BillTypeList"); | 
|                 } | 
|                 else | 
|                 { | 
|                     string sql1 = "select * from h_v_Xt_BillTypeList where 1 = 1 "; | 
|                     string sql = sql1 + sWhere+ "  order by hitemid desc"; | 
|                     ds = oCN.RunProcReturn(sql, "h_v_Xt_BillTypeList"); | 
|                 } | 
|   | 
|                 //添加列名 | 
|                 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列对象的列名 | 
|                 } | 
|   | 
|                 //if (ds.Tables[0].Rows.Count != 0 || ds != null) | 
|                 //{ | 
|                 objJsonResult.code = "1"; | 
|                 objJsonResult.count = 1; | 
|                 objJsonResult.Message = "Sucess!"; | 
|                 objJsonResult.data = ds.Tables[0]; | 
|                 objJsonResult.list = columnNameList; | 
|                 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 = "Exception!" + e.ToString(); | 
|                 objJsonResult.data = null; | 
|                 return objJsonResult; | 
|             } | 
|         } | 
|   | 
|         /// <summary> | 
|         /// 单据类型列表修改方法 | 
|         ///参数:string sql。 | 
|         ///返回值:object。 | 
|         /// </summary> | 
|         [Route("Xt_BillType/xg")] | 
|         [HttpGet] | 
|         public object xg(long HInterID) | 
|         { | 
|             try | 
|             { | 
|                 ds = oCN.RunProcReturn("select * from Xt_BillType where HItemID=" + HInterID, "Xt_BillType"); | 
|   | 
|                 objJsonResult.code = "1"; | 
|                 objJsonResult.count = 1; | 
|                 objJsonResult.Message = ""; | 
|                 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; | 
|             } | 
|         } | 
|   | 
|         /// <summary> | 
|         /// 获取最大基础资料ID | 
|         ///参数:string sql。 | 
|         ///返回值:object。 | 
|         /// </summary> | 
|         [Route("Xt_BillType/GetMAXBillID")] | 
|         [HttpGet] | 
|         public object GetMAXBillID() | 
|         { | 
|             try | 
|             { | 
|                 ds = oCN.RunProcReturn("select max(hitemid)+1 hitemid from Xt_BillType", "Xt_BillType"); | 
|   | 
|                 objJsonResult.code = "1"; | 
|                 objJsonResult.count = 1; | 
|                 objJsonResult.Message = ""; | 
|                 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; | 
|             } | 
|         } | 
|   | 
|         /// <summary> | 
|         /// 修改单据-保存按钮 | 
|         ///参数:string sql。 | 
|         ///返回值:object。 | 
|         /// </summary> | 
|         [Route("Xt_BillType/AddBill1")] | 
|         [HttpPost] | 
|         public object AddBill1([FromBody] JObject oMain) | 
|         { | 
|             try | 
|             { | 
|                 var _value = oMain["oMain"].ToString(); | 
|                 string msg1 = _value.ToString(); | 
|                 string[] sArray = msg1.Split(new string[] { ";" }, StringSplitOptions.RemoveEmptyEntries); | 
|                 string msg2 = sArray[0].ToString(); | 
|                 string msg3 = sArray[1].ToString(); | 
|                 string msg4 = sArray[2].ToString(); | 
|                 string msg5 = sArray[3].ToString(); | 
|                 //反序列化 | 
|                 msg2 = "[" + msg2.ToString() + "]"; | 
|                 List<BillType> list = Newtonsoft.Json.JsonConvert.DeserializeObject<List<BillType>>(msg2); | 
|   | 
|                 long HItemID = int.Parse(msg3); | 
|                 string HNumber = list[0].HNumber; | 
|                 string HName = list[0].HName; | 
|                 string HTemplate = list[0].HTemplate; | 
|                 string HHeadTable = list[0].HHeadTable; | 
|                 string HEntryTable = list[0].HEntryTable; | 
|                 string HViewName = list[0].HViewName; | 
|                 string HRightName = list[0].HRightName; | 
|   | 
|                 //若MAINDI重复则重新获取 | 
|                 oCN.BeginTran(); | 
|                 //主表 | 
|                 oCN.RunProc("Update Xt_BillType set " + | 
|                     " HNumber='" + HNumber + "'" + | 
|                     ",HName='" + HName + "'" + | 
|                     ",HTemplate='" + HTemplate + "'" + | 
|                     ",HHeadTable='" + HHeadTable + "'" + | 
|                     ",HEntryTable='" + HEntryTable + "'" + | 
|                     ",HViewName='" + HViewName + "'" + | 
|                     ",HRightName= '" + HRightName + "' Where HItemID=" + HItemID, ref DBUtility.ClsPub.sExeReturnInfo); | 
|                 //修改子项目代码 | 
|                 //oCN.RunProc("exec h_p_Gy_UpdateNumber Gy_Department,'" + HNumber + ".','" + this.HOldNumber + ".'", ref DBUtility.ClsPub.sExeReturnInfo); | 
|                 //将上级 为非末级 | 
|                 // | 
|                 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.Message; | 
|                 objJsonResult.data = null; | 
|                 return objJsonResult; | 
|             } | 
|         } | 
|   | 
|         /// <summary> | 
|         /// 新增单据-保存按钮 | 
|         ///参数:string sql。 | 
|         ///返回值:object。 | 
|         /// </summary> | 
|         [Route("Xt_BillType/AddBill")] | 
|         [HttpPost] | 
|         public object AddBill([FromBody] JObject oMain) | 
|         { | 
|             try | 
|             { | 
|                 var _value = oMain["oMain"].ToString(); | 
|                 string msg1 = _value.ToString(); | 
|                 //反序列化 | 
|                 msg1 = "[" + msg1.ToString() + "]"; | 
|                 List<BillType> list = Newtonsoft.Json.JsonConvert.DeserializeObject<List<BillType>>(msg1); | 
|                 long HItemID = list[0].HItemID; | 
|                 string HNumber = list[0].HNumber; | 
|                 string HName = list[0].HName; | 
|                 string HTemplate = list[0].HTemplate; | 
|                 string HHeadTable = list[0].HHeadTable; | 
|                 string HEntryTable = list[0].HEntryTable; | 
|                 string HViewName = list[0].HViewName; | 
|                 string HRightName = list[0].HRightName; | 
|   | 
|                 //若MAINDI重复则重新获取 | 
|                 oCN.BeginTran(); | 
|   | 
|                 //主表 | 
|                 oCN.RunProc("Insert Into Xt_BillType " + | 
|                 "(HNumber,HName,HTemplate,HHeadTable" + | 
|                 ",HEntryTable,HViewName,HRightName" + | 
|                 ") " + | 
|                 " values('" + HNumber + "','" + HName + "','" + HTemplate + "','" + HHeadTable + "'" + | 
|                 ",'" + HEntryTable + "','" + HViewName + "','" + HRightName + "'" + | 
|               ") "); | 
|                 //修改上级为非末级代码 | 
|                 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.Message; | 
|                 objJsonResult.data = null; | 
|                 return objJsonResult; | 
|             } | 
|         } | 
|   | 
|          | 
|         /// <summary> | 
|         /// 单据删除 | 
|         ///参数:string HInterID。 | 
|         ///返回值:object。 | 
|         /// </summary> | 
|         [Route("YS_ReceiveBill/delete_Test1")] | 
|         [HttpGet] | 
|         public object deleteYS_ReceiveBill(long HItemID) | 
|         { | 
|             try | 
|             { | 
|                 //若MAINDI重复则重新获取 | 
|                 oCN.BeginTran(); | 
|                 //主表 | 
|                 oCN.RunProc("delete from Xt_BillType Where HItemID =" + HItemID, ref DBUtility.ClsPub.sExeReturnInfo); | 
|                 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 = "Exception!" + e.ToString(); | 
|                 objJsonResult.data = null; | 
|                 return objJsonResult; | 
|             } | 
|         } | 
|   | 
|         #region 单据类型 金蝶同步 | 
|         [Route("Xt_BillType/SaveXt_BillTypeListApi")] | 
|         [HttpPost] | 
|         public object SaveXt_BillTypeListApi([FromBody] JObject msg) | 
|         { | 
|             try | 
|             { | 
|                 var _value = msg["model"].ToString(); | 
|                 LogService.Write("单据类型:" + _value); | 
|                 SQLHelper.ClsCN oCN = new SQLHelper.ClsCN(); | 
|                 ListModels oListModels = new ListModels(); | 
|                 List<Model.ClsXt_BillType_Model> lsmain = new List<Model.ClsXt_BillType_Model>(); | 
|                 lsmain = oListModels.getObjectByJson_Xt_BillType(_value); | 
|                 string sql = string.Empty; | 
|                 //保存 | 
|                 oCN.BeginTran(); | 
|                 sql = $"delete Xt_BillType where HItemID = {lsmain[0].HItemID}"; | 
|                 oCN.RunProc(sql); | 
|                 //sql = "set identity_insert Xt_BillType on"; | 
|                 //oCN.RunProc(sql); | 
|   | 
|                 LogService.Write("单据类型:" + $@"insert into Xt_BillType(HBilltypeID,HNumber,HName,HTemplate,HHeadTable,HEntryTable,HViewName,HRightName) | 
|                   values('{lsmain[0].HBilltypeID}','{lsmain[0].HNumber}','{lsmain[0].HName}','{lsmain[0].HTemplate}','{lsmain[0].HHeadTable}','{lsmain[0].HEntryTable}','{lsmain[0].HViewName}','{lsmain[0].HRightName}' )"); | 
|   | 
|                 oCN.RunProc($@"insert into Xt_BillType(HBilltypeID,HNumber,HName,HTemplate,HHeadTable,HEntryTable,HViewName,HRightName) | 
|                   values('{lsmain[0].HBilltypeID}','{lsmain[0].HNumber}','{lsmain[0].HName}','{lsmain[0].HTemplate}','{lsmain[0].HHeadTable}','{lsmain[0].HEntryTable}','{lsmain[0].HViewName}','{lsmain[0].HRightName}' )", ref DBUtility.ClsPub.sExeReturnInfo); | 
|                 //修改上级为非末级代码 | 
|                 sql = "set identity_insert Xt_BillType off"; | 
|                 oCN.RunProc(sql); | 
|                 oCN.Commit(); | 
|   | 
|                 objJsonResult.code = "1"; | 
|                 objJsonResult.count = 1; | 
|                 objJsonResult.Message = "保存成功!"; | 
|                 objJsonResult.data = 1; | 
|                 return objJsonResult; | 
|             } | 
|             catch (Exception e) | 
|             { | 
|                 objJsonResult.code = "0"; | 
|                 objJsonResult.count = 0; | 
|                 objJsonResult.Message = "保存失败!" + e.ToString(); | 
|                 objJsonResult.data = 1; | 
|                 return objJsonResult; | 
|             } | 
|         } | 
|         #endregion | 
|   | 
|     } | 
| } |