InsuBusiness.cs 121 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360
  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. Global.Set.minpacunt_drug_trac_cnt = JsonHelper.getDestValue(joInParam, "insuAdmObj.minpacunt_drug_trac_cnt");//应传药品追溯码结算数量
  657. Global.Set.mcs_trac_cnt = JsonHelper.getDestValue(joInParam, "insuAdmObj.mcs_trac_cnt");//应传耗材追溯码结算数量
  658. string patInfo ="";
  659. //打开读卡窗口,操作员选择读卡类型后进行读卡器读卡,再进行1101获取参保信息
  660. if (hBus.readCard(out outParam) != 0)
  661. {
  662. rtnResult = JsonHelper.setExceptionJson(-100, "读卡失败!", outParam).ToString();
  663. return rtnResult;
  664. }
  665. else
  666. {
  667. patInfo = outParam;
  668. //展示患者信息界面
  669. if (hBus.showPatInfo(patInfo, out outParam) != 0)
  670. {
  671. rtnResult = outParam;
  672. return rtnResult;
  673. }
  674. }
  675. //患者信息赋值给全局变量
  676. patInfo = outParam;
  677. if (hBus.setGlobalPatAfaterShowPatInfo(patInfo, out errMsg) != 0)
  678. {
  679. rtnResult = JsonHelper.setExceptionJson(-1, "setGlobalPatAfaterShowPatInfo", errMsg).ToString();
  680. return rtnResult;
  681. }
  682. //校验HIS姓名与医保姓名是否一致
  683. if (hBus.checkName(Global.pat.name,out errMsg) != 0)
  684. {
  685. rtnResult = JsonHelper.setExceptionJson(-1, "校验HIS与医保姓名是否一致", errMsg).ToString();
  686. return rtnResult;
  687. }
  688. //弹窗提示患者是否正常参保
  689. hBus.InsuMessage(out string InsuMess);
  690. MessageBox.Show(InsuMess,"参保信息提示");
  691. ////事前分析
  692. if (Global.curEvt.ext.isOpenAnalysis)
  693. {
  694. if (hBus.PreAnalysis("2", "", out errMsg) != 0) //事前事中:门诊挂号1 门诊收费登记2 住院登记3 住院收费登记4 住院执行医嘱5 门诊结算6 门诊预结算7 住院结算8 住院预结算9 购药划卡10
  695. {
  696. //rtnResult = JsonHelper.setExceptionJson(-1, "事前分析", errMsg).ToString();
  697. //return rtnResult;
  698. DialogResult dr = MessageBox.Show("【3101】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  699. if (dr != DialogResult.OK)
  700. {
  701. rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事前分析服务调用失败:", errMsg).ToString();
  702. return rtnResult;
  703. }
  704. }
  705. }
  706. //显示登记面板
  707. if (hBus.showOutPatRegisterForm(out outParam) != 0)
  708. {
  709. rtnResult = JsonHelper.setExceptionJson(-1, "显示登记面板", outParam).ToString();
  710. return rtnResult;
  711. }
  712. JObject joReg = JObject.Parse(outParam);
  713. //医保挂号
  714. JObject jo2201Inpar = JObject.Parse(JsonHelper.getDestProperty(joReg, "data"));
  715. JObject jo2201Inpar_plain = JObject.Parse(JsonHelper.getDestProperty(joReg, "data"));
  716. jo2201Inpar = JObject.Parse(JsonHelper.setCenterInpar("2201", jo2201Inpar));
  717. jo2201Inpar_plain = JObject.Parse(JsonHelper.setCenterInpar_plain("2201", jo2201Inpar_plain));
  718. //此处先取到就诊信息上传的入参,只要挂号成功就保存到云HIS后台(保存后台需要用到2203入参)
  719. JObject jo2203Inpar = new JObject();
  720. JObject jo2203Inpar_plain = new JObject();
  721. jo2203Inpar.Add("mdtrtinfo", JObject.Parse(JsonHelper.getDestValue(joReg, "mdtrtinfo")));
  722. jo2203Inpar.Add("diseinfo",JArray.Parse(JsonHelper.getDestValue(joReg, "diseinfo")));
  723. JObject jo2201Rtn = invoker.invokeCenterService("2201", jo2201Inpar);
  724. if (JsonHelper.parseCenterRtnValue(jo2201Rtn, out errMsg) != 0)
  725. {
  726. rtnResult = JsonHelper.setExceptionJson(-1, "医保挂号", errMsg).ToString();
  727. return rtnResult;
  728. }
  729. else
  730. {
  731. Global.pat.mdtrtID = JsonHelper.getDestValue(jo2201Rtn, "output.data.mdtrt_id");
  732. //插入患者本次就诊用的参保信息
  733. if (hBus.insertPatCurInsuInfo(patInfo, out outParam) != 0)
  734. {
  735. if (DialogResult.Yes != MessageBox.Show(outParam, " 是否继续? ", MessageBoxButtons.YesNo))
  736. {
  737. rtnResult = JsonHelper.setExceptionJson(-1, "插入患者本次就诊用的参保信息,请联系管理员!是否继续?", outParam).ToString();
  738. return rtnResult;
  739. }
  740. }
  741. jo2203Inpar["mdtrtinfo"]["mdtrt_id"] = Global.pat.mdtrtID;
  742. jo2203Inpar_plain = JObject.Parse(JsonHelper.setCenterInpar_plain("2203", jo2203Inpar));
  743. jo2203Inpar = JObject.Parse(JsonHelper.setCenterInpar("2203", jo2203Inpar));
  744. //门诊登记信息,插入云医保平台
  745. jo2201Rtn.Add("validflag", 1);
  746. jo2201Rtn.Add("regstate", 1);
  747. jo2201Rtn.Add("type", 3);
  748. Global.writeLog(jo2201Inpar_plain.ToString());
  749. if (mIS.saveOutpatRegisterInfo(jo2201Inpar_plain, jo2201Rtn, jo2203Inpar_plain, out errMsg) != 0)
  750. {
  751. rtnResult = JsonHelper.setExceptionJson(-1, "中心登记成功但医保平台保存失败,请联系管理员!", errMsg).ToString();
  752. return rtnResult;
  753. }
  754. //返回登记信息,插入HIS
  755. /* if (hIS.returnRegisterInfo(jo2201Inpar_plain, jo2201Rtn, out outParam) != 0)
  756. {
  757. rtnResult = JsonHelper.setExceptionJson(-1, "HIS平台保存登记信息", outParam).ToString();
  758. return rtnResult;
  759. }
  760. else
  761. {
  762. rtnResult = JsonHelper.setIrisReturnValue(0, "登记成功", null).ToString();
  763. return rtnResult;
  764. }*/
  765. }
  766. //门诊就诊信息上传
  767. JObject jo2203Rtn = invoker.invokeCenterService("2203",jo2203Inpar );
  768. if (JsonHelper.parseCenterRtnValue(jo2203Rtn, out errMsg) != 0)
  769. {
  770. rtnResult = JsonHelper.setExceptionJson(-1, "门诊就诊信息上传", errMsg).ToString();
  771. return rtnResult;
  772. }
  773. #region【门诊就诊信息上传成功后调用3101事前服务】
  774. //1.获取3101入参报文
  775. /*
  776. if (hIS.GetInsuPatInfo("1", Global.pat, out outParam) != 0)
  777. {
  778. rtnResult = JsonHelper.setExceptionJson(-1, "获取3101医保明细审核事前分析服务入参失败:", outParam).ToString();
  779. return rtnResult;
  780. }
  781. else
  782. {
  783. //2.调用医保3101明细审核事前分析服务
  784. JObject joInput = new JObject();
  785. //joInput.Add("data", JObject.Parse(outParam));
  786. joInput = JObject.Parse(outParam);
  787. JObject jo3101Rtn = invoker.invokeCenterService("3101", JsonHelper.setCenterInpar("3101", joInput.ToString().Replace("\r\n", ""))); //.Replace(" ", "")
  788. if (JsonHelper.parseCenterRtnValue(jo3101Rtn, out errMsg) != 0)
  789. {
  790. DialogResult dr = MessageBox.Show("【3101】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  791. if (dr != DialogResult.OK)
  792. {
  793. rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
  794. return rtnResult;
  795. }
  796. }
  797. }
  798. */
  799. #endregion
  800. //费用上传
  801. if (hBus.uploadFee("2204", 50, out outParam) != 0)
  802. {
  803. rtnResult = JsonHelper.setExceptionJson(-1, "费用上传", outParam).ToString();
  804. return rtnResult;
  805. }
  806. #region【门诊预结算2206前调用3102医保明细审核事中服务】
  807. //1.获取3102入参报文
  808. /*
  809. if (hIS.GetInsuPatInfo("2", Global.pat, out outParam) != 0)
  810. {
  811. rtnResult = JsonHelper.setExceptionJson(-1, "获取3102医保明细审核事中分析服务入参失败:", outParam).ToString();
  812. return rtnResult;
  813. }
  814. else
  815. {
  816. //2.调用医保3102明细审核事前分析服务
  817. JObject joInput = new JObject();
  818. //joInput.Add("data", JObject.Parse(outParam));
  819. joInput = JObject.Parse(outParam);
  820. JObject jo3101Rtn = invoker.invokeCenterService("3102", JsonHelper.setCenterInpar("3102", joInput.ToString().Replace("\r\n", "")));
  821. if (JsonHelper.parseCenterRtnValue(jo3101Rtn, out errMsg) != 0)
  822. {
  823. DialogResult dr = MessageBox.Show("【3102】医保明细审核事中分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  824. if (dr != DialogResult.OK)
  825. {
  826. rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事中分析服务调用失败:", errMsg).ToString();
  827. return rtnResult;
  828. }
  829. }
  830. }
  831. */
  832. #endregion
  833. ////事中分析
  834. if (Global.curEvt.ext.isOpenAnalysis)
  835. {
  836. if (hBus.PreAnalysis("7", "", out errMsg) != 0) //事前事中:门诊挂号1 门诊收费登记2 住院登记3 住院收费登记4 住院执行医嘱5 门诊结算6 门诊预结算7 住院结算8 住院预结算9 购药划卡10
  837. {
  838. //rtnResult = JsonHelper.setExceptionJson(-1, "事前分析", errMsg).ToString();
  839. //return rtnResult;
  840. DialogResult dr = MessageBox.Show("【3102】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  841. if (dr != DialogResult.OK)
  842. {
  843. rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
  844. return rtnResult;
  845. }
  846. }
  847. }
  848. //调用IRIS获取医保各项金额
  849. if (mIS.getSumFee(out outParam) != 0)
  850. {
  851. rtnResult = JsonHelper.setExceptionJson(-1, "获取医保费用各项汇总金额", outParam).ToString();
  852. return rtnResult;
  853. }
  854. JObject joSumFee = JObject.Parse(outParam);
  855. JObject joSettlement = JObject.Parse(JsonHelper.getDestValue(joReg, "settlement"));
  856. //修改joSettlement的就诊ID ,总金额等
  857. joSettlement["mdtrt_id"] = Global.pat.mdtrtID;
  858. joSettlement["medfee_sumamt"] = JsonHelper.getDestValue(joSumFee, "data.Sumamt");
  859. //预结算2206
  860. if (hBus.preSettlement_OutPat(joSettlement, out outParam) != 0)
  861. {
  862. rtnResult = JsonHelper.setExceptionJson(-1, "结算信息展示", outParam).ToString();
  863. return rtnResult;
  864. }
  865. //正式结算
  866. JObject joData = new JObject();
  867. joData.Add("data",joSettlement);
  868. JObject joRtn = invoker.invokeCenterService("2207", JsonHelper.setCenterInpar("2207", joData));
  869. if (JsonHelper.parseCenterRtnValue(joRtn, out errMsg) != 0)
  870. {
  871. rtnResult = JsonHelper.setExceptionJson(-1, "结算失败", errMsg).ToString();
  872. return rtnResult;
  873. }
  874. else
  875. {
  876. //返回给云医保平台结算信息
  877. if (mIS.saveSettlement(joRtn, out errMsg) != 0)
  878. {
  879. rtnResult = JsonHelper.setExceptionJson(-1, "结算成功,但云医保平台保存失败", errMsg).ToString();
  880. return rtnResult;
  881. }
  882. //返回给云医保平台结算明细信息
  883. if (mIS.saveSettlementDetail(joRtn, out errMsg) != 0)
  884. {
  885. rtnResult = JsonHelper.setExceptionJson(-1, "云医保平台保存结算明细失败", errMsg).ToString();
  886. return rtnResult;
  887. }
  888. //返回给HIS
  889. JObject joSetlinfo = JObject.Parse(JsonHelper.getDestValue(joRtn, "output.setlinfo"));
  890. if (hIS.returnOutpatSettlementInfo(joSettlement, joSetlinfo, out outParam) != 0)
  891. {
  892. rtnResult = JsonHelper.setExceptionJson(-1, "返回结算信息给HIS", outParam).ToString();
  893. return rtnResult;
  894. }
  895. else
  896. {
  897. JObject joHisServieRtn = JObject.Parse(outParam);
  898. hBus.returnToFrontEndAfterSettlement(joRtn, joHisServieRtn, out outParam);
  899. rtnResult = JsonHelper.setIrisReturnValue(0, "结算成功", JObject.Parse(outParam)).ToString();
  900. return rtnResult;
  901. }
  902. }
  903. }
  904. case "M5C"://门诊结算撤销
  905. {
  906. //查询HIS医保结算记录表获取该病人的参保地
  907. string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE billType = 1 and ValidFlag = 1 ";
  908. sqlStr = sqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  909. sqlStr = sqlStr + " AND SettlementID ='" + Global.pat.settlID + "'";
  910. JObject joSql = new JObject();
  911. joSql.Add("sqlStr", sqlStr);
  912. JObject joSettlInfo = mIS.QuerySettlementInfo(joSql);
  913. //if (JsonHelper.parseIrisRtnValue(joSettlInfo, out errMsg) != 0)
  914. //{
  915. // rtnResult = JsonHelper.setExceptionJson(-1, "查询结算信息失败!", errMsg).ToString();
  916. // return rtnResult;
  917. //}
  918. Global.pat.insuplc_admdvs = JsonHelper.getDestValue(joSettlInfo, "result.data[0].insuplc_admdvs");
  919. //退中心结算
  920. string newSettleID = "";
  921. if (cBus.cancleSettlement("2208", out outParam) != 0)
  922. {
  923. int i = outParam.IndexOf("获取到的就诊信息为无效状态,不能办理结算撤销业务");
  924. if (i != 0)
  925. {
  926. if (DialogResult.Yes != MessageBox.Show("医保中心提示:" + outParam + ",是否强制撤销HIS结算信息?", "提示", MessageBoxButtons.YesNo))
  927. {
  928. rtnResult = JsonHelper.setExceptionJson(-1, "中心取消结算失败,", outParam).ToString();
  929. return rtnResult;
  930. }
  931. newSettleID = "YC";
  932. }
  933. else
  934. {
  935. rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算", outParam).ToString();
  936. //查看是医保平台是否已经退费,如果是,则询问是否继续退费
  937. string SqlStr = " SELECT * FROM BS_MedInsuSettlement WHERE ValidFlag = 0 AND BillType = -1 ";
  938. SqlStr = SqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  939. SqlStr = SqlStr + " AND SettlementID ='" + Global.pat.settlID + "'";
  940. JObject joSqlStr = new JObject();
  941. joSqlStr.Add("sqlStr", SqlStr);
  942. JObject joCancleSettlInfo = mIS.QuerySettlementInfo(joSqlStr);
  943. JArray jaCancleSettlInfo = JArray.Parse(JsonHelper.getDestValue(joCancleSettlInfo, "result.data"));
  944. if (jaCancleSettlInfo.Count == 1)
  945. {
  946. //询问收款员是否继续进行HIS退费
  947. if (DialogResult.Yes == MessageBox.Show("中心提示:" + outParam, " 该费用在医保中心已成功退费但在HIS未成功退费,是否强制退HIS费用? ", MessageBoxButtons.YesNo))
  948. {
  949. rtnResult = JsonHelper.setExceptionJson(0, "该费用在医保中心已成功退费但在HIS未成功退费,收款员选择强制退HIS费用!", outParam).ToString();
  950. }
  951. }
  952. else
  953. {
  954. rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算(云医保平台未退费或未查询到退费记录)", outParam).ToString();
  955. }
  956. return rtnResult;
  957. }
  958. }
  959. else
  960. {
  961. newSettleID = JsonHelper.getDestValue(JObject.Parse(outParam), "output.setlinfo.setl_id");
  962. }
  963. //string newSettleID = "10290453";
  964. //Global.pat.mdtrtID = "202210281547480034293700000000";
  965. //Global.pat.psn_no = "YX423049577";
  966. //Global.pat.settlID = "10290445";
  967. //退云医保平台结算
  968. if (mIS.cancleSettlement(newSettleID, out outParam) != 0)
  969. {
  970. rtnResult = JsonHelper.setExceptionJson(-1, "取消平台结算信息", outParam).ToString();
  971. //return rtnResult;
  972. }
  973. //中心取消传送
  974. if (cBus.cancleFeeUpload("2205", out errMsg) != 0)
  975. {
  976. rtnResult = JsonHelper.setExceptionJson(-1, "取消中心费用", errMsg).ToString();
  977. return rtnResult;
  978. }
  979. //云平台取消传送
  980. if (mIS.deleteFee(out errMsg) != 0)
  981. {
  982. rtnResult = JsonHelper.setExceptionJson(-1, "删除医保平台费用", errMsg).ToString();
  983. return rtnResult;
  984. }
  985. //取消中心登记
  986. if (cBus.cancleRegister("2202", out outParam) != 0)
  987. {
  988. rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记失败,", outParam).ToString();
  989. return rtnResult;
  990. }
  991. //取消医保平台登记
  992. if (mIS.cancleRegister(3, out outParam) != 0)
  993. {
  994. rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记成功,但云医保平台取消失败,", outParam).ToString();
  995. return rtnResult;
  996. }
  997. //退HIS结算
  998. if (hIS.cancleSettlementInfo(joParam, out outParam) != 0)
  999. {
  1000. rtnResult = JsonHelper.setExceptionJson(-1, "取消HIS结算信息", outParam).ToString();
  1001. return rtnResult;
  1002. }
  1003. else
  1004. {
  1005. rtnResult = JsonHelper.setIrisReturnValue(0, "取消结算成功", null).ToString();
  1006. return rtnResult;
  1007. }
  1008. }
  1009. case "M6"://门诊移动支付结算
  1010. {
  1011. MobilePay mp = new MobilePay(InParam, out errMsg);
  1012. if (errMsg != "")
  1013. {
  1014. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易1", errMsg).ToString();
  1015. return rtnResult;
  1016. }
  1017. if (mp.MobilePaySettlement(out outParam) != 0)
  1018. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易2", outParam).ToString();
  1019. else
  1020. rtnResult = outParam;
  1021. return rtnResult;
  1022. }
  1023. case "M6C"://门诊移动支付结算撤销
  1024. {
  1025. string onlineYBFalg = JsonHelper.getDestValue(joInsuAdmObj, "onlineYBFalg");
  1026. MobilePay mp = new MobilePay(InParam, out errMsg);
  1027. if (errMsg != "")
  1028. {
  1029. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易3", errMsg).ToString();
  1030. return rtnResult;
  1031. }
  1032. if (String.IsNullOrEmpty(onlineYBFalg))
  1033. mp.MSettl.onlineYBFalg = "N";
  1034. else
  1035. mp.MSettl.onlineYBFalg = onlineYBFalg;
  1036. if (mp.MobilePayCancelSettlement(out outParam) != 0)
  1037. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易4", outParam).ToString();
  1038. else
  1039. rtnResult = JsonHelper.setExceptionJson(0, "Settlement 交易5", outParam).ToString();
  1040. return rtnResult;
  1041. }
  1042. case "M6Confirm"://门诊移动支付确认
  1043. {
  1044. MobilePay mp = new MobilePay(InParam, out errMsg);
  1045. if (errMsg != "")
  1046. {
  1047. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易6", errMsg).ToString();
  1048. return rtnResult;
  1049. }
  1050. if (mp.MobilePayConfirmSettlement(out outParam) != 0)
  1051. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易7", outParam).ToString();
  1052. else
  1053. rtnResult = outParam;
  1054. return rtnResult;
  1055. }
  1056. case "M6CallBack"://门诊移动支付回调
  1057. {
  1058. JObject jo = JObject.Parse(InParam);
  1059. joInsuAdmObj = new JObject();
  1060. joInsuAdmObj.Add("payOrdId", "");
  1061. jo.Add("insuAdmObj", joInsuAdmObj);
  1062. MobilePay mp = new MobilePay(jo.ToString(), out errMsg);
  1063. if (errMsg != "")
  1064. {
  1065. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易8", errMsg).ToString();
  1066. return rtnResult;
  1067. }
  1068. if (mp.MobilePayCallbackSettlement(out outParam) != 0)
  1069. rtnResult = outParam;
  1070. else
  1071. rtnResult = outParam;
  1072. return rtnResult;
  1073. }
  1074. case "Z4"://住院预结算
  1075. {
  1076. #region【住院预结算2303前调用3102医保明细审核事中服务】
  1077. //1.获取3102入参报文
  1078. /*
  1079. if (hIS.GetInsuPatInfo("9", Global.pat, out outParam) != 0)
  1080. {
  1081. rtnResult = JsonHelper.setExceptionJson(-1, "获取3102医保明细审核事中分析服务入参失败:", outParam).ToString();
  1082. return rtnResult;
  1083. }
  1084. else
  1085. {
  1086. //2.调用医保3102明细审核事前分析服务
  1087. JObject joInput = new JObject();
  1088. joInput = JObject.Parse(outParam);
  1089. JObject jo3102Rtn = invoker.invokeCenterService("3102", JsonHelper.setCenterInpar("3102", joInput.ToString().Replace("\r\n", "")));
  1090. if (JsonHelper.parseCenterRtnValue(jo3102Rtn, out errMsg) != 0)
  1091. {
  1092. DialogResult dr = MessageBox.Show("【3102】医保明细审核事中分析服务医保中心返回结果2:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  1093. if (dr != DialogResult.OK)
  1094. {
  1095. rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事中分析服务调用失败:", errMsg).ToString();
  1096. return rtnResult;
  1097. }
  1098. }
  1099. }
  1100. */
  1101. #endregion
  1102. Global.pat.RYorCY = "2";
  1103. Global.pat.admType = 2;
  1104. JObject joSettle = new JObject();
  1105. if (hBus.preSettlement("2303",out joSettle, out outParam) != 0)
  1106. {
  1107. rtnResult = JsonHelper.setExceptionJson(-1, "结算信息展示", outParam).ToString();
  1108. return rtnResult;
  1109. }
  1110. else
  1111. {
  1112. rtnResult = JsonHelper.setIrisReturnValue(0, "预结算成功", null).ToString();
  1113. return rtnResult;
  1114. }
  1115. }
  1116. case "Z4C"://住院预结算撤销
  1117. {
  1118. rtnResult = JsonHelper.setExceptionJson(-100, "该接口不支持预结算取消!", null).ToString();
  1119. return rtnResult;
  1120. }
  1121. case "Z5"://住院结算
  1122. {
  1123. Global.Set.minpacunt_drug_trac_cnt = JsonHelper.getDestValue(joInParam, "insuAdmObj.minpacunt_drug_trac_cnt");//应传药品追溯码结算数量
  1124. Global.Set.mcs_trac_cnt = JsonHelper.getDestValue(joInParam, "insuAdmObj.mcs_trac_cnt");//应传耗材追溯码结算数量
  1125. #region【住院预结算2303前调用3102医保明细审核事中服务】
  1126. //1.获取3102入参报文
  1127. /*
  1128. if (hIS.GetInsuPatInfo("9", Global.pat, out outParam) != 0)
  1129. {
  1130. rtnResult = JsonHelper.setExceptionJson(-1, "获取3102医保明细审核事中分析服务入参失败:", outParam).ToString();
  1131. return rtnResult;
  1132. }
  1133. else
  1134. {
  1135. //2.调用医保3102明细审核事前分析服务
  1136. JObject joInput = new JObject();
  1137. joInput = JObject.Parse(outParam);
  1138. JObject jo3102Rtn = invoker.invokeCenterService("3102", JsonHelper.setCenterInpar("3102", joInput.ToString().Replace("\r\n", "")));
  1139. if (JsonHelper.parseCenterRtnValue(jo3102Rtn, out errMsg) != 0)
  1140. {
  1141. DialogResult dr = MessageBox.Show("【3102】医保明细审核事中分析服务医保中心返回结果1:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  1142. if (dr != DialogResult.OK)
  1143. {
  1144. rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事中分析服务调用失败:", errMsg).ToString();
  1145. return rtnResult;
  1146. }
  1147. }
  1148. }
  1149. */
  1150. #endregion
  1151. #region【住院预结算2303前调用3102医保明细审核事中服务】
  1152. ////事中分析
  1153. if (Global.curEvt.ext.isOpenAnalysis)
  1154. {
  1155. if (hBus.PreAnalysis("9", "", out errMsg) != 0) //事前事中:门诊挂号1 门诊收费登记2 住院登记3 住院收费登记4 住院执行医嘱5 门诊结算6 门诊预结算7 住院结算8 住院预结算9 购药划卡10
  1156. {
  1157. //rtnResult = JsonHelper.setExceptionJson(-1, "事前分析", errMsg).ToString();
  1158. //return rtnResult;
  1159. DialogResult dr = MessageBox.Show("【3101】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
  1160. if (dr != DialogResult.OK)
  1161. {
  1162. rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
  1163. return rtnResult;
  1164. }
  1165. }
  1166. }
  1167. #endregion
  1168. Global.pat.admType = 2;
  1169. Global.pat.RYorCY = "2";
  1170. JObject joPreSetOutpar ;
  1171. if (hBus.preSettlement("2303",out joPreSetOutpar, out outParam) != 0)
  1172. {
  1173. rtnResult = JsonHelper.setExceptionJson(-1, "结算信息展示", outParam).ToString();
  1174. return rtnResult;
  1175. }
  1176. else
  1177. {
  1178. JObject joSettlement = JObject.Parse(JsonHelper.getDestValue(joPreSetOutpar, "Settlement"));
  1179. ////出院登记
  1180. //JObject joDischargeRegister = JObject.Parse(JsonHelper.getDestValue(joPreSetOutpar, "DischargeRegister"));
  1181. //JObject jo2402Rtn = invoker.invokeCenterService("2402", JsonHelper.setCenterInpar("2402", joDischargeRegister));
  1182. //if (JsonHelper.parseCenterRtnValue(jo2402Rtn, out errMsg) != 0)
  1183. //{
  1184. // rtnResult = JsonHelper.setExceptionJson(-1, "结算失败", errMsg).ToString();
  1185. // return rtnResult;
  1186. //}
  1187. //正式结算
  1188. joSettlement.Add("data", joSettlement);
  1189. JObject jo2304Rtn = invoker.invokeCenterService("2304",JsonHelper.setCenterInpar("2304",joSettlement));
  1190. if (JsonHelper.parseCenterRtnValue(jo2304Rtn, out errMsg) != 0)
  1191. {
  1192. rtnResult = JsonHelper.setExceptionJson(-1, "结算失败", errMsg).ToString();
  1193. cBus.cancleRegister("2405", out errMsg);
  1194. return rtnResult;
  1195. }
  1196. else
  1197. {
  1198. //返回给云医保平台结算信息
  1199. if (mIS.saveSettlement(jo2304Rtn, out errMsg) != 0)
  1200. {
  1201. rtnResult = JsonHelper.setExceptionJson(-1, "结算成功,但云医保平台保存失败", errMsg).ToString();
  1202. return rtnResult;
  1203. }
  1204. //返回给云医保平台结算明细信息
  1205. if (mIS.saveSettlementDetail(jo2304Rtn, out errMsg) != 0)
  1206. {
  1207. rtnResult = JsonHelper.setExceptionJson(-1, "云医保平台保存结算明细失败", errMsg).ToString();
  1208. Global.writeLog(rtnResult);
  1209. MessageBox.Show(errMsg);
  1210. }
  1211. //返回给HIS
  1212. JObject joSetlinfo = JObject.Parse(JsonHelper.getDestValue(jo2304Rtn, "output.setlinfo"));
  1213. if (hIS.returnInpatSettlementInfo(joParam, joSetlinfo, out outParam) != 0)
  1214. {
  1215. rtnResult = JsonHelper.setExceptionJson(-1, "返回结算信息给HIS", outParam).ToString();
  1216. return rtnResult;
  1217. }
  1218. else
  1219. {
  1220. //返回给前端
  1221. JObject joHisServieRtn = JObject.Parse(outParam);
  1222. hBus.returnToFrontEndAfterSettlement(jo2304Rtn, joHisServieRtn, out outParam);
  1223. rtnResult = JsonHelper.setIrisReturnValue(0, "结算成功", JObject.Parse(outParam)).ToString();
  1224. return rtnResult;
  1225. }
  1226. }
  1227. }
  1228. }
  1229. case "Z5C"://住院结算撤销
  1230. {
  1231. //查询结算表
  1232. string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE billType = 1 and Hospital_Dr=" + Global.inf.hospitalDr
  1233. + " and Adm_Dr='" + Global.pat.adm_Dr + "'"
  1234. + " and MdtrtID='" + Global.pat.mdtrtID + "'"
  1235. + " Order By ID DESC ";
  1236. JObject joSql = new JObject();
  1237. joSql.Add("sqlStr", sqlStr);
  1238. JObject joSettlInfo = mIS.QuerySettlementInfo(joSql);
  1239. //if (JsonHelper.parseIrisRtnValue(joSettlInfo, out errMsg) != 0)
  1240. //{
  1241. // rtnResult = JsonHelper.setExceptionJson(-1, "查询结算信息失败!", errMsg).ToString();
  1242. // return rtnResult;
  1243. //}
  1244. //MessageBox.Show(joSettlInfo.ToString());
  1245. Global.pat.insuplc_admdvs = JsonHelper.getDestValue(joSettlInfo, "result.data[0].insuplc_admdvs");
  1246. Global.pat.SettID_YBJSB = JsonHelper.getDestValue(joSettlInfo, "result.data[0].SettlementID");
  1247. if (Global.pat.settlID != Global.pat.SettID_YBJSB)
  1248. {
  1249. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易", "通过09010059服务获取到的SettlementID<" + Global.pat.settlID + ">与DLL通过SQL语句" +
  1250. joSql + ",获取到的SettlementID<" + Global.pat.SettID_YBJSB + ">不同,可能存在HIS单边账,请联系医保开发人员处理该笔结算记录!").ToString();
  1251. //return rtnResult;
  1252. }
  1253. Global.pat.settlID = Global.pat.SettID_YBJSB;
  1254. //取消中心结算信息
  1255. if (cBus.cancleSettlement("2305", out outParam) != 0)
  1256. {
  1257. rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算信息失败!", outParam).ToString();
  1258. //查看是医保平台是否已经退费,如果是,则询问是否继续退费
  1259. string SqlStr = " SELECT * FROM BS_MedInsuSettlement WHERE ValidFlag = 0 AND BillType = -1 ";
  1260. SqlStr = SqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  1261. SqlStr = SqlStr + " AND SettlementID ='" + Global.pat.settlID + "'";
  1262. JObject joSqlStr = new JObject();
  1263. joSqlStr.Add("sqlStr", SqlStr);
  1264. JObject joCancleSettlInfo = mIS.QuerySettlementInfo(joSqlStr);
  1265. JArray jaCancleSettlInfo = JArray.Parse(JsonHelper.getDestValue(joCancleSettlInfo, "result.data"));
  1266. if (jaCancleSettlInfo.Count == 1)
  1267. {
  1268. //询问收款员是否继续进行HIS退费
  1269. if (DialogResult.Yes == MessageBox.Show("中心提示:" + outParam, " 该费用在医保中心已成功退费但在HIS未成功退费,是否强制退HIS费用? ", MessageBoxButtons.YesNo))
  1270. {
  1271. rtnResult = JsonHelper.setExceptionJson(0, "该费用在医保中心已成功退费但在HIS未成功退费,收款员选择强制退HIS费用!", outParam).ToString();
  1272. }
  1273. }
  1274. else
  1275. {
  1276. rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算(云医保平台未退费或未查询到退费记录)", outParam).ToString();
  1277. }
  1278. return rtnResult;
  1279. }
  1280. else
  1281. {
  1282. //退结算会返一个新的ID
  1283. string newSettleID = JsonHelper.getDestValue(JObject.Parse(outParam), "output.setlinfo.setl_id");
  1284. //取消平台结算信息
  1285. if (mIS.cancleSettlement(newSettleID, out outParam) != 0)
  1286. {
  1287. rtnResult = JsonHelper.setExceptionJson(-1, "中心结算取消成功,医保平台结算信息取消失败!", outParam).ToString();
  1288. return rtnResult;
  1289. }
  1290. //中心取消传送
  1291. if (cBus.cancleFeeUpload("2302", out errMsg) != 0)
  1292. {
  1293. //rtnResult = JsonHelper.setExceptionJson(-1, "取消中心费用", errMsg).ToString();
  1294. //return rtnResult;
  1295. }
  1296. //云平台取消传送
  1297. if (mIS.deleteFee(out errMsg) != 0)
  1298. {
  1299. //rtnResult = JsonHelper.setExceptionJson(-1, "删除医保平台费用", errMsg).ToString();
  1300. //return rtnResult;
  1301. }
  1302. //取消HIS医保结算信息
  1303. if (hIS.cancleSettlementInfo(joParam, out outParam) != 0)
  1304. {
  1305. rtnResult = JsonHelper.setExceptionJson(-1, "中心跟医保平台结算取消成功, 取消HIS结算信息失败!", outParam).ToString();
  1306. return rtnResult;
  1307. }
  1308. //取消出院登记
  1309. if (cBus.cancleRegister("2405", out outParam) != 0)
  1310. {
  1311. rtnResult = JsonHelper.setExceptionJson(0, "中心,医保平台及HIS结算信息取消成功,取消出院登记失败!请手工取消出院登记!", outParam).ToString();
  1312. return rtnResult;
  1313. }
  1314. rtnResult = JsonHelper.setIrisReturnValue(0, "取消结算成功", null).ToString();
  1315. return rtnResult;
  1316. }
  1317. }
  1318. default:
  1319. {
  1320. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易", "传入的业务编码不对!").ToString();
  1321. return rtnResult;
  1322. }
  1323. }
  1324. return rtnResult;
  1325. }
  1326. catch (Exception ex)
  1327. {
  1328. rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易", ex.Message).ToString();
  1329. return rtnResult;
  1330. }
  1331. finally
  1332. {
  1333. Global.writeLog("Settlement 出参:" + JsonHelper.Compress(rtnResult));
  1334. }
  1335. }
  1336. //[STAThread]
  1337. //public void print(JObject joInParam)
  1338. //{
  1339. // //显示打印界面
  1340. // SettlementChecklist frmSettlList;
  1341. // string insuAdmObj = JsonHelper.getDestValue(joInParam, "insuAdmObj");
  1342. // if (insuAdmObj == "")
  1343. // {
  1344. // frmSettlList = new SettlementChecklist();
  1345. // }
  1346. // else
  1347. // {
  1348. // JObject joInsuAdmObj = JObject.Parse(insuAdmObj);
  1349. // frmSettlList = new SettlementChecklist(joInsuAdmObj);
  1350. // }
  1351. // if (frmSettlList.ShowDialog() == DialogResult.OK)
  1352. // {
  1353. // };
  1354. //}
  1355. //[STAThread]
  1356. /// <summary>
  1357. /// 辅助交易
  1358. /// </summary>
  1359. /// <param name="InParam"></param>
  1360. /// <returns></returns>
  1361. public string AgentFun(string InParam)
  1362. {
  1363. Global.writeLog("AgentFun 入参:" + JsonHelper.Compress(InParam));
  1364. //设置返回值,错误信息
  1365. int errCode;
  1366. string errMsg, rtnResult = "", outParam;
  1367. try
  1368. {
  1369. //解析入参
  1370. if (parseInparam(InParam, out errMsg) != 0)
  1371. {
  1372. rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  1373. return rtnResult;
  1374. }
  1375. //BS架构调用方式问题,每次调用都需要重新初始化
  1376. if (init(InParam, out outParam) != 0)
  1377. {
  1378. rtnResult = outParam;
  1379. return rtnResult;
  1380. }
  1381. //获取pat
  1382. //hBus.GetFeeHisInfo(businessType, joInParam, out Global.pat);
  1383. switch (businessType)
  1384. {
  1385. case "BasicData"://基础数据维护
  1386. {
  1387. BasicData bd = new BasicData();
  1388. if (bd.ShowDialog() != DialogResult.OK)
  1389. {
  1390. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出基础数据维护界面").ToString();
  1391. return rtnResult;
  1392. }
  1393. break;
  1394. }
  1395. case "Exception"://异常处理
  1396. {
  1397. //显示异常处理界面
  1398. HandleException frmEX = new HandleException();
  1399. if (frmEX.ShowDialog() != DialogResult.OK)
  1400. {
  1401. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出异常处理界面").ToString();
  1402. return rtnResult;
  1403. }
  1404. break;
  1405. }
  1406. case "CheckAndClearing"://对账清算
  1407. {
  1408. Clearing frmEX = new Clearing();
  1409. if (frmEX.ShowDialog() != DialogResult.OK)
  1410. {
  1411. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出对账清算界面").ToString();
  1412. return rtnResult;
  1413. }
  1414. break;
  1415. }
  1416. case "Print"://打印
  1417. {
  1418. //显示打印界面
  1419. SettlementChecklist frmSettlList;
  1420. string insuAdmObj = JsonHelper.getDestValue(joInParam, "insuAdmObj");
  1421. if (insuAdmObj == "")
  1422. {
  1423. frmSettlList = new SettlementChecklist();
  1424. if (frmSettlList.ShowDialog() != DialogResult.OK)
  1425. {
  1426. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出打印界面").ToString();
  1427. return rtnResult;
  1428. }
  1429. }
  1430. else
  1431. {
  1432. JObject joInsuAdmObj = JObject.Parse(insuAdmObj);
  1433. frmSettlList = new SettlementChecklist(joInsuAdmObj);
  1434. string groupID = JsonHelper.getDestValue((JObject)Global.curEvt.jaSession[0], "groupID");
  1435. string userName = JsonHelper.getDestValue((JObject)Global.curEvt.jaSession[0], "userName");
  1436. DataTable dt = (DataTable)frmSettlList.dgvSettlRecord.DataSource;
  1437. if (dt.Rows.Count != 1)
  1438. {
  1439. frmSettlList.ShowDialog();
  1440. }
  1441. else
  1442. {
  1443. frmSettlList.btnPrint_Click(null, null);
  1444. }
  1445. }
  1446. return JsonHelper.setIrisReturnValue(0, "", null).ToString();
  1447. break;
  1448. }
  1449. case "Log"://日志
  1450. {
  1451. MessageBox.Show(businessType);
  1452. break;
  1453. }
  1454. case "RecordUpload"://上传记录
  1455. {
  1456. MessageBox.Show(businessType);
  1457. break;
  1458. }
  1459. case "ToPutOnRecord"://医保备案相关
  1460. {
  1461. STA sta = new STA();
  1462. Thread thread = new Thread(sta.ToPutOnRecord);
  1463. thread.SetApartmentState(ApartmentState.STA); //重点
  1464. thread.IsBackground = true;
  1465. thread.Start();
  1466. thread.Join();
  1467. break;
  1468. }
  1469. case "MedInsuQuery"://医保查询
  1470. {
  1471. MedInsuQuery MedQuery = new MedInsuQuery();
  1472. if (MedQuery.ShowDialog() != DialogResult.OK)
  1473. {
  1474. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出医保查询界面").ToString();
  1475. return rtnResult;
  1476. }
  1477. break;
  1478. }
  1479. case "Appeal"://医保申诉
  1480. {
  1481. HopitalAppeal appeal = new HopitalAppeal();
  1482. if (appeal.ShowDialog() != DialogResult.OK)
  1483. {
  1484. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出医保申诉界面").ToString();
  1485. return rtnResult;
  1486. }
  1487. break;
  1488. }
  1489. case "PreAndInProcessAnalysis"://事前分析 诊间只有住院的事前分析
  1490. {
  1491. Global.pat.adm_Dr = int.Parse(JsonHelper.getDestValue(joInParam, "params[0].admID"));
  1492. Global.pat.adm_Dr = int.Parse(JsonHelper.getDestValue(joInParam, "params[0].admID"));
  1493. Global.pat.adm_Dr = int.Parse(JsonHelper.getDestValue(joInParam, "params[0].admID"));
  1494. JObject joResult = new JObject();
  1495. joResult.Add("result", JObject.Parse(JsonHelper.getDestValue(joParam, "insuData")));
  1496. //事前分析
  1497. if (Global.curEvt.ext.isOpenAnalysis)
  1498. {
  1499. if (hBus.PreAnalysis("5", joResult.ToString(), out errMsg) != 0)
  1500. {
  1501. MessageBox.Show(errMsg);
  1502. break;
  1503. }
  1504. }
  1505. break;
  1506. }
  1507. case "PrescribeCirculation"://医保处方流转
  1508. {
  1509. //显示医保处方流转界面
  1510. PrescriptionCirculation PresCir = new PrescriptionCirculation("");
  1511. if (PresCir.ShowDialog() != DialogResult.OK)
  1512. {
  1513. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出医保电子处方流转界面").ToString();
  1514. return rtnResult;
  1515. }
  1516. break;
  1517. }
  1518. case "Special"://就医特殊属性上传
  1519. {
  1520. SpecialPsn spec = new SpecialPsn();
  1521. if (spec.ShowDialog() != DialogResult.OK)
  1522. {
  1523. rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出就医特殊属性上传界面").ToString();
  1524. return rtnResult;
  1525. }
  1526. break;
  1527. }
  1528. case "ElectronicSettlementCertificate":// 电子结算凭证上传
  1529. {
  1530. EcSettlCertMainForm ecCert = new EcSettlCertMainForm();
  1531. ecCert.ShowDialog();
  1532. break;
  1533. }
  1534. default:
  1535. {
  1536. rtnResult = JsonHelper.setExceptionJson(-1, "AgentFun 交易", "传入的业务编码不对!").ToString();
  1537. return rtnResult;
  1538. }
  1539. }
  1540. return rtnResult;
  1541. }
  1542. catch (Exception ex)
  1543. {
  1544. rtnResult = JsonHelper.setExceptionJson(-1, "AgentFun 交易", ex.Message).ToString();
  1545. return rtnResult;
  1546. }
  1547. finally
  1548. {
  1549. Global.writeLog("AgentFun 出参:" + JsonHelper.Compress(rtnResult));
  1550. }
  1551. }
  1552. public string Download(string InParam)
  1553. {
  1554. Global.writeLog("Download 入参:" + JsonHelper.Compress(InParam));
  1555. //设置返回值,错误信息
  1556. int errCode;
  1557. string errMsg, rtnResult = "", outParam;
  1558. try
  1559. {
  1560. //解析入参
  1561. if (parseInparam(InParam, out errMsg) != 0)
  1562. {
  1563. rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  1564. return rtnResult;
  1565. }
  1566. //BS架构调用方式问题,每次调用都需要重新初始化
  1567. if (init(InParam, out outParam) != 0)
  1568. {
  1569. rtnResult = outParam;
  1570. return rtnResult;
  1571. }
  1572. dynamic joData = new JObject();
  1573. joData.data = joParam["data"];
  1574. //string code = (string)joInParam["code"];
  1575. string funNO = (string)joParam["funNO"];
  1576. switch (businessType)
  1577. {
  1578. case "DirectoryDownload":
  1579. {
  1580. string downloadParam = JsonHelper.setCenterInpar(funNO, joData.ToString());
  1581. rtnResult = hBus.DownloadDirectory(funNO, downloadParam).ToString();
  1582. break;
  1583. }
  1584. case "DictionayDownload":
  1585. {
  1586. string downloadParam = JsonHelper.setCenterInpar(funNO, joData.ToString());
  1587. rtnResult = hBus.downDictionary(downloadParam);
  1588. break;
  1589. }
  1590. }
  1591. return rtnResult;
  1592. }
  1593. catch (Exception ex)
  1594. {
  1595. rtnResult = JsonHelper.setExceptionJson(-100, "Download", ex.Message).ToString();
  1596. return rtnResult;
  1597. }
  1598. finally
  1599. {
  1600. Global.writeLog("Download 出参:" + rtnResult);
  1601. }
  1602. }
  1603. public string PlatformDirectConnect(string InParam)
  1604. {
  1605. //设置返回值,错误信息
  1606. int errCode;
  1607. string errMsg, rtnResult = "", outParam;
  1608. try
  1609. {
  1610. Global.writeLog("PlatformDirectConnect 入参:" + JsonHelper.Compress(InParam));
  1611. //解析入参
  1612. if (parseInparam(InParam, out errMsg) != 0)
  1613. {
  1614. rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  1615. return rtnResult;
  1616. }
  1617. Global.businessType = businessType;
  1618. string funNO = JsonHelper.getDestValue(joInParam, "funNO");
  1619. //BS架构调用方式问题,每次调用都需要重新初始化
  1620. if (init(InParam, out outParam) != 0)
  1621. {
  1622. rtnResult = outParam;
  1623. return rtnResult;
  1624. }
  1625. JObject joRtn;
  1626. string[] strArr = { "3501", "3502", "3503", "3504", "3505", "3506", "3507" };//进销存交易
  1627. bool exists = ((IList)strArr).Contains(funNO);
  1628. if (exists)
  1629. {
  1630. //解析入参
  1631. if (parsejoParam(joParam, funNO, out errMsg) != 0)
  1632. {
  1633. rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  1634. return rtnResult;
  1635. }
  1636. //if (funNO == "3505")
  1637. //{
  1638. // //解析入参
  1639. // if (parsejoParamSet(joParam, funNO, out errMsg) != 0)
  1640. // {
  1641. // rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
  1642. // return rtnResult;
  1643. // }
  1644. // invoker.invokeCenterServiceJXC("992001", JObject.Parse(JsonHelper.setCenterInpar("992001", joParam992001)));//结算信息上传
  1645. // invoker.invokeCenterServiceJXC("992004", JObject.Parse(JsonHelper.setCenterInpar("992004", joParam992004)));//结算费用明细上传
  1646. //}
  1647. //if (funNO == "3506")
  1648. //{
  1649. // invoker.invokeCenterServiceJXC("992002", JObject.Parse(JsonHelper.setCenterInpar("992002", joParam992001)));//结算退费信息上传
  1650. // invoker.invokeCenterServiceJXC("992004", JObject.Parse(JsonHelper.setCenterInpar("992004", joParam992004)));//结算退费费用明细上传
  1651. //}
  1652. joRtn = invoker.invokeCenterServiceJXC(funNO, JObject.Parse(JsonHelper.setCenterInpar(funNO, joParam)));
  1653. //joRtn = invoker.invokeCenterServiceJXC2(funNO, JObject.Parse(JsonHelper.setCenterInpar(funNO, joParam)));
  1654. string funNOA = funNO + 'A';
  1655. joRtn = invoker.invokeCenterService(funNOA, JsonHelper.setCenterInpar(funNOA, joParamA));
  1656. }
  1657. else //非进销存交易
  1658. {
  1659. if (funNO== "I2002")
  1660. {
  1661. joRtn = invoker.invokeCenterServiceFZJK("I2002", joParam);//追溯码辅助接口
  1662. }
  1663. else {
  1664. joRtn = invoker.invokeCenterService(funNO, JsonHelper.setCenterInpar(funNO, joParam));//正常交易走医保COM组件
  1665. }
  1666. }
  1667. if (JsonHelper.parseCenterRtnValue(joRtn, out errMsg) != 0)
  1668. {
  1669. rtnResult = JsonHelper.setExceptionJson(-1, "平台直连错误", errMsg).ToString();
  1670. return rtnResult;
  1671. }
  1672. else
  1673. {
  1674. rtnResult = JsonHelper.setIrisReturnValue(0, "", joRtn).ToString();
  1675. return rtnResult;
  1676. }
  1677. }
  1678. catch (Exception ex)
  1679. {
  1680. rtnResult = JsonHelper.setExceptionJson(-1, "PlatformDirectConnect 交易", ex.Message).ToString();
  1681. return rtnResult;
  1682. }
  1683. finally
  1684. {
  1685. Global.writeLog("PlatformDirectConnect 出参:" + JsonHelper.Compress(rtnResult));
  1686. }
  1687. }
  1688. private int parsejoParam(JObject joParam,string funno,out string errMsg)
  1689. {
  1690. errMsg = "";
  1691. try
  1692. {
  1693. if (funno == "3505"|| funno == "3506")
  1694. {
  1695. if (!string.IsNullOrEmpty(joParam["selinfo"]["setl_id"].ToString()))
  1696. {
  1697. if (joParam["selinfo"]["setl_id"].ToString().Substring(0, 4) == "4299" || joParam["selinfo"]["setl_id"].ToString().Substring(0, 4) == "4201")
  1698. {
  1699. joParam["selinfo"]["hi_feesetl_type"] = "1";
  1700. }
  1701. else
  1702. {
  1703. joParam["selinfo"]["hi_feesetl_type"] = "2";
  1704. }
  1705. }
  1706. else
  1707. {
  1708. joParam["selinfo"]["hi_feesetl_type"] = "0";
  1709. }
  1710. JObject joRtn = JObject.Parse(joParam["selinfo"].ToString());
  1711. //if (!string.IsNullOrEmpty(joParam["selinfo"]["drugtracinfo"].ToString()))
  1712. //{
  1713. // joRtn.Add("drug_trac_info", joParam["selinfo"]["drugtracinfo"]);
  1714. // joParam["selinfo"] = joRtn;
  1715. //}
  1716. //MessageBox.Show("111");
  1717. //MessageBox.Show(joParam.ToString());
  1718. JArray selDtl = new JArray();
  1719. selDtl.Add(JObject.Parse(joParam["selinfo"].ToString()));
  1720. //MessageBox.Show(selDtl.ToString());
  1721. joParamA = new JObject();
  1722. joParamA.Add("selinfoDetail", selDtl);
  1723. //MessageBox.Show(joParamA.ToString());
  1724. return 0;
  1725. }
  1726. else if (funno == "3501")
  1727. {
  1728. JObject joRtn = JObject.Parse(joParam["invinfo"].ToString());
  1729. //if (!string.IsNullOrEmpty(joParam["invinfo"]["drugtracinfo"].ToString()))
  1730. //{
  1731. // joRtn.Add("drug_trac_info", joParam["invinfo"]["drugtracinfo"]);
  1732. // joParam["invinfo"] = joRtn;
  1733. //}
  1734. joRtn.Add("trdn_flag", "1");
  1735. joParam["invinfo"] = joRtn;
  1736. JArray selDtl = new JArray();
  1737. selDtl.Add(JObject.Parse(joParam["invinfo"].ToString()));
  1738. //MessageBox.Show(selDtl.ToString());
  1739. joParamA = new JObject();
  1740. joParamA.Add("invinfoDetail", selDtl);
  1741. return 0;
  1742. }
  1743. else if (funno == "3502")
  1744. {
  1745. JObject joRtn = JObject.Parse(joParam["invinfo"].ToString());
  1746. //if (!string.IsNullOrEmpty(joParam["invinfo"]["drugtracinfo"].ToString()))
  1747. //{
  1748. // joRtn.Add("drug_trac_info", joParam["invinfo"]["drugtracinfo"]);
  1749. // joParam["invinfo"] = joRtn;
  1750. //}
  1751. joRtn.Add("manu_lotnum","");
  1752. joRtn["fixmedins_bchno"] = joRtn["fixmedins_bchno"].ToString();
  1753. joParam["invinfo"] = joRtn;
  1754. JArray selDtl = new JArray();
  1755. selDtl.Add(JObject.Parse(joParam["invinfo"].ToString()));
  1756. //MessageBox.Show(selDtl.ToString());
  1757. joParamA = new JObject();
  1758. joParamA.Add("invinfoDetail", selDtl);
  1759. return 0;
  1760. }
  1761. else if (funno == "3503")
  1762. {
  1763. JObject joRtn = JObject.Parse(joParam["purcinfo"].ToString());
  1764. //if (!string.IsNullOrEmpty(joParam["purcinfo"]["drugtracinfo"].ToString()))
  1765. //{
  1766. // joRtn.Add("drug_trac_info", joParam["purcinfo"]["drugtracinfo"]);
  1767. // joParam["purcinfo"] = joRtn;
  1768. //}
  1769. joRtn.Add("prdr_name", joParam["purcinfo"]["prodentp_name"].ToString());
  1770. joParam["purcinfo"] = joRtn;
  1771. JArray selDtl = new JArray();
  1772. selDtl.Add(JObject.Parse(joParam["purcinfo"].ToString()));
  1773. //MessageBox.Show(selDtl.ToString());
  1774. joParamA = new JObject();
  1775. joParamA.Add("purcinfoDetail", selDtl);
  1776. return 0;
  1777. }
  1778. else if ( funno == "3504")
  1779. {
  1780. JObject joRtn = JObject.Parse(joParam["purcinfo"].ToString());
  1781. //if (!string.IsNullOrEmpty(joParam["purcinfo"]["drugtracinfo"].ToString()))
  1782. //{
  1783. // joRtn.Add("drug_trac_info", joParam["purcinfo"]["drugtracinfo"]);
  1784. // joParam["purcinfo"] = joRtn;
  1785. //}
  1786. JArray selDtl = new JArray();
  1787. selDtl.Add(JObject.Parse(joParam["purcinfo"].ToString()));
  1788. //MessageBox.Show(selDtl.ToString());
  1789. joParamA = new JObject();
  1790. joParamA.Add("purcinfoDetail", selDtl);
  1791. return 0;
  1792. }
  1793. else { return -1; }
  1794. }
  1795. catch (Exception ex)
  1796. {
  1797. errMsg = "parsejoParam 解析入参异常1:" + errMsg;
  1798. return -1;
  1799. }
  1800. }
  1801. private int parsejoParamSet(JObject joParam, string funno, out string errMsg)
  1802. {
  1803. errMsg = "";
  1804. try
  1805. {
  1806. if (funno == "3505")
  1807. {
  1808. string setl_id = joParam["selinfo"]["setl_id"].ToString();
  1809. string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE billType = 1 ";
  1810. sqlStr = sqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  1811. sqlStr = sqlStr + " AND SettlementID ='" + setl_id + "'";
  1812. JObject joSql = new JObject();
  1813. joSql.Add("sqlStr", sqlStr);
  1814. JObject joSettlInfo = mIS.QuerySettlementInfo(joSql);
  1815. //查询结算信息
  1816. JObject Outpam = JObject.Parse(joSettlInfo["result"]["data"][0].ToString());
  1817. dynamic setlinfo = new JObject();//结算信息节点
  1818. setlinfo.setl_id = Outpam["SettlementID"];//结算ID
  1819. setlinfo.mdtrt_id = Outpam["MdtrtID"];//就诊ID
  1820. setlinfo.psn_no = Outpam["PersonnelNO"];//人员编号
  1821. setlinfo.psn_name = Outpam["PatientName"];//人员姓名
  1822. setlinfo.psn_cert_type = Outpam["MdtrtCertType"];//凭证类型
  1823. setlinfo.certno = Outpam["CertificateNO"];//证件号码
  1824. setlinfo.gend = Outpam["Gender"];//性别
  1825. setlinfo.naty = Outpam["Nation"];//民族
  1826. setlinfo.brdy = Outpam["BirthDay"];//出生日期
  1827. setlinfo.age = Outpam["Age"];//年龄
  1828. setlinfo.insutype = Outpam["InsuranceType"];//险种类型
  1829. setlinfo.psn_type = Outpam["PersonType"];//人员类别
  1830. setlinfo.cvlserv_flag = Outpam["CivilserviceFlag"];//公务员标志
  1831. setlinfo.setl_time = Outpam["SettlementTime"];//结算时间
  1832. setlinfo.mdtrt_cert_type = Outpam["MdtrtCertType"];//就诊凭证类型
  1833. setlinfo.med_type = Outpam["MedicalType"];//医疗类别
  1834. setlinfo.medfee_sumamt = Outpam["Sumamt"];//医疗费总额
  1835. setlinfo.fulamt_ownpay_amt = Outpam["OwnPayAmount"];//全自费金额
  1836. setlinfo.overlmt_selfpay = Outpam["OverLimitAmount"];//超限价自费费用
  1837. setlinfo.preselfpay_amt = Outpam["PreSelfPayAmount"];//先行自付金额
  1838. setlinfo.inscp_scp_amt = Outpam["InPolicyRangeAmount"];//符合政策范围金额
  1839. setlinfo.act_pay_dedc = Outpam["ActualPayDeductible"];//实际支付起付线
  1840. setlinfo.hifp_pay = Outpam["HealthInsurancePay"];//基本医疗保险统筹基金支出
  1841. setlinfo.pool_prop_selfpay = Outpam["HealthInsuranceRatio"];//基本医疗保险统筹基金支付比例
  1842. setlinfo.cvlserv_pay = Outpam["CivilserviceAllowancePay"];//公务员医疗补助资金支出
  1843. setlinfo.hifes_pay = Outpam["EnterpriseSupplementPay"];//企业补充医疗保险基金支出
  1844. setlinfo.hifmi_pay = Outpam["SeriousIllnessPay"];//居民大病保险资金支出
  1845. setlinfo.hifob_pay = Outpam["LargeExpensesSupplementPay"];//职工大额医疗费用补助基金支出
  1846. setlinfo.maf_pay = Outpam["MedicalAssistPay"];//医疗救助基金支出
  1847. setlinfo.oth_pay = Outpam["OtherPay"];//结算ID
  1848. setlinfo.fund_pay_sumamt = Outpam["FundPaySumamt"];//基金支付总额
  1849. setlinfo.psn_part_amt = Outpam["PersonPaySumamt"];//个人负担总金额
  1850. setlinfo.acct_pay = Outpam["AccountPaySumamt"];//个人账户支出
  1851. setlinfo.psn_cash_pay = Outpam["PersonCashPay"];//个人现金支出
  1852. setlinfo.balc = Outpam["Balance"];//余额
  1853. setlinfo.acct_mulaid_pay = Outpam["AccountMutualAidAmount"];//个人账户共济支付金额
  1854. setlinfo.medins_setl_id = Outpam["OrganSettlementID"];//医药机构结算结算ID
  1855. setlinfo.clr_optins = Outpam["ClearingOrgan"];//clr_optins
  1856. setlinfo.clr_way = Outpam["ClearingWay"];//clr_way
  1857. setlinfo.clr_type = Outpam["ClearingType"];//clr_type
  1858. setlinfo.exp_content = "";//exp_content
  1859. setlinfo.hosp_part_amt = Outpam["HospitalPartAmount"];//医院负担金额
  1860. setlinfo.hifdm_pay = 0;//伤残人员医疗保障基金支出
  1861. dynamic setlinfo1 = new JObject();//结算信息节点
  1862. setlinfo1.setl_id = Outpam["SettlementID"];//结算ID
  1863. string outParam = "";
  1864. string AdmID = Outpam["AdmID"].ToString();
  1865. string billID = Outpam["BillID"].ToString();
  1866. string recordID = Outpam["RecordID"].ToString();
  1867. Global.pat.adm_Dr = int.Parse(AdmID);
  1868. Global.pat.billID = billID;
  1869. Global.pat.recordID = recordID;
  1870. //获取IS费用
  1871. if (hIS.getHisFee(Global.pat, out outParam) != 0)
  1872. {
  1873. MessageBox.Show("获取HIS费用失败");
  1874. }
  1875. //调用医保平台转换HIS费用(转换医保编码等)
  1876. JObject joHisFee = JObject.Parse(outParam);
  1877. if (mIS.convertHisFeeWithInsuCode(joHisFee, out outParam) != 0)
  1878. {
  1879. MessageBox.Show("获取HIS费用医保对照关系失败");
  1880. }
  1881. JArray jaFeeDetail = JArray.Parse(JsonHelper.getDestValue(JObject.Parse(outParam), "data"));
  1882. MessageBox.Show("11111");
  1883. JObject jaFeeOne = new JObject();
  1884. for (int i = 0; i < jaFeeDetail.Count; i++)
  1885. {
  1886. jaFeeOne.Add("feedetl_sn", jaFeeDetail[i]["feedetl_sn"]);//费用明细流水号
  1887. jaFeeOne.Add("rxno", "");//处方号
  1888. if (string.IsNullOrEmpty(jaFeeDetail[i]["rx_circ_flag"].ToString()))
  1889. {
  1890. jaFeeOne.Add("rx_circ_flag", "");//外购处方标志
  1891. }
  1892. else
  1893. {
  1894. jaFeeOne.Add("rx_circ_flag", jaFeeDetail[i]["rx_circ_flag"]);//外购处方标志
  1895. }
  1896. jaFeeOne.Add("fee_ocur_time", jaFeeDetail[i]["fee_ocur_time"]);
  1897. jaFeeOne.Add("med_list_codg", jaFeeDetail[i]["med_list_codg"]);
  1898. jaFeeOne.Add("medins_list_codg", jaFeeDetail[i]["medins_list_codg"]);
  1899. jaFeeOne.Add("medins_list_name", jaFeeDetail[i]["medins_list_desc"]);
  1900. jaFeeOne.Add("prodname", jaFeeDetail[i]["medins_list_desc"]);
  1901. if (string.IsNullOrEmpty(jaFeeDetail[i]["spec"].ToString()))
  1902. {
  1903. jaFeeOne.Add("spec", "");
  1904. }
  1905. else
  1906. {
  1907. jaFeeOne.Add("spec", jaFeeDetail[i]["spec"]);
  1908. }
  1909. if (string.IsNullOrEmpty(jaFeeDetail[i]["doseForm"].ToString()))
  1910. {
  1911. jaFeeOne.Add("dosform_name", "");
  1912. }
  1913. else
  1914. {
  1915. jaFeeOne.Add("dosform_name", jaFeeDetail[i]["doseForm"]);
  1916. }
  1917. jaFeeOne.Add(" det_item_fee_sumamt", jaFeeDetail[i]["det_item_fee_sumamt"]);
  1918. jaFeeOne.Add("cnt", jaFeeDetail[i]["cnt"]);
  1919. jaFeeOne.Add("pric", jaFeeDetail[i]["pric"]);
  1920. if (string.IsNullOrEmpty(jaFeeDetail[i]["sin_dos_dscr"].ToString()))
  1921. {
  1922. jaFeeOne.Add("sin_dos_dscr", "");
  1923. }
  1924. else
  1925. {
  1926. jaFeeOne.Add("sin_dos_dscr", jaFeeDetail[i]["sin_dos_dscr"]);
  1927. }
  1928. if (string.IsNullOrEmpty(jaFeeDetail[i]["used_frqu_dscr"].ToString()))
  1929. {
  1930. jaFeeOne.Add("used_frqu_dscr", "");
  1931. }
  1932. else
  1933. {
  1934. jaFeeOne.Add("used_frqu_dscr", jaFeeDetail[i]["used_frqu_dscr"]);
  1935. }
  1936. if (string.IsNullOrEmpty(jaFeeDetail[i]["prd_days"].ToString()))
  1937. {
  1938. jaFeeOne.Add("prd_days", "");
  1939. }
  1940. else
  1941. {
  1942. jaFeeOne.Add("prd_days", jaFeeDetail[i]["prd_days"]);
  1943. }
  1944. if (string.IsNullOrEmpty(jaFeeDetail[i]["medc_way_dscr"].ToString()))
  1945. {
  1946. jaFeeOne.Add("medc_way_dscr", "");
  1947. }
  1948. else
  1949. {
  1950. jaFeeOne.Add("medc_way_dscr", jaFeeDetail[i]["medc_way_dscr"]);
  1951. }
  1952. if (string.IsNullOrEmpty(jaFeeDetail[i]["bilg_dr_codg"].ToString()))
  1953. {
  1954. jaFeeOne.Add("bilg_dr_codg", "");
  1955. }
  1956. else
  1957. {
  1958. jaFeeOne.Add("bilg_dr_codg", jaFeeDetail[i]["bilg_dr_codg"]);
  1959. }
  1960. if (string.IsNullOrEmpty(jaFeeDetail[i]["bilg_dr_name"].ToString()))
  1961. {
  1962. jaFeeOne.Add("bilg_dr_name", "");
  1963. }
  1964. else
  1965. {
  1966. jaFeeOne.Add("bilg_dr_name", jaFeeDetail[i]["bilg_dr_name"]);
  1967. }
  1968. jaFeeOne.Add("phar_name", "");
  1969. jaFeeOne.Add("phar_prac_cert_no", "");
  1970. jaFeeOne.Add("tcmdrug_used_way", ""); //中药使用方式 1复方 2单方 必填
  1971. jaFeeOne.Add("trdn_flag", "1");//拆零标志 必填 0否 1是
  1972. jaFeeDetail.Add(jaFeeOne);
  1973. jaFeeOne = new JObject();
  1974. }
  1975. MessageBox.Show("22222");
  1976. joParam992001.Add("setlinfo", JObject.Parse(setlinfo));//结算信息节点
  1977. joParam992004.Add("setlinfo", JObject.Parse(setlinfo1));
  1978. joParam992004.Add("drugdetail", jaFeeDetail);//购药明细节点
  1979. //JObject OutJo = invoker.invokeCenterServiceJXC("992001", JObject.Parse(JsonHelper.setCenterInpar("992001", Jo992001)));
  1980. //MessageBox.Show("上传返回:" + OutJo.ToString());
  1981. }
  1982. if (funno == "3506")
  1983. {
  1984. string setl_id = joParam["selinfo"]["setl_id"].ToString();
  1985. string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE billType = -1 ";
  1986. sqlStr = sqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  1987. sqlStr = sqlStr + " AND SettlementID ='" + setl_id + "'";
  1988. JObject joSql = new JObject();
  1989. joSql.Add("sqlStr", sqlStr);
  1990. JObject joSettlInfo = mIS.QuerySettlementInfo(joSql);
  1991. //查询结算信息
  1992. JObject Outpam = JObject.Parse(joSettlInfo["result"]["data"][0].ToString());
  1993. string mdtrt_id = Outpam["MdtrtID"].ToString();//ADMID
  1994. string sqlStr1 = "SELECT * FROM BS_MedInsuSettlement WHERE billType = 1 ";
  1995. sqlStr1 = sqlStr1 + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
  1996. sqlStr1 = sqlStr1 + " AND MdtrtID ='" + mdtrt_id + "'";
  1997. JObject joSql1 = new JObject();
  1998. joSql1.Add("sqlStr1", sqlStr);
  1999. JObject joSettlInfo1 = mIS.QuerySettlementInfo(joSql1);
  2000. JObject Outpam1= JObject.Parse(joSettlInfo1["result"]["data"][0].ToString());
  2001. dynamic setlinfo = new JObject();//结算信息节点
  2002. setlinfo.setl_id = Outpam["SettlementID"];//结算ID
  2003. setlinfo.init_setl_id = Outpam1["SettlementID"]; ;//结算ID
  2004. setlinfo.setl_time = Outpam["SettlementTime"];//结算时间
  2005. setlinfo.mdtrt_id = Outpam["MdtrtID"];//就诊ID
  2006. setlinfo.psn_no = Outpam["PersonnelNO"];//人员编号
  2007. setlinfo.exp_content = "";//人员姓名
  2008. dynamic setlinfo1 = new JObject();//结算信息节点
  2009. setlinfo1.setl_id = Outpam["SettlementID"];//结算ID
  2010. joParam992002.Add("data", JObject.Parse(setlinfo));//结算信息节点
  2011. string AdmID = Outpam["AdmID"].ToString();
  2012. string billID = Outpam["BillID"].ToString();
  2013. string recordID = Outpam["RecordID"].ToString();
  2014. Global.pat.adm_Dr = int.Parse(AdmID);
  2015. Global.pat.billID = billID;
  2016. Global.pat.recordID = recordID;
  2017. string outParam = "";
  2018. //获取IS费用
  2019. if (hIS.getHisFee(Global.pat, out outParam) != 0)
  2020. {
  2021. MessageBox.Show("获取HIS费用失败");
  2022. }
  2023. //调用医保平台转换HIS费用(转换医保编码等)
  2024. JObject joHisFee = JObject.Parse(outParam);
  2025. if (mIS.convertHisFeeWithInsuCode(joHisFee, out outParam) != 0)
  2026. {
  2027. MessageBox.Show("获取HIS费用医保对照关系失败");
  2028. }
  2029. JArray jaFeeDetail = JArray.Parse(JsonHelper.getDestValue(JObject.Parse(outParam), "data"));
  2030. JObject jaFeeOne = new JObject();
  2031. for (int i = 0; i < jaFeeDetail.Count; i++)
  2032. {
  2033. jaFeeOne.Add("feedetl_sn", jaFeeDetail[i]["feedetl_sn"]);//费用明细流水号
  2034. jaFeeOne.Add("rxno", "");//处方号
  2035. if (string.IsNullOrEmpty(jaFeeDetail[i]["rx_circ_flag"].ToString()))
  2036. {
  2037. jaFeeOne.Add("rx_circ_flag", "");//外购处方标志
  2038. }else {
  2039. jaFeeOne.Add("rx_circ_flag", jaFeeDetail[i]["rx_circ_flag"]);//外购处方标志
  2040. }
  2041. jaFeeOne.Add("fee_ocur_time", jaFeeDetail[i]["fee_ocur_time"]);
  2042. jaFeeOne.Add("med_list_codg", jaFeeDetail[i]["med_list_codg"]);
  2043. jaFeeOne.Add("medins_list_codg", jaFeeDetail[i]["medins_list_codg"]);
  2044. jaFeeOne.Add("medins_list_name", jaFeeDetail[i]["medins_list_desc"]);
  2045. jaFeeOne.Add("prodname", jaFeeDetail[i]["medins_list_desc"]);
  2046. if (string.IsNullOrEmpty(jaFeeDetail[i]["spec"].ToString()))
  2047. {
  2048. jaFeeOne.Add("spec", "");
  2049. }
  2050. else
  2051. {
  2052. jaFeeOne.Add("spec", jaFeeDetail[i]["spec"]);
  2053. }
  2054. if (string.IsNullOrEmpty(jaFeeDetail[i]["doseForm"].ToString()))
  2055. {
  2056. jaFeeOne.Add("dosform_name", "");
  2057. }
  2058. else
  2059. {
  2060. jaFeeOne.Add("dosform_name", jaFeeDetail[i]["doseForm"]);
  2061. }
  2062. jaFeeOne.Add(" det_item_fee_sumamt", jaFeeDetail[i]["det_item_fee_sumamt"]);
  2063. jaFeeOne.Add("cnt", jaFeeDetail[i]["cnt"]);
  2064. jaFeeOne.Add("pric", jaFeeDetail[i]["pric"]);
  2065. if (string.IsNullOrEmpty(jaFeeDetail[i]["sin_dos_dscr"].ToString()))
  2066. {
  2067. jaFeeOne.Add("sin_dos_dscr", "");
  2068. }
  2069. else
  2070. {
  2071. jaFeeOne.Add("sin_dos_dscr", jaFeeDetail[i]["sin_dos_dscr"]);
  2072. }
  2073. if (string.IsNullOrEmpty(jaFeeDetail[i]["used_frqu_dscr"].ToString()))
  2074. {
  2075. jaFeeOne.Add("used_frqu_dscr", "");
  2076. }
  2077. else
  2078. {
  2079. jaFeeOne.Add("used_frqu_dscr", jaFeeDetail[i]["used_frqu_dscr"]);
  2080. }
  2081. if (string.IsNullOrEmpty(jaFeeDetail[i]["prd_days"].ToString()))
  2082. {
  2083. jaFeeOne.Add("prd_days", "");
  2084. }
  2085. else
  2086. {
  2087. jaFeeOne.Add("prd_days", jaFeeDetail[i]["prd_days"]);
  2088. }
  2089. if (string.IsNullOrEmpty(jaFeeDetail[i]["medc_way_dscr"].ToString()))
  2090. {
  2091. jaFeeOne.Add("medc_way_dscr", "");
  2092. }
  2093. else
  2094. {
  2095. jaFeeOne.Add("medc_way_dscr", jaFeeDetail[i]["medc_way_dscr"]);
  2096. }
  2097. if (string.IsNullOrEmpty(jaFeeDetail[i]["bilg_dr_codg"].ToString()))
  2098. {
  2099. jaFeeOne.Add("bilg_dr_codg", "");
  2100. }
  2101. else
  2102. {
  2103. jaFeeOne.Add("bilg_dr_codg", jaFeeDetail[i]["bilg_dr_codg"]);
  2104. }
  2105. if (string.IsNullOrEmpty(jaFeeDetail[i]["bilg_dr_name"].ToString()))
  2106. {
  2107. jaFeeOne.Add("bilg_dr_name", "");
  2108. }
  2109. else
  2110. {
  2111. jaFeeOne.Add("bilg_dr_name", jaFeeDetail[i]["bilg_dr_name"]);
  2112. }
  2113. jaFeeOne.Add("phar_name", "");
  2114. jaFeeOne.Add("phar_prac_cert_no", "");
  2115. jaFeeOne.Add("tcmdrug_used_way", ""); //中药使用方式 1复方 2单方 必填
  2116. jaFeeOne.Add("trdn_flag", "1");//拆零标志 必填 0否 1是
  2117. jaFeeDetail.Add(jaFeeOne);
  2118. jaFeeOne = new JObject();
  2119. }
  2120. joParam992004.Add("setlinfo", JObject.Parse(setlinfo1));
  2121. joParam992004.Add("drugdetail", jaFeeDetail);//购药明细节点
  2122. }
  2123. return 0;
  2124. }
  2125. catch (Exception ex)
  2126. {
  2127. errMsg = "parsejoParam 解析入参异常2:" + errMsg;
  2128. return -1;
  2129. }
  2130. }
  2131. }
  2132. }