IrisServices.cs 73 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845
  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. // 异常值转换
  1236. Utils.convertTimestamp(joSetlinfo, "brdy");
  1237. Utils.convertTimestamp(joSetlinfo, "setl_time");
  1238. joSetlinfo.Add("HospitalDr", Global.inf.hospitalDr);
  1239. joSetlinfo.Add("admID", Global.pat.adm_Dr);
  1240. joSetlinfo.Add("ValidFlag", 1);
  1241. joSetlinfo.Add("BillType", 1);
  1242. joSetlinfo.Add("updateUserID",Global.user.ID);
  1243. joSetlinfo.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  1244. joSetlinfo.Add("billID", Global.pat.billID);
  1245. joSetlinfo.Add("recordID", Global.pat.recordID);
  1246. joSetlinfo.Add("msgid", Global.curEvt.msgid);
  1247. joSetlinfo.Add("interfaceDr", Global.inf.interfaceDr);
  1248. joSetlinfo.Add("admType", Global.pat.admType);
  1249. joSetlinfo.Add("insuplc_admdvs", Global.pat.insuplc_admdvs);
  1250. joSetlinfo.Add("ExpContent", Global.pat.ExpContent);
  1251. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010051", joSetlinfo).ToString(), "插入结算信息");
  1252. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1253. {
  1254. outParam = errMsg;
  1255. return -1;
  1256. }
  1257. else
  1258. {
  1259. outParam = joRtn.ToString();
  1260. return 0;
  1261. }
  1262. }
  1263. catch (Exception ex)
  1264. {
  1265. outParam = "插入结算信息:" + ex.Message;
  1266. return -1;
  1267. }
  1268. }
  1269. /// <summary>
  1270. /// 保存结算信息
  1271. /// </summary>
  1272. /// <param name="joSettlement"></param>
  1273. /// <param name="outParam"></param>
  1274. /// <returns></returns>
  1275. public int saveSettlementDetail(JObject joSettlement, out string outParam)
  1276. {
  1277. JObject joTmp = new JObject();
  1278. string errMsg = "";
  1279. try
  1280. {
  1281. JObject joSetlDetail = new JObject();
  1282. joSetlDetail.Add("HospitalDr", Global.inf.hospitalDr);
  1283. joSetlDetail.Add("InterfaceDr", Global.inf.interfaceDr);
  1284. joSetlDetail.Add("MdtrtID", Global.pat.mdtrtID);
  1285. joSetlDetail.Add("SettlementID", JsonHelper.getDestValue(joSettlement, "output.setlinfo.setl_id"));
  1286. joSetlDetail.Add("AdmID", Global.pat.adm_Dr);
  1287. joSetlDetail.Add("updateUserID", Global.user.ID);
  1288. if (JsonHelper.getDestValue(joSettlement, "output.setldetail") == "")
  1289. {
  1290. outParam = "中心返回结算明细为空!";
  1291. Global.writeLog(outParam);
  1292. return 0;
  1293. }
  1294. JArray jaSetlDetail = JArray.Parse(JsonHelper.getDestValue(joSettlement, "output.setldetail"));
  1295. joSetlDetail.Add("setldetail", jaSetlDetail);
  1296. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010056", joSetlDetail).ToString(), "插入结算明细信息");
  1297. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1298. {
  1299. outParam = errMsg;
  1300. return -1;
  1301. }
  1302. else
  1303. {
  1304. outParam = joRtn.ToString();
  1305. return 0;
  1306. }
  1307. }
  1308. catch (Exception ex)
  1309. {
  1310. outParam = "插入结算信息:" + ex.Message;
  1311. return -1;
  1312. }
  1313. }
  1314. /// <summary>
  1315. /// 取消结算
  1316. /// </summary>
  1317. /// <param name="outParam"></param>
  1318. /// <returns></returns>
  1319. public int cancleSettlement(string newSettlID, out string outParam)
  1320. {
  1321. JObject joTmp = new JObject();
  1322. string errMsg = "";
  1323. try
  1324. {
  1325. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  1326. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  1327. joTmp.Add("admID", Global.pat.adm_Dr);
  1328. joTmp.Add("mdtrt_id", Global.pat.mdtrtID);
  1329. joTmp.Add("setl_id", Global.pat.settlID);
  1330. joTmp.Add("new_setl_id", newSettlID);
  1331. joTmp.Add("updateUserID", Global.user.ID);
  1332. joTmp.Add("msgid", Global.curEvt.msgid);
  1333. joTmp.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  1334. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010052", joTmp).ToString(), "取消结算信息");
  1335. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1336. {
  1337. outParam = errMsg;
  1338. return -1;
  1339. }
  1340. else
  1341. {
  1342. outParam = joRtn.ToString();
  1343. return 0;
  1344. }
  1345. }
  1346. catch (Exception ex)
  1347. {
  1348. outParam = "取消结算信息:" + ex.Message;
  1349. return -1;
  1350. }
  1351. }
  1352. public JObject DynamicQuerySettlInfo(JObject joSqlStr)
  1353. {
  1354. try
  1355. {
  1356. InvokeHelper invoker = new InvokeHelper();
  1357. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010081", joSqlStr).ToString(), "动态查询结算信息");
  1358. return joRtn;
  1359. }
  1360. catch (Exception ex)
  1361. {
  1362. return JsonHelper.setExceptionJson(-1, "查询结算信息异常:", ex.Message);
  1363. }
  1364. }
  1365. /// <summary>
  1366. /// 查询登记信息
  1367. /// </summary>
  1368. /// <param name="type"></param>
  1369. /// <param name="outParam"></param>
  1370. /// <returns></returns>
  1371. public int queryRegisterInfo(int type,out string outParam)
  1372. {
  1373. JObject joTmp = new JObject();
  1374. string errMsg = "";
  1375. try
  1376. {
  1377. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  1378. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  1379. joTmp.Add("admID", Global.pat.adm_Dr);
  1380. joTmp.Add("mdtrt_id", Global.pat.mdtrtID);
  1381. joTmp.Add("type", type);
  1382. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010050", joTmp).ToString(), "查询云平台患者登记信息");
  1383. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1384. {
  1385. outParam = errMsg;
  1386. return -1;
  1387. }
  1388. else
  1389. {
  1390. outParam = joRtn.ToString();
  1391. return 0;
  1392. }
  1393. }
  1394. catch (Exception ex)
  1395. {
  1396. outParam = "查询云平台患者登记信息:" + ex.Message;
  1397. return -1;
  1398. }
  1399. }
  1400. /// <summary>
  1401. /// 插入患者该次就诊参保信息
  1402. /// </summary>
  1403. /// <param name="joBaseInfo"></param>
  1404. /// <param name="joInsuInfo"></param>
  1405. /// <param name="joIdetInfo"></param>
  1406. /// <param name="outParam"></param>
  1407. /// <returns></returns>
  1408. public int insertPatCurInsuInfo(JObject joBaseInfo, JObject joInsuInfo, JObject joIdetInfo, out string outParam)
  1409. {
  1410. JObject joTmp = new JObject();
  1411. string errMsg = "";
  1412. try
  1413. {
  1414. joTmp.Add("HospitalDr", Global.inf.hospitalDr);
  1415. joTmp.Add("InterfaceDr", Global.inf.interfaceDr);
  1416. joTmp.Add("AdmID", Global.pat.adm_Dr);
  1417. joTmp.Add("PatientName", Global.pat.name);
  1418. joTmp.Add("PersonalNO", Global.pat.psn_no);
  1419. joTmp.Add("MdtrtID", Global.pat.mdtrtID);
  1420. joTmp.Add("PsnCertType", JsonHelper.getDestValue(joBaseInfo, "psn_cert_type"));
  1421. joTmp.Add("PsnCertNO", JsonHelper.getDestValue(joBaseInfo, "certno"));
  1422. joTmp.Add("Gend", JsonHelper.getDestValue(joBaseInfo, "gend"));
  1423. joTmp.Add("Naty", JsonHelper.getDestValue(joBaseInfo, "naty"));
  1424. joTmp.Add("Brdy", JsonHelper.getDestValue(joBaseInfo, "brdy"));
  1425. joTmp.Add("Age", JsonHelper.getDestValue(joBaseInfo, "age"));
  1426. joTmp.Add("Balc", JsonHelper.getDestValue(joInsuInfo, "balc"));
  1427. joTmp.Add("Insutype", JsonHelper.getDestValue(joInsuInfo, "insutype"));
  1428. joTmp.Add("PsnType", JsonHelper.getDestValue(joInsuInfo, "psn_type"));
  1429. joTmp.Add("PsnInsuStas", JsonHelper.getDestValue(joInsuInfo, "psn_insu_stas"));
  1430. joTmp.Add("PsnInsuDate", JsonHelper.getDestValue(joInsuInfo, "psn_insu_date"));
  1431. joTmp.Add("PausInsuDate", JsonHelper.getDestValue(joInsuInfo, "paus_insu_date"));
  1432. joTmp.Add("Cvlservflag", JsonHelper.getDestValue(joInsuInfo, "cvlserv_flag"));
  1433. joTmp.Add("insuplcAdmdvs", JsonHelper.getDestValue(joInsuInfo, "insuplc_admdvs"));
  1434. joTmp.Add("EmpName", JsonHelper.getDestValue(joInsuInfo, "emp_name"));
  1435. joTmp.Add("PsnIdettype", JsonHelper.getDestValue(joIdetInfo, "psn_idet_type"));
  1436. joTmp.Add("PsnTypeLv", JsonHelper.getDestValue(joIdetInfo, "psn_type_lv"));
  1437. joTmp.Add("IdetBegntime", JsonHelper.getDestValue(joIdetInfo, "begntime"));
  1438. joTmp.Add("IdetEndtime", JsonHelper.getDestValue(joIdetInfo, "endtime"));
  1439. joTmp.Add("updateUserID", Global.user.ID);
  1440. string serviceCode = "09010070";
  1441. string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString();
  1442. JObject joRtn = invoker.invokeInsuService(inpar, "插入患者该次就诊参保信息");
  1443. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  1444. {
  1445. outParam = errMsg;
  1446. return -1;
  1447. }
  1448. else
  1449. {
  1450. outParam = joRtn.ToString();
  1451. return 0;
  1452. }
  1453. }
  1454. catch (Exception ex)
  1455. {
  1456. outParam = "医保平台插入患者该次就诊参保信息:" + ex.Message;
  1457. return -1;
  1458. }
  1459. }
  1460. #region 目录下载及对照
  1461. /// <summary>
  1462. /// 通过分页的方式查询医保目录
  1463. /// </summary>
  1464. /// <param name="currentPage"></param>
  1465. /// <param name="pageSize"></param>
  1466. /// <param name="irisCode"></param>
  1467. /// <param name="directoryType"></param>
  1468. public JObject getMIDirectoryByPagination(JObject jo)
  1469. {
  1470. string currentPage;
  1471. string pageSize;
  1472. string serviceCode;
  1473. string directoryType;
  1474. string directoryCode;
  1475. string directoryName;
  1476. string directoryDr;
  1477. string approvalNO ;
  1478. string dosageForm;
  1479. string specifications;
  1480. string manufacturers;
  1481. try
  1482. {
  1483. currentPage = JsonHelper.getDestValue(jo, "currentPage");
  1484. pageSize = JsonHelper.getDestValue(jo, "pageSize");
  1485. serviceCode = JsonHelper.getDestValue(jo, "serviceCode");
  1486. directoryType = JsonHelper.getDestValue(jo, "directoryType");
  1487. directoryCode = JsonHelper.getDestValue(jo, "directoryCode");
  1488. directoryName = JsonHelper.getDestValue(jo, "directoryName");
  1489. directoryDr = JsonHelper.getDestValue(jo, "directoryDr");
  1490. approvalNO = JsonHelper.getDestValue(jo, "approvalNO");
  1491. dosageForm = JsonHelper.getDestValue(jo, "dosageForm");
  1492. specifications = JsonHelper.getDestValue(jo, "specifications");
  1493. manufacturers = JsonHelper.getDestValue(jo, "manufacturers");
  1494. InvokeHelper invoker = new InvokeHelper();
  1495. dynamic joInput = new JObject();
  1496. joInput.code = serviceCode;
  1497. dynamic joTmp = new JObject();
  1498. JArray jaParmas = new JArray();
  1499. joTmp.HospitalDr = Global.inf.hospitalDr;
  1500. joTmp.InterfaceDr = Global.inf.interfaceDr;
  1501. joTmp.Code = directoryCode;
  1502. joTmp.Name = directoryName;
  1503. joTmp.ApprovalNO = approvalNO;
  1504. joTmp.Manufacturer = manufacturers;
  1505. joTmp.DosageForm = dosageForm;
  1506. joTmp.Specifications = specifications;
  1507. jaParmas.Add(joTmp);
  1508. joInput.Add("params", JArray.FromObject(jaParmas));
  1509. JArray jaPagination = new JArray();
  1510. joTmp = new JObject();
  1511. joTmp.pageSize = pageSize;
  1512. joTmp.currentPage = currentPage;
  1513. joTmp.sortColumn = "";
  1514. joTmp.sortOrder = "";
  1515. joTmp.hisType = directoryType;
  1516. jaPagination.Add(joTmp);
  1517. joInput.Add("pagination", JArray.FromObject(jaPagination));
  1518. return invoker.invokeInsuService(joInput.ToString(), "查询医保目录分页");
  1519. }
  1520. catch (Exception ex)
  1521. {
  1522. return JsonHelper.setExceptionJson(-1, "getDirectoryByPagination", ex.Message);
  1523. }
  1524. }
  1525. /// <summary>
  1526. /// 根据HisType获取当前目录最大版本号
  1527. /// </summary>
  1528. /// <param name="directoryType"></param>
  1529. /// <returns></returns>
  1530. public JObject getDirectoryMaxVersionNO(int directoryType)
  1531. {
  1532. try
  1533. {
  1534. dynamic joParam = new JObject();
  1535. joParam.HospitalDr = Global.inf.hospitalDr;
  1536. joParam.InterfaceDr = Global.inf.interfaceDr;
  1537. joParam.HisType = directoryType + 1;
  1538. JObject joInparam = JsonHelper.setIrisInpar("09010037", joParam);
  1539. JObject joRtn = invoker.invokeInsuService(joInparam.ToString(), "获取版本最大号");
  1540. return joRtn;
  1541. }
  1542. catch (Exception ex)
  1543. {
  1544. return JsonHelper.setExceptionJson(-1, "获取版本号异常:", ex.Message);
  1545. }
  1546. }
  1547. public JObject insertDictionary(JObject joData)
  1548. {
  1549. try
  1550. {
  1551. JObject joInparam = JsonHelper.setIrisInpar("09010073", joData);
  1552. JObject joRtn = invoker.invokeInsuService(joInparam.ToString(), "插入字典表");
  1553. return joRtn;
  1554. }
  1555. catch (Exception ex)
  1556. {
  1557. return JsonHelper.setExceptionJson(-1, "插入字典表异常:", ex.Message);
  1558. }
  1559. }
  1560. public JObject insertDictionaryDataDetail(JArray jaData)
  1561. {
  1562. try
  1563. {
  1564. dynamic joParam = new JObject();
  1565. joParam.HospitalDr = Global.inf.hospitalDr;
  1566. joParam.InterfaceDr = Global.inf.interfaceDr;
  1567. JObject joInparam = JsonHelper.setIrisInpar("09010074", jaData);
  1568. JObject joRtn = invoker.invokeInsuService( joInparam.ToString(),"插入字典明细表");
  1569. return joRtn;
  1570. }
  1571. catch (Exception ex)
  1572. {
  1573. return JsonHelper.setExceptionJson(-1, "插入字典明细表异常:", ex.Message);
  1574. }
  1575. }
  1576. public JObject ConvertHISDir(JObject joHisRtnDir)
  1577. {
  1578. try
  1579. {
  1580. //传给医保平台,进行对照匹配
  1581. dynamic joParam = new JObject();
  1582. joParam.TotalCount = joHisRtnDir["result"]["TotalCount"];
  1583. joParam.HospitalDr = Global.inf.hospitalDr;
  1584. joParam.InterfaceDr = Global.inf.interfaceDr;
  1585. joParam.Data = joHisRtnDir["result"]["Data"];
  1586. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010057", joParam).ToString(), "转换HIS目录分页,显示对照状态及对照的医保编码");
  1587. return joRtn;
  1588. }
  1589. catch (Exception ex)
  1590. {
  1591. return JsonHelper.setExceptionJson(-1, "转换HIS目录分页异常:", ex.Message);
  1592. }
  1593. }
  1594. public JObject GetMappedHISDir(JArray jaPagination, JArray jaParams)
  1595. {
  1596. try
  1597. {
  1598. //传给医保平台,进行对照匹配
  1599. dynamic joParam = new JObject();
  1600. joParam.pagination = jaPagination;
  1601. joParam.session = Global.curEvt.jaSession;
  1602. joParam.Add("params", jaParams);
  1603. joParam.code = "09010058";
  1604. JObject joRtn = invoker.invokeInsuService(joParam.ToString(), "获取已对照目录分页");
  1605. return joRtn;
  1606. }
  1607. catch (Exception ex)
  1608. {
  1609. return JsonHelper.setExceptionJson(-1, "获取已对照目录分页异常:", ex.Message);
  1610. }
  1611. }
  1612. public JObject GetNoMappHISDir(JObject joHisRtnDir)
  1613. {
  1614. try
  1615. {
  1616. //传给医保平台,进行对照匹配
  1617. dynamic joParam = new JObject();
  1618. joParam.TotalCount = joHisRtnDir["result"]["TotalCount"];
  1619. joParam.HospitalDr = Global.inf.hospitalDr;
  1620. joParam.InterfaceDr = Global.inf.interfaceDr;
  1621. joParam.Data = joHisRtnDir["result"]["Data"];
  1622. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010088", joParam).ToString(), "获取未对照目录");
  1623. return joRtn;
  1624. }
  1625. catch (Exception ex)
  1626. {
  1627. return JsonHelper.setExceptionJson(-1, "获取未对照目录异常:", ex.Message);
  1628. }
  1629. }
  1630. public JObject UpdateDirectoryBySelf(JObject joIn)
  1631. {
  1632. try
  1633. {
  1634. //查询区域通用目录
  1635. MIIrisServices mIS = new MIIrisServices();
  1636. JObject joRtnTY = mIS.getInterface_TY(Global.inf.interfaceDr.ToString(), "");
  1637. string InsuCurrencyCataLogue = JsonHelper.getDestValue(joRtnTY, "InsuCurrencyCataLogue"); //通用目录编码 6
  1638. string InterfaceName_TY = JsonHelper.getDestValue(joRtnTY, "InterfaceName_TY"); //通用目录接口名称
  1639. string HospName_TY = JsonHelper.getDestValue(joRtnTY, "HospitalName"); //通用目录所属医院名称
  1640. string HospitalDr_TY = JsonHelper.getDestValue(joRtnTY, "HospitalDr_TY"); //通用目录所属医院ID
  1641. JObject joParam = (JObject)joIn.DeepClone();
  1642. if ((InsuCurrencyCataLogue != "") && (HospitalDr_TY != ""))
  1643. {
  1644. joParam.Add("updateUserID", Global.user.ID);
  1645. joParam.Add("HospitalDr", HospitalDr_TY);
  1646. joParam.Add("InterfaceDr", InsuCurrencyCataLogue);
  1647. }
  1648. else
  1649. {
  1650. joParam.Add("updateUserID", Global.user.ID);
  1651. joParam.Add("HospitalDr", Global.inf.hospitalDr);
  1652. joParam.Add("InterfaceDr", Global.inf.interfaceDr);
  1653. }
  1654. InvokeHelper invoker = new InvokeHelper();
  1655. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010035", joParam).ToString(), "手动修改医保目录表");
  1656. return joRtn;
  1657. }
  1658. catch (Exception ex)
  1659. {
  1660. return JsonHelper.setExceptionJson(-1, "手动修改医保目录表异常:", ex.Message);
  1661. }
  1662. }
  1663. public JObject QueryTransactionLog(JObject joSqlStr)
  1664. {
  1665. try
  1666. {
  1667. InvokeHelper invoker = new InvokeHelper();
  1668. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010060", joSqlStr).ToString(), "查询交易日志(冲正)");
  1669. return joRtn;
  1670. }
  1671. catch (Exception ex)
  1672. {
  1673. return JsonHelper.setExceptionJson(-1, "查询交易日志(冲正)异常:", ex.Message);
  1674. }
  1675. }
  1676. public JObject QuerySettlementInfo(JObject joSqlStr)
  1677. {
  1678. try
  1679. {
  1680. InvokeHelper invoker = new InvokeHelper();
  1681. JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010059", joSqlStr).ToString(), "查询结算信息");
  1682. return joRtn;
  1683. }
  1684. catch (Exception ex)
  1685. {
  1686. return JsonHelper.setExceptionJson(-1, "查询交易日志(冲正)异常:", ex.Message);
  1687. }
  1688. }
  1689. #endregion
  1690. }
  1691. }