1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819 |
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using PTMedicalInsurance.Common;
- using PTMedicalInsurance.Business;
- using System.Windows.Forms;
- using PTMedicalInsurance.Helper;
- using Newtonsoft.Json.Linq;
- using PTMedicalInsurance.Variables;
- using PTMedicalInsurance.Forms;
- using System.IO;
- using System.Reflection;
- using System.Data;
- namespace PTMedicalInsurance
- {
- public class InsuBusiness : IInsuBusiness
- {
- //定义相关的变量
- private Patients patient;
- private Fees fee;
- private Settlements settlement;
- //json对象属性
- private JObject joInParam;
- private JArray jaSession ;
- private JArray jaParams;
- private JObject joParam;
- private JObject joInterface;
- //设置业务实例
- CenterBusiness cBus = new CenterBusiness();
- HisMainBusiness hBus = new HisMainBusiness();
- HisIrisServices hIS = new HisIrisServices();
- MIIrisServices mIS= new MIIrisServices();
- InvokeHelper invoker = new InvokeHelper();
- CardReader_HN CardRead = new CardReader_HN();
- //
- private string businessType;
- public InsuBusiness()
- {
- Global.curEvt.path = Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location);
- ComputerInfo comp = new ComputerInfo();
- Global.curEvt.mac = comp.GetMAC();
- Global.curEvt.ip = comp.GetIP(); //"10.1.4.100";
- Global.pat.insuplc_admdvs = ""; //如果是NULL中心会报错
- }
- private int parseInparam(string inParam,out string errMsg)
- {
- errMsg = "";
- try
- {
- joInParam = JObject.Parse(inParam);
- jaSession = JArray.Parse(JsonHelper.getDestValue(joInParam, "session"));
- Global.curEvt.jaSession = jaSession;
- jaParams = JArray.Parse(JsonHelper.getDestValue(joInParam, "params"));
- joParam = JObject.FromObject(jaParams[0]);
- joInterface = JObject.Parse(JsonHelper.getDestValue(joInParam, "interfaceinfo"));
- businessType = JsonHelper.getDestValue(joInParam, "businessType");
- return 0;
- }
- catch (Exception ex)
- {
- errMsg = "parseInparam 解析入参异常:" + errMsg;
- return -1;
- }
- }
-
- /// <summary>
- /// 签到
- /// </summary>
- /// <param name="InParam"></param>
- /// <returns></returns>
- public string Init(string InParam)
- {
- string errMsg, rtnResult ="";
- JObject joRtn = new JObject();
- try
- {
- if (hBus.initEnvironment(InParam, out errMsg) != 0)
- {
- return JsonHelper.setExceptionJson(-100, "initEnvironment 失败", errMsg).ToString();
- }
- else
- {
- if (mIS.isSigned(ref Global.curEvt.signno) != true)
- {
- //签到
- if (cBus.signIn(out joRtn) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "签到异常", (string)joRtn["err_msg"]).ToString();
- return rtnResult;
- }
- else
- {
- Global.curEvt.signno = JsonHelper.getDestValue(joRtn, "output.signinoutb.sign_no");
- //插入签到表
- if (mIS.saveSignRecord(Global.curEvt.signno, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "中心签到成功但插入签到表失败:" + errMsg, null).ToString();
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "签到成功", joRtn).ToString();
- }
- }
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "初始化成功!", null).ToString();
- }
- return rtnResult;
- }
- }
- catch (Exception ex)
- {
- rtnResult = JsonHelper.setExceptionJson(-100, "Init 异常", ex.Message).ToString();
- return rtnResult;
- }
- finally
- {
- Global.writeLog("初始化结果:" + rtnResult);
- }
- }
- /// <summary>
- /// 初始化
- /// </summary>
- /// <param name="inParam"></param>
- /// <param name="outParam"></param>
- /// <returns></returns>
- private int init(string inParam, out string outParam)
- {
- string errMsg;
- outParam = "";
- try
- {
- //BS架构调用方式问题,每次调用都需要重新初始化
- JObject joInitRtn = JObject.Parse(Init(inParam));
- //开启或关闭电子处方流转测试环境
- Global.inf.bPresCirulTest = false;
- //医保电子处方测试环境信息
- if (Global.inf.bPresCirulTest == true)
- {
- Global.inf.ecURL = "http://10.85.254.46:8000/hss-call-service-interface";
- }
- if (JsonHelper.parseIrisRtnValue(joInitRtn, out errMsg) != 0)
- {
- outParam = JsonHelper.setExceptionJson(-100, "init(HIS医保环境初始化)", errMsg).ToString();
- return -1;
- }
- else
- {
- return 0;
- }
- }
- catch (Exception ex)
- {
- outParam = JsonHelper.setExceptionJson(-100, "init(HIS医保环境初始化)异常", ex.Message).ToString();
- return -1;
- }
- }
- /// <summary>
- /// 获取患者信息
- /// </summary>
- /// <param name="InParam"></param>
- /// <returns></returns>
- public string GetPatientInfo(string InParam)
- {
- Global.writeLog("GetPatientInfo入参:" + JsonHelper.Compress(InParam));
- //设置返回值,错误信息
- int errCode;
- string errMsg, rtnResult = "",outParam;
- //BS架构调用方式问题,每次调用都需要重新初始化
- if (init(InParam,out outParam)!= 0)
- {
- rtnResult = outParam;
- return rtnResult;
- }
- JObject joInParam = JObject.Parse(InParam);
- string businessType = JsonHelper.getDestValue(joInParam,"businessType");
- Global.pat.admID = JsonHelper.getDestValue(joInParam, "params[0].admID");
- if (!string.IsNullOrEmpty(Global.pat.admID))
- {
- Global.pat.adm_Dr = int.Parse(Global.pat.admID);
- }
- try
- {
- switch (businessType)
- {
- case "M1"://门诊读卡
- {
- //打开读卡窗口,操作员选择读卡类型后进行读卡器读卡,再进行1101获取参保信息
- if (hBus.readCard(out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-100, "读卡失败!", outParam).ToString();
- }
- else
- {
- string patInfo = outParam;
- if (hBus.setGlobalPatAfaterShowPatInfo(patInfo, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "setGlobalPatAfaterShowPatInfo", errMsg).ToString();
- return rtnResult;
- }
- //展示患者信息界面
- if (hBus.showPatInfo(patInfo, out outParam) != 0)
- {
- rtnResult = outParam;
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "", JObject.Parse(outParam)).ToString();
- }
- }
- break;
- }
- case "Z1"://住院读卡
- {
- //打开读卡窗口,操作员选择读卡类型后进行读卡器读卡,再进行1101获取参保信息
- if (hBus.readCard(out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-100, "读卡失败!", outParam).ToString();
- }
- else
- {
- string patInfo = outParam;
- if (hBus.setGlobalPatAfaterShowPatInfo(patInfo, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "setGlobalPatAfaterShowPatInfo", errMsg).ToString();
- return rtnResult;
- }
- //展示患者信息界面
- if (hBus.showPatInfo(patInfo, out outParam) != 0)
- {
- rtnResult = outParam;
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0,"",JObject.Parse(outParam)).ToString();
- }
- }
- break;
- }
- }
- //在这里判断,建档的时候会直接拦截,因此加上判断条件
- //校验HIS姓名与医保姓名是否一致
- if (!string.IsNullOrEmpty(Global.pat.admID))
- {
- if (hBus.checkName(Global.pat.name, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "校验HIS与医保姓名是否一致", errMsg).ToString();
- return rtnResult;
- }
- }
- return rtnResult;
- }
- catch (Exception ex)
- {
- rtnResult = JsonHelper.setIrisReturnValue(-1 , "GetPatientInfo发生异常;" + ex.Message,null).ToString();
- return rtnResult;
- }
- finally
- {
- Global.writeLog("GetPatientInfo出参:" + JsonHelper.Compress(rtnResult));
- }
- }
- /// <summary>
- /// 登记
- /// </summary>
- /// <param name="InParam"></param>
- /// <returns></returns>
- public string Register(string InParam)
- {
- Global.writeLog("Register 入参:" + JsonHelper.Compress(InParam));
- //设置返回值,错误信息
- string errMsg, rtnResult = "", outParam;
- try
- {
- //解析入参
- if (parseInparam(InParam, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
- return rtnResult;
- }
- //BS架构调用方式问题,每次调用都需要重新初始化
- if (init(InParam, out outParam) != 0)
- {
- rtnResult = outParam;
- return rtnResult;
- }
- //获取pat
- hBus.GetRegPatInfo(businessType, joInParam, out Global.pat);
- switch (businessType)
- {
- case "M2"://门诊登记
- {
- break;
- }
- case "M2C"://门诊登记撤销
- {
- break;
- }
- case "Z0"://住院修改
- {
- break;
- }
- case "Z2"://入院登记
- {
- Global.pat.admType = 2;
- Global.writeLog(Global.pat.insuType);
- string regInParam = "";
-
- //显示登记面板
- if (hBus.showInPatRegisterForm( out regInParam) == 0)
- {
- Global.writeLog(regInParam);
- JObject joRegIn_plain = JObject.Parse(JsonHelper.setCenterInpar_plain("2401", regInParam));
- JObject joRegIn = JObject.Parse(JsonHelper.setCenterInpar("2401", regInParam));
- //上传给中心
- JObject joRegOut = invoker.invokeCenterService("2401", joRegIn);
- //将中心返回的结果返回HIS,调用HIS服务进行保存
- if (JsonHelper.parseCenterRtnValue(joRegOut,out errMsg) == 0)
- {
- joRegOut.Add("validflag",1);
- joRegOut.Add("regstate", 1);
- joRegOut.Add("type", 1);
- Global.pat.mdtrtID = JsonHelper.getDestValue(joRegOut, "output.result.mdtrt_id");
- //插入患者本次就诊用的参保信息
- if (hBus.insertPatCurInsuInfo(JsonHelper.getDestValue(joParam, "patientInfo"), out outParam) != 0)
- {
- if (DialogResult.Yes == MessageBox.Show(outParam, " 是否继续? ", MessageBoxButtons.YesNo))
- {
- }
- else
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "插入患者本次就诊用的参保信息,请联系管理员!", outParam).ToString();
- return rtnResult;
- }
- }
- //插入医保平台
- if (mIS.saveInpatRegisterInfo(joRegIn_plain, joRegOut, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "云平台保存登记信息", outParam).ToString();
- return rtnResult;
- }
- //返回登记信息,插入HIS
- if (hIS.returnRegisterInfo(joRegIn_plain, joRegOut, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "HIS平台保存登记信息", outParam).ToString();
- return rtnResult;
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "登记成功", null).ToString();
- return rtnResult;
- }
- }
- else
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "展示登记界面", errMsg).ToString();
- return rtnResult;
- }
- }
- else
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "展示登记界面", regInParam).ToString();
- return rtnResult;
- }
- }
- case "Z2C"://入院登记取消
- {
- //if (DialogResult.Yes == MessageBox.Show("即将进行取消中心医保登记,确定继续吗?", " 询问? ", MessageBoxButtons.YesNo))
- //{
- //}
- //else
- //{
- // rtnResult = JsonHelper.setExceptionJson(-1, "收费员撤销取消登记操作!", outParam).ToString();
- // return rtnResult;
- //}
- //取消中心登记
- if (cBus.cancleRegister("2404", out outParam) != 0)
- {
- //如果医保中心没有HIS所传的医保登记信息则默认撤销HIS登记信息
- int i = outParam.IndexOf("不存在有效的就诊登记信息");
- if (i != 0)
- {
- if (DialogResult.Yes != MessageBox.Show("医保中心提示:" + outParam+ ",是否强制撤销HIS医保登记信息?", "提示", MessageBoxButtons.YesNo))
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记失败,", outParam).ToString();
- return rtnResult;
- }
- }
- else
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记失败,", outParam).ToString();
- return rtnResult;
- }
- }
- //取消医保平台登记
- if (mIS.cancleRegister(1, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记成功,但云医保平台取消失败,", outParam).ToString();
- return rtnResult;
- }
- //取消HIS 登记
- if (hIS.cancleRegister( out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "中心和云医保平台取消登记成功,但HIS取消失败,", outParam).ToString();
- return rtnResult;
- }
- else
- {
- //CM 20230602 删除医保平台医保费用明细上传表数据
- mIS.deleteFee(out errMsg);
- rtnResult = JsonHelper.setIrisReturnValue(0, "取消医保登记成功", null).ToString();
- return rtnResult;
- }
- }
- case "Z6"://出院登记
- {
- break;
- }
- case "Z6C"://出院登记取消
- {
- if (cBus.cancleRegister("2405", out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "取消出院登记", errMsg).ToString();
- return rtnResult;
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "取消出院登记成功", null).ToString();
- return rtnResult;
- }
- break;
- }
- default:
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "Register 交易", "传入的业务编码不对!").ToString();
- return rtnResult;
- }
- }
- }
- catch (Exception ex)
- {
- rtnResult = JsonHelper.setIrisReturnValue(-1, "Register 发生异常;" + ex.Message, null).ToString();
- return rtnResult;
- }
- finally
- {
- Global.writeLog("Register 出参:" + JsonHelper.Compress(rtnResult));
- }
- return "";
- }
- /// <summary>
- /// 费用上传
- /// </summary>
- /// <param name="InParam"></param>
- /// <returns></returns>
- public string FeeUpload(string InParam)
- {
- Global.writeLog("FeeUpload 入参:" + JsonHelper.Compress(InParam));
- //设置返回值,错误信息
- int errCode;
- string errMsg, rtnResult = "", outParam;
- try
- {
- //解析入参
- if (parseInparam(InParam, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
- return rtnResult;
- }
-
- //BS架构调用方式问题,每次调用都需要重新初始化
- if (init(InParam, out outParam) != 0)
- {
- rtnResult = outParam;
- return rtnResult;
- }
- //获取pat
- hBus.GetFeeHisInfo(businessType, joInParam, out Global.pat);
- switch (businessType)
- {
- case "M3"://门诊费用上传
- {
- break;
- }
- case "M3C"://门诊费用撤销
- {
- break;
- }
- case "Z3"://入院费用上传
- {
- //从医保平台获取患者详细的医保登记信息
- if (mIS.queryRegisterInfo(1, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "查询患者云平台登记信息", outParam).ToString();
- return rtnResult;
- }
- JObject joReg = JObject.Parse(outParam);
- Global.pat.medType = JsonHelper.getDestValue(joReg, "data.MedicalType");
- Global.pat.insuType = JsonHelper.getDestValue(joReg, "data.InsuType");
- //先取消中心费用传送
- cBus.cancleFeeUpload("2302", out errMsg);
- //再删除医保传送表的数据
- mIS.deleteFee( out errMsg);
- #region【住院费用上传前调用3101事前服务】
- if (Global.curEvt.ext.isOpenAnalysis)
- {
- if (hIS.GetInsuPatInfo("4", Global.pat, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "获取3101医保明细审核事前分析服务入参失败:", outParam).ToString();
- return rtnResult;
- }
- else
- {
- //2.调用医保3101明细审核事前分析服务
- JObject joInput = new JObject();
- joInput = JObject.Parse(outParam);
- JObject jo3101Rtn = invoker.invokeCenterService("3101", JsonHelper.setCenterInpar("3101", joInput.ToString().Replace("\r\n", "")));
- if (JsonHelper.parseCenterRtnValue(jo3101Rtn, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
- return rtnResult;
- }
- else
- {
- JArray jaResult = JArray.Parse(JsonHelper.getDestValue(jo3101Rtn, "output.result"));
- if (jaResult.HasValues)
- {
- PreAndInProcessAnalysisForm paipaForm = new PreAndInProcessAnalysisForm(jo3101Rtn);
- paipaForm.Text = "事前事中智能审核-3101医保明细审核事前分析服务调用失败返回";
- if (paipaForm.ShowDialog() != DialogResult.OK)
- {
- errMsg = "事前事中审核不通过,操作员取消!";
- rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
- return rtnResult;
- }
- else
- {
- //河南医保没有开通3103接口
- //【3103】事前事中服务反馈服务
- //if (hBus.PreAnalysisFeedBack("3101", paipaForm.JrID, out errMsg) != 0)
- //{
- // rtnResult = JsonHelper.setExceptionJson(-1, "【3103】事前事中服务反馈服务", errMsg).ToString();
- // return rtnResult;
- //}
- }
- }
- }
- }
- }
- //1.获取3101入参报文
- /* 20221207 CM 朱鹏飞要求屏蔽调用事前事中服务交易
- if (hIS.GetInsuPatInfo("5", Global.pat, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "获取3101医保明细审核事前分析服务入参失败:", outParam).ToString();
- return rtnResult;
- }
- else
- {
- //2.调用医保3101明细审核事前分析服务
- JObject joInput = new JObject();
- joInput = JObject.Parse(outParam);
- JObject jo3101Rtn = invoker.invokeCenterService("3101", JsonHelper.setCenterInpar("3101", joInput.ToString().Replace("\r\n", "")));
- if (JsonHelper.parseCenterRtnValue(jo3101Rtn, out errMsg) != 0)
- {
- DialogResult dr = MessageBox.Show("【3101】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
- if (dr != DialogResult.OK)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
- return rtnResult;
- }
- }
- }
- */
- #endregion
- //开始进行费用传送
- //调用HIS费用查询信息
- if (hIS.getHisFee(Global.pat, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "获取HIS费用", outParam).ToString();
- return rtnResult;
- }
- //调用医保平台转换
- JObject joHisFee = JObject.Parse(outParam);
- if (mIS.convertHisFeeWithInsuCode(joHisFee,out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "转换HIS费用", outParam).ToString();
- return rtnResult;
- }
- JArray jaFeeDetail = JArray.Parse(JsonHelper.getDestValue(JObject.Parse(outParam), "data"));
- //按指定条数分割后上传,保存,更新
- if (hBus.uploadFeeToCenter("2301",10, jaFeeDetail, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "上传费用", outParam).ToString();
- return rtnResult;
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "住院费用上传成功", null).ToString();
- return rtnResult;
- }
- }
- case "Z3C"://住院费用上传取消
- {
- if (cBus.cancleFeeUpload("2302", out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "取消中心费用", errMsg).ToString();
- return rtnResult;
- }
- if (mIS.deleteFee( out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "删除医保平台费用", errMsg).ToString();
- return rtnResult;
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "住院费用上传取消成功", null).ToString();
- return rtnResult;
- }
- }
- default:
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "FeeUpload 交易", "传入的业务编码不对!").ToString();
- return rtnResult;
- }
- }
- return rtnResult;
- }
- catch (Exception ex)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "FeeUpload 交易", ex.Message).ToString();
- return rtnResult;
- }
- finally
- {
- Global.writeLog("FeeUpload 出参:" + JsonHelper.Compress(rtnResult));
- }
- }
- /// <summary>
- /// 结算
- /// </summary>
- /// <param name="InParam"></param>
- /// <returns></returns>
- public string Settlement(string InParam)
- {
- Global.writeLog("Settlement 入参:" + JsonHelper.Compress(InParam));
- //设置返回值,错误信息
- string errMsg, rtnResult = "", outParam;
- try
- {
- //解析入参
- if (parseInparam(InParam, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
- return rtnResult;
- }
- //BS架构调用方式问题,每次调用都需要重新初始化
- if (init(InParam, out outParam) != 0)
- {
- rtnResult = outParam;
- return rtnResult;
- }
- //获取pat
- hBus.GetSettlementHisInfo(businessType, joInParam, out Global.pat);
- switch (businessType)
- {
- case "M4"://门诊预结算
- {
- OutpatientRegistration frmReg = new OutpatientRegistration();
- if (frmReg.ShowDialog() == DialogResult.OK)
- {
- rtnResult = "调用结束";
- }
- break;
- }
- case "M4C"://门诊预结算撤销
- {
- break;
- }
- case "M5"://门诊结算
- {
- Global.pat.admType = 1;
- string patInfo ="";
- //打开读卡窗口,操作员选择读卡类型后进行读卡器读卡,再进行1101获取参保信息
- if (hBus.readCard(out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-100, "读卡失败!", outParam).ToString();
- return rtnResult;
- }
- else
- {
- patInfo = outParam;
- //展示患者信息界面
- if (hBus.showPatInfo(patInfo, out outParam) != 0)
- {
- rtnResult = outParam;
- return rtnResult;
- }
- }
- //患者信息赋值给全局变量
- patInfo = outParam;
-
- if (hBus.setGlobalPatAfaterShowPatInfo(patInfo, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "setGlobalPatAfaterShowPatInfo", errMsg).ToString();
- return rtnResult;
- }
- //校验HIS姓名与医保姓名是否一致
- if (hBus.checkName(Global.pat.name, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "校验HIS与医保姓名是否一致", errMsg).ToString();
- return rtnResult;
- }
- //显示登记面板
- if (hBus.showOutPatRegisterForm(out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "显示登记面板", outParam).ToString();
- return rtnResult;
- }
- JObject joReg = JObject.Parse(outParam);
- //医保挂号
- JObject jo2201Inpar = JObject.Parse(JsonHelper.getDestProperty(joReg, "data"));
- JObject jo2201Inpar_plain = JObject.Parse(JsonHelper.getDestProperty(joReg, "data"));
- jo2201Inpar = JObject.Parse(JsonHelper.setCenterInpar("2201", jo2201Inpar));
- jo2201Inpar_plain = JObject.Parse(JsonHelper.setCenterInpar_plain("2201", jo2201Inpar_plain));
- //此处先取到就诊信息上传的入参,只要挂号成功就保存到云HIS后台(保存后台需要用到2203入参)
- JObject jo2203Inpar = new JObject();
- JObject jo2203Inpar_plain = new JObject();
- jo2203Inpar.Add("mdtrtinfo", JObject.Parse(JsonHelper.getDestValue(joReg, "mdtrtinfo")));
- jo2203Inpar.Add("diseinfo",JArray.Parse(JsonHelper.getDestValue(joReg, "diseinfo")));
- JObject jo2201Rtn = invoker.invokeCenterService("2201", jo2201Inpar);
- if (JsonHelper.parseCenterRtnValue(jo2201Rtn, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "医保挂号", errMsg).ToString();
- return rtnResult;
- }
- else
- {
- Global.pat.mdtrtID = JsonHelper.getDestValue(jo2201Rtn, "output.data.mdtrt_id");
- //插入患者本次就诊用的参保信息
- if (hBus.insertPatCurInsuInfo(patInfo, out outParam) != 0)
- {
- if (DialogResult.Yes == MessageBox.Show(outParam, " 是否继续? ", MessageBoxButtons.YesNo))
- {
-
- }
- else
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "插入患者本次就诊用的参保信息,请联系管理员!是否继续?", outParam).ToString();
- return rtnResult;
- }
- }
- jo2203Inpar["mdtrtinfo"]["mdtrt_id"] = Global.pat.mdtrtID;
- jo2203Inpar_plain = JObject.Parse(JsonHelper.setCenterInpar_plain("2203", jo2203Inpar));
- jo2203Inpar = JObject.Parse(JsonHelper.setCenterInpar("2203", jo2203Inpar));
- //门诊登记信息,插入云医保平台
- jo2201Rtn.Add("validflag", 1);
- jo2201Rtn.Add("regstate", 1);
- jo2201Rtn.Add("type", 3);
- Global.writeLog(jo2201Inpar_plain.ToString());
- if (mIS.saveOutpatRegisterInfo(jo2201Inpar_plain, jo2201Rtn, jo2203Inpar_plain, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "中心登记成功但医保平台保存失败,请联系管理员!", errMsg).ToString();
- return rtnResult;
- }
- }
- //门诊就诊信息上传
- JObject jo2203Rtn = invoker.invokeCenterService("2203",jo2203Inpar );
- if (JsonHelper.parseCenterRtnValue(jo2203Rtn, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "门诊就诊信息上传", errMsg).ToString();
- return rtnResult;
- }
- #region【门诊就诊信息上传成功后调用3101事前服务】
- //事前分析
- if (Global.curEvt.ext.isOpenAnalysis)
- {
- if (hBus.PreAnalysis("1", "", out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "门诊就诊信息上传成功后调用3101事前服务失败:", errMsg).ToString();
- return rtnResult;
- }
- }
- //1.获取3101入参报文
- /*
- if (hIS.GetInsuPatInfo("1", Global.pat, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "获取3101医保明细审核事前分析服务入参失败:", outParam).ToString();
- return rtnResult;
- }
- else
- {
- //2.调用医保3101明细审核事前分析服务
- JObject joInput = new JObject();
- //joInput.Add("data", JObject.Parse(outParam));
- joInput = JObject.Parse(outParam);
- JObject jo3101Rtn = invoker.invokeCenterService("3101", JsonHelper.setCenterInpar("3101", joInput.ToString().Replace("\r\n", ""))); //.Replace(" ", "")
- if (JsonHelper.parseCenterRtnValue(jo3101Rtn, out errMsg) != 0)
- {
- DialogResult dr = MessageBox.Show("【3101】医保明细审核事前分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
- if (dr != DialogResult.OK)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "【3101】医保明细审核事前分析服务调用失败:", errMsg).ToString();
- return rtnResult;
- }
- }
- }
- */
- #endregion
- //费用上传
- if (hBus.uploadFee("2204", 50, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "费用上传", outParam).ToString();
- return rtnResult;
- }
- #region【门诊预结算2206前调用3102医保明细审核事中服务】
- //1.获取3102入参报文
- if (Global.curEvt.ext.isOpenAnalysis)
- {
- if (hIS.GetInsuPatInfo("2", Global.pat, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "获取3102医保明细审核事中分析服务入参失败:", outParam).ToString();
- return rtnResult;
- }
- else
- {
- //2.调用医保3102明细审核事前分析服务
- JObject joInput = new JObject();
- //joInput.Add("data", JObject.Parse(outParam));
- joInput = JObject.Parse(outParam);
- JObject jo3101Rtn = invoker.invokeCenterService("3102", JsonHelper.setCenterInpar("3102", joInput.ToString().Replace("\r\n", "")));
- if (JsonHelper.parseCenterRtnValue(jo3101Rtn, out errMsg) != 0)
- {
- DialogResult dr = MessageBox.Show("【3102】医保明细审核事中分析服务医保中心返回结果:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
- if (dr != DialogResult.OK)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事中分析服务调用失败:", errMsg).ToString();
- return rtnResult;
- }
- }
- }
- }
- #endregion
- //调用IRIS获取医保各项金额
- if (mIS.getSumFee(out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "获取医保费用各项汇总金额", outParam).ToString();
- return rtnResult;
- }
- JObject joSumFee = JObject.Parse(outParam);
- JObject joSettlement = JObject.Parse(JsonHelper.getDestValue(joReg, "settlement"));
- //修改joSettlement的就诊ID ,总金额等
- joSettlement["mdtrt_id"] = Global.pat.mdtrtID;
- joSettlement["medfee_sumamt"] = JsonHelper.getDestValue(joSumFee, "data.Sumamt");
- //预结算2206
- if (hBus.preSettlement_OutPat(joSettlement, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "结算信息展示", outParam).ToString();
- return rtnResult;
- }
- #region【门诊正式结算前调用社保卡验密】
- if (Global.pat.mdtrtcertType == "03")
- {
- if (CardRead.VerifyPIN(1, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "社保卡验密异常iVerifyPIN", outParam).ToString();
- return rtnResult;
- }
- }
- else
- if (Global.pat.mdtrtcertType == "02") //身份证结算前必须传exp_content
- {
- if (hBus.checkIDCardPwd(out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "身份证验密失败", outParam).ToString();
- return rtnResult;
- }
- JObject jo = new JObject();
- jo.Add("ecToken", outParam);
- //joSettlement.Add("exp_content", jo.ToString().Replace(@"\r\n", ""));
- joSettlement["exp_content"] = jo.ToString().Replace(@"\r\n", "");
- //outParam.Replace(@"\", "").Replace("\"{", "{").Replace("}\"", "}");
- //MessageBox.Show(joSettlement.ToString().Replace(@"\r\n", "").Replace(@"\", "").Replace("\"{", "{").Replace("}\"", "}"));
- //outParam.Replace(@"\", "").Replace("\"{", "{").Replace("}\"", "}")
- //rtnResult = JsonHelper.setExceptionJson(-1, "身份证验密调试", joSettlement.ToString()).ToString();
- //return rtnResult;
- }
- #endregion
- //正式结算
- JObject joData = new JObject();
- joData.Add("data", joSettlement);
- JObject joRtn = invoker.invokeCenterService("2207", JsonHelper.setCenterInpar("2207", joData).Replace(@"\r\n", ""));
- if (JsonHelper.parseCenterRtnValue(joRtn, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "结算失败", errMsg).ToString();
- return rtnResult;
- }
- else
- {
- //返回给云医保平台结算信息
- if (mIS.saveSettlement(joRtn, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "结算成功,但云医保平台保存失败", errMsg).ToString();
- return rtnResult;
- }
- //返回给云医保平台结算明细信息
- if (mIS.saveSettlementDetail(joRtn, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "云医保平台保存结算明细失败", errMsg).ToString();
- return rtnResult;
- }
- //返回给HIS
- JObject joSetlinfo = JObject.Parse(JsonHelper.getDestValue(joRtn, "output.setlinfo"));
- if (hIS.returnOutpatSettlementInfo(joSettlement, joSetlinfo, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "返回结算信息给HIS", outParam).ToString();
- return rtnResult;
- }
- else
- {
- JObject joHisServieRtn = JObject.Parse(outParam);
- hBus.returnToFrontEndAfterSettlement(joRtn, joHisServieRtn, out outParam);
- rtnResult = JsonHelper.setIrisReturnValue(0, "结算成功", JObject.Parse(outParam)).ToString();
- return rtnResult;
- }
- }
- }
- case "M5C"://门诊结算撤销
- {
- //查询HIS医保结算记录表获取该病人的参保地
- string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE billType = 1 and ValidFlag = 1 ";
- sqlStr = sqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
- sqlStr = sqlStr + " AND SettlementID ='" + Global.pat.settlID + "'";
- JObject joSql = new JObject();
- joSql.Add("sqlStr", sqlStr);
- JObject joSettlInfo = mIS.QuerySettlementInfo(joSql);
- //if (JsonHelper.parseIrisRtnValue(joSettlInfo, out errMsg) != 0)
- //{
- // rtnResult = JsonHelper.setExceptionJson(-1, "查询结算信息失败!", errMsg).ToString();
- // return rtnResult;
- //}
- Global.pat.insuplc_admdvs = JsonHelper.getDestValue(joSettlInfo, "result.data[0].insuplc_admdvs");
- //退中心结算
- string newSettleID = "";
- if (cBus.cancleSettlement("2208", out outParam) != 0)
- {
- int i = outParam.IndexOf("获取到的就诊信息为无效状态,不能办理结算撤销业务");
- if (i != 0)
- {
- if (DialogResult.Yes != MessageBox.Show("医保中心提示:" + outParam + ",是否强制撤销HIS结算信息?", "提示", MessageBoxButtons.YesNo))
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "中心取消结算失败,", outParam).ToString();
- return rtnResult;
- }
- newSettleID = "YC";
- }
- else
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算", outParam).ToString();
- //查看是医保平台是否已经退费,如果是,则询问是否继续退费
- string SqlStr = " SELECT * FROM BS_MedInsuSettlement WHERE ValidFlag = 0 AND BillType = -1 ";
- SqlStr = SqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
- SqlStr = SqlStr + " AND SettlementID ='" + Global.pat.settlID + "'";
- JObject joSqlStr = new JObject();
- joSqlStr.Add("sqlStr", SqlStr);
- JObject joCancleSettlInfo = mIS.QuerySettlementInfo(joSqlStr);
- JArray jaCancleSettlInfo = JArray.Parse(JsonHelper.getDestValue(joCancleSettlInfo, "result.data"));
- if (jaCancleSettlInfo.Count == 1)
- {
- //询问收款员是否继续进行HIS退费
- if (DialogResult.Yes == MessageBox.Show("中心提示:" + outParam, " 该费用在医保中心已成功退费但在HIS未成功退费,是否强制退HIS费用? ", MessageBoxButtons.YesNo))
- {
- rtnResult = JsonHelper.setExceptionJson(0, "该费用在医保中心已成功退费但在HIS未成功退费,收款员选择强制退HIS费用!", outParam).ToString();
- }
- }
- else
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算(云医保平台未退费或未查询到退费记录)", outParam).ToString();
- }
- return rtnResult;
- }
- }
- else
- {
- newSettleID = JsonHelper.getDestValue(JObject.Parse(outParam), "output.setlinfo.setl_id");
- }
-
- //string newSettleID = "10290453";
- //Global.pat.mdtrtID = "202210281547480034293700000000";
- //Global.pat.psn_no = "YX423049577";
- //Global.pat.settlID = "10290445";
- //退云医保平台结算
- if (mIS.cancleSettlement(newSettleID, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "取消平台结算信息", outParam).ToString();
- //return rtnResult;
- }
- //中心取消传送
- if (cBus.cancleFeeUpload("2205", out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "取消中心费用", errMsg).ToString();
- return rtnResult;
- }
- //云平台取消传送
- if (mIS.deleteFee(out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "删除医保平台费用", errMsg).ToString();
- return rtnResult;
- }
- //取消中心登记
- if (cBus.cancleRegister("2202", out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记失败,", outParam).ToString();
- return rtnResult;
- }
- //取消医保平台登记
- if (mIS.cancleRegister(3, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "中心取消登记成功,但云医保平台取消失败,", outParam).ToString();
- return rtnResult;
- }
- //退HIS结算
- if (hIS.cancleSettlementInfo(joParam, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "取消HIS结算信息", outParam).ToString();
- return rtnResult;
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "取消结算成功", null).ToString();
- return rtnResult;
- }
- }
- case "Z4"://住院预结算
- {
- #region【住院预结算2303前调用3102医保明细审核事中服务】
- //1.获取3102入参报文
- /*
- if (hIS.GetInsuPatInfo("9", Global.pat, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "获取3102医保明细审核事中分析服务入参失败:", outParam).ToString();
- return rtnResult;
- }
- else
- {
- //2.调用医保3102明细审核事前分析服务
- JObject joInput = new JObject();
- joInput = JObject.Parse(outParam);
- JObject jo3102Rtn = invoker.invokeCenterService("3102", JsonHelper.setCenterInpar("3102", joInput.ToString().Replace("\r\n", "")));
- if (JsonHelper.parseCenterRtnValue(jo3102Rtn, out errMsg) != 0)
- {
- DialogResult dr = MessageBox.Show("【3102】医保明细审核事中分析服务医保中心返回结果2:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
- if (dr != DialogResult.OK)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事中分析服务调用失败:", errMsg).ToString();
- return rtnResult;
- }
- }
- }
- */
- #endregion
- Global.pat.RYorCY = "2";
- Global.pat.admType = 2;
- JObject joSettle = new JObject();
- if (hBus.preSettlement("2303",out joSettle, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "结算信息展示", outParam).ToString();
- return rtnResult;
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "预结算成功", null).ToString();
- return rtnResult;
- }
- }
- case "Z4C"://住院预结算撤销
- {
- rtnResult = JsonHelper.setExceptionJson(-100, "该接口不支持预结算取消!", null).ToString();
- return rtnResult;
- }
- case "Z5"://住院结算
- {
- #region【住院预结算2303前调用3102医保明细审核事中服务】
- if (Global.curEvt.ext.isOpenAnalysis)
- {
- //1.获取3102入参报文
- if (hIS.GetInsuPatInfo("9", Global.pat, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "获取3102医保明细审核事中分析服务入参失败:", outParam).ToString();
- return rtnResult;
- }
- else
- {
- //2.调用医保3102明细审核事前分析服务
- JObject joInput = new JObject();
- joInput = JObject.Parse(outParam);
- JObject jo3102Rtn = invoker.invokeCenterService("3102", JsonHelper.setCenterInpar("3102", joInput.ToString().Replace("\r\n", "")));
- if (JsonHelper.parseCenterRtnValue(jo3102Rtn, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事中分析服务调用失败:", errMsg).ToString();
- return rtnResult;
- }
- else
- {
- JArray jaResult = JArray.Parse(JsonHelper.getDestValue(jo3102Rtn, "output.result"));
- if (jaResult.HasValues)
- {
- PreAndInProcessAnalysisForm paipaForm = new PreAndInProcessAnalysisForm(jo3102Rtn);
- paipaForm.Text = "事前事中智能审核-3102医保明细审核事中分析服务调用返回";
- if (paipaForm.ShowDialog() != DialogResult.OK)
- {
- errMsg = "事前事中审核不通过,操作员取消!";
- rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事中分析服务调用失败:", errMsg).ToString();
- return rtnResult;
- }
- else
- {
- //【3103】事前事中服务反馈服务
- //if (hBus.PreAnalysisFeedBack("3102", paipaForm.JrID, out errMsg) != 0)
- //{
- // rtnResult = JsonHelper.setExceptionJson(-1, "【3103】事前事中服务反馈服务", errMsg).ToString();
- // return rtnResult;
- //}
- }
- }
- }
- }
- }
- #endregion
- //打开读卡窗口,操作员选择读卡类型后进行读卡器读卡,再进行1101获取参保信息
- string patInfo = "";
- if (hBus.readCard(out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-100, "读卡失败!", outParam).ToString();
- return rtnResult;
- }
- else
- {
- patInfo = outParam;
- //展示患者信息界面
- if (hBus.showPatInfo(patInfo, out outParam) != 0)
- {
- rtnResult = outParam;
- return rtnResult;
- }
- else
- {
- //校验HIS姓名与医保姓名是否一致
- if (hBus.checkName(Global.pat.name, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "校验HIS与医保姓名是否一致", errMsg).ToString();
- return rtnResult;
- }
- }
- }
- //社保卡结算验密
- if (Global.pat.mdtrtcertType == "03")
- {
- if (CardRead.VerifyPIN(1, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "社保卡验密异常iVerifyPIN", outParam).ToString();
- return rtnResult;
- }
- }
- #region【住院预结算2303前调用3102医保明细审核事中服务】
- //1.获取3102入参报文
- /*
- if (hIS.GetInsuPatInfo("9", Global.pat, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "获取3102医保明细审核事中分析服务入参失败:", outParam).ToString();
- return rtnResult;
- }
- else
- {
- //2.调用医保3102明细审核事前分析服务
- JObject joInput = new JObject();
- joInput = JObject.Parse(outParam);
- JObject jo3102Rtn = invoker.invokeCenterService("3102", JsonHelper.setCenterInpar("3102", joInput.ToString().Replace("\r\n", "")));
- if (JsonHelper.parseCenterRtnValue(jo3102Rtn, out errMsg) != 0)
- {
- DialogResult dr = MessageBox.Show("【3102】医保明细审核事中分析服务医保中心返回结果1:" + errMsg + "!是否继续?", "提示", MessageBoxButtons.OKCancel, MessageBoxIcon.Question);
- if (dr != DialogResult.OK)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "【3102】医保明细审核事中分析服务调用失败:", errMsg).ToString();
- return rtnResult;
- }
- }
- }
- */
- #endregion
- Global.pat.admType = 2;
- Global.pat.RYorCY = "2";
- JObject joPreSetOutpar ;
- if (hBus.preSettlement("2303",out joPreSetOutpar, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "结算信息展示", outParam).ToString();
- return rtnResult;
- }
- else
- {
- JObject joSettlement = JObject.Parse(JsonHelper.getDestValue(joPreSetOutpar, "Settlement"));
- //住院结算交易入参exp_content 扩展字段增加ecToken,身份证就医必填,格式为:"exp_content": "{\"ecToken\":\"*********\"}"
- if (Global.pat.mdtrtcertType == "02")
- {
- if (hBus.checkIDCardPwd(out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "身份证验密失败", outParam).ToString();
- return rtnResult;
- }
- JObject jo = new JObject();
- jo.Add("ecToken", outParam);
- joSettlement["exp_content"] = jo.ToString().Replace(@"\r\n", "");
- //joSettlement.Add("exp_content", jo.ToString().Replace(@"\r\n", ""));
- }
- //正式结算
- joSettlement.Add("data", joSettlement);
- JObject jo2304Rtn = invoker.invokeCenterService("2304",JsonHelper.setCenterInpar("2304",joSettlement).Replace(@"\r\n", ""));
- if (JsonHelper.parseCenterRtnValue(jo2304Rtn, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "结算失败", errMsg).ToString();
- cBus.cancleRegister("2405", out errMsg);
- return rtnResult;
- }
- else
- {
- //返回给云医保平台结算信息
- if (mIS.saveSettlement(jo2304Rtn, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "结算成功,但云医保平台保存失败", errMsg).ToString();
- return rtnResult;
- }
- //返回给云医保平台结算明细信息
- if (mIS.saveSettlementDetail(jo2304Rtn, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "云医保平台保存结算明细失败", errMsg).ToString();
- Global.writeLog(rtnResult);
- MessageBox.Show(errMsg);
- }
- //返回给HIS
- JObject joSetlinfo = JObject.Parse(JsonHelper.getDestValue(jo2304Rtn, "output.setlinfo"));
- if (hIS.returnInpatSettlementInfo(joParam, joSetlinfo, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "返回结算信息给HIS", outParam).ToString();
- return rtnResult;
- }
- else
- {
- //返回给前端
- JObject joHisServieRtn = JObject.Parse(outParam);
- hBus.returnToFrontEndAfterSettlement(jo2304Rtn, joHisServieRtn, out outParam);
- rtnResult = JsonHelper.setIrisReturnValue(0, "结算成功", JObject.Parse(outParam)).ToString();
- return rtnResult;
- }
- }
- }
- }
- case "Z5C"://住院结算撤销
- {
- //查询结算表
- string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE billType = 1 and Hospital_Dr=" + Global.inf.hospitalDr
- + " and Adm_Dr='" + Global.pat.adm_Dr + "'"
- + " and MdtrtID='" + Global.pat.mdtrtID + "'"
- + " Order By ID DESC ";
- JObject joSql = new JObject();
- joSql.Add("sqlStr", sqlStr);
- JObject joSettlInfo = mIS.QuerySettlementInfo(joSql);
- //if (JsonHelper.parseIrisRtnValue(joSettlInfo, out errMsg) != 0)
- //{
- // rtnResult = JsonHelper.setExceptionJson(-1, "查询结算信息失败!", errMsg).ToString();
- // return rtnResult;
- //}
- //MessageBox.Show(joSettlInfo.ToString());
- Global.pat.insuplc_admdvs = JsonHelper.getDestValue(joSettlInfo, "result.data[0].insuplc_admdvs");
- Global.pat.SettID_YBJSB = JsonHelper.getDestValue(joSettlInfo, "result.data[0].SettlementID");
- if (Global.pat.settlID != Global.pat.SettID_YBJSB)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易", "通过09010059服务获取到的SettlementID<" + Global.pat.settlID + ">与DLL通过SQL语句" +
- joSql + ",获取到的SettlementID<" + Global.pat.SettID_YBJSB + ">不同,可能存在HIS单边账,请联系医保开发人员处理该笔结算记录!").ToString();
- //return rtnResult;
- }
- Global.pat.settlID = Global.pat.SettID_YBJSB;
- //取消中心结算信息
- if (cBus.cancleSettlement("2305", out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算信息失败!", outParam).ToString();
- //查看是医保平台是否已经退费,如果是,则询问是否继续退费
- string SqlStr = " SELECT * FROM BS_MedInsuSettlement WHERE ValidFlag = 0 AND BillType = -1 ";
- SqlStr = SqlStr + " AND Hospital_Dr=" + Global.inf.hospitalDr + " AND Interface_Dr=" + Global.inf.interfaceDr;
- SqlStr = SqlStr + " AND SettlementID ='" + Global.pat.settlID + "'";
- JObject joSqlStr = new JObject();
- joSqlStr.Add("sqlStr", SqlStr);
- JObject joCancleSettlInfo = mIS.QuerySettlementInfo(joSqlStr);
- JArray jaCancleSettlInfo = JArray.Parse(JsonHelper.getDestValue(joCancleSettlInfo, "result.data"));
- if (jaCancleSettlInfo.Count == 1)
- {
- //询问收款员是否继续进行HIS退费
- if (DialogResult.Yes == MessageBox.Show("中心提示:" + outParam, " 该费用在医保中心已成功退费但在HIS未成功退费,是否强制退HIS费用? ", MessageBoxButtons.YesNo))
- {
- rtnResult = JsonHelper.setExceptionJson(0, "该费用在医保中心已成功退费但在HIS未成功退费,收款员选择强制退HIS费用!", outParam).ToString();
- }
- }
- else
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "取消中心结算(云医保平台未退费或未查询到退费记录)", outParam).ToString();
- }
- return rtnResult;
- }
- else
- {
- //退结算会返一个新的ID
- string newSettleID = JsonHelper.getDestValue(JObject.Parse(outParam), "output.setlinfo.setl_id");
- //取消平台结算信息
- if (mIS.cancleSettlement(newSettleID, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "中心结算取消成功,医保平台结算信息取消失败!", outParam).ToString();
- return rtnResult;
- }
- //中心取消传送
- if (cBus.cancleFeeUpload("2302", out errMsg) != 0)
- {
- //rtnResult = JsonHelper.setExceptionJson(-1, "取消中心费用", errMsg).ToString();
- //return rtnResult;
- }
- //云平台取消传送
- if (mIS.deleteFee(out errMsg) != 0)
- {
- //rtnResult = JsonHelper.setExceptionJson(-1, "删除医保平台费用", errMsg).ToString();
- //return rtnResult;
- }
- //取消HIS医保结算信息
- if (hIS.cancleSettlementInfo(joParam, out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "中心跟医保平台结算取消成功, 取消HIS结算信息失败!", outParam).ToString();
- return rtnResult;
- }
- //取消出院登记
- if (cBus.cancleRegister("2405", out outParam) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(0, "中心,医保平台及HIS结算信息取消成功,取消出院登记失败!请手工取消出院登记!", outParam).ToString();
- return rtnResult;
- }
- rtnResult = JsonHelper.setIrisReturnValue(0, "取消结算成功", null).ToString();
- return rtnResult;
- }
- }
- default:
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易", "传入的业务编码不对!").ToString();
- return rtnResult;
- }
- }
- return rtnResult;
- }
- catch (Exception ex)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "Settlement 交易", ex.Message).ToString();
- return rtnResult;
- }
- finally
- {
- Global.writeLog("Settlement 出参:" + JsonHelper.Compress(rtnResult));
- }
- }
- //[STAThread]
- //public void print(JObject joInParam)
- //{
- // //显示打印界面
- // SettlementChecklist frmSettlList;
- // string insuAdmObj = JsonHelper.getDestValue(joInParam, "insuAdmObj");
- // if (insuAdmObj == "")
- // {
- // frmSettlList = new SettlementChecklist();
- // }
- // else
- // {
- // JObject joInsuAdmObj = JObject.Parse(insuAdmObj);
- // frmSettlList = new SettlementChecklist(joInsuAdmObj);
- // }
- // if (frmSettlList.ShowDialog() == DialogResult.OK)
- // {
- // };
- //}
- //[STAThread]
- /// <summary>
- /// 辅助交易
- /// </summary>
- /// <param name="InParam"></param>
- /// <returns></returns>
- public string AgentFun(string InParam)
- {
- Global.writeLog("AgentFun 入参:" + JsonHelper.Compress(InParam));
- //设置返回值,错误信息
- int errCode;
- string errMsg, rtnResult = "", outParam;
- try
- {
- //解析入参
- if (parseInparam(InParam, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
- return rtnResult;
- }
- //BS架构调用方式问题,每次调用都需要重新初始化
- if (init(InParam, out outParam) != 0)
- {
- rtnResult = outParam;
- return rtnResult;
- }
- //获取通用目录
- string sTYML = mIS.GetCommonInterface_Dr(Global.inf.interfaceDr.ToString(), "");
- if (sTYML == "")
- Global.inf.interfaceDr_TY = Global.inf.interfaceDr;
- else
- Global.inf.interfaceDr_TY = int.Parse(sTYML);
- //获取pat
- //hBus.GetFeeHisInfo(businessType, joInParam, out Global.pat);
- switch (businessType)
- {
- case "BasicData"://基础数据维护
- {
- BasicData bd = new BasicData();
- bd.ShowDialog();
- break;
- }
- case "Exception"://异常处理
- {
- //显示异常处理界面
- HandleException frmEX = new HandleException();
- frmEX.ShowDialog();
- break;
- }
- case "CheckAndClearing"://对账清算
- {
- Clearing frmEX = new Clearing();
- frmEX.ShowDialog();
- break;
- }
- case "Print"://打印
- {
- //显示打印界面
- SettlementBillPrint frmSettlList;
- string insuAdmObj = JsonHelper.getDestValue(joInParam, "insuAdmObj");
- if (insuAdmObj == "")
- {
- frmSettlList = new SettlementBillPrint();
- if (frmSettlList.ShowDialog() != DialogResult.OK)
- {
- rtnResult = JsonHelper.setExceptionJson(-100, "", "已退出打印界面").ToString();
- return rtnResult;
- }
- }
- else
- {
- JObject joInsuAdmObj = JObject.Parse(insuAdmObj);
- frmSettlList = new SettlementBillPrint(joInsuAdmObj);
- string groupID = JsonHelper.getDestValue((JObject)Global.curEvt.jaSession[0], "groupID");
- string userName = JsonHelper.getDestValue((JObject)Global.curEvt.jaSession[0], "userName");
- DataTable dt = (DataTable)frmSettlList.dgvSettlRecord.DataSource;
- int i = frmSettlList.dgvSettlRecord.CurrentRow.Index;
- string AdmID = dt.Rows[i]["AdmID"].ToString();
- string PsnNo = dt.Rows[i]["PersonnelNO"].ToString();
- string MdtrtID = dt.Rows[i]["MdtrtID"].ToString();
- string SettlementID = dt.Rows[i]["SettlementID"].ToString();
- Global.pat.adm_Dr = int.Parse(AdmID);
- if (((groupID == "3") && (dt.Rows.Count > 0)) ||
- (userName == "朱振") || (userName == "朱鹏飞") || (userName == "陈蒙") ||
- (userName == "张可宁") || (userName == "史绍兴") || (userName == "陈柏全") ||
- (userName == "李翔") || (userName == "王晓兵") || (userName == "史绍兴"))
- {
- //frmSettlList.ShowDialog();
- frmSettlList.btnDesign_Click(null, null);
- }
- else
- {
- JObject joRtnFee = frmSettlList.UpdateMedInsuUploadData(AdmID, PsnNo, MdtrtID, SettlementID);
- frmSettlList.btnPrint_Click(null, null);
- }
- }
- return JsonHelper.setIrisReturnValue(0, "", null).ToString();
- break;
- }
- case "Log"://日志
- {
- MessageBox.Show(businessType);
- break;
- }
- case "RecordUpload"://上传记录
- {
- MessageBox.Show(businessType);
- break;
- }
- case "HospitalRegister"://备案
- {
- ToRecordChoose Referral = new ToRecordChoose();
- Referral.ShowDialog();
- break;
- }
- case "MedInsuQuery"://医保查询
- {
- MedInsuQuery MedQuery = new MedInsuQuery();
- MedQuery.ShowDialog();
- break;
- }
- case "PrescribeCirculation"://医保处方流转
- {
- //PrescriptionCirculation PresCir = new PrescriptionCirculation();
- PrescriptionCirculation PresCir = new PrescriptionCirculation("");
- //PresCir.WindowState = FormWindowState.Minimized;
- PresCir.ShowDialog();
- break;
- }
- case "PreAndInProcessAnalysis"://事前分析 诊间只有住院的事前分析
- {
- Global.pat.adm_Dr = int.Parse(JsonHelper.getDestValue(joInParam, "params[0].admID"));
- //Global.pat.psn_no = JsonHelper.getDestValue(joInParam, "params[0].insuData.patient_dtos[0].patn_id");
- Global.pat.psn_no = JsonHelper.getDestValue(joInParam, "insuAdmObj.psn_no");
- Global.pat.insuplc_admdvs = JsonHelper.getDestValue(joInParam, "params[0].insuData.patient_dtos[0].poolarea");
- Global.pat.insuType = JsonHelper.getDestValue(joInParam, "params[0].insuData.patient_dtos[0].fsi_encounter_dtos[0].insutype");
- Global.pat.medType = JsonHelper.getDestValue(joInParam, "params[0].insuData.patient_dtos[0].fsi_encounter_dtos[0].med_type");
- JObject joResult = new JObject();
- joResult.Add("result", JObject.Parse(JsonHelper.getDestValue(joParam, "insuData")));
- string trig_scen = "4"; //住院
- if (Global.pat.medType.Substring(0, 1) == "1")
- trig_scen = "2"; //门诊
- //事前分析
- if (Global.curEvt.ext.isOpenAnalysis)
- {
- //if (hBus.PreAnalysis("2", joResult.ToString(), out errMsg) != 0) 20240614 苏国平、朱鹏飞要求更改
- if (hBus.PreAnalysis(trig_scen, joResult.ToString(), out errMsg) != 0)
- {
- //MessageBox.Show(errMsg);
- rtnResult = JsonHelper.setIrisReturnValue(-1, "医保事前事中服务:" + errMsg, null).ToString();
- break;
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "医保事前事中服务" + errMsg, null).ToString();
- }
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "事前事中服务接口未开启", null).ToString();
- }
- break;
- }
- default:
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "AgentFun 交易", "传入的业务编码不对!").ToString();
- return rtnResult;
- }
- }
- return rtnResult;
- }
- catch (Exception ex)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "AgentFun 交易", ex.Message).ToString();
- return rtnResult;
- }
- finally
- {
- Global.writeLog("AgentFun 出参:" + JsonHelper.Compress(rtnResult));
- }
- }
- public string Download(string InParam)
- {
- Global.writeLog("Download 入参:" + JsonHelper.Compress(InParam));
- //设置返回值,错误信息
- int errCode;
- string errMsg, rtnResult = "", outParam;
- try
- {
- //解析入参
- if (parseInparam(InParam, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
- return rtnResult;
- }
- //BS架构调用方式问题,每次调用都需要重新初始化
- if (init(InParam, out outParam) != 0)
- {
- rtnResult = outParam;
- return rtnResult;
- }
- dynamic joData = new JObject();
- joData.data = joParam["data"];
- //string code = (string)joInParam["code"];
- string funNO = (string)joParam["funNO"];
- switch (businessType)
- {
- case "DirectoryDownload":
- {
- string downloadParam = JsonHelper.setCenterInpar(funNO, joData.ToString());
- rtnResult = hBus.DownloadDirectory(funNO, downloadParam).ToString();
- break;
- }
- case "DictionayDownload":
- {
- string downloadParam = JsonHelper.setCenterInpar(funNO, joData.ToString());
- rtnResult = hBus.downDictionary(downloadParam);
- break;
- }
- }
- return rtnResult;
- }
- catch (Exception ex)
- {
- rtnResult = JsonHelper.setExceptionJson(-100, "Download", ex.Message).ToString();
- return rtnResult;
- }
- finally
- {
- Global.writeLog("Download 出参:" + rtnResult);
- }
- }
-
- public string PlatformDirectConnect(string InParam)
- {
- //设置返回值,错误信息
- int errCode;
- string errMsg, rtnResult = "", outParam;
- try
- {
- Global.writeLog("PlatformDirectConnect 入参:" + JsonHelper.Compress(InParam));
- //解析入参
- if (parseInparam(InParam, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "", errMsg).ToString();
- return rtnResult;
- }
- Global.businessType = businessType;
- string funNO = JsonHelper.getDestValue(joInParam, "funNO");
- Global.pat.insuplc_admdvs = JsonHelper.getDestValue(joInParam, "params[0].setlinfo.hsorg");
- //BS架构调用方式问题,每次调用都需要重新初始化
- if (init(InParam, out outParam) != 0)
- {
- rtnResult = outParam;
- return rtnResult;
- }
- JObject joRtn = invoker.invokeCenterService(funNO, JsonHelper.setCenterInpar(funNO, joParam));
- if (JsonHelper.parseCenterRtnValue(joRtn, out errMsg) != 0)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "平台直连错误", errMsg).ToString();
- return rtnResult;
- }
- else
- {
- rtnResult = JsonHelper.setIrisReturnValue(0, "", joRtn).ToString();
- return rtnResult;
- }
- }
- catch (Exception ex)
- {
- rtnResult = JsonHelper.setExceptionJson(-1, "PlatformDirectConnect 交易", ex.Message).ToString();
- return rtnResult;
- }
- finally
- {
- Global.writeLog("PlatformDirectConnect 出参:" + JsonHelper.Compress(rtnResult));
- }
- }
- }
- }
|