| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265 | using Newtonsoft.Json.Linq;using PTMedicalInsurance.Common;using PTMedicalInsurance.Helper;using PTMedicalInsurance.Variables;using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Threading.Tasks;using System.Windows.Forms;namespace PTMedicalInsurance.Business{    class PreAndInProcessAnalysis    {        private HisIrisServices hIS = new HisIrisServices();        private JArray patient_dtos; //患者信息集合        private JArray fsi_encounter_dtos; //就诊信息集合        private JArray fsi_diagnose_dtos;  //诊断信息集合        private JArray fsi_order_dtos; //处方信息集合        private JArray fsi_operation_dtos; // 手术信息集合        MIIrisServices mis = new MIIrisServices();        public PreAndInProcessAnalysis(string inpar)        {            try            {                JObject jo = JObject.Parse(inpar);                JObject joResult = JObject.FromObject(jo["result"]);                patient_dtos = JArray.FromObject(joResult["patient_dtos"]);                fsi_encounter_dtos = JArray.FromObject(patient_dtos[0]["fsi_encounter_dtos"]);                fsi_diagnose_dtos = JArray.FromObject(fsi_encounter_dtos[0]["fsi_diagnose_dtos"]);                fsi_order_dtos = JArray.FromObject(fsi_encounter_dtos[0]["fsi_order_dtos"]);                fsi_operation_dtos = JArray.FromObject(fsi_encounter_dtos[0]["fsi_operation_dtos"]);            }            catch (Exception ex)            {                Global.writeLog("PreAndInProcessAnalysis构造异常:" + ex.Message);                throw;            }        }        #region 设置Patient        public int setPatientByHisBaseInfo(out string msg)        {            string errMsg = string.Empty;            msg = "";            try            {                if (hIS.GetHisPatBaseInfo(out errMsg) != 0)                {                    msg = errMsg;                    return -1;                }                JObject jo = JObject.Parse(errMsg);                Global.pat.name = JsonHelper.getDestValue(jo, "result.patName");                Global.pat.brdy = JsonHelper.getDestValue(jo, "result.patBirthdate");                Global.pat.gend = JsonHelper.getDestValue(jo, "result.patSex");                Global.pat.age = JsonHelper.getDestValue(jo, "result.Age");                Global.pat.naty = JsonHelper.getDestValue(jo, "result.naty");                Global.pat.certNO = JsonHelper.getDestValue(jo, "result.credNo");                Global.pat.certType = JsonHelper.getDestValue(jo, "result.credCode");                return 0;            }            catch (Exception ex)            {                msg = ex.Message;                return -1;            }        }        #endregion        public JObject Get3101Inpar(string trig_scen,Patients p)        {            try            {                JObject joInpar = new JObject();                joInpar.Add("syscode", "YBJK");                joInpar.Add("patient_dtos", GetPatient_dtos(trig_scen, p));                joInpar.Add("rule_ids", "");                joInpar.Add("task_id", GetMsgID());                joInpar.Add("trig_scen", trig_scen);                JObject joData = new JObject();                joData.Add("data",joInpar);                return joData;            }            catch (Exception ex)            {                MessageBox.Show("Get3101Inpar:" + ex.Message);                return null;            }        }        private string GetMsgID()        {            return Global.inf.hospitalNO + DateTime.Now.ToString("yyyyMMddHHmmssffff");        }        public JArray GetPatient_dtos(string trig_scen, Patients p)        {            try            {                string curr_mdtrt_id = p.mdtrtID;                if (string.IsNullOrEmpty(curr_mdtrt_id))                {                    curr_mdtrt_id = Global.pat.adm_Dr.ToString();                }                JObject joInpar = new JObject();                joInpar.Add("patn_id", p.psn_no);                joInpar.Add("patn_name", p.name);                string gend = p.gend;                if (gend == "男") gend = "1";                if (gend == "女") gend = "2";                joInpar.Add("gend",gend);                joInpar.Add("brdy", p.brdy);                if (p.insuplc_admdvs == "") p.insuplc_admdvs = Global.pat.insuplc_admdvs;                joInpar.Add("poolarea", p.insuplc_admdvs);                joInpar.Add("curr_mdtrt_id", curr_mdtrt_id);                joInpar.Add("fsi_encounter_dtos", GetFsi_encounter_dtos(trig_scen,p));                joInpar.Add("fsi_his_data_dto", new JArray());                JArray ja = new JArray();                ja.Add(joInpar);                return ja;            }            catch (Exception ex)            {                MessageBox.Show("GetPatient_dtos:" + ex.Message);                return null;            }        }        public JArray GetFsi_encounter_dtos(string trig_scen, Patients p)        {            try            {                JObject jofsi_encounter_dtos = JObject.FromObject(fsi_encounter_dtos[0]);                JObject joInpar = new JObject();                 string mdtrtID = p.mdtrtID;                if (string.IsNullOrEmpty(mdtrtID)) mdtrtID = Global.pat.adm_Dr.ToString();                joInpar.Add("mdtrt_id", mdtrtID);  //就诊标识                joInpar.Add("medins_id", Global.inf.hospitalNO);  //医疗服务机构标识                joInpar.Add("medins_name", Global.inf.hospitalName);  //医疗机构名称                joInpar.Add("medins_admdvs", Global.inf.areaCode);  //医疗机构行政区划编码                joInpar.Add("medins_type", "A");  //医疗服务机构类型                joInpar.Add("medins_lv", "04");  //医疗机构等级                joInpar.Add("wardarea_codg", JsonHelper.getDestValue(jofsi_encounter_dtos, "wardarea_codg"));  //病区标识                joInpar.Add("wardno", JsonHelper.getDestValue(jofsi_encounter_dtos, "wardno"));  //病房号                joInpar.Add("bedno", JsonHelper.getDestValue(jofsi_encounter_dtos, "bedno"));  //病床号                joInpar.Add("adm_date", JsonHelper.getDestValue(jofsi_encounter_dtos, "adm_date"));  //入院日期                joInpar.Add("dscg_date", JsonHelper.getDestValue(jofsi_encounter_dtos, "dscg_date"));  //出院日期                joInpar.Add("dscg_main_dise_codg", JsonHelper.getDestValue(jofsi_encounter_dtos, "dscg_main_dise_codg"));  //主诊断编码                joInpar.Add("dscg_main_dise_name", JsonHelper.getDestValue(jofsi_encounter_dtos, "dscg_main_dise_name"));  //主诊断名称                joInpar.Add("fsi_diagnose_dtos", GetFsi_diagnose__dtos(trig_scen, p));  //诊断信息DTO                joInpar.Add("dr_codg", JsonHelper.getDestValue(jofsi_encounter_dtos, "dr_codg"));  //医师标识                joInpar.Add("adm_dept_codg", JsonHelper.getDestValue(jofsi_encounter_dtos, "adm_dept_codg"));  //入院科室标识                joInpar.Add("adm_dept_name", JsonHelper.getDestValue(jofsi_encounter_dtos, "adm_dept_name"));  //入院科室名称                joInpar.Add("dscg_dept_codg", JsonHelper.getDestValue(jofsi_encounter_dtos, "dscg_dept_codg"));  //出院科室标识                joInpar.Add("dscg_dept_name", JsonHelper.getDestValue(jofsi_encounter_dtos, "dscg_dept_name"));  //出院科室名称                joInpar.Add("med_mdtrt_type", JsonHelper.getDestValue(jofsi_encounter_dtos, "med_mdtrt_type"));  //就诊类型                string med_type = JsonHelper.getDestValue(jofsi_encounter_dtos, "med_type");                joInpar.Add("med_type", med_type);  //医疗类别                joInpar.Add("fsi_order_dtos", GetFsi__order_dtos(trig_scen,p));  //处方(医嘱)信息                string matn_stas = JsonHelper.getDestValue(jofsi_encounter_dtos, "matn_stas");                if (string.IsNullOrEmpty(matn_stas)) matn_stas = "0";                joInpar.Add("matn_stas",matn_stas );  //生育状态                joInpar.Add("medfee_sumamt", JsonHelper.getDestValue(jofsi_encounter_dtos, "medfee_sumamt"));  //总费用                joInpar.Add("ownpay_amt", JsonHelper.getDestValue(jofsi_encounter_dtos, "ownpay_amt"));  //自费金额                joInpar.Add("selfpay_amt", JsonHelper.getDestValue(jofsi_encounter_dtos, "selfpay_amt"));  //自付金额                joInpar.Add("acct_payamt", JsonHelper.getDestValue(jofsi_encounter_dtos, "acct_payamt"));  //个人账户支付金额                joInpar.Add("ma_amt", JsonHelper.getDestValue(jofsi_encounter_dtos, "ma_amt"));  //救助金支付金额                joInpar.Add("hifp_payamt", JsonHelper.getDestValue(jofsi_encounter_dtos, "hifp_payamt"));  //统筹金支付金额                joInpar.Add("setl_totlnum", JsonHelper.getDestValue(jofsi_encounter_dtos, "setl_totlnum"));  //结算总次数                string insutype = JsonHelper.getDestValue(jofsi_encounter_dtos, "insutype");                if (insutype =="") insutype = Global.pat.insuType;                joInpar.Add("insutype", insutype);  //险种                string reimFlag = JsonHelper.getDestValue(jofsi_encounter_dtos, "reim_flag");                // 报销标志(必填)                if (string.IsNullOrEmpty(reimFlag))                {                    reimFlag = "1";                }                joInpar.Add("reim_flag", reimFlag);                // 异地结算标志(必填)                string outSetlFlag = JsonHelper.getDestValue(jofsi_encounter_dtos, "out_setl_flag");                if (string.IsNullOrEmpty(outSetlFlag))                {                    outSetlFlag = Utils.isOtherCityPatient()?"1":"0";                }                joInpar.Add("out_setl_flag", outSetlFlag);                joInpar.Add("fsi_operation_dtos", GetFsi__operation__dtos(trig_scen,p));  //手术操作集合                JArray ja = new JArray();                ja.Add(joInpar);                return ja;             }            catch (Exception ex)            {                MessageBox.Show("GetPatient_dtos:" + ex.Message);                return null;            }        }        public JArray GetFsi_diagnose__dtos(string trig_scen, Patients p)        {            try            {                return fsi_diagnose_dtos;            }            catch (Exception ex)            {                MessageBox.Show("GetPatient_dtos:" + ex.Message);                return null;            }        }                public JArray GetFsi__operation__dtos(string trig_scen, Patients p)        {            try            {                return fsi_operation_dtos;            }            catch (Exception ex)            {                MessageBox.Show("GetPatient_dtos:" + ex.Message);                return null;            }        }        #region 组织入参        public JArray GetFsi__order_dtos(string trig_scen, Patients p)        {            string errMsg = "";            try            {                for (int i = 0; i < fsi_order_dtos.Count; i++)                {                    decimal pric = decimal.Parse(fsi_order_dtos[i]["pric"].ToString());                    fsi_order_dtos[i]["pric"] = pric.ToString("#0.00");                    fsi_order_dtos[i]["hilist_pric"] = pric.ToString("#0.00");                }                //调用医保平台进行转换                if (mis.convertFsiOrderDtos(fsi_order_dtos, out errMsg) != 0)                {                    return null;                }                else                {                    JObject joRtn = JObject.Parse(errMsg);                    return JArray.FromObject(joRtn["data"]);                }            }            catch (Exception ex)            {                MessageBox.Show("GetFsi__order_dtos:" + ex.Message);                return null;            }        }        #endregion    }}
 |