MutualAid.cs 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Linq;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. using System.Windows.Forms;
  10. using PTMedicalInsurance.Business;
  11. using Newtonsoft.Json;
  12. using Newtonsoft.Json.Linq;
  13. using PTMedicalInsurance.Common;
  14. using PTMedicalInsurance.Helper;
  15. using PTMedicalInsurance.FormSetter;
  16. using PTMedicalInsurance.Variables;
  17. namespace PTMedicalInsurance.Forms
  18. {
  19. public partial class MutualAid : Form
  20. {
  21. public DataTable dtSumumt;
  22. public DataTable dtSettlInfo;
  23. public string settlementID;
  24. public string finalSettlementInfo;
  25. int numbersOfMutualAid = 1;
  26. InsuServices iris = new InsuServices();
  27. InvokeHelper center = new InvokeHelper();
  28. HisMainBusiness hBus = new HisMainBusiness();
  29. MIIrisServices mIS = new MIIrisServices();
  30. public string mutualAidPay; //共济金额
  31. //1.声明自适应类实例
  32. AutoResizeForm asc = new AutoResizeForm();
  33. public MutualAid(string settlId,string BusiType)
  34. {
  35. InitializeComponent();
  36. GridViewSetter grdSetter = new GridViewSetter();
  37. grdSetter.SetHeaderTextOfDgvMutualAidSettleInfo(dgvSettlInfo);
  38. grdSetter.SetHeaderTextOfDgvMutualAidSumamtInfo(dgvSumamt);
  39. grdSetter.SetHeaderTextOfDgvMutualAidQueryInfo(dgv_MutualAidQuery);
  40. settlementID = settlId;
  41. string errMsg;
  42. getSettlInfo(out errMsg);
  43. getSumamtInfo(out errMsg);
  44. tbMainSettlID.Text = settlId;
  45. Global.pat.AccountMutualAidPay = false; //先初始化一下 只有确认完成的时候 才把状态改为true
  46. //门诊结算
  47. if (BusiType == "M5")
  48. {
  49. btCancleMutualAid.Visible = false;
  50. btMutualAid.Visible = true;
  51. btYes.Visible = true;
  52. }
  53. //门诊撤销结算
  54. if (BusiType == "M5C")
  55. {
  56. btCancleMutualAid.Visible = true;
  57. btMutualAid.Visible = false;
  58. btYes.Visible = true;
  59. }
  60. grdSetter.DatagridviewColumnWidthAdaptation(dgvSettlInfo);
  61. grdSetter.DatagridviewColumnWidthAdaptation(dgvSumamt);
  62. grdSetter.DatagridviewColumnWidthAdaptation(dgv_MutualAidQuery);
  63. asc.controllInitializeSize(this);
  64. asc.controlAutoSize(this);
  65. }
  66. public MutualAid()
  67. {
  68. InitializeComponent();
  69. GridViewSetter grdSetter = new GridViewSetter();
  70. grdSetter.SetHeaderTextOfDgvMutualAidSettleInfo(dgvSettlInfo);
  71. grdSetter.SetHeaderTextOfDgvMutualAidSumamtInfo(dgvSumamt);
  72. grdSetter.SetHeaderTextOfDgvMutualAidQueryInfo(dgv_MutualAidQuery);
  73. grdSetter.DatagridviewColumnWidthAdaptation(dgvSettlInfo);
  74. grdSetter.DatagridviewColumnWidthAdaptation(dgvSumamt);
  75. grdSetter.DatagridviewColumnWidthAdaptation(dgv_MutualAidQuery);
  76. //this.WindowState = FormWindowState.Minimized;
  77. asc.controllInitializeSize(this);
  78. asc.controlAutoSize(this);
  79. tb_AccountMutualAidPay.SelectedIndex = 2;
  80. }
  81. #region 方法封装
  82. //获取结算汇总信息
  83. private int getSumamtInfo(out string errMsg)
  84. {
  85. errMsg = "";
  86. try
  87. {
  88. string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE Hospital_Dr=" + Global.inf.hospitalDr + " AND SettlementID='" + settlementID + "'";
  89. JObject joRtn = iris.querySettlementInfo(sqlStr);
  90. dtSumumt = (DataTable)JsonConvert.DeserializeObject(joRtn["result"]["data"].ToString(), (typeof(DataTable)));
  91. decimal accountPay=0, cashPay=0, mutualAidPay = 0;
  92. for (int i = 1; i < dtSettlInfo.Rows.Count; i++)
  93. {
  94. int billType = int.Parse(dtSettlInfo.Rows[i]["BillType"].ToString());
  95. accountPay = accountPay + decimal.Parse(dtSettlInfo.Rows[i]["AccountPaySumamt"].ToString()) * billType;
  96. mutualAidPay = mutualAidPay + decimal.Parse(dtSettlInfo.Rows[i]["AccountMutualAidAmount"].ToString()) * billType;
  97. if (billType == 1) { numbersOfMutualAid++; }
  98. else { dgvSettlInfo.Rows[i].DefaultCellStyle.ForeColor = Color.Red; }
  99. }
  100. dgvSettlInfo.Refresh();
  101. dtSumumt.Rows[0]["AccountPaySumamt"] = decimal.Parse(dtSumumt.Rows[0]["AccountPaySumamt"].ToString()) + accountPay;
  102. dtSumumt.Rows[0]["PersonCashPay"] = decimal.Parse(dtSumumt.Rows[0]["PersonCashPay"].ToString()) - accountPay;
  103. dtSumumt.Rows[0]["AccountMutualAidAmount"] = accountPay;
  104. dgvSumamt.DataSource = dtSumumt;
  105. dgvSettlInfo.SelectedIndex = dgvSettlInfo.Rows.Count - 1;
  106. return 0;
  107. }
  108. catch (Exception e)
  109. {
  110. errMsg = e.Message;
  111. return 1;
  112. }
  113. }
  114. //获取多次结算信息
  115. private int getSettlInfo(out string errMsg)
  116. {
  117. errMsg = "";
  118. try
  119. {
  120. string sqlStr = "SELECT * FROM BS_MedInsuSettlement "
  121. + " WHERE Hospital_Dr=" + Global.inf.hospitalDr
  122. + " AND MainSettlementIDOfMutualAid='" + settlementID + "'";
  123. JObject joRtn = iris.querySettlementInfo(sqlStr);
  124. dtSettlInfo = (DataTable)JsonConvert.DeserializeObject(joRtn["result"]["data"].ToString(), (typeof(DataTable)));
  125. dgvSettlInfo.DataSource = dtSettlInfo;
  126. return 0;
  127. }
  128. catch (Exception e)
  129. {
  130. errMsg = e.Message;
  131. return 1;
  132. }
  133. }
  134. //中心共济结算
  135. private int mutualAid(string patInfo, out string output)
  136. {
  137. output = "";
  138. string mPsnNO, mdtrtCertType, mdtrtCertNO, mInsutype,mName,mCertNo,mCertType;
  139. try
  140. {
  141. Global.writeLog("账户代支授权人1101返回值",patInfo,"");
  142. int i = dgvSumamt.SelectedIndex;
  143. string userSetlId = dtSettlInfo.Rows[i]["SettlementID"].ToString();
  144. string userMdtrtId = dtSettlInfo.Rows[i]["MdtrtID"].ToString();
  145. string userMedType = dtSettlInfo.Rows[i]["MedicalType"].ToString();
  146. //Global.pat.certNO_GJSQR = mCertNo;
  147. //Global.pat.name_GJSQR = mName;
  148. //Global.pat.insuType_GJSQR = mInsutype;
  149. mdtrtCertType = Global.pat.mdtrtcertType_GJSQR;
  150. mdtrtCertNO = Global.pat.mdtrtcertNO_GJSQR;
  151. //MessageBox.Show(Global.pat.certNO_GJSQR+"|"+ Global.pat.name_GJSQR+"|"+ Global.pat.certNO_SYR+"|"+ Global.pat.name_SYR+"|"+ Global.pat.insuType_GJSQR+"|"
  152. //+ mutualAidPay+"|"+ Global.inf.hospitalNO+"|"+ Global.pat.mdtrtcertType_GJSQR+"|"+ Global.pat.mdtrtcertNO_GJSQR);
  153. //组织入参
  154. JObject joData2596 = new JObject();
  155. joData2596.Add("autherCertno", Global.pat.certNO_GJSQR); //授权人证件号码
  156. joData2596.Add("autherName", Global.pat.name_GJSQR); //授权人姓名
  157. joData2596.Add("userCertno", Global.pat.certNO_SYR); //使用人证件号码
  158. joData2596.Add("acctUserName", Global.pat.name_SYR); //使用人姓名
  159. joData2596.Add("insutype", Global.pat.insuType_GJSQR); //险种
  160. joData2596.Add("acctPay", Global.pat.mutualAidPay); //代支金额
  161. joData2596.Add("fixmedinsCode", Global.inf.hospitalNO); //医疗服务机构编号
  162. joData2596.Add("mdtrt_cert_type", mdtrtCertType); //就诊凭证类型
  163. joData2596.Add("mdtrt_cert_no", mdtrtCertNO); //就诊凭证编号
  164. joData2596.Add("userSetlId", userSetlId); //使用人结算ID
  165. joData2596.Add("userMdtrtId", userMdtrtId); //使用人就诊Id
  166. joData2596.Add("userMedType", userMedType); //使用人就诊医疗类别
  167. JObject joInPut2596 = new JObject();
  168. joInPut2596.Add("acctMulaidBind", joData2596);
  169. //调用中心结算
  170. JObject joRtn2596 = center.invokeCenterServiceOfMutualAid("2596", JsonHelper.setCenterInpar_MutualMid("2596", joInPut2596));
  171. //保存中心返回的结果
  172. if (JsonHelper.parseCenterReturnJson(joRtn2596, out output) != 0)
  173. {
  174. return -1;
  175. }
  176. else
  177. {
  178. output = joRtn2596.ToString();
  179. return 0;
  180. }
  181. return 0;
  182. }
  183. catch (Exception e)
  184. {
  185. output = e.Message;
  186. return 1;
  187. }
  188. }
  189. //撤销中心共济结算
  190. private int cancleMutualAid(out string errMsg)
  191. {
  192. errMsg = "";
  193. try
  194. {
  195. int i = dgvSettlInfo.SelectedIndex;
  196. mIS.getInterface(dtSettlInfo.Rows[i]["InterfaceDr"].ToString());
  197. if ((dtSettlInfo.Rows[i]["MutualAidFlag"].ToString() == "") || (dtSettlInfo.Rows[i]["MutualAidFlag"].ToString() == "0"))
  198. {
  199. errMsg = "当前结算无医保账户代支结算信息!";
  200. return -1;
  201. }
  202. else if (int.Parse(dtSettlInfo.Rows[i]["MutualAidFlag"].ToString()) == 1)
  203. {
  204. errMsg = "当前结算为主结算,请选择正确的医保账户代支结算!";
  205. return -1;
  206. }
  207. //南宁基线版
  208. if (dtSettlInfo.Rows[i]["InterfaceDr"].ToString() == "7")
  209. {
  210. Global.inf.mutualAidCenterURL = @"http://10.98.34.114/mbs-hiIntf-nanning/web/api/fsi/callService";
  211. Global.inf.mutualAidHospitalAreaCode = "450100";
  212. }
  213. //广西基线版
  214. if (dtSettlInfo.Rows[i]["InterfaceDr"].ToString() == "11")
  215. {
  216. Global.inf.mutualAidCenterURL = @"http://10.98.34.113/mbs-hiIntf-qubenji/web/api/fsi/callService";
  217. Global.inf.mutualAidHospitalAreaCode = "459900";
  218. }
  219. Global.inf.hospitalNO = "H45010302052";
  220. Global.inf.hospitalName = "南宁普瑞眼科医院";
  221. Global.inf.mutualAidPatientAreaCode = dtSettlInfo.Rows[i]["insuplc_admdvs"].ToString();
  222. Global.inf.mutualAidHospitalAreaCode = Global.inf.mutualAidPatientAreaCode;
  223. Global.pat.insuplc_admdvs_GJSQR = Global.inf.mutualAidPatientAreaCode;
  224. //组织入参
  225. JObject joData2597 = new JObject();
  226. joData2597.Add("mdtrtId", dtSettlInfo.Rows[i]["MdtrtID"].ToString());
  227. joData2597.Add("setlId", dtSettlInfo.Rows[i]["SettlementID"].ToString());
  228. joData2597.Add("fixmedinsCode", Global.inf.hospitalNO);
  229. JObject joInPut2597 = new JObject();
  230. joInPut2597.Add("acctMulaidBind", joData2597);
  231. //MessageBox.Show(joData2597.ToString());
  232. JObject joRtn2597 = center.invokeCenterServiceOfMutualAid("2597", JsonHelper.setCenterInpar_MutualMid("2597", joInPut2597));
  233. //将中心返回的结果返回HIS 调用HIS服务进行保存
  234. if (JsonHelper.parseCenterReturnJson(joRtn2597, out errMsg) != 0)
  235. {
  236. return -1;
  237. }
  238. else
  239. {
  240. errMsg = joRtn2597.ToString();
  241. dgvSettlInfo.SelectedIndex = dgvSettlInfo.Rows.Count - 1;
  242. return 0;
  243. }
  244. }
  245. catch (Exception e)
  246. {
  247. errMsg = e.Message;
  248. return -1;
  249. }
  250. }
  251. //保存到云医保平台
  252. private int saveMutualAidSettlementToCloudPlatform(string patInfo,string centerReturn,out string errMsg)
  253. {
  254. errMsg = "";
  255. try
  256. {
  257. //返回给云医保平台
  258. JObject joCenterRtn = JObject.Parse(centerReturn);
  259. //JObject joSetlinfo = JObject.Parse(JsonHelper.getDestValue(joCenterRtn, "output"));
  260. JObject joSetlinfo = new JObject();
  261. JObject joPatInfo = JObject.Parse(patInfo);
  262. //以下节点中心不返回,传给后台保存的值为空,手工置为0
  263. if (Global.pat.cvlserv_flag_GJSQR == "是")
  264. Global.pat.cvlserv_flag_GJSQR = "1";
  265. else
  266. Global.pat.cvlserv_flag_GJSQR = "0";
  267. joSetlinfo.Add("setl_id", JsonHelper.getDestValue(joCenterRtn, "output.setlId")); //结算Id
  268. joSetlinfo.Add("mdtrt_id", JsonHelper.getDestValue(joCenterRtn, "output.mdtrtId")); //就诊Id
  269. joSetlinfo.Add("psn_no", Global.pat.psn_no_GJSQR); //授权人医保编号
  270. joSetlinfo.Add("psn_name", Global.pat.name_GJSQR); //授权人姓名
  271. joSetlinfo.Add("psn_cert_type", Global.pat.psn_cert_type_GJSQR); //授权人证件类型
  272. joSetlinfo.Add("certno", Global.pat.certNO_GJSQR); //授权人证件号码
  273. joSetlinfo.Add("gend", Global.pat.gend_GJSQR); //授权人性别
  274. joSetlinfo.Add("naty", Global.pat.naty_GJSQR); //授权人民族
  275. joSetlinfo.Add("brdy", Global.pat.brdy_GJSQR); //授权人生日
  276. joSetlinfo.Add("age", Global.pat.age_GJSQR); //授权人年龄
  277. joSetlinfo.Add("insutype", Global.pat.insuType_GJSQR); //授权人险种类型
  278. //joSetlinfo.Add("insutype", JsonHelper.getDestValue(joCenterRtn, "output.insuType")); //险种
  279. joSetlinfo.Add("psn_type", Global.pat.psn_type_GJSQR); //授权人人员类别
  280. joSetlinfo.Add("cvlserv_flag", Global.pat.cvlserv_flag_GJSQR); //授权人是否公务员
  281. joSetlinfo.Add("setl_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  282. joSetlinfo.Add("mdtrt_cert_type", Global.pat.mdtrtcertType_GJSQR);
  283. joSetlinfo.Add("med_type", "110102");
  284. joSetlinfo.Add("medfee_sumamt", JsonHelper.getDestValue(joCenterRtn, "output.medfeeSumamt")); //医保总费用
  285. joSetlinfo.Add("fulamt_ownpay_amt", 0);
  286. joSetlinfo.Add("overlmt_selfpay", 0);
  287. joSetlinfo.Add("preselfpay_amt", 0);
  288. joSetlinfo.Add("inscp_scp_amt", 0);
  289. joSetlinfo.Add("act_pay_dedc", 0); //起付线
  290. joSetlinfo.Add("hifp_pay", 0);
  291. joSetlinfo.Add("pool_prop_selfpay", 0);
  292. joSetlinfo.Add("cvlserv_pay", 0);
  293. joSetlinfo.Add("hifes_pay", 0);
  294. joSetlinfo.Add("hifmi_pay", 0);
  295. joSetlinfo.Add("hifob_pay", 0);
  296. joSetlinfo.Add("hifdm_pay", 0);
  297. joSetlinfo.Add("maf_pay", 0);
  298. joSetlinfo.Add("oth_pay", 0);
  299. joSetlinfo.Add("fund_pay_sumamt", JsonHelper.getDestValue(joCenterRtn, "output.fundPaySumamt")); //基金支付金额
  300. joSetlinfo.Add("psn_part_amt", 0);
  301. joSetlinfo.Add("acct_pay", JsonHelper.getDestValue(joCenterRtn, "output.acctPay")); //个人账户支出金额
  302. joSetlinfo.Add("psn_cash_pay", 0);
  303. joSetlinfo.Add("hosp_part_amt", 0);
  304. joSetlinfo.Add("balc", JsonHelper.getDestValue(joCenterRtn, "output.balance")); //授权人支出后账户余额
  305. joSetlinfo.Add("acct_mulaid_pay", 0);
  306. joSetlinfo.Add("medins_setl_id", Global.curEvt.msgid);
  307. joSetlinfo.Add("clr_optins", JsonHelper.getDestValue(joCenterRtn, "output.clrOptions")); //清算经办机构
  308. joSetlinfo.Add("clr_way", "1"); //清算方式
  309. joSetlinfo.Add("clr_type", JsonHelper.getDestValue(joCenterRtn, "output.clrType")); //清算类别
  310. joSetlinfo.Add("exp_content", JsonHelper.getDestValue(joCenterRtn, "output")); //
  311. joSetlinfo.Add("HospitalDr", Global.inf.hospitalDr);
  312. joSetlinfo.Add("admID", dtSettlInfo.Rows[0]["AdmID"].ToString());
  313. joSetlinfo.Add("ValidFlag", 1);
  314. joSetlinfo.Add("BillType", 1);
  315. joSetlinfo.Add("updateUserID", Global.user.ID);
  316. joSetlinfo.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  317. joSetlinfo.Add("billID", dtSettlInfo.Rows[0]["BillID"].ToString());
  318. joSetlinfo.Add("recordID", dtSettlInfo.Rows[0]["RecordID"].ToString());
  319. joSetlinfo.Add("msgid", Global.curEvt.msgid);
  320. joSetlinfo.Add("interfaceDr", Global.inf.mutualAidInterfaceDr);
  321. joSetlinfo.Add("admType", dtSettlInfo.Rows[0]["admType"].ToString());
  322. joSetlinfo.Add("insuplc_admdvs", Global.pat.insuplc_admdvs_GJSQR ); //JsonHelper.getDestValue(joPatInfo, "selectedInsuInfo.insuplc_admdvs")
  323. joSetlinfo.Add("MainSettlementIDOfMutualAid", dtSettlInfo.Rows[0]["SettlementID"].ToString());
  324. numbersOfMutualAid++;
  325. joSetlinfo.Add("MutualAidFlag", numbersOfMutualAid);
  326. dynamic joTmp = new JObject();
  327. joTmp.code = "09010051";
  328. JArray jaTmp = new JArray();
  329. jaTmp.Add(joSetlinfo);
  330. joTmp.Add("params", jaTmp);
  331. JObject joRtn = center.invokeInsuService(joTmp.ToString(), "插入结算信息");
  332. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  333. {
  334. return -1;
  335. }
  336. /*
  337. JObject joSetlDetail = new JObject();
  338. joSetlDetail.Add("HospitalDr", Global.inf.hospitalDr);
  339. joSetlDetail.Add("InterfaceDr", Global.inf.interfaceDr);
  340. joSetlDetail.Add("MdtrtID", JsonHelper.getDestValue(joCenterRtn, "output.mdtrtId"));
  341. joSetlDetail.Add("SettlementID", JsonHelper.getDestValue(joSetlinfo, "setl_id"));
  342. joSetlDetail.Add("AdmID", dtSettlInfo.Rows[0]["AdmID"].ToString());
  343. joSetlDetail.Add("updateUserID", Global.user.ID);
  344. JArray jaSetlDetail = JArray.Parse(JsonHelper.getDestValue(joCenterRtn, "output.setldetail"));
  345. joSetlDetail.Add("setldetail", jaSetlDetail);
  346. joTmp = new JObject();
  347. joTmp.code = "09010056";
  348. jaTmp = new JArray();
  349. jaTmp.Add(joSetlDetail);
  350. joTmp.Add("params", jaTmp);
  351. JObject joInsertSetlDetail = center.invokeInsuService(joTmp.ToString(), "插入结算明细信息");
  352. if (JsonHelper.parseIrisRtnValue(joInsertSetlDetail, out errMsg) != 0)
  353. {
  354. MessageBox.Show("插入结算明细信息:" + errMsg);
  355. }*/
  356. return 0;
  357. }
  358. catch (Exception e)
  359. {
  360. errMsg = e.Message;
  361. return -1;
  362. }
  363. }
  364. /// <summary>
  365. /// 撤销云平台结算信息
  366. /// </summary>
  367. /// <param name="errMsg"></param>
  368. /// <returns></returns>
  369. private int cancleMutualAidOfCloudPlatform(string centerReturn,out string errMsg)
  370. {
  371. errMsg = "";
  372. try
  373. {
  374. int i = dgvSettlInfo.SelectedIndex;
  375. dynamic joTmp = new JObject();
  376. joTmp.admID = dtSettlInfo.Rows[i]["AdmID"].ToString();
  377. joTmp.PersonalNO = dtSettlInfo.Rows[i]["PersonnelNO"].ToString();
  378. joTmp.mdtrt_id = dtSettlInfo.Rows[i]["MdtrtID"].ToString();
  379. joTmp.setl_id = dtSettlInfo.Rows[i]["SettlementID"].ToString();
  380. JObject joCenterRtn = JObject.Parse(centerReturn);
  381. joTmp.newSetlId = JsonHelper.getDestValue(joCenterRtn, "output.setlId");
  382. JObject joIrisRtn = iris.cancleSettlement(joTmp);
  383. if (JsonHelper.parseIrisRtnValue(joIrisRtn, out errMsg) != 0)
  384. {
  385. return -1;
  386. }
  387. else
  388. {
  389. return 0;
  390. }
  391. }
  392. catch (Exception e)
  393. {
  394. errMsg = e.Message;
  395. return -1;
  396. }
  397. }
  398. /// <summary>
  399. /// 获取最终的结算信息,返回给HIS。无论共济多少次,返回给HIS的只有这一条。
  400. /// </summary>
  401. /// <param name="output"></param>
  402. /// <returns></returns>
  403. private int getFinalSettlementInfo(out string output)
  404. {
  405. output = "";
  406. try
  407. {
  408. JObject joCenterRtn = new JObject();
  409. JObject joSetlinfo = JObject.Parse(JsonHelper.getDestValue(joCenterRtn, "output.result"));
  410. joSetlinfo.Add("HospitalDr", Global.inf.hospitalDr);
  411. joSetlinfo.Add("admID", dtSettlInfo.Rows[0]["Adm_Dr"].ToString());
  412. joSetlinfo.Add("ValidFlag", 1);
  413. joSetlinfo.Add("BillType", 1);
  414. joSetlinfo.Add("updateUserID", Global.user.ID);
  415. joSetlinfo.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  416. joSetlinfo.Add("billID", dtSettlInfo.Rows[0]["BillID"].ToString());
  417. joSetlinfo.Add("recordID", dtSettlInfo.Rows[0]["RecordID"].ToString());
  418. joSetlinfo.Add("msgid", Global.curEvt.msgid);
  419. joSetlinfo.Add("interfaceDr", Global.inf.interfaceDr);
  420. joSetlinfo.Add("admType", dtSettlInfo.Rows[0]["admType"].ToString());
  421. joSetlinfo.Add("insuplc_admdvs", Global.pat.insuplc_admdvs);
  422. joSetlinfo.Add("MainSettlementIDOfMutualAid", dtSettlInfo.Rows[0]["SettlementID"].ToString());
  423. joSetlinfo.Add("MutualAidFlag", numbersOfMutualAid);
  424. output = joSetlinfo.ToString();
  425. return 0;
  426. }
  427. catch (Exception e)
  428. {
  429. output = e.Message;
  430. return -1;
  431. }
  432. }
  433. #endregion
  434. private void btMutualAid_Click(object sender, EventArgs e)
  435. {
  436. string errMsg, patInfo, outParam;
  437. try
  438. {
  439. if (dtSumumt.Rows.Count == 0)
  440. {
  441. MessageBox.Show("请先查询结算信息!");
  442. return;
  443. }
  444. #region【此处的读卡在弹框前会触发读取授权人的参保信息】
  445. if (Global.pat.patInfo_mutualAidPay == "")
  446. {
  447. Global.Set.psnCashPay = dgvSettlInfo.Rows[dgvSettlInfo.CurrentRow.Index].Cells["PersonCashPay"].Value.ToString();
  448. #region【选择接口目录】
  449. MutualAidChooser frm = new MutualAidChooser();
  450. if (frm.ShowDialog() == DialogResult.OK)
  451. {
  452. mutualAidPay = frm.mutualAidPay;
  453. int i = frm.cbxInterface.SelectedIndex;
  454. DataTable dtInteface = (DataTable)frm.cbxInterface.DataSource;
  455. Global.inf.mutualAidCenterURL = dtInteface.Rows[i]["CenterURL"].ToString();
  456. Global.inf.mutualAidHospitalAreaCode = dtInteface.Rows[i]["AreaCode"].ToString();
  457. Global.inf.mutualAidInterfaceDr = int.Parse(dtInteface.Rows[i]["ID"].ToString());
  458. }
  459. else
  460. {
  461. //MessageBox.Show("收费员取消账户代支结算!");
  462. return;
  463. }
  464. #endregion
  465. //选中的账户授权人的接口类型与使用人不一致的情况下,调用签到信息
  466. if (Global.inf.mutualAidInterfaceDr != Global.inf.interfaceDr)
  467. {
  468. if (mIS.isSigned_MutualAid(ref Global.curEvt.signno) != true)
  469. {
  470. //先签到
  471. CenterBusiness cBus = new CenterBusiness();
  472. JObject jo9001Rtn = new JObject();
  473. cBus.signIn_MutualAid(out jo9001Rtn);
  474. }
  475. }
  476. #region【读卡-医保账户代支授权人】
  477. //打开读卡窗口,操作员选择读卡类型后进行读卡器读卡,再进行1101获取参保信息
  478. if (hBus.MutualAidReadCard(out outParam) != 0)
  479. {
  480. MessageBox.Show(JsonHelper.setExceptionJson(-100, "医保账户代支读卡失败!", outParam).ToString());
  481. return;
  482. }
  483. else
  484. {
  485. //展示患者信息界面
  486. Global.pat.patInfo_mutualAidPay = outParam;
  487. if (hBus.MutualAidShowPatInfo(outParam, out Global.pat.patInfo_mutualAidPay) != 0)
  488. {
  489. MessageBox.Show("医保账户代支读卡成功,展示患者信息界面失败:" + Global.pat.patInfo_mutualAidPay);
  490. return;
  491. }
  492. }
  493. #endregion
  494. }
  495. #endregion
  496. //医保代支结算-2596
  497. string centerReturn;
  498. if (mutualAid(Global.pat.patInfo_mutualAidPay, out centerReturn) != 0)
  499. {
  500. MessageBox.Show(centerReturn);
  501. return;
  502. }
  503. //保存到医保平台
  504. if (saveMutualAidSettlementToCloudPlatform(Global.pat.patInfo_mutualAidPay, centerReturn,out errMsg) != 0)
  505. {
  506. MessageBox.Show(errMsg);
  507. return;
  508. }
  509. //更新医保结算表主结算记录 账户共济标志和主结算ID
  510. if (mIS.updateSettlement(dtSettlInfo.Rows[0]["SettlementID"].ToString(), 1, out errMsg) != 0)
  511. {
  512. MessageBox.Show(JsonHelper.setExceptionJson(-1, "更新云医保平台账户共济主结算信息失败", errMsg).ToString());
  513. //return;
  514. }
  515. //刷新结算信息显示
  516. if (getSettlInfo(out errMsg) != 0)
  517. {
  518. MessageBox.Show(errMsg);
  519. return;
  520. }
  521. //刷新汇总信息显示
  522. if (getSumamtInfo(out errMsg) != 0)
  523. {
  524. MessageBox.Show(errMsg);
  525. return;
  526. }
  527. else
  528. {
  529. Global.pat.AccountMutualAidPay = true;
  530. MessageBox.Show("医保账户代支结算成功!");
  531. }
  532. }
  533. catch (Exception ex)
  534. {
  535. MessageBox.Show(ex.Message);
  536. return;
  537. }
  538. }
  539. private void btCancleMutualAid_Click(object sender, EventArgs e)
  540. {
  541. string errMsg = "";
  542. try
  543. {
  544. //撤销中心共济结算
  545. string centerReturn;
  546. if (cancleMutualAid(out centerReturn) != 0)
  547. {
  548. MessageBox.Show(centerReturn);
  549. return;
  550. }
  551. //保存到医保平台
  552. if (cancleMutualAidOfCloudPlatform(centerReturn, out errMsg) != 0)
  553. {
  554. MessageBox.Show(errMsg);
  555. return;
  556. }
  557. //刷新结算信息显示
  558. if (getSettlInfo(out errMsg) != 0)
  559. {
  560. MessageBox.Show(errMsg);
  561. return;
  562. }
  563. //刷新汇总信息显示
  564. if (getSumamtInfo(out errMsg) != 0)
  565. {
  566. MessageBox.Show(errMsg);
  567. return;
  568. }
  569. else
  570. {
  571. MessageBox.Show("撤销医保账户代支结算成功!");
  572. }
  573. }
  574. catch (Exception ex)
  575. {
  576. MessageBox.Show(ex.Message);
  577. return;
  578. }
  579. }
  580. private void btYes_Click(object sender, EventArgs e)
  581. {
  582. try
  583. {
  584. JObject joSetlinfo = new JObject();
  585. joSetlinfo.Add("setl_time", dtSumumt.Rows[0]["SettlementTime"].ToString());
  586. joSetlinfo.Add("cvlserv_pay", dtSumumt.Rows[0]["CivilserviceAllowancePay"].ToString());
  587. joSetlinfo.Add("hifdm_pay", dtSumumt.Rows[0]["HealthInsurancePay"].ToString());
  588. joSetlinfo.Add("cvlserv_flag", dtSumumt.Rows[0]["CivilserviceAllowancePay"].ToString());
  589. joSetlinfo.Add("med_type", dtSumumt.Rows[0]["MedicalType"].ToString());
  590. joSetlinfo.Add("brdy", dtSumumt.Rows[0]["BirthDay"].ToString());
  591. joSetlinfo.Add("naty", dtSumumt.Rows[0]["Nation"].ToString());
  592. joSetlinfo.Add("psn_cash_pay", dtSumumt.Rows[0]["PersonCashPay"].ToString());
  593. joSetlinfo.Add("certno", dtSumumt.Rows[0]["CertificateNO"].ToString());
  594. joSetlinfo.Add("hifmi_pay", dtSumumt.Rows[0]["SeriousIllnessPay"].ToString());
  595. joSetlinfo.Add("psn_no", dtSumumt.Rows[0]["PersonnelNO"].ToString());
  596. joSetlinfo.Add("act_pay_dedc", dtSumumt.Rows[0]["ActualPayDeductible"].ToString());
  597. joSetlinfo.Add("mdtrt_cert_type", dtSumumt.Rows[0]["MdtrtCertType"].ToString());
  598. joSetlinfo.Add("balc", dtSumumt.Rows[0]["Balance"].ToString());
  599. joSetlinfo.Add("medins_setl_id", dtSumumt.Rows[0]["OrganSettlementID"].ToString());
  600. joSetlinfo.Add("psn_cert_type", dtSumumt.Rows[0]["CertificateType"].ToString());
  601. joSetlinfo.Add("acct_mulaid_pay", dtSumumt.Rows[0]["AccountMutualAidAmount"].ToString());
  602. joSetlinfo.Add("clr_way", dtSumumt.Rows[0]["ClearingWay"].ToString());
  603. joSetlinfo.Add("hifob_pay", dtSumumt.Rows[0]["LargeExpensesSupplementPay"].ToString());
  604. joSetlinfo.Add("oth_pay", dtSumumt.Rows[0]["OtherPay"].ToString());
  605. joSetlinfo.Add("medfee_sumamt", dtSumumt.Rows[0]["Sumamt"].ToString());
  606. joSetlinfo.Add("hifes_pay", dtSumumt.Rows[0]["EnterpriseSupplementPay"].ToString());
  607. joSetlinfo.Add("gend", dtSumumt.Rows[0]["Gender"].ToString());
  608. joSetlinfo.Add("mdtrt_id", dtSumumt.Rows[0]["MdtrtID"].ToString());
  609. joSetlinfo.Add("acct_pay", dtSumumt.Rows[0]["AccountPaySumamt"].ToString());
  610. joSetlinfo.Add("fund_pay_sumamt", dtSumumt.Rows[0]["FundPaySumamt"].ToString());
  611. joSetlinfo.Add("fulamt_ownpay_amt", dtSumumt.Rows[0]["OwnPayAmount"].ToString());
  612. joSetlinfo.Add("hosp_part_amt", dtSumumt.Rows[0]["HospitalPartAmount"].ToString());
  613. joSetlinfo.Add("setl_id", dtSumumt.Rows[0]["SettlementID"].ToString());
  614. joSetlinfo.Add("inscp_scp_amt", dtSumumt.Rows[0]["InPolicyRangeAmount"].ToString());
  615. joSetlinfo.Add("insutype", dtSumumt.Rows[0]["InsuranceType"].ToString());
  616. joSetlinfo.Add("maf_pay", dtSumumt.Rows[0]["MedicalAssistPay"].ToString());
  617. joSetlinfo.Add("psn_name", dtSumumt.Rows[0]["PatientName"].ToString());
  618. joSetlinfo.Add("psn_part_amt", dtSumumt.Rows[0]["PersonPaySumamt"].ToString());
  619. joSetlinfo.Add("clr_optins", dtSumumt.Rows[0]["ClearingOrgan"].ToString());
  620. joSetlinfo.Add("pool_prop_selfpay", dtSumumt.Rows[0]["HealthInsuranceRatio"].ToString());
  621. joSetlinfo.Add("psn_type", dtSumumt.Rows[0]["PersonType"].ToString());
  622. joSetlinfo.Add("hifp_pay", dtSumumt.Rows[0]["HealthInsurancePay"].ToString());
  623. joSetlinfo.Add("overlmt_selfpay", dtSumumt.Rows[0]["OverLimitAmount"].ToString());
  624. joSetlinfo.Add("preselfpay_amt", dtSumumt.Rows[0]["PreSelfPayAmount"].ToString());
  625. joSetlinfo.Add("age", dtSumumt.Rows[0]["Age"].ToString());
  626. joSetlinfo.Add("clr_type", dtSumumt.Rows[0]["ClearingType"].ToString());
  627. joSetlinfo.Add("HospitalDr", Global.inf.hospitalDr);
  628. joSetlinfo.Add("admID", dtSumumt.Rows[0]["AdmID"].ToString());
  629. joSetlinfo.Add("ValidFlag", dtSumumt.Rows[0]["ValidFlag"].ToString());
  630. joSetlinfo.Add("BillType", dtSumumt.Rows[0]["BillType"].ToString());
  631. joSetlinfo.Add("updateUserID", Global.user.ID);
  632. joSetlinfo.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  633. joSetlinfo.Add("billID", dtSumumt.Rows[0]["BillID"].ToString());
  634. joSetlinfo.Add("recordID", dtSumumt.Rows[0]["RecordID"].ToString());
  635. joSetlinfo.Add("msgid", dtSumumt.Rows[0]["msgid"].ToString());
  636. joSetlinfo.Add("interfaceDr", dtSumumt.Rows[0]["InterfaceDr"].ToString());
  637. joSetlinfo.Add("admType", dtSumumt.Rows[0]["admType"].ToString());
  638. joSetlinfo.Add("insuplc_admdvs", dtSumumt.Rows[0]["AccountPaySumamt"].ToString());
  639. joSetlinfo.Add("MainSettlementIDOfMutualAid", dtSumumt.Rows[0]["SettlementID"].ToString());
  640. finalSettlementInfo = joSetlinfo.ToString();
  641. Global.pat.patInfo_mutualAidPay = "";
  642. this.DialogResult = DialogResult.OK;
  643. Global.writeLog("finalSettlementInfo", finalSettlementInfo,"");
  644. Close();
  645. }
  646. catch (Exception ex)
  647. {
  648. MessageBox.Show(ex.Message);
  649. }
  650. }
  651. private void btNO_Click(object sender, EventArgs e)
  652. {
  653. this.DialogResult = DialogResult.Cancel;
  654. this.Close();
  655. }
  656. private void btQuerySettlInfo_Click(object sender, EventArgs e)
  657. {
  658. settlementID = tbMainSettlID.Text;
  659. string errMsg;
  660. if (getSettlInfo(out errMsg) != 0) { MessageBox.Show(errMsg); }
  661. if (getSumamtInfo(out errMsg) != 0) { MessageBox.Show(errMsg); }
  662. }
  663. private void btnExit_Click(object sender, EventArgs e)
  664. {
  665. Close();
  666. }
  667. private void btnInputDemo_Click(object sender, EventArgs e)
  668. {
  669. rtbInparam.Text = @"{""acctMulaidBind"":{""mdtrtId"":"""",""setlId"":"""",""fixmedinsCode"":""H45010302052""}}";
  670. JObject joTmp = JObject.Parse(rtbInparam.Text);
  671. rtbInparam.Text = joTmp.ToString();
  672. }
  673. private void btnRectification_Click(object sender, EventArgs e)
  674. {
  675. string errorMsg = "";
  676. #region【选择接口目录】
  677. MutualAidChooser frm = new MutualAidChooser();
  678. if (frm.ShowDialog() == DialogResult.OK)
  679. {
  680. mutualAidPay = frm.mutualAidPay;
  681. int i = frm.cbxInterface.SelectedIndex;
  682. DataTable dtInteface = (DataTable)frm.cbxInterface.DataSource;
  683. Global.inf.mutualAidCenterURL = dtInteface.Rows[i]["CenterURL"].ToString();
  684. Global.inf.mutualAidHospitalAreaCode = dtInteface.Rows[i]["AreaCode"].ToString();
  685. Global.inf.mutualAidInterfaceDr = int.Parse(dtInteface.Rows[i]["ID"].ToString());
  686. }
  687. else
  688. {
  689. MessageBox.Show("收费员取消账户代支结算!");
  690. return;
  691. }
  692. #endregion
  693. JObject joRtn = new JObject();
  694. Global.pat.insuplc_admdvs_GJSQR = tbCBD_Hand.Text;
  695. if ((tbCBD_Hand.Text == "") || (tbCBD_Hand.Text == "") || (tbCBD_Hand.Text == ""))
  696. {
  697. MessageBox.Show("入参不能为空!");
  698. return;
  699. }
  700. joRtn = center.invokeCenterServiceOfMutualAid("2599", JsonHelper.setCenterInpar_MutualMid("2599", JObject.Parse(rtbInparam.Text)));
  701. if (JsonHelper.parseCenterRtnValue(joRtn, out errorMsg) != 0)
  702. {
  703. MessageBox.Show("医保账户代支结算冲正失败:" + errorMsg);
  704. }
  705. else
  706. {
  707. rtbOutparam.Text = joRtn.ToString();
  708. }
  709. }
  710. private void btnQuery_Click(object sender, EventArgs e)
  711. {
  712. if (tb_CertNO_SYR.Text == "")
  713. {
  714. MessageBox.Show("使用人身份证号不能为空!");
  715. return;
  716. }
  717. #region【1101获取身份信息】
  718. if (tb_UserNO.Text == "")
  719. {
  720. string errorMsg, patInfo;
  721. JObject joData1101 = new JObject();
  722. joData1101.Add("mdtrt_cert_type", "02"); //就诊凭证类型
  723. joData1101.Add("mdtrt_cert_no", tb_CertNO_SYR.Text); //就诊凭证编码
  724. joData1101.Add("card_sn", ""); //卡识别码
  725. joData1101.Add("begntime", "");
  726. joData1101.Add("psn_cert_type", "01"); //证件类别
  727. joData1101.Add("certno", tb_CertNO_SYR.Text); //证件号码
  728. joData1101.Add("psn_name", ""); //姓名
  729. JObject joInput1101 = new JObject();
  730. joInput1101.Add("data", joData1101);
  731. string inPutParam = JsonHelper.setCenterInpar("1101", joInput1101);
  732. JObject joRtn1101 = center.invokeCenterService("1101", inPutParam);
  733. if (JsonHelper.parseCenterRtnValue(joRtn1101, out errorMsg) != 0)
  734. {
  735. MessageBox.Show("1101获取参保人信息失败:" + errorMsg);
  736. return;
  737. }
  738. else
  739. {
  740. string outParam = joRtn1101.ToString();
  741. Global.pat.psn_no = JsonHelper.getDestValue(JObject.Parse(outParam), "output.baseinfo.psn_no"); //人员编号
  742. tb_UserNO.Text = Global.pat.psn_no;
  743. //展示患者信息界面
  744. if (hBus.showPatInfo(outParam, out patInfo) != 0)
  745. {
  746. MessageBox.Show("展示患者参保信息界面失败:" + patInfo);
  747. return;
  748. }
  749. }
  750. }
  751. #endregion
  752. if (tb_UserNO.Text == "")
  753. {
  754. MessageBox.Show("使用人医保编号不能为空!");
  755. return;
  756. }
  757. string error;
  758. dynamic joData = new JObject();
  759. joData.auther_no = ""; //授权人医保编码
  760. joData.user_no = tb_UserNO.Text; //使用人医保编码
  761. joData.begndate = dt_ST.Value.ToString("yyyy-MM-dd");
  762. joData.enddate = dt_ET.Value.ToString("yyyy-MM-dd");
  763. joData.auther_certno = ""; //授权人证件号码
  764. joData.user_certno = tb_CertNO_SYR.Text; //使用人证件号码
  765. JObject joData2589 = new JObject();
  766. joData2589.Add("data", joData);
  767. //上传给中心
  768. string inPutParam2589 = JsonHelper.setCenterInpar("2589", joData2589.ToString());
  769. rtb_InParam.Text = inPutParam2589;
  770. InvokeHelper invoker = new InvokeHelper();
  771. JObject joRtn = invoker.invokeCenterService("2589", inPutParam2589);
  772. if (JsonHelper.parseCenterReturnJson(joRtn, out error) != 0)
  773. {
  774. MessageBox.Show("【2589】个账共济查询失败:" + error);
  775. return;
  776. }
  777. else
  778. {
  779. DataTable dt = (DataTable)joRtn["output"].ToObject(typeof(DataTable)); //["result"]
  780. dgv_MutualAidQuery.DataSource = dt;
  781. if (dt.Rows.Count == 0)
  782. {
  783. MessageBox.Show("【2589】个账共济查询失败:医保返回当前使用人无账户代支绑定信息!");
  784. return;
  785. }
  786. }
  787. }
  788. private void btnReadCard_Click(object sender, EventArgs e)
  789. {
  790. #region【读卡-医保账户代支授权人】
  791. string patInfo,outParam;
  792. //打开读卡窗口,操作员选择读卡类型后进行读卡器读卡,再进行1101获取参保信息
  793. if (hBus.MutualAidReadCard(out outParam) != 0)
  794. {
  795. MessageBox.Show(JsonHelper.setExceptionJson(-100, "医保账户代支读卡失败!", outParam).ToString());
  796. return;
  797. }
  798. else
  799. {
  800. //展示患者信息界面
  801. if (hBus.MutualAidShowPatInfo(outParam, out patInfo) != 0)
  802. {
  803. MessageBox.Show("医保账户代支读卡成功,展示患者信息界面失败:" + patInfo);
  804. return;
  805. }
  806. }
  807. #endregion
  808. tb_UserNO.Text = Global.pat.psn_no_GJSQR;
  809. }
  810. private void MutualAid_Load(object sender, EventArgs e)
  811. {
  812. dt_ST.Text = DateTime.Now.ToString("yyyy-MM-dd 00:00:00");
  813. dt_ET.Text = DateTime.Now.ToString("yyyy-MM-dd 23:59:59");
  814. }
  815. }
  816. }