IrisServices.cs 73 KB

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