CGDD_SyncService.cs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. using HH.YiDaSyncNC.Dtos;
  2. using HH.YiDaSyncNC.Dtos.NC;
  3. using HH.YiDaSyncNC.Helper;
  4. using HH.YiDaSyncNC.Models;
  5. using Newtonsoft.Json;
  6. using SqlSugar;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.Configuration;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using System.Xml.Linq;
  14. namespace HH.YiDaSyncNC.DataSync
  15. {
  16. class CGDD_SyncService
  17. {
  18. public string _AppType;
  19. public string _SystemToken;
  20. public string _UserId;
  21. public string _FormId;
  22. public SqlSugarClient _db;
  23. public SqlSugarClient _db_nc;
  24. public string _NCApiUrl;
  25. public static string _Static_PK_po_order_bb = ConfigurationManager.AppSettings["po_order_bb"];
  26. public CGDD_SyncService(string AppType, string SystemToken, string UserId, string FormId, SqlSugarClient db, SqlSugarClient db_nc, string NCApiUrl)
  27. {
  28. _AppType = AppType;
  29. _SystemToken = SystemToken;
  30. _UserId = UserId;
  31. _FormId = FormId;
  32. _db = db;
  33. _db_nc = db_nc;
  34. _NCApiUrl = NCApiUrl;
  35. }
  36. public class IdCodeModel
  37. {
  38. public int sourceId { get; set; }
  39. public string Id { get; set; }
  40. }
  41. public void DataSync()
  42. {
  43. DingTalkService _dingTalkService = new DingTalkService(_AppType, _SystemToken, _UserId, _FormId);
  44. // 宜搭全量数据Id
  45. var idList = _dingTalkService.GetFormIdList("{\"radioField_lycrvvtk\":\"Y\"}");
  46. //var idList = _dingTalkService.GetFormIdList();
  47. // var idList = _dingTalkService.GetFormIdList("{\"textField_lr26y1io\":\"TESTDD202505200001\"}");
  48. LogHelper.WriteLog(JsonConvert.SerializeObject(idList.Count), "idList");
  49. // 获取当前最大Id
  50. var newId = 100000001;
  51. var maxData = _db_nc.Queryable<po_order_bb>().Where(w => w.pk_order_bb.Contains(_Static_PK_po_order_bb)).OrderByDescending(obd => obd.pk_order_bb).First();
  52. if (maxData != null && maxData.pk_order_bb.Contains(_Static_PK_po_order_bb))
  53. {
  54. newId = Convert.ToInt32(maxData.pk_order_bb.Replace(_Static_PK_po_order_bb, "")) + 1;
  55. }
  56. #region 获取NC中选项数据的Id
  57. var bd_customerDic = _db_nc.Queryable<bd_customer>().ToList();
  58. var bd_incomeDic = _db_nc.Queryable<bd_income>().ToList();
  59. var org_orgsDic = _db_nc.Queryable<org_orgs>().ToList();
  60. var bd_projectDic = _db_nc.Queryable<bd_project>().ToList();
  61. var bd_materialDic = _db_nc.Queryable<bd_material>().ToList();
  62. var bd_measdocDic = _db_nc.Queryable<bd_measdoc>().ToList();
  63. var org_deptDic = _db_nc.Queryable<org_dept>().ToList();
  64. var bd_psndocDic = _db_nc.Queryable<bd_psndoc>().ToList();
  65. var sm_userDic = _db_nc.Queryable<sm_user>().ToList();
  66. #endregion
  67. #region 插入数据
  68. // 向NC插入数据
  69. foreach (var item in idList)
  70. {
  71. string createTime = "";
  72. string modifyTime = "";
  73. var ydDataSource = _dingTalkService.GetFormDataById(item, out createTime, out modifyTime);
  74. // 如果NC单据号为空,说明没有传入过NC,此时正常走新增逻辑
  75. if (ydDataSource.FirstOrDefault(f => f.Key == "textField_ltxyt75m").Value != null && !string.IsNullOrWhiteSpace(ydDataSource["textField_ltxyt75m"].ToString()))
  76. {
  77. LogHelper.WriteLog("", "有NC单据号,需走修订流程,此时跳过:" + ydDataSource.FirstOrDefault(f => f.Key == "textField_ltxyt75m").Value);
  78. continue;
  79. }
  80. var dataSource = new CGDD_SyncServiceModel.DataModel();
  81. dataSource.集团 = "0";
  82. if (ydDataSource.FirstOrDefault(f => f.Key == "selectField_lr26l3h7").Value != null)
  83. {
  84. if (!string.IsNullOrWhiteSpace(ydDataSource["selectField_lr26l3h7"].ToString()))
  85. {
  86. var tempData = org_orgsDic.FirstOrDefault(f => f.name == ydDataSource["selectField_lr26l3h7"].ToString());
  87. if (tempData != null)
  88. {
  89. dataSource.组织 = tempData.code; // 组织
  90. }
  91. }
  92. }
  93. dataSource.订单编号 = ydDataSource["textField_lr26y1io"].ToString();
  94. dataSource.订单日期 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  95. dataSource.供应商 = ydDataSource["textField_lr26l3hf"].ToString();
  96. dataSource.制单人 = "OA-NC";
  97. dataSource.创建人 = "OA-NC";
  98. dataSource.制单时间 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  99. dataSource.创建时间 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  100. var detailList = new List<CGDD_SyncServiceModel.DataModel.OrderB>();
  101. var detailObjList = (List<object>)ydDataSource["tableField_ltxyt76f"]; // 采购物耗明细
  102. foreach (var objItem in detailObjList)
  103. {
  104. var detailItem = new CGDD_SyncServiceModel.DataModel.OrderB();
  105. detailItem.数量 = ((Dictionary<string, object>)objItem)["numberField_ltxyt75z"].ToString(); // 主数量
  106. if (detailItem.数量 == "0")
  107. {
  108. continue;
  109. }
  110. detailItem.物料编码 = ((Dictionary<string, object>)objItem)["textField_ltxyt75w"].ToString(); // 物料编码
  111. // detailItem.物料名称 = ((Dictionary<string, object>)objItem)["textField_ltxyt75x"].ToString(); // 物料编码
  112. if (!string.IsNullOrWhiteSpace(((Dictionary<string, object>)objItem)["textField_ltxyt75y"].ToString()))
  113. {
  114. DBHelper.WriteLog(((Dictionary<string, object>)objItem)["textField_ltxyt75y"].ToString(), "计量单位");
  115. detailItem.计量单位 = bd_measdocDic.FirstOrDefault(f => f.name.Trim() == ((Dictionary<string, object>)objItem)["textField_ltxyt75y"].ToString().Trim()).code; // 计量单位
  116. }
  117. detailItem.项目 = ((Dictionary<string, object>)objItem)["textField_lu23oe2w"].ToString(); // 项目编码
  118. detailItem.无税单价 = ((Dictionary<string, object>)objItem)["numberField_lutkmlw0"].ToString(); // 本币无税单价
  119. detailItem.含税单价 = ((Dictionary<string, object>)objItem)["numberField_ltxyt761"].ToString(); // 含税单价
  120. detailItem.无税金额 = ((Dictionary<string, object>)objItem)["numberField_lutkmlvz"].ToString(); // 无税金额
  121. detailItem.税额 = ((Dictionary<string, object>)objItem)["numberField_lutkmlw3"].ToString(); // 税额
  122. detailItem.价税合计 = ((Dictionary<string, object>)objItem)["numberField_ltxyt764"].ToString(); // 本币价税合计
  123. detailItem.联系人 = ((Dictionary<string, object>)objItem)["textField_lutkmlwb"].ToString(); //
  124. detailItem.收货地址 = ((Dictionary<string, object>)objItem)["textField_ltxyt76a"].ToString(); //
  125. detailList.Add(detailItem);
  126. }
  127. dataSource.pk_order_b = detailList;
  128. dataSource.数量 = dataSource.pk_order_b.Sum(s => Convert.ToDecimal(s.数量)).ToString();
  129. dataSource.价税合计 = dataSource.pk_order_b.Sum(s => Convert.ToDecimal(s.价税合计)).ToString();
  130. var results = NCImportFunc.NCImport(CGDD_SyncServiceModel.ImportXml.TemplateHeade(), CGDD_SyncServiceModel.ImportXml.Header(dataSource, item), _NCApiUrl + "?account=LY01&groupcode=0");
  131. DBHelper.WriteLog(results);
  132. XElement xE = XElement.Parse(results);
  133. string resultcode = xE.Element("sendresult").Element("resultcode").Value;
  134. DBHelper.WriteLog($"状态码:" + resultcode);
  135. string content = xE.Element("sendresult").Element("content")?.Value;
  136. string resultdescription = xE.Element("sendresult").Element("resultdescription")?.Value;
  137. var ncResData = new YiDaResDto()
  138. {
  139. syncTime = DateTime.Now,
  140. };
  141. // NC接口执行完成后的处理
  142. if (resultcode == "1")
  143. {
  144. DBHelper.WriteLog($"Id为【{JsonConvert.SerializeObject(item)}】的单据操作成功!");
  145. ncResData.bSuccess = true;
  146. ncResData.ncNo = xE.Element("sendresult").Element("content").Value;
  147. ncResData.log = "同步成功!";
  148. // 更新审核状态,并插入在途状态表
  149. var po_order = _db_nc.Queryable<po_order>().First(f => f.pk_order == xE.Element("sendresult").Element("content").Value);
  150. var po_order_b = _db_nc.Queryable<po_order_b>().Where(w => w.pk_order == xE.Element("sendresult").Element("content").Value).ToList();
  151. po_order.approver = "1001G1100000000B6553";
  152. po_order.forderstatus = "3";
  153. po_order.taudittime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  154. _db_nc.Updateable(po_order).ExecuteCommand();
  155. foreach (var itemB in po_order_b)
  156. {
  157. var bb = new po_order_bb();
  158. bb.dplanarrvdate = itemB.dplanarrvdate;
  159. bb.nmaxhandlenum = itemB.nastnum;
  160. bb.nonwaynum = itemB.nastnum;
  161. bb.pk_group = itemB.pk_group;
  162. bb.pk_order = itemB.pk_order;
  163. bb.pk_order_b = itemB.pk_order_b;
  164. bb.pk_org = itemB.pk_org;
  165. bb.pk_org_v = itemB.pk_org_v;
  166. bb.ts = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  167. bb.pk_order_bb = _Static_PK_po_order_bb + newId;
  168. _db_nc.Insertable(bb).ExecuteCommand();
  169. newId++;
  170. }
  171. }
  172. else
  173. {
  174. DBHelper.WriteLog($"Id为【{JsonConvert.SerializeObject(item)}】的单据操作失败!" + resultdescription + ";");
  175. ncResData.bSuccess = false;
  176. ncResData.ncNo = "";
  177. ncResData.log = "同步失败!原因为【" + resultdescription + "】";
  178. }
  179. var ydRes = _dingTalkService.UpdateFormDataSyncDataById(ncResData, item);
  180. }
  181. #endregion
  182. }
  183. }
  184. }