JsonMappingForm.cs 20 KB

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