KP_TP_SyncService.cs 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577
  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 KP_TP_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_so_saleorder = ConfigurationManager.AppSettings["so_saleorder"];
  26. public static string _Static_PK_so_saleorder_b = ConfigurationManager.AppSettings["so_saleorder_b"];
  27. public static string _Static_pk_org_jt = ConfigurationManager.AppSettings["pk_org_jt"];
  28. public KP_TP_SyncService(string AppType, string SystemToken, string UserId, string FormId, SqlSugarClient db, SqlSugarClient db_nc, string NCApiUrl)
  29. {
  30. _AppType = AppType;
  31. _SystemToken = SystemToken;
  32. _UserId = UserId;
  33. _FormId = FormId;
  34. _db = db;
  35. _db_nc = db_nc;
  36. _NCApiUrl = NCApiUrl;
  37. }
  38. public class IdCodeModel
  39. {
  40. public int sourceId { get; set; }
  41. public string Id { get; set; }
  42. }
  43. public class FormItem
  44. {
  45. public string title { get; set; }
  46. }
  47. public void DataSync()
  48. {
  49. DingTalkService _dingTalkService = new DingTalkService(_AppType, _SystemToken, _UserId, _FormId);
  50. // 宜搭全量数据Id
  51. var idList = _dingTalkService.GetFormIdList("{\"radioField_lycrvvtk\":\"Y\",\"selectField_lvituew9\":\"已红冲\"}");
  52. //var idList = _dingTalkService.GetFormIdList("{\"textField_lvdosccc\":\"KP_2024071700252\"}");
  53. LogHelper.WriteLog(JsonConvert.SerializeObject(idList.Count), "idList");
  54. #region 获取NC中选项数据的Id
  55. var bd_customerDic = _db_nc.Queryable<bd_customer>().ToList();
  56. var bd_incomeDic = _db_nc.Queryable<bd_income>().ToList();
  57. var org_orgsDic = _db_nc.Queryable<org_orgs>().ToList();
  58. var bd_projectDic = _db_nc.Queryable<bd_project>().ToList();
  59. var bd_materialDic = _db_nc.Queryable<bd_material>().ToList();
  60. var bd_measdocDic = _db_nc.Queryable<bd_measdoc>().ToList();
  61. var org_deptDic = _db_nc.Queryable<org_dept>().ToList();
  62. var bd_psndocDic = _db_nc.Queryable<bd_psndoc>().ToList();
  63. var sm_userDic = _db_nc.Queryable<sm_user>().ToList();
  64. var bd_defdoc_kplx = _db_nc.Queryable<bd_defdoc>().Where(w => w.pk_defdoclist == "1001G1100000000016FV").ToList(); // 开票类型
  65. var bd_defdoc_htywlx = _db_nc.Queryable<bd_defdoc>().Where(w => w.pk_defdoclist == "1001G1100000000010PV").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. }
  78. else
  79. {
  80. continue;
  81. }
  82. var ncResData = new List<YiDaResDto>();
  83. #region 表头
  84. // 表头
  85. var dataSource = new KP_SyncServiceModel.DataModel();
  86. if (ydDataSource.FirstOrDefault(f => f.Key == "selectField_lvc9x4vo").Value != null)
  87. {
  88. if (!string.IsNullOrWhiteSpace(ydDataSource["selectField_lvc9x4vo"].ToString()))
  89. {
  90. var tempData = org_orgsDic.FirstOrDefault(f => f.name == ydDataSource["selectField_lvc9x4vo"].ToString());
  91. if (tempData != null)
  92. {
  93. dataSource.组织 = tempData.code; // 组织
  94. }
  95. }
  96. }
  97. dataSource.单据日期 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  98. //if (!string.IsNullOrWhiteSpace(ydDataSource["dateField_lw5ud9bk"].ToString()))
  99. //{
  100. // dataSource.单据日期 = UnixTimeHelper.ConvertMillisecondsToDateTime(Convert.ToInt64(ydDataSource["dateField_lw5ud9bk"].ToString())).ToString("yyyy-MM-dd HH:mm:ss");
  101. //}
  102. if (ydDataSource.FirstOrDefault(f => f.Key == "textField_lvdojfuj").Value != null)
  103. {
  104. if (!string.IsNullOrWhiteSpace(ydDataSource["textField_lvdojfuj"].ToString()))
  105. {
  106. var tempData = bd_customerDic.FirstOrDefault(f => f.code == ydDataSource["textField_lvdojfuj"].ToString());
  107. if (tempData != null)
  108. {
  109. dataSource.客户 = tempData.code; // 客户
  110. }
  111. }
  112. }
  113. if (ydDataSource.FirstOrDefault(f => f.Key == "selectField_lvc9x4vq").Value != null)
  114. {
  115. if (!string.IsNullOrWhiteSpace(ydDataSource["selectField_lvc9x4vq"].ToString()))
  116. {
  117. var tempData = bd_incomeDic.FirstOrDefault(f => f.name == ydDataSource["selectField_lvc9x4vq"].ToString());
  118. if (tempData != null)
  119. {
  120. dataSource.收款协议 = tempData.code; // 收款协议
  121. }
  122. }
  123. }
  124. if (ydDataSource.FirstOrDefault(f => f.Key == "departmentSelectField_lvc7mi3w").Value != null)
  125. {
  126. if (!string.IsNullOrWhiteSpace(ydDataSource["departmentSelectField_lvc7mi3w"].ToString()))
  127. {
  128. var tempData = org_deptDic.FirstOrDefault(f => f.name == JsonConvert.DeserializeObject<List<string>>(JsonConvert.SerializeObject(ydDataSource["departmentSelectField_lvc7mi3w"]))[0]);
  129. if (tempData != null)
  130. {
  131. dataSource.部门 = tempData.code; // 部门
  132. }
  133. }
  134. }
  135. dataSource.审批人 = "OA-NC";
  136. dataSource.制单人 = "OA-NC";
  137. dataSource.创建人 = "OA-NC";
  138. dataSource.审批时间 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  139. dataSource.制单时间 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  140. dataSource.创建时间 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  141. if (ydDataSource.FirstOrDefault(f => f.Key == "textField_lvdntzul").Value != null)
  142. {
  143. if (!string.IsNullOrWhiteSpace(ydDataSource["textField_lvdntzul"].ToString()))
  144. {
  145. var tempData = bd_projectDic.FirstOrDefault(f => f.project_code == ydDataSource["textField_lvdntzul"].ToString());
  146. if (tempData != null)
  147. {
  148. dataSource.项目 = tempData.project_code; // 项目
  149. }
  150. }
  151. }
  152. dataSource.发票号 = ydDataSource["textField_lwsth4o3"].ToString(); // 取重开发票号
  153. dataSource.客户打印名称 = ydDataSource["selectField_lvdojfui"].ToString();
  154. if (ydDataSource.FirstOrDefault(f => f.Key == "selectField_lvc9x4vp").Value != null)
  155. {
  156. if (!string.IsNullOrWhiteSpace(ydDataSource["selectField_lvc9x4vp"].ToString()))
  157. {
  158. var tempName = ydDataSource["selectField_lvc9x4vp"].ToString();
  159. if (ydDataSource["selectField_lvc9x4vp"].ToString() == "增值税专票")
  160. {
  161. tempName = "增值税专用发票";
  162. }
  163. if (ydDataSource["selectField_lvc9x4vp"].ToString() == "增值税普票")
  164. {
  165. tempName = "增值税普通发票";
  166. }
  167. var tempData = bd_defdoc_kplx.FirstOrDefault(f => f.name == tempName);
  168. if (tempData != null)
  169. {
  170. dataSource.开票类型 = tempData.pk_defdoc; // 开票类型
  171. }
  172. }
  173. }
  174. dataSource.OA单据号 = ydDataSource["textField_lvdosccc"].ToString();
  175. if (ydDataSource.FirstOrDefault(f => f.Key == "selectField_lvc9x4vn").Value != null)
  176. {
  177. if (!string.IsNullOrWhiteSpace(ydDataSource["selectField_lvc9x4vn"].ToString()))
  178. {
  179. if (ydDataSource["selectField_lvc9x4vn"].ToString().Contains("一次性") || ydDataSource["selectField_lvc9x4vn"].ToString().Contains("工程订单"))
  180. {
  181. dataSource.合同业务类型 = "1001G11000000000113F";
  182. }
  183. else
  184. {
  185. var tempData = bd_defdoc_htywlx.FirstOrDefault(f => f.name == ydDataSource["selectField_lvc9x4vn"].ToString());
  186. if (tempData != null)
  187. {
  188. dataSource.合同业务类型 = tempData.pk_defdoc; // 合同业务类型
  189. }
  190. }
  191. }
  192. }
  193. dataSource.年份 = DateTime.Now.ToString("yyyy");
  194. dataSource.月份 = DateTime.Now.ToString("MM");
  195. #endregion
  196. var detailList = new List<KP_SyncServiceModel.DataModel.OrderB>();
  197. #region 大业主开票明细
  198. if (ydDataSource.FirstOrDefault(f => f.Key == "tableField_lvc9x4vt").Value != null)
  199. {
  200. if (ydDataSource.FirstOrDefault(f => f.Key == "tableField_lvc9x4vt").Value != null)
  201. {
  202. var detailObjList1 = (List<object>)ydDataSource["tableField_lvc9x4vt"]; // 大业主开票明细
  203. if (detailObjList1.Count() > 0 && !string.IsNullOrWhiteSpace(((Dictionary<string, object>)detailObjList1.FirstOrDefault())["textField_lvdojfup"].ToString()))
  204. {
  205. foreach (var objItem in detailObjList1)
  206. {
  207. var detailItem = new KP_SyncServiceModel.DataModel.OrderB();
  208. if (!string.IsNullOrWhiteSpace(((Dictionary<string, object>)objItem)["associationFormField_lvynhq7p_id"].ToString()))
  209. {
  210. var sourceStr = ((Dictionary<string, object>)objItem)["associationFormField_lvynhq7p_id"].ToString().Replace("\\", "");
  211. var a = sourceStr = sourceStr.Substring(1, sourceStr.Length - 2);
  212. var b = JsonConvert.DeserializeObject<List<FormItem>>(a);
  213. var materialData = bd_materialDic.FirstOrDefault(f => f.name == b[0].title);
  214. detailItem.物料 = materialData.code; // 物料
  215. var unitCode = bd_measdocDic.FirstOrDefault(f => f.pk_measdoc == materialData.pk_measdoc);
  216. detailItem.计量单位 = unitCode.code; // 计量单位
  217. }
  218. var hsdj = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp2v"].ToString());
  219. var se = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp2z"].ToString());
  220. var wsdj = hsdj - se;
  221. var sl = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp2w"].ToString());
  222. var wsje = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp30"].ToString());
  223. var jshj = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp2y"].ToString());
  224. // 含税单价
  225. detailItem.含税单价 = hsdj.ToString();
  226. // 无税单价
  227. detailItem.无税单价 = wsdj.ToString();
  228. // 含税净价
  229. detailItem.含税净价 = hsdj.ToString();
  230. // 无税净价
  231. detailItem.无税净价 = wsdj.ToString();
  232. // 税额
  233. detailItem.税额 = se.ToString();
  234. // 无税金额
  235. detailItem.无税金额 = wsje.ToString();
  236. // 数量
  237. detailItem.数量 = sl.ToString();
  238. // 价税合计
  239. detailItem.价税合计 = jshj.ToString();
  240. detailItem.换算率 = "1.00/1.00";
  241. detailItem.税码 = "CN04"; // 税率码
  242. detailItem.税率 = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp2x"].ToString()).ToString(); // 税率
  243. detailItem.开票内容 = ((Dictionary<string, object>)objItem)["textField_lvd8pp2t"].ToString();
  244. detailItem.行id = ((Dictionary<string, object>)objItem)["textField_lvdojfup"].ToString();
  245. detailList.Add(detailItem);
  246. }
  247. }
  248. }
  249. }
  250. #endregion
  251. #region 工程订单开票明细
  252. if (ydDataSource.FirstOrDefault(f => f.Key == "tableField_lvd8pp44").Value != null)
  253. {
  254. var detailObjList2 = (List<object>)ydDataSource["tableField_lvd8pp44"]; // 工程订单开票明细
  255. if (ydDataSource.FirstOrDefault(f => f.Key == "tableField_lvd8pp44").Value != null)
  256. {
  257. if (detailObjList2.Count() > 0 && !string.IsNullOrWhiteSpace(((Dictionary<string, object>)detailObjList2.FirstOrDefault())["textField_lvdojfur"].ToString()))
  258. {
  259. dataSource.项目 = "PM99001";
  260. foreach (var objItem in detailObjList2)
  261. {
  262. var detailItem = new KP_SyncServiceModel.DataModel.OrderB();
  263. if (!string.IsNullOrWhiteSpace(((Dictionary<string, object>)objItem)["associationFormField_lvynrr6a_id"].ToString()))
  264. {
  265. var sourceStr = ((Dictionary<string, object>)objItem)["associationFormField_lvynrr6a_id"].ToString().Replace("\\", "");
  266. var a = sourceStr = sourceStr.Substring(1, sourceStr.Length - 2);
  267. var b = JsonConvert.DeserializeObject<List<FormItem>>(a);
  268. var materialData = bd_materialDic.FirstOrDefault(f => f.name == b[0].title);
  269. detailItem.物料 = materialData.code; // 物料
  270. var unitCode = bd_measdocDic.FirstOrDefault(f => f.pk_measdoc == materialData.pk_measdoc);
  271. detailItem.计量单位 = unitCode.code; // 计量单位
  272. }
  273. var hsdj = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp3y"].ToString());
  274. var se = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp42"].ToString());
  275. var wsdj = hsdj - se;
  276. var sl = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp3z"].ToString());
  277. var wsje = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp43"].ToString());
  278. var jshj = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp41"].ToString());
  279. // 含税单价
  280. detailItem.含税单价 = hsdj.ToString();
  281. // 无税单价
  282. detailItem.无税单价 = wsdj.ToString();
  283. // 含税净价
  284. detailItem.含税净价 = hsdj.ToString();
  285. // 无税净价
  286. detailItem.无税净价 = wsdj.ToString();
  287. // 税额
  288. detailItem.税额 = se.ToString();
  289. // 无税金额
  290. detailItem.无税金额 = wsje.ToString();
  291. // 数量
  292. detailItem.数量 = sl.ToString();
  293. // 价税合计
  294. detailItem.价税合计 = jshj.ToString();
  295. detailItem.换算率 = "1.00/1.00";
  296. detailItem.税码 = "CN04"; // 税率码
  297. detailItem.税率 = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvd8pp40"].ToString()).ToString(); // 税率
  298. detailItem.开票内容 = ((Dictionary<string, object>)objItem)["textField_lvd8pp3w"].ToString();
  299. detailItem.行id = ((Dictionary<string, object>)objItem)["textField_lvdojfur"].ToString();
  300. detailList.Add(detailItem);
  301. }
  302. }
  303. }
  304. }
  305. #endregion
  306. #region 小业主开票明细
  307. if (ydDataSource.FirstOrDefault(f => f.Key == "tableField_lvdnme13").Value != null)
  308. {
  309. var detailObjList3 = (List<object>)ydDataSource["tableField_lvdnme13"]; // 小业主
  310. if (ydDataSource.FirstOrDefault(f => f.Key == "tableField_lvdnme13").Value != null)
  311. {
  312. if (detailObjList3.Count() > 0 && !string.IsNullOrWhiteSpace(((Dictionary<string, object>)detailObjList3.FirstOrDefault())["textField_lvdojfus"].ToString()))
  313. {
  314. foreach (var objItem in detailObjList3)
  315. {
  316. var detailItem = new KP_SyncServiceModel.DataModel.OrderB();
  317. if (!string.IsNullOrWhiteSpace(((Dictionary<string, object>)objItem)["associationFormField_lvynrr6c_id"].ToString()))
  318. {
  319. var sourceStr = ((Dictionary<string, object>)objItem)["associationFormField_lvynrr6c_id"].ToString().Replace("\\", "");
  320. var a = sourceStr = sourceStr.Substring(1, sourceStr.Length - 2);
  321. var b = JsonConvert.DeserializeObject<List<FormItem>>(a);
  322. var materialData = bd_materialDic.FirstOrDefault(f => f.name == b[0].title);
  323. detailItem.物料 = materialData.code; // 物料
  324. var unitCode = bd_measdocDic.FirstOrDefault(f => f.pk_measdoc == materialData.pk_measdoc);
  325. detailItem.计量单位 = unitCode.code; // 计量单位
  326. }
  327. var hsdj = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvdnme0w"].ToString());
  328. var se = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvdnme10"].ToString());
  329. var wsdj = hsdj - se;
  330. var sl = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvdnme0x"].ToString());
  331. var wsje = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvdnme11"].ToString());
  332. var jshj = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvdnme0z"].ToString());
  333. // 含税单价
  334. detailItem.含税单价 = hsdj.ToString();
  335. // 无税单价
  336. detailItem.无税单价 = wsdj.ToString();
  337. // 含税净价
  338. detailItem.含税净价 = hsdj.ToString();
  339. // 无税净价
  340. detailItem.无税净价 = wsdj.ToString();
  341. // 税额
  342. detailItem.税额 = se.ToString();
  343. // 无税金额
  344. detailItem.无税金额 = wsje.ToString();
  345. // 数量
  346. detailItem.数量 = sl.ToString();
  347. // 价税合计
  348. detailItem.价税合计 = jshj.ToString();
  349. detailItem.换算率 = "1.00/1.00";
  350. detailItem.税码 = "CN04"; // 税率码
  351. detailItem.税率 = Convert.ToDecimal(((Dictionary<string, object>)objItem)["numberField_lvdnme0y"].ToString()).ToString(); // 税率
  352. detailItem.开票内容 = ((Dictionary<string, object>)objItem)["textField_lvdnme0u"].ToString();
  353. detailItem.行id = ((Dictionary<string, object>)objItem)["textField_lvdojfus"].ToString();
  354. detailList.Add(detailItem);
  355. }
  356. }
  357. }
  358. }
  359. #endregion
  360. var 旧发票号 = ydDataSource["textField_lvd8pp35"].ToString();
  361. var 新发票号 = ydDataSource["textField_lwsth4o3"].ToString();
  362. foreach (var detailItem in detailList)
  363. {
  364. // 替换明细中,开票内容字段中的发票号
  365. detailItem.开票内容 = detailItem.开票内容.Replace(旧发票号, 新发票号);
  366. // 将金额和数量都改为负数
  367. detailItem.数量 = "-" + detailItem.数量;
  368. detailItem.含税单价 = "-" + detailItem.含税单价;
  369. detailItem.无税单价 = "-" + detailItem.无税单价;
  370. detailItem.含税净价 = "-" + detailItem.含税净价;
  371. detailItem.无税净价 = "-" + detailItem.无税净价;
  372. detailItem.税额 = "-" + detailItem.税额;
  373. detailItem.无税金额 = "-" + detailItem.无税金额;
  374. detailItem.价税合计 = "-" + detailItem.价税合计;
  375. }
  376. dataSource.明细 = detailList;
  377. dataSource.数量 = dataSource.明细.Sum(s => Convert.ToDecimal(s.数量)).ToString();
  378. dataSource.价税合计 = dataSource.明细.Sum(s => Convert.ToDecimal(s.价税合计)).ToString();
  379. // 销售订单主表id
  380. var csaleorderid = ydDataSource["textField_ltxyt75m"].ToString();
  381. // -------------------------------销售订单同步完,开始同步销售发票
  382. var saleorderData = _db_nc.Queryable<so_saleorder>().First(f => f.csaleorderid == csaleorderid);
  383. var saleorderbData = _db_nc.Queryable<so_saleorder_b>().Where(f => f.csaleorderid == csaleorderid).ToList();
  384. dataSource.销售订单单据号 = saleorderData.vbillcode;
  385. dataSource.销售订单主表id = saleorderData.csaleorderid;
  386. foreach (var detailItem in dataSource.明细)
  387. {
  388. detailItem.销售订单子表id = saleorderbData.FirstOrDefault(f => f.vbdef10 == detailItem.行id).csaleorderbid;
  389. }
  390. var results_销售发票 = NCImportFunc.NCImport(KP_SyncServiceModel.ImportXml_销售发票.TemplateHeade(), KP_SyncServiceModel.ImportXml_销售发票.Header(dataSource, item + "_tp"), _NCApiUrl + "?account=LY01&groupcode=0");
  391. LogHelper.WriteLog(JsonConvert.SerializeObject(results_销售发票), "results_销售发票");
  392. XElement xE_销售发票 = XElement.Parse(results_销售发票);
  393. string resultcode_销售发票 = xE_销售发票.Element("sendresult").Element("resultcode").Value;
  394. string resultdescription_销售发票 = xE_销售发票.Element("sendresult").Element("resultdescription")?.Value;
  395. if (resultcode_销售发票 == "1")
  396. {
  397. ncResData.Add(new YiDaResDto()
  398. {
  399. bSuccess = true,
  400. ncNo = xE_销售发票.Element("sendresult").Element("content").Value,
  401. log = "同步成功!"
  402. });
  403. }
  404. else
  405. {
  406. ncResData.Add(new YiDaResDto()
  407. {
  408. bSuccess = false,
  409. ncNo = "",
  410. log = "同步失败!原因为【" + resultdescription_销售发票 + "】!"
  411. });
  412. }
  413. // -------------------------------销售发票同步完,开始同步应收 (新版)应收不同步,改为调用审核接口,让NC自动取生成应收单
  414. var results_销售发票审核 = HttpRequestHelper.ApporeNCCSOBill(xE_销售发票.Element("sendresult").Element("content").Value);
  415. LogHelper.WriteLog(JsonConvert.SerializeObject(results_销售发票审核), "results_销售发票审核");
  416. if (results_销售发票审核.state == 0)
  417. {
  418. ncResData.Add(new YiDaResDto()
  419. {
  420. bSuccess = true,
  421. ncNo = "",
  422. log = "同步成功!"
  423. });
  424. }
  425. else
  426. {
  427. ncResData.Add(new YiDaResDto()
  428. {
  429. bSuccess = false,
  430. ncNo = "",
  431. log = "同步失败!原因为【" + results_销售发票审核.msg + "】!"
  432. });
  433. }
  434. var finalResData = new YiDaResDto();
  435. if (ncResData.FirstOrDefault(f => !f.bSuccess) != null)
  436. {
  437. finalResData.bSuccess = false;
  438. finalResData.syncTime = DateTime.Now;
  439. finalResData.ncNo = csaleorderid;
  440. finalResData.log = string.Join(" || ", ncResData.Select(s => s.log));
  441. }
  442. else
  443. {
  444. finalResData.bSuccess = true;
  445. finalResData.syncTime = DateTime.Now;
  446. finalResData.ncNo = csaleorderid;
  447. finalResData.log = string.Join(" || ", ncResData.Select(s => s.log));
  448. }
  449. var ydRes = _dingTalkService.UpdateFormDataSyncDataById(finalResData, item);
  450. }
  451. #endregion
  452. }
  453. }
  454. }