InsuBusiness.cs 128 KB

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