HandleException.cs 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824
  1. using Newtonsoft.Json.Linq;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.ComponentModel;
  5. using System.Data;
  6. using System.Drawing;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. using System.Windows.Forms;
  11. using PTMedicalInsurance.Common;
  12. using PTMedicalInsurance.Helper;
  13. using PTMedicalInsurance.FormSetter;
  14. using PTMedicalInsurance.Business;
  15. using PTMedicalInsurance.Variables;
  16. using FastReport;
  17. using System.Security.Policy;
  18. using FastReport.Editor;
  19. using System.Collections;
  20. namespace PTMedicalInsurance.Forms
  21. {
  22. public partial class HandleException : Form
  23. {
  24. private int iLog = 0;
  25. private int iSettl = 0;
  26. private int iReg = 0;
  27. string ID, SettlementID, PersonnelNO, msgid, MdtrtID, PatientName, Sumamt, AdmType;
  28. //设置业务实例
  29. CenterBusiness cBus = new CenterBusiness();
  30. HisMainBusiness hBus = new HisMainBusiness();
  31. HisIrisServices hIS = new HisIrisServices();
  32. MIIrisServices mIS = new MIIrisServices();
  33. InvokeHelper invoker = new InvokeHelper();
  34. //1.声明自适应类实例
  35. AutoResizeForm asc = new AutoResizeForm();
  36. public HandleException()
  37. {
  38. InitializeComponent();
  39. //this.StartPosition = FormStartPosition.CenterParent;
  40. asc.controllInitializeSize(this);
  41. asc.controlAutoSize(this);
  42. }
  43. private void cbb_InterfaceDr_SelectedValueChanged(object sender, EventArgs e)
  44. {
  45. DataTable dtInteface = (DataTable)cbb_InterfaceDr.DataSource;
  46. int i = cbb_InterfaceDr.SelectedIndex;
  47. if (i != 2)
  48. {
  49. Global.pat.insuplc_admdvs = "";
  50. }
  51. else
  52. {
  53. Global.pat.insuplc_admdvs = "530199";
  54. }
  55. Global.inf.hospitalNO = dtInteface.Rows[i]["HospitalNO"].ToString();
  56. Global.inf.hospitalName = dtInteface.Rows[i]["HospitalName"].ToString();
  57. Global.inf.centerURL = dtInteface.Rows[i]["CenterURL"].ToString();
  58. Global.inf.areaCode = dtInteface.Rows[i]["AreaCode"].ToString();
  59. Global.user.name = "0";
  60. Global.user.ID = "0";
  61. Global.inf.operatoType = "3";
  62. Global.inf.version = "v1.0";
  63. Global.inf.recivedSystem = "SY";
  64. Global.inf.interfaceDr = int.Parse(dtInteface.Rows[i]["ID"].ToString());
  65. ComboxSetter cbxSetter = new ComboxSetter();
  66. cbxSetter.setCbxDictionaryDataSource(dtInteface.Rows[i]["ID"].ToString(), "insutype", cbb_InsuType);
  67. //cbxSetter.setCbxDictionaryDataSource(dtInteface.Rows[i]["ID"].ToString(), "clr_type", cbxClrType);
  68. }
  69. private void HandleException_Load(object sender, EventArgs e)
  70. {
  71. dpST_Log.Text = DateTime.Now.ToString("yyyy-MM-dd 00:00:00");
  72. dpED_Log.Text = DateTime.Now.ToString("yyyy-MM-dd 23:59:59");
  73. dpST_Settl.Text = DateTime.Now.ToString("yyyy-MM-dd 00:00:00");
  74. dpED_Settl.Text = DateTime.Now.ToString("yyyy-MM-dd 23:59:59");
  75. dpST_OutPatReg.Text = DateTime.Now.ToString("yyyy-MM-dd 00:00:00");
  76. dpED_OutPatReg.Text = DateTime.Now.ToString("yyyy-MM-dd 23:59:59");
  77. dtSignBegin.Text = DateTime.Now.ToString("yyyy-MM-dd 00:00:00");
  78. dtSignEnd.Text = DateTime.Now.ToString("yyyy-MM-dd 23:59:59");
  79. dt_ST.Text = DateTime.Now.ToString("yyyy-MM-dd 00:00:00");
  80. dt_ET.Text = DateTime.Now.ToString("yyyy-MM-dd 23:59:59");
  81. dgvSettlRecord.AutoGenerateColumns = false;
  82. GridViewSetter grdSetter = new GridViewSetter();
  83. grdSetter.SetHeaderTextOfSettlList(dgvSettlRecord);
  84. grdSetter.SetHeaderTextOfCenterLog(dgvLog);
  85. grdSetter.SetHeaderTextOfRegister(dgvOutPatReg);
  86. grdSetter.SetHeaderTextOfSign(dgvSignQuery);
  87. grdSetter.SetHeaderTextOfSettlList(dgv_SettleData);
  88. ComboxSetter cbxSetter = new ComboxSetter();
  89. cbxSetter.setCbxInterfaceDataSource(cbb_InterfaceDr);
  90. cbxSetter.setCbxDictionaryDataSource(Global.inf.interfaceDr.ToString(), "med_type", cbb_MedType);
  91. cbxSetter.setCbxDictionaryDataSource(Global.inf.interfaceDr.ToString(), "insutype", cbb_InsuType);
  92. cbb_InterfaceDr.SelectedValueChanged += new EventHandler(cbb_InterfaceDr_SelectedValueChanged);
  93. rbgAdmType.SelectedIndex = 0;
  94. rbgBillType.SelectedIndex = 1;
  95. }
  96. #region 结算异常
  97. private void btnQuerySettleRec_Click(object sender, EventArgs e)
  98. {
  99. if (tbName.Text == "")
  100. {
  101. MessageBox.Show("请输入患者姓名!");
  102. return;
  103. }
  104. string sqlStr = "SELECT * FROM BS_MedInsuSettlement WHERE Hospital_Dr=" + Global.inf.hospitalDr;
  105. sqlStr = sqlStr + " and OccurTime>'" + dpST_Settl.Text + "'";
  106. sqlStr = sqlStr + " and OccurTime<'" + dpED_Settl.Text + "'";
  107. if (tbName.Text != "")
  108. {
  109. sqlStr = sqlStr + " and PatientName='" + tbName.Text + "'";
  110. }
  111. if (tbPatSettlID.Text != "")
  112. {
  113. sqlStr = sqlStr + " and SettlementID='" + tbPatSettlID.Text + "'";
  114. }
  115. if (tbHisNO.Text != "")
  116. {
  117. sqlStr = sqlStr + " and Adm_Dr='" + tbHisNO.Text + "'";
  118. }
  119. if (rbgAdmType.SelectedIndex == 1)
  120. {
  121. sqlStr = sqlStr + " and admType=1";
  122. }
  123. if (rbgAdmType.SelectedIndex == 2)
  124. {
  125. sqlStr = sqlStr + " and admType=2";
  126. }
  127. if (rbgBillType.SelectedIndex == 1)
  128. {
  129. sqlStr = sqlStr + " and BillType=1";
  130. }
  131. if (rbgBillType.SelectedIndex == 2)
  132. {
  133. sqlStr = sqlStr + " and BillType=-1";
  134. }
  135. JObject joSqlstr = new JObject();
  136. joSqlstr.Add("sqlStr", sqlStr);
  137. JArray jaParam = new JArray();
  138. jaParam.Add(joSqlstr);
  139. JObject joSettlQuery = new JObject();
  140. joSettlQuery.Add("params", jaParam);
  141. joSettlQuery.Add("code", "09010059");
  142. InvokeHelper invoker = new InvokeHelper();
  143. JObject joRtn = invoker.invokeInsuService(joSettlQuery.ToString(), "查询结算信息");
  144. MessageBox.Show(joRtn.ToString());
  145. MessageBox.Show(joRtn["result"]["data"].ToString());
  146. if (joRtn["result"]["data"].ToString() == "[]")
  147. {
  148. MessageBox.Show("查询结果为空!");
  149. return;
  150. }
  151. DataTable dt = (DataTable)joRtn["result"]["data"].ToObject(typeof(DataTable));
  152. dgvSettlRecord.DataSource = dt;
  153. }
  154. private void btnReverseBySettl_Click(object sender, EventArgs e)
  155. {
  156. //InvokeHelper invoker = new InvokeHelper();
  157. DataTable dt = (DataTable)dgvSettlRecord.DataSource;
  158. string errorMessage = "";
  159. int a = dgvOutPatReg.CurrentRow.Index;
  160. //Global.inf.patientAreaCode = dt.Rows[a]["insuplc_admdvs"].ToString();
  161. Global.pat.insuplc_admdvs = dt.Rows[a]["insuplc_admdvs"].ToString();
  162. string mdtrt_id = dt.Rows[a]["MdtrtID"].ToString();
  163. string psn_no = dt.Rows[a]["PersonnelNO"].ToString();
  164. string adm_Dr = dt.Rows[a]["AdmID"].ToString();
  165. string setl_id = dt.Rows[a]["SettlementID"].ToString();
  166. JObject joInparam = new JObject();
  167. JObject joData = new JObject();
  168. joData.Add("omsgid", dt.Rows[a]["msgid"].ToString());
  169. joData.Add("psn_no", dt.Rows[a]["PersonnelNO"].ToString());
  170. string infno = "";
  171. if (dt.Rows[a]["infno"].ToString() == "1") infno = "2207";
  172. if (dt.Rows[a]["infno"].ToString() == "2") infno = "2304";
  173. joData.Add("oinfno", infno);
  174. joInparam.Add("data", joData);
  175. MessageBox.Show(joInparam.ToString());
  176. JObject joRtn = invoker.invokeCenterService("2601", JsonHelper.setCenterInpar("2601", joInparam.ToString()));
  177. //将中心返回的结果返回HIS 调用HIS服务进行保存
  178. if (JsonHelper.parseIrisRtnValue(joRtn, out errorMessage) != 0)
  179. {
  180. MessageBox.Show("冲正失败:" + errorMessage);
  181. }
  182. else
  183. {
  184. dynamic joTmp = new JObject();
  185. joTmp.admID = adm_Dr;
  186. joTmp.PersonalNO = psn_no;
  187. joTmp.mdtrt_id = mdtrt_id;
  188. joTmp.setl_id = setl_id;
  189. //JObject jo2305IrisRtn = mIS.cancleSettlement(joTmp);
  190. JObject jo2305IrisRtn = new JObject();
  191. if (JsonHelper.parseIrisRtnValue(jo2305IrisRtn, out errorMessage) != 0)
  192. {
  193. errorMessage = "中心取消结算成功但云HIS平台取消失败,请联系管理员!" + errorMessage;
  194. MessageBox.Show(errorMessage);
  195. }
  196. }
  197. }
  198. private void btCancleSettl_Click(object sender, EventArgs e)
  199. {
  200. string outParam;
  201. DataTable dt = (DataTable)dgvSettlRecord.DataSource;
  202. string errorMessage = "";
  203. int a = dgvSettlRecord.CurrentRow.Index;
  204. //Global.inf.patientAreaCode = dt.Rows[a]["insuplc_admdvs"].ToString()
  205. MessageBox.Show("111");
  206. Global.pat.insuplc_admdvs = dt.Rows[a]["insuplc_admdvs"].ToString();
  207. MessageBox.Show(dt.Rows[a]["insuplc_admdvs"].ToString());
  208. MessageBox.Show(Global.pat.insuplc_admdvs);
  209. Global.pat.mdtrtID = dt.Rows[a]["MdtrtID"].ToString();
  210. Global.pat.psn_no = dt.Rows[a]["PersonnelNO"].ToString();
  211. Global.pat.settlID = dt.Rows[a]["SettlementID"].ToString();
  212. Global.pat.adm_Dr = int.Parse(dt.Rows[a]["AdmID"].ToString());
  213. //取消中心结算信息
  214. if (cBus.cancleSettlement("2305", out outParam) != 0)
  215. {
  216. MessageBox.Show( "取消中心结算信息失败!" + outParam);
  217. return;
  218. }
  219. else
  220. {
  221. //取消平台结算信息
  222. //if (mIS.cancleSettlement(out outParam) != 0)
  223. if (cBus.cancleSettlement("2305", out outParam) != 0)
  224. {
  225. MessageBox.Show("中心结算取消成功,医保平台结算信息取消失败!" + outParam);
  226. return ;
  227. }
  228. //取消出院登记
  229. if (cBus.cancleRegister("2405", out outParam) != 0)
  230. {
  231. MessageBox.Show("中心,医保平台及HIS结算信息取消成功,取消出院登记失败!请手工取消出院登记!" + outParam);
  232. return ;
  233. }
  234. }
  235. }
  236. #endregion
  237. #region 日志异常
  238. private void btnQueryLog_Click(object sender, EventArgs e)
  239. {
  240. string errMsg;
  241. string sqlStr = "SELECT * FROM BS_MedInsuTransactionLog WHERE Hospital_Dr=" + Global.inf.hospitalDr;
  242. sqlStr = sqlStr + " and InfDate>='" + dpST_Log.Value.ToString("yyyy-MM-dd") + "'";
  243. sqlStr = sqlStr + " and InfDate<='" + dpED_Log.Value.ToString("yyyy-MM-dd") + "'";
  244. if (tbPsnNO.Text != "")
  245. {
  246. sqlStr = sqlStr + " and PSNNO='" + tbPsnNO.Text + "'";
  247. }
  248. if (tbTransNO.Text != "")
  249. {
  250. sqlStr = sqlStr + " and Infno='" + tbTransNO.Text + "'";
  251. }
  252. JObject joSqlstr = new JObject();
  253. joSqlstr.Add("sqlStr", sqlStr);
  254. JObject joRtn = mIS.QueryTransactionLog(joSqlstr);
  255. //if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  256. //{
  257. // MessageBox.Show(errMsg);
  258. // return;
  259. //}
  260. try
  261. {
  262. if (joRtn["result"]["data"].ToString() == "[]")
  263. {
  264. MessageBox.Show("查询结果为空!");
  265. return;
  266. }
  267. DataTable dt = (DataTable)joRtn["result"]["data"].ToObject(typeof(DataTable));
  268. dgvLog.DataSource = dt;
  269. }
  270. catch (Exception eX)
  271. {
  272. MessageBox.Show(eX.Message);
  273. }
  274. }
  275. private void btnReverseByLog_Click(object sender, EventArgs e)
  276. {
  277. InvokeHelper invoker = new InvokeHelper();
  278. DataTable dt = (DataTable)dgvLog.DataSource;
  279. JObject joInparam = new JObject();
  280. JObject joData = new JObject();
  281. int a = dgvLog.CurrentRow.Index;
  282. if (tbCBD_Log.Text != "")
  283. { Global.pat.insuplc_admdvs = tbCBD_Log.Text; }
  284. else
  285. Global.pat.insuplc_admdvs = dt.Rows[a]["insuplc_admdvs"].ToString();
  286. joData.Add("omsgid", dt.Rows[a]["msgid"].ToString());
  287. joData.Add("psn_no", dt.Rows[a]["psn_no"].ToString());
  288. joData.Add("oinfno", dt.Rows[a]["infno"].ToString());
  289. //joData.Add("oinfno", "2207");
  290. joInparam.Add("data", joData);
  291. JObject joRtn = invoker.invokeCenterService("2601", JsonHelper.setCenterInpar("2601", joInparam.ToString()));
  292. string errorMessage = "";
  293. if (JsonHelper.parseCenterRtnValue(joRtn, out errorMessage) != 0)
  294. {
  295. MessageBox.Show("冲正失败" + errorMessage);
  296. }
  297. else
  298. {
  299. MessageBox.Show("冲正成功");
  300. }
  301. }
  302. #endregion
  303. #region 手工
  304. private void btPatInfo_ex_Click(object sender, EventArgs e)
  305. {
  306. rtbInparam.Text = @"{""data"":{""omsgid"":""H51010604235202205280848088230"",""psn_no"":""1530541881"",""oinfno"":""2201""}}";
  307. JObject joTmp = JObject.Parse(rtbInparam.Text);
  308. rtbInparam.Text = joTmp.ToString();
  309. }
  310. private void btnPatInfoShow_Click(object sender, EventArgs e)
  311. {
  312. string errorMsg = "";
  313. JObject joRtn = new JObject();
  314. Global.pat.insuplc_admdvs = tbCBD_Hand.Text;
  315. if (Chk_DealNo.Checked)
  316. {
  317. //joRtn = invoker.invokeCenterService(tb_DealNo.Text, JsonHelper.setCenterInpar(tb_DealNo.Text, rtbInparam.Text));
  318. string[] strArr = { "3501", "3502", "3503", "3504", "3505", "3506", "3507" };
  319. bool exists = ((IList)strArr).Contains(tb_DealNo.Text);
  320. if (exists)
  321. {
  322. joRtn = invoker.invokeCenterServiceJXC(tb_DealNo.Text, JObject.Parse(JsonHelper.setCenterInpar(tb_DealNo.Text, rtbInparam.Text)));
  323. }
  324. else
  325. {
  326. joRtn = invoker.invokeCenterService(tb_DealNo.Text, JsonHelper.setCenterInpar(tb_DealNo.Text, rtbInparam.Text));
  327. }
  328. }
  329. else
  330. {
  331. joRtn = invoker.invokeCenterService("2601", JsonHelper.setCenterInpar("2601", rtbInparam.Text));
  332. }
  333. if (JsonHelper.parseCenterRtnValue(joRtn, out errorMsg) != 0)
  334. {
  335. MessageBox.Show("调用失败:" + errorMsg);
  336. }
  337. else
  338. {
  339. rtbOutparam.Text = joRtn.ToString();
  340. MessageBox.Show("调用成功!:");
  341. }
  342. }
  343. #endregion
  344. #region 门诊登记
  345. private void btnQueryOutPatReg_Click(object sender, EventArgs e)
  346. {
  347. string sqlStr = "SELECT * FROM BS_MedInsuRegisterInfo WHERE Type=3 and Hospital_Dr=" + Global.inf.hospitalDr;
  348. sqlStr = sqlStr + " and OccurTime>'" + dpST_OutPatReg.Text + "'";
  349. sqlStr = sqlStr + " and OccurTime<'" + dpED_OutPatReg.Text + "'";
  350. if (tbOutPatName.Text != "")
  351. {
  352. sqlStr = sqlStr + " and Pat_Name='" + tbOutPatName.Text + "'";
  353. }
  354. if (tbOutPatRegID.Text != "")
  355. {
  356. sqlStr = sqlStr + " and InsuRegID='" + tbOutPatRegID.Text + "'";
  357. }
  358. if (tbOutPatPsnNO.Text != "")
  359. {
  360. sqlStr = sqlStr + " and PersonalNO='" + tbOutPatPsnNO.Text + "'";
  361. }
  362. JObject joSqlstr = new JObject();
  363. joSqlstr.Add("sqlStr", sqlStr);
  364. JArray jaParam = new JArray();
  365. jaParam.Add(joSqlstr);
  366. JObject joSettlQuery = new JObject();
  367. joSettlQuery.Add("params", jaParam);
  368. joSettlQuery.Add("code", "09010062");
  369. InvokeHelper invoker = new InvokeHelper();
  370. JObject joRtn = invoker.invokeInsuService(joSettlQuery.ToString(), "查询门诊挂号");
  371. try
  372. {
  373. if (joRtn["result"]["data"].ToString() == "[]")
  374. {
  375. MessageBox.Show("查询结果为空!");
  376. return;
  377. }
  378. DataTable dt = (DataTable)joRtn["result"]["data"].ToObject(typeof(DataTable));
  379. dgvOutPatReg.DataSource = dt;
  380. }
  381. catch (Exception eX)
  382. {
  383. MessageBox.Show(eX.Message);
  384. }
  385. }
  386. private void btnCancleOutPatReg_Click(object sender, EventArgs e)
  387. {
  388. InvokeHelper invoker = new InvokeHelper();
  389. DataTable dt = (DataTable)dgvOutPatReg.DataSource;
  390. string errorMessage = "";
  391. int a = dgvOutPatReg.CurrentRow.Index;
  392. //组织挂号入参
  393. JObject joCancleRegInpar = new JObject();
  394. Global.pat.insuplc_admdvs = dt.Rows[a]["insuplc_admdvs"].ToString();
  395. joCancleRegInpar.Add("psn_no", dt.Rows[a]["PersonalNO"].ToString());
  396. joCancleRegInpar.Add("mdtrt_id", dt.Rows[a]["InsuRegID"].ToString());
  397. joCancleRegInpar.Add("ipt_otp_no", dt.Rows[a]["AdmID"].ToString());
  398. JObject joRegInput = new JObject();
  399. joRegInput.Add("data", joCancleRegInpar);
  400. //取消挂号信息
  401. JObject jo2202Rtn = invoker.invokeCenterService("2202", JsonHelper.setCenterInpar("2202", joRegInput.ToString()));
  402. if (JsonHelper.parseCenterRtnValue(jo2202Rtn, out errorMessage) != 0)
  403. {
  404. MessageBox.Show("取消挂号失败" + errorMessage);
  405. }
  406. else
  407. {
  408. dynamic joTmp = new JObject();
  409. joTmp.admID = dt.Rows[a]["AdmID"].ToString();
  410. joTmp.PersonalNO = dt.Rows[a]["PersonalNO"].ToString();
  411. joTmp.InsuRegID = dt.Rows[a]["InsuRegID"].ToString();
  412. joTmp.Add("billID", "");
  413. joTmp.Type = 3;
  414. joTmp.CancleRegDate = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
  415. JObject jo2404IrisRtn = hIS.cancleRegister(joTmp);
  416. if (JsonHelper.parseIrisRtnValue(jo2404IrisRtn, out errorMessage) != 0)
  417. {
  418. MessageBox.Show(errorMessage);
  419. }
  420. else
  421. {
  422. MessageBox.Show("取消挂号成功");
  423. }
  424. }
  425. }
  426. private void btnCancleOutPatFee_Click(object sender, EventArgs e)
  427. {
  428. InvokeHelper invoker = new InvokeHelper();
  429. DataTable dt = (DataTable)dgvOutPatReg.DataSource;
  430. string errorMessage = "";
  431. int a = dgvOutPatReg.CurrentRow.Index;
  432. Global.pat.insuplc_admdvs = dt.Rows[a]["insuplc_admdvs"].ToString();
  433. string mdtrt_id = dt.Rows[a]["InsuRegID"].ToString();
  434. string psn_no = dt.Rows[a]["PersonalNO"].ToString();
  435. string adm_Dr = dt.Rows[a]["AdmID"].ToString();
  436. //组织入参
  437. dynamic joTmp = new JObject();
  438. joTmp.chrg_bchno = "0000";
  439. joTmp.mdtrt_id = mdtrt_id;
  440. joTmp.psn_no = psn_no;
  441. JObject joData = new JObject();
  442. joData.Add("data", joTmp);
  443. //组织好后上传给中心
  444. JObject joCenterRtn = invoker.invokeCenterService("2205", JsonHelper.setCenterInpar("2205", joData.ToString()));
  445. if (joCenterRtn["infcode"].ToString() == "0")
  446. {
  447. //删除医保传送表的数据
  448. joTmp = new JObject();
  449. joTmp.code = "09010048";
  450. joTmp.HospitalDr = Global.inf.hospitalDr;
  451. joTmp.admID = adm_Dr;
  452. joTmp.mdtrt_id = mdtrt_id;
  453. joTmp.updateUserID = Global.user.ID;
  454. JObject joIris2301DeleteRtn = invoker.invokeInsuService(joTmp.ToString(), "删除门诊明细");
  455. if (JsonHelper.parseCenterRtnValue(joIris2301DeleteRtn, out errorMessage) != 0)
  456. {
  457. MessageBox.Show("取消门诊费用失败" + errorMessage);
  458. }
  459. else
  460. {
  461. MessageBox.Show("取消门诊费用成功");
  462. }
  463. }
  464. else
  465. {
  466. MessageBox.Show("取消门诊费用失败");
  467. }
  468. }
  469. #endregion
  470. private void btnExit_Click(object sender, EventArgs e)
  471. {
  472. Close();
  473. }
  474. private void uiButton8_Click(object sender, EventArgs e)
  475. {
  476. if (dgv_SettleData.DataSource == null)
  477. {
  478. MessageBox.Show("请先查询结算表信息!");
  479. return;
  480. }
  481. if (string.IsNullOrEmpty(dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["ID"].Value.ToString()))
  482. {
  483. MessageBox.Show("医保结算记录ID不能为空!");
  484. return;
  485. }
  486. if (string.IsNullOrEmpty(tb_SettlementID.Text))
  487. {
  488. MessageBox.Show("医保结算ID不能为空!");
  489. return;
  490. }
  491. AdmType = dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["AdmType"].Value.ToString();
  492. string errMsg = "";
  493. string infno;
  494. JObject joData = new JObject();
  495. JObject joInparam = new JObject();
  496. joData.Add("omsgid", tb_MsgID.Text);
  497. joData.Add("psn_no", tb_PersonnelNO.Text);
  498. if (AdmType == "1")
  499. infno = "2207";
  500. else
  501. infno = "2304";
  502. joData.Add("oinfno", infno);
  503. joInparam.Add("data", joData);
  504. JObject joRtn = invoker.invokeCenterService("2601", JsonHelper.setCenterInpar("2601", joInparam.ToString()));
  505. //将中心返回的结果返回HIS 调用HIS服务进行保存
  506. if (JsonHelper.parseIrisRtnValue(joRtn, out errMsg) != 0)
  507. {
  508. MessageBox.Show("冲正失败:" + errMsg);
  509. return;
  510. }
  511. else
  512. {
  513. dynamic joTmp = new JObject();
  514. joTmp.admID = tb_RecordID.Text;
  515. joTmp.PersonalNO = tb_PersonnelNO.Text;
  516. joTmp.mdtrt_id = tb_MdtrtID.Text;
  517. joTmp.setl_id = tb_SettlementID.Text;
  518. if (mIS.NullifySettlement(ID, tb_SettlementID.Text, out errMsg) != 0)
  519. {
  520. errMsg = "中心取消结算成功但作废云HIS平台医保结算表信息失败,请联系管理员!" + errMsg;
  521. MessageBox.Show(errMsg);
  522. return;
  523. }
  524. else
  525. {
  526. MessageBox.Show("冲正成功!");
  527. }
  528. }
  529. }
  530. private void btnSignQuery_Click(object sender, EventArgs e)
  531. {
  532. string sqlStr = "SELECT Top 50 * FROM HB_MedInsuSignRecord WHERE Hospital_Dr=" + Global.inf.hospitalDr;
  533. sqlStr = sqlStr + " and Interface_Dr=" + Global.inf.interfaceDr;
  534. sqlStr = sqlStr + " and CreateTime>'" + dtSignBegin.Text + "'";
  535. sqlStr = sqlStr + " and CreateTime<'" + dtSignEnd.Text + "'";
  536. if (edtSignNo.Text != "")
  537. {
  538. sqlStr = sqlStr + " and SignNo='" + edtSignNo.Text + "'";
  539. }
  540. if (edtSignOpterNo.Text != "")
  541. {
  542. sqlStr = sqlStr + " and OperatorNO='" + edtSignOpterNo.Text + "'";
  543. }
  544. if (edtOpterName.Text != "")
  545. {
  546. sqlStr = sqlStr + " and OperatorName='" + edtOpterName.Text + "'";
  547. }
  548. sqlStr = sqlStr + " Order By CreateTime DESC ";
  549. JObject joSqlstr = new JObject();
  550. joSqlstr.Add("sqlStr", sqlStr);
  551. JArray jaParam = new JArray();
  552. jaParam.Add(joSqlstr);
  553. JObject joSettlQuery = new JObject();
  554. joSettlQuery.Add("params", jaParam);
  555. joSettlQuery.Add("code", "09010064");
  556. joSettlQuery.Add("queryType", "All");
  557. InvokeHelper invoker = new InvokeHelper();
  558. JObject joRtn = invoker.invokeInsuService(joSettlQuery.ToString(), "查询签到信息");
  559. try
  560. {
  561. if (joRtn["result"]["data"].ToString() == "[]")
  562. {
  563. MessageBox.Show("查询结果为空!");
  564. return;
  565. }
  566. DataTable dt = (DataTable)joRtn["result"]["data"].ToObject(typeof(DataTable));
  567. dgvSignQuery.DataSource = dt;
  568. }
  569. catch (Exception eX)
  570. {
  571. MessageBox.Show(eX.Message);
  572. }
  573. }
  574. private void btnCancelSign_Click(object sender, EventArgs e)
  575. {
  576. InvokeHelper invoker = new InvokeHelper();
  577. DataTable dt = (DataTable)dgvSignQuery.DataSource;
  578. string errorMessage = "";
  579. int a = dgvSignQuery.CurrentRow.Index;
  580. if (a <0)
  581. {
  582. MessageBox.Show("请先选中需要签退的签到记录信息!");
  583. return;
  584. }
  585. //组织签退入参
  586. JObject joCancleRegInpar = new JObject();
  587. joCancleRegInpar.Add("sign_no", dt.Rows[a]["SignNo"].ToString());
  588. joCancleRegInpar.Add("opter_no", dt.Rows[a]["OperatorNO"].ToString());
  589. JObject joRegInput = new JObject();
  590. joRegInput.Add("signOut", joCancleRegInpar);
  591. //取消挂号信息
  592. JObject jo9002Rtn = invoker.invokeCenterService("9002", JsonHelper.setCenterInpar("9002", joRegInput.ToString()));
  593. if (JsonHelper.parseCenterRtnValue(jo9002Rtn, out errorMessage) != 0)
  594. {
  595. MessageBox.Show("医保签退失败" + errorMessage);
  596. }
  597. else
  598. {
  599. MessageBox.Show("医保签退成功");
  600. }
  601. }
  602. private void Chk_DealNo_CheckedChanged(object sender, EventArgs e)
  603. {
  604. if (Chk_DealNo.Checked)
  605. {
  606. tb_DealNo.Visible = true;
  607. }
  608. else
  609. {
  610. tb_DealNo.Visible = false;
  611. }
  612. }
  613. private void btn_Query_Click(object sender, EventArgs e)
  614. {
  615. DataTable dtInteface = (DataTable)cbb_InterfaceDr.DataSource;
  616. int i = cbb_InterfaceDr.SelectedIndex;
  617. GridViewSetter grdSetter = new GridViewSetter();
  618. string sqlStr = " SELECT * FROM BS_MedInsuSettlement WHERE Hospital_Dr='" + Global.inf.hospitalDr + "'";
  619. sqlStr = sqlStr + " AND ValidFlag='1' And BillType='1'";
  620. sqlStr = sqlStr + " AND Interface_Dr= '" + Global.inf.interfaceDr + "'";
  621. sqlStr = sqlStr + " AND MedicalType='" + cbb_MedType.SelectedValue + "'";
  622. sqlStr = sqlStr + " AND SettlementDateTime>='" + dt_ST.Value.ToString("yyyy-MM-dd HH:mm:ss") + "'";
  623. sqlStr = sqlStr + " AND SettlementDateTime<='" + dt_ET.Value.ToString("yyyy-MM-dd HH:mm:ss") + "'";
  624. if (cbb_InterfaceDr.Text != "")
  625. {
  626. sqlStr = sqlStr + " And Interface_dr =" + dtInteface.Rows[i]["ID"].ToString();
  627. }
  628. if (cbb_InsuType.Text != "")
  629. {
  630. sqlStr = sqlStr + " And InsuranceType ='" + cbb_InsuType.SelectedValue + "'";
  631. }
  632. if (cbb_MedType.Text != "")
  633. {
  634. sqlStr = sqlStr + " And MedicalType =" + cbb_MedType.SelectedValue;
  635. }
  636. if (tb_Certno.Text != "")
  637. {
  638. sqlStr = sqlStr + " And CertificateNO =" + tb_Certno.Text;
  639. }
  640. if (tb_PsnNo.Text != "")
  641. {
  642. sqlStr = sqlStr + " And PersonnelNO =" + tb_PsnNo.Text;
  643. }
  644. if (tb_SettleID.Text != "")
  645. {
  646. sqlStr = sqlStr + " And SettlementID =" + tb_SettleID.Text;
  647. }
  648. JObject joSqlstr = new JObject();
  649. joSqlstr.Add("sqlStr", sqlStr);
  650. JArray jaParam = new JArray();
  651. jaParam.Add(joSqlstr);
  652. JObject joSettlQuery = new JObject();
  653. joSettlQuery.Add("params", jaParam);
  654. joSettlQuery.Add("code", "09010059");
  655. InvokeHelper invoker = new InvokeHelper();
  656. JObject joRtn = invoker.invokeInsuService(joSettlQuery.ToString(), "查询结算信息");
  657. //MessageBox.Show(joRtn.ToString());
  658. //MessageBox.Show(joRtn["result"]["data"].ToString());
  659. if (joRtn["result"]["data"].ToString() == "[]")
  660. {
  661. MessageBox.Show("查询结果为空!");
  662. return;
  663. }
  664. DataTable dt = (DataTable)joRtn["result"]["data"].ToObject(typeof(DataTable));
  665. dgv_SettleData.DataSource = dt;
  666. }
  667. private void dgv_SettleData_CellClick(object sender, DataGridViewCellEventArgs e)
  668. {
  669. if (dgv_SettleData.DataSource == null)
  670. {
  671. MessageBox.Show("请先查询结算表信息!");
  672. return;
  673. }
  674. if (string.IsNullOrEmpty(dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["ID"].Value.ToString()))
  675. {
  676. MessageBox.Show("医保结算记录ID不能为空!");
  677. return;
  678. }
  679. AdmType = dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["AdmType"].Value.ToString();
  680. MdtrtID = tb_MdtrtID.Text = dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["MdtrtID"].Value.ToString();
  681. ID = tb_RecordID.Text = dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["ID"].Value.ToString();
  682. SettlementID = tb_SettlementID.Text = dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["SettlementID"].Value.ToString();
  683. PersonnelNO = tb_PersonnelNO.Text = dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["PersonnelNO"].Value.ToString();
  684. msgid = tb_MsgID.Text = dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["msgid"].Value.ToString();
  685. PatientName = tb_PatientName.Text = dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["PatientName"].Value.ToString();
  686. Sumamt = tb_Sumamt.Text = dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["Sumamt"].Value.ToString();
  687. }
  688. private void uiButton7_Click(object sender, EventArgs e)
  689. {
  690. string errMsg = "";
  691. if (dgv_SettleData.DataSource == null)
  692. {
  693. MessageBox.Show("请先查询结算表信息!");
  694. return;
  695. }
  696. if (string.IsNullOrEmpty(dgv_SettleData.Rows[dgv_SettleData.CurrentRow.Index].Cells["ID"].Value.ToString()))
  697. {
  698. MessageBox.Show("医保结算记录ID不能为空!");
  699. return;
  700. }
  701. if (string.IsNullOrEmpty(tb_SettlementID.Text))
  702. {
  703. MessageBox.Show("医保结算ID不能为空!");
  704. return;
  705. }
  706. if (mIS.NullifySettlement(ID, tb_SettlementID.Text, out errMsg) != 0)
  707. {
  708. errMsg = "中心取消结算成功但作废云HIS平台医保结算表信息失败,请联系管理员!" + errMsg;
  709. MessageBox.Show(errMsg);
  710. return;
  711. }
  712. else
  713. {
  714. MessageBox.Show("冲正成功!");
  715. }
  716. }
  717. }
  718. }