IrisServices.cs 71 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789
  1. /******************************************************************************
  2. * 文件名称: CardReader.cs
  3. * 文件说明: 读卡的封装,包括社保卡,身份证,电子凭证等等
  4. * 当前版本: V1.0
  5. * 创建日期: 2022-06-25
  6. *
  7. * * 2020-06-20: 增加 IrisServices 类(基类)
  8. * ***** 2020-06-25: 增加 CardReader 方法,获取URL地址,USER信息,地方版SSCard.dll使用
  9. * ***** 2020-06-25: 增加 CardReader 方法重载,国家版电子凭证使用
  10. *
  11. *
  12. * * 2020-06-20: 增加 HisIrisServices 类(子类)
  13. * ***** 2020-06-25: 增加 CardReader 方法,获取URL地址,USER信息,地方版SSCard.dll使用
  14. * ***** 2020-06-25: 增加 CardReader 方法重载,国家版电子凭证使用
  15. *
  16. *
  17. * * 2020-06-20: 增加 MIIrisServices 类(子类)
  18. * ***** 2020-06-25: 增加 CardReader 方法,获取URL地址,USER信息,地方版SSCard.dll使用
  19. * ***** 2020-06-25: 增加 CardReader 方法重载,国家版电子凭证使用
  20. ******************************************************************************/
  21. using Newtonsoft.Json.Linq;
  22. using System;
  23. using System.Collections.Generic;
  24. using System.Linq;
  25. using System.Text;
  26. using System.Threading.Tasks;
  27. using PTMedicalInsurance.Variables;
  28. using PTMedicalInsurance.Helper;
  29. using System.Windows.Forms;
  30. using AnHuiMI.Common;
  31. namespace PTMedicalInsurance.Business
  32. {
  33. class IrisServices
  34. {
  35. }
  36. class HisIrisServices
  37. {
  38. private InvokeHelper invoker = new InvokeHelper();
  39. /// <summary>
  40. /// 获取患者基本信息
  41. /// </summary>
  42. /// <param name="errMsg"></param>
  43. /// <returns></returns>
  44. public int GetHisPatBaseInfo(out string errMsg)
  45. {
  46. errMsg = "";
  47. try
  48. {
  49. dynamic joTmp = new JObject();
  50. joTmp.admID = Global.pat.adm_Dr;
  51. JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110021", joTmp).ToString(), "获取HIS患者基本信息");
  52. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  53. {
  54. errMsg = "获取HIS患者基本信息失败,请联系管理员!" + errMsg;
  55. return -1;
  56. }
  57. else
  58. {
  59. Global.pat.certNO = joRtn["result"]["credNo"].ToString();//用于读卡前调用获取身份证号,节省收费员输入身份证号
  60. errMsg = joRtn.ToString();
  61. return 0;
  62. }
  63. }
  64. catch (Exception ex)
  65. {
  66. errMsg = "GetHisPatBaseInfo异常:" + ex.Message;
  67. return -1;
  68. }
  69. }
  70. /// <summary>
  71. /// 获取诊断信息
  72. /// </summary>
  73. /// <param name="jaSession"></param>
  74. /// <param name="diagnoses"></param>
  75. /// <returns></returns>
  76. public int getPatDiagnoses(Patients pat, out string outParam)
  77. {
  78. outParam = "";
  79. string errMsg;
  80. try
  81. {
  82. JObject joTmp = new JObject();
  83. joTmp.Add("admID", pat.adm_Dr);
  84. joTmp.Add("psn_no", pat.psn_no);
  85. //JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110001", joTmp).ToString(), "获取诊断信息");
  86. JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110014", joTmp).ToString(), "获取诊断信息");
  87. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  88. {
  89. outParam = "获取诊断信息失败,请联系管理员!" + errMsg;
  90. return -1;
  91. }
  92. else
  93. {
  94. outParam = joRtn.ToString();
  95. return 0;
  96. }
  97. }
  98. catch (Exception ex)
  99. {
  100. outParam = "getPatDiagnoses 异常:" + ex.Message;
  101. return -1;
  102. }
  103. }
  104. /// <summary>
  105. /// 返回登记信息给HIS
  106. /// </summary>
  107. /// <param name="joRegIn"></param>
  108. /// <param name="joRegOut"></param>
  109. /// <param name="outParam"></param>
  110. /// <returns></returns>
  111. public int returnRegisterInfo(JObject joRegInOld, JObject joRegOut, out string outParam)
  112. {
  113. string errMsg;
  114. try
  115. {
  116. JObject joRegIn = Utils.removeWrapper(joRegInOld);
  117. joRegIn.Add("admID", Global.pat.adm_Dr);
  118. joRegIn.Add("mdtrt_id", Global.pat.mdtrtID);
  119. joRegIn.Add("interfaceDr", Global.inf.interfaceDr);
  120. joRegIn.Add("billID", Global.pat.billID);
  121. string serviceCode = "05110002", serviceName = "将登记信息返回给HIS";
  122. string inpar = JsonHelper.setIrisInpar(serviceCode, joRegIn).ToString();
  123. JObject joRtn = invoker.invokeHISService(inpar,serviceName);
  124. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  125. {
  126. outParam = "中心登记成功但云HIS平台保存失败,请联系管理员!" + errMsg;
  127. return -1;
  128. }
  129. else
  130. {
  131. outParam = "返回给HIS成功";
  132. return 0;
  133. }
  134. }
  135. catch (Exception ex )
  136. {
  137. outParam = "HIS保存登记信息出现异常:!" + ex.Message;
  138. return -1;
  139. }
  140. }
  141. /// <summary>
  142. /// 获取His费用
  143. /// </summary>
  144. /// <param name="pat"></param>
  145. /// <param name="errMsg"></param>
  146. /// <returns></returns>
  147. public int getHisFee(Patients pat, out string outParam)
  148. {
  149. outParam = "";
  150. string errMsg;
  151. try
  152. {
  153. dynamic joIrisParam = new JObject();
  154. JArray jaIrisParams = new JArray();
  155. JObject joIrisTmp = new JObject();
  156. joIrisParam.code = "05110003";
  157. joIrisParam.session = Global.curEvt.jaSession;
  158. joIrisTmp.Add("admID", pat.adm_Dr);
  159. joIrisTmp.Add("billID", pat.billID);
  160. joIrisTmp.Add("recordID", pat.recordID);
  161. jaIrisParams.Add(joIrisTmp);
  162. joIrisParam.Add("params", JArray.FromObject(jaIrisParams));
  163. JObject joRtn = invoker.invokeHISService(joIrisParam.ToString(), "获取HIS费用");
  164. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  165. {
  166. outParam = errMsg;
  167. return -1;
  168. }
  169. else
  170. {
  171. outParam = joRtn.ToString();
  172. return 0;
  173. }
  174. }
  175. catch (Exception ex)
  176. {
  177. outParam = "deleteFee 异常:" + ex.Message;
  178. return -1;
  179. }
  180. }
  181. /// <summary>
  182. /// 取消登记信息
  183. /// </summary>
  184. /// <param name="outParam"></param>
  185. /// <returns></returns>
  186. public int cancleRegister( out string outParam)
  187. {
  188. outParam = "";
  189. string errMsg;
  190. try
  191. {
  192. dynamic joTmp = new JObject();
  193. joTmp.Add("admID", Global.pat.adm_Dr);
  194. joTmp.Add("interfaceDr", Global.inf.interfaceDr);
  195. joTmp.Add("billID", Global.pat.billID);
  196. string serviceCode = "05110004";
  197. string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString();
  198. JObject joRtn = invoker.invokeHISService(inpar, "取消HIS登记信息");
  199. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  200. {
  201. outParam = joRtn.ToString();
  202. return -1;
  203. }
  204. else
  205. {
  206. outParam = joRtn.ToString();
  207. return 0;
  208. }
  209. }
  210. catch (Exception ex)
  211. {
  212. outParam = "取消登记异常" + ":" + ex.Message;
  213. return -1;
  214. }
  215. }
  216. /// <summary>
  217. /// HIS预结算
  218. /// </summary>
  219. /// <param name="joParam"></param>
  220. /// <param name="joSetlinfo"></param>
  221. /// <param name="outParam"></param>
  222. /// <returns></returns>
  223. public int preSettlementInfo(JObject joParam, JObject joSetlinfo, out string outParam)
  224. {
  225. string errMsg;
  226. try
  227. {
  228. dynamic joTmp = new JObject();
  229. joTmp = joParam.DeepClone();
  230. joTmp.insuPayInfo = joSetlinfo;
  231. joTmp.updateUserID = Global.user.ID;
  232. joTmp.middleSettleFlag = "";
  233. JObject joSumFee = new JObject();
  234. if (sumInsuRtnSettlInfo(joSetlinfo, out joSumFee, out errMsg) != 0)
  235. {
  236. outParam = "汇总结算结果失败,请联系管理员!" + errMsg;
  237. return -1;
  238. }
  239. joTmp.sumFeeObj = joSumFee;
  240. JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110020", joTmp).ToString(), "返回2303结算结果给HIS");
  241. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  242. {
  243. outParam = "返回2303结算结果给HIS失败,请联系管理员!" + errMsg;
  244. return -1;
  245. }
  246. else
  247. {
  248. outParam = joRtn.ToString();
  249. return 0;
  250. }
  251. }
  252. catch (Exception ex)
  253. {
  254. outParam = "返回2303结算结果给HIS出现异常:!" + ex.Message;
  255. return -1;
  256. }
  257. }
  258. //public int preSettlementInfo(JObject joParam, JObject joSetlinfo, out string outParam)
  259. //{
  260. // string errMsg;
  261. // try
  262. // {
  263. // dynamic joTmp = new JObject();
  264. // joTmp = joParam.DeepClone();
  265. // joTmp.insuPayInfo = joSetlinfo;
  266. // joTmp.updateUserID = Global.user.ID;
  267. // joTmp.middleSettleFlag = "";
  268. // JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110011", joTmp).ToString(), "返回2304结算结果给HIS");
  269. // if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  270. // {
  271. // outParam = "返回2303结算结果给HIS失败,请联系管理员!" + errMsg;
  272. // return -1;
  273. // }
  274. // else
  275. // {
  276. // outParam = joRtn.ToString();
  277. // return 0;
  278. // }
  279. // }
  280. // catch (Exception ex)
  281. // {
  282. // outParam = "返回2303结算结果给HIS出现异常:!" + ex.Message;
  283. // return -1;
  284. // }
  285. //}
  286. /// <summary>
  287. /// 返回住院结算信息给HIS
  288. /// </summary>
  289. /// <param name="joParam"></param>
  290. /// <param name="joSetlinfo"></param>
  291. /// <param name="outParam"></param>
  292. /// <returns></returns>
  293. public int returnInpatSettlementInfo(JObject joParam, JObject joSetlinfo, out string outParam)
  294. {
  295. string errMsg;
  296. try
  297. {
  298. dynamic joTmp = new JObject();
  299. joTmp = joParam.DeepClone();
  300. joTmp.insuPayInfo = joSetlinfo;
  301. joTmp.updateUserID = Global.user.ID;
  302. joTmp.middleSettleFlag = "";
  303. JObject joSumFee = new JObject();
  304. if (sumInsuRtnSettlInfo(joSetlinfo, out joSumFee, out errMsg) != 0)
  305. {
  306. outParam = "汇总结算结果失败,请联系管理员!" + errMsg;
  307. return -1;
  308. }
  309. joTmp.sumFeeObj = joSumFee;
  310. //JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110007", joTmp).ToString(), "返回2304结算结果给HIS");
  311. JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110017", joTmp).ToString(), "返回2304结算结果给HIS");
  312. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  313. {
  314. outParam = "返回2304结算结果给HIS失败,请联系管理员!" + errMsg;
  315. return -1;
  316. }
  317. else
  318. {
  319. outParam = joRtn.ToString();
  320. return 0;
  321. }
  322. }
  323. catch (Exception ex)
  324. {
  325. outParam = "返回2304结算结果给HIS出现异常:!" + ex.Message;
  326. return -1;
  327. }
  328. }
  329. /// <summary>
  330. /// 预结算后返回门诊结算信息给HIS,HIS进行预结算
  331. /// </summary>
  332. /// <param name="joSetlInpar"></param>
  333. /// <param name="joSetlinfo"></param>
  334. /// <param name="outParam"></param>
  335. /// <returns></returns>
  336. public int preSettlement(JObject joSetlInpar, JObject joSetlinfo, out string outParam)
  337. {
  338. string errMsg;
  339. try
  340. {
  341. JObject joSumFee = new JObject();
  342. if (sumInsuRtnSettlInfo(joSetlinfo, out joSumFee, out errMsg) != 0)
  343. {
  344. outParam = "汇总结算结果失败,请联系管理员!" + errMsg;
  345. return -1;
  346. }
  347. dynamic joTmp = new JObject();
  348. joTmp.settleInfo = joSetlinfo;
  349. joTmp.updateUserID = Global.user.ID;
  350. joTmp.regInfo = joSetlInpar;
  351. joTmp.middleSettleFlag = "";
  352. joTmp.interfaceDr = Global.inf.interfaceDr;
  353. dynamic joHisInfo = new JObject();
  354. joHisInfo.admID = Global.pat.adm_Dr;
  355. joHisInfo.billID = Global.pat.billID;
  356. joHisInfo.recordID = Global.pat.recordID;
  357. joTmp.hisInfo = joHisInfo;
  358. joTmp.psn_type = Global.pat.psn_type;
  359. joTmp.sumFeeObj = joSumFee;
  360. JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110019", joTmp).ToString(), "返回2206结算结果给HIS进行预结算");
  361. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  362. {
  363. outParam = "返回2206结算结果给HIS进行预结算失败,请联系管理员!" + errMsg;
  364. return -1;
  365. }
  366. else
  367. {
  368. outParam = joRtn.ToString();
  369. return 0;
  370. }
  371. }
  372. catch (Exception ex)
  373. {
  374. outParam = "返回2206结算结果给HIS进行预结算异常!" + ex.Message;
  375. return -1;
  376. }
  377. }
  378. /// <summary>
  379. /// 返回门诊结算信息给HIS
  380. /// </summary>
  381. /// <param name="joSetlInpar"></param>
  382. /// <param name="joSetlinfo"></param>
  383. /// <param name="outParam"></param>
  384. /// <returns></returns>
  385. public int returnOutpatSettlementInfo(JObject joSetlInpar, JObject joSetlinfo, out string outParam)
  386. {
  387. string errMsg;
  388. try
  389. {
  390. JObject joSumFee = new JObject();
  391. if (sumInsuRtnSettlInfo(joSetlinfo, out joSumFee, out errMsg) != 0)
  392. {
  393. outParam = "返回2207结算结果给HIS失败,请联系管理员!";
  394. return -1;
  395. }
  396. dynamic joTmp = new JObject();
  397. joTmp.settleInfo = joSetlinfo;
  398. joTmp.updateUserID = Global.user.ID;
  399. joTmp.regInfo = joSetlInpar;
  400. joTmp.middleSettleFlag = "";
  401. joTmp.interfaceDr = Global.inf.interfaceDr;
  402. dynamic joHisInfo = new JObject();
  403. joHisInfo.admID = Global.pat.adm_Dr;
  404. joHisInfo.billID = Global.pat.billID;
  405. joHisInfo.recordID = Global.pat.recordID;
  406. joTmp.hisInfo = joHisInfo;
  407. joTmp.psn_type = Global.pat.psn_type;
  408. joTmp.sumFeeObj = joSumFee;
  409. //0511018 {"feeObj":{"ybAmt":"医保支付","psnAcctAmt":"个人账户","psnCashAmt":"个人现金","hospAmt":"医院垫付"}}
  410. JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110018", joTmp).ToString(), "返回2207结算结果给HIS");
  411. //JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110009", joTmp).ToString(), "返回2207结算结果给HIS");
  412. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  413. {
  414. outParam = "返回2207结算结果给HIS失败,请联系管理员!" + errMsg;
  415. return -1;
  416. }
  417. else
  418. {
  419. outParam = joRtn.ToString();
  420. return 0;
  421. }
  422. }
  423. catch (Exception ex)
  424. {
  425. outParam = "返回22207结算结果给HIS出现异常:!" + ex.Message;
  426. return -1;
  427. }
  428. }
  429. /// <summary>
  430. /// 获取结算费用的封装
  431. /// </summary>
  432. /// <param name="jo"></param>
  433. /// <param name="path"></param>
  434. /// <returns></returns>
  435. private decimal getFee(JObject jo, string path)
  436. {
  437. try
  438. {
  439. string temp = JsonHelper.getDestValue(jo, path);
  440. if (temp == "")
  441. {
  442. return 0;
  443. }
  444. else
  445. {
  446. return decimal.Parse(temp);
  447. }
  448. }
  449. catch (Exception ex)
  450. {
  451. Global.writeLog("getFee异常:" + ex.Message);
  452. return 0;
  453. }
  454. }
  455. /// <summary>
  456. /// 汇总医保返回的结算金额(按照HIS的原则汇总,后期HIS按照这个来进行勾稽关系判断)
  457. /// </summary>
  458. /// <param name="jo"></param>
  459. /// <returns></returns>
  460. public int sumInsuRtnSettlInfo(JObject jo, out JObject joSumFee, out string errMsg)
  461. {
  462. // 医疗费总额是患者在医药机构花费的所有诊疗、药品、耗材、服务设施等项目费用的总和 = 基金支付总额 + 个人负担总金额 + 其他(如医院负担金额);
  463. //3、基金支付总额 = 基本医保统筹基金支出(含职工基本医疗保险、居民基本医疗保险)+补充医疗保险基金支出 (含覆盖全体参保人的居民大病保险和大额医疗费用补助、覆盖部分参保人的企业职工大额医疗费用补助和公务员医疗补助等)+医疗救助基金支出 + 其他支出(如伤残人员医疗保障基金支出);
  464. //5、个人账户支出中包含账户共济支付金额
  465. joSumFee = new JObject();
  466. errMsg = "";
  467. decimal ybAmt, psnAcctAmt, hospAmt, psnCashAmt, medFee;
  468. try
  469. {
  470. ybAmt = getFee(jo, "hifp_pay") //基本医保统筹基金支出
  471. + getFee(jo, "hifes_pay") //企业补充医疗保险基金支出
  472. + getFee(jo, "hifmi_pay") //居民大病保险
  473. //+ getFee(jo, "hifob_pay") //大额医疗费用补助
  474. + getFee(jo, "hifob_pay") //职工大额医疗费用补助
  475. + getFee(jo, "cvlserv_pay") //公务员医疗补助
  476. + getFee(jo, "maf_pay") //医疗救助基金支出
  477. + getFee(jo, "oth_pay"); //其他支出
  478. psnAcctAmt = getFee(jo, "acct_pay"); //账户支付金额
  479. psnCashAmt = getFee(jo, "psn_cash_pay"); //现金支付金额
  480. hospAmt = getFee(jo, "hosp_part_amt"); //医院承担金额
  481. medFee = getFee(jo, "medfee_sumamt"); //总费用
  482. joSumFee.Add("ybAmt", ybAmt);
  483. joSumFee.Add("psnAcctAmt", psnAcctAmt);
  484. joSumFee.Add("hospAmt", hospAmt);
  485. joSumFee.Add("psnCashAmt", psnCashAmt);
  486. if (medFee != (ybAmt + psnAcctAmt + psnCashAmt + hospAmt))
  487. {
  488. errMsg = "ybAmt + psnAcctAmt + psnCashAmt + hospAmt != medFee";
  489. return -1;
  490. }
  491. return 0;
  492. }
  493. catch (Exception ex)
  494. {
  495. errMsg = ex.Message;
  496. return 1;
  497. }
  498. }
  499. /// <summary>
  500. /// 取消结算信息
  501. /// </summary>
  502. /// <param name="joParam"></param>
  503. /// <param name="outParam"></param>
  504. /// <returns></returns>
  505. public int cancleSettlementInfo(JObject joParam, out string outParam)
  506. {
  507. string errMsg;
  508. try
  509. {
  510. dynamic joTmp = new JObject();
  511. joTmp = joParam.DeepClone();
  512. joTmp.updateUserID = Global.user.ID;
  513. joTmp.middleSettleFlag = "";
  514. JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110008", joTmp).ToString(), "取消HIS医保结算信息");
  515. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  516. {
  517. outParam = "取消HIS医保结算信息失败,请联系管理员!" + errMsg;
  518. return -1;
  519. }
  520. else
  521. {
  522. outParam = "取消HIS医保结算信息成功";
  523. return 0;
  524. }
  525. }
  526. catch (Exception ex)
  527. {
  528. outParam = "返回2304结算结果给HIS出现异常:!" + ex.Message;
  529. return -1;
  530. }
  531. }
  532. public int getHISDir(JArray jaPagination, JArray jaParams, out JObject joRtn, out string outParam)
  533. {
  534. string errMsg;
  535. joRtn = new JObject();
  536. try
  537. {
  538. dynamic joTmp = new JObject();
  539. joTmp.pagination = jaPagination;
  540. joTmp.session = Global.curEvt.jaSession;
  541. joTmp.Add("params",jaParams);
  542. joTmp.code = "05111002";
  543. joRtn = invoker.invokeHISService(joTmp.ToString(), "查询HIS目录分页");
  544. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  545. {
  546. outParam = "查询HIS目录分页失败,请联系管理员!" + errMsg;
  547. return -1;
  548. }
  549. else
  550. {
  551. if (joRtn["result"]["Data"] == null)
  552. {
  553. outParam = "Data节点不存在";
  554. return -1;
  555. }
  556. outParam = "查询HIS目录分页成功";
  557. return 0;
  558. }
  559. }
  560. catch (Exception ex)
  561. {
  562. outParam = "查询HIS目录分页异常:!" + ex.Message;
  563. return -1;
  564. }
  565. }
  566. /// <summary>
  567. /// 从HIS获取医保事前事中服务交易入参报文
  568. /// </summary>
  569. /// <param name="pat"></param>
  570. /// <param name="errMsg"></param>
  571. /// <returns></returns>
  572. public int GetInsuPatInfo(string TrigScen, Patients pat, out string outParam)
  573. {
  574. outParam = "";
  575. string errMsg;
  576. try
  577. {
  578. dynamic joIrisParam = new JObject();
  579. JArray jaIrisParams = new JArray();
  580. JObject joIrisTmp = new JObject();
  581. joIrisParam.code = "05110015";
  582. joIrisParam.session = Global.curEvt.jaSession;
  583. joIrisTmp.Add("admID", pat.adm_Dr);
  584. joIrisTmp.Add("billID", pat.billID);
  585. joIrisTmp.Add("recordID", pat.recordID);
  586. joIrisTmp.Add("userID",Global.user.ID);
  587. joIrisTmp.Add("hospID", Global.inf.hisHospitalDr);
  588. joIrisTmp.Add("psnNo", Global.pat.psn_no);
  589. joIrisTmp.Add("mdtrtId", Global.pat.mdtrtID);
  590. joIrisTmp.Add("InsuredType", Global.pat.insuType);
  591. joIrisTmp.Add("MedicalType", Global.pat.medType);
  592. joIrisTmp.Add("YBArea", Global.pat.insuplc_admdvs);
  593. joIrisTmp.Add("TrigScen", TrigScen);
  594. joIrisTmp.Add("InterfaceID", Global.inf.interfaceDr);
  595. jaIrisParams.Add(joIrisTmp);
  596. joIrisParam.Add("params", JArray.FromObject(jaIrisParams));
  597. JObject joRtn = invoker.invokeHISService(joIrisParam.ToString(), "获取HIS费用");
  598. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  599. {
  600. outParam = errMsg;
  601. return -1;
  602. }
  603. else
  604. {
  605. outParam = joRtn.ToString();
  606. return 0;
  607. }
  608. }
  609. catch (Exception ex)
  610. {
  611. outParam = "GetInsuPatInfo医保事前事中服务报文获取 异常:" + ex.Message;
  612. return -1;
  613. }
  614. }
  615. }
  616. class MIIrisServices
  617. {
  618. private InvokeHelper invoker = new InvokeHelper();
  619. /// <summary>
  620. /// 获取接口信息
  621. /// </summary>
  622. /// <returns></returns>
  623. public JObject getInterface()
  624. {
  625. dynamic joParam = new JObject();
  626. joParam.HospitalDr = Global.inf.hospitalDr;
  627. joParam.InterfaceID = "";
  628. JObject joInparam = JsonHelper.setIrisInpar("09010003", joParam);
  629. InvokeHelper invoker = new InvokeHelper();
  630. return invoker.invokeInsuService(joInparam.ToString(), "获取接口信息");
  631. }
  632. public JObject getInterface(string interfaceID)
  633. {
  634. dynamic joParam = new JObject();
  635. joParam.HospitalDr = Global.inf.hospitalDr;
  636. joParam.InterfaceID = interfaceID;
  637. JObject joInparam = JsonHelper.setIrisInpar("09010003", joParam);
  638. InvokeHelper invoke = new InvokeHelper();
  639. JObject joRtn = invoke.invokeInsuService(joInparam.ToString(), "获取接口信息");
  640. JObject joInterfaceInfo = JObject.Parse(JsonHelper.getDestValue(joRtn, "result.data[0]"));
  641. joInterfaceInfo.Add("operatorNO", "0");
  642. joInterfaceInfo.Add("operatorName", "管理员");
  643. return joInterfaceInfo;
  644. }
  645. public JObject getInterface_TY(string interfaceID,string hospitalDr)
  646. {
  647. dynamic joParam = new JObject();
  648. joParam.HospitalDr = hospitalDr;
  649. joParam.InterfaceID = interfaceID;
  650. JObject joInparam = JsonHelper.setIrisInpar("09010003", joParam);
  651. InvokeHelper invoke = new InvokeHelper();
  652. JObject joRtn = invoke.invokeInsuService(joInparam.ToString(), "获取接口信息");
  653. JObject joInterfaceInfo = JObject.Parse(JsonHelper.getDestValue(joRtn, "result.data[0]"));
  654. joInterfaceInfo.Add("operatorNO", "0");
  655. joInterfaceInfo.Add("operatorName", "管理员");
  656. return joInterfaceInfo;
  657. }
  658. /// <summary>
  659. /// 判断是否签到过,如果未签到,返回false,如果签到则返回ture,同时返回签到号
  660. /// </summary>
  661. /// <param name="signno"></param>
  662. /// <returns></returns>
  663. public bool isSigned(ref string signno)
  664. {
  665. JObject joIn = new JObject();
  666. joIn.Add("operatorNO", Global.user.ID.ToUpper());
  667. joIn.Add("operatorName", Global.user.name);
  668. joIn.Add("mac", Global.curEvt.mac);
  669. joIn.Add("ip", Global.curEvt.ip);
  670. joIn.Add("hospitalDr", Global.inf.hospitalDr);
  671. joIn.Add("interfaceDr", Global.inf.interfaceDr);
  672. joIn.Add("date", DateTime.Now.ToString("yyyy-MM-dd"));
  673. string data = JsonHelper.setIrisInpar("09010064", joIn).ToString();
  674. JObject joRtn = invoker.invokeInsuService(data, "查询签到信息");
  675. string errMsg = "";
  676. //MessageBox.Show("查询签到信息:"+joRtn.ToString());
  677. if (JsonHelper.parseIrisRtnValue(joRtn,out errMsg)!= 0)
  678. {
  679. signno = "";
  680. return false;
  681. }
  682. else
  683. {
  684. signno = JsonHelper.getDestValue(joRtn, "result.SignNo");
  685. return true;
  686. }
  687. }
  688. /// <summary>
  689. ///保存签到信息
  690. /// </summary>
  691. /// <param name="signno"></param>
  692. /// <returns></returns>
  693. public int saveSignRecord( string signno,out string errMsg)
  694. {
  695. if (signno == "")
  696. {
  697. errMsg = "signno不能为空!";
  698. return -1;
  699. }
  700. errMsg = ""; ;
  701. JObject joIn = new JObject();
  702. joIn.Add("operatorNO", Global.user.ID);
  703. joIn.Add("operatorName", Global.user.name);
  704. joIn.Add("mac", Global.curEvt.mac);
  705. joIn.Add("ip", Global.curEvt.ip);
  706. joIn.Add("hospitalDr", Global.inf.hospitalDr);
  707. joIn.Add("interfaceDr", Global.inf.interfaceDr);
  708. joIn.Add("date", DateTime.Now.ToString("yyyy-MM-dd"));
  709. joIn.Add("signNo", signno);
  710. joIn.Add("createTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  711. joIn.Add("division", Global.inf.areaCode);
  712. string data = JsonHelper.setIrisInpar("09010065", joIn).ToString();
  713. //MessageBox.Show("插入签到信息入参:"+ data);
  714. JObject joRtn = invoker.invokeInsuService(data, "插入签到信息");
  715. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  716. {
  717. return -1;
  718. }
  719. else
  720. {
  721. return 0;
  722. }
  723. }
  724. /// <summary>
  725. /// 保存住院登记信息
  726. /// </summary>
  727. /// <param name="joRegIn"></param>
  728. /// <param name="joRegOut"></param>
  729. /// <param name="outParam"></param>
  730. /// <returns></returns>
  731. public int saveInpatRegisterInfo(JObject joRegInOld,JObject joRegOut,out string outParam)
  732. {
  733. //插入云医保平台
  734. JObject joTmp = new JObject();
  735. string errMsg = "";
  736. try
  737. {
  738. JObject joRegIn = Utils.removeWrapper(joRegInOld);
  739. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  740. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  741. joTmp.Add("AdmDr", Global.pat.adm_Dr);
  742. joTmp.Add("PatientName", Global.pat.name);
  743. joTmp.Add("PersonalNO", Global.pat.psn_no);
  744. joTmp.Add("InsuRegID", JsonHelper.getDestValue(joRegOut, "output.result.mdtrt_id"));
  745. joTmp.Add("RegDate", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.begntime"));
  746. joTmp.Add("InsuType", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.insutype"));
  747. joTmp.Add("CertificateType", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.mdtrt_cert_type"));
  748. joTmp.Add("CertificateNO", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.mdtrt_cert_no"));
  749. joTmp.Add("MedicalType", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.med_type"));
  750. joTmp.Add("AttendDoctorNO", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.atddr_no"));
  751. joTmp.Add("ChiefPhyDocName", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.chfpdr_name"));
  752. joTmp.Add("AdmInDiagDesc", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.adm_diag_dscr"));
  753. joTmp.Add("AdmInDepCode", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.adm_dept_codg"));
  754. joTmp.Add("AdmInDepName", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.adm_dept_name"));
  755. joTmp.Add("AdmBed", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.adm_bed"));
  756. joTmp.Add("MainDiagCode", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.dscg_maindiag_code"));
  757. joTmp.Add("MainDiagName", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.dscg_maindiag_name"));
  758. joTmp.Add("MainConditionDesc", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.main_cond_dscr"));
  759. joTmp.Add("DiseasecCode", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.dise_codg"));
  760. joTmp.Add("DiseasecName", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.dise_name"));
  761. joTmp.Add("OperationCode", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.oprn_oprt_code"));
  762. joTmp.Add("OperationName", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.oprn_oprt_name"));
  763. joTmp.Add("DiseasecTypeCode", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.dise_type_code"));
  764. joTmp.Add("InsuranceAreaCode", Global.pat.insuplc_admdvs);
  765. joTmp.Add("TreatmentAreaCode", Global.pat.mdtrtarea_admvs);
  766. joTmp.Add("RegState", JsonHelper.getDestValue(joRegOut, "regstate"));
  767. joTmp.Add("ValidFlag", JsonHelper.getDestValue(joRegOut, "validflag"));
  768. joTmp.Add("Type", JsonHelper.getDestValue(joRegOut, "type"));
  769. joTmp.Add("updateUserID", Global.user.ID);
  770. joTmp.Add("MSGID", Global.curEvt.msgid);
  771. joTmp.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  772. joTmp.Add("ConerName", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.coner_name"));
  773. joTmp.Add("Tel", JsonHelper.getDestValue(joRegIn, "input.mdtrtinfo.tel"));
  774. joTmp.Add("ExpContent", Global.pat.ExpContent);
  775. string serviceCode = "09010044";
  776. string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString();
  777. JObject joRtn = invoker.invokeInsuService(inpar, "新增住院登记信息");
  778. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  779. {
  780. outParam = joRtn.ToString();
  781. return -1;
  782. }
  783. else
  784. {
  785. outParam = joRtn.ToString();
  786. return 0;
  787. }
  788. }
  789. catch (Exception ex)
  790. {
  791. outParam = "保存住院登记信息异常:" + ex.Message;
  792. return -1;
  793. }
  794. }
  795. /// <summary>
  796. /// 保存门诊登记信息
  797. /// </summary>
  798. /// <param name="jo2201Inpar"></param>
  799. /// <param name="jo2201Rtn"></param>
  800. /// <param name="jo2203Inpar"></param>
  801. /// <param name="outParam"></param>
  802. /// <returns></returns>
  803. public int saveOutpatRegisterInfo(JObject jo2201InparOld, JObject jo2201Rtn,JObject jo2203InparOld, out string outParam)
  804. {
  805. //插入云医保平台
  806. JObject joTmp = new JObject();
  807. string errMsg = "";
  808. try
  809. {
  810. // 转换
  811. JObject jo2201Inpar = Utils.removeWrapper(jo2201InparOld);
  812. JObject jo2203Inpar = Utils.removeWrapper(jo2203InparOld);
  813. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  814. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  815. joTmp.Add("AdmDr", Global.pat.adm_Dr);
  816. joTmp.Add("PatientName", Global.pat.name);
  817. joTmp.Add("PersonalNO", Global.pat.psn_no);
  818. joTmp.Add("InsuRegID", JsonHelper.getDestValue(jo2201Rtn, "output.data.mdtrt_id"));
  819. joTmp.Add("RegDate", JsonHelper.getDestValue(jo2201Inpar, "input.data.begntime"));
  820. joTmp.Add("InsuType", JsonHelper.getDestValue(jo2201Inpar, "input.data.insutype"));
  821. joTmp.Add("CertificateType", JsonHelper.getDestValue(jo2201Inpar, "input.data.mdtrt_cert_type"));
  822. joTmp.Add("CertificateNO", JsonHelper.getDestValue(jo2201Inpar, "input.data.mdtrt_cert_no"));
  823. joTmp.Add("MedicalType", JsonHelper.getDestValue(jo2203Inpar, "input.mdtrtinfo.med_type"));
  824. joTmp.Add("AttendDoctorNO", JsonHelper.getDestValue(jo2201Inpar, "input.data.atddr_no"));
  825. joTmp.Add("ChiefPhyDocName", JsonHelper.getDestValue(jo2201Inpar, "input.data.dr_name"));
  826. joTmp.Add("AdmInDiagDesc", JsonHelper.getDestValue(jo2203Inpar, "input.mdtrtinfo.main_cond_dscr"));
  827. joTmp.Add("AdmInDepCode", JsonHelper.getDestValue(jo2201Inpar, "input.data.dept_code"));
  828. joTmp.Add("AdmInDepName", JsonHelper.getDestValue(jo2201Inpar, "input.data.dept_name"));
  829. joTmp.Add("AdmBed", "");
  830. joTmp.Add("MainDiagCode", " ");
  831. joTmp.Add("MainDiagName", " ");
  832. joTmp.Add("MainConditionDesc", JsonHelper.getDestValue(jo2203Inpar, "input.mdtrtinfo.main_cond_dscr"));
  833. joTmp.Add("DiseasecCode", JsonHelper.getDestValue(jo2203Inpar, "input.mdtrtinfo.dise_codg"));
  834. joTmp.Add("DiseasecName", JsonHelper.getDestValue(jo2203Inpar, "input.mdtrtinfo.dise_name"));
  835. joTmp.Add("OperationCode", "");
  836. joTmp.Add("OperationName", "");
  837. joTmp.Add("DiseasecTypeCode", "");
  838. joTmp.Add("InsuranceAreaCode", Global.pat.insuplc_admdvs);
  839. joTmp.Add("TreatmentAreaCode", Global.pat.mdtrtarea_admvs);
  840. joTmp.Add("RegState", JsonHelper.getDestValue(jo2201Rtn, "regstate"));
  841. joTmp.Add("ValidFlag", JsonHelper.getDestValue(jo2201Rtn, "validflag"));
  842. joTmp.Add("Type", JsonHelper.getDestValue(jo2201Rtn, "type"));
  843. joTmp.Add("updateUserID", Global.user.ID);
  844. joTmp.Add("msgid", Global.curEvt.msgid);
  845. joTmp.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  846. joTmp.Add("ExpContent", Global.pat.ExpContent);
  847. string serviceCode = "09010044";
  848. string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString();
  849. JObject joRtn = invoker.invokeInsuService(inpar, "新增门诊登记信息");
  850. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  851. {
  852. outParam = joRtn.ToString();
  853. return -1;
  854. }
  855. else
  856. {
  857. outParam = joRtn.ToString();
  858. return 0;
  859. }
  860. }
  861. catch (Exception ex)
  862. {
  863. outParam = "保存门诊登记信息异常:" + ex.Message;
  864. return -1;
  865. }
  866. }
  867. /// <summary>
  868. /// 取消登记
  869. /// </summary>
  870. /// <param name="type"></param>
  871. /// <param name="outParam"></param>
  872. /// <returns></returns>
  873. public int cancleRegister(int type,out string outParam)
  874. {
  875. outParam = "";
  876. string errMsg;
  877. try
  878. {
  879. dynamic joTmp = new JObject();
  880. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  881. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  882. joTmp.Add("AdmDr", Global.pat.adm_Dr);
  883. joTmp.Add("PersonalNO",Global.pat.psn_no);
  884. joTmp.Add("InsuRegID", Global.pat.mdtrtID);
  885. joTmp.Add("CancleRegDate", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  886. joTmp.Add("Type", type);
  887. joTmp.Add("ValidFlag", -1);
  888. joTmp.Add("updateUserID", Global.user.ID);
  889. string serviceCode = "09010044";
  890. string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString();
  891. JObject joRtn = invoker.invokeInsuService(inpar, "取消云医保平台登记信息");
  892. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  893. {
  894. outParam = "退结算失败,请根据输入条件检查是否存在该笔数据!" + errMsg;
  895. return -1;
  896. }
  897. else
  898. {
  899. outParam = joRtn.ToString();
  900. return 0;
  901. }
  902. }
  903. catch (Exception ex)
  904. {
  905. outParam = "取消登记异常" + ":" + ex.Message;
  906. return -1;
  907. }
  908. }
  909. /// <summary>
  910. /// 删除费用明细
  911. /// </summary>
  912. /// <param name="pat"></param>
  913. /// <param name="errMsg"></param>
  914. /// <returns></returns>
  915. public int deleteFee(out string errMsg)
  916. {
  917. try
  918. {
  919. dynamic joTmp = new JObject();
  920. joTmp = new JObject();
  921. joTmp.code = "09010048";
  922. joTmp.HospitalDr = Global.inf.hospitalDr;
  923. joTmp.admID = Global.pat.adm_Dr;
  924. joTmp.mdtrt_id = Global.pat.mdtrtID;
  925. joTmp.updateUserID = Global.user.ID;
  926. JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "删除2301明细");
  927. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  928. {
  929. return -1;
  930. }
  931. else
  932. {
  933. return 0;
  934. }
  935. }
  936. catch (Exception ex)
  937. {
  938. errMsg = "deleteFee 异常:" + ex.Message;
  939. return -1;
  940. }
  941. }
  942. /// <summary>
  943. /// 根据HIS的费用明细获取对照关系
  944. /// </summary>
  945. /// <returns></returns>
  946. public int convertHisFeeWithInsuCode( JObject joHisFee, out string outParam)
  947. {
  948. outParam = "";
  949. string errMsg;
  950. try
  951. {
  952. JArray jaFee = JArray.FromObject(joHisFee["result"]);
  953. //var filtered = jaFeef.Where(jObject => jObject["det_item_fee_sumamt"].ToString()!="0.00");//过滤总费用为0的费用明细
  954. // 将过滤后的JArray转换回JSON字符串
  955. // JArray jaFee = JArray.Parse(filtered.ToString());
  956. JObject joTmp = JsonHelper.setIrisInpar("09010045", jaFee);
  957. joTmp.Add("mdtrt_id", Global.pat.mdtrtID);
  958. joTmp.Add("med_type", Global.pat.medType);
  959. joTmp.Add("psn_no", Global.pat.psn_no);
  960. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  961. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  962. JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "根据HIS的费用明细获取对照关系");
  963. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  964. {
  965. outParam = errMsg;
  966. return -1;
  967. }
  968. else
  969. {
  970. outParam = joRtn.ToString();
  971. return 0;
  972. }
  973. }
  974. catch (Exception ex)
  975. {
  976. outParam = "convertHisFeeWithInsuCode 异常:" + ex.Message;
  977. return -1;
  978. }
  979. }
  980. /// <summary>
  981. /// 插入医保费用
  982. /// </summary>
  983. /// <param name="jaTmp"></param>
  984. /// <param name="outParam"></param>
  985. /// <returns></returns>
  986. public int insertFee(JArray jaTmp,out string outParam)
  987. {
  988. try
  989. {
  990. outParam = "";
  991. string errMsg;
  992. dynamic joTmp = new JObject();
  993. joTmp = new JObject();
  994. joTmp.code = "09010046";
  995. joTmp.HospitalDr = Global.inf.hospitalDr;
  996. joTmp.admID = Global.pat.adm_Dr;
  997. joTmp.mdtrt_id = Global.pat.mdtrtID;
  998. joTmp.updateUserID = Global.user.ID;
  999. joTmp.Add("params", jaTmp);
  1000. ;
  1001. JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "插入2301明细");
  1002. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1003. {
  1004. outParam = errMsg;
  1005. return -1;
  1006. }
  1007. else
  1008. {
  1009. outParam = joRtn.ToString();
  1010. return 0;
  1011. }
  1012. }
  1013. catch (Exception ex)
  1014. {
  1015. outParam = "insertFee 异常:" + ex.Message;
  1016. return -1;
  1017. }
  1018. }
  1019. /// <summary>
  1020. /// 更新医保费用
  1021. /// </summary>
  1022. /// <param name="jaTmp"></param>
  1023. /// <param name="outParam"></param>
  1024. /// <returns></returns>
  1025. public int updateFee(JArray jaTmp, out string outParam)
  1026. {
  1027. try
  1028. {
  1029. outParam = "";
  1030. string errMsg;
  1031. dynamic joTmp = new JObject();
  1032. joTmp.code = "09010047";
  1033. JArray jaParams = jaTmp;
  1034. joTmp.Add("params", jaParams);
  1035. joTmp.HospitalDr = Global.inf.hospitalDr;
  1036. joTmp.admID = Global.pat.adm_Dr;
  1037. joTmp.mdtrt_id = Global.pat.mdtrtID;
  1038. joTmp.updateUserID =Global.user.ID;
  1039. JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "更新2301明细");
  1040. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1041. {
  1042. outParam = errMsg;
  1043. return -1;
  1044. }
  1045. else
  1046. {
  1047. outParam = joRtn.ToString();
  1048. return 0;
  1049. }
  1050. }
  1051. catch (Exception ex)
  1052. {
  1053. outParam = "updateFee 异常:" + ex.Message;
  1054. return -1;
  1055. }
  1056. }
  1057. /// <summary>
  1058. /// 获取各项费用汇总
  1059. /// </summary>
  1060. /// <param name="outParam"></param>
  1061. /// <returns></returns>
  1062. public int getSumFee(out string outParam)
  1063. {
  1064. try
  1065. {
  1066. outParam = "";
  1067. string errMsg;
  1068. //调用IRIS获取医保各项金额
  1069. dynamic joTmp = new JObject();
  1070. joTmp = new JObject();
  1071. joTmp.code = "09010049";
  1072. joTmp.HospitalDr = Global.inf.hospitalDr;
  1073. joTmp.admID = Global.pat.adm_Dr;
  1074. joTmp.mdtrt_id = Global.pat.mdtrtID;
  1075. joTmp.updateUserID = Global.user.ID; ;
  1076. JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "获取各项费用汇总"); ;
  1077. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1078. {
  1079. outParam = errMsg;
  1080. return -1;
  1081. }
  1082. else
  1083. {
  1084. outParam = joRtn.ToString();
  1085. return 0;
  1086. }
  1087. }
  1088. catch (Exception ex)
  1089. {
  1090. outParam = "getSumFee 异常:" + ex.Message;
  1091. return -1;
  1092. }
  1093. }
  1094. /// <summary>
  1095. /// 转换结算信息
  1096. /// </summary>
  1097. /// <param name="pat"></param>
  1098. /// <param name="joSettlement"></param>
  1099. /// <param name="outParam"></param>
  1100. /// <returns></returns>
  1101. public int convertSettlementWithInsuCode(JObject joSettlement, out string outParam)
  1102. {
  1103. outParam = "";
  1104. string errMsg;
  1105. try
  1106. {
  1107. JObject joOutput = JObject.FromObject(joSettlement["output"]);
  1108. //编码转换
  1109. JObject joInpar = new JObject();
  1110. joInpar.Add("hospitalDr", Global.inf.hospitalDr);
  1111. joInpar.Add("interfaceDr", Global.inf.interfaceDr);
  1112. joInpar.Add("output", joOutput);
  1113. InvokeHelper invoker = new InvokeHelper();
  1114. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010055", joInpar).ToString(), "结算信息编码转换");
  1115. if (JsonHelper.getDestValue(joRtn, "errorCode") != "")
  1116. {
  1117. outParam = JsonHelper.getDestValue(joRtn, "errorMessage");
  1118. return -1;
  1119. }
  1120. else
  1121. {
  1122. outParam = joRtn.ToString();
  1123. return 0;
  1124. }
  1125. }
  1126. catch (Exception ex)
  1127. {
  1128. outParam = "convertSettlementWithInsuCode 异常:" + ex.Message;
  1129. return -1;
  1130. }
  1131. }
  1132. /// <summary>
  1133. /// 根据HIS的费用明细获取对照关系
  1134. /// </summary>
  1135. /// <returns></returns>
  1136. public int convertHisFeeWithInsuCodeOfMobilePay(Patients pat, JObject joHisFee, out string outParam)
  1137. {
  1138. outParam = "";
  1139. string errMsg;
  1140. try
  1141. {
  1142. JArray jaFee = JArray.FromObject(joHisFee["result"]);
  1143. JObject joTmp = JsonHelper.setIrisInpar("09010086", jaFee);
  1144. joTmp.Add("mdtrt_id", pat.mdtrtID);
  1145. joTmp.Add("med_type", pat.medType);
  1146. joTmp.Add("psn_no", pat.psn_no);
  1147. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  1148. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  1149. JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "根据HIS的费用明细获取对照关系");
  1150. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1151. {
  1152. outParam = errMsg;
  1153. return -1;
  1154. }
  1155. else
  1156. {
  1157. outParam = joRtn.ToString();
  1158. return 0;
  1159. }
  1160. }
  1161. catch (Exception ex)
  1162. {
  1163. outParam = " convertHisFeeWithInsuCodeOfMobilePay异常:" + ex.Message;
  1164. return -1;
  1165. }
  1166. }
  1167. /// <summary>
  1168. /// 插入结算信息
  1169. /// </summary>
  1170. /// <param name="joSettlement"></param>
  1171. /// <param name="outParam"></param>
  1172. /// <returns></returns>
  1173. public int saveSettlement(JObject joSettlement, out string outParam)
  1174. {
  1175. JObject joTmp = new JObject();
  1176. string errMsg = "";
  1177. try
  1178. {
  1179. JObject joSetlinfo = JObject.Parse(JsonHelper.getDestValue(joSettlement, "output.setlinfo"));
  1180. // 异常值转换
  1181. Utils.convertTimestamp(joSetlinfo, "brdy");
  1182. Utils.convertTimestamp(joSetlinfo, "setl_time");
  1183. joSetlinfo.Add("HospitalDr", Global.inf.hospitalDr);
  1184. joSetlinfo.Add("admID", Global.pat.adm_Dr);
  1185. joSetlinfo.Add("ValidFlag", 1);
  1186. joSetlinfo.Add("BillType", 1);
  1187. joSetlinfo.Add("updateUserID",Global.user.ID);
  1188. joSetlinfo.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  1189. joSetlinfo.Add("billID", Global.pat.billID);
  1190. joSetlinfo.Add("recordID", Global.pat.recordID);
  1191. joSetlinfo.Add("msgid", Global.curEvt.msgid);
  1192. joSetlinfo.Add("interfaceDr", Global.inf.interfaceDr);
  1193. joSetlinfo.Add("admType", Global.pat.admType);
  1194. joSetlinfo.Add("insuplc_admdvs", Global.pat.insuplc_admdvs);
  1195. joSetlinfo.Add("ExpContent", Global.pat.ExpContent);
  1196. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010051", joSetlinfo).ToString(), "插入结算信息");
  1197. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1198. {
  1199. outParam = errMsg;
  1200. return -1;
  1201. }
  1202. else
  1203. {
  1204. outParam = joRtn.ToString();
  1205. return 0;
  1206. }
  1207. }
  1208. catch (Exception ex)
  1209. {
  1210. outParam = "插入结算信息:" + ex.Message;
  1211. return -1;
  1212. }
  1213. }
  1214. /// <summary>
  1215. /// 保存结算信息
  1216. /// </summary>
  1217. /// <param name="joSettlement"></param>
  1218. /// <param name="outParam"></param>
  1219. /// <returns></returns>
  1220. public int saveSettlementDetail(JObject joSettlement, out string outParam)
  1221. {
  1222. JObject joTmp = new JObject();
  1223. string errMsg = "";
  1224. try
  1225. {
  1226. JObject joSetlDetail = new JObject();
  1227. joSetlDetail.Add("HospitalDr", Global.inf.hospitalDr);
  1228. joSetlDetail.Add("InterfaceDr", Global.inf.interfaceDr);
  1229. joSetlDetail.Add("MdtrtID", Global.pat.mdtrtID);
  1230. joSetlDetail.Add("SettlementID", JsonHelper.getDestValue(joSettlement, "output.setlinfo.setl_id"));
  1231. joSetlDetail.Add("AdmID", Global.pat.adm_Dr);
  1232. joSetlDetail.Add("updateUserID", Global.user.ID);
  1233. if (JsonHelper.getDestValue(joSettlement, "output.setldetail") == "")
  1234. {
  1235. outParam = "中心返回结算明细为空!";
  1236. Global.writeLog(outParam);
  1237. return 0;
  1238. }
  1239. JArray jaSetlDetail = JArray.Parse(JsonHelper.getDestValue(joSettlement, "output.setldetail"));
  1240. joSetlDetail.Add("setldetail", jaSetlDetail);
  1241. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010056", joSetlDetail).ToString(), "插入结算明细信息");
  1242. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1243. {
  1244. outParam = errMsg;
  1245. return -1;
  1246. }
  1247. else
  1248. {
  1249. outParam = joRtn.ToString();
  1250. return 0;
  1251. }
  1252. }
  1253. catch (Exception ex)
  1254. {
  1255. outParam = "插入结算信息:" + ex.Message;
  1256. return -1;
  1257. }
  1258. }
  1259. /// <summary>
  1260. /// 取消结算
  1261. /// </summary>
  1262. /// <param name="outParam"></param>
  1263. /// <returns></returns>
  1264. public int cancleSettlement(string newSettlID, out string outParam)
  1265. {
  1266. JObject joTmp = new JObject();
  1267. string errMsg = "";
  1268. try
  1269. {
  1270. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  1271. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  1272. joTmp.Add("admID", Global.pat.adm_Dr);
  1273. joTmp.Add("mdtrt_id", Global.pat.mdtrtID);
  1274. joTmp.Add("setl_id", Global.pat.settlID);
  1275. joTmp.Add("new_setl_id", newSettlID);
  1276. joTmp.Add("updateUserID", Global.user.ID);
  1277. joTmp.Add("msgid", Global.curEvt.msgid);
  1278. joTmp.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  1279. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010052", joTmp).ToString(), "取消结算信息");
  1280. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1281. {
  1282. outParam = errMsg;
  1283. return -1;
  1284. }
  1285. else
  1286. {
  1287. outParam = joRtn.ToString();
  1288. return 0;
  1289. }
  1290. }
  1291. catch (Exception ex)
  1292. {
  1293. outParam = "取消结算信息:" + ex.Message;
  1294. return -1;
  1295. }
  1296. }
  1297. public JObject DynamicQuerySettlInfo(JObject joSqlStr)
  1298. {
  1299. try
  1300. {
  1301. InvokeHelper invoker = new InvokeHelper();
  1302. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010081", joSqlStr).ToString(), "动态查询结算信息");
  1303. return joRtn;
  1304. }
  1305. catch (Exception ex)
  1306. {
  1307. return JsonHelper.setExceptionJson(-1, "查询结算信息异常:", ex.Message);
  1308. }
  1309. }
  1310. /// <summary>
  1311. /// 查询登记信息
  1312. /// </summary>
  1313. /// <param name="type"></param>
  1314. /// <param name="outParam"></param>
  1315. /// <returns></returns>
  1316. public int queryRegisterInfo(int type,out string outParam)
  1317. {
  1318. JObject joTmp = new JObject();
  1319. string errMsg = "";
  1320. try
  1321. {
  1322. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  1323. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  1324. joTmp.Add("admID", Global.pat.adm_Dr);
  1325. joTmp.Add("mdtrt_id", Global.pat.mdtrtID);
  1326. joTmp.Add("type", type);
  1327. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010050", joTmp).ToString(), "查询云平台患者登记信息");
  1328. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1329. {
  1330. outParam = errMsg;
  1331. return -1;
  1332. }
  1333. else
  1334. {
  1335. outParam = joRtn.ToString();
  1336. return 0;
  1337. }
  1338. }
  1339. catch (Exception ex)
  1340. {
  1341. outParam = "查询云平台患者登记信息:" + ex.Message;
  1342. return -1;
  1343. }
  1344. }
  1345. /// <summary>
  1346. /// 插入患者该次就诊参保信息
  1347. /// </summary>
  1348. /// <param name="joBaseInfo"></param>
  1349. /// <param name="joInsuInfo"></param>
  1350. /// <param name="joIdetInfo"></param>
  1351. /// <param name="outParam"></param>
  1352. /// <returns></returns>
  1353. public int insertPatCurInsuInfo(JObject joBaseInfo, JObject joInsuInfo, JObject joIdetInfo, out string outParam)
  1354. {
  1355. JObject joTmp = new JObject();
  1356. string errMsg = "";
  1357. try
  1358. {
  1359. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  1360. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  1361. joTmp.Add("AdmID", Global.pat.adm_Dr);
  1362. joTmp.Add("PatientName", Global.pat.name);
  1363. joTmp.Add("PersonalNO", Global.pat.psn_no);
  1364. joTmp.Add("MdtrtID", Global.pat.mdtrtID);
  1365. joTmp.Add("PsnCertType", JsonHelper.getDestValue(joBaseInfo, "psn_cert_type"));
  1366. joTmp.Add("PsnCertNO", JsonHelper.getDestValue(joBaseInfo, "certno"));
  1367. joTmp.Add("Gend", JsonHelper.getDestValue(joBaseInfo, "gend"));
  1368. joTmp.Add("Naty", JsonHelper.getDestValue(joBaseInfo, "naty"));
  1369. joTmp.Add("Brdy", JsonHelper.getDestValue(joBaseInfo, "brdy"));
  1370. joTmp.Add("Age", JsonHelper.getDestValue(joBaseInfo, "age"));
  1371. joTmp.Add("Balc", JsonHelper.getDestValue(joInsuInfo, "balc"));
  1372. joTmp.Add("Insutype", JsonHelper.getDestValue(joInsuInfo, "insutype"));
  1373. joTmp.Add("PsnType", JsonHelper.getDestValue(joInsuInfo, "psn_type"));
  1374. joTmp.Add("PsnInsuStas", JsonHelper.getDestValue(joInsuInfo, "psn_insu_stas"));
  1375. joTmp.Add("PsnInsuDate", JsonHelper.getDestValue(joInsuInfo, "psn_insu_date"));
  1376. joTmp.Add("PausInsuDate", JsonHelper.getDestValue(joInsuInfo, "paus_insu_date"));
  1377. joTmp.Add("Cvlservflag", JsonHelper.getDestValue(joInsuInfo, "cvlserv_flag"));
  1378. joTmp.Add("insuplcAdmdvs", JsonHelper.getDestValue(joInsuInfo, "insuplc_admdvs"));
  1379. joTmp.Add("EmpName", JsonHelper.getDestValue(joInsuInfo, "emp_name"));
  1380. joTmp.Add("PsnIdettype", JsonHelper.getDestValue(joIdetInfo, "psn_idet_type"));
  1381. joTmp.Add("PsnTypeLv", JsonHelper.getDestValue(joIdetInfo, "psn_type_lv"));
  1382. joTmp.Add("IdetBegntime", JsonHelper.getDestValue(joIdetInfo, "begntime"));
  1383. joTmp.Add("IdetEndtime", JsonHelper.getDestValue(joIdetInfo, "endtime"));
  1384. joTmp.Add("updateUserID", Global.user.ID);
  1385. string serviceCode = "09010070";
  1386. string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString();
  1387. JObject joRtn = invoker.invokeInsuService(inpar, "插入患者该次就诊参保信息");
  1388. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1389. {
  1390. outParam = errMsg;
  1391. return -1;
  1392. }
  1393. else
  1394. {
  1395. outParam = joRtn.ToString();
  1396. return 0;
  1397. }
  1398. }
  1399. catch (Exception ex)
  1400. {
  1401. outParam = "医保平台插入患者该次就诊参保信息:" + ex.Message;
  1402. return -1;
  1403. }
  1404. }
  1405. #region 目录下载及对照
  1406. /// <summary>
  1407. /// 通过分页的方式查询医保目录
  1408. /// </summary>
  1409. /// <param name="currentPage"></param>
  1410. /// <param name="pageSize"></param>
  1411. /// <param name="irisCode"></param>
  1412. /// <param name="directoryType"></param>
  1413. public JObject getMIDirectoryByPagination(JObject jo)
  1414. {
  1415. string currentPage;
  1416. string pageSize;
  1417. string serviceCode;
  1418. string directoryType;
  1419. string directoryCode;
  1420. string directoryName;
  1421. string directoryDr;
  1422. string approvalNO ;
  1423. string dosageForm;
  1424. string specifications;
  1425. string manufacturers;
  1426. try
  1427. {
  1428. currentPage = JsonHelper.getDestValue(jo, "currentPage");
  1429. pageSize = JsonHelper.getDestValue(jo, "pageSize");
  1430. serviceCode = JsonHelper.getDestValue(jo, "serviceCode");
  1431. directoryType = JsonHelper.getDestValue(jo, "directoryType");
  1432. directoryCode = JsonHelper.getDestValue(jo, "directoryCode");
  1433. directoryName = JsonHelper.getDestValue(jo, "directoryName");
  1434. directoryDr = JsonHelper.getDestValue(jo, "directoryDr");
  1435. approvalNO = JsonHelper.getDestValue(jo, "approvalNO");
  1436. dosageForm = JsonHelper.getDestValue(jo, "dosageForm");
  1437. specifications = JsonHelper.getDestValue(jo, "specifications");
  1438. manufacturers = JsonHelper.getDestValue(jo, "manufacturers");
  1439. InvokeHelper invoker = new InvokeHelper();
  1440. dynamic joInput = new JObject();
  1441. joInput.code = serviceCode;
  1442. dynamic joTmp = new JObject();
  1443. JArray jaParmas = new JArray();
  1444. joTmp.HospitalDr = Global.inf.hospitalDr;
  1445. joTmp.InterfaceDr = directoryDr;
  1446. joTmp.Code = directoryCode;
  1447. joTmp.Name = directoryName;
  1448. joTmp.ApprovalNO = approvalNO;
  1449. joTmp.Manufacturer = manufacturers;
  1450. joTmp.DosageForm = dosageForm;
  1451. joTmp.Specifications = specifications;
  1452. jaParmas.Add(joTmp);
  1453. joInput.Add("params", JArray.FromObject(jaParmas));
  1454. JArray jaPagination = new JArray();
  1455. joTmp = new JObject();
  1456. joTmp.pageSize = pageSize;
  1457. joTmp.currentPage = currentPage;
  1458. joTmp.sortColumn = "";
  1459. joTmp.sortOrder = "";
  1460. joTmp.hisType = directoryType;
  1461. jaPagination.Add(joTmp);
  1462. joInput.Add("pagination", JArray.FromObject(jaPagination));
  1463. return invoker.invokeInsuService(joInput.ToString(), "查询医保目录分页");
  1464. }
  1465. catch (Exception ex)
  1466. {
  1467. return JsonHelper.setExceptionJson(-1, "getDirectoryByPagination", ex.Message);
  1468. }
  1469. }
  1470. /// <summary>
  1471. /// 根据HisType获取当前目录最大版本号
  1472. /// </summary>
  1473. /// <param name="directoryType"></param>
  1474. /// <returns></returns>
  1475. public JObject getDirectoryMaxVersionNO(int directoryType)
  1476. {
  1477. try
  1478. {
  1479. dynamic joParam = new JObject();
  1480. joParam.HospitalDr = Global.inf.hospitalDr;
  1481. joParam.InterfaceDr = Global.inf.interfaceDr;
  1482. joParam.HisType = directoryType + 1;
  1483. JObject joInparam = JsonHelper.setIrisInpar("09010037", joParam);
  1484. JObject joRtn = invoker.invokeInsuService(joInparam.ToString(), "获取版本最大号");
  1485. return joRtn;
  1486. }
  1487. catch (Exception ex)
  1488. {
  1489. return JsonHelper.setExceptionJson(-1, "获取版本号异常:", ex.Message);
  1490. }
  1491. }
  1492. public JObject insertDictionary(JObject joData)
  1493. {
  1494. try
  1495. {
  1496. JObject joInparam = JsonHelper.setIrisInpar("09010073", joData);
  1497. JObject joRtn = invoker.invokeInsuService(joInparam.ToString(), "插入字典表");
  1498. return joRtn;
  1499. }
  1500. catch (Exception ex)
  1501. {
  1502. return JsonHelper.setExceptionJson(-1, "插入字典表异常:", ex.Message);
  1503. }
  1504. }
  1505. public JObject insertDictionaryDataDetail(JArray jaData)
  1506. {
  1507. try
  1508. {
  1509. dynamic joParam = new JObject();
  1510. joParam.HospitalDr = Global.inf.hospitalDr;
  1511. joParam.InterfaceDr = Global.inf.interfaceDr;
  1512. JObject joInparam = JsonHelper.setIrisInpar("09010074", jaData);
  1513. JObject joRtn = invoker.invokeInsuService( joInparam.ToString(),"插入字典明细表");
  1514. return joRtn;
  1515. }
  1516. catch (Exception ex)
  1517. {
  1518. return JsonHelper.setExceptionJson(-1, "插入字典明细表异常:", ex.Message);
  1519. }
  1520. }
  1521. public JObject ConvertHISDir(JObject joHisRtnDir)
  1522. {
  1523. try
  1524. {
  1525. //传给医保平台,进行对照匹配
  1526. dynamic joParam = new JObject();
  1527. joParam.TotalCount = joHisRtnDir["result"]["TotalCount"];
  1528. joParam.HospitalDr = Global.inf.hospitalDr;
  1529. joParam.InterfaceDr = Global.inf.interfaceDr;
  1530. joParam.Data = joHisRtnDir["result"]["Data"];
  1531. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010057", joParam).ToString(), "转换HIS目录分页,显示对照状态及对照的医保编码");
  1532. return joRtn;
  1533. }
  1534. catch (Exception ex)
  1535. {
  1536. return JsonHelper.setExceptionJson(-1, "转换HIS目录分页异常:", ex.Message);
  1537. }
  1538. }
  1539. public JObject GetMappedHISDir(JArray jaPagination, JArray jaParams)
  1540. {
  1541. try
  1542. {
  1543. //传给医保平台,进行对照匹配
  1544. dynamic joParam = new JObject();
  1545. joParam.pagination = jaPagination;
  1546. joParam.session = Global.curEvt.jaSession;
  1547. joParam.Add("params", jaParams);
  1548. joParam.code = "09010058";
  1549. JObject joRtn = invoker.invokeInsuService(joParam.ToString(), "获取已对照目录分页");
  1550. return joRtn;
  1551. }
  1552. catch (Exception ex)
  1553. {
  1554. return JsonHelper.setExceptionJson(-1, "获取已对照目录分页异常:", ex.Message);
  1555. }
  1556. }
  1557. public JObject GetNoMappHISDir(JObject joHisRtnDir)
  1558. {
  1559. try
  1560. {
  1561. //传给医保平台,进行对照匹配
  1562. dynamic joParam = new JObject();
  1563. joParam.TotalCount = joHisRtnDir["result"]["TotalCount"];
  1564. joParam.HospitalDr = Global.inf.hospitalDr;
  1565. joParam.InterfaceDr = Global.inf.interfaceDr;
  1566. joParam.Data = joHisRtnDir["result"]["Data"];
  1567. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010088", joParam).ToString(), "获取未对照目录");
  1568. return joRtn;
  1569. }
  1570. catch (Exception ex)
  1571. {
  1572. return JsonHelper.setExceptionJson(-1, "获取未对照目录异常:", ex.Message);
  1573. }
  1574. }
  1575. public JObject UpdateDirectoryBySelf(JObject joIn)
  1576. {
  1577. try
  1578. {
  1579. //查询区域通用目录
  1580. MIIrisServices mIS = new MIIrisServices();
  1581. JObject joRtnTY = mIS.getInterface_TY(Global.inf.interfaceDr.ToString(), "");
  1582. string InsuCurrencyCataLogue = JsonHelper.getDestValue(joRtnTY, "InsuCurrencyCataLogue"); //通用目录编码 6
  1583. string InterfaceName_TY = JsonHelper.getDestValue(joRtnTY, "InterfaceName_TY"); //通用目录接口名称
  1584. string HospName_TY = JsonHelper.getDestValue(joRtnTY, "HospitalName"); //通用目录所属医院名称
  1585. string HospitalDr_TY = JsonHelper.getDestValue(joRtnTY, "HospitalDr_TY"); //通用目录所属医院ID
  1586. JObject joParam = (JObject)joIn.DeepClone();
  1587. if ((InsuCurrencyCataLogue != "") && (HospitalDr_TY != ""))
  1588. {
  1589. joParam.Add("updateUserID", Global.user.ID);
  1590. joParam.Add("HospitalDr", HospitalDr_TY);
  1591. joParam.Add("InterfaceDr", InsuCurrencyCataLogue);
  1592. }
  1593. else
  1594. {
  1595. joParam.Add("updateUserID", Global.user.ID);
  1596. joParam.Add("HospitalDr", Global.inf.hospitalDr);
  1597. joParam.Add("InterfaceDr", Global.inf.interfaceDr);
  1598. }
  1599. InvokeHelper invoker = new InvokeHelper();
  1600. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010035", joParam).ToString(), "手动修改医保目录表");
  1601. return joRtn;
  1602. }
  1603. catch (Exception ex)
  1604. {
  1605. return JsonHelper.setExceptionJson(-1, "手动修改医保目录表异常:", ex.Message);
  1606. }
  1607. }
  1608. public JObject QueryTransactionLog(JObject joSqlStr)
  1609. {
  1610. try
  1611. {
  1612. InvokeHelper invoker = new InvokeHelper();
  1613. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010060", joSqlStr).ToString(), "查询交易日志(冲正)");
  1614. return joRtn;
  1615. }
  1616. catch (Exception ex)
  1617. {
  1618. return JsonHelper.setExceptionJson(-1, "查询交易日志(冲正)异常:", ex.Message);
  1619. }
  1620. }
  1621. public JObject QuerySettlementInfo(JObject joSqlStr)
  1622. {
  1623. try
  1624. {
  1625. InvokeHelper invoker = new InvokeHelper();
  1626. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010059", joSqlStr).ToString(), "查询结算信息");
  1627. return joRtn;
  1628. }
  1629. catch (Exception ex)
  1630. {
  1631. return JsonHelper.setExceptionJson(-1, "查询结算信息:", ex.Message);
  1632. }
  1633. }
  1634. #endregion
  1635. }
  1636. }