MobilePay.cs 77 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599
  1. using Newtonsoft.Json.Linq;
  2. using PTMedicalInsurance.Common;
  3. using PTMedicalInsurance.Helper;
  4. using PTMedicalInsurance.Variables;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. namespace PTMedicalInsurance.Business
  11. {
  12. class MobilePay
  13. {
  14. private HisIrisServices hIS = new HisIrisServices();
  15. private MIIrisServices mIS = new MIIrisServices();
  16. private CenterBusiness cBus = new CenterBusiness();
  17. private InvokeHelper invoker = new InvokeHelper();
  18. private Patients MPat;
  19. private Settlements MSettl;
  20. private JArray jaFee;
  21. //
  22. //private string fixmedins_code;//定点医疗服务机构编码
  23. //private string yhappid;//渠道ID
  24. //private string orgId;//电子凭证机构号
  25. //前端传过来的入参,从这里面取值
  26. private JObject joParam;
  27. private JObject joInsuAdmObj;
  28. public MobilePay(string inpar, out string errMsg)
  29. {
  30. errMsg = "";
  31. try
  32. {
  33. JObject joInpar = JObject.Parse(inpar);
  34. joParam = JObject.Parse(JsonHelper.getDestValue(joInpar, "params[0]"));
  35. joInsuAdmObj = JObject.Parse(JsonHelper.getDestValue(joInpar, "insuAdmObj"));
  36. setPatientByInPar();
  37. setSettlementsByInPar();
  38. }
  39. catch (Exception ex)
  40. {
  41. errMsg = "MobilePay异常:" + ex.Message;
  42. }
  43. }
  44. private JObject OutpatientReg()
  45. {
  46. string diagnoses;
  47. if (hIS.getPatDiagnoses(Global.pat, out diagnoses) != 0)
  48. {
  49. return JsonHelper.setExceptionJson(-1, "挂号", "获取诊断异常" + diagnoses);
  50. }
  51. JObject joHisRtnInfo = JObject.Parse(diagnoses);
  52. JObject joRegInpar = new JObject();
  53. string occurTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  54. joRegInpar.Add("psn_no", Global.pat.psn_no);
  55. joRegInpar.Add("insutype", Global.pat.insuType);
  56. joRegInpar.Add("begntime", JsonHelper.getDestValue(joHisRtnInfo, "mdtrtinfo.begntime"));//挂号时间 occurTime
  57. joRegInpar.Add("mdtrt_cert_type", "02");//就诊凭证类型
  58. joRegInpar.Add("mdtrt_cert_no", MPat.certNO);//就诊凭证编号
  59. joRegInpar.Add("ipt_otp_no", Global.pat.adm_Dr);
  60. joRegInpar.Add("atddr_no", JsonHelper.getDestValue(joHisRtnInfo, "mdtrtinfo.atddr_no"));
  61. joRegInpar.Add("dr_name", JsonHelper.getDestValue(joHisRtnInfo, "mdtrtinfo.chfpdr_name"));
  62. joRegInpar.Add("dept_code", JsonHelper.getDestValue(joHisRtnInfo, "mdtrtinfo.adm_dept_codg"));
  63. joRegInpar.Add("dept_name", JsonHelper.getDestValue(joHisRtnInfo, "mdtrtinfo.adm_dept_name"));
  64. joRegInpar.Add("caty", "72");
  65. JObject joReg = new JObject();
  66. joReg.Add("data", joRegInpar);
  67. JObject jo2201Inpar = JObject.Parse(JsonHelper.setCenterInpar("2201", joReg));
  68. JObject jo2201Rtn = invoker.invokeCenterService("2201", jo2201Inpar);
  69. string errMsg = "";
  70. if (JsonHelper.parseCenterRtnValue(jo2201Rtn, out errMsg) != 0)
  71. {
  72. return JsonHelper.setExceptionJson(-1, "医保挂号", errMsg);
  73. }
  74. else
  75. {
  76. Global.pat.mdtrtID = JsonHelper.getDestValue(jo2201Rtn, "output.data.mdtrt_id");
  77. }
  78. return jo2201Rtn;
  79. }
  80. public int MobilePaySettlement(out string outPar)
  81. {
  82. string errMsg, patInfo, M6201Inpar, M6202Inpar;
  83. //M6201Rtn, M6202Rtn,M6301Inpar,M6301Rtn;
  84. outPar = "";
  85. try
  86. {
  87. if (GetPatientInfo(out errMsg) != 0)
  88. {
  89. outPar = errMsg;
  90. return -1;
  91. }
  92. patInfo = errMsg;
  93. JObject jo1194Rtn = invoker.invokeCenterService("1101", JsonHelper.setCenterInpar("1101", patInfo));
  94. if (JsonHelper.parseCenterRtnValue(jo1194Rtn, out errMsg) != 0)
  95. {
  96. outPar = errMsg;
  97. return -1;
  98. }
  99. setPatientInsuInfo(jo1194Rtn);
  100. //2201
  101. //JObject jo2201Rtn = OutpatientReg();
  102. if (Get6201Inpar(out errMsg) != 0)
  103. {
  104. outPar = errMsg;
  105. return -1;
  106. }
  107. M6201Inpar = errMsg;
  108. JObject joM6201Rtn = invoker.invokeMPService("6201", errMsg);
  109. if (JsonHelper.parseMPRtnValue(joM6201Rtn, out errMsg) != 0)
  110. {
  111. outPar = errMsg;
  112. return -1;
  113. }
  114. JObject joEncData = JObject.Parse(errMsg);
  115. Global.writeLog("返回值:" + errMsg);
  116. //设置
  117. setPatientBy6201Rtn(joEncData);
  118. //存入MI 患者表,登记表,费用表
  119. if (saveToMi(out errMsg) != 0)
  120. {
  121. outPar = errMsg;
  122. return -1;
  123. }
  124. //M6202
  125. if (Get6202Inpar(JObject.Parse(M6201Inpar), out errMsg) != 0)
  126. {
  127. outPar = errMsg;
  128. return -1;
  129. }
  130. M6202Inpar = errMsg;
  131. JObject joM6202Rtn = invoker.invokeMPService("6202", M6202Inpar);
  132. if (JsonHelper.parseMPRtnValue(joM6202Rtn, out errMsg) != 0)
  133. {
  134. outPar = errMsg;
  135. return -1;
  136. }
  137. joEncData = JObject.Parse(errMsg);
  138. Global.writeLog(JsonHelper.Compress(joEncData));
  139. //设置
  140. setSettlementsBy6202Rtn(joEncData);
  141. MSettl.confirmFlag = 0;
  142. //存入MI 结算表
  143. if (saveSettlement(out errMsg) != 0)
  144. {
  145. outPar = errMsg;
  146. return -1;
  147. }
  148. //6301查询具体明细信息
  149. //if (Get6301Inpar(out errMsg) != 0)
  150. //{
  151. // outPar = errMsg;
  152. // return -1;
  153. //}
  154. //M6301Inpar = errMsg;
  155. //JObject joM6301Rtn = invoker.invokeMPService("6301", eh.encrypt(M6301Inpar));
  156. //if (JsonHelper.parseMPRtnValue(joM6301Rtn, out errMsg) != 0)
  157. //{
  158. // outPar = errMsg;
  159. // return -1;
  160. //}
  161. //joEncData = JObject.Parse(eh.decrypt(errMsg));
  162. //JObject joSettlInfo = JObject.Parse(JsonHelper.getDestValue(joEncData, "extData.SETLINFO"));
  163. //Global.writeLog(JsonHelper.Compress(joEncData));
  164. ////设置
  165. //setSettlementsBy6301Rtn(joSettlInfo);
  166. ////存入MI 结算表
  167. //if (saveSettlement(out errMsg) != 0)
  168. //{
  169. // outPar = errMsg;
  170. //}
  171. //返回给HIS后端
  172. JObject joPreSettl = JObject.Parse(JsonHelper.getDestValue(joEncData, "extData.preSetl"));
  173. //JObject joTmp = JObject.Parse(JsonHelper.getDestValue(joM6201Rtn, "encData"));
  174. JObject joTmp = new JObject();
  175. joTmp.Add("insutype", MPat.insuType);
  176. joTmp.Add("psn_no", MPat.psn_no);
  177. joTmp.Add("insuplc_admdvs", MPat.insuplc_admdvs);
  178. joTmp.Add("mdtrtId", MPat.mdtrtID);
  179. joTmp.Add("mdtrt_id", MPat.mdtrtID);
  180. joPreSettl.Add("setl_id", MPat.payOrdId);
  181. joTmp.Add("mdtrt_cert_type", JsonHelper.getDestValue(joPreSettl, "mdtrt_cert_type"));
  182. joTmp.Add("mdtrt_cert_no", JsonHelper.getDestValue(joPreSettl, "certno"));
  183. joTmp.Add("med_type", JsonHelper.getDestValue(joPreSettl, "med_type"));
  184. if (returnMPSettlementInfo(joTmp, joPreSettl, out errMsg) != 0)
  185. {
  186. outPar = errMsg;
  187. return -1;
  188. }
  189. //返回给HIS前端
  190. outPar = errMsg;
  191. return 0;
  192. }
  193. catch (Exception ex)
  194. {
  195. outPar = ex.Message;
  196. return -1;
  197. }
  198. }
  199. public int MobilePayConfirmSettlement(out string outPar)
  200. {
  201. string errMsg, M6301Inpar;
  202. outPar = "";
  203. try
  204. {
  205. //EncryptHelper eh = new EncryptHelper();
  206. //6301查询具体明细信息
  207. if (Get6301Inpar(out errMsg) != 0)
  208. {
  209. outPar = errMsg;
  210. return -1;
  211. }
  212. M6301Inpar = errMsg;
  213. JObject joM6301Rtn = invoker.invokeMPService("6301", M6301Inpar);
  214. if (JsonHelper.parseMPRtnValue(joM6301Rtn, out errMsg) != 0)
  215. {
  216. outPar = errMsg;
  217. return -1;
  218. }
  219. JObject joEncData = JObject.Parse((errMsg));
  220. Global.writeLog(JsonHelper.Compress(joEncData));
  221. string setlInfo = JsonHelper.getDestValue(joEncData, "extData.setlinfo");
  222. if (string.IsNullOrEmpty(setlInfo))
  223. {
  224. //此时为异步返回结算内容
  225. string ordStatus = JsonHelper.getDestValue(joEncData, "ordStas");
  226. outPar = JsonHelper.setExceptionJson(0, "移动医保结算", "当前订单状态为:【"+ordStatus+"】,结算成功,但未返回结算明细!").ToString();
  227. return 0;
  228. }
  229. //设置
  230. setSettlementsBy6301Rtn(joEncData);
  231. MSettl.confirmFlag = 1;
  232. //存入MI 结算表
  233. if (updateSettlement(out errMsg) != 0)
  234. {
  235. outPar = errMsg;
  236. return -1;
  237. }
  238. else
  239. {
  240. //返回给HIS前端
  241. outPar = JsonHelper.setExceptionJson(0, "云医保平台", "确认成功!").ToString();
  242. return 0;
  243. }
  244. }
  245. catch (Exception ex)
  246. {
  247. outPar = ex.Message;
  248. return -1;
  249. }
  250. }
  251. public int MobilePayCancelSettlement(out string outPar)
  252. {
  253. string errMsg;
  254. outPar = "";
  255. try
  256. {
  257. /**目前从微信那边处理退费
  258. if (Get6203Inpar(out errMsg) != 0)
  259. {
  260. }
  261. YH6203Inpar = errMsg;
  262. JObject jo6203Rtn = invoker.invokeMPService("6203", M6203Inpar);
  263. //M6202
  264. if (ParseCenterRtnValue(jo6203Rtn, out errMsg) != 0)
  265. {
  266. }
  267. else
  268. {
  269. string newSettlID = JsonHelper.getDestValue(jo6203Rtn,"");
  270. //撤销医保平台结算数据
  271. cancleSettlement(newSettlID,out errMsg);
  272. //撤销医保平台费用,登记,
  273. }
  274. **/
  275. //处理撤销数据
  276. if (cancleSettlement(MPat.settlID, out errMsg) != 0)
  277. {
  278. outPar = errMsg;
  279. return -1;
  280. }
  281. else
  282. {
  283. outPar = errMsg;
  284. return 0;
  285. }
  286. }
  287. catch (Exception ex)
  288. {
  289. return -1;
  290. }
  291. }
  292. #region 赋值MPat,Msettle结构体
  293. public void setPatientByInPar()
  294. {
  295. MPat.adm_Dr = int.Parse(JsonHelper.getDestValue(joParam, "admID"));
  296. Global.pat.adm_Dr = MPat.adm_Dr;
  297. MPat.recordID = JsonHelper.getDestValue(joParam, "recordID");
  298. MPat.billID = JsonHelper.getDestValue(joParam, "billID");
  299. MPat.medType = JsonHelper.getDestValue(joInsuAdmObj, "medType");
  300. MPat.certType = JsonHelper.getDestValue(joInsuAdmObj, "mdtrtCertType");
  301. MPat.token = JsonHelper.getDestValue(joInsuAdmObj, "ecToken");
  302. MPat.payAuthNo = JsonHelper.getDestValue(joInsuAdmObj, "payAuthNo");
  303. MPat.uldLatlnt = JsonHelper.getDestValue(joInsuAdmObj, "uldLatlnt");
  304. MPat.payOrdId = JsonHelper.getDestValue(joInsuAdmObj, "payOrdId");
  305. MPat.mdtrtID = JsonHelper.getDestValue(joInsuAdmObj, "mdtrt_id");
  306. MPat.settlID = JsonHelper.getDestValue(joInsuAdmObj, "setl_id");
  307. Global.pat.mdtrtID = MPat.mdtrtID;
  308. }
  309. public void setPatientBy6201Rtn(JObject jo)
  310. {
  311. MPat.payOrdId = JsonHelper.getDestValue(jo, "payOrdId");
  312. MPat.payToken = JsonHelper.getDestValue(jo, "payToken");
  313. //MPat.psn_no = JsonHelper.getDestValue(jo, "psn_no");
  314. //MPat.insuType = JsonHelper.getDestValue(jo, "insutype");
  315. //MPat.insuplc_admdvs = JsonHelper.getDestValue(jo, "insuplc_admdvs");
  316. MPat.mdtrtID = JsonHelper.getDestValue(jo, "extData.mdtrtId");
  317. }
  318. //{"errorCode":0,"errorMessage":"","result":{"patName":"张振","patBirthdate":"1993-02-07","patSex":"男","credCode":"01","credNo":"522226199302073619"}}
  319. public void setPatientByHisBaseInfo(JObject jo)
  320. {
  321. MPat.name = JsonHelper.getDestValue(jo, "result.patName");
  322. MPat.brdy = JsonHelper.getDestValue(jo, "result.patBirthdate");
  323. MPat.gend = JsonHelper.getDestValue(jo, "result.patSex");
  324. MPat.age = JsonHelper.getDestValue(jo, "result.Age");
  325. MPat.naty = JsonHelper.getDestValue(jo, "result.naty");
  326. MPat.certNO = JsonHelper.getDestValue(jo, "result.credNo");
  327. MPat.IDNO = MPat.certNO;
  328. MPat.certType = JsonHelper.getDestValue(jo, "result.credCode");
  329. }
  330. public void setPatientByMiRegInfo(JObject jo)
  331. {
  332. MPat.name = JsonHelper.getDestValue(jo, "data.PatientName");
  333. MPat.psn_no = JsonHelper.getDestValue(jo, "data.PersonalNO");
  334. MPat.certNO = JsonHelper.getDestValue(jo, "data.CertificateNO");
  335. MPat.IDNO = MPat.certNO;
  336. MPat.certType = JsonHelper.getDestValue(jo, "data.CertificateType");
  337. MPat.payToken = JsonHelper.getDestValue(jo, "data.payToken");
  338. MPat.insuplc_admdvs = JsonHelper.getDestValue(jo, "data.InsuranceAreaCode");
  339. }
  340. public void setPatientInsuInfo(JObject jo)
  341. {
  342. MPat.insuplc_admdvs = JsonHelper.getDestValue(jo, "output.insuinfo[0].insuplc_admdvs");
  343. MPat.psn_no = JsonHelper.getDestValue(jo, "output.baseinfo.psn_no");
  344. MPat.insuType = JsonHelper.getDestValue(jo, "output.insuinfo[0].insutype");
  345. Global.pat.insuplc_admdvs = MPat.insuplc_admdvs;
  346. Global.pat.psn_no = MPat.psn_no;
  347. Global.pat.insuType = MPat.insuType;
  348. }
  349. public void setPatientByDiagnoseInfo(JObject jo)
  350. {
  351. MPat.admAttendDoctorNO = JsonHelper.getDestValue(jo, "atddr_no");
  352. MPat.admDiagCode = JsonHelper.getDestValue(jo, "dscg_maindiag_code");
  353. MPat.admDiagName = JsonHelper.getDestValue(jo, "dscg_maindiag_name");
  354. MPat.AdmInDepCode = JsonHelper.getDestValue(jo, "adm_dept_codg");
  355. }
  356. public void setSettlementsBy6202Rtn(JObject jo)
  357. {
  358. MSettl.settlID = JsonHelper.getDestValue(jo, "payOrdId");
  359. MPat.payOrdId = MSettl.settlID;
  360. MSettl.ordStas = JsonHelper.getDestValue(jo, "ordStas");
  361. MSettl.sumamt = getDecimalFee(jo, "feeSumamt");
  362. MSettl.personCashPay = getDecimalFee(jo, "ownPayAmt");
  363. MSettl.accountPaySumamt = getDecimalFee(jo, "psnAcctPay");
  364. MSettl.fundPaySumamt = getDecimalFee(jo, "fundPay");
  365. MSettl.deposit = getDecimalFee(jo, "deposit");
  366. MSettl.clearingOrgan = JsonHelper.getDestValue(jo, "extData.preSetl.clr_optins");
  367. MSettl.clearingType = JsonHelper.getDestValue(jo, "extData.preSetl.clr_type");
  368. MSettl.clearingWay = JsonHelper.getDestValue(jo, "extData.preSetl.clr_way");
  369. MSettl.civilserviceAllowancePay = getDecimalFee(jo, "extData.preSetl.cvlserv_pay");
  370. MSettl.ownPayAmount = getDecimalFee(jo, "extData.preSetl.fulamt_ownpay_amt");
  371. MSettl.overLimitAmountmt = getDecimalFee(jo, "extData.preSetl.overlmt_selfpay");
  372. MSettl.preSelfPayAmount = getDecimalFee(jo, "extData.preSetl.preselfpay_amt");
  373. MSettl.inPolicyRangeAmount = getDecimalFee(jo, "extData.preSetl.inscp_scp_amt");
  374. MSettl.actualPayDeductible = getDecimalFee(jo, "extData.preSetl.act_pay_dedc");
  375. MSettl.healthInsurancePay = getDecimalFee(jo, "extData.preSetl.hifp_pay");
  376. MSettl.healthInsuranceRatio = getDecimalFee(jo, "extData.preSetl.pool_prop_selfpay");
  377. MSettl.enterpriseSupplementPay = getDecimalFee(jo, "extData.preSetl.hifes_pay");
  378. MSettl.seriousIllnessPay = getDecimalFee(jo, "extData.preSetl.hifmi_pay");
  379. MSettl.largeExpensesSupplementPay = getDecimalFee(jo, "extData.preSetl.hifob_pay");
  380. MSettl.medicalAssistPay = getDecimalFee(jo, "extData.preSetl.maf_pay");
  381. MSettl.hospitalPartAmount = getDecimalFee(jo, "extData.preSetl.hosp_part_amt");
  382. MSettl.otherPay = getDecimalFee(jo, "extData.preSetl.oth_pay");
  383. MSettl.personPaySumamt = getDecimalFee(jo, "extData.preSetl.psn_part_amt");
  384. MSettl.balance = getDecimalFee(jo, "extData.preSetl.balc");
  385. MSettl.accountMutualAidAmount = getDecimalFee(jo, "extData.preSetl.acct_mulaid_pay");
  386. }
  387. public void setSettlementsBy6301Rtn(JObject joRtn)
  388. {
  389. JObject jo = JObject.Parse(JsonHelper.getDestValue(joRtn, "extData.setlinfo"));
  390. MPat.settlID = JsonHelper.getDestValue(jo, "setlId");
  391. MPat.psn_no = JsonHelper.getDestValue(jo, "psnNo");
  392. MPat.naty = JsonHelper.getDestValue(jo, "naty");
  393. MPat.name = JsonHelper.getDestValue(jo, "psnName");
  394. MPat.age = JsonHelper.getDestValue(jo, "age");
  395. MPat.gend = JsonHelper.getDestValue(jo, "gend");
  396. MPat.certNO = JsonHelper.getDestValue(jo, "certno");
  397. MPat.brdy = JsonHelper.getDestValue(jo, "brdy");
  398. MPat.insuType = JsonHelper.getDestValue(jo, "insutype");
  399. MPat.psn_type = JsonHelper.getDestValue(jo, "psnType");
  400. MPat.mdtrtcertType = JsonHelper.getDestValue(jo, "mdtrtCertType");
  401. MPat.medType = JsonHelper.getDestValue(jo, "medType");
  402. MPat.insuplc_admdvs = JsonHelper.getDestValue(joRtn, "extData.insuplcAdmdvs");
  403. MPat.payOrdId = JsonHelper.getDestValue(joRtn, "payOrdId");
  404. MSettl.ordStas = JsonHelper.getDestValue(joRtn, "ordStas");
  405. MSettl.sumamt = getDecimalFee(joRtn, "feeSumamt");
  406. MSettl.personCashPay = getDecimalFee(jo, "psnCashPay");
  407. MSettl.accountPaySumamt = getDecimalFee(jo, "acctPay");
  408. MSettl.fundPaySumamt = getDecimalFee(jo, "fundPaySumamt");
  409. //MSettl.deposit = getDecimalFee(jo, "deposit");
  410. MSettl.clearingOrgan = JsonHelper.getDestValue(jo, "clrOptins");
  411. MSettl.clearingType = JsonHelper.getDestValue(jo, "clrType");
  412. MSettl.clearingWay = JsonHelper.getDestValue(jo, "clrWay");
  413. MSettl.civilserviceAllowancePay = getDecimalFee(jo, "cvlservPay");
  414. MSettl.ownPayAmount = getDecimalFee(jo, "fulamtOwnpayAmt");
  415. MSettl.overLimitAmountmt = getDecimalFee(jo, "overlmtSelfpay");
  416. MSettl.preSelfPayAmount = getDecimalFee(jo, "preselfpayAmt");
  417. MSettl.inPolicyRangeAmount = getDecimalFee(jo, "inscpScpAmt");
  418. MSettl.actualPayDeductible = getDecimalFee(jo, "actPayDedc");
  419. MSettl.healthInsurancePay = getDecimalFee(jo, "hifpPay");
  420. MSettl.healthInsuranceRatio = getDecimalFee(jo, "poolPropSelfpay");
  421. MSettl.enterpriseSupplementPay = getDecimalFee(jo, "hifesPay");
  422. MSettl.seriousIllnessPay = getDecimalFee(jo, "hifmiPay");
  423. MSettl.largeExpensesSupplementPay = getDecimalFee(jo, "hifobPay");
  424. MSettl.medicalAssistPay = getDecimalFee(jo, "mafPay");
  425. MSettl.hospitalPartAmount = getDecimalFee(jo, "hospPartAmt");
  426. MSettl.otherPay = getDecimalFee(jo, "othPay");
  427. MSettl.personPaySumamt = getDecimalFee(jo, "psnPartAmt");
  428. MSettl.balance = getDecimalFee(jo, "balc");
  429. MSettl.accountMutualAidAmount = getDecimalFee(jo, "acctMulaidPay");
  430. }
  431. public void setSettlementsByInPar()
  432. {
  433. MSettl.clearingWay = JsonHelper.getDestValue(joInsuAdmObj, "psnSetlway");
  434. MSettl.settlID = JsonHelper.getDestValue(joInsuAdmObj, "payOrdId");
  435. }
  436. #endregion
  437. #region 组织入参
  438. public int GetPatientInfo(out string outparam)
  439. {
  440. string errMsg = "";
  441. outparam = "";
  442. try
  443. {
  444. JObject joInpar = new JObject();
  445. //查询患者基本信息
  446. if (hIS.GetHisPatBaseInfo(out errMsg) != 0)
  447. {
  448. outparam = errMsg;
  449. return -1;
  450. }
  451. setPatientByHisBaseInfo(JObject.Parse(errMsg));
  452. //入参
  453. joInpar.Add("mdtrt_cert_type", "02");//就诊凭证类型
  454. joInpar.Add("mdtrt_cert_no", MPat.certNO);//就诊凭证编号
  455. joInpar.Add("card_sn", "");//卡识别码
  456. joInpar.Add("begntime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));//开始时间 获取历史参保信息时传入
  457. joInpar.Add("psn_cert_type", "01");//就诊凭证类型为“ 02” 时默认传 01 代表身份 证,其他证件类型按实际上传
  458. joInpar.Add("certno", MPat.certNO);//证件号码
  459. joInpar.Add("psn_name", MPat.name);//姓名
  460. JObject joData = new JObject();
  461. joData.Add("data", joInpar);
  462. outparam = joData.ToString();
  463. return 0;
  464. }
  465. catch (Exception ex)
  466. {
  467. outparam = "GetPatientInfo:" + ex.Message;
  468. return -1;
  469. }
  470. finally
  471. {
  472. Global.writeLog("GetPatientInfo", "", outparam);
  473. }
  474. }
  475. //组织M6201入参
  476. public int Get6201Inpar(out string outparam)
  477. {
  478. string errMsg = "";
  479. outparam = "";
  480. try
  481. {
  482. JObject joInpar = new JObject();
  483. //查询患者基本信息
  484. if (hIS.GetHisPatBaseInfo(out errMsg) != 0)
  485. {
  486. outparam = errMsg;
  487. return -1;
  488. }
  489. setPatientByHisBaseInfo(JObject.Parse(errMsg));
  490. JObject joPatBaseInfo = JObject.Parse(JsonHelper.getDestValue(JObject.Parse(errMsg), "result"));
  491. //获取诊断
  492. if (getDiagnoses(out errMsg) != 0)
  493. {
  494. outparam = errMsg;
  495. return -1;
  496. }
  497. JObject joDiagnoses = JObject.Parse(errMsg);
  498. JArray jaDiseinfoList = JArray.Parse(JsonHelper.getDestValue(joDiagnoses, "diseinfoList"));
  499. JObject joMdtrtinfo = JObject.Parse(JsonHelper.getDestValue(joDiagnoses, "mdtrtinfo"));
  500. setPatientByDiagnoseInfo(joMdtrtinfo);
  501. //获取费用
  502. if (GetFee(out errMsg) != 0)
  503. {
  504. outparam = errMsg;
  505. return -1;
  506. }
  507. JObject joFee = JObject.Parse(errMsg);
  508. JArray jaFeedetailList = JArray.Parse(JsonHelper.getDestValue(joFee, "feedetailList"));
  509. for (int i = 0; i < jaFeedetailList.Count; i++)
  510. {
  511. JObject joTmp = new JObject();
  512. joTmp.Add("act_purc_pric", jaFeedetailList[i]["pric"]);
  513. joTmp.Add("sin_dos", jaFeedetailList[i]["sinDosDscr"]);
  514. //joTmp.Add("medins_list_name", jaFeedetailList[i]["medListName"]);
  515. //((JObject)jaFeedetailList[i]).Property("chrgBchno").Remove();
  516. //((JObject)jaFeedetailList[i]).Property("diseCodg").Remove();
  517. ((JObject)jaFeedetailList[i]).Property("rxno").Remove();
  518. //((JObject)jaFeedetailList[i]).Property("feeOcurTime").Remove();
  519. ((JObject)jaFeedetailList[i]).Property("sinDosDscr").Remove();
  520. ((JObject)jaFeedetailList[i]).Property("usedFrquDscr").Remove();
  521. ((JObject)jaFeedetailList[i]).Property("prdDays").Remove();
  522. ((JObject)jaFeedetailList[i]).Property("medcWayDscr").Remove();
  523. //((JObject)jaFeedetailList[i]).Property("bilgDeptCodg").Remove();
  524. ((JObject)jaFeedetailList[i]).Property("acordDeptCodg").Remove();
  525. ((JObject)jaFeedetailList[i]).Property("acordDeptName").Remove();
  526. ((JObject)jaFeedetailList[i]).Property("ordersDrCode").Remove();
  527. ((JObject)jaFeedetailList[i]).Property("ordersDrName").Remove();
  528. ((JObject)jaFeedetailList[i]).Property("tcmdrugUsedWay").Remove();
  529. ((JObject)jaFeedetailList[i]).Property("etipFlag").Remove();
  530. ((JObject)jaFeedetailList[i]).Property("etipHospCode").Remove();
  531. ((JObject)jaFeedetailList[i]).Property("dscgTkdrugFlag").Remove();
  532. ((JObject)jaFeedetailList[i]).Property("matnFeeFlag").Remove();
  533. ((JObject)jaFeedetailList[i]).Property("initFeedetlSn").Remove();
  534. ((JObject)jaFeedetailList[i]).Property("medType").Remove();
  535. ((JObject)jaFeedetailList[i]).Property("memo").Remove();
  536. //((JObject)jaFeedetailList[i]).Property("expContent").Remove();
  537. //((JObject)jaFeedetailList[i]).Property("medListName").Remove();
  538. //((JObject)jaFeedetailList[i]).Property("medListSpc").Remove();
  539. ((JObject)jaFeedetailList[i]).Property("combNo").Remove();
  540. //jaFeedetailList[i]["chrgBchno"] = MPat.adm_Dr.ToString();
  541. jaFeedetailList[i]["expContent"] = joTmp.ToString();
  542. jaFeedetailList[i]["medType"] = JsonHelper.getDestValue(joInsuAdmObj, "medType");
  543. jaFeedetailList[i]["psnNo"] = MPat.psn_no;
  544. }
  545. //入参
  546. joInpar.Add("orgCodg", Global.inf.hospitalNO);//机构编码
  547. //joInpar.Add("orgId", "");//电子凭证机构号
  548. joInpar.Add("psnNo", MPat.psn_no);//人员编号
  549. joInpar.Add("insutype", MPat.insuType);//险种类型
  550. joInpar.Add("medOrgOrd", MPat.recordID);//医疗机构订单号 前端传入
  551. joInpar.Add("initRxOrd", JsonHelper.getDestValue(joInsuAdmObj, "initRxOrd"));//要续方的原处方流水 前端传入
  552. joInpar.Add("rxCircFlag", JsonHelper.getDestValue(joInsuAdmObj, "rxCircFlag"));//电子处方流转标志 前端传入
  553. MSettl.settlTime = Convert.ToDateTime(JsonHelper.getDestValue(joMdtrtinfo, "begntime"));
  554. joInpar.Add("begntime", JsonHelper.getDestValue(joMdtrtinfo, "begntime"));//开始时间
  555. joInpar.Add("idNo", JsonHelper.getDestValue(joPatBaseInfo, "credNo"));//证件号码
  556. joInpar.Add("userName", JsonHelper.getDestValue(joPatBaseInfo, "patName"));//用户姓名
  557. joInpar.Add("idType", JsonHelper.getDestValue(joPatBaseInfo, "credCode"));//证件类别
  558. joInpar.Add("ecToken", JsonHelper.getDestValue(joInsuAdmObj, "ecToken"));//电子凭证授权ecToken 前端传入
  559. joInpar.Add("insuCode", Global.inf.areaCode);//就诊参保地行政区划
  560. joInpar.Add("iptOtpNo", JsonHelper.getDestValue(joMdtrtinfo, "ipt_no"));//住院/门诊号
  561. joInpar.Add("atddrNo", JsonHelper.getDestValue(joMdtrtinfo, "atddr_no"));//医师编码
  562. joInpar.Add("drName", JsonHelper.getDestValue(joMdtrtinfo, "chfpdr_name"));//医师姓名
  563. joInpar.Add("deptCode", JsonHelper.getDestValue(joMdtrtinfo, "adm_dept_codg"));//科室编码
  564. joInpar.Add("deptName", JsonHelper.getDestValue(joMdtrtinfo, "adm_dept_name"));//科室名称
  565. joInpar.Add("caty", "A10");//科别
  566. //joInpar.Add("mdtrtId", Global.pat.mdtrtID);//医保就诊ID
  567. joInpar.Add("medType", MPat.medType);//医疗类别 前端传入
  568. joInpar.Add("feeType", JsonHelper.getDestValue(joInsuAdmObj, "feeType"));//费用类型 前端传入
  569. joInpar.Add("medfeeSumamt", JsonHelper.getDestValue(joFee, "medfeeSumamt"));//医疗费总额
  570. joInpar.Add("acctUsedFlag", JsonHelper.getDestValue(joInsuAdmObj, "acctUsedFlag"));//个人账户使用标志 前端传入
  571. joInpar.Add("mainCondDscr", JsonHelper.getDestValue(joMdtrtinfo, "mainCondDscr"));//主要病情描述
  572. joInpar.Add("diseCodg", JsonHelper.getDestValue(joMdtrtinfo, "diseCodg"));//病种编码
  573. joInpar.Add("diseName", JsonHelper.getDestValue(joMdtrtinfo, "diseName"));//病种名称
  574. joInpar.Add("psnSetlway", JsonHelper.getDestValue(joInsuAdmObj, "psnSetlway"));//个人结算方式 前端传入
  575. joInpar.Add("chrgBchno", JsonHelper.getDestValue(joFee, "chrgBchno"));//收费批次号
  576. //joInpar.Add("pubHospRfomFlag", JsonHelper.getDestValue(joInsuAdmObj, "pubHospRfomFlag"));//公立医院改革标志
  577. //joInpar.Add("invono", JsonHelper.getDestValue(joMdtrtinfo, "invono"));//发票号
  578. //joInpar.Add("endtime", JsonHelper.getDestValue(joMdtrtinfo, "endtime"));//出院时间
  579. //joInpar.Add("fulamtOwnpayAmt", JsonHelper.getDestValue(joMdtrtinfo, "fulamtOwnpayAmt"));//全自费金额
  580. //joInpar.Add("overlmtSelfpay", JsonHelper.getDestValue(joMdtrtinfo, "overlmtSelfpay"));//超限价金额
  581. //joInpar.Add("preselfpayAmt", JsonHelper.getDestValue(joMdtrtinfo, "preselfpayAmt"));//先行自付金额
  582. //joInpar.Add("inscpScpAmt", JsonHelper.getDestValue(joMdtrtinfo, "inscpScpAmt"));//符合政策范围金额
  583. //joInpar.Add("oprnOprtCode", JsonHelper.getDestValue(joMdtrtinfo, "oprnOprtCode"));//手术操作代码
  584. //joInpar.Add("oprnOprtName", JsonHelper.getDestValue(joMdtrtinfo, "oprnOprtName"));//手术操作名称
  585. //joInpar.Add("fpscNo", JsonHelper.getDestValue(joMdtrtinfo, "fpscNo"));//计划生育服务证号
  586. //joInpar.Add("latechbFlag", JsonHelper.getDestValue(joMdtrtinfo, "latechbFlag"));//晚育标志
  587. joInpar.Add("gesoVal", JsonHelper.getDestValue(joMdtrtinfo, "gesoVal"));//孕周数
  588. joInpar.Add("fetts", JsonHelper.getDestValue(joMdtrtinfo, "fetts"));//胎次
  589. joInpar.Add("fetusCnt", JsonHelper.getDestValue(joMdtrtinfo, "fetusCnt"));//胎儿数
  590. //joInpar.Add("pretFlag", JsonHelper.getDestValue(joMdtrtinfo, "pretFlag"));//早产标志
  591. //joInpar.Add("birctrlType", JsonHelper.getDestValue(joMdtrtinfo, "birctrlType"));//计划生育手术类别
  592. //joInpar.Add("birctrlMatnDate", JsonHelper.getDestValue(joMdtrtinfo, "birctrlMatnDate"));//计划生育手术或生育日期
  593. //joInpar.Add("copFlag", JsonHelper.getDestValue(joMdtrtinfo, "copFlag"));//伴有并发症标志
  594. //joInpar.Add("dscgDeptCodg", JsonHelper.getDestValue(joMdtrtinfo, "dscgDeptCodg"));//出院科室编码
  595. //joInpar.Add("dscgDeptName", JsonHelper.getDestValue(joMdtrtinfo, "dscgDeptName"));//出院科室名称
  596. //joInpar.Add("dscgDed", JsonHelper.getDestValue(joMdtrtinfo, "dscgDed"));//出院床位
  597. //joInpar.Add("dscgWay", JsonHelper.getDestValue(joMdtrtinfo, "dscgWay"));//离院方式
  598. //joInpar.Add("dieDate", JsonHelper.getDestValue(joMdtrtinfo, "dieDate"));//死亡日期
  599. joInpar.Add("matnType", JsonHelper.getDestValue(joMdtrtinfo, "matnType"));//生育类别
  600. joInpar.Add("expContent", JsonHelper.getDestValue(joInsuAdmObj, "expContent"));//扩展参数 前端传入
  601. //joInpar.Add("midSetlFlag", JsonHelper.getDestValue(joInsuAdmObj, "midSetlFlag"));//中途结算标志 前端传入
  602. joInpar.Add("diseinfoList", jaDiseinfoList);//诊断或症状明细
  603. joInpar.Add("feedetailList", jaFeedetailList);//费用明细
  604. //joInpar.Add("admDiagDscr", JsonHelper.getDestValue(joMdtrtinfo, "admDiagDscr"));//入院诊断描述
  605. //joInpar.Add("admDeptCodg", JsonHelper.getDestValue(joMdtrtinfo, "admDeptCodg"));//入院科室编码
  606. //joInpar.Add("admDeptName", JsonHelper.getDestValue(joMdtrtinfo, "admDeptName"));//入院科室名称
  607. //joInpar.Add("admBed", JsonHelper.getDestValue(joMdtrtinfo, "admBed"));//入院床位
  608. joInpar.Add("payAuthNo", JsonHelper.getDestValue(joInsuAdmObj, "payAuthNo"));//支付授权码 前端传入
  609. joInpar.Add("uldLatlnt", JsonHelper.getDestValue(joInsuAdmObj, "uldLatlnt"));//经纬度 前端传入
  610. joInpar.Add("mdtrtCertType", JsonHelper.getDestValue(joInsuAdmObj, "mdtrtCertType"));//就诊凭证类型 前端传入
  611. joInpar.Add("insuplcAdmdvs", MPat.insuplc_admdvs);//用户参保地行政区划
  612. //JObject joData = new JObject();
  613. //joData.Add("data",joInpar);
  614. outparam = joInpar.ToString();
  615. return 0;
  616. }
  617. catch (Exception ex)
  618. {
  619. outparam = "Get6201Inpar:" + ex.Message;
  620. return -1;
  621. }
  622. finally
  623. {
  624. Global.writeLog("Get6201Inpar", "", outparam);
  625. }
  626. }
  627. //获取入参,入参基本为类局部变量
  628. public int Get6202Inpar(JObject joM6201Inpar, out string outparam)
  629. {
  630. outparam = "";
  631. try
  632. {
  633. //获取其他入参
  634. JObject joInpar = new JObject();
  635. joInpar.Add("payAuthNo", MPat.payAuthNo);//支付授权码 前端传入
  636. joInpar.Add("payOrdId", MPat.payOrdId);//待支付订单号
  637. joInpar.Add("payToken", MPat.payToken);//支付订单对应的token
  638. joInpar.Add("orgCodg", Global.inf.hospitalNO);//定点机构编码
  639. joInpar.Add("orgBizSer", DateTime.Now.ToString("yyyyMMddHHmmssffff"));//业务流水号 前端传入
  640. //joInpar.Add("ecAuthCode", "");
  641. //joInpar.Add("ecChnlAppId", "");
  642. //joInpar.Add("ecChnlUserId", "");
  643. //joInpar.Add("mdtrtId", MPat.mdtrtID);
  644. joInpar.Add("chrgBchno", JsonHelper.getDestValue(joM6201Inpar, "chrgBchno"));//收费批次号
  645. //joInpar.Add("feeType", JsonHelper.getDestValue(joM6201Inpar, "feeType"));//费用类别
  646. //joInpar.Add("deposit", JsonHelper.getDestValue(joInsuAdmObj, "deposit"));//住院押金
  647. //joInpar.Add("expContent", "");//扩展数据
  648. //joInpar.Add("acctUsedFlag", "1");//个账使用标识
  649. //JObject joData = new JObject();
  650. //joData.Add("data", joInpar);
  651. outparam = joInpar.ToString();
  652. return 0;
  653. }
  654. catch (Exception ex)
  655. {
  656. outparam = "Get6202Inpar:" + ex.Message;
  657. return -1;
  658. }
  659. finally
  660. {
  661. Global.writeLog("Get6202Inpar", "", outparam);
  662. }
  663. }
  664. //组织M6203入参
  665. public int Get6203Inpar(out string outparam)
  666. {
  667. string errMsg = "";
  668. outparam = "";
  669. try
  670. {
  671. JObject joInpar = new JObject();
  672. //获取医保平台结算信息
  673. if (QuerySettleInfo(out errMsg) != 0)
  674. {
  675. outparam = errMsg;
  676. return -1;
  677. }
  678. JObject joRtn = JObject.Parse(errMsg);
  679. JObject joSettl = JObject.Parse(JsonHelper.getDestValue(joRtn, "data"));
  680. //入参
  681. joInpar.Add("payOrdId", JsonHelper.getDestValue(joSettl, "SettlementID"));//支付订单号
  682. joInpar.Add("appRefdSn", JsonHelper.getDestValue(joSettl, ""));//应用退款流水号
  683. joInpar.Add("appRefdTime", JsonHelper.getDestValue(joSettl, ""));//应用退费时间
  684. joInpar.Add("totlRefdAmt", JsonHelper.getDestValue(joSettl, "Sumamt"));//总退费金额
  685. joInpar.Add("psnAcctRefdAmt", JsonHelper.getDestValue(joSettl, "AccountPaySumamt"));//医保个人账户支付
  686. joInpar.Add("fundRefdAmt", JsonHelper.getDestValue(joSettl, "FundPaySumamt"));//基金支付
  687. joInpar.Add("cashRefdAmt", JsonHelper.getDestValue(joInsuAdmObj, "PersonCashPay"));//现金退费金额
  688. joInpar.Add("ecToken", MPat.token);//电子凭证授权Token 前端传入
  689. joInpar.Add("refdType", "ALL");//退费类型 前端传入
  690. joInpar.Add("expData", "");//扩展数据 前端传入
  691. joInpar.Add("payAuthNo", MPat.payAuthNo);//支付授权码 前端传入
  692. //JObject joData = new JObject();
  693. //joData.Add("data", joInpar);
  694. outparam = joInpar.ToString();
  695. return 0;
  696. }
  697. catch (Exception ex)
  698. {
  699. outparam = "Get6203Inpar:" + ex.Message;
  700. return -1;
  701. }
  702. finally
  703. {
  704. Global.writeLog("Get6203Inpar", "", outparam);
  705. }
  706. }
  707. //获取入参,入参基本为类局部变量
  708. public int Get6301Inpar(out string outparam)
  709. {
  710. outparam = "";
  711. try
  712. {
  713. string errMsg;
  714. //查询登记信息
  715. if (mIS.queryRegisterInfo(4, out errMsg) != 0)
  716. {
  717. outparam = errMsg;
  718. return -1;
  719. }
  720. setPatientByMiRegInfo(JObject.Parse(errMsg));
  721. //获取其他入参
  722. JObject joInpar = new JObject();
  723. joInpar.Add("payOrdId", MPat.payOrdId);//待支付订单号
  724. joInpar.Add("payToken", MPat.payToken);//支付订单对应的token
  725. joInpar.Add("orgCodg", Global.inf.hospitalNO);//定点机构编码
  726. joInpar.Add("idNo", MPat.IDNO);//业务流水号 前端传入
  727. joInpar.Add("userName", MPat.name);
  728. joInpar.Add("idType", "01");
  729. joInpar.Add("expData", "");
  730. //JObject joData = new JObject();
  731. //joData.Add("data", joInpar);
  732. outparam = joInpar.ToString();
  733. return 0;
  734. }
  735. catch (Exception ex)
  736. {
  737. outparam = "Get6301Inpar:" + ex.Message;
  738. return -1;
  739. }
  740. finally
  741. {
  742. Global.writeLog("Get6301Inpar", "", outparam);
  743. }
  744. }
  745. public int Get6401Inpar(out string outparam)
  746. {
  747. string errMsg = "";
  748. outparam = "";
  749. try
  750. {
  751. JObject joInpar = new JObject();
  752. //获取医保平台结算信息
  753. if (QuerySettleInfo(out errMsg) != 0)
  754. {
  755. outparam = errMsg;
  756. return -1;
  757. }
  758. JObject joRtn = JObject.Parse(errMsg);
  759. JObject joSettl = JObject.Parse(JsonHelper.getDestValue(joRtn, "data"));
  760. //入参
  761. joInpar.Add("payOrdId", JsonHelper.getDestValue(joSettl, "SettlementID"));//支付订单号
  762. joInpar.Add("appRefdSn", JsonHelper.getDestValue(joSettl, ""));//应用退款流水号
  763. joInpar.Add("appRefdTime", JsonHelper.getDestValue(joSettl, ""));//应用退费时间
  764. joInpar.Add("totlRefdAmt", JsonHelper.getDestValue(joSettl, "Sumamt"));//总退费金额
  765. joInpar.Add("psnAcctRefdAmt", JsonHelper.getDestValue(joSettl, "AccountPaySumamt"));//医保个人账户支付
  766. joInpar.Add("fundRefdAmt", JsonHelper.getDestValue(joSettl, "FundPaySumamt"));//基金支付
  767. joInpar.Add("cashRefdAmt", JsonHelper.getDestValue(joInsuAdmObj, "PersonCashPay"));//现金退费金额
  768. joInpar.Add("ecToken", MPat.token);//电子凭证授权Token 前端传入
  769. joInpar.Add("refdType", "ALL");//退费类型 前端传入
  770. joInpar.Add("expData", "");//扩展数据 前端传入
  771. joInpar.Add("payAuthNo", MPat.payAuthNo);//支付授权码 前端传入
  772. //JObject joData = new JObject();
  773. //joData.Add("data", joInpar);
  774. outparam = joInpar.ToString();
  775. return 0;
  776. }
  777. catch (Exception ex)
  778. {
  779. outparam = "Get6203Inpar:" + ex.Message;
  780. return -1;
  781. }
  782. finally
  783. {
  784. Global.writeLog("Get6203Inpar", "", outparam);
  785. }
  786. }
  787. #endregion
  788. #region 诊断
  789. //获取诊断信息
  790. public int getDiagnoses(out string errMsg)
  791. {
  792. errMsg = "";
  793. try
  794. {
  795. //调用服务获取门诊诊断信息
  796. string outparam = "";
  797. if (hIS.getPatDiagnoses(MPat, out outparam) != 0)
  798. {
  799. return -1;
  800. }
  801. JObject joRtn = JObject.Parse(outparam);
  802. JObject joMdtrtInfo = JObject.Parse(JsonHelper.getDestValue(joRtn, "mdtrtinfo"));
  803. JArray jaDiagnoses = JArray.Parse(JsonHelper.getDestValue(joRtn, "diseinfo"));
  804. //组织门诊结算诊断入参
  805. JArray jaRow = new JArray();
  806. for (int i = 0; i < jaDiagnoses.Count; i++)
  807. {
  808. JObject joTmp = new JObject();
  809. joTmp.Add("diagType", jaDiagnoses[i]["diag_type"]);//
  810. joTmp.Add("diagSrtNo", jaDiagnoses[i]["diag_srt_no"]);//
  811. joTmp.Add("diagCode", jaDiagnoses[i]["diag_code"]);//
  812. joTmp.Add("diagName", jaDiagnoses[i]["diag_name"]);//
  813. joTmp.Add("diagDept", jaDiagnoses[i]["diag_dept"]);//
  814. joTmp.Add("diseDorNo", jaDiagnoses[i]["dise_dor_no"]);//
  815. joTmp.Add("diseDorName", jaDiagnoses[i]["dise_dor_name"]);//
  816. joTmp.Add("diagTime", jaDiagnoses[i]["diag_time"]);//
  817. joTmp.Add("valiFlag", "1");//
  818. jaRow.Add(joTmp);
  819. }
  820. JObject joDiagRow = new JObject();
  821. joDiagRow.Add("diseinfoList", jaRow);
  822. joDiagRow.Add("mdtrtinfo", joMdtrtInfo);
  823. outparam = joDiagRow.ToString();
  824. errMsg = outparam;
  825. return 0;
  826. }
  827. catch (Exception ex)
  828. {
  829. errMsg = "getDiagnoses:" + ex.Message;
  830. return -1;
  831. }
  832. }
  833. #endregion
  834. #region 费用
  835. private int GetFee(out string outparam)
  836. {
  837. string hisFee, chrgBchno = "";
  838. JObject jo = new JObject();
  839. JObject joRow = new JObject();
  840. JArray jaRow = new JArray();
  841. try
  842. {
  843. //获取HIS费用
  844. if (hIS.getHisFee(MPat, out hisFee) != 0)
  845. {
  846. outparam = hisFee;
  847. return -1;
  848. }
  849. JObject joFee = JObject.Parse(hisFee);
  850. //处理
  851. //调用医保平台转换HIS费用(转换医保编码等)
  852. JObject joHisFee = JObject.Parse(hisFee);
  853. if (mIS.convertHisFeeWithInsuCodeOfMobilePay(MPat, joHisFee, out outparam) != 0)
  854. {
  855. return -1;
  856. }
  857. JArray jaFeeDetail = JArray.Parse(JsonHelper.getDestValue(JObject.Parse(outparam), "data"));
  858. jaFee = (JArray)jaFeeDetail.DeepClone();
  859. decimal sumFee = 0;
  860. //转换
  861. for (int i = 0; i < jaFeeDetail.Count; i++)
  862. {
  863. decimal cnt = decimal.Parse(jaFeeDetail[i]["cnt"].ToString());
  864. decimal pric = decimal.Parse(jaFeeDetail[i]["pric"].ToString());
  865. decimal sumamt = decimal.Parse(jaFeeDetail[i]["det_item_fee_sumamt"].ToString());
  866. sumFee = sumFee + sumamt;
  867. JObject joTmp = new JObject();
  868. joTmp.Add("feedetlSn", jaFeeDetail[i]["feedetl_sn"]);//费用明细流水号
  869. //joTmp.Add("mdtrtId", Global.pat.mdtrtID);//医保就诊ID
  870. //joTmp.Add("psnNo", jaFeeDetail[i]["psnNo"]);//人员编号
  871. chrgBchno = jaFeeDetail[i]["chrg_bchno"].ToString();
  872. joTmp.Add("chrgBchno", jaFeeDetail[i]["chrg_bchno"]);//收费批次号
  873. joTmp.Add("diseCodg", "");//病种编码
  874. joTmp.Add("rxno", jaFeeDetail[i]["rxno"]);//处方号
  875. joTmp.Add("rxCircFlag", jaFeeDetail[i]["rx_circ_flag"]);//外购处方标志
  876. joTmp.Add("feeOcurTime", jaFeeDetail[i]["fee_ocur_time"]);//费用发生时间
  877. joTmp.Add("medListCodg", jaFeeDetail[i]["med_list_codg"]);//医疗目录编码
  878. joTmp.Add("medinsListCodg", jaFeeDetail[i]["medins_list_codg"]);//医药机构目录编码
  879. joTmp.Add("detItemFeeSumamt", sumamt.ToString("#0.00"));//明细项目费用总额
  880. joTmp.Add("cnt", cnt.ToString("#0.0000"));//数量
  881. joTmp.Add("pric", pric.ToString("#0.000000"));//单价
  882. joTmp.Add("sinDosDscr", jaFeeDetail[i]["sin_dos_dscr"]);//单次剂量描述
  883. joTmp.Add("usedFrquDscr", jaFeeDetail[i]["used_frqu_dscr"]);//使用频次描述
  884. joTmp.Add("prdDays", jaFeeDetail[i]["prd_days"]);//周期天数
  885. joTmp.Add("medcWayDscr", jaFeeDetail[i]["medc_way_dscr"]);//用药途径描述
  886. joTmp.Add("bilgDeptCodg", jaFeeDetail[i]["bilg_dept_codg"]);//开单科室编码
  887. joTmp.Add("bilgDeptName", jaFeeDetail[i]["bilg_dept_name"]);//开单科室名称
  888. joTmp.Add("bilgDrCodg", jaFeeDetail[i]["bilg_dr_codg"]);//开单医生编码
  889. joTmp.Add("bilgDrName", jaFeeDetail[i]["bilg_dr_name"]);//开单医师姓名
  890. joTmp.Add("acordDeptCodg", jaFeeDetail[i]["acord_dept_codg"]);//受单科室编码
  891. joTmp.Add("acordDeptName", jaFeeDetail[i]["acord_dept_name"]);//受单科室名称
  892. joTmp.Add("ordersDrCode", jaFeeDetail[i]["orders_dr_code"]);//受单医生编码
  893. joTmp.Add("ordersDrName", jaFeeDetail[i]["orders_dr_name"]);//受单医生姓名
  894. joTmp.Add("hospApprFlag", jaFeeDetail[i]["hosp_appr_flag"]);//医院审批标志
  895. joTmp.Add("tcmdrugUsedWay", jaFeeDetail[i]["tcmdrug_used_way"]);//中药使用方式
  896. joTmp.Add("etipFlag", jaFeeDetail[i]["etip_flag"]);//外检标志
  897. joTmp.Add("etipHospCode", jaFeeDetail[i]["etip_hosp_code"]);//外检医院编码
  898. joTmp.Add("dscgTkdrugFlag", jaFeeDetail[i]["dscg_tkdrug_flag"]);//出院带药标志
  899. joTmp.Add("matnFeeFlag", jaFeeDetail[i]["matn_fee_flag"]);//生育费用标志
  900. joTmp.Add("initFeedetlSn", jaFeeDetail[i]["init_feedetl_sn"]);//原费用流水号
  901. joTmp.Add("drordNo", jaFeeDetail[i]["drord_no"]);//医嘱号
  902. joTmp.Add("medType", jaFeeDetail[i]["med_type"]);//医疗类别
  903. joTmp.Add("memo", "");//备注
  904. joTmp.Add("expContent", jaFeeDetail[i]["expContent"]);//扩展字段
  905. joTmp.Add("medListName", jaFeeDetail[i]["medins_list_name"]);//医疗目录名称
  906. joTmp.Add("medListSpc", jaFeeDetail[i]["med_list_spc"]);//医疗目录规格
  907. joTmp.Add("combNo", jaFeeDetail[i]["comb_no"]);//组套编号
  908. jaRow.Add(joTmp);
  909. }
  910. jo.Add("medfeeSumamt", sumFee.ToString("#0.00"));
  911. jo.Add("chrgBchno", chrgBchno);
  912. jo.Add("feedetailList", jaRow);
  913. outparam = jo.ToString();
  914. return 0;
  915. }
  916. catch (Exception ex)
  917. {
  918. outparam = "获取费用异常:" + ex.Message;
  919. Global.writeLog("GetFee", jo.ToString(), "获取费用异常:" + ex.Message);
  920. return -1;
  921. }
  922. }
  923. /// <summary>
  924. /// 汇总医保返回的结算金额(按照HIS的原则汇总,后期HIS按照这个来进行勾稽关系判断)
  925. /// </summary>
  926. /// <param name="jo"></param>
  927. /// <returns></returns>
  928. public int sumInsuRtnSettlInfo(JObject jo, out JObject joSumFee, out string errMsg)
  929. {
  930. // 医疗费总额是患者在医药机构花费的所有诊疗、药品、耗材、服务设施等项目费用的总和 = 基金支付总额 + 个人负担总金额 + 其他(如医院负担金额);
  931. //3、基金支付总额 = 基本医保统筹基金支出(含职工基本医疗保险、居民基本医疗保险)+补充医疗保险基金支出 (含覆盖全体参保人的居民大病保险和大额医疗费用补助、覆盖部分参保人的企业职工大额医疗费用补助和公务员医疗补助等)+医疗救助基金支出 + 其他支出(如伤残人员医疗保障基金支出);
  932. //5、个人账户支出中包含账户共济支付金额
  933. joSumFee = new JObject();
  934. errMsg = "";
  935. decimal ybAmt, psnAcctAmt, hospAmt, psnCashAmt, medFee;
  936. try
  937. {
  938. ybAmt = 0; psnAcctAmt = 0; hospAmt = 0; psnCashAmt = 0; medFee = 0;
  939. ybAmt = MSettl.fundPaySumamt;
  940. psnAcctAmt = MSettl.accountPaySumamt;
  941. psnCashAmt = MSettl.personCashPay;
  942. hospAmt = MSettl.hospitalPartAmount;
  943. medFee = MSettl.sumamt;
  944. joSumFee.Add("sumamt", medFee);
  945. joSumFee.Add("ybAmt", ybAmt);
  946. joSumFee.Add("psnAcctAmt", psnAcctAmt);
  947. joSumFee.Add("hospAmt", hospAmt);
  948. joSumFee.Add("psnCashAmt", psnCashAmt);
  949. if (medFee != (ybAmt + psnAcctAmt + psnCashAmt + hospAmt))
  950. {
  951. errMsg = "ybAmt(" + ybAmt.ToString() + ")+" + "psnAcctAmt(" + psnAcctAmt.ToString() + ")+" + "psnCashAmt(" + psnCashAmt.ToString() + ")+" + "hospAmt(" + hospAmt.ToString() + ")" + "!=medFee(" + medFee.ToString() + ")";
  952. return -1;
  953. }
  954. return 0;
  955. }
  956. catch (Exception ex)
  957. {
  958. errMsg = ex.Message;
  959. return 1;
  960. }
  961. }
  962. /// <summary>
  963. /// 获取结算费用的封装
  964. /// </summary>
  965. /// <param name="jo"></param>
  966. /// <param name="path"></param>
  967. /// <returns></returns>
  968. private decimal getDecimalFee(JObject jo, string path)
  969. {
  970. try
  971. {
  972. string temp = JsonHelper.getDestValue(jo, path);
  973. if (temp == "")
  974. {
  975. return 0;
  976. }
  977. else
  978. {
  979. return decimal.Parse(temp);
  980. }
  981. }
  982. catch (Exception ex)
  983. {
  984. Global.writeLog("getFee异常:" + ex.Message);
  985. return 0;
  986. }
  987. }
  988. #endregion
  989. #region 结算
  990. /// <summary>
  991. /// 返回移动支付结算信息给HIS
  992. /// </summary>
  993. /// <param name="joSetlInpar"></param>
  994. /// <param name="joSetlinfo"></param>中心返回的信息
  995. /// <param name="outParam"></param>
  996. /// <returns></returns>
  997. public int returnMPSettlementInfo(JObject joReg, JObject joSettl, out string outParam)
  998. {
  999. string errMsg;
  1000. try
  1001. {
  1002. JObject joSumFee = new JObject();
  1003. if (sumInsuRtnSettlInfo(joSettl, out joSumFee, out errMsg) != 0)
  1004. {
  1005. outParam = "返回结算结果给HIS失败,请联系管理员!" + errMsg;
  1006. return -1;
  1007. }
  1008. dynamic joTmp = new JObject();
  1009. joTmp.settleInfo = joSettl;
  1010. joTmp.updateUserID = Global.user.ID;
  1011. joTmp.regInfo = joReg;
  1012. joTmp.middleSettleFlag = "";
  1013. joTmp.interfaceDr = Global.inf.interfaceDr;
  1014. dynamic joHisInfo = new JObject();
  1015. joHisInfo.admID = MPat.adm_Dr;
  1016. joHisInfo.billID = MPat.billID;
  1017. joHisInfo.recordID = MPat.recordID;
  1018. joTmp.hisInfo = joHisInfo;
  1019. joTmp.psn_type = MPat.psn_type;
  1020. joTmp.mobilePayFlag = "Y";
  1021. joTmp.sumFeeObj = joSumFee;
  1022. joTmp.mdtrtinfo = MPat.mdtrtID;
  1023. JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110018", joTmp).ToString(), "返回移动支付结算结果给HIS");
  1024. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1025. {
  1026. outParam = "返回移动支付结算结果给HIS失败,请联系管理员!" + errMsg;
  1027. return -1;
  1028. }
  1029. else
  1030. {
  1031. joSumFee.Add("payAuthNo", MPat.payAuthNo);
  1032. joSumFee.Add("payOrdId", MPat.payOrdId);
  1033. joSumFee.Add("setlLatlnt", MPat.uldLatlnt);
  1034. joSumFee.Add("org_no", Global.inf.hospitalNO);
  1035. joSumFee.Add("medOrgOrd", MPat.recordID);
  1036. joSumFee.Add("mdtrtId", MPat.mdtrtID);
  1037. joSumFee.Add("gmt_out_create", MSettl.settlTime.ToString("yyyy-MM-dd HH:mm:ss"));
  1038. joRtn["result"] = joSumFee;
  1039. outParam = joRtn.ToString();
  1040. return 0;
  1041. }
  1042. }
  1043. catch (Exception ex)
  1044. {
  1045. outParam = "返回移动支付结算结果给HIS出现异常:!" + ex.Message;
  1046. return -1;
  1047. }
  1048. }
  1049. //查询结算信息
  1050. public int QuerySettleInfo(out string errMsg)
  1051. {
  1052. errMsg = "";
  1053. try
  1054. {
  1055. string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE Hospital_Dr= " + Global.inf.hospitalDr;
  1056. sqlStr = sqlStr + " and AdmType = 3 and Adm_Dr= " + MPat.adm_Dr + " and SettlementID= '" + MPat.payOrdId + "'";
  1057. JObject joSqlstr = new JObject();
  1058. joSqlstr.Add("sqlStr", sqlStr);
  1059. JObject joRtn = mIS.DynamicQuerySettlInfo(joSqlstr);
  1060. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1061. {
  1062. return -1;
  1063. }
  1064. else
  1065. {
  1066. errMsg = joRtn.ToString();
  1067. return 0;
  1068. }
  1069. }
  1070. catch (Exception ex)
  1071. {
  1072. errMsg = ex.Message;
  1073. return -1;
  1074. }
  1075. }
  1076. #endregion
  1077. #region 存入MI
  1078. /// <summary>
  1079. /// 插入患者该次就诊参保信息
  1080. /// </summary>
  1081. /// <param name="joBaseInfo"></param>
  1082. /// <param name="joInsuInfo"></param>
  1083. /// <param name="joIdetInfo"></param>
  1084. /// <param name="outParam"></param>
  1085. /// <returns></returns>
  1086. private int insertPatCurInsuInfo(out string outParam)
  1087. {
  1088. JObject joTmp = new JObject();
  1089. string errMsg = "";
  1090. try
  1091. {
  1092. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  1093. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  1094. joTmp.Add("AdmID", MPat.adm_Dr);
  1095. joTmp.Add("PatientName", MPat.name);
  1096. joTmp.Add("PersonalNO", MPat.psn_no);
  1097. joTmp.Add("MdtrtID", MPat.mdtrtID);
  1098. joTmp.Add("PsnCertType", "");
  1099. joTmp.Add("PsnCertNO", MPat.certNO);
  1100. joTmp.Add("Gend", MPat.gend);
  1101. joTmp.Add("Naty", "");
  1102. joTmp.Add("Brdy", MPat.brdy);
  1103. joTmp.Add("Age", MPat.age);
  1104. joTmp.Add("Balc", MPat.balc);
  1105. joTmp.Add("Insutype", MPat.insuType);
  1106. joTmp.Add("PsnType", MPat.psn_type);
  1107. joTmp.Add("PsnInsuStas", "");
  1108. joTmp.Add("PsnInsuDate", "");
  1109. joTmp.Add("PausInsuDate", "");
  1110. joTmp.Add("Cvlservflag", "");
  1111. joTmp.Add("insuplcAdmdvs", MPat.insuplc_admdvs);
  1112. joTmp.Add("EmpName", MPat.emp_name);
  1113. joTmp.Add("PsnIdettype", "");
  1114. joTmp.Add("PsnTypeLv", "");
  1115. joTmp.Add("IdetBegntime", "");
  1116. joTmp.Add("IdetEndtime", "");
  1117. if (string.IsNullOrEmpty(Global.user.ID)) Global.user.ID = "0";
  1118. joTmp.Add("updateUserID", Global.user.ID);
  1119. string serviceCode = "09010070";
  1120. string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString();
  1121. JObject joRtn = invoker.invokeInsuService(inpar, "插入患者该次就诊参保信息");
  1122. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1123. {
  1124. outParam = errMsg;
  1125. return -1;
  1126. }
  1127. else
  1128. {
  1129. outParam = joRtn.ToString();
  1130. return 0;
  1131. }
  1132. }
  1133. catch (Exception ex)
  1134. {
  1135. outParam = "医保平台插入患者该次就诊参保信息:" + ex.Message;
  1136. return -1;
  1137. }
  1138. }
  1139. /// <summary>
  1140. /// 插入登记信息
  1141. /// </summary>
  1142. /// <param name="joInpar"></param> 48交易入参
  1143. /// <param name="joOutpar"></param>48交易出参
  1144. /// <param name="outParam"></param>
  1145. /// <returns></returns>
  1146. private int saveRegisterInfo(out string outParam)
  1147. {
  1148. //插入云医保平台
  1149. JObject joTmp = new JObject();
  1150. string errMsg = "";
  1151. try
  1152. {
  1153. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  1154. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  1155. joTmp.Add("AdmDr", MPat.adm_Dr);
  1156. joTmp.Add("PatientName", MPat.name);
  1157. joTmp.Add("PersonalNO", MPat.psn_no);
  1158. joTmp.Add("InsuRegID", MPat.mdtrtID);
  1159. joTmp.Add("RegDate", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  1160. joTmp.Add("InsuType", MPat.insuType);
  1161. joTmp.Add("CertificateType", MPat.certType);
  1162. joTmp.Add("CertificateNO", MPat.certNO);
  1163. joTmp.Add("MedicalType", MPat.medType);
  1164. joTmp.Add("AttendDoctorNO", MPat.admAttendDoctorNO);
  1165. joTmp.Add("ChiefPhyDocName", "");
  1166. joTmp.Add("AdmInDiagDesc", "");
  1167. joTmp.Add("AdmInDepCode", MPat.AdmInDepCode);
  1168. joTmp.Add("AdmInDepName", "");
  1169. joTmp.Add("AdmBed", "");
  1170. joTmp.Add("MainDiagCode", MPat.admDiagCode);
  1171. joTmp.Add("MainDiagName", MPat.admDiagName);
  1172. joTmp.Add("MainConditionDesc", "");
  1173. joTmp.Add("DiseasecCode", "");
  1174. joTmp.Add("DiseasecName", "");
  1175. joTmp.Add("OperationCode", "");
  1176. joTmp.Add("OperationName", "");
  1177. joTmp.Add("DiseasecTypeCode", "");
  1178. joTmp.Add("InsuranceAreaCode", MPat.insuplc_admdvs);
  1179. joTmp.Add("TreatmentAreaCode", Global.inf.areaCode);
  1180. joTmp.Add("payOrdId", MPat.payOrdId);
  1181. joTmp.Add("payToken", MPat.payToken);
  1182. joTmp.Add("RegState", "1");
  1183. joTmp.Add("ValidFlag", "1");
  1184. joTmp.Add("Type", "4");//线上支付门诊
  1185. joTmp.Add("updateUserID", Global.user.ID);
  1186. joTmp.Add("msgid", Global.curEvt.msgid);
  1187. joTmp.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  1188. string serviceCode = "09010044";
  1189. string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString();
  1190. JObject joRtn = invoker.invokeInsuService(inpar, "新增门诊登记信息");
  1191. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1192. {
  1193. outParam = joRtn.ToString();
  1194. return -1;
  1195. }
  1196. else
  1197. {
  1198. outParam = joRtn.ToString();
  1199. return 0;
  1200. }
  1201. }
  1202. catch (Exception ex)
  1203. {
  1204. outParam = "保存门诊登记信息异常:" + ex.Message;
  1205. return -1;
  1206. }
  1207. }
  1208. /// <summary>
  1209. /// 插入结算信息
  1210. /// </summary>
  1211. /// <param name="joSettlement"></param>
  1212. /// <param name="outParam"></param>
  1213. /// <returns></returns>
  1214. public int saveSettlement(out string outParam)
  1215. {
  1216. JObject joTmp = new JObject();
  1217. string errMsg = "";
  1218. try
  1219. {
  1220. JObject joSetlinfo = new JObject();
  1221. joSetlinfo.Add("HospitalDr", Global.inf.hospitalDr);
  1222. joSetlinfo.Add("admID", MPat.adm_Dr);
  1223. joSetlinfo.Add("mdtrt_id", MPat.mdtrtID);
  1224. joSetlinfo.Add("setl_id", MSettl.settlID);//
  1225. joSetlinfo.Add("psn_no", MPat.psn_no);
  1226. joSetlinfo.Add("psn_name", MPat.name);
  1227. //joSetlinfo.Add("mdtrt_cert_type", JsonHelper.getDestValue(joRtnSetlinfo, "mdtrt_cert_type"));
  1228. joSetlinfo.Add("certno", MPat.certNO);
  1229. joSetlinfo.Add("gend", MPat.gend);
  1230. joSetlinfo.Add("naty", MPat.naty);
  1231. joSetlinfo.Add("brdy", MPat.brdy);
  1232. joSetlinfo.Add("age", MPat.age);
  1233. joSetlinfo.Add("insutype", MPat.insuType);
  1234. joSetlinfo.Add("psn_type", MPat.psn_type);
  1235. joSetlinfo.Add("cvlserv_flag", "");
  1236. joSetlinfo.Add("setl_time", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  1237. joSetlinfo.Add("mdtrt_cert_type", MPat.mdtrtcertType);
  1238. joSetlinfo.Add("med_type", MPat.medType);
  1239. joSetlinfo.Add("medfee_sumamt", MSettl.sumamt);//总费用
  1240. joSetlinfo.Add("fulamt_ownpay_amt", MSettl.fundPaySumamt);//全自费金额
  1241. joSetlinfo.Add("overlmt_selfpay", MSettl.overLimitAmountmt);//超限价自费费用
  1242. joSetlinfo.Add("preselfpay_amt", MSettl.preSelfPayAmount);//先行自付金额
  1243. joSetlinfo.Add("inscp_scp_amt", MSettl.inPolicyRangeAmount);//符合政策范围金额
  1244. joSetlinfo.Add("act_pay_dedc", MSettl.actualPayDeductible);//实际支付起付线
  1245. joSetlinfo.Add("hifp_pay", MSettl.healthInsurancePay);//基本医疗保险统筹基金支出
  1246. joSetlinfo.Add("pool_prop_selfpay", MSettl.healthInsuranceRatio);//基本医疗保险统筹基金支付比例
  1247. joSetlinfo.Add("cvlserv_pay", MSettl.civilserviceAllowancePay);//公务员医疗补助资金支出
  1248. joSetlinfo.Add("hifes_pay", MSettl.enterpriseSupplementPay);//企业支付 占用 大病报销金额
  1249. joSetlinfo.Add("hifmi_pay", MSettl.seriousIllnessPay);// 居民大病保险资金支出
  1250. joSetlinfo.Add("hifob_pay", MSettl.largeExpensesSupplementPay);//职工大额医疗费用补助基金支出
  1251. joSetlinfo.Add("maf_pay", MSettl.medicalAssistPay);//医疗救助基金支出
  1252. joSetlinfo.Add("hosp_part_amt", MSettl.hospitalPartAmount);//医院负担金额
  1253. joSetlinfo.Add("oth_pay", MSettl.otherPay);//其他支出
  1254. joSetlinfo.Add("fund_pay_sumamt", MSettl.fundPaySumamt);//基金支付总额
  1255. joSetlinfo.Add("psn_part_amt", MSettl.personPaySumamt);//个人负担总金额
  1256. joSetlinfo.Add("acct_pay", MSettl.accountMutualAidAmount);//个人账户支出
  1257. joSetlinfo.Add("psn_cash_pay", MSettl.personCashPay);//个人现金支出
  1258. joSetlinfo.Add("balc", MSettl.balance);// 余额
  1259. joSetlinfo.Add("acct_mulaid_pay", "");//个人账户共济支付金额
  1260. joSetlinfo.Add("medins_setl_id", "");//医药机构结算ID
  1261. joSetlinfo.Add("clr_optins", MSettl.clearingOrgan);//清算经办机构
  1262. joSetlinfo.Add("clr_way", MSettl.clearingWay);//清算方式
  1263. joSetlinfo.Add("clr_type", MSettl.clearingType);//清算类别
  1264. joSetlinfo.Add("ValidFlag", 1);
  1265. joSetlinfo.Add("BillType", 1);
  1266. joSetlinfo.Add("ConfirmFlag", MSettl.confirmFlag);
  1267. joSetlinfo.Add("msgid", Global.curEvt.msgid);
  1268. joSetlinfo.Add("admType", "3");
  1269. joSetlinfo.Add("billID", MPat.billID);
  1270. joSetlinfo.Add("recordID", MPat.recordID);
  1271. joSetlinfo.Add("interfaceDr", Global.inf.interfaceDr);
  1272. joSetlinfo.Add("insuplc_admdvs", MPat.insuplc_admdvs);
  1273. joSetlinfo.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  1274. joSetlinfo.Add("HospitalizationsDays", MSettl.hospitalizationsDays);
  1275. joSetlinfo.Add("HospitalizationsTimes", MSettl.hospitalizationsTimes);
  1276. joSetlinfo.Add("HISAdmTime", MSettl.hisAdmTime);
  1277. joSetlinfo.Add("HISDischargeTime", MSettl.hisDischargeTime);
  1278. joSetlinfo.Add("updateUserID", Global.user.ID);
  1279. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010051", joSetlinfo).ToString(), "插入结算信息");
  1280. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1281. {
  1282. outParam = errMsg;
  1283. return -1;
  1284. }
  1285. else
  1286. {
  1287. outParam = joSetlinfo.ToString();
  1288. return 0;
  1289. }
  1290. }
  1291. catch (Exception ex)
  1292. {
  1293. outParam = "插入结算信息:" + ex.Message;
  1294. return -1;
  1295. }
  1296. }
  1297. public int updateSettlement(out string outParam)
  1298. {
  1299. JObject joTmp = new JObject();
  1300. string errMsg = "";
  1301. try
  1302. {
  1303. JObject joSetlinfo = new JObject();
  1304. joSetlinfo.Add("HospitalDr", Global.inf.hospitalDr);
  1305. joSetlinfo.Add("AdmDr", MPat.adm_Dr);
  1306. joSetlinfo.Add("MdtrtID", MPat.mdtrtID);
  1307. joSetlinfo.Add("SettlementID", MSettl.settlID);//
  1308. joSetlinfo.Add("PersonnelNO", MPat.psn_no);
  1309. joSetlinfo.Add("PatientName", MPat.name);
  1310. //joSetlinfo.Add("CertificateType", JsonHelper.getDestValue(joRtnSetlinfo, "mdtrt_cert_type"));
  1311. joSetlinfo.Add("CertificateNO", MPat.certNO);
  1312. joSetlinfo.Add("Gender", MPat.gend);
  1313. joSetlinfo.Add("Nation", MPat.naty);
  1314. joSetlinfo.Add("BirthDay", MPat.brdy);
  1315. joSetlinfo.Add("Age", MPat.age);
  1316. joSetlinfo.Add("InsuranceType", MPat.insuType);
  1317. joSetlinfo.Add("PersonType", MPat.psn_type);
  1318. joSetlinfo.Add("CivilserviceFlag", "");
  1319. joSetlinfo.Add("SettlementDateTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  1320. joSetlinfo.Add("MdtrtCertType", MPat.mdtrtcertType);
  1321. joSetlinfo.Add("MedicalType", MPat.medType);
  1322. joSetlinfo.Add("Sumamt", MSettl.sumamt);//总费用
  1323. joSetlinfo.Add("OwnPayAmount", MSettl.fundPaySumamt);//全自费金额
  1324. joSetlinfo.Add("OverLimitAmount", MSettl.overLimitAmountmt);//超限价自费费用
  1325. joSetlinfo.Add("PreSelfPayAmount", MSettl.preSelfPayAmount);//先行自付金额
  1326. joSetlinfo.Add("InPolicyRangeAmount", MSettl.inPolicyRangeAmount);//符合政策范围金额
  1327. joSetlinfo.Add("ActualPayDeductible", MSettl.actualPayDeductible);//实际支付起付线
  1328. joSetlinfo.Add("HealthInsurancePay", MSettl.healthInsurancePay);//基本医疗保险统筹基金支出
  1329. joSetlinfo.Add("HealthInsuranceRatio", MSettl.healthInsuranceRatio);//基本医疗保险统筹基金支付比例
  1330. joSetlinfo.Add("CivilserviceAllowancePay", MSettl.civilserviceAllowancePay);//公务员医疗补助资金支出
  1331. joSetlinfo.Add("EnterpriseSupplementPay", MSettl.enterpriseSupplementPay);//企业支付
  1332. joSetlinfo.Add("SeriousIllnessPay", MSettl.seriousIllnessPay);// 居民大病保险资金支出
  1333. joSetlinfo.Add("LargeExpensesSupplementPay", MSettl.largeExpensesSupplementPay);//职工大额医疗费用补助基金支出
  1334. joSetlinfo.Add("MedicalAssistPay", MSettl.medicalAssistPay);//医疗救助基金支出
  1335. joSetlinfo.Add("HospitalPartAmount", MSettl.hospitalPartAmount);//医院负担金额
  1336. joSetlinfo.Add("OtherPay", MSettl.otherPay);//其他支出
  1337. joSetlinfo.Add("FundPaySumamt", MSettl.fundPaySumamt);//基金支付总额
  1338. joSetlinfo.Add("PersonPaySumamt", MSettl.personPaySumamt);//个人负担总金额
  1339. joSetlinfo.Add("AccountPaySumamt", MSettl.accountMutualAidAmount);//个人账户支出
  1340. joSetlinfo.Add("PersonCashPay", MSettl.personCashPay);//个人现金支出
  1341. joSetlinfo.Add("Balance", MSettl.balance);// 余额
  1342. joSetlinfo.Add("AccountMutualAidAmount", "");//个人账户共济支付金额
  1343. joSetlinfo.Add("OrganSettlementID", "");//医药机构结算ID
  1344. joSetlinfo.Add("ClearingOrgan", MSettl.clearingOrgan);//清算经办机构
  1345. joSetlinfo.Add("ClearingWay", MSettl.clearingWay);//清算方式
  1346. joSetlinfo.Add("ClearingType", MSettl.clearingType);//清算类别
  1347. joSetlinfo.Add("ValidFlag", 1);
  1348. joSetlinfo.Add("BillType", 1);
  1349. joSetlinfo.Add("ConfirmFlag", MSettl.confirmFlag);
  1350. joSetlinfo.Add("MSGID", Global.curEvt.msgid);
  1351. joSetlinfo.Add("AdmType", "3");
  1352. joSetlinfo.Add("BillID", MPat.billID);
  1353. joSetlinfo.Add("RecordID", MPat.recordID);
  1354. joSetlinfo.Add("InterfaceDr", Global.inf.interfaceDr);
  1355. joSetlinfo.Add("InsuranceAreaCode", MPat.insuplc_admdvs);
  1356. joSetlinfo.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  1357. joSetlinfo.Add("HospitalizationsDays", MSettl.hospitalizationsDays);
  1358. joSetlinfo.Add("HospitalizationsTimes", MSettl.hospitalizationsTimes);
  1359. joSetlinfo.Add("HISAdmTime", MSettl.hisAdmTime);
  1360. joSetlinfo.Add("HISDischargeTime", MSettl.hisDischargeTime);
  1361. joSetlinfo.Add("updateUserID", Global.user.ID);
  1362. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010080", joSetlinfo).ToString(), "更新结算信息");
  1363. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1364. {
  1365. outParam = errMsg;
  1366. return -1;
  1367. }
  1368. else
  1369. {
  1370. outParam = joSetlinfo.ToString();
  1371. return 0;
  1372. }
  1373. }
  1374. catch (Exception ex)
  1375. {
  1376. outParam = "插入结算信息:" + ex.Message;
  1377. return -1;
  1378. }
  1379. }
  1380. /// <summary>
  1381. /// 取消结算
  1382. /// </summary>
  1383. /// <param name="outParam"></param>
  1384. /// <returns></returns>
  1385. public int cancleSettlement(string newSettlID, out string outParam)
  1386. {
  1387. JObject joTmp = new JObject();
  1388. string errMsg = "";
  1389. try
  1390. {
  1391. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  1392. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  1393. joTmp.Add("admID", MPat.adm_Dr);
  1394. joTmp.Add("mdtrt_id", MPat.mdtrtID);
  1395. joTmp.Add("setl_id", MPat.settlID);
  1396. joTmp.Add("new_setl_id", newSettlID);
  1397. joTmp.Add("updateUserID", Global.user.ID);
  1398. joTmp.Add("msgid", Global.curEvt.msgid);
  1399. joTmp.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  1400. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010052", joTmp).ToString(), "取消结算信息");
  1401. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1402. {
  1403. outParam = errMsg;
  1404. return -1;
  1405. }
  1406. else
  1407. {
  1408. outParam = JsonHelper.setExceptionJson(0, "云医保平台", "取消结算成功").ToString();
  1409. return 0;
  1410. }
  1411. }
  1412. catch (Exception ex)
  1413. {
  1414. outParam = "取消结算信息:" + ex.Message;
  1415. return -1;
  1416. }
  1417. }
  1418. /// <summary>
  1419. /// 插入医保费用
  1420. /// </summary>
  1421. /// <param name="jaTmp"></param>
  1422. /// <param name="outParam"></param>
  1423. /// <returns></returns>
  1424. public int insertFee(JArray jaTmp, out string outParam)
  1425. {
  1426. try
  1427. {
  1428. outParam = "";
  1429. string errMsg;
  1430. dynamic joTmp = new JObject();
  1431. joTmp = new JObject();
  1432. joTmp.code = "09010046";
  1433. joTmp.HospitalDr = Global.inf.hospitalDr;
  1434. joTmp.admID = MPat.adm_Dr;
  1435. joTmp.mdtrt_id = MPat.mdtrtID;
  1436. joTmp.updateUserID = Global.user.ID;
  1437. joTmp.Add("params", jaTmp);
  1438. ;
  1439. JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "插入2301明细");
  1440. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1441. {
  1442. outParam = errMsg;
  1443. return -1;
  1444. }
  1445. else
  1446. {
  1447. outParam = joRtn.ToString();
  1448. return 0;
  1449. }
  1450. }
  1451. catch (Exception ex)
  1452. {
  1453. outParam = "insertFee 异常:" + ex.Message;
  1454. return -1;
  1455. }
  1456. }
  1457. private int saveToMi(out string errMsg)
  1458. {
  1459. errMsg = "";
  1460. try
  1461. {
  1462. //存储参保信息
  1463. if (insertPatCurInsuInfo(out errMsg) != 0)
  1464. {
  1465. return -1;
  1466. }
  1467. //存储登记信息
  1468. if (saveRegisterInfo(out errMsg) != 0)
  1469. {
  1470. return -1;
  1471. }
  1472. //处理jaFee
  1473. foreach (var jo in jaFee)
  1474. {
  1475. jo["mdtrt_id"] = MPat.mdtrtID;
  1476. jo["psn_no"] = MPat.psn_no;
  1477. }
  1478. //存储费用信息
  1479. if (insertFee(jaFee, out errMsg) != 0)
  1480. {
  1481. return -1;
  1482. }
  1483. return 0;
  1484. }
  1485. catch (Exception ex)
  1486. {
  1487. errMsg = "saveToMi:" + ex.Message;
  1488. return -1;
  1489. }
  1490. }
  1491. #endregion
  1492. #region 解析中心返回
  1493. /// <summary>
  1494. /// 解析银海移动支付返参
  1495. /// </summary>
  1496. /// <param name="joRtn"></param>
  1497. /// <param name="errorMsg"></param>
  1498. /// <returns></returns>
  1499. public int ParseCenterRtnValue(JObject joRtn, out string errorMsg)
  1500. {
  1501. try
  1502. {
  1503. errorMsg = JsonHelper.getDestValue(joRtn, "message");
  1504. return int.Parse(JsonHelper.getDestValue(joRtn, "code")); //0 成功-1 失败
  1505. }
  1506. catch (Exception ex)
  1507. {
  1508. errorMsg = "解析银海移动支付返参发生异常:" + ex.Message;
  1509. return -1;
  1510. }
  1511. }
  1512. #endregion
  1513. }
  1514. }