JsonMappingForm.cs 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659
  1. using Microsoft.VisualBasic;
  2. using Newtonsoft.Json.Linq;
  3. using PTMedicalInsurance;
  4. using PTMedicalInsurance.Common;
  5. using PTMedicalInsurance.Entity;
  6. using PTMedicalInsurance.Helper;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.ComponentModel;
  10. using System.Data;
  11. using System.Drawing;
  12. using System.Linq;
  13. using System.Text;
  14. using System.Threading.Tasks;
  15. using System.Windows.Forms;
  16. namespace PTMedicalInsurance.Forms
  17. {
  18. public partial class JsonMappingForm : Form
  19. {
  20. List<FieldMapping> fieldMappings = new List<FieldMapping>();
  21. private bool baseToLocal = true;
  22. private bool orginInputFlag = true;
  23. string separator = ">";
  24. string arrayPattern = "[]";
  25. JsonMapper mapper;
  26. public JsonMappingForm()
  27. {
  28. InitializeComponent();
  29. }
  30. /// <summary>
  31. /// 初始化
  32. /// </summary>
  33. /// <param name="baseJson">基线实例</param>
  34. /// <param name="localJson">本地实例</param>
  35. /// <param name="tradeName">交易名称</param>
  36. public JsonMappingForm(string baseJson, string localJson, string tradeName, bool inputFlag = true)
  37. {
  38. InitializeComponent();
  39. txtBase.Text = baseJson;
  40. txtLocal.Text = localJson;
  41. txtName.Text = tradeName;
  42. this.baseToLocal = inputFlag;
  43. this.orginInputFlag = inputFlag; //原始状态
  44. // 初始化mapper
  45. mapper = new JsonMapper(txtName.Text);
  46. txtName.Enabled = false;
  47. }
  48. private void JsonMappingForm_Load(object sender, EventArgs e)
  49. {
  50. btnMap.Enabled = false;
  51. if (!this.baseToLocal)
  52. {
  53. radioOutput.Checked = true;
  54. }
  55. this.loadFieldMapping();
  56. this.loadConfig();
  57. }
  58. private void btnLoad_Click(object sender, EventArgs e)
  59. {
  60. loadFieldMapping();
  61. }
  62. private void loadFieldMapping()
  63. {
  64. lstBase.Items.Clear();
  65. lstLocal.Items.Clear();
  66. btnMap.Enabled = true;
  67. //btnLoad.Enabled = false;
  68. if (!string.IsNullOrEmpty(txtBase.Text.Trim()))
  69. {
  70. JObject joInput = JObject.Parse(txtBase.Text);
  71. parseJsonToList(joInput, this.lstBase, new StringBuilder());
  72. }
  73. if (!string.IsNullOrEmpty(txtLocal.Text.Trim()))
  74. {
  75. JObject joInput = JObject.Parse(txtLocal.Text);
  76. parseJsonToList(joInput, this.lstLocal, new StringBuilder());
  77. }
  78. }
  79. private void parseJsonToList(JToken jToken, ListBox lstBox, StringBuilder sb)
  80. {
  81. if (jToken is JProperty jProperty)
  82. {
  83. if (sb.Length > 0)
  84. {
  85. sb.Append(".");
  86. }
  87. sb.Append(jProperty.Name);
  88. parseJsonToList(jProperty.Value, lstBox, sb);
  89. }
  90. else if (jToken is JArray jArray)
  91. {
  92. sb.Append("[]");
  93. if (jArray.Count > 0)
  94. {
  95. var item = jArray[0]; // only load first row
  96. parseJsonToList(item, lstBox, new StringBuilder(sb.ToString()));
  97. }
  98. }
  99. else if (jToken is JObject jObject)
  100. {
  101. foreach (var property in jObject.Properties())
  102. {
  103. parseJsonToList(property, lstBox, new StringBuilder(sb.ToString()));
  104. }
  105. }
  106. else
  107. {
  108. // 输出最终结果
  109. lstBox.Items.Add(sb.ToString());
  110. }
  111. // JValue
  112. }
  113. private void btnMap_Click(object sender, EventArgs e)
  114. {
  115. baseToLocal = radioInput.Checked;
  116. if (lstBase.SelectedIndex < 0)
  117. {
  118. MessageBox.Show("请先选中基线版属性!");
  119. return;
  120. }
  121. if (lstLocal.SelectedIndex < 0)
  122. {
  123. MessageBox.Show("请先选中地方版属性!");
  124. return;
  125. }
  126. AddMapping();
  127. }
  128. private void AddMapping()
  129. {
  130. FieldMapping field = new FieldMapping();
  131. string sKey = lstBase.SelectedItem.ToString();
  132. string tKey = lstLocal.SelectedItem.ToString();
  133. field.Source = sKey;
  134. field.Target = tKey;
  135. string text = field.Source + separator + field.Target;
  136. if (!this.baseToLocal)
  137. {
  138. text = field.Target + separator + field.Source;
  139. field.Source = lstLocal.SelectedItem.ToString();
  140. field.Target = lstBase.SelectedItem.ToString();
  141. }
  142. if ("saveToExpand".Equals(field.Expression))
  143. {
  144. text += "(*)";
  145. }
  146. FieldMapping orginField = null;
  147. // array
  148. List <FieldMapping> childs = null;
  149. if (field.Source.Contains(arrayPattern) && field.Target.Contains(arrayPattern))
  150. {
  151. sKey = field.Source.Split(arrayPattern.ToCharArray())[0] + arrayPattern;
  152. tKey = field.Target.Split(arrayPattern.ToCharArray())[0] + arrayPattern;
  153. orginField = fieldMappings.FirstOrDefault(m => m.Source == sKey && m.Target == tKey)??new FieldMapping();
  154. childs = orginField.Child??new List<FieldMapping>();
  155. orginField.Source = sKey;
  156. orginField.Target = tKey;
  157. field.Source = field.Source.Replace(sKey + ".", "");
  158. field.Target = field.Target.Replace(tKey + ".", "");
  159. }
  160. if (childs != null)
  161. {
  162. if (!childs.Contains(field))
  163. {
  164. childs.Add(field);
  165. orginField.Child = childs;
  166. if(!fieldMappings.Contains(orginField))
  167. {
  168. fieldMappings.Add(orginField);
  169. }
  170. }
  171. }
  172. else
  173. {
  174. fieldMappings.Add(field);
  175. }
  176. lstMap.Items.Add(text);
  177. // clear selectedItem
  178. lstLocal.Items.Remove(lstLocal.SelectedItem);
  179. lstBase.Items.Remove(lstBase.SelectedItem);
  180. }
  181. private void lstMap_DoubleClick(object sender, EventArgs e)
  182. {
  183. string text = lstMap.SelectedItem.ToString();
  184. string[] fields = text.Split(separator.ToCharArray());
  185. if (!fields[1].Contains("【"))
  186. {
  187. if (this.baseToLocal)
  188. {
  189. if (!lstBase.Items.Contains(fields[0])) lstBase.Items.Add(fields[0]);
  190. if (!lstLocal.Items.Contains(fields[1])) lstLocal.Items.Add(fields[1]);
  191. }
  192. else
  193. {
  194. if (!lstBase.Items.Contains(fields[1])) lstBase.Items.Add(fields[1]);
  195. if (!lstLocal.Items.Contains(fields[0])) lstLocal.Items.Add(fields[0]);
  196. }
  197. }
  198. fields[1] = fields[1].Replace("【】", "");
  199. FieldMapping field = QuerySelectedField();
  200. if (field != null)
  201. {
  202. this.fieldMappings.Remove(field);
  203. }
  204. lstMap.Items.Remove(lstMap.SelectedItem);
  205. }
  206. private FieldMapping QuerySelectedField()
  207. {
  208. if (lstMap.SelectedItem == null) return null;
  209. // TODO:如果目标是数组未处理
  210. string text = lstMap.SelectedItem.ToString();
  211. string[] fields = text.Split(separator.ToCharArray());
  212. // remove from fieldMapping
  213. string txtValue = fields[1].Replace("【","").Replace("】","");
  214. FieldMapping field = this.fieldMappings.FirstOrDefault(m => (m.Source == fields[0] && m.Target == fields[1]) || (m.Target == fields[0] && m.Value == txtValue));
  215. return field;
  216. }
  217. private void btnConfig_Click(object sender, EventArgs e)
  218. {
  219. if (string.IsNullOrEmpty(txtName.Text))
  220. {
  221. MessageBox.Show("请输入交易名称!");
  222. return;
  223. }
  224. if (lstMap.Items.Count > 0) {
  225. if (!Utils.Confirm("加载配置将清除已有配置,您确定要加载吗?"))
  226. {
  227. return;
  228. }
  229. lstMap.Items.Clear();
  230. }
  231. loadConfig();
  232. }
  233. private void loadConfig()
  234. {
  235. this.baseToLocal = radioInput.Checked;
  236. if(this.mapper == null)
  237. {
  238. mapper = new JsonMapper(txtName.Text);
  239. }
  240. mapper.reload();
  241. if (this.baseToLocal)
  242. {
  243. fieldMappings = mapper.GetInputMapping();
  244. loadConfigMapping();
  245. }
  246. else
  247. {
  248. fieldMappings = mapper.GetOutputMapping();
  249. loadConfigMapping();
  250. }
  251. }
  252. private void loadConfigMapping(bool clearFlag = true)
  253. {
  254. lstMap.Items.Clear();
  255. if (fieldMappings?.Count > 0)
  256. {
  257. fieldMappings.ForEach((map) =>
  258. {
  259. if (map.Child != null)
  260. {
  261. map.Child.ForEach((m) => loadChildMapping(m, clearFlag, map.Source+".",map.Target + "."));
  262. }
  263. else
  264. {
  265. loadChildMapping(map);
  266. }
  267. });
  268. }
  269. }
  270. private void loadChildMapping(FieldMapping map,bool clearFlag = true, string srcRoot = "",string destRoot = "")
  271. {
  272. string text = srcRoot + map.Source + separator + destRoot + map.Target;
  273. if ("saveToExpand".Equals(map.Expression))
  274. {
  275. text += "(*)";
  276. }
  277. if (string.IsNullOrEmpty(map.Source))
  278. {
  279. text = destRoot + map.Target + separator + "【" + map.Value + "】";
  280. }
  281. else
  282. {
  283. if (clearFlag)
  284. {
  285. // clear selectedItem
  286. lstBase.Items.Remove(srcRoot+map.Source);
  287. lstLocal.Items.Remove(destRoot+map.Target);
  288. }
  289. }
  290. lstMap.Items.Add(text);
  291. }
  292. private void btnTest_Click(object sender, EventArgs e)
  293. {
  294. if (mapper == null) return;
  295. try
  296. {
  297. JObject joRtn = new JObject();
  298. if (this.baseToLocal)
  299. {
  300. // 转换入参
  301. if (this.fieldMappings != null)
  302. {
  303. mapper.SetInputMapping(this.fieldMappings);
  304. joRtn = mapper.MapRequest<JObject, JObject>(JObject.Parse(txtBase.Text));
  305. }
  306. }
  307. else
  308. {
  309. // 出参
  310. if (this.fieldMappings != null)
  311. {
  312. mapper.SetOutputMapping(this.fieldMappings);
  313. joRtn = mapper.MapResponse<JObject, JObject>(JObject.Parse(txtBase.Text));
  314. }
  315. }
  316. this.txtLocal.Clear();
  317. this.txtLocal.AppendText(JsonHelper.toJsonString(joRtn));
  318. }
  319. catch (Exception ex)
  320. {
  321. MessageBox.Show(ex.Message);
  322. }
  323. }
  324. private void btnSave_Click(object sender, EventArgs e)
  325. {
  326. if (!Utils.Confirm("将覆盖原有数据,您确定要保存吗?"))
  327. {
  328. return;
  329. }
  330. if (this.baseToLocal)
  331. {
  332. //入参
  333. mapper.SetInputMapping(this.fieldMappings);
  334. }
  335. else
  336. {
  337. mapper.SetOutputMapping(this.fieldMappings);
  338. }
  339. mapper.Save();
  340. MessageBox.Show("保存成功!");
  341. }
  342. private void radioInput_CheckedChanged(object sender, EventArgs e)
  343. {
  344. this.baseToLocal = radioInput.Checked;
  345. }
  346. private void btnChange_Click(object sender, EventArgs e)
  347. {
  348. mapper.ChangeDirection(this.fieldMappings);
  349. if(orginInputFlag)
  350. {
  351. this.loadConfigMapping(false);
  352. }
  353. else
  354. {
  355. this.loadConfigMapping(false);
  356. }
  357. }
  358. private void btnMockLocal_Click(object sender, EventArgs e)
  359. {
  360. txtLocal.Clear();
  361. txtLocal.AppendText(Utils.MockData(radioInput.Checked, txtName.Text));
  362. }
  363. private void txtLocalName_KeyDown(object sender, KeyEventArgs e)
  364. {
  365. if (e.KeyCode == Keys.Enter)
  366. {
  367. int index = lstLocal.FindString(txtLocalName.Text.Trim());
  368. lstLocal.SelectedIndex = index;
  369. }
  370. }
  371. private void btnExchange_Click(object sender, EventArgs e)
  372. {
  373. string text = txtBase.Text;
  374. txtBase.Text = txtLocal.Text;
  375. txtLocal.Text = text;
  376. }
  377. private void txtBaseName_KeyDown(object sender, KeyEventArgs e)
  378. {
  379. if (e.KeyCode == Keys.Enter)
  380. {
  381. int index = lstBase.FindString(txtBaseName.Text.Trim());
  382. lstBase.SelectedIndex = index;
  383. }
  384. }
  385. private void fixValue_Click(object sender, EventArgs e)
  386. {
  387. string strValue = Interaction.InputBox("请输入");
  388. string text = lstLocal.SelectedItem + separator + "【" + strValue + "】";
  389. lstMap.Items.Add(text);
  390. string target = lstLocal.SelectedItem.ToString();
  391. if (target.Contains(arrayPattern))
  392. {
  393. string prefix_target = target.Substring(0, target.IndexOf(arrayPattern) + 2);
  394. var rtn = GetFieldMappingByTarget(prefix_target);
  395. FieldMapping fieldMapping = rtn.mapping;
  396. if (!rtn.exists)
  397. {
  398. this.fieldMappings.Add(rtn.mapping);
  399. }
  400. fieldMapping.Target = prefix_target;
  401. List<FieldMapping> childs = fieldMapping.Child ?? new List<FieldMapping>();
  402. string subKey = target.Replace(prefix_target + ".", "");
  403. FieldMapping subField = childs.FirstOrDefault(m => (m.Target == subKey));
  404. if (subField == null)
  405. {
  406. subField = new FieldMapping();
  407. childs.Add(subField);
  408. }
  409. subField.Source = null;
  410. subField.Target = subKey;
  411. subField.Value = strValue;
  412. }
  413. else
  414. {
  415. var rtn = GetFieldMappingByTarget(target);
  416. FieldMapping fieldMapping = rtn.mapping;
  417. if (!rtn.exists)
  418. {
  419. this.fieldMappings.Add(rtn.mapping);
  420. }
  421. fieldMapping.Target = target;
  422. fieldMapping.Value = strValue;
  423. }
  424. // clear selectedItem
  425. lstLocal.Items.Remove(lstLocal.SelectedItem);
  426. }
  427. private (bool exists,FieldMapping mapping) GetFieldMappingByTarget(string target)
  428. {
  429. FieldMapping fieldMapping = this.fieldMappings.FirstOrDefault(m => (m.Target == target));
  430. //数组中的固定值
  431. if (fieldMapping == null)
  432. {
  433. fieldMapping = new FieldMapping();
  434. return (false, fieldMapping);
  435. }
  436. return (true,fieldMapping);
  437. }
  438. private void AddGlobalVar(string key)
  439. {
  440. FieldMapping fieldMapping = new FieldMapping();
  441. fieldMapping.Target = lstLocal.SelectedItem.ToString();
  442. fieldMapping.Source = "Global_"+key;
  443. fieldMapping.Expression = "GlobaVariables";
  444. this.fieldMappings.Add(fieldMapping);
  445. string text = fieldMapping.Source + separator + fieldMapping.Target;
  446. lstMap.Items.Add(text);
  447. // clear selectedItem
  448. lstLocal.Items.Remove(lstLocal.SelectedItem);
  449. }
  450. private void medtrt_id_Click(object sender, EventArgs e)
  451. {
  452. AddGlobalVar("mdtrtid");
  453. }
  454. private void insuplc_admvs_Click(object sender, EventArgs e)
  455. {
  456. AddGlobalVar("insuplc");
  457. }
  458. private void insuadm_admvs_Click(object sender, EventArgs e)
  459. {
  460. AddGlobalVar("mdtrtarea");
  461. }
  462. private void pns_no_Click(object sender, EventArgs e)
  463. {
  464. AddGlobalVar("psn");
  465. }
  466. private void psn_name_Click(object sender, EventArgs e)
  467. {
  468. AddGlobalVar("name");
  469. }
  470. private void gender_Click(object sender, EventArgs e)
  471. {
  472. AddGlobalVar("gender");
  473. }
  474. private void age_Click(object sender, EventArgs e)
  475. {
  476. AddGlobalVar("age");
  477. }
  478. private void btnBaseMock_Click(object sender, EventArgs e)
  479. {
  480. txtLocal.Clear();
  481. txtLocal.AppendText(Utils.MockData(radioInput.Checked, txtName.Text));
  482. }
  483. private void medtype_Click(object sender, EventArgs e)
  484. {
  485. AddGlobalVar("medtype");
  486. }
  487. private void insutype_Click(object sender, EventArgs e)
  488. {
  489. AddGlobalVar("insutype");
  490. }
  491. private void birthday_Click(object sender, EventArgs e)
  492. {
  493. AddGlobalVar("birthday");
  494. }
  495. private void stringToDate_Click(object sender, EventArgs e)
  496. {
  497. FieldMapping mapping = QuerySelectedField();
  498. if (mapping != null)
  499. {
  500. mapping.Expression = "ShortDate";
  501. }
  502. }
  503. private void numToDate_Click(object sender, EventArgs e)
  504. {
  505. FieldMapping mapping = QuerySelectedField();
  506. if (mapping != null)
  507. {
  508. mapping.Expression = "LongToDate";
  509. }
  510. }
  511. private void ecToken_Click(object sender, EventArgs e)
  512. {
  513. AddGlobalVar("ectoken");
  514. }
  515. private void saveToExpand_Click(object sender, EventArgs e)
  516. {
  517. FieldMapping fieldMapping = new FieldMapping();
  518. fieldMapping.Source = lstLocal.SelectedItem.ToString();
  519. fieldMapping.Expression = "SaveToExpand";
  520. this.fieldMappings.Add(fieldMapping);
  521. string text = fieldMapping.Source + separator + "(*)";
  522. lstMap.Items.Add(text);
  523. // clear selectedItem
  524. lstLocal.Items.Remove(lstLocal.SelectedItem);
  525. }
  526. private void clearway_Click(object sender, EventArgs e)
  527. {
  528. AddGlobalVar("clearway");
  529. }
  530. private void ToString_Click(object sender, EventArgs e)
  531. {
  532. FieldMapping mapping = QuerySelectedField();
  533. if (mapping != null)
  534. {
  535. mapping.Expression = "ConvertToString";
  536. }
  537. }
  538. private void insuOrgCode_Click(object sender, EventArgs e)
  539. {
  540. AddGlobalVar("insuorg");
  541. }
  542. private void admid_Click(object sender, EventArgs e)
  543. {
  544. AddGlobalVar("admid");
  545. }
  546. private void certtype_Click(object sender, EventArgs e)
  547. {
  548. AddGlobalVar("certtype");
  549. }
  550. private void certno_Click(object sender, EventArgs e)
  551. {
  552. AddGlobalVar("certno");
  553. }
  554. private void ecCardNo_Click(object sender, EventArgs e)
  555. {
  556. AddGlobalVar("eccardno");
  557. }
  558. private void settleid_Click(object sender, EventArgs e)
  559. {
  560. AddGlobalVar("settlid");
  561. }
  562. private void cardsn_Click(object sender, EventArgs e)
  563. {
  564. AddGlobalVar("cardsn");
  565. }
  566. private void bizType_Click(object sender, EventArgs e)
  567. {
  568. AddGlobalVar("biztype");
  569. }
  570. }
  571. }