IsvRegisterServiceImpl.java 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885
  1. package com.ywt.alipaympapi.service.impl;
  2. import com.ywt.alipaympapi.core.ConstantDef;
  3. import com.ywt.alipaympapi.core.utils.*;
  4. import com.ywt.alipaympapi.models.enums.*;
  5. import com.ywt.alipaympapi.models.union_reg.HospitalCustomInfo;
  6. import com.ywt.alipaympapi.service.IsvRegisterService;
  7. import com.ywt.alipaympapi.service.services.DoctorSrv;
  8. import com.ywt.alipaympapi.service.services.SystemSrv;
  9. import com.ywt.core.exception.AppMessageException;
  10. import com.ywt.gapi.Result;
  11. import com.ywt.gapi.ResultCode;
  12. import com.ywt.gapi.order.*;
  13. import com.ywt.gapi.system.Dept;
  14. import com.ywt.gapi.system.*;
  15. import com.ywt.gapi.taihe.register.*;
  16. import com.ywt.gapi.taihe.register.RegisteredOrder;
  17. import com.ywt.gapi.third.taihe.*;
  18. import com.ywt.gapi.user.*;
  19. import com.ywt.model.PageVO;
  20. import com.ywt.model.Pagination;
  21. import com.ywt.request.queue.QueryQueueListRequest;
  22. import com.ywt.request.register.*;
  23. import com.ywt.request.register.CancelOrderRequest;
  24. import com.ywt.response.queue.QueryQueueListResponse;
  25. import com.ywt.response.register.*;
  26. import lombok.extern.slf4j.Slf4j;
  27. import org.springframework.beans.factory.annotation.Autowired;
  28. import org.springframework.stereotype.Service;
  29. import redis.clients.jedis.JedisCommands;
  30. import java.time.LocalDate;
  31. import java.util.*;
  32. import java.util.stream.Collectors;
  33. @Service
  34. @Slf4j
  35. public class IsvRegisterServiceImpl implements IsvRegisterService {
  36. @Autowired
  37. private TaiheRegisterServiceGrpc.TaiheRegisterServiceBlockingStub taiheRegisterServiceBlockingStub;
  38. @Autowired
  39. private SystemServiceGrpc.SystemServiceBlockingStub systemServiceBlockingStub;
  40. @Autowired
  41. private TaiheServiceGrpc.TaiheServiceBlockingStub taiheServiceBlockingStub;
  42. @Autowired
  43. private SystemSrv systemSrv;
  44. @Autowired
  45. private JedisCommands jedisCommands;
  46. @Autowired
  47. private DoctorSrv doctorSrv;
  48. @Autowired
  49. private DoctorServiceGrpc.DoctorServiceBlockingStub doctorServiceBlockingStub;
  50. @Autowired
  51. private OrderServiceGrpc.OrderServiceBlockingStub orderServiceBlockingStub;
  52. @Override
  53. public List<QueryDepartmentListResponseData> queryDepartmentList(QueryDepartmentListRequest request) throws Exception {
  54. log.info("IsvRegisterServiceImpl#queryDepartmentList--QueryDepartmentListRequest:{}", JsonSerializer.toJson(request));
  55. int hospitalId = BizUtil.getCurrentHospitalId();
  56. String hospitalDistrictId = request.getHospitalDistrictId();
  57. int subHospitalId = 0;
  58. if (!Checker.isNone(hospitalDistrictId)) {
  59. subHospitalId = Integer.parseInt(hospitalDistrictId);
  60. }
  61. List<HospitalDept> deptList = null;
  62. HospitalDeptListRequest req = HospitalDeptListRequest.newBuilder()
  63. .setHospitalId(hospitalId)
  64. .setSubHospitalId(subHospitalId)
  65. .build();
  66. HospitalDeptListResponse res = systemServiceBlockingStub.getHospitalDeptList(req);
  67. if (res.getResult().getCode() != ResultCode.SUCCEED) {
  68. throw new AppMessageException(res.getResult().getInfo());
  69. }
  70. Result result = res.getResult();
  71. if (result.getCode() == ResultCode.SUCCEED) {
  72. deptList = res.getHospitalDeptListList();
  73. }
  74. if (deptList == null) {
  75. throw new AppMessageException("科室不存在");
  76. }
  77. String parentId = request.getParentId();
  78. int deptParentId = 0;
  79. if (!Checker.isNone(parentId)) {
  80. deptParentId = Integer.parseInt(parentId);
  81. }
  82. List<QueryDepartmentListResponseData> lst = new LinkedList<>();
  83. for (HospitalDept d : deptList) {
  84. if (deptParentId == 0) {
  85. QueryDepartmentListResponseData map = new QueryDepartmentListResponseData();
  86. map.setDepartmentId(d.getDeptId() + "");
  87. map.setDepartmentCode(d.getDeptCode());
  88. map.setName(d.getDeptName());
  89. map.setHasChildren(d.getDeptListList().size() > 0);
  90. map.setRemain(0);
  91. //院区id
  92. map.setHospitalDistrictId(hospitalDistrictId);
  93. map.setHospitalId(hospitalId);
  94. lst.add(map);
  95. } else {
  96. if (deptParentId == d.getDeptId()) {
  97. for (Dept secDept : d.getDeptListList()) {
  98. QueryDepartmentListResponseData map = new QueryDepartmentListResponseData();
  99. map.setDepartmentId(secDept.getDeptId() + "");
  100. map.setDepartmentCode(secDept.getDeptCode());
  101. map.setName(secDept.getDeptName());
  102. map.setHasChildren(false);
  103. map.setRemain(0);
  104. map.setHospitalDistrictId(hospitalDistrictId);
  105. map.setHospitalId(hospitalId);
  106. lst.add(map);
  107. }
  108. }
  109. }
  110. }
  111. return lst;
  112. }
  113. @Override
  114. public List<QueryDepOrderSourceRemainResponseData> queryDepOrderSourceRemain(QueryDepOrderSourceRemainRequest request) throws Exception {
  115. int hospitalId = BizUtil.getCurrentHospitalId();
  116. String deptCode = Checker.getStringValue(request.getDepCode());
  117. String doctorCode = "";
  118. String serviceDate = "";
  119. String serviceCode = "";
  120. Map<String, Object> dataMap = getScheduleListCommon(hospitalId, deptCode, doctorCode, serviceCode, serviceDate, -1, -1);
  121. List<QueryDepOrderSourceRemainResponseData> dataList = new ArrayList<>();
  122. if (!Checker.isNone(dataMap.get("hasSchedulingList"))) {
  123. dataList = (List<QueryDepOrderSourceRemainResponseData>) dataMap.get("hasSchedulingList");
  124. }
  125. return dataList;
  126. }
  127. @Override
  128. public PageVO<QueryDepDoctorListResponseData> queryDepDoctorList(QueryDepDoctorListRequest request) throws Exception {
  129. int hospitalId = BizUtil.getCurrentHospitalId();
  130. String deptCode = Checker.getStringValue(request.getDepCode());
  131. String doctorCode = Checker.getStringValue(request.getDoctorCode());
  132. String serviceDate = Checker.getStringValue(request.getDate());
  133. String serviceCode = Checker.getStringValue(request.getServiceCode());
  134. Map<String, Object> dataMap = getScheduleListCommon(hospitalId, deptCode, doctorCode, serviceCode, serviceDate, -1, -1);
  135. List<QueryDepDoctorListResponseData> dataList = new ArrayList<>();
  136. if (!Checker.isNone(dataMap.get("groupByDoctorList"))) {
  137. dataList = (List<QueryDepDoctorListResponseData>) dataMap.get("groupByDoctorList");
  138. }
  139. Pagination pagination = new Pagination(1, dataList.size(), dataList.size());
  140. PageVO<QueryDepDoctorListResponseData> res = new PageVO<>(pagination, dataList);
  141. return res;
  142. }
  143. /**
  144. * 原来的获取科室排班列表方法抽离
  145. *
  146. * @param startOffset 开始日期 offset, 值取 0 表示当天;
  147. * @param endOffset 结束日期 offset, 值取 0 表示当天;
  148. * @param serviceDate 指定时间,具体某一天:yyyy-MM-dd
  149. * <p>
  150. * startOffset 和 endOffset 其中一个为负值时,表示不指定日期范围,默认按照“太和查未来 8 天,不包括当天;白云查未来 6 天,包括当天”的规则查询。
  151. * 都不为负值时,按照传入的 offset 计算开始结束日期。
  152. */
  153. private Map<String, Object> getScheduleListCommon(int hospitalId, String deptCode, String doctorCode,
  154. String serviceCode, String serviceDate, int startOffset, int endOffset) throws AppMessageException {
  155. String redisKeyPattern = "ALI_SCHEDULE_LIST_%s_%s_%d_%s_%s";
  156. String key = String.format(redisKeyPattern, deptCode, doctorCode, hospitalId, serviceCode, serviceDate);
  157. if (startOffset >= 0 && endOffset >= 0) {
  158. redisKeyPattern = "ALI_SCHEDULE_LIST_%s_%s_%d_%s_%s_%d_%d";
  159. key = String.format(redisKeyPattern, deptCode, doctorCode, hospitalId, serviceCode, serviceDate, startOffset, endOffset);
  160. }
  161. String value = jedisCommands.get(key);
  162. if (!StringHelper.isNullOrWhiteSpace(value)) {
  163. Map<String, Object> cacheMap = JsonSerializer.from(value, Map.class);
  164. if (cacheMap != null) {
  165. return cacheMap;
  166. }
  167. }
  168. List<Dept> deptList = systemSrv.getDeptListByHospitalId(hospitalId);
  169. if (deptList == null || deptList.size() == 0) {
  170. throw new AppMessageException(String.format("无法获取科室数据(%d)", hospitalId));
  171. }
  172. List<Dept> tmpDeptList = deptList.stream().filter(p -> p.getDeptCode().equals(deptCode)).collect(Collectors.toList());
  173. if (tmpDeptList.size() == 0) {
  174. log.error(String.format("deptCode 不存在(%d-%s-%s)", hospitalId, deptCode, doctorCode));
  175. throw new AppMessageException("暂无出诊信息");
  176. }
  177. Dept secDept = tmpDeptList.get(0);
  178. tmpDeptList = deptList.stream().filter(p -> p.getDeptId() == secDept.getParentId()).collect(Collectors.toList());
  179. if (tmpDeptList.size() == 0) {
  180. log.error(String.format("deptCode 不合法(%d-%s-%s)", hospitalId, deptCode, doctorCode));
  181. throw new AppMessageException("暂无出诊信息");
  182. }
  183. Map<String, Object> map = new HashMap<>();
  184. map.put("hospitalId", hospitalId);
  185. map.put("hospitalName", BizUtil.getHospitalNameByIdSimply(hospitalId));
  186. map.put("deptCode", deptCode);
  187. map.put("deptName", secDept.getDeptName());
  188. // 批量日期查询 HIS 接口
  189. boolean isTaihe = hospitalId == ConstantDef.TAIHE_HOSPITAL_ID;
  190. if (startOffset < 0 || endOffset < 0) {
  191. startOffset = isTaihe ? 1 : 0;
  192. endOffset = isTaihe ? 9 : 7;
  193. }
  194. Calendar calendar = Calendar.getInstance();
  195. if (startOffset > 0) {
  196. calendar.add(Calendar.DATE, startOffset);
  197. }
  198. String startDate = DateUtil.formatDate(calendar.getTime(), "yyyy-MM-dd"); //日期
  199. calendar = Calendar.getInstance();
  200. calendar.add(Calendar.DATE, endOffset);
  201. String endDate = DateUtil.formatDate(calendar.getTime(), "yyyy-MM-dd"); //日期
  202. // 如果传了具体的日期,那之查这一天的
  203. if (!Checker.isNone(serviceDate)) {
  204. startDate = serviceDate;
  205. endDate = serviceDate;
  206. }
  207. GetScheduleListRequest getScheduleListRequest = GetScheduleListRequest.newBuilder()
  208. .setDeptCode(deptCode)
  209. .setDoctorCode(doctorCode)
  210. .setServiceDate(startDate)
  211. .setServiceEndDate(endDate)
  212. .setHospitalId(hospitalId)
  213. .setServiceCode(serviceCode)
  214. .build();
  215. GetScheduleListResponse getScheduleListResponse = taiheServiceBlockingStub.getScheduleList(getScheduleListRequest);
  216. List<Schedule> scheduleList;
  217. if (getScheduleListResponse.getCode() == ResultCode.SUCCEED_VALUE) {
  218. scheduleList = getScheduleListResponse.getSchedulesList();
  219. } else {
  220. log.error("NfyyByfyRegisterController#getConvertedScheduleList(): HIS 获取排班接口出错:{}", getScheduleListResponse.getMsg());
  221. scheduleList = new LinkedList<>();
  222. }
  223. List<QueryDepDoctorListResponseData> groupByDoctorList = convertToScheduleListGroupByDoctor(scheduleList, hospitalId);
  224. map.put("groupByDoctorList", groupByDoctorList);
  225. List<QueryDepOrderSourceRemainResponseData> hasSchedulingList = checkHasSchedulingGroupByDate(scheduleList, startOffset, endOffset);
  226. map.put("hasSchedulingList", hasSchedulingList);
  227. jedisCommands.set(key, JsonSerializer.toJson(map));
  228. jedisCommands.expire(key, 3 * 60);
  229. return map;
  230. }
  231. /**
  232. * 排班记录转为List(按医生分组)
  233. */
  234. private List<QueryDepDoctorListResponseData> convertToScheduleListGroupByDoctor(List<Schedule> scheduleList, int hospitalId) {
  235. Map<Integer, QueryDepDoctorListResponseData> doctorSet = new HashMap<>();
  236. GetDoctorByHisCodeResponse getDoctorByHisCodeResponse;
  237. String avatar;
  238. int doctorId;
  239. for (Schedule s : scheduleList) {
  240. doctorId = 0;
  241. avatar = ConstantDef.DOCTOR_AVATAR_URL;
  242. getDoctorByHisCodeResponse = getDoctorByHisCode(s.getDoctorCode(), hospitalId);
  243. if (getDoctorByHisCodeResponse.getResult().getCode() == ResultCode.SUCCEED) {
  244. if (!StringHelper.isNullOrWhiteSpace(getDoctorByHisCodeResponse.getAvatar())) {
  245. avatar = getDoctorByHisCodeResponse.getAvatar();
  246. }
  247. doctorId = getDoctorByHisCodeResponse.getDoctorId();
  248. }
  249. if (doctorId <= 0) {
  250. continue;
  251. }
  252. if (s.getScheduleStatus() != 1) {
  253. continue;
  254. }
  255. QueryDepDoctorListResponseData item = doctorSet.get(doctorId);
  256. if (Checker.isNone(item)) {
  257. item = new QueryDepDoctorListResponseData();
  258. item.setDoctorId(doctorId + "");
  259. item.setHospitalId(hospitalId);
  260. item.setName(s.getDoctorName());
  261. item.setDesc(s.getDoctorSpec());
  262. item.setPicUrl(avatar);
  263. // 这个数后面再统计
  264. item.setRemain(0);
  265. // 目前系统里面并没有专家号和普通号的区分,目前统一用普通号
  266. item.setType("normal");
  267. item.setLevel(s.getDoctorTitle());
  268. item.setDoctorCode(s.getDoctorCode());
  269. item.setDeptCode(s.getDeptCode());
  270. item.setDistrictName(HospitalNameEnum.getDisplayName(hospitalId));
  271. }
  272. List<OrderSource> orderSourceList = item.getOrderSources();
  273. if (Checker.isNone(orderSourceList)) {
  274. orderSourceList = new ArrayList<>();
  275. }
  276. OrderSource os = new OrderSource();
  277. //号源id
  278. os.setOrderSourceId(s.getScheduleItemCode());
  279. //号源开始时间段
  280. os.setStartTime("");
  281. //号源截止时间段
  282. os.setEndTime("");
  283. //挂号费用
  284. os.setCost(String.format("%.2f", s.getFee() / 100d));
  285. // os.setCost(BizUtil.cent2Yuan(s.getFee()) + "");
  286. //剩余数量
  287. os.setRemain(Checker.getIntegerValue(s.getAvailableLeftNum()));
  288. //true:确认挂号时支付,false:就诊时支付
  289. os.setOnlinePay(true);
  290. os.setDatePeriod(s.getDatePeriod());
  291. os.setDatePeriodName(s.getDatePeriodName());
  292. os.setServiceDate(s.getServiceDate());
  293. orderSourceList.add(os);
  294. item.setOrderSources(orderSourceList);
  295. doctorSet.put(doctorId, item);
  296. }
  297. List<QueryDepDoctorListResponseData> dataList = new ArrayList<>();
  298. Set<Integer> doctorIdSet = doctorSet.keySet();
  299. for (Integer doctorIdInt : doctorIdSet) {
  300. QueryDepDoctorListResponseData data = doctorSet.get(doctorIdInt);
  301. List<OrderSource> sourceList = data.getOrderSources();
  302. if (!Checker.isNone(sourceList)) {
  303. int remain = sourceList.stream().mapToInt(OrderSource::getRemain).sum();
  304. data.setRemain(remain);
  305. }
  306. dataList.add(data);
  307. }
  308. // 过滤掉没有号的医生数据
  309. dataList = dataList.stream().filter(p -> p.getRemain() > 0).collect(Collectors.toList());
  310. return dataList;
  311. }
  312. /**
  313. * 排班记录转为List(按日期判断是否有医生排班)
  314. */
  315. private List<QueryDepOrderSourceRemainResponseData> checkHasSchedulingGroupByDate(List<Schedule> scheduleList, int startOffset, int endOffset) {
  316. List<QueryDepOrderSourceRemainResponseData> remainResponseList = new ArrayList<>();
  317. if (endOffset > startOffset && !Checker.isNone(scheduleList)) {
  318. for (int offset = startOffset; offset < endOffset; offset++) {
  319. Calendar c = Calendar.getInstance();
  320. if (offset > 0) {
  321. c.add(Calendar.DATE, offset);
  322. }
  323. String strDate = DateUtil.formatDate(c.getTime(), "yyyy-MM-dd"); //日期
  324. List<Schedule> itemScheduleList = scheduleList.stream().filter(s -> strDate.equals(s.getServiceDate())).collect(Collectors.toList());
  325. QueryDepOrderSourceRemainResponseData data = new QueryDepOrderSourceRemainResponseData();
  326. int remain = 0; //当期日期是否有排班
  327. if (!Checker.isNone(itemScheduleList)) {
  328. remain = itemScheduleList.stream().mapToInt(Schedule::getAvailableLeftNum).sum();
  329. }
  330. data.setDate(strDate);
  331. data.setRemain(remain);
  332. remainResponseList.add(data);
  333. }
  334. }
  335. return remainResponseList;
  336. }
  337. private GetDoctorByHisCodeResponse getDoctorByHisCode(String doctorCode, int hospitalId) {
  338. GetDoctorByHisCodeRequest getDoctorByHisCodeRequest = GetDoctorByHisCodeRequest.newBuilder()
  339. .setHospitalId(hospitalId)
  340. .setHisCode(doctorCode)
  341. .build();
  342. return doctorServiceBlockingStub.getDoctorByHisCode(getDoctorByHisCodeRequest);
  343. }
  344. @Override
  345. public List<QueryDoctorOrderSourceListResponseData> queryDoctorOrderSourceList(QueryDoctorOrderSourceListRequest request) throws Exception {
  346. return null;
  347. }
  348. // 挂号确认
  349. @Override
  350. public OrderConfirmResponseData orderConfirm(OrderConfirmRequest request) throws Exception {
  351. log.info("IsvRegisterServiceImpl#orderConfirm--OrderConfirmRequest:{}", JsonSerializer.toJson(request));
  352. int userId = ContextHelper.getCurrentUserIdWrapped();
  353. int hospitalId = BizUtil.getCurrentHospitalId();
  354. String deptCode = Checker.getStringValue(request.getDeptCode());
  355. String deptName = Checker.getStringValue(request.getDeptName());
  356. String doctorCode = Checker.getStringValue(request.getDoctorCode());
  357. String doctorName = Checker.getStringValue(request.getDoctorName());
  358. double registeredFee = request.getRegisteredFee();
  359. double medicalFee = request.getMedicalFee();
  360. String registeredDate = Checker.getStringValue(request.getRegisteredDate());
  361. int period = request.getPeriod();
  362. String startTime = Checker.getStringValue(request.getStartTime());
  363. String endTime = Checker.getStringValue(request.getEndTime());
  364. int medicalCardId = request.getMedicalCardId();
  365. String scheduleItemCode = Checker.getStringValue(request.getScheduleItemCode());
  366. int deptId = request.getDeptId();
  367. String lockQueueNo = Checker.getStringValue(request.getLockQueueNo());
  368. String availableNumStr = Checker.getStringValue(request.getAvailableNumStr());
  369. if (hospitalId < 1) {
  370. throw new AppMessageException("医院不存在");
  371. }
  372. if (StringHelper.isNullOrWhiteSpace(deptCode) || StringHelper.isNullOrWhiteSpace(deptName)) {
  373. throw new AppMessageException("科室不存在");
  374. }
  375. if (StringHelper.isNullOrWhiteSpace(doctorCode) || StringHelper.isNullOrWhiteSpace(doctorName)) {
  376. throw new AppMessageException("医生不存在");
  377. }
  378. if (StringHelper.isNullOrWhiteSpace(registeredDate)) {
  379. throw new AppMessageException("请选择挂号日期");
  380. }
  381. Date date = DateUtil.parseDate(registeredDate, "yyyy-MM-dd");
  382. if (date == null) {
  383. throw new AppMessageException("预约日期格式不正确");
  384. }
  385. DatePeriodEnum datePeriodEnum = DatePeriodEnum.valueOf(period);
  386. if (datePeriodEnum == null) {
  387. throw new AppMessageException("预约时段不存在");
  388. }
  389. if (StringHelper.isNullOrWhiteSpace(startTime)) {
  390. throw new AppMessageException("预约开始时间不存在");
  391. }
  392. if (StringHelper.isNullOrWhiteSpace(endTime)) {
  393. throw new AppMessageException("预约结束时间不存在");
  394. }
  395. if (medicalCardId < 1) {
  396. throw new AppMessageException("请选择就诊人");
  397. }
  398. if (StringHelper.isNullOrWhiteSpace(scheduleItemCode)) {
  399. throw new AppMessageException("门诊排班项记录标识不能为空");
  400. }
  401. if (userId == 0) {
  402. throw new AppMessageException("请先登录");
  403. }
  404. int registeredFeeInt = (int) (registeredFee * 100);
  405. int medicalFeeInt = (int) (medicalFee * 100);
  406. int total = (int) ((registeredFee + medicalFee) * 100);
  407. int paymentChannel = total > 0
  408. ? PaymentChannelEnum.ALI_PAY.getValue()
  409. : PaymentChannelEnum.FREE.getValue();
  410. int source;
  411. int terminal = BizUtil.getCurrentTerminalWrapped();
  412. switch (TerminalEnum.valueOf(terminal)) {
  413. case TAI_HE_OFFICIAL:
  414. source = TerminalEnum.TAI_HE_OFFICIAL.getValue();
  415. break;
  416. case NFYYBYFY_WXAPP:
  417. source = TerminalEnum.NFYYBYFY_WXAPP.getValue();
  418. break;
  419. case NFYYBYFY_ALIPAY_MP:
  420. source = TerminalEnum.NFYYBYFY_ALIPAY_MP.getValue();
  421. break;
  422. default:
  423. source = TerminalEnum.TaiheWxOfficial.getValue();
  424. break;
  425. }
  426. CreateRegisteredRequest req = CreateRegisteredRequest.newBuilder()
  427. .setDeptCode(deptCode)
  428. .setDeptName(deptName)
  429. .setDoctorCode(doctorCode)
  430. .setDoctorName(doctorName)
  431. .setTotal(total)
  432. .setRegisteredFee(registeredFeeInt)
  433. .setMedicalFee(medicalFeeInt)
  434. .setRegisteredDate(date.getTime())
  435. .setStartTime(startTime)
  436. .setEndTime(endTime)
  437. .setUserId(userId)
  438. .setMedicalCardId(medicalCardId)
  439. .setScheduleItemCode(scheduleItemCode)
  440. .setPaymentChannel(paymentChannel)
  441. .setSource(source)
  442. .setPeriod(period)
  443. .setDoctorTitle("")
  444. .setDeptId(Checker.getIntegerValue(deptId))
  445. .setLockQueueNo(lockQueueNo)
  446. .setAvailableNumStr(availableNumStr)
  447. .setHospitalId(hospitalId)
  448. .build();
  449. CreateRegisteredResponse res = taiheRegisterServiceBlockingStub.createRegistered(req);
  450. if (res.getCode() != ResultCode.SUCCEED_VALUE) {
  451. //预约失败
  452. throw new AppMessageException(res.getMsg());
  453. }
  454. if (!systemSrv.checkIsNetDept(deptCode, hospitalId)) {
  455. //非互联网医院名医诊区挂号
  456. OrderConfirmResponseData responseData = new OrderConfirmResponseData();
  457. responseData.setOrderId(res.getOrderId() + "");
  458. responseData.setOrderType(res.getOrderType());
  459. responseData.setAmount(String.format("%.2f", (registeredFee + medicalFee)));
  460. responseData.setStatus(res.getStatus());
  461. return responseData;
  462. }
  463. return null;
  464. }
  465. // 预约单详情
  466. @Override
  467. public QueryOrderDetailResponseData queryOrderDetail(QueryOrderDetailRequest request) throws Exception {
  468. if (Checker.isNone(request.getOrderId())) {
  469. throw new AppMessageException("没有挂号详情");
  470. }
  471. int orderId = Integer.parseInt(request.getOrderId());
  472. int userId = ContextHelper.getCurrentUserIdWrapped();
  473. int pageIndex = 1;
  474. int pageSize = 1;
  475. GetRegisteredOrderListRequest req = GetRegisteredOrderListRequest.newBuilder()
  476. .setPageIndex(pageIndex)
  477. .setPageSize(pageSize)
  478. .setUserId(userId)
  479. .setOrderId(orderId)
  480. .build();
  481. GetRegisteredOrderListResponse res = orderServiceBlockingStub.getRegisteredOrderList(req);
  482. if (res.getResult().getCode() == ResultCode.SUCCEED) {
  483. if (!Checker.isNone(res.getOrdersList())) {
  484. com.ywt.gapi.order.RegisteredOrder item = res.getOrdersList().get(0);
  485. String deptCode = item.getDeptCode();
  486. double amount = item.getTotal() / 100d;
  487. QueryOrderDetailResponseData data = new QueryOrderDetailResponseData();
  488. data.setOrderId(Integer.toString(orderId));
  489. data.setOrderNo(item.getOrderNo());
  490. data.setUserName(item.getPatientName());
  491. data.setDoctorName(item.getDoctorName());
  492. data.setDepName(item.getDeptName());
  493. data.setDeptCode(item.getDeptCode());
  494. data.setDistrictName(item.getHospitalName());
  495. data.setHisPatientId(item.getHisPatientId());
  496. String amountStr = String.format("%.2f", amount);
  497. data.setAmount(amountStr);
  498. data.setTimeRange(item.getStartTime() + "~" + item.getEndTime());
  499. data.setQrCode("");
  500. // 预约单状态 (0-待支付, 1-预约成功, 2-叫号中,7-已就诊,8-预期未就诊,9-取消预约)
  501. int orderStatus = item.getRegisteredStatus();
  502. String statusName = "";
  503. if ((item.getRegisteredStatus() & RegisteredStatusEnum.Cancel.getValue()) == RegisteredStatusEnum.Cancel.getValue()
  504. ) {
  505. statusName = "取消预约";
  506. orderStatus = 9;
  507. } else if (item.getRegisteredStatus() == RegisteredStatusEnum.Refunded.getValue()) {
  508. statusName = "已退款";
  509. orderStatus = 9;
  510. } else if (item.getPaymentStatus() == PaymentStatusEnum.Pending.getValue()) {
  511. statusName = "待支付";
  512. orderStatus = 0;
  513. } else if (item.getPaymentStatus() == PaymentStatusEnum.Success.getValue()) {
  514. GetCommonOrderListRequest reqTwo = GetCommonOrderListRequest.newBuilder()
  515. .setPageIndex(1)
  516. .setPageSize(999)
  517. .setUserId(userId)
  518. .build();
  519. GetCommonOrderListResponse resTwo = taiheRegisterServiceBlockingStub.getCommonOrderList(reqTwo);
  520. if (resTwo.getCode() == ResultCode.SUCCEED_VALUE) {
  521. for (CommonOrder itemTwo : resTwo.getOrderList()) {
  522. if (orderId == itemTwo.getOrderId()) {
  523. statusName = itemTwo.getStatusName();
  524. orderStatus = getStatus(itemTwo.getStatusName());
  525. }
  526. }
  527. }
  528. }
  529. data.setStatus(orderStatus);
  530. data.setStatusStr(statusName);
  531. data.setSystemTime(DateUtil.convertTimestampToDateString(item.getCreateTime()));
  532. data.setCreateTime(DateUtil.convertTimestampToDateString(item.getCreateTime()));
  533. data.setCancelTime("");
  534. data.setLevel("");
  535. data.setPayType("");
  536. data.setAge("");
  537. data.setExpireTime("");
  538. data.setQueueNum("");
  539. data.setSex(SexEnum.getSexDisplayName(Checker.getIntegerValue(item.getSex())));
  540. data.setStartTime(Checker.getStringValue(item.getStartTime()));
  541. data.setEndTime(Checker.getStringValue(item.getEndTime()));
  542. data.setRegisteredDate(DateUtil.convertTimestampToDateString(item.getRegisteredDate(), "yyyy年MM月dd日"));
  543. data.setCardNum(Checker.getStringValue(item.getMedicalCardNo()));
  544. return data;
  545. }
  546. }
  547. throw new AppMessageException("没有挂号详情");
  548. }
  549. @Override
  550. public PageVO<QueryOrderListResponseData> queryOrderList(QueryOrderListRequest request) throws Exception {
  551. if (request.getPageIndex() < 1) {
  552. throw new AppMessageException("页码错误");
  553. }
  554. if (request.getPageSize() < 1) {
  555. throw new AppMessageException("页大小错误");
  556. }
  557. List<QueryOrderListResponseData> list = new ArrayList<>();
  558. int total = 0;
  559. int userId = ContextHelper.getCurrentUserIdWrapped();
  560. GetCommonOrderListRequest req = GetCommonOrderListRequest.newBuilder()
  561. .setPageIndex(request.getPageIndex())
  562. .setPageSize(request.getPageSize())
  563. .setUserId(userId)
  564. .build();
  565. GetCommonOrderListResponse res = taiheRegisterServiceBlockingStub.getCommonOrderList(req);
  566. if (res.getCode() == ResultCode.SUCCEED_VALUE) {
  567. total = res.getOrderList().size();
  568. for (CommonOrder item : res.getOrderList()) {
  569. String deptCode = item.getDeptCode();
  570. double amount = item.getAmount() / 100d;
  571. QueryOrderListResponseData data = new QueryOrderListResponseData();
  572. int orderId = Checker.getIntegerValue(item.getOrderId());
  573. data.setOrderId(Integer.toString(orderId));
  574. data.setOrderNo(item.getOrderNo());
  575. data.setUserName(item.getPatientName());
  576. data.setDoctorName(item.getDoctorName());
  577. data.setDepName(item.getDeptName());
  578. data.setDeptCode(item.getDeptCode());
  579. data.setDistrictName(item.getHospitalName());
  580. data.setTimeRange(item.getStartTime() + "~" + item.getEndTime());
  581. String amountStr = String.format("%.2f", amount);
  582. data.setAmount(amountStr);
  583. data.setStatus(getStatus(item.getStatusName()));
  584. data.setCreateTime(Checker.getStringValue(item.getStartTime()));
  585. data.setEndTime(Checker.getStringValue(item.getEndTime()));
  586. list.add(data);
  587. }
  588. }
  589. Pagination pagination = new Pagination(request.getPageIndex(), request.getPageSize(), total);
  590. PageVO<QueryOrderListResponseData> resp = new PageVO<>(pagination, list);
  591. return resp;
  592. }
  593. @Override
  594. public CancelOrderResponseData cancelOrder(CancelOrderRequest request) throws Exception {
  595. CancelOrderResponseData responseData = new CancelOrderResponseData();
  596. String orderIdStr = request.getOrderId();
  597. if (Checker.isNone(orderIdStr) || Integer.parseInt(orderIdStr) <= 0) {
  598. throw new AppMessageException("订单不存在");
  599. }
  600. int orderId = Integer.parseInt(orderIdStr);
  601. int userId = ContextHelper.getCurrentUserIdWrapped();
  602. int hospitalId = BizUtil.getCurrentHospitalId();
  603. CancelRegisteredRequest req = CancelRegisteredRequest.newBuilder()
  604. .setOrderId(orderId)
  605. .setUserId(userId)
  606. .setHospitalId(hospitalId)
  607. .build();
  608. CancelRegisteredResponse res = taiheRegisterServiceBlockingStub.cancelRegistered(req);
  609. responseData.setIsSuccess(false);
  610. if (res.getCode() == ResultCode.SUCCEED_VALUE) {
  611. responseData.setIsSuccess(true);
  612. }
  613. return responseData;
  614. }
  615. @Override
  616. public List<QueryHospitalDistrictListResponseData> queryHospitalDistrictList(QueryHospitalDistrictListRequest
  617. request) throws Exception {
  618. int hospitalId = BizUtil.getCurrentHospitalId();
  619. List<Integer> hospitalIds = new ArrayList<>();
  620. hospitalIds.add(hospitalId);
  621. GetHospitalByHospitalIdsRequest req = GetHospitalByHospitalIdsRequest.newBuilder()
  622. .addAllHospitalId(hospitalIds)
  623. .build();
  624. GetHospitalByHospitalIdsResponse res = systemServiceBlockingStub.getHospitalByHospitalIds(req);
  625. if (res.getCode() != ResultCode.SUCCEED.getNumber()) {
  626. throw new AppMessageException(res.getMessage());
  627. }
  628. List<Map<String, Object>> list = new LinkedList<>();
  629. List<Hospital> hospitalList = res.getHospitalList();
  630. List<Hospital> subHospList = hospitalList.stream().filter(h -> Checker.getIntegerValue(h.getParentId()) > 0).collect(Collectors.toList());
  631. Set<Integer> parentHospitalIds = subHospList.stream().map(h -> Checker.getIntegerValue(h.getParentId())).collect(Collectors.toSet());
  632. List<Hospital> filteredParentHospitalList = hospitalList.stream().filter(h -> Checker.getIntegerValue(h.getParentId()) == 0 && !parentHospitalIds.contains(h.getHospitalId())).collect(Collectors.toList());
  633. List<QueryHospitalDistrictListResponseData> responseDataList = new ArrayList<>();
  634. for (Hospital h : subHospList) {
  635. QueryHospitalDistrictListResponseData item = new QueryHospitalDistrictListResponseData();
  636. item.setHospitalDistrictId(h.getHospitalId() + "");
  637. item.setName(h.getHospitalName());
  638. item.setAddress(h.getAddress());
  639. item.setDescription("");
  640. Map<String, String> map = new HashMap<>();
  641. map.put("hospitalId", h.getParentId() + "");
  642. map.put("subHospitalId", h.getHospitalId() + "");
  643. map.put("hospitalLogo", h.getLogo());
  644. HospitalCustomInfo p = BizUtil.getHospitalCustomInfo(h.getHospitalId());
  645. if (p != null) {
  646. map.put("alias", p.getAlias());
  647. map.put("areaName", p.getAreaName());
  648. }
  649. item.setExtInfo(map);
  650. responseDataList.add(item);
  651. }
  652. for (Hospital h : filteredParentHospitalList) {
  653. QueryHospitalDistrictListResponseData item = new QueryHospitalDistrictListResponseData();
  654. item.setHospitalDistrictId(h.getHospitalId() + "");
  655. item.setName(h.getHospitalName());
  656. item.setAddress(h.getAddress());
  657. item.setDescription("");
  658. Map<String, String> map = new HashMap<>();
  659. map.put("hospitalId", h.getHospitalId() + "");
  660. map.put("subHospitalId", "0");
  661. map.put("hospitalLogo", h.getLogo());
  662. HospitalCustomInfo p = BizUtil.getHospitalCustomInfo(h.getHospitalId());
  663. if (p != null) {
  664. map.put("alias", p.getAlias());
  665. map.put("areaName", p.getAreaName());
  666. }
  667. item.setExtInfo(map);
  668. responseDataList.add(item);
  669. }
  670. return responseDataList;
  671. }
  672. @Override
  673. public List<QueryQueueListResponse> queryQueueList(QueryQueueListRequest request) throws Exception {
  674. log.info("IsvRegisterServiceImpl#queryQueueList--QueryQueueListRequest:{}", JsonSerializer.toJson(request));
  675. int hospitalId = BizUtil.getCurrentHospitalId();
  676. //用户唯一识别号
  677. int userId = ContextHelper.getCurrentUserIdWrapped();
  678. List<QueryQueueListResponse> list = new LinkedList<>();
  679. com.ywt.gapi.taihe.register.GetQueueListRequest req = com.ywt.gapi.taihe.register.GetQueueListRequest.newBuilder()
  680. .setUserId(userId)
  681. .setHospitalId(hospitalId)
  682. .build();
  683. com.ywt.gapi.taihe.register.GetQueueListResponse res = taiheRegisterServiceBlockingStub.getQueueList(req);
  684. if (res.getCode() != ResultCode.SUCCEED_VALUE) {
  685. throw new AppMessageException(res.getMsg());
  686. }
  687. List<com.ywt.gapi.taihe.register.RegisteredOrder> queueList = res.getOrderList();
  688. LocalDate now = LocalDate.now();
  689. for (com.ywt.gapi.taihe.register.RegisteredOrder order : queueList) {
  690. QueryQueueListResponse reportItem = new QueryQueueListResponse();
  691. int cancel = 0; //是否显示退号按钮,1-是,0-否
  692. LocalDate regDate = DateUtil.convertToLocalDate(new Date(order.getRegisteredDate()));//预约日期
  693. if (now.isBefore(regDate)) {
  694. cancel = 1;
  695. }
  696. String statusName = order.getStatusName();
  697. int status = order.getStatus();
  698. if (order.getStatus() == 1) {
  699. //已预约
  700. statusName = "未取号";
  701. if (DateUtil.convertTimestampToDateString(order.getRegisteredDate(), "yyyy-MM-dd").equals(
  702. DateUtil.formatDate(new Date(), "yyyy-MM-dd"))) {
  703. } else {
  704. status = 0;
  705. }
  706. }
  707. reportItem.setCardNum(order.getMedicalCardId() + "");//就诊卡卡号
  708. reportItem.setName(order.getPatientName());//就诊人姓名
  709. reportItem.setSex(SexEnum.getSexDisplayName(order.getSex()));//性别
  710. reportItem.setAge("");//年龄
  711. reportItem.setTitle(statusName);//排队标题
  712. reportItem.setDepName(order.getDeptName());//科室
  713. reportItem.setDoctorName(order.getDoctorName());//医生姓名
  714. reportItem.setDoctorDesc("");//医生描述
  715. reportItem.setAddress(order.getAddress());//就诊地点
  716. int queueNum = 0, leftOver = 0;
  717. GetQueueInfoRequest getQueueInfoRequest = GetQueueInfoRequest.newBuilder()
  718. .setRegistrationId(order.getHisSeqCode())
  719. .setHospitalId(hospitalId)
  720. .build();
  721. GetQueueInfoResponse getQueueInfoResponse = taiheServiceBlockingStub.getQueueInfo(getQueueInfoRequest);
  722. if (getQueueInfoResponse.getCode() == ResultCode.SUCCEED_VALUE) {
  723. QueueInfo data = getQueueInfoResponse.getQueueInfo();
  724. queueNum = data.getWaitingNumber();
  725. }
  726. reportItem.setQueueNum(queueNum + "");//排队编号
  727. reportItem.setLeftover("0");//前面排队剩余人数
  728. reportItem.setStatus(statusName);//状态,expired:已过号,queuing:排队中,ringing:叫号中,completed:已完成
  729. reportItem.setContext(order.getRemark());//排队结束显示内容
  730. list.add(reportItem);
  731. }
  732. return list;
  733. }
  734. @Override
  735. public QueryDoctorInfoResponseData queryDoctorInfo(QueryDoctorInfoRequest request) throws Exception {
  736. int doctorId = Integer.parseInt(Checker.getStringValue(request.getDoctorId(), "0"));
  737. int hospitalId = BizUtil.getCurrentHospitalId();
  738. if (doctorId < 1) {
  739. throw new AppMessageException("invalid doctorId");
  740. }
  741. QueryDoctorInfoResponseData responseData = new QueryDoctorInfoResponseData();
  742. GetDoctorRequest req = GetDoctorRequest.newBuilder().setDoctorId(doctorId).build();
  743. GetDoctorResponse resp = doctorServiceBlockingStub.getDoctor(req);
  744. Result result = resp.getResult();
  745. if (result.getCode() != ResultCode.SUCCEED) {
  746. throw new AppMessageException(result.getInfo());
  747. }
  748. DoctorInfo info = resp.getDoctorInfo();
  749. responseData.setDoctorId(info.getDoctorid() + "");//医生id
  750. responseData.setName(info.getName());//医生姓名
  751. responseData.setLevel(info.getTitle());//医生职级
  752. responseData.setPicUrl(info.getAvatar());//医生头像地址
  753. responseData.setDescription(info.getBriefIntro());//医生简介
  754. responseData.setSpecialty(info.getSpecialty());//擅长领域
  755. responseData.setDistrictName(systemSrv.getHospitalNameById(hospitalId));//院区名称
  756. List<Department> departmentList = new ArrayList<>();
  757. Department department = new Department();
  758. department.setName(info.getDept());
  759. department.setDepartmentId(info.getDeptIds());
  760. departmentList.add(department);
  761. responseData.setDepartments(departmentList);
  762. return responseData;
  763. }
  764. @Override
  765. public PageVO<QueryDoctorListResponseData> queryDoctorList(QueryDoctorListRequest request) throws Exception {
  766. log.info("IsvRegisterServiceImpl#queryDoctorList--QueryDoctorListRequest:{}", JsonSerializer.toJson(request));
  767. int pageIndex = request.getPageIndex();
  768. int pageSize = request.getPageSize();
  769. String deptCode = request.getDeptCode();
  770. String doctorName = request.getDoctorName();
  771. int hospitalId = BizUtil.getCurrentHospitalId();
  772. GetDoctorListRequest getDoctorListRequest = GetDoctorListRequest.newBuilder()
  773. .setDeptCode(deptCode)
  774. .setDoctorName(doctorName)
  775. .setHospitalId(hospitalId)
  776. .build();
  777. GetDoctorListResponse getDoctorListResponse = taiheServiceBlockingStub.getDoctorList(getDoctorListRequest);
  778. int total = 0;
  779. List<QueryDoctorListResponseData> doctorList = new LinkedList<>();
  780. if (getDoctorListResponse.getCode() == ResultCode.SUCCEED_VALUE) {
  781. List<com.ywt.gapi.third.taihe.Doctor> doctorsList = getDoctorListResponse.getDoctorsList();
  782. total = doctorsList.size();
  783. for (com.ywt.gapi.third.taihe.Doctor doctor : doctorsList) {
  784. QueryDoctorListResponseData doctorItem = new QueryDoctorListResponseData();
  785. //医生id
  786. doctorItem.setDoctorId(doctor.getDoctorCode());
  787. //医生姓名
  788. doctorItem.setName(doctor.getDoctorName());
  789. //医生简介
  790. doctorItem.setDesc(doctor.getDoctorIntro());
  791. //医生头像地址
  792. doctorItem.setPicUrl("");
  793. //职级,医生职级
  794. doctorItem.setLevel(doctor.getDoctorTitle());
  795. //医生所在科室
  796. Department department = new Department();
  797. department.setDepartmentId(doctor.getDoctorDeptCode());
  798. department.setName(doctor.getDoctorDept());
  799. List<Department> deptList = new ArrayList();
  800. deptList.add(department);
  801. doctorItem.setDepartments(deptList);
  802. doctorList.add(doctorItem);
  803. }
  804. }
  805. Pagination pagination = new Pagination(pageIndex, pageSize, total);
  806. PageVO<QueryDoctorListResponseData> res = new PageVO<>(pagination, doctorList);
  807. return res;
  808. }
  809. private int getStatus(String statusName) {
  810. if ("已完成".equals(statusName)) {
  811. return 1;
  812. }
  813. if ("待支付".equals(statusName)) {
  814. return 0;
  815. }
  816. if ("已取消".equals(statusName)) {
  817. return 9;
  818. }
  819. if ("待就诊".equals(statusName)) {
  820. return 2;
  821. }
  822. if ("已退款".equals(statusName)) {
  823. return 11;
  824. }
  825. return 0;
  826. }
  827. }