InsuBusiness.cs 120 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using PTMedicalInsurance.Common;
  7. using PTMedicalInsurance.Business;
  8. using System.Windows.Forms;
  9. using PTMedicalInsurance.Helper;
  10. using Newtonsoft.Json.Linq;
  11. using PTMedicalInsurance.Variables;
  12. using PTMedicalInsurance.Forms;
  13. using System.IO;
  14. using System.Reflection;
  15. using System.Data;
  16. using HuBeiMI.Forms;
  17. using System.Collections;
  18. using System.Data.SqlTypes;
  19. using Sunny.UI.Win32;
  20. using Sunny.UI;
  21. using PTMedicalInsurance.Forms.ElectronicSettlementCertificates;
  22. using System.Threading;
  23. namespace PTMedicalInsurance
  24. {
  25. public class InsuBusiness : IInsuBusiness
  26. {
  27. //定义相关的变量
  28. private Patients patient;
  29. private Fees fee;
  30. private Settlements settlement;
  31. //json对象属性
  32. private JObject joInParam;
  33. private JArray jaSession ;
  34. private JArray jaParams;
  35. private JObject joParam;
  36. private JObject joInterface;
  37. private JObject joInsuAdmObj;
  38. private JObject joParamA;//临时进销存使用
  39. JObject joParam992001;//临时进销存使用
  40. JObject joParam992002;//临时进销存使用
  41. JObject joParam992004;//临时进销存使用
  42. //设置业务实例
  43. CenterBusiness cBus = new CenterBusiness();
  44. HisMainBusiness hBus = new HisMainBusiness();
  45. HisIrisServices hIS = new HisIrisServices();
  46. MIIrisServices mIS= new MIIrisServices();
  47. InvokeHelper invoker = new InvokeHelper();
  48. //
  49. private string businessType;
  50. public InsuBusiness()
  51. {
  52. Global.curEvt.path = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location);
  53. ComputerInfo comp = new ComputerInfo();
  54. Global.curEvt.mac = comp.GetMAC();
  55. Global.curEvt.ip = comp.GetIP(); //"10.1.4.100";
  56. Global.pat.insuplc_admdvs = ""; //如果是NULL中心会报错
  57. }
  58. private int parseInparam(string inParam,out string errMsg)
  59. {
  60. errMsg = "";
  61. try
  62. {
  63. joInParam = JObject.Parse(inParam);
  64. jaSession = JArray.Parse(JsonHelper.getDestValue(joInParam, "session"));
  65. Global.curEvt.jaSession = jaSession;
  66. jaParams = JArray.Parse(JsonHelper.getDestValue(joInParam, "params"));
  67. joParam = JObject.FromObject(jaParams[0]);
  68. if (JsonHelper.getDestValue(joInParam, "insuAdmObj") != "")
  69. joInsuAdmObj = JObject.Parse(JsonHelper.getDestValue(joInParam, "insuAdmObj"));
  70. joInterface = JObject.Parse(JsonHelper.getDestValue(joInParam, "interfaceinfo"));
  71. Global.pat.insuplc_admdvs= JsonHelper.getDestValue(joInParam, "insuplc_admdvs");
  72. businessType = JsonHelper.getDestValue(joInParam, "businessType");
  73. return 0;
  74. }
  75. catch (Exception ex)
  76. {
  77. errMsg = "parseInparam 解析入参异常:" + errMsg;
  78. return -1;
  79. }
  80. }
  81. /// <summary>
  82. /// 签到
  83. /// </summary>
  84. /// <param name="InParam"></param>
  85. /// <returns></returns>
  86. public string Init(string InParam)
  87. {
  88. string errMsg, rtnResult ="";
  89. JObject joRtn = new JObject();
  90. try
  91. {
  92. if (hBus.initEnvironment(InParam, out errMsg) != 0)
  93. {
  94. return JsonHelper.setExceptionJson(-100, "initEnvironment 失败", errMsg).ToString();
  95. }
  96. else
  97. {
  98. //if (businessType != "BasicData") //医保对照不需要调用签到交易
  99. if ((businessType != "BasicData") && (businessType != "M6") && (businessType != "M6C") && (businessType != "M6Confirm") && (businessType != "M6CallBack"))
  100. {
  101. if (mIS.isSigned(ref Global.curEvt.signno) != true)
  102. {
  103. //签到
  104. if (cBus.signIn(out joRtn) != 0)
  105. {
  106. rtnResult = JsonHelper.setExceptionJson(-1, "签到异常", (string)joRtn["err_msg"]).ToString();
  107. return rtnResult;
  108. }
  109. else
  110. {
  111. Global.curEvt.signno = JsonHelper.getDestValue(joRtn, "output.signinoutb.sign_no");
  112. //插入签到表
  113. if (mIS.saveSignRecord(Global.curEvt.signno, out errMsg) != 0)
  114. {
  115. rtnResult = JsonHelper.setIrisReturnValue(0, "中心签到成功但插入签到表失败:" + errMsg, null).ToString();
  116. }
  117. else
  118. {
  119. rtnResult = JsonHelper.setIrisReturnValue(0, "签到成功", joRtn).ToString();
  120. }
  121. }
  122. }
  123. else
  124. {
  125. rtnResult = JsonHelper.setIrisReturnValue(0, "初始化成功!", null).ToString();
  126. }
  127. }
  128. else
  129. {
  130. Global.curEvt.signno = "abc123";
  131. rtnResult = JsonHelper.setIrisReturnValue(0, "初始化成功!", null).ToString();
  132. }
  133. return rtnResult;
  134. }
  135. }
  136. catch (Exception ex)
  137. {
  138. rtnResult = JsonHelper.setExceptionJson(-100, "Init 异常", ex.Message).ToString();
  139. return rtnResult;
  140. }
  141. finally
  142. {
  143. Global.writeLog("初始化结果:" + rtnResult);
  144. }
  145. }
  146. /// <summary>
  147. /// 初始化
  148. /// </summary>
  149. /// <param name="inParam"></param>
  150. /// <param name="outParam"></param>
  151. /// <returns></returns>
  152. private int init(string inParam, out string outParam)
  153. {
  154. string errMsg;
  155. outParam = "";
  156. try
  157. {
  158. //BS架构调用方式问题,每次调用都需要重新初始化
  159. JObject joInitRtn = JObject.Parse(Init(inParam));
  160. if (JsonHelper.parseIrisRtnValue(joInitRtn, out errMsg) != 0)
  161. {
  162. outParam = JsonHelper.setExceptionJson(-100, "init(HIS医保环境初始化)", errMsg).ToString();
  163. return -1;
  164. }
  165. else
  166. {
  167. return 0;
  168. }
  169. }
  170. catch (Exception ex)
  171. {
  172. outParam = JsonHelper.setExceptionJson(-100, "init(HIS医保环境初始化)异常", ex.Message).ToString();
  173. return -1;
  174. }
  175. }
  176. /// <summary>
  177. /// 获取患者信息
  178. /// </summary>
  179. /// <param name="InParam"></param>
  180. /// <returns></returns>
  181. public string GetPatientInfo(string InParam)
  182. {
  183. Global.writeLog("GetPatientInfo入参:" + JsonHelper.Compress(InParam));
  184. //设置返回值,错误信息
  185. int errCode;
  186. string errMsg, rtnResult = "",outParam;
  187. //BS架构调用方式问题,每次调用都需要重新初始化
  188. if (init(InParam,out outParam)!= 0)
  189. {
  190. rtnResult = outParam;
  191. return rtnResult;
  192. }
  193. JObject joInParam = JObject.Parse(InParam);
  194. string businessType = JsonHelper.getDestValue(joInParam,"businessType");
  195. try
  196. {
  197. switch (businessType)
  198. {
  199. case "M1"://门诊读卡
  200. {
  201. //打开读卡窗口,操作员选择读卡类型后进行读卡器读卡,再进行1101获取参保信息
  202. if (hBus.readCard(out outParam) != 0)
  203. {
  204. rtnResult = JsonHelper.setExceptionJson(-100, "读卡失败!", outParam).ToString();
  205. }
  206. else
  207. {
  208. //展示患者信息界面
  209. if (hBus.showPatInfo(outParam, out outParam) != 0)
  210. {
  211. rtnResult = outParam;
  212. }
  213. else
  214. {
  215. rtnResult = JsonHelper.setIrisReturnValue(0, "", JObject.Parse(outParam)).ToString();
  216. }
  217. }
  218. break;
  219. }
  220. case "Z1"://住院读卡
  221. {
  222. //打开读卡窗口,操作员选择读卡类型后进行读卡器读卡,再进行1101获取参保信息
  223. if (hBus.readCard(out outParam) != 0)
  224. {
  225. rtnResult = JsonHelper.setExceptionJson(-100, "读卡失败!", outParam).ToString();
  226. }
  227. else
  228. {
  229. //住院提示特殊人员标识:JsonHelper.getDestValue(JObject.Parse(outParam), "output.exp_content.ectoken");
  230. string patInfo = outParam;
  231. //展示患者信息界面
  232. if (hBus.showPatInfo(patInfo, out outParam) != 0)
  233. {
  234. string idtype = JsonHelper.getDestValue(JObject.Parse(outParam), "output.selectedIdInfo.psn_idet_type");
  235. if (idtype != null)
  236. {
  237. string[] s1 = new string[8] { "9937", "230705", "211112", "236022", "230508", "236018", "2304", "2303" };//武汉乡村振兴人员身份类别
  238. if (s1.Contains(idtype))
  239. {
  240. MessageBox.Show("该人员存在特殊人员身份为" + idtype);
  241. }
  242. }
  243. rtnResult = outParam;
  244. }
  245. else
  246. {
  247. rtnResult = JsonHelper.setIrisReturnValue(0,"",JObject.Parse(outParam)).ToString();
  248. }
  249. }
  250. break;
  251. }
  252. }
  253. return rtnResult;
  254. }
  255. catch (Exception ex)
  256. {
  257. rtnResult = JsonHelper.setIrisReturnValue(-1 , "GetPatientInfo发生异常;" + ex.Message,null).ToString();
  258. return rtnResult;
  259. }
  260. finally
  261. {
  262. Global.writeLog("GetPatientInfo出参:" + JsonHelper.Compress(rtnResult));
  263. }
  264. }
  265. /// <summary>
  266. /// 登记
  267. /// </summary>
  268. /// <param name="InParam"></param>
  269. /// <returns></returns>
  270. public string Register(string InParam)
  271. {
  272. Global.writeLog("Register 入参:" + JsonHelper.Compress(InParam));
  273. //设置返回值,错误信息
  274. string errMsg, rtnResult = "", outParam;
  275. try
  276. {
  277. //解析入参
  278. if (parseInparam(InParam, out errMsg) != 0)
  279. {
  280. rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  281. return rtnResult;
  282. }
  283. //BS架构调用方式问题,每次调用都需要重新初始化
  284. if (init(InParam, out outParam) != 0)
  285. {
  286. rtnResult = outParam;
  287. return rtnResult;
  288. }
  289. //获取pat
  290. hBus.GetRegPatInfo(businessType, joInParam, out Global.pat);
  291. switch (businessType)
  292. {
  293. case "M2"://门诊登记
  294. {
  295. break;
  296. }
  297. case "M2C"://门诊登记撤销
  298. {
  299. break;
  300. }
  301. case "Z0"://住院修改
  302. {
  303. break;
  304. }
  305. case "Z2"://入院登记
  306. {
  307. Global.writeLog(Global.pat.insuType);
  308. string regInParam = "";
  309. //校验HIS姓名与医保姓名是否一致
  310. if (hBus.checkName(Global.pat.name, out errMsg) != 0)
  311. {
  312. rtnResult = JsonHelper.setExceptionJson(-1, "校验HIS与医保姓名是否一致", errMsg).ToString();
  313. return rtnResult;
  314. }
  315. //显示登记面板
  316. if (hBus.showInPatRegisterForm( out regInParam) == 0)
  317. {
  318. Global.writeLog(regInParam);
  319. JObject joRegIn_plain = JObject.Parse(JsonHelper.setCenterInpar_plain("2401", regInParam));
  320. JObject joRegIn = JObject.Parse(JsonHelper.setCenterInpar("2401", regInParam));
  321. //上传给中心
  322. JObject joRegOut = invoker.invokeCenterService("2401", joRegIn);
  323. //将中心返回的结果返回HIS,调用HIS服务进行保存
  324. if (JsonHelper.parseCenterRtnValue(joRegOut,out errMsg) == 0)
  325. {
  326. joRegOut.Add("validflag",1);
  327. joRegOut.Add("regstate", 1);
  328. joRegOut.Add("type", 1);
  329. Global.pat.mdtrtID = JsonHelper.getDestValue(joRegOut, "output.result.mdtrt_id");
  330. //插入患者本次就诊用的参保信息
  331. if (hBus.insertPatCurInsuInfo(JsonHelper.getDestValue(joParam, "patientInfo"), out outParam) != 0)
  332. {
  333. if (DialogResult.Yes == MessageBox.Show(outParam, " 是否继续? ", MessageBoxButtons.YesNo))
  334. {
  335. }
  336. else
  337. {
  338. rtnResult = JsonHelper.setExceptionJson(-1, "插入患者本次就诊用的参保信息,请联系管理员!", outParam).ToString();
  339. return rtnResult;
  340. }
  341. }
  342. //插入医保平台
  343. if (mIS.saveInpatRegisterInfo(joRegIn_plain, joRegOut, out outParam) != 0)
  344. {
  345. rtnResult = JsonHelper.setExceptionJson(-1, "云平台保存登记信息", outParam).ToString();
  346. return rtnResult;
  347. }
  348. //返回登记信息,插入HIS
  349. if (hIS.returnRegisterInfo(joRegIn_plain, joRegOut, out outParam) != 0)
  350. {
  351. rtnResult = JsonHelper.setExceptionJson(-1, "HIS平台保存登记信息", outParam).ToString();
  352. return rtnResult;
  353. }
  354. else
  355. {
  356. rtnResult = JsonHelper.setIrisReturnValue(0, "登记成功", null).ToString();
  357. return rtnResult;
  358. }
  359. }
  360. else
  361. {
  362. rtnResult = JsonHelper.setExceptionJson(-1, "展示登记界面", errMsg).ToString();
  363. return rtnResult;
  364. }
  365. }
  366. else
  367. {
  368. rtnResult = JsonHelper.setExceptionJson(-1, "展示登记界面", regInParam).ToString();
  369. return rtnResult;
  370. }
  371. }
  372. case "Z2C"://入院登记取消
  373. {
  374. //if (DialogResult.Yes == MessageBox.Show("即将进行取消中心医保登记,确定继续吗?", " 询问? ", MessageBoxButtons.YesNo))
  375. //{
  376. //}
  377. //else
  378. //{
  379. // rtnResult = JsonHelper.setExceptionJson(-1, "收费员撤销取消登记操作!", outParam).ToString();
  380. // return rtnResult;
  381. //}
  382. //取消中心登记
  383. if (cBus.cancleRegister("2404", out outParam) != 0)
  384. {
  385. //如果医保中心没有HIS所传的医保登记信息则默认撤销HIS登记信息
  386. int i = outParam.IndexOf("不存在有效的就诊登记信息");
  387. if (i != 0)
  388. {
  389. if (DialogResult.Yes != MessageBox.Show("医保中心提示:" + outParam+ ",是否强制撤销HIS医保登记信息?", "提示", MessageBoxButtons.YesNo))
  390. {
  391. rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记失败,", outParam).ToString();
  392. return rtnResult;
  393. } else
  394. {
  395. rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记失败,", outParam).ToString();
  396. return rtnResult;
  397. }
  398. }
  399. }
  400. //取消医保平台登记
  401. if (mIS.cancleRegister(1, out outParam) != 0)
  402. {
  403. rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记成功,但云医保平台取消失败,", outParam).ToString();
  404. return rtnResult;
  405. }
  406. //取消HIS 登记
  407. if (hIS.cancleRegister( out outParam) != 0)
  408. {
  409. rtnResult = JsonHelper.setExceptionJson(-1, "中心和云医保平台取消登记成功,但HIS取消失败,", outParam).ToString();
  410. return rtnResult;
  411. }
  412. else
  413. {
  414. //CM 20230602 删除医保平台医保费用明细上传表数据
  415. mIS.deleteFee(out errMsg);
  416. rtnResult = JsonHelper.setIrisReturnValue(0, "取消医保登记成功", null).ToString();
  417. return rtnResult;
  418. }
  419. }
  420. case "Z6"://出院登记
  421. {
  422. break;
  423. }
  424. case "Z6C"://出院登记取消
  425. {
  426. if (cBus.cancleRegister("2405", out errMsg) != 0)
  427. {
  428. rtnResult = JsonHelper.setExceptionJson(-1, "取消出院登记", errMsg).ToString();
  429. return rtnResult;
  430. }
  431. else
  432. {
  433. rtnResult = JsonHelper.setIrisReturnValue(0, "取消出院登记成功", null).ToString();
  434. return rtnResult;
  435. }
  436. break;
  437. }
  438. default:
  439. {
  440. rtnResult = JsonHelper.setExceptionJson(-1, "Register 交易", "传入的业务编码不对!").ToString();
  441. return rtnResult;
  442. }
  443. }
  444. }
  445. catch (Exception ex)
  446. {
  447. rtnResult = JsonHelper.setIrisReturnValue(-1, "Register 发生异常;" + ex.Message, null).ToString();
  448. return rtnResult;
  449. }
  450. finally
  451. {
  452. Global.writeLog("Register 出参:" + JsonHelper.Compress(rtnResult));
  453. }
  454. return "";
  455. }
  456. /// <summary>
  457. /// 费用上传
  458. /// </summary>
  459. /// <param name="InParam"></param>
  460. /// <returns></returns>
  461. public string FeeUpload(string InParam)
  462. {
  463. Global.writeLog("FeeUpload 入参:" + JsonHelper.Compress(InParam));
  464. //设置返回值,错误信息
  465. int errCode;
  466. string errMsg, rtnResult = "", outParam;
  467. try
  468. {
  469. //解析入参
  470. if (parseInparam(InParam, out errMsg) != 0)
  471. {
  472. rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  473. return rtnResult;
  474. }
  475. //BS架构调用方式问题,每次调用都需要重新初始化
  476. if (init(InParam, out outParam) != 0)
  477. {
  478. rtnResult = outParam;
  479. return rtnResult;
  480. }
  481. //获取pat
  482. hBus.GetFeeHisInfo(businessType, joInParam, out Global.pat);
  483. switch (businessType)
  484. {
  485. case "M3"://门诊费用上传
  486. {
  487. break;
  488. }
  489. case "M3C"://门诊费用撤销
  490. {
  491. break;
  492. }
  493. case "Z3"://入院费用上传
  494. {
  495. ////事前分析
  496. if (Global.curEvt.ext.isOpenAnalysis)
  497. {
  498. if (hBus.PreAnalysis("4", "", out errMsg) != 0)
  499. {
  500. //rtnResult = JsonHelper.setExceptionJson(-1, "事前分析", errMsg).ToString();
  501. //return rtnResult;
  502. DialogResult dr = MessageBox.Show("【3101】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  503. if (dr != DialogResult.OK)
  504. {
  505. rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
  506. return rtnResult;
  507. }
  508. }
  509. }
  510. //从医保平台获取患者详细的医保登记信息
  511. if (mIS.queryRegisterInfo(1, out outParam) != 0)
  512. {
  513. rtnResult = JsonHelper.setExceptionJson(-1, "查询患者云平台登记信息", outParam).ToString();
  514. return rtnResult;
  515. }
  516. JObject joReg = JObject.Parse(outParam);
  517. Global.pat.medType = JsonHelper.getDestValue(joReg, "data.MedicalType");
  518. Global.pat.insuType = JsonHelper.getDestValue(joReg, "data.InsuType");
  519. //先取消中心费用传送
  520. cBus.cancleFeeUpload("2302", out errMsg);
  521. //再删除医保传送表的数据
  522. mIS.deleteFee( out errMsg);
  523. #region【住院费用上传前调用3101事前服务】
  524. //1.获取3101入参报文
  525. /* 20221207 CM 朱鹏飞要求屏蔽调用事前事中服务交易
  526. if (hIS.GetInsuPatInfo("5", Global.pat, out outParam) != 0)
  527. {
  528. rtnResult = JsonHelper.setExceptionJson(-1, "获取3101医保明细审核事前分析服务入参失败:", outParam).ToString();
  529. return rtnResult;
  530. }
  531. else
  532. {
  533. //2.调用医保3101明细审核事前分析服务
  534. JObject joInput = new JObject();
  535. joInput = JObject.Parse(outParam);
  536. JObject jo3101Rtn = invoker.invokeCenterService("3101", JsonHelper.setCenterInpar("3101", joInput.ToString().Replace("\r\n", "")));
  537. if (JsonHelper.parseCenterRtnValue(jo3101Rtn, out errMsg) != 0)
  538. {
  539. DialogResult dr = MessageBox.Show("【3101】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  540. if (dr != DialogResult.OK)
  541. {
  542. rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
  543. return rtnResult;
  544. }
  545. }
  546. }
  547. */
  548. #endregion
  549. //开始进行费用传送
  550. //调用HIS费用查询信息
  551. if (hIS.getHisFee(Global.pat, out outParam) != 0)
  552. {
  553. rtnResult = JsonHelper.setExceptionJson(-1, "获取HIS费用", outParam).ToString();
  554. return rtnResult;
  555. }
  556. //调用医保平台转换
  557. JObject joHisFee = JObject.Parse(outParam);
  558. if (mIS.convertHisFeeWithInsuCode(joHisFee,out outParam) != 0)
  559. {
  560. rtnResult = JsonHelper.setExceptionJson(-1, "转换HIS费用", outParam).ToString();
  561. return rtnResult;
  562. }
  563. JArray jaFeeDetail = JArray.Parse(JsonHelper.getDestValue(JObject.Parse(outParam), "data"));
  564. //按指定条数分割后上传,保存,更新
  565. if (hBus.uploadFeeToCenter("2301",10, jaFeeDetail, out outParam) != 0)
  566. {
  567. rtnResult = JsonHelper.setExceptionJson(-1, "上传费用", outParam).ToString();
  568. return rtnResult;
  569. }
  570. else
  571. {
  572. rtnResult = JsonHelper.setIrisReturnValue(0, "住院费用上传成功", null).ToString();
  573. return rtnResult;
  574. }
  575. }
  576. case "Z3C"://住院费用上传取消
  577. {
  578. if (cBus.cancleFeeUpload("2302", out errMsg) != 0)
  579. {
  580. rtnResult = JsonHelper.setExceptionJson(-1, "取消中心费用", errMsg).ToString();
  581. return rtnResult;
  582. }
  583. if (mIS.deleteFee( out errMsg) != 0)
  584. {
  585. rtnResult = JsonHelper.setExceptionJson(-1, "删除医保平台费用", errMsg).ToString();
  586. return rtnResult;
  587. }
  588. else
  589. {
  590. rtnResult = JsonHelper.setIrisReturnValue(0, "住院费用上传取消成功", null).ToString();
  591. return rtnResult;
  592. }
  593. }
  594. default:
  595. {
  596. rtnResult = JsonHelper.setExceptionJson(-1, "FeeUpload 交易", "传入的业务编码不对!").ToString();
  597. return rtnResult;
  598. }
  599. }
  600. return rtnResult;
  601. }
  602. catch (Exception ex)
  603. {
  604. rtnResult = JsonHelper.setExceptionJson(-1, "FeeUpload 交易", ex.Message).ToString();
  605. return rtnResult;
  606. }
  607. finally
  608. {
  609. Global.writeLog("FeeUpload 出参:" + JsonHelper.Compress(rtnResult));
  610. }
  611. }
  612. /// <summary>
  613. /// 结算
  614. /// </summary>
  615. /// <param name="InParam"></param>
  616. /// <returns></returns>
  617. public string Settlement(string InParam)
  618. {
  619. Global.writeLog("Settlement 入参:" + JsonHelper.Compress(InParam));
  620. //设置返回值,错误信息
  621. string errMsg, rtnResult = "", outParam;
  622. try
  623. {
  624. //解析入参
  625. if (parseInparam(InParam, out errMsg) != 0)
  626. {
  627. rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  628. return rtnResult;
  629. }
  630. //BS架构调用方式问题,每次调用都需要重新初始化
  631. if (init(InParam, out outParam) != 0)
  632. {
  633. rtnResult = outParam;
  634. return rtnResult;
  635. }
  636. //获取pat
  637. hBus.GetSettlementHisInfo(businessType, joInParam, out Global.pat);
  638. switch (businessType)
  639. {
  640. case "M4"://门诊预结算
  641. {
  642. OutpatientRegistration frmReg = new OutpatientRegistration();
  643. if (frmReg.ShowDialog() == DialogResult.OK)
  644. {
  645. rtnResult = "调用结束";
  646. }
  647. break;
  648. }
  649. case "M4C"://门诊预结算撤销
  650. {
  651. break;
  652. }
  653. case "M5"://门诊结算
  654. {
  655. Global.pat.admType = 1;
  656. string patInfo ="";
  657. //打开读卡窗口,操作员选择读卡类型后进行读卡器读卡,再进行1101获取参保信息
  658. if (hBus.readCard(out outParam) != 0)
  659. {
  660. rtnResult = JsonHelper.setExceptionJson(-100, "读卡失败!", outParam).ToString();
  661. return rtnResult;
  662. }
  663. else
  664. {
  665. patInfo = outParam;
  666. //展示患者信息界面
  667. if (hBus.showPatInfo(patInfo, out outParam) != 0)
  668. {
  669. rtnResult = outParam;
  670. return rtnResult;
  671. }
  672. }
  673. //患者信息赋值给全局变量
  674. patInfo = outParam;
  675. if (hBus.setGlobalPatAfaterShowPatInfo(patInfo, out errMsg) != 0)
  676. {
  677. rtnResult = JsonHelper.setExceptionJson(-1, "setGlobalPatAfaterShowPatInfo", errMsg).ToString();
  678. return rtnResult;
  679. }
  680. //校验HIS姓名与医保姓名是否一致
  681. if (hBus.checkName(Global.pat.name,out errMsg) != 0)
  682. {
  683. rtnResult = JsonHelper.setExceptionJson(-1, "校验HIS与医保姓名是否一致", errMsg).ToString();
  684. return rtnResult;
  685. }
  686. //弹窗提示患者是否正常参保
  687. hBus.InsuMessage(out string InsuMess);
  688. MessageBox.Show(InsuMess,"参保信息提示");
  689. ////事前分析
  690. if (Global.curEvt.ext.isOpenAnalysis)
  691. {
  692. if (hBus.PreAnalysis("2", "", out errMsg) != 0) //事前事中:门诊挂号1 门诊收费登记2 住院登记3 住院收费登记4 住院执行医嘱5 门诊结算6 门诊预结算7 住院结算8 住院预结算9 购药划卡10
  693. {
  694. //rtnResult = JsonHelper.setExceptionJson(-1, "事前分析", errMsg).ToString();
  695. //return rtnResult;
  696. DialogResult dr = MessageBox.Show("【3101】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  697. if (dr != DialogResult.OK)
  698. {
  699. rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事前分析服务调用失败:", errMsg).ToString();
  700. return rtnResult;
  701. }
  702. }
  703. }
  704. //显示登记面板
  705. if (hBus.showOutPatRegisterForm(out outParam) != 0)
  706. {
  707. rtnResult = JsonHelper.setExceptionJson(-1, "显示登记面板", outParam).ToString();
  708. return rtnResult;
  709. }
  710. JObject joReg = JObject.Parse(outParam);
  711. //医保挂号
  712. JObject jo2201Inpar = JObject.Parse(JsonHelper.getDestProperty(joReg, "data"));
  713. JObject jo2201Inpar_plain = JObject.Parse(JsonHelper.getDestProperty(joReg, "data"));
  714. jo2201Inpar = JObject.Parse(JsonHelper.setCenterInpar("2201", jo2201Inpar));
  715. jo2201Inpar_plain = JObject.Parse(JsonHelper.setCenterInpar_plain("2201", jo2201Inpar_plain));
  716. //此处先取到就诊信息上传的入参,只要挂号成功就保存到云HIS后台(保存后台需要用到2203入参)
  717. JObject jo2203Inpar = new JObject();
  718. JObject jo2203Inpar_plain = new JObject();
  719. jo2203Inpar.Add("mdtrtinfo", JObject.Parse(JsonHelper.getDestValue(joReg, "mdtrtinfo")));
  720. jo2203Inpar.Add("diseinfo",JArray.Parse(JsonHelper.getDestValue(joReg, "diseinfo")));
  721. JObject jo2201Rtn = invoker.invokeCenterService("2201", jo2201Inpar);
  722. if (JsonHelper.parseCenterRtnValue(jo2201Rtn, out errMsg) != 0)
  723. {
  724. rtnResult = JsonHelper.setExceptionJson(-1, "医保挂号", errMsg).ToString();
  725. return rtnResult;
  726. }
  727. else
  728. {
  729. Global.pat.mdtrtID = JsonHelper.getDestValue(jo2201Rtn, "output.data.mdtrt_id");
  730. //插入患者本次就诊用的参保信息
  731. if (hBus.insertPatCurInsuInfo(patInfo, out outParam) != 0)
  732. {
  733. if (DialogResult.Yes != MessageBox.Show(outParam, " 是否继续? ", MessageBoxButtons.YesNo))
  734. {
  735. rtnResult = JsonHelper.setExceptionJson(-1, "插入患者本次就诊用的参保信息,请联系管理员!是否继续?", outParam).ToString();
  736. return rtnResult;
  737. }
  738. }
  739. jo2203Inpar["mdtrtinfo"]["mdtrt_id"] = Global.pat.mdtrtID;
  740. jo2203Inpar_plain = JObject.Parse(JsonHelper.setCenterInpar_plain("2203", jo2203Inpar));
  741. jo2203Inpar = JObject.Parse(JsonHelper.setCenterInpar("2203", jo2203Inpar));
  742. //门诊登记信息,插入云医保平台
  743. jo2201Rtn.Add("validflag", 1);
  744. jo2201Rtn.Add("regstate", 1);
  745. jo2201Rtn.Add("type", 3);
  746. Global.writeLog(jo2201Inpar_plain.ToString());
  747. if (mIS.saveOutpatRegisterInfo(jo2201Inpar_plain, jo2201Rtn, jo2203Inpar_plain, out errMsg) != 0)
  748. {
  749. rtnResult = JsonHelper.setExceptionJson(-1, "中心登记成功但医保平台保存失败,请联系管理员!", errMsg).ToString();
  750. return rtnResult;
  751. }
  752. //返回登记信息,插入HIS
  753. /* if (hIS.returnRegisterInfo(jo2201Inpar_plain, jo2201Rtn, out outParam) != 0)
  754. {
  755. rtnResult = JsonHelper.setExceptionJson(-1, "HIS平台保存登记信息", outParam).ToString();
  756. return rtnResult;
  757. }
  758. else
  759. {
  760. rtnResult = JsonHelper.setIrisReturnValue(0, "登记成功", null).ToString();
  761. return rtnResult;
  762. }*/
  763. }
  764. //门诊就诊信息上传
  765. JObject jo2203Rtn = invoker.invokeCenterService("2203",jo2203Inpar );
  766. if (JsonHelper.parseCenterRtnValue(jo2203Rtn, out errMsg) != 0)
  767. {
  768. rtnResult = JsonHelper.setExceptionJson(-1, "门诊就诊信息上传", errMsg).ToString();
  769. return rtnResult;
  770. }
  771. #region【门诊就诊信息上传成功后调用3101事前服务】
  772. //1.获取3101入参报文
  773. /*
  774. if (hIS.GetInsuPatInfo("1", Global.pat, out outParam) != 0)
  775. {
  776. rtnResult = JsonHelper.setExceptionJson(-1, "获取3101医保明细审核事前分析服务入参失败:", outParam).ToString();
  777. return rtnResult;
  778. }
  779. else
  780. {
  781. //2.调用医保3101明细审核事前分析服务
  782. JObject joInput = new JObject();
  783. //joInput.Add("data", JObject.Parse(outParam));
  784. joInput = JObject.Parse(outParam);
  785. JObject jo3101Rtn = invoker.invokeCenterService("3101", JsonHelper.setCenterInpar("3101", joInput.ToString().Replace("\r\n", ""))); //.Replace(" ", "")
  786. if (JsonHelper.parseCenterRtnValue(jo3101Rtn, out errMsg) != 0)
  787. {
  788. DialogResult dr = MessageBox.Show("【3101】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  789. if (dr != DialogResult.OK)
  790. {
  791. rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
  792. return rtnResult;
  793. }
  794. }
  795. }
  796. */
  797. #endregion
  798. //费用上传
  799. if (hBus.uploadFee("2204", 50, out outParam) != 0)
  800. {
  801. rtnResult = JsonHelper.setExceptionJson(-1, "费用上传", outParam).ToString();
  802. return rtnResult;
  803. }
  804. #region【门诊预结算2206前调用3102医保明细审核事中服务】
  805. //1.获取3102入参报文
  806. /*
  807. if (hIS.GetInsuPatInfo("2", Global.pat, out outParam) != 0)
  808. {
  809. rtnResult = JsonHelper.setExceptionJson(-1, "获取3102医保明细审核事中分析服务入参失败:", outParam).ToString();
  810. return rtnResult;
  811. }
  812. else
  813. {
  814. //2.调用医保3102明细审核事前分析服务
  815. JObject joInput = new JObject();
  816. //joInput.Add("data", JObject.Parse(outParam));
  817. joInput = JObject.Parse(outParam);
  818. JObject jo3101Rtn = invoker.invokeCenterService("3102", JsonHelper.setCenterInpar("3102", joInput.ToString().Replace("\r\n", "")));
  819. if (JsonHelper.parseCenterRtnValue(jo3101Rtn, out errMsg) != 0)
  820. {
  821. DialogResult dr = MessageBox.Show("【3102】医保明细审核事中分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  822. if (dr != DialogResult.OK)
  823. {
  824. rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事中分析服务调用失败:", errMsg).ToString();
  825. return rtnResult;
  826. }
  827. }
  828. }
  829. */
  830. #endregion
  831. ////事中分析
  832. if (Global.curEvt.ext.isOpenAnalysis)
  833. {
  834. if (hBus.PreAnalysis("7", "", out errMsg) != 0) //事前事中:门诊挂号1 门诊收费登记2 住院登记3 住院收费登记4 住院执行医嘱5 门诊结算6 门诊预结算7 住院结算8 住院预结算9 购药划卡10
  835. {
  836. //rtnResult = JsonHelper.setExceptionJson(-1, "事前分析", errMsg).ToString();
  837. //return rtnResult;
  838. DialogResult dr = MessageBox.Show("【3102】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  839. if (dr != DialogResult.OK)
  840. {
  841. rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
  842. return rtnResult;
  843. }
  844. }
  845. }
  846. //调用IRIS获取医保各项金额
  847. if (mIS.getSumFee(out outParam) != 0)
  848. {
  849. rtnResult = JsonHelper.setExceptionJson(-1, "获取医保费用各项汇总金额", outParam).ToString();
  850. return rtnResult;
  851. }
  852. JObject joSumFee = JObject.Parse(outParam);
  853. JObject joSettlement = JObject.Parse(JsonHelper.getDestValue(joReg, "settlement"));
  854. //修改joSettlement的就诊ID ,总金额等
  855. joSettlement["mdtrt_id"] = Global.pat.mdtrtID;
  856. joSettlement["medfee_sumamt"] = JsonHelper.getDestValue(joSumFee, "data.Sumamt");
  857. //预结算2206
  858. if (hBus.preSettlement_OutPat(joSettlement, out outParam) != 0)
  859. {
  860. rtnResult = JsonHelper.setExceptionJson(-1, "结算信息展示", outParam).ToString();
  861. return rtnResult;
  862. }
  863. //正式结算
  864. JObject joData = new JObject();
  865. joData.Add("data",joSettlement);
  866. JObject joRtn = invoker.invokeCenterService("2207", JsonHelper.setCenterInpar("2207", joData));
  867. if (JsonHelper.parseCenterRtnValue(joRtn, out errMsg) != 0)
  868. {
  869. rtnResult = JsonHelper.setExceptionJson(-1, "结算失败", errMsg).ToString();
  870. return rtnResult;
  871. }
  872. else
  873. {
  874. //返回给云医保平台结算信息
  875. if (mIS.saveSettlement(joRtn, out errMsg) != 0)
  876. {
  877. rtnResult = JsonHelper.setExceptionJson(-1, "结算成功,但云医保平台保存失败", errMsg).ToString();
  878. return rtnResult;
  879. }
  880. //返回给云医保平台结算明细信息
  881. if (mIS.saveSettlementDetail(joRtn, out errMsg) != 0)
  882. {
  883. rtnResult = JsonHelper.setExceptionJson(-1, "云医保平台保存结算明细失败", errMsg).ToString();
  884. return rtnResult;
  885. }
  886. //返回给HIS
  887. JObject joSetlinfo = JObject.Parse(JsonHelper.getDestValue(joRtn, "output.setlinfo"));
  888. if (hIS.returnOutpatSettlementInfo(joSettlement, joSetlinfo, out outParam) != 0)
  889. {
  890. rtnResult = JsonHelper.setExceptionJson(-1, "返回结算信息给HIS", outParam).ToString();
  891. return rtnResult;
  892. }
  893. else
  894. {
  895. JObject joHisServieRtn = JObject.Parse(outParam);
  896. hBus.returnToFrontEndAfterSettlement(joRtn, joHisServieRtn, out outParam);
  897. rtnResult = JsonHelper.setIrisReturnValue(0, "结算成功", JObject.Parse(outParam)).ToString();
  898. return rtnResult;
  899. }
  900. }
  901. }
  902. case "M5C"://门诊结算撤销
  903. {
  904. //查询HIS医保结算记录表获取该病人的参保地
  905. string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE billType = 1 and ValidFlag = 1 ";
  906. sqlStr = sqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  907. sqlStr = sqlStr + " AND SettlementID ='" + Global.pat.settlID + "'";
  908. JObject joSql = new JObject();
  909. joSql.Add("sqlStr", sqlStr);
  910. JObject joSettlInfo = mIS.QuerySettlementInfo(joSql);
  911. //if (JsonHelper.parseIrisRtnValue(joSettlInfo, out errMsg) != 0)
  912. //{
  913. // rtnResult = JsonHelper.setExceptionJson(-1, "查询结算信息失败!", errMsg).ToString();
  914. // return rtnResult;
  915. //}
  916. Global.pat.insuplc_admdvs = JsonHelper.getDestValue(joSettlInfo, "result.data[0].insuplc_admdvs");
  917. //退中心结算
  918. string newSettleID = "";
  919. if (cBus.cancleSettlement("2208", out outParam) != 0)
  920. {
  921. int i = outParam.IndexOf("获取到的就诊信息为无效状态,不能办理结算撤销业务");
  922. if (i != 0)
  923. {
  924. if (DialogResult.Yes != MessageBox.Show("医保中心提示:" + outParam + ",是否强制撤销HIS结算信息?", "提示", MessageBoxButtons.YesNo))
  925. {
  926. rtnResult = JsonHelper.setExceptionJson(-1, "中心取消结算失败,", outParam).ToString();
  927. return rtnResult;
  928. }
  929. newSettleID = "YC";
  930. }
  931. else
  932. {
  933. rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算", outParam).ToString();
  934. //查看是医保平台是否已经退费,如果是,则询问是否继续退费
  935. string SqlStr = " SELECT * FROM BS_MedInsuSettlement WHERE ValidFlag = 0 AND BillType = -1 ";
  936. SqlStr = SqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  937. SqlStr = SqlStr + " AND SettlementID ='" + Global.pat.settlID + "'";
  938. JObject joSqlStr = new JObject();
  939. joSqlStr.Add("sqlStr", SqlStr);
  940. JObject joCancleSettlInfo = mIS.QuerySettlementInfo(joSqlStr);
  941. JArray jaCancleSettlInfo = JArray.Parse(JsonHelper.getDestValue(joCancleSettlInfo, "result.data"));
  942. if (jaCancleSettlInfo.Count == 1)
  943. {
  944. //询问收款员是否继续进行HIS退费
  945. if (DialogResult.Yes == MessageBox.Show("中心提示:" + outParam, " 该费用在医保中心已成功退费但在HIS未成功退费,是否强制退HIS费用? ", MessageBoxButtons.YesNo))
  946. {
  947. rtnResult = JsonHelper.setExceptionJson(0, "该费用在医保中心已成功退费但在HIS未成功退费,收款员选择强制退HIS费用!", outParam).ToString();
  948. }
  949. }
  950. else
  951. {
  952. rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算(云医保平台未退费或未查询到退费记录)", outParam).ToString();
  953. }
  954. return rtnResult;
  955. }
  956. }
  957. else
  958. {
  959. newSettleID = JsonHelper.getDestValue(JObject.Parse(outParam), "output.setlinfo.setl_id");
  960. }
  961. //string newSettleID = "10290453";
  962. //Global.pat.mdtrtID = "202210281547480034293700000000";
  963. //Global.pat.psn_no = "YX423049577";
  964. //Global.pat.settlID = "10290445";
  965. //退云医保平台结算
  966. if (mIS.cancleSettlement(newSettleID, out outParam) != 0)
  967. {
  968. rtnResult = JsonHelper.setExceptionJson(-1, "取消平台结算信息", outParam).ToString();
  969. //return rtnResult;
  970. }
  971. //中心取消传送
  972. if (cBus.cancleFeeUpload("2205", out errMsg) != 0)
  973. {
  974. rtnResult = JsonHelper.setExceptionJson(-1, "取消中心费用", errMsg).ToString();
  975. return rtnResult;
  976. }
  977. //云平台取消传送
  978. if (mIS.deleteFee(out errMsg) != 0)
  979. {
  980. rtnResult = JsonHelper.setExceptionJson(-1, "删除医保平台费用", errMsg).ToString();
  981. return rtnResult;
  982. }
  983. //取消中心登记
  984. if (cBus.cancleRegister("2202", out outParam) != 0)
  985. {
  986. rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记失败,", outParam).ToString();
  987. return rtnResult;
  988. }
  989. //取消医保平台登记
  990. if (mIS.cancleRegister(3, out outParam) != 0)
  991. {
  992. rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记成功,但云医保平台取消失败,", outParam).ToString();
  993. return rtnResult;
  994. }
  995. //退HIS结算
  996. if (hIS.cancleSettlementInfo(joParam, out outParam) != 0)
  997. {
  998. rtnResult = JsonHelper.setExceptionJson(-1, "取消HIS结算信息", outParam).ToString();
  999. return rtnResult;
  1000. }
  1001. else
  1002. {
  1003. rtnResult = JsonHelper.setIrisReturnValue(0, "取消结算成功", null).ToString();
  1004. return rtnResult;
  1005. }
  1006. }
  1007. case "M6"://门诊移动支付结算
  1008. {
  1009. MobilePay mp = new MobilePay(InParam, out errMsg);
  1010. if (errMsg != "")
  1011. {
  1012. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易1", errMsg).ToString();
  1013. return rtnResult;
  1014. }
  1015. if (mp.MobilePaySettlement(out outParam) != 0)
  1016. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易2", outParam).ToString();
  1017. else
  1018. rtnResult = outParam;
  1019. return rtnResult;
  1020. }
  1021. case "M6C"://门诊移动支付结算撤销
  1022. {
  1023. string onlineYBFalg = JsonHelper.getDestValue(joInsuAdmObj, "onlineYBFalg");
  1024. MobilePay mp = new MobilePay(InParam, out errMsg);
  1025. if (errMsg != "")
  1026. {
  1027. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易3", errMsg).ToString();
  1028. return rtnResult;
  1029. }
  1030. if (String.IsNullOrEmpty(onlineYBFalg))
  1031. mp.MSettl.onlineYBFalg = "N";
  1032. else
  1033. mp.MSettl.onlineYBFalg = onlineYBFalg;
  1034. if (mp.MobilePayCancelSettlement(out outParam) != 0)
  1035. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易4", outParam).ToString();
  1036. else
  1037. rtnResult = JsonHelper.setExceptionJson(0, "Settlement 交易5", outParam).ToString();
  1038. return rtnResult;
  1039. }
  1040. case "M6Confirm"://门诊移动支付确认
  1041. {
  1042. MobilePay mp = new MobilePay(InParam, out errMsg);
  1043. if (errMsg != "")
  1044. {
  1045. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易6", errMsg).ToString();
  1046. return rtnResult;
  1047. }
  1048. if (mp.MobilePayConfirmSettlement(out outParam) != 0)
  1049. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易7", outParam).ToString();
  1050. else
  1051. rtnResult = outParam;
  1052. return rtnResult;
  1053. }
  1054. case "M6CallBack"://门诊移动支付回调
  1055. {
  1056. JObject jo = JObject.Parse(InParam);
  1057. joInsuAdmObj = new JObject();
  1058. joInsuAdmObj.Add("payOrdId", "");
  1059. jo.Add("insuAdmObj", joInsuAdmObj);
  1060. MobilePay mp = new MobilePay(jo.ToString(), out errMsg);
  1061. if (errMsg != "")
  1062. {
  1063. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易8", errMsg).ToString();
  1064. return rtnResult;
  1065. }
  1066. if (mp.MobilePayCallbackSettlement(out outParam) != 0)
  1067. rtnResult = outParam;
  1068. else
  1069. rtnResult = outParam;
  1070. return rtnResult;
  1071. }
  1072. case "Z4"://住院预结算
  1073. {
  1074. #region【住院预结算2303前调用3102医保明细审核事中服务】
  1075. //1.获取3102入参报文
  1076. /*
  1077. if (hIS.GetInsuPatInfo("9", Global.pat, out outParam) != 0)
  1078. {
  1079. rtnResult = JsonHelper.setExceptionJson(-1, "获取3102医保明细审核事中分析服务入参失败:", outParam).ToString();
  1080. return rtnResult;
  1081. }
  1082. else
  1083. {
  1084. //2.调用医保3102明细审核事前分析服务
  1085. JObject joInput = new JObject();
  1086. joInput = JObject.Parse(outParam);
  1087. JObject jo3102Rtn = invoker.invokeCenterService("3102", JsonHelper.setCenterInpar("3102", joInput.ToString().Replace("\r\n", "")));
  1088. if (JsonHelper.parseCenterRtnValue(jo3102Rtn, out errMsg) != 0)
  1089. {
  1090. DialogResult dr = MessageBox.Show("【3102】医保明细审核事中分析服务医保中心返回结果2:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  1091. if (dr != DialogResult.OK)
  1092. {
  1093. rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事中分析服务调用失败:", errMsg).ToString();
  1094. return rtnResult;
  1095. }
  1096. }
  1097. }
  1098. */
  1099. #endregion
  1100. Global.pat.RYorCY = "2";
  1101. Global.pat.admType = 2;
  1102. JObject joSettle = new JObject();
  1103. if (hBus.preSettlement("2303",out joSettle, out outParam) != 0)
  1104. {
  1105. rtnResult = JsonHelper.setExceptionJson(-1, "结算信息展示", outParam).ToString();
  1106. return rtnResult;
  1107. }
  1108. else
  1109. {
  1110. rtnResult = JsonHelper.setIrisReturnValue(0, "预结算成功", null).ToString();
  1111. return rtnResult;
  1112. }
  1113. }
  1114. case "Z4C"://住院预结算撤销
  1115. {
  1116. rtnResult = JsonHelper.setExceptionJson(-100, "该接口不支持预结算取消!", null).ToString();
  1117. return rtnResult;
  1118. }
  1119. case "Z5"://住院结算
  1120. {
  1121. #region【住院预结算2303前调用3102医保明细审核事中服务】
  1122. //1.获取3102入参报文
  1123. /*
  1124. if (hIS.GetInsuPatInfo("9", Global.pat, out outParam) != 0)
  1125. {
  1126. rtnResult = JsonHelper.setExceptionJson(-1, "获取3102医保明细审核事中分析服务入参失败:", outParam).ToString();
  1127. return rtnResult;
  1128. }
  1129. else
  1130. {
  1131. //2.调用医保3102明细审核事前分析服务
  1132. JObject joInput = new JObject();
  1133. joInput = JObject.Parse(outParam);
  1134. JObject jo3102Rtn = invoker.invokeCenterService("3102", JsonHelper.setCenterInpar("3102", joInput.ToString().Replace("\r\n", "")));
  1135. if (JsonHelper.parseCenterRtnValue(jo3102Rtn, out errMsg) != 0)
  1136. {
  1137. DialogResult dr = MessageBox.Show("【3102】医保明细审核事中分析服务医保中心返回结果1:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  1138. if (dr != DialogResult.OK)
  1139. {
  1140. rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事中分析服务调用失败:", errMsg).ToString();
  1141. return rtnResult;
  1142. }
  1143. }
  1144. }
  1145. */
  1146. #endregion
  1147. #region【住院预结算2303前调用3102医保明细审核事中服务】
  1148. ////事中分析
  1149. if (Global.curEvt.ext.isOpenAnalysis)
  1150. {
  1151. if (hBus.PreAnalysis("9", "", out errMsg) != 0) //事前事中:门诊挂号1 门诊收费登记2 住院登记3 住院收费登记4 住院执行医嘱5 门诊结算6 门诊预结算7 住院结算8 住院预结算9 购药划卡10
  1152. {
  1153. //rtnResult = JsonHelper.setExceptionJson(-1, "事前分析", errMsg).ToString();
  1154. //return rtnResult;
  1155. DialogResult dr = MessageBox.Show("【3101】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  1156. if (dr != DialogResult.OK)
  1157. {
  1158. rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
  1159. return rtnResult;
  1160. }
  1161. }
  1162. }
  1163. #endregion
  1164. Global.pat.admType = 2;
  1165. Global.pat.RYorCY = "2";
  1166. JObject joPreSetOutpar ;
  1167. if (hBus.preSettlement("2303",out joPreSetOutpar, out outParam) != 0)
  1168. {
  1169. rtnResult = JsonHelper.setExceptionJson(-1, "结算信息展示", outParam).ToString();
  1170. return rtnResult;
  1171. }
  1172. else
  1173. {
  1174. JObject joSettlement = JObject.Parse(JsonHelper.getDestValue(joPreSetOutpar, "Settlement"));
  1175. ////出院登记
  1176. //JObject joDischargeRegister = JObject.Parse(JsonHelper.getDestValue(joPreSetOutpar, "DischargeRegister"));
  1177. //JObject jo2402Rtn = invoker.invokeCenterService("2402", JsonHelper.setCenterInpar("2402", joDischargeRegister));
  1178. //if (JsonHelper.parseCenterRtnValue(jo2402Rtn, out errMsg) != 0)
  1179. //{
  1180. // rtnResult = JsonHelper.setExceptionJson(-1, "结算失败", errMsg).ToString();
  1181. // return rtnResult;
  1182. //}
  1183. //正式结算
  1184. joSettlement.Add("data", joSettlement);
  1185. JObject jo2304Rtn = invoker.invokeCenterService("2304",JsonHelper.setCenterInpar("2304",joSettlement));
  1186. if (JsonHelper.parseCenterRtnValue(jo2304Rtn, out errMsg) != 0)
  1187. {
  1188. rtnResult = JsonHelper.setExceptionJson(-1, "结算失败", errMsg).ToString();
  1189. cBus.cancleRegister("2405", out errMsg);
  1190. return rtnResult;
  1191. }
  1192. else
  1193. {
  1194. //返回给云医保平台结算信息
  1195. if (mIS.saveSettlement(jo2304Rtn, out errMsg) != 0)
  1196. {
  1197. rtnResult = JsonHelper.setExceptionJson(-1, "结算成功,但云医保平台保存失败", errMsg).ToString();
  1198. return rtnResult;
  1199. }
  1200. //返回给云医保平台结算明细信息
  1201. if (mIS.saveSettlementDetail(jo2304Rtn, out errMsg) != 0)
  1202. {
  1203. rtnResult = JsonHelper.setExceptionJson(-1, "云医保平台保存结算明细失败", errMsg).ToString();
  1204. Global.writeLog(rtnResult);
  1205. MessageBox.Show(errMsg);
  1206. }
  1207. //返回给HIS
  1208. JObject joSetlinfo = JObject.Parse(JsonHelper.getDestValue(jo2304Rtn, "output.setlinfo"));
  1209. if (hIS.returnInpatSettlementInfo(joParam, joSetlinfo, out outParam) != 0)
  1210. {
  1211. rtnResult = JsonHelper.setExceptionJson(-1, "返回结算信息给HIS", outParam).ToString();
  1212. return rtnResult;
  1213. }
  1214. else
  1215. {
  1216. //返回给前端
  1217. JObject joHisServieRtn = JObject.Parse(outParam);
  1218. hBus.returnToFrontEndAfterSettlement(jo2304Rtn, joHisServieRtn, out outParam);
  1219. rtnResult = JsonHelper.setIrisReturnValue(0, "结算成功", JObject.Parse(outParam)).ToString();
  1220. return rtnResult;
  1221. }
  1222. }
  1223. }
  1224. }
  1225. case "Z5C"://住院结算撤销
  1226. {
  1227. //查询结算表
  1228. string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE billType = 1 and Hospital_Dr=" + Global.inf.hospitalDr
  1229. + " and Adm_Dr='" + Global.pat.adm_Dr + "'"
  1230. + " and MdtrtID='" + Global.pat.mdtrtID + "'"
  1231. + " Order By ID DESC ";
  1232. JObject joSql = new JObject();
  1233. joSql.Add("sqlStr", sqlStr);
  1234. JObject joSettlInfo = mIS.QuerySettlementInfo(joSql);
  1235. //if (JsonHelper.parseIrisRtnValue(joSettlInfo, out errMsg) != 0)
  1236. //{
  1237. // rtnResult = JsonHelper.setExceptionJson(-1, "查询结算信息失败!", errMsg).ToString();
  1238. // return rtnResult;
  1239. //}
  1240. //MessageBox.Show(joSettlInfo.ToString());
  1241. Global.pat.insuplc_admdvs = JsonHelper.getDestValue(joSettlInfo, "result.data[0].insuplc_admdvs");
  1242. Global.pat.SettID_YBJSB = JsonHelper.getDestValue(joSettlInfo, "result.data[0].SettlementID");
  1243. if (Global.pat.settlID != Global.pat.SettID_YBJSB)
  1244. {
  1245. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易", "通过09010059服务获取到的SettlementID<" + Global.pat.settlID + ">与DLL通过SQL语句" +
  1246. joSql + ",获取到的SettlementID<" + Global.pat.SettID_YBJSB + ">不同,可能存在HIS单边账,请联系医保开发人员处理该笔结算记录!").ToString();
  1247. //return rtnResult;
  1248. }
  1249. Global.pat.settlID = Global.pat.SettID_YBJSB;
  1250. //取消中心结算信息
  1251. if (cBus.cancleSettlement("2305", out outParam) != 0)
  1252. {
  1253. rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算信息失败!", outParam).ToString();
  1254. //查看是医保平台是否已经退费,如果是,则询问是否继续退费
  1255. string SqlStr = " SELECT * FROM BS_MedInsuSettlement WHERE ValidFlag = 0 AND BillType = -1 ";
  1256. SqlStr = SqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  1257. SqlStr = SqlStr + " AND SettlementID ='" + Global.pat.settlID + "'";
  1258. JObject joSqlStr = new JObject();
  1259. joSqlStr.Add("sqlStr", SqlStr);
  1260. JObject joCancleSettlInfo = mIS.QuerySettlementInfo(joSqlStr);
  1261. JArray jaCancleSettlInfo = JArray.Parse(JsonHelper.getDestValue(joCancleSettlInfo, "result.data"));
  1262. if (jaCancleSettlInfo.Count == 1)
  1263. {
  1264. //询问收款员是否继续进行HIS退费
  1265. if (DialogResult.Yes == MessageBox.Show("中心提示:" + outParam, " 该费用在医保中心已成功退费但在HIS未成功退费,是否强制退HIS费用? ", MessageBoxButtons.YesNo))
  1266. {
  1267. rtnResult = JsonHelper.setExceptionJson(0, "该费用在医保中心已成功退费但在HIS未成功退费,收款员选择强制退HIS费用!", outParam).ToString();
  1268. }
  1269. }
  1270. else
  1271. {
  1272. rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算(云医保平台未退费或未查询到退费记录)", outParam).ToString();
  1273. }
  1274. return rtnResult;
  1275. }
  1276. else
  1277. {
  1278. //退结算会返一个新的ID
  1279. string newSettleID = JsonHelper.getDestValue(JObject.Parse(outParam), "output.setlinfo.setl_id");
  1280. //取消平台结算信息
  1281. if (mIS.cancleSettlement(newSettleID, out outParam) != 0)
  1282. {
  1283. rtnResult = JsonHelper.setExceptionJson(-1, "中心结算取消成功,医保平台结算信息取消失败!", outParam).ToString();
  1284. return rtnResult;
  1285. }
  1286. //中心取消传送
  1287. if (cBus.cancleFeeUpload("2302", out errMsg) != 0)
  1288. {
  1289. //rtnResult = JsonHelper.setExceptionJson(-1, "取消中心费用", errMsg).ToString();
  1290. //return rtnResult;
  1291. }
  1292. //云平台取消传送
  1293. if (mIS.deleteFee(out errMsg) != 0)
  1294. {
  1295. //rtnResult = JsonHelper.setExceptionJson(-1, "删除医保平台费用", errMsg).ToString();
  1296. //return rtnResult;
  1297. }
  1298. //取消HIS医保结算信息
  1299. if (hIS.cancleSettlementInfo(joParam, out outParam) != 0)
  1300. {
  1301. rtnResult = JsonHelper.setExceptionJson(-1, "中心跟医保平台结算取消成功, 取消HIS结算信息失败!", outParam).ToString();
  1302. return rtnResult;
  1303. }
  1304. //取消出院登记
  1305. if (cBus.cancleRegister("2405", out outParam) != 0)
  1306. {
  1307. rtnResult = JsonHelper.setExceptionJson(0, "中心,医保平台及HIS结算信息取消成功,取消出院登记失败!请手工取消出院登记!", outParam).ToString();
  1308. return rtnResult;
  1309. }
  1310. rtnResult = JsonHelper.setIrisReturnValue(0, "取消结算成功", null).ToString();
  1311. return rtnResult;
  1312. }
  1313. }
  1314. default:
  1315. {
  1316. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易", "传入的业务编码不对!").ToString();
  1317. return rtnResult;
  1318. }
  1319. }
  1320. return rtnResult;
  1321. }
  1322. catch (Exception ex)
  1323. {
  1324. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易", ex.Message).ToString();
  1325. return rtnResult;
  1326. }
  1327. finally
  1328. {
  1329. Global.writeLog("Settlement 出参:" + JsonHelper.Compress(rtnResult));
  1330. }
  1331. }
  1332. //[STAThread]
  1333. //public void print(JObject joInParam)
  1334. //{
  1335. // //显示打印界面
  1336. // SettlementChecklist frmSettlList;
  1337. // string insuAdmObj = JsonHelper.getDestValue(joInParam, "insuAdmObj");
  1338. // if (insuAdmObj == "")
  1339. // {
  1340. // frmSettlList = new SettlementChecklist();
  1341. // }
  1342. // else
  1343. // {
  1344. // JObject joInsuAdmObj = JObject.Parse(insuAdmObj);
  1345. // frmSettlList = new SettlementChecklist(joInsuAdmObj);
  1346. // }
  1347. // if (frmSettlList.ShowDialog() == DialogResult.OK)
  1348. // {
  1349. // };
  1350. //}
  1351. //[STAThread]
  1352. /// <summary>
  1353. /// 辅助交易
  1354. /// </summary>
  1355. /// <param name="InParam"></param>
  1356. /// <returns></returns>
  1357. public string AgentFun(string InParam)
  1358. {
  1359. Global.writeLog("AgentFun 入参:" + JsonHelper.Compress(InParam));
  1360. //设置返回值,错误信息
  1361. int errCode;
  1362. string errMsg, rtnResult = "", outParam;
  1363. try
  1364. {
  1365. //解析入参
  1366. if (parseInparam(InParam, out errMsg) != 0)
  1367. {
  1368. rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  1369. return rtnResult;
  1370. }
  1371. //BS架构调用方式问题,每次调用都需要重新初始化
  1372. if (init(InParam, out outParam) != 0)
  1373. {
  1374. rtnResult = outParam;
  1375. return rtnResult;
  1376. }
  1377. //获取pat
  1378. //hBus.GetFeeHisInfo(businessType, joInParam, out Global.pat);
  1379. switch (businessType)
  1380. {
  1381. case "BasicData"://基础数据维护
  1382. {
  1383. BasicData bd = new BasicData();
  1384. if (bd.ShowDialog() != DialogResult.OK)
  1385. {
  1386. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出基础数据维护界面").ToString();
  1387. return rtnResult;
  1388. }
  1389. break;
  1390. }
  1391. case "Exception"://异常处理
  1392. {
  1393. //显示异常处理界面
  1394. HandleException frmEX = new HandleException();
  1395. if (frmEX.ShowDialog() != DialogResult.OK)
  1396. {
  1397. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出异常处理界面").ToString();
  1398. return rtnResult;
  1399. }
  1400. break;
  1401. }
  1402. case "CheckAndClearing"://对账清算
  1403. {
  1404. Clearing frmEX = new Clearing();
  1405. if (frmEX.ShowDialog() != DialogResult.OK)
  1406. {
  1407. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出对账清算界面").ToString();
  1408. return rtnResult;
  1409. }
  1410. break;
  1411. }
  1412. case "Print"://打印
  1413. {
  1414. //显示打印界面
  1415. SettlementChecklist frmSettlList;
  1416. string insuAdmObj = JsonHelper.getDestValue(joInParam, "insuAdmObj");
  1417. if (insuAdmObj == "")
  1418. {
  1419. frmSettlList = new SettlementChecklist();
  1420. if (frmSettlList.ShowDialog() != DialogResult.OK)
  1421. {
  1422. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出打印界面").ToString();
  1423. return rtnResult;
  1424. }
  1425. }
  1426. else
  1427. {
  1428. JObject joInsuAdmObj = JObject.Parse(insuAdmObj);
  1429. frmSettlList = new SettlementChecklist(joInsuAdmObj);
  1430. string groupID = JsonHelper.getDestValue((JObject)Global.curEvt.jaSession[0], "groupID");
  1431. string userName = JsonHelper.getDestValue((JObject)Global.curEvt.jaSession[0], "userName");
  1432. DataTable dt = (DataTable)frmSettlList.dgvSettlRecord.DataSource;
  1433. if (dt.Rows.Count != 1)
  1434. {
  1435. frmSettlList.ShowDialog();
  1436. }
  1437. else
  1438. {
  1439. frmSettlList.btnPrint_Click(null, null);
  1440. }
  1441. }
  1442. return JsonHelper.setIrisReturnValue(0, "", null).ToString();
  1443. break;
  1444. }
  1445. case "Log"://日志
  1446. {
  1447. MessageBox.Show(businessType);
  1448. break;
  1449. }
  1450. case "RecordUpload"://上传记录
  1451. {
  1452. MessageBox.Show(businessType);
  1453. break;
  1454. }
  1455. case "ToPutOnRecord"://医保备案相关
  1456. {
  1457. STA sta = new STA();
  1458. Thread thread = new Thread(sta.ToPutOnRecord);
  1459. thread.SetApartmentState(ApartmentState.STA); //重点
  1460. thread.IsBackground = true;
  1461. thread.Start();
  1462. thread.Join();
  1463. break;
  1464. }
  1465. case "MedInsuQuery"://医保查询
  1466. {
  1467. MedInsuQuery MedQuery = new MedInsuQuery();
  1468. if (MedQuery.ShowDialog() != DialogResult.OK)
  1469. {
  1470. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出医保查询界面").ToString();
  1471. return rtnResult;
  1472. }
  1473. break;
  1474. }
  1475. case "Appeal"://医保申诉
  1476. {
  1477. HopitalAppeal appeal = new HopitalAppeal();
  1478. if (appeal.ShowDialog() != DialogResult.OK)
  1479. {
  1480. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出医保申诉界面").ToString();
  1481. return rtnResult;
  1482. }
  1483. break;
  1484. }
  1485. case "PreAndInProcessAnalysis"://事前分析 诊间只有住院的事前分析
  1486. {
  1487. Global.pat.adm_Dr = int.Parse(JsonHelper.getDestValue(joInParam, "params[0].admID"));
  1488. Global.pat.adm_Dr = int.Parse(JsonHelper.getDestValue(joInParam, "params[0].admID"));
  1489. Global.pat.adm_Dr = int.Parse(JsonHelper.getDestValue(joInParam, "params[0].admID"));
  1490. JObject joResult = new JObject();
  1491. joResult.Add("result", JObject.Parse(JsonHelper.getDestValue(joParam, "insuData")));
  1492. //事前分析
  1493. if (Global.curEvt.ext.isOpenAnalysis)
  1494. {
  1495. if (hBus.PreAnalysis("5", joResult.ToString(), out errMsg) != 0)
  1496. {
  1497. MessageBox.Show(errMsg);
  1498. break;
  1499. }
  1500. }
  1501. break;
  1502. }
  1503. case "PrescribeCirculation"://医保处方流转
  1504. {
  1505. //显示医保处方流转界面
  1506. PrescriptionCirculation PresCir = new PrescriptionCirculation("");
  1507. if (PresCir.ShowDialog() != DialogResult.OK)
  1508. {
  1509. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出医保电子处方流转界面").ToString();
  1510. return rtnResult;
  1511. }
  1512. break;
  1513. }
  1514. case "Special"://就医特殊属性上传
  1515. {
  1516. SpecialPsn spec = new SpecialPsn();
  1517. if (spec.ShowDialog() != DialogResult.OK)
  1518. {
  1519. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出就医特殊属性上传界面").ToString();
  1520. return rtnResult;
  1521. }
  1522. break;
  1523. }
  1524. case "ElectronicSettlementCertificate":// 电子结算凭证上传
  1525. {
  1526. EcSettlCertMainForm ecCert = new EcSettlCertMainForm();
  1527. ecCert.ShowDialog();
  1528. break;
  1529. }
  1530. default:
  1531. {
  1532. rtnResult = JsonHelper.setExceptionJson(-1, "AgentFun 交易", "传入的业务编码不对!").ToString();
  1533. return rtnResult;
  1534. }
  1535. }
  1536. return rtnResult;
  1537. }
  1538. catch (Exception ex)
  1539. {
  1540. rtnResult = JsonHelper.setExceptionJson(-1, "AgentFun 交易", ex.Message).ToString();
  1541. return rtnResult;
  1542. }
  1543. finally
  1544. {
  1545. Global.writeLog("AgentFun 出参:" + JsonHelper.Compress(rtnResult));
  1546. }
  1547. }
  1548. public string Download(string InParam)
  1549. {
  1550. Global.writeLog("Download 入参:" + JsonHelper.Compress(InParam));
  1551. //设置返回值,错误信息
  1552. int errCode;
  1553. string errMsg, rtnResult = "", outParam;
  1554. try
  1555. {
  1556. //解析入参
  1557. if (parseInparam(InParam, out errMsg) != 0)
  1558. {
  1559. rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  1560. return rtnResult;
  1561. }
  1562. //BS架构调用方式问题,每次调用都需要重新初始化
  1563. if (init(InParam, out outParam) != 0)
  1564. {
  1565. rtnResult = outParam;
  1566. return rtnResult;
  1567. }
  1568. dynamic joData = new JObject();
  1569. joData.data = joParam["data"];
  1570. //string code = (string)joInParam["code"];
  1571. string funNO = (string)joParam["funNO"];
  1572. switch (businessType)
  1573. {
  1574. case "DirectoryDownload":
  1575. {
  1576. string downloadParam = JsonHelper.setCenterInpar(funNO, joData.ToString());
  1577. rtnResult = hBus.DownloadDirectory(funNO, downloadParam).ToString();
  1578. break;
  1579. }
  1580. case "DictionayDownload":
  1581. {
  1582. string downloadParam = JsonHelper.setCenterInpar(funNO, joData.ToString());
  1583. rtnResult = hBus.downDictionary(downloadParam);
  1584. break;
  1585. }
  1586. }
  1587. return rtnResult;
  1588. }
  1589. catch (Exception ex)
  1590. {
  1591. rtnResult = JsonHelper.setExceptionJson(-100, "Download", ex.Message).ToString();
  1592. return rtnResult;
  1593. }
  1594. finally
  1595. {
  1596. Global.writeLog("Download 出参:" + rtnResult);
  1597. }
  1598. }
  1599. public string PlatformDirectConnect(string InParam)
  1600. {
  1601. //设置返回值,错误信息
  1602. int errCode;
  1603. string errMsg, rtnResult = "", outParam;
  1604. try
  1605. {
  1606. Global.writeLog("PlatformDirectConnect 入参:" + JsonHelper.Compress(InParam));
  1607. //解析入参
  1608. if (parseInparam(InParam, out errMsg) != 0)
  1609. {
  1610. rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  1611. return rtnResult;
  1612. }
  1613. Global.businessType = businessType;
  1614. string funNO = JsonHelper.getDestValue(joInParam, "funNO");
  1615. //BS架构调用方式问题,每次调用都需要重新初始化
  1616. if (init(InParam, out outParam) != 0)
  1617. {
  1618. rtnResult = outParam;
  1619. return rtnResult;
  1620. }
  1621. JObject joRtn;
  1622. string[] strArr = { "3501", "3502", "3503", "3504", "3505", "3506", "3507" };//进销存交易
  1623. bool exists = ((IList)strArr).Contains(funNO);
  1624. if (exists)
  1625. {
  1626. //解析入参
  1627. if (parsejoParam(joParam, funNO, out errMsg) != 0)
  1628. {
  1629. rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  1630. return rtnResult;
  1631. }
  1632. //if (funNO == "3505")
  1633. //{
  1634. // //解析入参
  1635. // if (parsejoParamSet(joParam, funNO, out errMsg) != 0)
  1636. // {
  1637. // rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  1638. // return rtnResult;
  1639. // }
  1640. // invoker.invokeCenterServiceJXC("992001", JObject.Parse(JsonHelper.setCenterInpar("992001", joParam992001)));//结算信息上传
  1641. // invoker.invokeCenterServiceJXC("992004", JObject.Parse(JsonHelper.setCenterInpar("992004", joParam992004)));//结算费用明细上传
  1642. //}
  1643. //if (funNO == "3506")
  1644. //{
  1645. // invoker.invokeCenterServiceJXC("992002", JObject.Parse(JsonHelper.setCenterInpar("992002", joParam992001)));//结算退费信息上传
  1646. // invoker.invokeCenterServiceJXC("992004", JObject.Parse(JsonHelper.setCenterInpar("992004", joParam992004)));//结算退费费用明细上传
  1647. //}
  1648. joRtn = invoker.invokeCenterServiceJXC(funNO, JObject.Parse(JsonHelper.setCenterInpar(funNO, joParam)));
  1649. string funNOA = funNO + 'A';
  1650. joRtn = invoker.invokeCenterService(funNOA, JsonHelper.setCenterInpar(funNOA, joParamA));
  1651. }
  1652. else //非进销存交易
  1653. {
  1654. if (funNO== "I2002")
  1655. {
  1656. joRtn = invoker.invokeCenterServiceFZJK("I2002", joParam);//追溯码辅助接口
  1657. }
  1658. else {
  1659. joRtn = invoker.invokeCenterService(funNO, JsonHelper.setCenterInpar(funNO, joParam));//正常交易走医保COM组件
  1660. }
  1661. }
  1662. if (JsonHelper.parseCenterRtnValue(joRtn, out errMsg) != 0)
  1663. {
  1664. rtnResult = JsonHelper.setExceptionJson(-1, "平台直连错误", errMsg).ToString();
  1665. return rtnResult;
  1666. }
  1667. else
  1668. {
  1669. rtnResult = JsonHelper.setIrisReturnValue(0, "", joRtn).ToString();
  1670. return rtnResult;
  1671. }
  1672. }
  1673. catch (Exception ex)
  1674. {
  1675. rtnResult = JsonHelper.setExceptionJson(-1, "PlatformDirectConnect 交易", ex.Message).ToString();
  1676. return rtnResult;
  1677. }
  1678. finally
  1679. {
  1680. Global.writeLog("PlatformDirectConnect 出参:" + JsonHelper.Compress(rtnResult));
  1681. }
  1682. }
  1683. private int parsejoParam(JObject joParam,string funno,out string errMsg)
  1684. {
  1685. errMsg = "";
  1686. try
  1687. {
  1688. if (funno == "3505"|| funno == "3506")
  1689. {
  1690. if (!string.IsNullOrEmpty(joParam["selinfo"]["setl_id"].ToString()))
  1691. {
  1692. if (joParam["selinfo"]["setl_id"].ToString().Substring(0, 4) == "4299" || joParam["selinfo"]["setl_id"].ToString().Substring(0, 4) == "4201")
  1693. {
  1694. joParam["selinfo"]["hi_feesetl_type"] = "1";
  1695. }
  1696. else
  1697. {
  1698. joParam["selinfo"]["hi_feesetl_type"] = "2";
  1699. }
  1700. }
  1701. else
  1702. {
  1703. joParam["selinfo"]["hi_feesetl_type"] = "0";
  1704. }
  1705. JObject joRtn = JObject.Parse(joParam["selinfo"].ToString());
  1706. //if (!string.IsNullOrEmpty(joParam["selinfo"]["drugtracinfo"].ToString()))
  1707. //{
  1708. // joRtn.Add("drug_trac_info", joParam["selinfo"]["drugtracinfo"]);
  1709. // joParam["selinfo"] = joRtn;
  1710. //}
  1711. //MessageBox.Show("111");
  1712. //MessageBox.Show(joParam.ToString());
  1713. JArray selDtl = new JArray();
  1714. selDtl.Add(JObject.Parse(joParam["selinfo"].ToString()));
  1715. //MessageBox.Show(selDtl.ToString());
  1716. joParamA = new JObject();
  1717. joParamA.Add("selinfoDetail", selDtl);
  1718. //MessageBox.Show(joParamA.ToString());
  1719. return 0;
  1720. }
  1721. else if (funno == "3501")
  1722. {
  1723. JObject joRtn = JObject.Parse(joParam["invinfo"].ToString());
  1724. //if (!string.IsNullOrEmpty(joParam["invinfo"]["drugtracinfo"].ToString()))
  1725. //{
  1726. // joRtn.Add("drug_trac_info", joParam["invinfo"]["drugtracinfo"]);
  1727. // joParam["invinfo"] = joRtn;
  1728. //}
  1729. JArray selDtl = new JArray();
  1730. selDtl.Add(JObject.Parse(joParam["invinfo"].ToString()));
  1731. //MessageBox.Show(selDtl.ToString());
  1732. joParamA = new JObject();
  1733. joParamA.Add("invinfoDetail", selDtl);
  1734. return 0;
  1735. }
  1736. else if (funno == "3502")
  1737. {
  1738. JObject joRtn = JObject.Parse(joParam["invinfo"].ToString());
  1739. //if (!string.IsNullOrEmpty(joParam["invinfo"]["drugtracinfo"].ToString()))
  1740. //{
  1741. // joRtn.Add("drug_trac_info", joParam["invinfo"]["drugtracinfo"]);
  1742. // joParam["invinfo"] = joRtn;
  1743. //}
  1744. JArray selDtl = new JArray();
  1745. selDtl.Add(JObject.Parse(joParam["invinfo"].ToString()));
  1746. //MessageBox.Show(selDtl.ToString());
  1747. joParamA = new JObject();
  1748. joParamA.Add("invinfoDetail", selDtl);
  1749. return 0;
  1750. }
  1751. else if (funno == "3503")
  1752. {
  1753. JObject joRtn = JObject.Parse(joParam["purcinfo"].ToString());
  1754. //if (!string.IsNullOrEmpty(joParam["purcinfo"]["drugtracinfo"].ToString()))
  1755. //{
  1756. // joRtn.Add("drug_trac_info", joParam["purcinfo"]["drugtracinfo"]);
  1757. // joParam["purcinfo"] = joRtn;
  1758. //}
  1759. JArray selDtl = new JArray();
  1760. selDtl.Add(JObject.Parse(joParam["purcinfo"].ToString()));
  1761. //MessageBox.Show(selDtl.ToString());
  1762. joParamA = new JObject();
  1763. joParamA.Add("purcinfoDetail", selDtl);
  1764. return 0;
  1765. }
  1766. else if ( funno == "3504")
  1767. {
  1768. JObject joRtn = JObject.Parse(joParam["purcinfo"].ToString());
  1769. //if (!string.IsNullOrEmpty(joParam["purcinfo"]["drugtracinfo"].ToString()))
  1770. //{
  1771. // joRtn.Add("drug_trac_info", joParam["purcinfo"]["drugtracinfo"]);
  1772. // joParam["purcinfo"] = joRtn;
  1773. //}
  1774. JArray selDtl = new JArray();
  1775. selDtl.Add(JObject.Parse(joParam["purcinfo"].ToString()));
  1776. //MessageBox.Show(selDtl.ToString());
  1777. joParamA = new JObject();
  1778. joParamA.Add("purcinfoDetail", selDtl);
  1779. return 0;
  1780. }
  1781. else { return -1; }
  1782. }
  1783. catch (Exception ex)
  1784. {
  1785. errMsg = "parsejoParam 解析入参异常1:" + errMsg;
  1786. return -1;
  1787. }
  1788. }
  1789. private int parsejoParamSet(JObject joParam, string funno, out string errMsg)
  1790. {
  1791. errMsg = "";
  1792. try
  1793. {
  1794. if (funno == "3505")
  1795. {
  1796. string setl_id = joParam["selinfo"]["setl_id"].ToString();
  1797. string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE billType = 1 ";
  1798. sqlStr = sqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  1799. sqlStr = sqlStr + " AND SettlementID ='" + setl_id + "'";
  1800. JObject joSql = new JObject();
  1801. joSql.Add("sqlStr", sqlStr);
  1802. JObject joSettlInfo = mIS.QuerySettlementInfo(joSql);
  1803. //查询结算信息
  1804. JObject Outpam = JObject.Parse(joSettlInfo["result"]["data"][0].ToString());
  1805. dynamic setlinfo = new JObject();//结算信息节点
  1806. setlinfo.setl_id = Outpam["SettlementID"];//结算ID
  1807. setlinfo.mdtrt_id = Outpam["MdtrtID"];//就诊ID
  1808. setlinfo.psn_no = Outpam["PersonnelNO"];//人员编号
  1809. setlinfo.psn_name = Outpam["PatientName"];//人员姓名
  1810. setlinfo.psn_cert_type = Outpam["MdtrtCertType"];//凭证类型
  1811. setlinfo.certno = Outpam["CertificateNO"];//证件号码
  1812. setlinfo.gend = Outpam["Gender"];//性别
  1813. setlinfo.naty = Outpam["Nation"];//民族
  1814. setlinfo.brdy = Outpam["BirthDay"];//出生日期
  1815. setlinfo.age = Outpam["Age"];//年龄
  1816. setlinfo.insutype = Outpam["InsuranceType"];//险种类型
  1817. setlinfo.psn_type = Outpam["PersonType"];//人员类别
  1818. setlinfo.cvlserv_flag = Outpam["CivilserviceFlag"];//公务员标志
  1819. setlinfo.setl_time = Outpam["SettlementTime"];//结算时间
  1820. setlinfo.mdtrt_cert_type = Outpam["MdtrtCertType"];//就诊凭证类型
  1821. setlinfo.med_type = Outpam["MedicalType"];//医疗类别
  1822. setlinfo.medfee_sumamt = Outpam["Sumamt"];//医疗费总额
  1823. setlinfo.fulamt_ownpay_amt = Outpam["OwnPayAmount"];//全自费金额
  1824. setlinfo.overlmt_selfpay = Outpam["OverLimitAmount"];//超限价自费费用
  1825. setlinfo.preselfpay_amt = Outpam["PreSelfPayAmount"];//先行自付金额
  1826. setlinfo.inscp_scp_amt = Outpam["InPolicyRangeAmount"];//符合政策范围金额
  1827. setlinfo.act_pay_dedc = Outpam["ActualPayDeductible"];//实际支付起付线
  1828. setlinfo.hifp_pay = Outpam["HealthInsurancePay"];//基本医疗保险统筹基金支出
  1829. setlinfo.pool_prop_selfpay = Outpam["HealthInsuranceRatio"];//基本医疗保险统筹基金支付比例
  1830. setlinfo.cvlserv_pay = Outpam["CivilserviceAllowancePay"];//公务员医疗补助资金支出
  1831. setlinfo.hifes_pay = Outpam["EnterpriseSupplementPay"];//企业补充医疗保险基金支出
  1832. setlinfo.hifmi_pay = Outpam["SeriousIllnessPay"];//居民大病保险资金支出
  1833. setlinfo.hifob_pay = Outpam["LargeExpensesSupplementPay"];//职工大额医疗费用补助基金支出
  1834. setlinfo.maf_pay = Outpam["MedicalAssistPay"];//医疗救助基金支出
  1835. setlinfo.oth_pay = Outpam["OtherPay"];//结算ID
  1836. setlinfo.fund_pay_sumamt = Outpam["FundPaySumamt"];//基金支付总额
  1837. setlinfo.psn_part_amt = Outpam["PersonPaySumamt"];//个人负担总金额
  1838. setlinfo.acct_pay = Outpam["AccountPaySumamt"];//个人账户支出
  1839. setlinfo.psn_cash_pay = Outpam["PersonCashPay"];//个人现金支出
  1840. setlinfo.balc = Outpam["Balance"];//余额
  1841. setlinfo.acct_mulaid_pay = Outpam["AccountMutualAidAmount"];//个人账户共济支付金额
  1842. setlinfo.medins_setl_id = Outpam["OrganSettlementID"];//医药机构结算结算ID
  1843. setlinfo.clr_optins = Outpam["ClearingOrgan"];//clr_optins
  1844. setlinfo.clr_way = Outpam["ClearingWay"];//clr_way
  1845. setlinfo.clr_type = Outpam["ClearingType"];//clr_type
  1846. setlinfo.exp_content = "";//exp_content
  1847. setlinfo.hosp_part_amt = Outpam["HospitalPartAmount"];//医院负担金额
  1848. setlinfo.hifdm_pay = 0;//伤残人员医疗保障基金支出
  1849. dynamic setlinfo1 = new JObject();//结算信息节点
  1850. setlinfo1.setl_id = Outpam["SettlementID"];//结算ID
  1851. string outParam = "";
  1852. string AdmID = Outpam["AdmID"].ToString();
  1853. string billID = Outpam["BillID"].ToString();
  1854. string recordID = Outpam["RecordID"].ToString();
  1855. Global.pat.adm_Dr = int.Parse(AdmID);
  1856. Global.pat.billID = billID;
  1857. Global.pat.recordID = recordID;
  1858. //获取IS费用
  1859. if (hIS.getHisFee(Global.pat, out outParam) != 0)
  1860. {
  1861. MessageBox.Show("获取HIS费用失败");
  1862. }
  1863. //调用医保平台转换HIS费用(转换医保编码等)
  1864. JObject joHisFee = JObject.Parse(outParam);
  1865. if (mIS.convertHisFeeWithInsuCode(joHisFee, out outParam) != 0)
  1866. {
  1867. MessageBox.Show("获取HIS费用医保对照关系失败");
  1868. }
  1869. JArray jaFeeDetail = JArray.Parse(JsonHelper.getDestValue(JObject.Parse(outParam), "data"));
  1870. MessageBox.Show("11111");
  1871. JObject jaFeeOne = new JObject();
  1872. for (int i = 0; i < jaFeeDetail.Count; i++)
  1873. {
  1874. jaFeeOne.Add("feedetl_sn", jaFeeDetail[i]["feedetl_sn"]);//费用明细流水号
  1875. jaFeeOne.Add("rxno", "");//处方号
  1876. if (string.IsNullOrEmpty(jaFeeDetail[i]["rx_circ_flag"].ToString()))
  1877. {
  1878. jaFeeOne.Add("rx_circ_flag", "");//外购处方标志
  1879. }
  1880. else
  1881. {
  1882. jaFeeOne.Add("rx_circ_flag", jaFeeDetail[i]["rx_circ_flag"]);//外购处方标志
  1883. }
  1884. jaFeeOne.Add("fee_ocur_time", jaFeeDetail[i]["fee_ocur_time"]);
  1885. jaFeeOne.Add("med_list_codg", jaFeeDetail[i]["med_list_codg"]);
  1886. jaFeeOne.Add("medins_list_codg", jaFeeDetail[i]["medins_list_codg"]);
  1887. jaFeeOne.Add("medins_list_name", jaFeeDetail[i]["medins_list_desc"]);
  1888. jaFeeOne.Add("prodname", jaFeeDetail[i]["medins_list_desc"]);
  1889. if (string.IsNullOrEmpty(jaFeeDetail[i]["spec"].ToString()))
  1890. {
  1891. jaFeeOne.Add("spec", "");
  1892. }
  1893. else
  1894. {
  1895. jaFeeOne.Add("spec", jaFeeDetail[i]["spec"]);
  1896. }
  1897. if (string.IsNullOrEmpty(jaFeeDetail[i]["doseForm"].ToString()))
  1898. {
  1899. jaFeeOne.Add("dosform_name", "");
  1900. }
  1901. else
  1902. {
  1903. jaFeeOne.Add("dosform_name", jaFeeDetail[i]["doseForm"]);
  1904. }
  1905. jaFeeOne.Add(" det_item_fee_sumamt", jaFeeDetail[i]["det_item_fee_sumamt"]);
  1906. jaFeeOne.Add("cnt", jaFeeDetail[i]["cnt"]);
  1907. jaFeeOne.Add("pric", jaFeeDetail[i]["pric"]);
  1908. if (string.IsNullOrEmpty(jaFeeDetail[i]["sin_dos_dscr"].ToString()))
  1909. {
  1910. jaFeeOne.Add("sin_dos_dscr", "");
  1911. }
  1912. else
  1913. {
  1914. jaFeeOne.Add("sin_dos_dscr", jaFeeDetail[i]["sin_dos_dscr"]);
  1915. }
  1916. if (string.IsNullOrEmpty(jaFeeDetail[i]["used_frqu_dscr"].ToString()))
  1917. {
  1918. jaFeeOne.Add("used_frqu_dscr", "");
  1919. }
  1920. else
  1921. {
  1922. jaFeeOne.Add("used_frqu_dscr", jaFeeDetail[i]["used_frqu_dscr"]);
  1923. }
  1924. if (string.IsNullOrEmpty(jaFeeDetail[i]["prd_days"].ToString()))
  1925. {
  1926. jaFeeOne.Add("prd_days", "");
  1927. }
  1928. else
  1929. {
  1930. jaFeeOne.Add("prd_days", jaFeeDetail[i]["prd_days"]);
  1931. }
  1932. if (string.IsNullOrEmpty(jaFeeDetail[i]["medc_way_dscr"].ToString()))
  1933. {
  1934. jaFeeOne.Add("medc_way_dscr", "");
  1935. }
  1936. else
  1937. {
  1938. jaFeeOne.Add("medc_way_dscr", jaFeeDetail[i]["medc_way_dscr"]);
  1939. }
  1940. if (string.IsNullOrEmpty(jaFeeDetail[i]["bilg_dr_codg"].ToString()))
  1941. {
  1942. jaFeeOne.Add("bilg_dr_codg", "");
  1943. }
  1944. else
  1945. {
  1946. jaFeeOne.Add("bilg_dr_codg", jaFeeDetail[i]["bilg_dr_codg"]);
  1947. }
  1948. if (string.IsNullOrEmpty(jaFeeDetail[i]["bilg_dr_name"].ToString()))
  1949. {
  1950. jaFeeOne.Add("bilg_dr_name", "");
  1951. }
  1952. else
  1953. {
  1954. jaFeeOne.Add("bilg_dr_name", jaFeeDetail[i]["bilg_dr_name"]);
  1955. }
  1956. jaFeeOne.Add("phar_name", "");
  1957. jaFeeOne.Add("phar_prac_cert_no", "");
  1958. jaFeeOne.Add("tcmdrug_used_way", ""); //中药使用方式 1复方 2单方 必填
  1959. jaFeeOne.Add("trdn_flag", "1");//拆零标志 必填 0否 1是
  1960. jaFeeDetail.Add(jaFeeOne);
  1961. jaFeeOne = new JObject();
  1962. }
  1963. MessageBox.Show("22222");
  1964. joParam992001.Add("setlinfo", JObject.Parse(setlinfo));//结算信息节点
  1965. joParam992004.Add("setlinfo", JObject.Parse(setlinfo1));
  1966. joParam992004.Add("drugdetail", jaFeeDetail);//购药明细节点
  1967. //JObject OutJo = invoker.invokeCenterServiceJXC("992001", JObject.Parse(JsonHelper.setCenterInpar("992001", Jo992001)));
  1968. //MessageBox.Show("上传返回:" + OutJo.ToString());
  1969. }
  1970. if (funno == "3506")
  1971. {
  1972. string setl_id = joParam["selinfo"]["setl_id"].ToString();
  1973. string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE billType = -1 ";
  1974. sqlStr = sqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  1975. sqlStr = sqlStr + " AND SettlementID ='" + setl_id + "'";
  1976. JObject joSql = new JObject();
  1977. joSql.Add("sqlStr", sqlStr);
  1978. JObject joSettlInfo = mIS.QuerySettlementInfo(joSql);
  1979. //查询结算信息
  1980. JObject Outpam = JObject.Parse(joSettlInfo["result"]["data"][0].ToString());
  1981. string mdtrt_id = Outpam["MdtrtID"].ToString();//ADMID
  1982. string sqlStr1 = "SELECT * FROM BS_MedInsuSettlement WHERE billType = 1 ";
  1983. sqlStr1 = sqlStr1 + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  1984. sqlStr1 = sqlStr1 + " AND MdtrtID ='" + mdtrt_id + "'";
  1985. JObject joSql1 = new JObject();
  1986. joSql1.Add("sqlStr1", sqlStr);
  1987. JObject joSettlInfo1 = mIS.QuerySettlementInfo(joSql1);
  1988. JObject Outpam1= JObject.Parse(joSettlInfo1["result"]["data"][0].ToString());
  1989. dynamic setlinfo = new JObject();//结算信息节点
  1990. setlinfo.setl_id = Outpam["SettlementID"];//结算ID
  1991. setlinfo.init_setl_id = Outpam1["SettlementID"]; ;//结算ID
  1992. setlinfo.setl_time = Outpam["SettlementTime"];//结算时间
  1993. setlinfo.mdtrt_id = Outpam["MdtrtID"];//就诊ID
  1994. setlinfo.psn_no = Outpam["PersonnelNO"];//人员编号
  1995. setlinfo.exp_content = "";//人员姓名
  1996. dynamic setlinfo1 = new JObject();//结算信息节点
  1997. setlinfo1.setl_id = Outpam["SettlementID"];//结算ID
  1998. joParam992002.Add("data", JObject.Parse(setlinfo));//结算信息节点
  1999. string AdmID = Outpam["AdmID"].ToString();
  2000. string billID = Outpam["BillID"].ToString();
  2001. string recordID = Outpam["RecordID"].ToString();
  2002. Global.pat.adm_Dr = int.Parse(AdmID);
  2003. Global.pat.billID = billID;
  2004. Global.pat.recordID = recordID;
  2005. string outParam = "";
  2006. //获取IS费用
  2007. if (hIS.getHisFee(Global.pat, out outParam) != 0)
  2008. {
  2009. MessageBox.Show("获取HIS费用失败");
  2010. }
  2011. //调用医保平台转换HIS费用(转换医保编码等)
  2012. JObject joHisFee = JObject.Parse(outParam);
  2013. if (mIS.convertHisFeeWithInsuCode(joHisFee, out outParam) != 0)
  2014. {
  2015. MessageBox.Show("获取HIS费用医保对照关系失败");
  2016. }
  2017. JArray jaFeeDetail = JArray.Parse(JsonHelper.getDestValue(JObject.Parse(outParam), "data"));
  2018. JObject jaFeeOne = new JObject();
  2019. for (int i = 0; i < jaFeeDetail.Count; i++)
  2020. {
  2021. jaFeeOne.Add("feedetl_sn", jaFeeDetail[i]["feedetl_sn"]);//费用明细流水号
  2022. jaFeeOne.Add("rxno", "");//处方号
  2023. if (string.IsNullOrEmpty(jaFeeDetail[i]["rx_circ_flag"].ToString()))
  2024. {
  2025. jaFeeOne.Add("rx_circ_flag", "");//外购处方标志
  2026. }else {
  2027. jaFeeOne.Add("rx_circ_flag", jaFeeDetail[i]["rx_circ_flag"]);//外购处方标志
  2028. }
  2029. jaFeeOne.Add("fee_ocur_time", jaFeeDetail[i]["fee_ocur_time"]);
  2030. jaFeeOne.Add("med_list_codg", jaFeeDetail[i]["med_list_codg"]);
  2031. jaFeeOne.Add("medins_list_codg", jaFeeDetail[i]["medins_list_codg"]);
  2032. jaFeeOne.Add("medins_list_name", jaFeeDetail[i]["medins_list_desc"]);
  2033. jaFeeOne.Add("prodname", jaFeeDetail[i]["medins_list_desc"]);
  2034. if (string.IsNullOrEmpty(jaFeeDetail[i]["spec"].ToString()))
  2035. {
  2036. jaFeeOne.Add("spec", "");
  2037. }
  2038. else
  2039. {
  2040. jaFeeOne.Add("spec", jaFeeDetail[i]["spec"]);
  2041. }
  2042. if (string.IsNullOrEmpty(jaFeeDetail[i]["doseForm"].ToString()))
  2043. {
  2044. jaFeeOne.Add("dosform_name", "");
  2045. }
  2046. else
  2047. {
  2048. jaFeeOne.Add("dosform_name", jaFeeDetail[i]["doseForm"]);
  2049. }
  2050. jaFeeOne.Add(" det_item_fee_sumamt", jaFeeDetail[i]["det_item_fee_sumamt"]);
  2051. jaFeeOne.Add("cnt", jaFeeDetail[i]["cnt"]);
  2052. jaFeeOne.Add("pric", jaFeeDetail[i]["pric"]);
  2053. if (string.IsNullOrEmpty(jaFeeDetail[i]["sin_dos_dscr"].ToString()))
  2054. {
  2055. jaFeeOne.Add("sin_dos_dscr", "");
  2056. }
  2057. else
  2058. {
  2059. jaFeeOne.Add("sin_dos_dscr", jaFeeDetail[i]["sin_dos_dscr"]);
  2060. }
  2061. if (string.IsNullOrEmpty(jaFeeDetail[i]["used_frqu_dscr"].ToString()))
  2062. {
  2063. jaFeeOne.Add("used_frqu_dscr", "");
  2064. }
  2065. else
  2066. {
  2067. jaFeeOne.Add("used_frqu_dscr", jaFeeDetail[i]["used_frqu_dscr"]);
  2068. }
  2069. if (string.IsNullOrEmpty(jaFeeDetail[i]["prd_days"].ToString()))
  2070. {
  2071. jaFeeOne.Add("prd_days", "");
  2072. }
  2073. else
  2074. {
  2075. jaFeeOne.Add("prd_days", jaFeeDetail[i]["prd_days"]);
  2076. }
  2077. if (string.IsNullOrEmpty(jaFeeDetail[i]["medc_way_dscr"].ToString()))
  2078. {
  2079. jaFeeOne.Add("medc_way_dscr", "");
  2080. }
  2081. else
  2082. {
  2083. jaFeeOne.Add("medc_way_dscr", jaFeeDetail[i]["medc_way_dscr"]);
  2084. }
  2085. if (string.IsNullOrEmpty(jaFeeDetail[i]["bilg_dr_codg"].ToString()))
  2086. {
  2087. jaFeeOne.Add("bilg_dr_codg", "");
  2088. }
  2089. else
  2090. {
  2091. jaFeeOne.Add("bilg_dr_codg", jaFeeDetail[i]["bilg_dr_codg"]);
  2092. }
  2093. if (string.IsNullOrEmpty(jaFeeDetail[i]["bilg_dr_name"].ToString()))
  2094. {
  2095. jaFeeOne.Add("bilg_dr_name", "");
  2096. }
  2097. else
  2098. {
  2099. jaFeeOne.Add("bilg_dr_name", jaFeeDetail[i]["bilg_dr_name"]);
  2100. }
  2101. jaFeeOne.Add("phar_name", "");
  2102. jaFeeOne.Add("phar_prac_cert_no", "");
  2103. jaFeeOne.Add("tcmdrug_used_way", ""); //中药使用方式 1复方 2单方 必填
  2104. jaFeeOne.Add("trdn_flag", "1");//拆零标志 必填 0否 1是
  2105. jaFeeDetail.Add(jaFeeOne);
  2106. jaFeeOne = new JObject();
  2107. }
  2108. joParam992004.Add("setlinfo", JObject.Parse(setlinfo1));
  2109. joParam992004.Add("drugdetail", jaFeeDetail);//购药明细节点
  2110. }
  2111. return 0;
  2112. }
  2113. catch (Exception ex)
  2114. {
  2115. errMsg = "parsejoParam 解析入参异常2:" + errMsg;
  2116. return -1;
  2117. }
  2118. }
  2119. }
  2120. }