FK_CLBX_SyncService.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317
  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 FK_CLBX_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_bd_project = ConfigurationManager.AppSettings["bd_project"];
  26. public static string _Static_pk_org_jt = ConfigurationManager.AppSettings["pk_org_jt"];
  27. public FK_CLBX_SyncService(string AppType, string SystemToken, string UserId, string FormId, SqlSugarClient db, SqlSugarClient db_nc, string NCApiUrl)
  28. {
  29. _AppType = AppType;
  30. _SystemToken = SystemToken;
  31. _UserId = UserId;
  32. _FormId = FormId;
  33. _db = db;
  34. _db_nc = db_nc;
  35. _NCApiUrl = NCApiUrl;
  36. }
  37. public class IdCodeModel
  38. {
  39. public int sourceId { get; set; }
  40. public string Id { get; set; }
  41. }
  42. public class FormItem
  43. {
  44. public string title { get; set; }
  45. }
  46. public void DataSync()
  47. {
  48. DingTalkService _dingTalkService = new DingTalkService(_AppType, _SystemToken, _UserId, _FormId);
  49. // 宜搭全量数据Id
  50. var idList = _dingTalkService.GetFormCodeList("");
  51. // var idList = _dingTalkService.GetFormIdList("{\"serialNumberField_lsx02quw\":\"FYBX202407070062\"}");
  52. LogHelper.WriteLog(JsonConvert.SerializeObject(idList.Count), "idList");
  53. #region 获取NC中选项数据的Id
  54. var bd_custclassDic = _db_nc.Queryable<bd_custclass>().ToList();
  55. var org_orgsDic = _db_nc.Queryable<org_orgs>().ToList();
  56. var bd_projectDic = _db_nc.Queryable<bd_project>().ToList();
  57. var org_deptDic = _db_nc.Queryable<org_dept>().ToList();
  58. #endregion
  59. #region 插入数据
  60. // 向NC插入数据
  61. foreach (var item in idList)
  62. {
  63. string createTime = "";
  64. string modifyTime = "";
  65. var ydDataSource = _dingTalkService.GetFormDataById(item, out createTime, out modifyTime);
  66. // 如果NC单据号为空,说明没有传入过NC,此时需要走此逻辑去传输
  67. if (ydDataSource.FirstOrDefault(f => f.Key == "textField_ltxyt75m").Value != null && !string.IsNullOrWhiteSpace(ydDataSource["textField_ltxyt75m"].ToString()))
  68. {
  69. continue;
  70. }
  71. var ncResData = new List<YiDaResDto>();
  72. #region 表头
  73. // 表头
  74. var dataSource = new FK_CLBX_SyncServiceModel.DataModel();
  75. if (!string.IsNullOrWhiteSpace(ydDataSource["associationFormField_lvyplgvg_id"].ToString()))
  76. {
  77. var sourceStr = ydDataSource["associationFormField_lvyplgvg_id"].ToString().Replace("\\", "");
  78. var a = sourceStr = sourceStr.Substring(1, sourceStr.Length - 2);
  79. var b = JsonConvert.DeserializeObject<List<FormItem>>(a);
  80. var tempData = org_orgsDic.FirstOrDefault(f => f.name == b[0].title);
  81. if (tempData != null)
  82. {
  83. dataSource.组织 = tempData.code; // 组织
  84. }
  85. }
  86. dataSource.支付人 = "OA-NC";
  87. if (ydDataSource.FirstOrDefault(f => f.Key == "dateField_lsx0pirp").Value != null && !string.IsNullOrWhiteSpace(ydDataSource["dateField_lsx0pirp"].ToString()))
  88. {
  89. dataSource.支付日期 = UnixTimeHelper.ConvertMillisecondsToDateTime(Convert.ToInt64(ydDataSource["dateField_lsx0pirp"].ToString())).ToString("yyyy-MM-dd HH:mm:ss");
  90. }
  91. else
  92. {
  93. var resData = new YiDaResDto();
  94. resData.bSuccess = false;
  95. resData.syncTime = DateTime.Now;
  96. resData.ncNo = "";
  97. resData.log = "付款银行账户为空,NC无法执行审批操作";
  98. _dingTalkService.UpdateFormDataSyncDataById(resData, item);
  99. continue;
  100. }
  101. dataSource.创建人 = "OA-NC";
  102. dataSource.制单人 = "OA-NC";
  103. dataSource.单据日期 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  104. dataSource.生效人 = "OA-NC";
  105. dataSource.生效日期 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  106. // dataSource.发票号 = ydDataSource["textField_lw7erc7d"].ToString();
  107. dataSource.付款银行账户 = ydDataSource["textField_lsx02qvj"].ToString().Trim().Replace(" ", "");
  108. dataSource.年份 = DateTime.Now.ToString("yyyy");
  109. dataSource.月份 = DateTime.Now.ToString("MM");
  110. dataSource.起算日期 = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  111. // 判断是项目、或是部门
  112. // 如果通过新字段取不到,则取老字段
  113. var xmbmValue = "";
  114. if (ydDataSource.FirstOrDefault(f => f.Key == "selectField_lysgxw9d").Value != null)
  115. {
  116. xmbmValue = ydDataSource["selectField_lysgxw9d"].ToString();
  117. }
  118. else
  119. {
  120. if (ydDataSource.FirstOrDefault(f => f.Key == "departmentSelectField_lvuaqzvf").Value != null)
  121. {
  122. if (!string.IsNullOrWhiteSpace(ydDataSource["departmentSelectField_lvuaqzvf"].ToString()))
  123. {
  124. xmbmValue = JsonConvert.DeserializeObject<List<string>>(JsonConvert.SerializeObject(ydDataSource["departmentSelectField_lvuaqzvf"]))[0];
  125. }
  126. }
  127. }
  128. var project = bd_projectDic.FirstOrDefault(f => f.project_name == xmbmValue); ;
  129. var dept = org_deptDic.FirstOrDefault(f => f.name == xmbmValue);
  130. if (project != null)
  131. {
  132. dataSource.项目 = project.project_code;
  133. }
  134. else if (dept != null)
  135. {
  136. dataSource.部门 = dept.code;
  137. }
  138. #endregion
  139. var detailList = new List<FK_CLBX_SyncServiceModel.DataModel.Item>();
  140. // 交通费(车船票)
  141. if (ydDataSource.FirstOrDefault(f => f.Key == "numberField_lujixr38").Value != null && !string.IsNullOrWhiteSpace(ydDataSource["numberField_lujixr38"].ToString()) && ydDataSource["numberField_lujixr38"].ToString() != "0")
  142. {
  143. var detailItem = new FK_CLBX_SyncServiceModel.DataModel.Item();
  144. detailItem.收支项目 = "2";
  145. detailItem.价税合计 = ydDataSource["numberField_lujixr38"].ToString();
  146. detailItem.无税金额 = ydDataSource["numberField_lujixr38"].ToString();
  147. detailItem.税额 = "0";
  148. detailList.Add(detailItem);
  149. }
  150. // 住宿费
  151. if (ydDataSource.FirstOrDefault(f => f.Key == "numberField_lvuk32z0").Value != null && !string.IsNullOrWhiteSpace(ydDataSource["numberField_lvuk32z0"].ToString()) && ydDataSource["numberField_lvuk32z0"].ToString() != "0")
  152. {
  153. var detailItem = new FK_CLBX_SyncServiceModel.DataModel.Item();
  154. detailItem.收支项目 = "1";
  155. detailItem.价税合计 = ydDataSource["numberField_lvuk32z0"].ToString();
  156. detailItem.无税金额 = ydDataSource["numberField_lvuk32z0"].ToString();
  157. detailItem.税额 = "0";
  158. detailList.Add(detailItem);
  159. }
  160. // 餐费
  161. if (ydDataSource.FirstOrDefault(f => f.Key == "numberField_lujixr39").Value != null && !string.IsNullOrWhiteSpace(ydDataSource["numberField_lujixr39"].ToString()) && ydDataSource["numberField_lujixr39"].ToString() != "0")
  162. {
  163. var detailItem = new FK_CLBX_SyncServiceModel.DataModel.Item();
  164. detailItem.收支项目 = "3";
  165. detailItem.价税合计 = ydDataSource["numberField_lujixr39"].ToString();
  166. detailItem.无税金额 = ydDataSource["numberField_lujixr39"].ToString();
  167. detailItem.税额 = "0";
  168. detailList.Add(detailItem);
  169. }
  170. // 交通费
  171. if (ydDataSource.FirstOrDefault(f => f.Key == "textField_lujixr3b").Value != null && !string.IsNullOrWhiteSpace(ydDataSource["textField_lujixr3b"].ToString()) && ydDataSource["textField_lujixr3b"].ToString() != "0")
  172. {
  173. var detailItem = new FK_CLBX_SyncServiceModel.DataModel.Item();
  174. detailItem.收支项目 = "2";
  175. detailItem.价税合计 = ydDataSource["textField_lujixr3b"].ToString();
  176. detailItem.无税金额 = ydDataSource["textField_lujixr3b"].ToString();
  177. detailItem.税额 = "0";
  178. detailList.Add(detailItem);
  179. }
  180. // 交通费(新版字段)
  181. if (ydDataSource.FirstOrDefault(f => f.Key == "numberField_lz15kh79").Value != null && !string.IsNullOrWhiteSpace(ydDataSource["numberField_lz15kh79"].ToString()) && ydDataSource["numberField_lz15kh79"].ToString() != "0")
  182. {
  183. var detailItem = new FK_CLBX_SyncServiceModel.DataModel.Item();
  184. detailItem.收支项目 = "2";
  185. detailItem.价税合计 = ydDataSource["numberField_lz15kh79"].ToString();
  186. detailItem.无税金额 = ydDataSource["numberField_lz15kh79"].ToString();
  187. detailItem.税额 = "0";
  188. detailList.Add(detailItem);
  189. }
  190. dataSource.明细 = detailList;
  191. dataSource.价税合计 = dataSource.明细.Sum(s => Convert.ToDecimal(s.价税合计)).ToString();
  192. var results = NCImportFunc.NCImport(FK_CLBX_SyncServiceModel.ImportXml.TemplateHeade(), FK_CLBX_SyncServiceModel.ImportXml.Header(dataSource, item + "_clbx"), _NCApiUrl + "?account=LY01&groupcode=0");
  193. LogHelper.WriteLog(JsonConvert.SerializeObject(results), "results");
  194. XElement xE = XElement.Parse(results);
  195. string resultcode = xE.Element("sendresult").Element("resultcode").Value;
  196. string resultdescription = xE.Element("sendresult").Element("resultdescription")?.Value;
  197. if (resultcode == "1")
  198. {
  199. ncResData.Add(new YiDaResDto()
  200. {
  201. bSuccess = true,
  202. ncNo = xE.Element("sendresult").Element("content").Value,
  203. log = "同步成功!"
  204. });
  205. var recitemData = _db_nc.Queryable<ap_payitem>().Where(w => w.pk_paybill == xE.Element("sendresult").Element("content").Value).ToList();
  206. foreach (var recitem in recitemData)
  207. {
  208. var a = dataSource.明细.FirstOrDefault(f => f.无税金额 == recitem.def11);
  209. recitem.scomment = a.摘要;
  210. _db_nc.Updateable(recitem).ExecuteCommand();
  211. }
  212. }
  213. else
  214. {
  215. ncResData.Add(new YiDaResDto()
  216. {
  217. bSuccess = false,
  218. ncNo = "",
  219. log = "同步失败!原因为【" + resultdescription + "】!"
  220. });
  221. }
  222. var results_付款单审核 = HttpRequestHelper.ApproveNCFKBill(xE.Element("sendresult").Element("content").Value);
  223. LogHelper.WriteLog(JsonConvert.SerializeObject(results_付款单审核), "results_付款单审核");
  224. if (results_付款单审核.state == 0)
  225. {
  226. ncResData.Add(new YiDaResDto()
  227. {
  228. bSuccess = true,
  229. ncNo = "",
  230. log = "同步成功!"
  231. });
  232. }
  233. else
  234. {
  235. ncResData.Add(new YiDaResDto()
  236. {
  237. bSuccess = false,
  238. ncNo = "",
  239. log = "同步失败!原因为【" + results_付款单审核.msg + "】!"
  240. });
  241. }
  242. var finalResData = new YiDaResDto();
  243. if (ncResData.FirstOrDefault(f => !f.bSuccess) != null)
  244. {
  245. finalResData.bSuccess = false;
  246. finalResData.syncTime = DateTime.Now;
  247. finalResData.ncNo = xE.Element("sendresult").Element("content").Value;
  248. finalResData.log = string.Join(" || ", ncResData.Select(s => s.log));
  249. }
  250. else
  251. {
  252. finalResData.bSuccess = true;
  253. finalResData.syncTime = DateTime.Now;
  254. finalResData.ncNo = xE.Element("sendresult").Element("content").Value;
  255. finalResData.log = string.Join(" || ", ncResData.Select(s => s.log));
  256. }
  257. var ydRes = _dingTalkService.UpdateFormDataSyncDataById(finalResData, item);
  258. }
  259. #endregion
  260. }
  261. }
  262. }