| | |
| | | @GetMapping("/search") |
| | | public AjaxResult searchHospitals( |
| | | @RequestParam(value = "keyword", required = false) String keyword, |
| | | @RequestParam(value = "deptId", required = false) Long deptId) { |
| | | @RequestParam(value = "deptId", required = false) Long deptId, |
| | | @RequestParam(value = "pageSize", required = false, defaultValue = "50") Integer pageSize) { |
| | | List<HospData> list; |
| | | |
| | | // 如果keyword为空,使用部门区域过滤查询 |
| | |
| | | |
| | | list = hospDataMapper.searchHospitals(keyword, ""); |
| | | |
| | | } |
| | | |
| | | // 限制返回数量 |
| | | if (pageSize != null && pageSize > 0 && list.size() > pageSize) { |
| | | list = list.subList(0, pageSize); |
| | | } |
| | | |
| | | // 确保"家中"在结果中 |
| | |
| | | * 获取常用转出医院列表(从MySQL tb_hosp_data表查询) |
| | | * @param serviceOrdClass 分公司编码(service_order_class) |
| | | * @param region 地域关键词(可选) |
| | | * @param pageSize 返回结果数量限制(默认50) |
| | | */ |
| | | @GetMapping("/frequent/out") |
| | | public AjaxResult getFrequentOutHospitals( |
| | | @RequestParam("serviceOrdClass") String serviceOrdClass, |
| | | @RequestParam(value = "region", required = false) String region) { |
| | | @RequestParam(value = "region", required = false) String region, |
| | | @RequestParam(value = "pageSize", required = false, defaultValue = "50") Integer pageSize) { |
| | | // 查询常用转出医院ID列表 |
| | | logger.info("getFrequentOutHospitals 传入的 serviceOrdClass :{}",serviceOrdClass); |
| | | List<Integer> hospIds = sqlHospDataService.selectFrequentOutHospitalIds(serviceOrdClass); |
| | |
| | | |
| | | // 根据ID列表查询医院详情 |
| | | List<HospData> hospitals = hospDataMapper.selectHospDataByIds(hospIds, region); |
| | | |
| | | // 限制返回数量 |
| | | if (pageSize != null && pageSize > 0 && hospitals.size() > pageSize) { |
| | | hospitals = hospitals.subList(0, pageSize); |
| | | } |
| | | |
| | | return success(hospitals); |
| | | } |
| | |
| | | * 获取常用转入医院列表(从MySQL tb_hosp_data表查询) |
| | | * @param serviceOrdClass 分公司编码(service_order_class) |
| | | * @param region 地域关键词(可选) |
| | | * @param pageSize 返回结果数量限制(默认50) |
| | | */ |
| | | @GetMapping("/frequent/in") |
| | | public AjaxResult getFrequentInHospitals( |
| | | @RequestParam("serviceOrdClass") String serviceOrdClass, |
| | | @RequestParam(value = "region", required = false) String region) { |
| | | @RequestParam(value = "region", required = false) String region, |
| | | @RequestParam(value = "pageSize", required = false, defaultValue = "50") Integer pageSize) { |
| | | // 查询常用转入医院ID列表 |
| | | logger.info("getFrequentInHospitals 传入的 serviceOrdClass {}",serviceOrdClass); |
| | | List<Integer> hospIds = sqlHospDataService.selectFrequentInHospitalIds(serviceOrdClass); |
| | |
| | | |
| | | // 根据ID列表查询医院详情 |
| | | List<HospData> hospitals = hospDataMapper.selectHospDataByIds(hospIds, region); |
| | | |
| | | // 限制返回数量 |
| | | if (pageSize != null && pageSize > 0 && hospitals.size() > pageSize) { |
| | | hospitals = hospitals.subList(0, pageSize); |
| | | } |
| | | |
| | | if(homeHospId>0) { |
| | | |
| | | HospData hospData= hospDataMapper.selectHospDataById(homeHospId); |
| | | HospData hospData = hospDataMapper.selectHospDataById(homeHospId); |
| | | hospitals.add(0,hospData); |
| | | } |
| | | return success(hospitals); |
| | | } |
| | | |
| | | /** |
| | | * 根据部门区域配置搜索医院(从MySQL tb_hosp_data表查询,支持省、市、县/区等多级区域) |
| | | * 根据部门区域配置搜索医院(从MySQLtb_hosp_data表查询,支持省、市、县/区等多级区域) |
| | | * @param keyword 搜索关键词 |
| | | * @param deptId 部门ID |
| | | * @param pageSize 返回结果数量限制(默认50) |
| | | */ |
| | | @GetMapping("/search/by-dept-region") |
| | | public AjaxResult searchHospitalsByDeptRegion( |
| | | @RequestParam(value = "keyword", required = false) String keyword, |
| | | @RequestParam("deptId") Long deptId) { |
| | | logger.info("根据部门区域配置搜索医院:deptId={}, keyword={}", deptId, keyword); |
| | | @RequestParam("deptId") Long deptId, |
| | | @RequestParam(value = "pageSize", required = false, defaultValue = "50") Integer pageSize) { |
| | | logger.info("根据部门区域配置搜索医院:deptId={}, keyword={}, pageSize={}", deptId, keyword, pageSize); |
| | | |
| | | // 调用Mapper查询,自动根据部门的区域配置过滤医院 |
| | | List<HospData> hospitals = hospDataMapper.searchHospitalsByDeptRegion(keyword, deptId); |
| | | logger.info("查询到医院数量:{}", hospitals.size()); |
| | | |
| | | // 限制返回数量 |
| | | if (pageSize != null && pageSize > 0 && hospitals.size() > pageSize) { |
| | | hospitals = hospitals.subList(0, pageSize); |
| | | } |
| | | |
| | | // 确保"家中"在结果中 |
| | | Integer homeHospId = hospDataMapper.getHomeHospId(); |
| | | if (homeHospId > 0 && hospitals.stream().noneMatch(h -> h.getHospId().equals(homeHospId))) { |