/****************************************************************************** * 文件名称: CardReader.cs * 文件说明: 读卡的封装,包括社保卡,身份证,电子凭证等等 * 当前版本: V1.0 * 创建日期: 2022-06-25 * * * 2020-06-20: 增加 IrisServices 类(基类) * ***** 2020-06-25: 增加 CardReader 方法,获取URL地址,USER信息,地方版SSCard.dll使用 * ***** 2020-06-25: 增加 CardReader 方法重载,国家版电子凭证使用 * * * * 2020-06-20: 增加 HisIrisServices 类(子类) * ***** 2020-06-25: 增加 CardReader 方法,获取URL地址,USER信息,地方版SSCard.dll使用 * ***** 2020-06-25: 增加 CardReader 方法重载,国家版电子凭证使用 * * * * 2020-06-20: 增加 MIIrisServices 类(子类) * ***** 2020-06-25: 增加 CardReader 方法,获取URL地址,USER信息,地方版SSCard.dll使用 * ***** 2020-06-25: 增加 CardReader 方法重载,国家版电子凭证使用 ******************************************************************************/ using Newtonsoft.Json.Linq; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using PTMedicalInsurance.Variables; using PTMedicalInsurance.Helper; using System.Windows.Forms; namespace PTMedicalInsurance.Business { class IrisServices { } class HisIrisServices { private InvokeHelper invoker = new InvokeHelper(); /// /// 获取诊断信息 /// /// /// /// public int getPatDiagnoses(Patients pat, out string outParam) { outParam = ""; string errMsg; try { JObject joTmp = new JObject(); joTmp.Add("admID", pat.adm_Dr); joTmp.Add("psn_no", pat.psn_no); //JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110001", joTmp).ToString(), "获取诊断信息"); JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110014", joTmp).ToString(), "获取诊断信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = "获取诊断信息失败,请联系管理员!" + errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "getPatDiagnoses 异常:" + ex.Message; return -1; } } /// /// 返回登记信息给HIS /// /// /// /// /// public int returnRegisterInfo(JObject joRegIn, JObject joRegOut, out string outParam) { string errMsg; try { JObject joIn = new JObject(); joIn.Add("admID", Global.pat.adm_Dr); joIn.Add("mdtrt_id", JsonHelper.getDestValue(joRegOut, "output.prm_akc190")); joIn.Add("interfaceDr", Global.inf.interfaceDr); joIn.Add("billID", Global.pat.billID); joIn.Add("psn_type", Global.pat.psn_type); joIn.Add("psn_no", Global.pat.psn_no); joIn.Add("fixmedins_code", Global.inf.hospitalNO); joIn.Add("insutype", Global.pat.insuType); joIn.Add("med_type", Global.pat.medType); joIn.Add("insuplc_admdvs", Global.pat.insuplc_admdvs); joIn.Add("input",joRegIn); string serviceCode = "05110002", serviceName = "将登记信息返回给HIS"; string inpar = JsonHelper.setIrisInpar(serviceCode, joIn).ToString(); JObject joRtn = invoker.invokeHISService(inpar,serviceName); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = "中心登记成功但云HIS平台保存失败,请联系管理员!" + errMsg; return -1; } else { outParam = "返回给HIS成功"; return 0; } } catch (Exception ex ) { outParam = "HIS保存登记信息出现异常:!" + ex.Message; return -1; } } /// /// 获取His费用 /// /// /// /// public int getHisFee(Patients pat, out string outParam) { outParam = ""; string errMsg; try { dynamic joIrisParam = new JObject(); JArray jaIrisParams = new JArray(); JObject joIrisTmp = new JObject(); joIrisParam.code = "05110003"; joIrisParam.session = Global.curEvt.jaSession; joIrisTmp.Add("admID", pat.adm_Dr); joIrisTmp.Add("billID", pat.billID); joIrisTmp.Add("recordID", pat.recordID); jaIrisParams.Add(joIrisTmp); joIrisParam.Add("params", JArray.FromObject(jaIrisParams)); JObject joRtn = invoker.invokeHISService(joIrisParam.ToString(), "获取HIS费用"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "deleteFee 异常:" + ex.Message; return -1; } } /// /// 取消登记信息 /// /// /// public int cancleRegister( out string outParam) { outParam = ""; string errMsg; try { dynamic joTmp = new JObject(); joTmp.Add("admID", Global.pat.adm_Dr); joTmp.Add("interfaceDr", Global.inf.interfaceDr); joTmp.Add("billID", Global.pat.billID); string serviceCode = "05110004"; string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString(); JObject joRtn = invoker.invokeHISService(inpar, "取消HIS登记信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = joRtn.ToString(); return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "取消登记异常" + ":" + ex.Message; return -1; } } /// /// HIS预结算 /// /// /// /// /// public int preSettlementInfo(JObject joParam, JObject joSetlinfo, out string outParam) { string errMsg; try { //费用转换 JObject joInsuPayInfo = new JObject(); joInsuPayInfo.Add("setl_id", JsonHelper.getDestValue(joSetlinfo, "output.prm_yka103")); joInsuPayInfo.Add("medfee_sumamt", JsonHelper.getDestValue(joSetlinfo, "output.prm_yka055")); joInsuPayInfo.Add("fulamt_ownpay_amt", JsonHelper.getDestValue(joSetlinfo, "output.prm_yka056")); joInsuPayInfo.Add("overlmt_selfpay", ""); joInsuPayInfo.Add("preselfpay_amt", JsonHelper.getDestValue(joSetlinfo, "output.prm_yka057")); joInsuPayInfo.Add("inscp_scp_amt", JsonHelper.getDestValue(joSetlinfo, "output.prm_yka111")); joInsuPayInfo.Add("act_pay_dedc", JsonHelper.getDestValue(joSetlinfo, "output.prm_yka058")); joInsuPayInfo.Add("hifp_pay", JsonHelper.getDestValue(joSetlinfo, "output.prm_yka248")); joInsuPayInfo.Add("pool_prop_selfpay", ""); joInsuPayInfo.Add("cvlserv_pay", JsonHelper.getDestValue(joSetlinfo, "output.prm_yke030")); joInsuPayInfo.Add("hifes_pay", ""); joInsuPayInfo.Add("hifmi_pay", JsonHelper.getDestValue(joSetlinfo, "output.prm_yka062")); joInsuPayInfo.Add("hifob_pay", JsonHelper.getDestValue(joSetlinfo, "output.prm_yka082")); joInsuPayInfo.Add("maf_pay", JsonHelper.getDestValue(joSetlinfo, "output.prm_ake181")); joInsuPayInfo.Add("oth_pay", JsonHelper.getDestValue(joSetlinfo, "output.prm_ake173")); joInsuPayInfo.Add("psn_part_amt", ""); joInsuPayInfo.Add("balc", ""); joInsuPayInfo.Add("acct_mulaid_pay", ""); joInsuPayInfo.Add("medins_setl_id", Global.pat.billID); joInsuPayInfo.Add("clr_optins", JsonHelper.getDestValue(joSetlinfo, "output.prm_ykb037")); joInsuPayInfo.Add("clr_way", JsonHelper.getDestValue(joSetlinfo, "output.prm_yka054")); joInsuPayInfo.Add("clr_type", JsonHelper.getDestValue(joSetlinfo, "output.prm_yka316")); joInsuPayInfo.Add("psn_name", Global.pat.name); dynamic joTmp = new JObject(); joTmp = joParam.DeepClone(); joTmp.insuPayInfo = joInsuPayInfo; joTmp.updateUserID = Global.user.ID; joTmp.middleSettleFlag = ""; JObject joSumFee = new JObject(); if (sumInsuRtnSettlInfo("43",joSetlinfo, out joSumFee, out errMsg) != 0) { outParam = "汇总结算结果失败,请联系管理员!" + errMsg; return -1; } joTmp.sumFeeObj = joSumFee; JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110020", joTmp).ToString(), "返回2303结算结果给HIS"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = "返回2303结算结果给HIS失败,请联系管理员!" + errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "返回2303结算结果给HIS出现异常:!" + ex.Message; return -1; } } /// /// 返回住院结算信息给HIS /// /// /// /// /// public int returnInpatSettlementInfo(JObject joSettlRtn, JObject joSetlinfo, out string outParam) { string errMsg; try { dynamic joTmp = new JObject(); joTmp.admID = Global.pat.adm_Dr; joTmp.recordID = Global.pat.recordID; joTmp.billID = Global.pat.billID; joTmp.insuPayInfo = joSetlinfo; joTmp.updateUserID = Global.user.ID; joTmp.middleSettleFlag = ""; JObject joSumFee = new JObject(); if (sumInsuRtnSettlInfo("41", joSettlRtn, out joSumFee, out errMsg) != 0) { outParam = "汇总结算结果失败,请联系管理员!" + errMsg; return -1; } joTmp.sumFeeObj = joSumFee; //JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110007", joTmp).ToString(), "返回2304结算结果给HIS"); JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110017", joTmp).ToString(), "返回2304结算结果给HIS"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = "返回2304结算结果给HIS失败,请联系管理员!" + errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "返回2304结算结果给HIS出现异常:!" + ex.Message; return -1; } } /// /// 获取结算费用的封装 /// /// /// /// private decimal getFee(JObject jo,string path) { try { string temp = JsonHelper.getDestValue(jo, path); if (temp == "") { return 0; } else { return decimal.Round(decimal.Parse(temp),2); } } catch (Exception ex) { Global.writeLog("getFee异常:" + ex.Message); return 0; } } /// /// 汇总医保返回的结算金额(按照HIS的原则汇总,后期HIS按照这个来进行勾稽关系判断) /// /// /// public int sumInsuRtnSettlInfo(string funNO,JObject jo,out JObject joSumFee ,out string errMsg ) { // 医疗费总额是患者在医药机构花费的所有诊疗、药品、耗材、服务设施等项目费用的总和 = 基金支付总额 + 个人负担总金额 + 其他(如医院负担金额); //3、基金支付总额 = 基本医保统筹基金支出(含职工基本医疗保险、居民基本医疗保险)+补充医疗保险基金支出 (含覆盖全体参保人的居民大病保险和大额医疗费用补助、覆盖部分参保人的企业职工大额医疗费用补助和公务员医疗补助等)+医疗救助基金支出 + 其他支出(如伤残人员医疗保障基金支出); //5、个人账户支出中包含账户共济支付金额 joSumFee = new JObject(); errMsg = ""; decimal ybAmt, psnAcctAmt, hospAmt, psnCashAmt, medFee;//医保基金支付(含其他基金支付,比如民政补助,商业保险等),账户支付,医院承担,现金支付,实际总费用(HIS) decimal centerSumumt;//中心的总费用 贵州的计算公式貌似每个地区不一致 //以下猜测 //如果是单病种,如果患者的实际总费用小于单病种定额,同时患者又有超限额费用(比如晶体单价超了),那么现金支付=超限价金额,医保基金支付= 单病种定额 ,此时公式计算为中心返回的总费用= 单病种定额 + 现金支付 // 不能用医院实际金额去计算,同时,医院承担金额还是按照单病种定额-医院实际金额返回 //如果是单病种,如果患者的实际总费用大于单病种定额,同时患者又有超限额费用(比如晶体单价超了),那么现金支付=超限价金额,医保基金支付= 单病种定额 ,此时公式计算为中心返回的总费用= 患者实际总费用 + 现金支付 // 此时用医院实际金额去计算,同时,医院承担金额还是按照单病种定额-医院实际金额返回(负的) try { ybAmt = 0;psnAcctAmt = 0;hospAmt = 0;psnCashAmt = 0;medFee = 0;centerSumumt = 0; if (funNO == "48") { ybAmt = getFee(jo, "output.prm_yka248") //本次基本医疗报销金额 + getFee(jo, "output.prm_yka062") //本次大病医疗报销金额 + getFee(jo, "output.prm_yke030") //本次公务员报销金额 + getFee(jo, "output.prm_ake032") //城 乡 居 民 卫 计 局 补 偿 金 额 ( 卫 计 补 偿 ) + getFee(jo, "output.prm_ake181") //医疗救助补偿金额 + getFee(jo, "output.prm_ake183") //优抚补偿金额 + getFee(jo, "output.prm_ake173") //其他基金 + getFee(jo, "output.prm_yka082") //大额补充保险报销金额 + getFee(jo, "output.prm_yka083"); //大病额外报销 psnAcctAmt = getFee(jo, "output.prm_yka065"); psnCashAmt = getFee(jo, "output.psn_cash_pay"); hospAmt = getFee(jo, "output.hosp_part_amt"); medFee = getFee(jo, "output.prm_yka055"); centerSumumt = getFee(jo, "output.prm_yka525"); } if (funNO == "41") { ybAmt = getFee(jo, "output.prm_yka248") //本次基本医疗报销金额 + getFee(jo, "output.prm_yka062") //本次大病医疗报销金额 + getFee(jo, "output.prm_yke030") //本次公务员报销金额 + getFee(jo, "output.prm_ake032") //城 乡 居 民 卫 计 局 补 偿 金 额 ( 卫 计 补 偿 ) + getFee(jo, "output.prm_ake181") //医疗救助补偿金额 + getFee(jo, "output.prm_ake183") //优抚补偿金额 + getFee(jo, "output.prm_ake173") //其他基金 + getFee(jo, "output.prm_yka082") //大额补充保险报销金额 + getFee(jo, "output.prm_yka083"); //大病额外报销 psnAcctAmt = getFee(jo, "output.prm_yka065"); psnCashAmt = getFee(jo, "output.psn_cash_pay"); hospAmt = getFee(jo, "output.hosp_part_amt"); medFee = getFee(jo, "output.prm_yka055"); centerSumumt = getFee(jo, "output.prm_yka525"); } if (funNO == "43") { ybAmt = getFee(jo, "output.prm_yka248") //本次基本医疗报销金额 + getFee(jo, "output.prm_yka062") //本次大病医疗报销金额 + getFee(jo, "output.prm_yke030") //本次公务员报销金额 + getFee(jo, "output.prm_ake032") //城 乡 居 民 卫 计 局 补 偿 金 额 ( 卫 计 补 偿 ) + getFee(jo, "output.prm_ake181") //医疗救助补偿金额 + getFee(jo, "output.prm_ake183") //优抚补偿金额 + getFee(jo, "output.prm_ake173") //其他基金 + getFee(jo, "output.prm_yka082") //大额补充保险报销金额 + getFee(jo, "output.prm_yka083"); //大病额外报销 psnAcctAmt = getFee(jo, "output.prm_yka065"); psnCashAmt = getFee(jo, "output.psn_cash_pay"); hospAmt = getFee(jo, "output.hosp_part_amt"); medFee = getFee(jo, "output.prm_yka055"); centerSumumt = getFee(jo, "output.prm_yka525"); } if (medFee != (ybAmt + psnAcctAmt + psnCashAmt + hospAmt)) { if (centerSumumt + (medFee - ybAmt) == (ybAmt + psnAcctAmt + psnCashAmt + hospAmt)) { errMsg = "该笔数据应该为单病种,中心返回金额= 医保基金+ 个人账户+ 现金支付(可能存在超限金额); 医院承担(个别地区医院承担不包含超限金额)= 医保支付 - HIS实际总费用;"; errMsg = errMsg + "ybAmt(" + ybAmt.ToString() + ")+" + "psnAcctAmt(" + psnAcctAmt.ToString() + ")+" + "psnCashAmt(" + psnCashAmt.ToString() + ")+" + "hospAmt(" + hospAmt.ToString() + ")" + "==centerSumumt(" + centerSumumt.ToString() + ")" + "medFee(" + medFee.ToString() + ")-" + "ybAmt(" + ybAmt.ToString() + ")"; hospAmt = hospAmt - psnCashAmt; } else { Global.writeLog("ybAmt(" + ybAmt.ToString() + ")+" + "psnAcctAmt(" + psnAcctAmt.ToString() + ")+" + "psnCashAmt(" + psnCashAmt.ToString() + ")+" + "hospAmt(" + hospAmt.ToString() + ")" + "!=centerSumumt(" + centerSumumt.ToString() + ")"); errMsg = "ybAmt(" + ybAmt.ToString() + ")+" + "psnAcctAmt(" + psnAcctAmt.ToString() + ")+" + "psnCashAmt(" + psnCashAmt.ToString() + ")+" + "hospAmt(" + hospAmt.ToString() + ")" + "!=medFee(" + medFee.ToString() + ")"; errMsg = errMsg + System.Environment.NewLine; errMsg = errMsg + "ybAmt 为如下节点之和:" + "prm_yka248(" + getFee(jo, "output.prm_yka248").ToString() + ")+"; errMsg = errMsg + "prm_yka062(" + getFee(jo, "output.prm_yka062").ToString() + ")+"; errMsg = errMsg + "prm_yke030(" + getFee(jo, "output.prm_yke030").ToString() + ")+"; errMsg = errMsg + "prm_ake032(" + getFee(jo, "output.prm_ake032").ToString() + ")+"; errMsg = errMsg + "prm_ake181(" + getFee(jo, "output.prm_ake181").ToString() + ")+"; errMsg = errMsg + "prm_ake183(" + getFee(jo, "output.prm_ake183").ToString() + ")+"; errMsg = errMsg + "prm_ake173(" + getFee(jo, "output.prm_ake173").ToString() + ")+"; errMsg = errMsg + "prm_yka082(" + getFee(jo, "output.prm_yka082").ToString() + ")+"; errMsg = errMsg + "prm_yka083(" + getFee(jo, "output.prm_yka083").ToString() + ")"; errMsg = errMsg + System.Environment.NewLine; errMsg = errMsg + "psnAcctAmt 为如下节点之和:" + "prm_yka065(" + getFee(jo, "output.prm_yka065").ToString() + ")"; errMsg = errMsg + System.Environment.NewLine; errMsg = errMsg + "hospAmt 为如下节点之和:" + "hosp_part_amt(" + getFee(jo, "output.hosp_part_amt").ToString() + ")"; errMsg = errMsg + System.Environment.NewLine; errMsg = errMsg + "medFee 为如下节点之和:" + "prm_yka055(" + getFee(jo, "output.prm_yka055").ToString() + ")"; //errMsg = "ybAmt + psnAcctAmt + psnCashAmt + hospAmt != medFee"; return -1; } } else { errMsg = "ybAmt(" + ybAmt.ToString() + ")+" + "psnAcctAmt(" + psnAcctAmt.ToString() + ")+" + "psnCashAmt(" + psnCashAmt.ToString() + ")+" + "hospAmt(" + hospAmt.ToString() + ")" + "!=medFee(" + medFee.ToString() + ")"; errMsg = errMsg + System.Environment.NewLine; errMsg = errMsg + "ybAmt 为如下节点之和:" + "prm_yka248(" + getFee(jo, "output.prm_yka248").ToString() + ")+"; errMsg = errMsg + "prm_yka062(" + getFee(jo, "output.prm_yka062").ToString() + ")+"; errMsg = errMsg + "prm_yke030(" + getFee(jo, "output.prm_yke030").ToString() + ")+"; errMsg = errMsg + "prm_ake032(" + getFee(jo, "output.prm_ake032").ToString() + ")+"; errMsg = errMsg + "prm_ake181(" + getFee(jo, "output.prm_ake181").ToString() + ")+"; errMsg = errMsg + "prm_ake183(" + getFee(jo, "output.prm_ake183").ToString() + ")+"; errMsg = errMsg + "prm_ake173(" + getFee(jo, "output.prm_ake173").ToString() + ")+"; errMsg = errMsg + "prm_yka082(" + getFee(jo, "output.prm_yka082").ToString() + ")+"; errMsg = errMsg + "prm_yka083(" + getFee(jo, "output.prm_yka083").ToString() + ")"; errMsg = errMsg + System.Environment.NewLine; errMsg = errMsg + "psnAcctAmt 为如下节点之和:" + "prm_yka065(" + getFee(jo, "output.prm_yka065").ToString() + ")"; errMsg = errMsg + System.Environment.NewLine; errMsg = errMsg + "hospAmt 为如下节点之和:" + "hosp_part_amt(" + getFee(jo, "output.hosp_part_amt").ToString() + ")"; errMsg = errMsg + System.Environment.NewLine; errMsg = errMsg + "medFee 为如下节点之和:" + "prm_yka055(" + getFee(jo, "output.prm_yka055").ToString() + ")"; } Global.writeLog(errMsg); joSumFee.Add("ybAmt", ybAmt); joSumFee.Add("psnAcctAmt", psnAcctAmt); joSumFee.Add("hospAmt", hospAmt); joSumFee.Add("psnCashAmt", psnCashAmt); return 0; } catch (Exception ex) { errMsg = ex.Message; return 1; } } /// /// 返回门诊结算信息给HIS /// /// /// /// /// public int returnOutpatSettlementInfo(JObject joSetlInpar, JObject joSetlinfo, out string outParam) { string errMsg; try { JObject joSumFee = new JObject(); if (sumInsuRtnSettlInfo("48",joSetlinfo, out joSumFee, out errMsg) != 0) { outParam = "返回48结算结果给HIS失败,请联系管理员!" + errMsg; return -1; } dynamic joTmp = new JObject(); joTmp.settleInfo = joSetlInpar; joTmp.updateUserID = Global.user.ID; joTmp.regInfo = joSetlInpar; joTmp.middleSettleFlag = ""; joTmp.interfaceDr = Global.inf.interfaceDr; dynamic joHisInfo = new JObject(); joHisInfo.admID = Global.pat.adm_Dr; joHisInfo.billID = Global.pat.billID; joHisInfo.recordID = Global.pat.recordID; joTmp.hisInfo = joHisInfo; joTmp.psn_type = Global.pat.psn_type; joTmp.sumFeeObj = joSumFee; //05110018 {"feeObj":{"ybAmt":"医保支付","psnAcctAmt":"个人账户","psnCashAmt":"个人现金","hospAmt":"医院垫付"}} //JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110009", joTmp).ToString(), "返回2207结算结果给HIS"); JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110018", joTmp).ToString(), "返回2207结算结果给HIS"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = "返回2207结算结果给HIS失败,请联系管理员!" + errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "返回2207结算结果给HIS出现异常:!" + ex.Message; return -1; } } /// /// 取消结算信息 /// /// /// /// public int cancleSettlementInfo(JObject joParam, out string outParam) { string errMsg; try { dynamic joTmp = new JObject(); joTmp = joParam.DeepClone(); joTmp.updateUserID = Global.user.ID; joTmp.middleSettleFlag = ""; JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110008", joTmp).ToString(), "取消HIS医保结算信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = "取消HIS医保结算信息失败,请联系管理员!" + errMsg; return -1; } else { outParam = "取消HIS医保结算信息成功"; return 0; } } catch (Exception ex) { outParam = "取消HIS医保结算信息出现异常:!" + ex.Message; return -1; } } public int getHISDir(JArray jaPagination, JArray jaParams, out JObject joRtn, out string outParam) { string errMsg; joRtn = new JObject(); try { dynamic joTmp = new JObject(); joTmp.pagination = jaPagination; joTmp.session = Global.curEvt.jaSession; joTmp.Add("params",jaParams); joTmp.code = "05111002"; joRtn = invoker.invokeHISService(joTmp.ToString(), "查询HIS目录分页"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = "查询HIS目录分页失败,请联系管理员!" + errMsg; return -1; } else { if (joRtn["result"]["Data"] == null) { outParam = "Data节点不存在"; return -1; } outParam = "查询HIS目录分页成功"; return 0; } } catch (Exception ex) { outParam = "查询HIS目录分页异常:!" + ex.Message; return -1; } } /// /// 从HIS获取医保事前事中服务交易入参报文 /// /// /// /// public int GetInsuPatInfo(string TrigScen, Patients pat, out string outParam) { outParam = ""; string errMsg; try { dynamic joIrisParam = new JObject(); JArray jaIrisParams = new JArray(); JObject joIrisTmp = new JObject(); joIrisParam.code = "05110015"; joIrisParam.session = Global.curEvt.jaSession; joIrisTmp.Add("admID", pat.adm_Dr); joIrisTmp.Add("billID", pat.billID); joIrisTmp.Add("recordID", pat.recordID); joIrisTmp.Add("userID", Global.user.ID); joIrisTmp.Add("hospID", Global.inf.hisHospitalDr); joIrisTmp.Add("psnNo", Global.pat.psn_no); joIrisTmp.Add("mdtrtId", Global.pat.mdtrtID); joIrisTmp.Add("InsuredType", Global.pat.insuType); joIrisTmp.Add("MedicalType", Global.pat.medType); joIrisTmp.Add("YBArea", Global.pat.insuplc_admdvs); joIrisTmp.Add("TrigScen", TrigScen); joIrisTmp.Add("InterfaceID", Global.inf.interfaceDr); jaIrisParams.Add(joIrisTmp); joIrisParam.Add("params", JArray.FromObject(jaIrisParams)); JObject joRtn = invoker.invokeHISService(joIrisParam.ToString(), "医保事前事中服务报文获取"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "GetInsuPatInfo医保事前事中服务报文获取 异常:" + ex.Message; return -1; } } /// /// 获取患者基本信息 /// /// /// public int GetHisPatBaseInfo(out string errMsg) { errMsg = ""; try { dynamic joTmp = new JObject(); joTmp.admID = Global.pat.adm_Dr; JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110021", joTmp).ToString(), "获取HIS患者基本信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { errMsg = "获取HIS患者基本信息失败,请联系管理员!" + errMsg; return -1; } else { errMsg = joRtn.ToString(); return 0; } } catch (Exception ex) { errMsg = "GetHisPatBaseInfo异常:" + ex.Message; return -1; } } /// /// 事前分析 /// /// /// public int PreAnalysis(out string errMsg) { errMsg = ""; try { JObject joTmp = new JObject(); joTmp.Add("billID", Global.pat.billID); joTmp.Add("recordID", Global.pat.recordID); JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110022", joTmp).ToString(), "获取事前分析内容"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { errMsg = "获取事前分析内容失败,请联系管理员!" + errMsg; return -1; } else { errMsg = joRtn.ToString(); return 0; } } catch (Exception ex) { errMsg = ex.Message; return -1; } } public int BatchHisRecord(JArray jaMiRecord, out string errMsg) { errMsg = ""; try { JObject joRtn = invoker.invokeHISService(JsonHelper.setIrisInpar("05110042", jaMiRecord).ToString(), "匹配His结算记录"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { errMsg = "获取事前分析内容失败,请联系管理员!" + errMsg; return -1; } else { errMsg = joRtn.ToString(); return 0; } } catch (Exception ex) { errMsg = ex.Message; return -1; } } } class MIIrisServices { private InvokeHelper invoker = new InvokeHelper(); /// /// 获取接口信息 /// /// public JObject getInterface() { dynamic joParam = new JObject(); joParam.HospitalDr = Global.inf.hospitalDr; joParam.InterfaceID = ""; JObject joInparam = JsonHelper.setIrisInpar("09010003", joParam); InvokeHelper invoker = new InvokeHelper(); return invoker.invokeInsuService(joInparam.ToString(), "获取接口信息"); } public JObject getInterface(string interfaceID) { dynamic joParam = new JObject(); joParam.HospitalDr = Global.inf.hospitalDr; joParam.InterfaceID = interfaceID; JObject joInparam = JsonHelper.setIrisInpar("09010003", joParam); InvokeHelper invoke = new InvokeHelper(); JObject joRtn = invoke.invokeInsuService(joInparam.ToString(), "获取接口信息"); JObject joInterfaceInfo = JObject.Parse(JsonHelper.getDestValue(joRtn, "result.data[0]")); joInterfaceInfo.Add("operatorNO", "0"); joInterfaceInfo.Add("operatorName", "管理员"); return joInterfaceInfo; } /// /// 判断是否签到过,如果未签到,返回false,如果签到则返回ture,同时返回签到号 /// /// /// public bool isSigned(ref string signno) { JObject joIn = new JObject(); joIn.Add("operatorNO", Global.user.ID.ToUpper()); joIn.Add("operatorName", Global.user.name); joIn.Add("mac", Global.curEvt.mac); joIn.Add("ip", Global.curEvt.ip); joIn.Add("hospitalDr", Global.inf.hospitalDr); joIn.Add("interfaceDr", Global.inf.interfaceDr); joIn.Add("date", DateTime.Now.ToString("yyyy-MM-dd")); string data = JsonHelper.setIrisInpar("09010064", joIn).ToString(); JObject joRtn = invoker.invokeInsuService(data, "查询签到信息"); string errMsg = ""; if ( JsonHelper.parseIrisRtnValue(joRtn,out errMsg)!= 0) { signno = ""; return false; } else { signno = JsonHelper.getDestValue(joRtn, "result.SignNo"); return true; } } /// ///保存签到信息 /// /// /// public int saveSignRecord( string signno,out string errMsg) { if (signno == "") { errMsg = "signno不能为空!"; return -1; } errMsg = ""; ; JObject joIn = new JObject(); joIn.Add("operatorNO", Global.user.ID); joIn.Add("operatorName", Global.user.name); joIn.Add("mac", Global.curEvt.mac); joIn.Add("ip", Global.curEvt.ip); joIn.Add("hospitalDr", Global.inf.hospitalDr); joIn.Add("interfaceDr", Global.inf.interfaceDr); joIn.Add("date", DateTime.Now.ToString("yyyy-MM-dd")); joIn.Add("signNo", signno); joIn.Add("createTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); joIn.Add("division", Global.inf.areaCode); string data = JsonHelper.setIrisInpar("09010065", joIn).ToString(); JObject joRtn = invoker.invokeInsuService(data, "插入签到信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { return -1; } else { return 0; } } /// /// 保存住院登记信息 /// /// /// /// /// public int saveInpatRegisterInfo(JObject joRegIn,JObject joRegOut,out string outParam) { //插入云医保平台 JObject joTmp = new JObject(); string errMsg = ""; try { joTmp.Add("HospitalDr", Global.inf.hospitalDr); joTmp.Add("InterfaceDr", Global.inf.interfaceDr); joTmp.Add("AdmDr", Global.pat.adm_Dr); joTmp.Add("PatientName", Global.pat.name); joTmp.Add("PersonalNO", Global.pat.psn_no); joTmp.Add("InsuRegID", JsonHelper.getDestValue(joRegOut, "output.prm_akc190")); joTmp.Add("RegDate", JsonHelper.getDestValue(joRegIn, "prm_akc192")); joTmp.Add("InsuType", JsonHelper.getDestValue(joRegOut, "output.prm_ykb065")); joTmp.Add("CertificateType", "01");//这个属性还是必须的? joTmp.Add("CertificateNO", JsonHelper.getDestValue(joRegOut, "output.prm_aac002")); joTmp.Add("MedicalType", JsonHelper.getDestValue(joRegOut, "output.prm_aka130")); joTmp.Add("AttendDoctorNO", ""); joTmp.Add("ChiefPhyDocName", ""); joTmp.Add("AdmInDiagDesc", JsonHelper.getDestValue(joRegIn, "prm_akc193")); joTmp.Add("AdmInDepCode", JsonHelper.getDestValue(joRegIn, "prm_ykc011")); joTmp.Add("AdmInDepName", JsonHelper.getDestValue(joRegIn, "prm_yka098")); joTmp.Add("AdmBed", JsonHelper.getDestValue(joRegIn, "prm_ykc012")); joTmp.Add("MainDiagCode", JsonHelper.getDestValue(joRegIn, "prm_yke120")); joTmp.Add("MainDiagName", JsonHelper.getDestValue(joRegIn, "prm_akc193")); joTmp.Add("MainConditionDesc", ""); joTmp.Add("DiseasecCode", ""); joTmp.Add("DiseasecName", ""); joTmp.Add("OperationCode", ""); joTmp.Add("OperationName", ""); joTmp.Add("DiseasecTypeCode", ""); joTmp.Add("InsuranceAreaCode", Global.pat.insuplc_admdvs); joTmp.Add("TreatmentAreaCode", Global.inf.areaCode); joTmp.Add("RegState", JsonHelper.getDestValue(joRegOut, "regstate")); joTmp.Add("ValidFlag", JsonHelper.getDestValue(joRegOut, "validflag")); joTmp.Add("Type", JsonHelper.getDestValue(joRegOut, "type")); joTmp.Add("updateUserID", Global.user.ID); joTmp.Add("msgid", Global.curEvt.msgid); joTmp.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); joTmp.Add("ConerName",""); joTmp.Add("Tel", ""); string serviceCode = "09010044"; string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString(); JObject joRtn = invoker.invokeInsuService(inpar, "新增住院登记信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = joRtn.ToString(); return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "保存住院登记信息异常:" + ex.Message; return -1; } } /// /// 保存门诊登记信息 /// /// /// /// /// /// public int saveOutpatRegisterInfo(JObject jo2201Inpar, JObject jo2201Rtn,JObject jo2203Inpar, out string outParam) { //插入云医保平台 JObject joTmp = new JObject(); string errMsg = ""; try { joTmp.Add("HospitalDr", Global.inf.hospitalDr); joTmp.Add("InterfaceDr", Global.inf.interfaceDr); joTmp.Add("AdmDr", Global.pat.adm_Dr); joTmp.Add("PatientName", Global.pat.name); joTmp.Add("PersonalNO", Global.pat.psn_no); joTmp.Add("InsuRegID", JsonHelper.getDestValue(jo2201Rtn, "output.data.mdtrt_id")); joTmp.Add("RegDate", JsonHelper.getDestValue(jo2201Inpar, "mdtrtinfo.begntime")); joTmp.Add("InsuType", JsonHelper.getDestValue(jo2201Inpar, "mdtrtinfo.insutype")); joTmp.Add("CertificateType", JsonHelper.getDestValue(jo2201Inpar, "mdtrtinfo.mdtrt_cert_type")); joTmp.Add("CertificateNO", JsonHelper.getDestValue(jo2201Inpar, "mdtrtinfo.mdtrt_cert_no")); joTmp.Add("MedicalType", JsonHelper.getDestValue(jo2203Inpar, "mdtrtinfo.med_type")); joTmp.Add("AttendDoctorNO", JsonHelper.getDestValue(jo2201Inpar, "mdtrtinfo.atddr_no")); joTmp.Add("ChiefPhyDocName", JsonHelper.getDestValue(jo2201Inpar, "mdtrtinfo.dr_name")); joTmp.Add("AdmInDiagDesc", JsonHelper.getDestValue(jo2203Inpar, "mdtrtinfo.main_cond_dscr")); joTmp.Add("AdmInDepCode", JsonHelper.getDestValue(jo2201Inpar, "mdtrtinfo.dept_code")); joTmp.Add("AdmInDepName", JsonHelper.getDestValue(jo2201Inpar, "mdtrtinfo.dept_name")); joTmp.Add("AdmBed", ""); joTmp.Add("MainDiagCode", " "); joTmp.Add("MainDiagName", " "); joTmp.Add("MainConditionDesc", JsonHelper.getDestValue(jo2203Inpar, "mdtrtinfo.main_cond_dscr")); joTmp.Add("DiseasecCode", JsonHelper.getDestValue(jo2203Inpar, "mdtrtinfo.dise_codg")); joTmp.Add("DiseasecName", JsonHelper.getDestValue(jo2203Inpar, "mdtrtinfo.dise_name")); joTmp.Add("OperationCode", ""); joTmp.Add("OperationName", ""); joTmp.Add("DiseasecTypeCode", ""); joTmp.Add("InsuranceAreaCode", Global.pat.insuplc_admdvs); joTmp.Add("TreatmentAreaCode", Global.inf.areaCode); joTmp.Add("RegState", JsonHelper.getDestValue(jo2201Rtn, "regstate")); joTmp.Add("ValidFlag", JsonHelper.getDestValue(jo2201Rtn, "validflag")); joTmp.Add("Type", JsonHelper.getDestValue(jo2201Rtn, "type")); joTmp.Add("updateUserID", Global.user.ID); joTmp.Add("msgid", Global.curEvt.msgid); joTmp.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); string serviceCode = "09010044"; string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString(); JObject joRtn = invoker.invokeInsuService(inpar, "新增门诊登记信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = joRtn.ToString(); return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "保存门诊登记信息异常:" + ex.Message; return -1; } } /// /// 取消登记 /// /// /// /// public int cancleRegister(int type,out string outParam) { outParam = ""; string errMsg; try { dynamic joTmp = new JObject(); joTmp.Add("HospitalDr", Global.inf.hospitalDr); joTmp.Add("InterfaceDr", Global.inf.interfaceDr); joTmp.Add("AdmDr", Global.pat.adm_Dr); joTmp.Add("PersonalNO",Global.pat.psn_no); joTmp.Add("InsuRegID", Global.pat.mdtrtID); joTmp.Add("CancleRegDate", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); joTmp.Add("Type", type); joTmp.Add("ValidFlag", -1); joTmp.Add("updateUserID", Global.user.ID); string serviceCode = "09010044"; string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString(); JObject joRtn = invoker.invokeInsuService(inpar, "取消云医保平台登记信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = "退结算失败,请根据输入条件检查是否存在该笔数据!" + errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "取消登记异常" + ":" + ex.Message; return -1; } } /// /// 删除费用明细 /// /// /// /// public int deleteFee(out string errMsg) { try { dynamic joTmp = new JObject(); joTmp = new JObject(); joTmp.code = "09010048"; joTmp.HospitalDr = Global.inf.hospitalDr; joTmp.admID = Global.pat.adm_Dr; joTmp.mdtrt_id = Global.pat.mdtrtID; joTmp.updateUserID = Global.user.ID; JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "删除2301明细"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { return -1; } else { return 0; } } catch (Exception ex) { errMsg = "deleteFee 异常:" + ex.Message; return -1; } } /// /// 根据HIS的费用明细获取对照关系 /// /// public int convertHisFeeWithInsuCode( JObject joHisFee, out string outParam) { outParam = ""; string errMsg; try { JArray jaFee = JArray.FromObject(joHisFee["result"]); JObject joTmp = JsonHelper.setIrisInpar("09010045", jaFee); joTmp.Add("mdtrt_id", Global.pat.mdtrtID); joTmp.Add("med_type", Global.pat.medType); joTmp.Add("psn_no", Global.pat.psn_no); //joTmp.Add("HospitalDr", Global.inf.hospitalDr); //joTmp.Add("InterfaceDr", Global.inf.interfaceDr); JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "根据HIS的费用明细获取对照关系"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "convertHisFeeWithInsuCode 异常:" + ex.Message; return -1; } } /// /// 根据HIS的费用明细获取对照关系 /// /// public int convertHisFeeWithInsuCodeOfMobilePay(Patients pat, JObject joHisFee, out string outParam) { outParam = ""; string errMsg; try { JArray jaFee = JArray.FromObject(joHisFee["result"]); JObject joTmp = JsonHelper.setIrisInpar("09010086", jaFee); joTmp.Add("mdtrt_id", pat.mdtrtID); joTmp.Add("med_type", pat.medType); joTmp.Add("psn_no", pat.psn_no); JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "根据HIS的费用明细获取对照关系"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = " convertHisFeeWithInsuCodeOfMobilePay异常:" + ex.Message; return -1; } } /// /// 转换事前事中 处方信息集合 /// /// public int convertFsiOrderDtos(JArray fsiOrderDtos, out string outParam) { outParam = ""; string errMsg; try { JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010077",fsiOrderDtos).ToString(), "转换事前事中处方信息集合"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "convertHisFeeWithInsuCode 异常:" + ex.Message; return -1; } } /// /// 插入医保费用 /// /// /// /// public int insertFee(JArray jaTmp,out string outParam) { try { outParam = ""; string errMsg; dynamic joTmp = new JObject(); joTmp = new JObject(); joTmp.code = "09010046"; joTmp.HospitalDr = Global.inf.hospitalDr; joTmp.admID = Global.pat.adm_Dr; joTmp.mdtrt_id = Global.pat.mdtrtID; joTmp.updateUserID = Global.user.ID; joTmp.Add("params", jaTmp); ; JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "插入2301明细"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "insertFee 异常:" + ex.Message; return -1; } } /// /// 更新医保费用 /// /// /// /// public int updateFee(JArray jaTmp, out string outParam) { try { outParam = ""; string errMsg; dynamic joTmp = new JObject(); joTmp.code = "09010047"; JArray jaParams = jaTmp; joTmp.Add("params", jaParams); joTmp.HospitalDr = Global.inf.hospitalDr; joTmp.admID = Global.pat.adm_Dr; joTmp.mdtrt_id = Global.pat.mdtrtID; joTmp.updateUserID =Global.user.ID; JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "更新2301明细"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "updateFee 异常:" + ex.Message; return -1; } } /// /// 获取各项费用汇总 /// /// /// public int getSumFee(out string outParam) { try { outParam = ""; string errMsg; //调用IRIS获取医保各项金额 dynamic joTmp = new JObject(); joTmp = new JObject(); joTmp.code = "09010049"; joTmp.HospitalDr = Global.inf.hospitalDr; joTmp.admID = Global.pat.adm_Dr; joTmp.mdtrt_id = Global.pat.mdtrtID; joTmp.updateUserID = Global.user.ID; ; JObject joRtn = invoker.invokeInsuService(joTmp.ToString(), "获取各项费用汇总"); ; if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "getSumFee 异常:" + ex.Message; return -1; } } /// /// 转换结算信息 /// /// /// /// /// public int convertSettlementWithInsuCode(JObject joSettlement, out string outParam) { outParam = ""; string errMsg; try { JObject joOutput = JObject.FromObject(joSettlement["output"]); //编码转换 JObject joInpar = new JObject(); joInpar.Add("hospitalDr", Global.inf.hospitalDr); joInpar.Add("interfaceDr", Global.inf.interfaceDr); joInpar.Add("output", joOutput); InvokeHelper invoker = new InvokeHelper(); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010055", joInpar).ToString(), "结算信息编码转换"); if (JsonHelper.getDestValue(joRtn, "errorCode") != "") { outParam = JsonHelper.getDestValue(joRtn, "errorMessage"); return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "convertSettlementWithInsuCode 异常:" + ex.Message; return -1; } } /// /// 插入结算信息 /// /// /// /// public int saveSettlement(JObject joSettlement, out string outParam) { JObject joTmp = new JObject(); string errMsg = ""; try { JObject joRtnSetlinfo = JObject.Parse(JsonHelper.getDestValue(joSettlement, "output")); JObject joSetlinfo = new JObject(); joSetlinfo.Add("HospitalDr", Global.inf.hospitalDr); joSetlinfo.Add("admID", Global.pat.adm_Dr); if (JsonHelper.getDestValue(joRtnSetlinfo, "prm_akc190") != "") joSetlinfo.Add("mdtrt_id", JsonHelper.getDestValue(joRtnSetlinfo, "prm_akc190")); else joSetlinfo.Add("mdtrt_id", Global.pat.mdtrtID); joSetlinfo.Add("setl_id", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka103"));// joSetlinfo.Add("psn_no", JsonHelper.getDestValue(joRtnSetlinfo, "prm_aac001")); joSetlinfo.Add("psn_name", JsonHelper.getDestValue(joRtnSetlinfo, "prm_aac003")); //joSetlinfo.Add("mdtrt_cert_type", JsonHelper.getDestValue(joRtnSetlinfo, "mdtrt_cert_type")); joSetlinfo.Add("certno", JsonHelper.getDestValue(joRtnSetlinfo, "prm_aac002")); joSetlinfo.Add("gend", JsonHelper.getDestValue(joRtnSetlinfo, "prm_aac004")); joSetlinfo.Add("naty", ""); joSetlinfo.Add("brdy", JsonHelper.getDestValue(joRtnSetlinfo, "prm_aac006")); joSetlinfo.Add("age", JsonHelper.getDestValue(joRtnSetlinfo, "prm_akc023")); joSetlinfo.Add("insutype", Global.pat.insuType); joSetlinfo.Add("psn_type", JsonHelper.getDestValue(joRtnSetlinfo, "prm_akc021")); joSetlinfo.Add("cvlserv_flag", ""); joSetlinfo.Add("setl_time", JsonHelper.getDestValue(joRtnSetlinfo, "prm_aae036")); joSetlinfo.Add("mdtrt_cert_type", JsonHelper.getDestValue(joRtnSetlinfo, "mdtrt_cert_type")); joSetlinfo.Add("med_type", Global.pat.medType); joSetlinfo.Add("medfee_sumamt", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka055"));//总费用 joSetlinfo.Add("fulamt_ownpay_amt", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka056"));//全自费金额 joSetlinfo.Add("overlmt_selfpay", "");//超限价自费费用 joSetlinfo.Add("preselfpay_amt", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka057"));//先行自付金额 joSetlinfo.Add("inscp_scp_amt", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka111"));//符合政策范围金额 joSetlinfo.Add("act_pay_dedc", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka058"));//实际支付起付线 joSetlinfo.Add("hifp_pay", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka248"));//基本医疗保险统筹基金支出 joSetlinfo.Add("pool_prop_selfpay", "0");//基本医疗保险统筹基金支付比例 joSetlinfo.Add("cvlserv_pay", JsonHelper.getDecimalFee(joRtnSetlinfo, "prm_yke030"));//公务员医疗补助资金支出 joSetlinfo.Add("hifes_pay", JsonHelper.getDecimalFee(joRtnSetlinfo, "prm_yka062"));//企业支付 占用 大病报销金额 joSetlinfo.Add("hifmi_pay", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka082"));// 居民大病保险资金支出 joSetlinfo.Add("hifob_pay", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka083"));//职工大额医疗费用补助基金支出 joSetlinfo.Add("maf_pay", JsonHelper.getDecimalFee(joRtnSetlinfo, "prm_ake181"));//医疗救助基金支出 joSetlinfo.Add("hosp_part_amt", JsonHelper.getDestValue(joRtnSetlinfo, "hosp_part_amt"));//医院负担金额 joSetlinfo.Add("oth_pay", JsonHelper.getDecimalFee(joRtnSetlinfo, "prm_ake173"));//其他支出 joSetlinfo.Add("fund_pay_sumamt", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka248"));//基金支付总额 joSetlinfo.Add("psn_part_amt", JsonHelper.getDestValue(joRtnSetlinfo, "prm_akc190"));//个人负担总金额 joSetlinfo.Add("acct_pay", JsonHelper.getDecimalFee(joRtnSetlinfo, "prm_yka065"));//个人账户支出 joSetlinfo.Add("psn_cash_pay", JsonHelper.getDestValue(joRtnSetlinfo, "psn_cash_pay"));//个人现金支出 joSetlinfo.Add("balc", JsonHelper.getDestValue(joRtnSetlinfo, "prm_akc087"));// 余额 joSetlinfo.Add("acct_mulaid_pay", "");//个人账户共济支付金额 joSetlinfo.Add("medins_setl_id", "");//医药机构结算ID joSetlinfo.Add("clr_optins", JsonHelper.getDestValue(joRtnSetlinfo, "prm_ykb037"));//清算经办机构 joSetlinfo.Add("clr_way", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka054"));//清算方式 joSetlinfo.Add("clr_type", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yka316"));//清算类别 joSetlinfo.Add("ValidFlag", 1); joSetlinfo.Add("BillType", 1); joSetlinfo.Add("msgid", Global.curEvt.msgid); joSetlinfo.Add("admType", Global.pat.admType); joSetlinfo.Add("billID", Global.pat.billID); joSetlinfo.Add("recordID", Global.pat.recordID); joSetlinfo.Add("interfaceDr", Global.inf.interfaceDr); if (JsonHelper.getDestValue(joRtnSetlinfo, "prm_yab003") != "") joSetlinfo.Add("insuplc_admdvs", JsonHelper.getDestValue(joRtnSetlinfo, "prm_yab003"));//参保地存分中心编号 else joSetlinfo.Add("insuplc_admdvs",Global.pat.insuplc_admdvs); joSetlinfo.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); joSetlinfo.Add("HospitalizationsDays", Global.settl.hospitalizationsDays); joSetlinfo.Add("HospitalizationsTimes", Global.settl.hospitalizationsTimes); joSetlinfo.Add("HISAdmTime", Global.settl.hisAdmTime); joSetlinfo.Add("HISDischargeTime", Global.settl.hisDischargeTime); joSetlinfo.Add("updateUserID", Global.user.ID); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010051", joSetlinfo).ToString(), "插入结算信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joSetlinfo.ToString(); return 0; } } catch (Exception ex) { outParam = "插入结算信息:" + ex.Message; return -1; } } /// /// 保存结算信息 /// /// /// /// public int saveSettlementDetail(JObject joSettlement, out string outParam) { JObject joTmp = new JObject(); string errMsg = ""; try { JObject joSetlDetail = new JObject(); joSetlDetail.Add("HospitalDr", Global.inf.hospitalDr); joSetlDetail.Add("InterfaceDr", Global.inf.interfaceDr); joSetlDetail.Add("MdtrtID", Global.pat.mdtrtID); joSetlDetail.Add("SettlementID", JsonHelper.getDestValue(joSettlement, "output.setlinfo.setl_id")); joSetlDetail.Add("AdmID", Global.pat.adm_Dr); joSetlDetail.Add("updateUserID", Global.user.ID); if (JsonHelper.getDestValue(joSettlement, "output.setldetail") == "") { outParam = "中心返回结算明细为空!"; return 0; } JArray jaSetlDetail = JArray.Parse(JsonHelper.getDestValue(joSettlement, "output.setldetail")); joSetlDetail.Add("setldetail", jaSetlDetail); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010056", joSetlDetail).ToString(), "插入结算明细信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "插入结算信息:" + ex.Message; return -1; } } /// /// 取消结算 /// /// /// public int cancleSettlement(string newSettlID, out string outParam) { JObject joTmp = new JObject(); string errMsg = ""; try { joTmp.Add("HospitalDr", Global.inf.hospitalDr); joTmp.Add("InterfaceDr", Global.inf.interfaceDr); joTmp.Add("admID", Global.pat.adm_Dr); joTmp.Add("mdtrt_id", Global.pat.mdtrtID); joTmp.Add("setl_id", Global.pat.settlID); joTmp.Add("new_setl_id", newSettlID); joTmp.Add("updateUserID", Global.user.ID); joTmp.Add("msgid", Global.curEvt.msgid); joTmp.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010052", joTmp).ToString(), "取消结算信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "取消结算信息:" + ex.Message; return -1; } } /// /// 查询登记信息 /// /// /// /// public int queryRegisterInfo(int type,out string outParam) { JObject joTmp = new JObject(); string errMsg = ""; try { joTmp.Add("HospitalDr", Global.inf.hospitalDr); joTmp.Add("InterfaceDr", Global.inf.interfaceDr); joTmp.Add("admID", Global.pat.adm_Dr); joTmp.Add("mdtrt_id", Global.pat.mdtrtID); joTmp.Add("type", type); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010050", joTmp).ToString(), "查询云平台患者登记信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "查询云平台患者登记信息:" + ex.Message; return -1; } } /// /// 插入患者该次就诊参保信息 /// /// /// /// /// /// public int insertPatCurInsuInfo(JObject joBaseInfo, out string outParam) { JObject joTmp = new JObject(); string errMsg = ""; try { joTmp.Add("HospitalDr", Global.inf.hospitalDr); joTmp.Add("InterfaceDr", Global.inf.interfaceDr); joTmp.Add("AdmID", Global.pat.adm_Dr); joTmp.Add("PatientName", Global.pat.name); joTmp.Add("PersonalNO", Global.pat.psn_no); joTmp.Add("MdtrtID", Global.pat.mdtrtID); joTmp.Add("PsnCertType", ""); joTmp.Add("PsnCertNO", JsonHelper.getDestValue(joBaseInfo, "prm_aac002")); joTmp.Add("Gend", JsonHelper.getDestValue(joBaseInfo, "prm_aac004")); joTmp.Add("Naty", ""); joTmp.Add("Brdy", JsonHelper.getDestValue(joBaseInfo, "prm_aac006")); joTmp.Add("Age", JsonHelper.getDestValue(joBaseInfo, "prm_aac006")); joTmp.Add("Balc", JsonHelper.getDestValue(joBaseInfo, "balc")); joTmp.Add("Insutype", JsonHelper.getDestValue(joBaseInfo, "prm_ykb065")); joTmp.Add("PsnType", JsonHelper.getDestValue(joBaseInfo, "prm_akc021")); joTmp.Add("PsnInsuStas", ""); joTmp.Add("PsnInsuDate", ""); joTmp.Add("PausInsuDate", ""); joTmp.Add("Cvlservflag", ""); joTmp.Add("insuplcAdmdvs", JsonHelper.getDestValue(joBaseInfo, "prm_yab003")); joTmp.Add("EmpName", JsonHelper.getDestValue(joBaseInfo, "prm_aab004")); joTmp.Add("PsnIdettype",Global.pat.patExtend.ykc296); joTmp.Add("PsnTypeLv", ""); joTmp.Add("IdetBegntime", ""); joTmp.Add("IdetEndtime", ""); joTmp.Add("ExtField1", JsonHelper.getDestValue(joBaseInfo, "prm_auther_certno")); joTmp.Add("ExtField2", JsonHelper.getDestValue(joBaseInfo, "prm_auther_insu_admdvs")); joTmp.Add("ExtField3", JsonHelper.getDestValue(joBaseInfo, "prm_auther_name")); joTmp.Add("ExtField4", JsonHelper.getDestValue(joBaseInfo, "prm_auther_no")); joTmp.Add("updateUserID", Global.user.ID); string serviceCode = "09010070"; string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString(); JObject joRtn = invoker.invokeInsuService(inpar, "插入患者该次就诊参保信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = errMsg; return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "医保平台插入患者该次就诊参保信息:" + ex.Message; return -1; } } /// /// /// /// 48交易入参 /// 48交易出参 /// /// public int saveOutpatRegisterInfo(JObject joInpar, JObject joOutpar, out string outParam) { //插入云医保平台 JObject joTmp = new JObject(); string errMsg = ""; try { joTmp.Add("HospitalDr", Global.inf.hospitalDr); joTmp.Add("InterfaceDr", Global.inf.interfaceDr); joTmp.Add("AdmDr", Global.pat.adm_Dr); joTmp.Add("PatientName", Global.pat.name); joTmp.Add("PersonalNO", Global.pat.psn_no); joTmp.Add("InsuRegID", JsonHelper.getDestValue(joOutpar, "output.prm_akc190")); joTmp.Add("RegDate", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); joTmp.Add("InsuType", JsonHelper.getDestValue(joInpar, "input.prm_ykb065")); joTmp.Add("CertificateType", "01"); joTmp.Add("CertificateNO", Global.pat.certNO); joTmp.Add("MedicalType", JsonHelper.getDestValue(joInpar, "input.prm_aka130")); joTmp.Add("AttendDoctorNO", ""); joTmp.Add("ChiefPhyDocName", ""); joTmp.Add("AdmInDiagDesc", ""); joTmp.Add("AdmInDepCode", ""); joTmp.Add("AdmInDepName", ""); joTmp.Add("AdmBed", ""); joTmp.Add("MainDiagCode", " "); joTmp.Add("MainDiagName", " "); joTmp.Add("MainConditionDesc", JsonHelper.getDestValue(joInpar, "input.prm_ykc173")); joTmp.Add("DiseasecCode", ""); joTmp.Add("DiseasecName", ""); joTmp.Add("OperationCode", ""); joTmp.Add("OperationName", ""); joTmp.Add("DiseasecTypeCode", ""); joTmp.Add("InsuranceAreaCode", Global.pat.insuplc_admdvs); joTmp.Add("TreatmentAreaCode", Global.inf.areaCode); joTmp.Add("RegState", "1"); joTmp.Add("ValidFlag", "1"); joTmp.Add("Type", "1"); joTmp.Add("updateUserID", Global.user.ID); joTmp.Add("msgid", Global.curEvt.msgid); joTmp.Add("OccurTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); string serviceCode = "09010044"; string inpar = JsonHelper.setIrisInpar(serviceCode, joTmp).ToString(); JObject joRtn = invoker.invokeInsuService(inpar, "新增门诊登记信息"); if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0) { outParam = joRtn.ToString(); return -1; } else { outParam = joRtn.ToString(); return 0; } } catch (Exception ex) { outParam = "保存门诊登记信息异常:" + ex.Message; return -1; } } #region 目录下载及对照 /// /// 通过分页的方式查询医保目录 /// /// /// /// /// public JObject getMIDirectoryByPagination(JObject jo) { string currentPage; string pageSize; string serviceCode; string directoryType; string directoryCode; string directoryName; string directoryDr; string approvalNO ; string verNO; try { currentPage = JsonHelper.getDestValue(jo, "currentPage"); pageSize = JsonHelper.getDestValue(jo, "pageSize"); serviceCode = JsonHelper.getDestValue(jo, "serviceCode"); directoryType = JsonHelper.getDestValue(jo, "directoryType"); directoryCode = JsonHelper.getDestValue(jo, "directoryCode"); directoryName = JsonHelper.getDestValue(jo, "directoryName"); directoryDr = JsonHelper.getDestValue(jo, "directoryDr"); approvalNO = JsonHelper.getDestValue(jo, "approvalNO"); verNO = JsonHelper.getDestValue(jo, "verNO"); InvokeHelper invoker = new InvokeHelper(); dynamic joInput = new JObject(); joInput.code = serviceCode; dynamic joTmp = new JObject(); JArray jaParmas = new JArray(); joTmp.HospitalDr = Global.inf.hospitalDr; joTmp.InterfaceDr = directoryDr; if (serviceCode == "09010043") { joTmp.Type = directoryCode; } else { joTmp.Code = directoryCode; } joTmp.Name = directoryName; joTmp.VerNO = verNO; joTmp.ApprovalNO = approvalNO; jaParmas.Add(joTmp); joInput.Add("params", JArray.FromObject(jaParmas)); JArray jaPagination = new JArray(); joTmp = new JObject(); joTmp.pageSize = pageSize; joTmp.currentPage = currentPage; joTmp.sortColumn = ""; joTmp.sortOrder = ""; joTmp.hisType = directoryType; jaPagination.Add(joTmp); joInput.Add("pagination", JArray.FromObject(jaPagination)); return invoker.invokeInsuService(joInput.ToString(), "查询医保目录分页"); } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "getDirectoryByPagination", ex.Message); } } /// /// 根据HisType获取当前目录最大版本号 /// /// /// public JObject getDirectoryMaxVersionNO(int directoryType) { try { dynamic joParam = new JObject(); joParam.HospitalDr = Global.inf.hospitalDr; joParam.InterfaceDr = Global.inf.interfaceDr; joParam.HisType = ""; if (directoryType == 0) { joParam.directoryType = "Directory"; } if (directoryType == 7) { joParam.directoryType = "LimitPrice"; } if (directoryType == 6) { joParam.directoryType = "SelfpayProportion"; } JObject joInparam = JsonHelper.setIrisInpar("09010037", joParam); JObject joRtn = invoker.invokeInsuService(joInparam.ToString(), "获取最大版本号"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "获取版本号异常:", ex.Message); } } public JObject insertDirectory(JArray jaParam) { JObject joIn = new JObject(); JObject joRtn = new JObject(); string outParam = ""; try { joIn.Add(new JProperty("params", jaParam)); joIn.Add("code", "09010035"); joIn.Add("updateUserID", Global.user.ID); string sInput = joIn.ToString(); joRtn = invoker.invokeInsuService(sInput, "插入医保目录"); outParam = joRtn.ToString(); return joRtn; } catch (Exception ex) { joRtn = JsonHelper.setExceptionJson(-1, "PTMedicalInsurance.Services.MIIrisServices.insertDirectory", ex.Message); outParam = joRtn.ToString(); return joRtn; } } public JObject insertDictionary(JObject joData) { try { JObject joInparam = JsonHelper.setIrisInpar("09010073", joData); JObject joRtn = invoker.invokeInsuService(joInparam.ToString(), "插入字典表"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "插入字典表异常:", ex.Message); } } public JObject insertDictionaryDataDetail(JArray jaData) { try { dynamic joParam = new JObject(); joParam.HospitalDr = Global.inf.hospitalDr; joParam.InterfaceDr = Global.inf.interfaceDr; JObject joInparam = JsonHelper.setIrisInpar("09010074", jaData); JObject joRtn = invoker.invokeInsuService(joInparam.ToString(), "插入字典明细表"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "插入字典明细表异常:", ex.Message); } } public JObject UpdateLimitPrice(JArray jaParam) { JObject joIn = new JObject(); JObject joRtn = new JObject(); string outParam = ""; try { joIn.Add(new JProperty("params", jaParam)); joIn.Add("code", "09010084"); joIn.Add("updateUserID", Global.user.ID); string sInput = joIn.ToString(); joRtn = invoker.invokeInsuService(sInput, "更新目录限价表"); outParam = joRtn.ToString(); return joRtn; } catch (Exception ex) { joRtn = JsonHelper.setExceptionJson(-1, "UpdateLimitPrice", ex.Message); outParam = joRtn.ToString(); return joRtn; } } public JObject UpdateSelfPercent(JArray jaParam) { JObject joIn = new JObject(); JObject joRtn = new JObject(); string outParam = ""; try { joIn.Add(new JProperty("params", jaParam)); joIn.Add("code", "09010085"); joIn.Add("updateUserID", Global.user.ID); string sInput = joIn.ToString(); joRtn = invoker.invokeInsuService(sInput, "更新自付比例表"); outParam = joRtn.ToString(); return joRtn; } catch (Exception ex) { joRtn = JsonHelper.setExceptionJson(-1, "UpdateSelfPercent", ex.Message); outParam = joRtn.ToString(); return joRtn; } } /// /// 插入字典主表和子表 /// /// /// public JObject insertDictionarys(JObject jaData) { try { dynamic joParam = new JObject(); JObject joInparam = JsonHelper.setIrisInpar("09010074", jaData); JObject joRtn = invoker.invokeInsuService( joInparam.ToString(),"插入字典明细表"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "插入字典明细表异常:", ex.Message); } } public JObject ConvertHISDir(JObject joHisRtnDir) { try { //传给医保平台,进行对照匹配 dynamic joParam = new JObject(); joParam.TotalCount = joHisRtnDir["result"]["TotalCount"]; joParam.HospitalDr = Global.inf.hospitalDr; joParam.InterfaceDr = Global.inf.interfaceDr; joParam.Data = joHisRtnDir["result"]["Data"]; JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010057", joParam).ToString(), "转换HIS目录分页,显示对照状态及对照的医保编码"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "转换HIS目录分页异常:", ex.Message); } } public JObject GetMappedHISDir(JArray jaPagination, JArray jaParams) { try { //传给医保平台,进行对照匹配 dynamic joParam = new JObject(); joParam.pagination = jaPagination; joParam.session = Global.curEvt.jaSession; joParam.Add("params", jaParams); joParam.code = "09010058"; JObject joRtn = invoker.invokeInsuService(joParam.ToString(), "获取已对照目录分页"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "获取已对照目录分页异常:", ex.Message); } } public JObject GetNoMappHISDir(JObject joHisRtnDir) { try { //传给医保平台,进行对照匹配 dynamic joParam = new JObject(); joParam.TotalCount = joHisRtnDir["result"]["TotalCount"]; joParam.HospitalDr = Global.inf.hospitalDr; joParam.InterfaceDr = Global.inf.interfaceDr; joParam.Data = joHisRtnDir["result"]["Data"]; JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010088", joParam).ToString(), "获取未对照目录"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "获取未对照目录异常:", ex.Message); } } public JObject UpdateDirectoryBySelf(JObject joIn) { try { JObject joParam = (JObject)joIn.DeepClone(); joParam.Add("updateUserID", Global.user.ID); joParam.Add("HospitalDr", Global.inf.hospitalDr); joParam.Add("InterfaceDr", Global.inf.interfaceDr); InvokeHelper invoker = new InvokeHelper(); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010035", joParam).ToString(), "手动修改医保目录表"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "手动修改医保目录表异常:", ex.Message); } } #endregion public JObject QueryTransactionLog(JObject joSqlStr) { try { InvokeHelper invoker = new InvokeHelper(); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010060", joSqlStr).ToString(), "查询交易日志(冲正)"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "查询交易日志(冲正)异常:", ex.Message); } } public JObject QuerySettlementInfo(JObject joSqlStr) { try { InvokeHelper invoker = new InvokeHelper(); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010059", joSqlStr).ToString(), "查询结算信息"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "查询结算信息异常:", ex.Message); } } public JObject DynamicQuerySettlInfo(JObject joSqlStr) { try { InvokeHelper invoker = new InvokeHelper(); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010081", joSqlStr).ToString(), "动态查询结算信息"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "查询结算信息异常:", ex.Message); } } public JObject DynamicQuery(JObject joSqlStr,string eventName) { try { InvokeHelper invoker = new InvokeHelper(); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010081", joSqlStr).ToString(), eventName); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, $"{eventName}异常:", ex.Message); } } public JObject QuerySettlementSumInfo(JObject joSqlStr) { try { InvokeHelper invoker = new InvokeHelper(); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010061", joSqlStr).ToString(), "查询结算信息"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "查询结算信息异常:", ex.Message); } } /// /// 获取指定字典信息 /// /// public JObject getSpecDictionary(string interfaceDr, string dicType) { string sqlStr = " select '' Code,'' Name,'' PinyinSearchCode union all "; sqlStr = sqlStr + " SELECT B.Code,B.Descripts AS Name,'' PinyinSearchCode FROM HB_Dictionary A JOIN HB_DictionaryDataDetail B ON A.ID = B.HBDictionary_Dr WHERE A.Interface_Dr= " + interfaceDr + " And A.InsuCode = '" + dicType + "' "; JObject joSqlstr = new JObject(); joSqlstr.Add("sqlStr", sqlStr); JArray jaParam = new JArray(); jaParam.Add(joSqlstr); JObject joSettlQuery = new JObject(); joSettlQuery.Add("params", jaParam); joSettlQuery.Add("code", "09010063"); InvokeHelper invoker = new InvokeHelper(); return invoker.invokeInsuService(joSettlQuery.ToString(), "查询指定字典信息"); } /// /// 获取指定字典信息 /// /// public JObject getSpecDictionary(string interfaceDr, string dicType,string dicCode) { string sqlStr = " "; sqlStr = sqlStr + " SELECT B.Code,B.Descripts AS Name,'' PinyinSearchCode FROM HB_Dictionary A JOIN HB_DictionaryDataDetail B " + "ON A.ID = B.HBDictionary_Dr WHERE A.Interface_Dr= " + interfaceDr + " And A.InsuCode = '" + dicType + "' " + " And B.Code = '" + dicCode + "' "; JObject joSqlstr = new JObject(); joSqlstr.Add("sqlStr", sqlStr); JArray jaParam = new JArray(); jaParam.Add(joSqlstr); JObject joSettlQuery = new JObject(); joSettlQuery.Add("params", jaParam); joSettlQuery.Add("code", "09010063"); InvokeHelper invoker = new InvokeHelper(); return invoker.invokeInsuService(joSettlQuery.ToString(), "查询指定字典信息"); } public JObject DynamicQueryPatCurrentInsuInfo(JObject joSqlStr) { try { InvokeHelper invoker = new InvokeHelper(); JObject joRtn = invoker.invokeInsuService(JsonHelper.setIrisInpar("09010082", joSqlStr).ToString(), "动态查询患者就诊参保信息"); return joRtn; } catch (Exception ex) { return JsonHelper.setExceptionJson(-1, "查询结算信息异常:", ex.Message); } } } }