就诊-元数据
This commit is contained in:
		| @@ -1,16 +1,18 @@ | |||||||
| package com.openhis.web.basedatamanage.appservice.impl; | package com.openhis.web.basedatamanage.appservice.impl; | ||||||
|  |  | ||||||
|  | import java.util.*; | ||||||
|  | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
|  | import javax.annotation.Resource; | ||||||
|  |  | ||||||
|  | import org.springframework.beans.BeanUtils; | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.openhis.administration.domain.Organization; | import com.openhis.administration.domain.Organization; | ||||||
| import com.openhis.administration.service.IOrganizationService; | import com.openhis.administration.service.IOrganizationService; | ||||||
| import com.openhis.web.basedatamanage.appservice.IOrganizationAppService; | import com.openhis.web.basedatamanage.appservice.IOrganizationAppService; | ||||||
| import com.openhis.web.basedatamanage.dto.OrganizationQueryDto; | import com.openhis.web.basedatamanage.dto.OrganizationQueryDto; | ||||||
| import org.springframework.beans.BeanUtils; |  | ||||||
| import org.springframework.stereotype.Service; |  | ||||||
|  |  | ||||||
| import javax.annotation.Resource; |  | ||||||
| import java.util.*; |  | ||||||
| import java.util.stream.Collectors; |  | ||||||
|  |  | ||||||
| @Service | @Service | ||||||
| public class IOrganizationAppServiceImpl implements IOrganizationAppService { | public class IOrganizationAppServiceImpl implements IOrganizationAppService { | ||||||
| @@ -39,7 +41,7 @@ public class IOrganizationAppServiceImpl implements IOrganizationAppService { | |||||||
|     private List<OrganizationQueryDto> buildTree(List<Organization> records) { |     private List<OrganizationQueryDto> buildTree(List<Organization> records) { | ||||||
|         // 按b_no的层级排序,确保父节点先处理 |         // 按b_no的层级排序,确保父节点先处理 | ||||||
|         List<Organization> sortedRecords = records.stream() |         List<Organization> sortedRecords = records.stream() | ||||||
|                 .sorted(Comparator.comparingInt(r -> r.getBusNo().split("\\.").length)).collect(Collectors.toList()); |             .sorted(Comparator.comparingInt(r -> r.getBusNo().split("\\.").length)).collect(Collectors.toList()); | ||||||
|  |  | ||||||
|         Map<String, OrganizationQueryDto> nodeMap = new HashMap<>(); |         Map<String, OrganizationQueryDto> nodeMap = new HashMap<>(); | ||||||
|         List<OrganizationQueryDto> tree = new ArrayList<>(); |         List<OrganizationQueryDto> tree = new ArrayList<>(); | ||||||
|   | |||||||
| @@ -1,17 +1,27 @@ | |||||||
| package com.openhis.web.outpatientservice.appservice; | package com.openhis.web.outpatientservice.appservice; | ||||||
|  |  | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
|  | import com.openhis.web.outpatientservice.dto.ContractMetadata; | ||||||
| import com.openhis.web.outpatientservice.dto.PatientMetadata; | import com.openhis.web.outpatientservice.dto.PatientMetadata; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  |  | ||||||
| public interface IOutpatientRegistrationAppService { | public interface IOutpatientRegistrationAppService { | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 门诊挂号 - 查询患者信息 |      * 查询患者信息 | ||||||
|      * |      * | ||||||
|      * @param searchKey 模糊查询关键字 |      * @param searchKey 模糊查询关键字 | ||||||
|      * @param pageNo    当前页 |      * @param pageNo 当前页 | ||||||
|      * @param pageSize  每页多少条 |      * @param pageSize 每页多少条 | ||||||
|      * @return 患者信息 |      * @return 患者信息 | ||||||
|      */ |      */ | ||||||
|     Page<PatientMetadata> getPatientMetadataBySearchKey(String searchKey, Integer pageNo, Integer pageSize); |     Page<PatientMetadata> getPatientMetadataBySearchKey(String searchKey, Integer pageNo, Integer pageSize); | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询费用性质 | ||||||
|  |      *  | ||||||
|  |      * @return 费用性质 | ||||||
|  |      */ | ||||||
|  |     List<ContractMetadata> getContractMetadata(); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,21 +1,30 @@ | |||||||
| package com.openhis.web.outpatientservice.appservice.impl; | package com.openhis.web.outpatientservice.appservice.impl; | ||||||
|  |  | ||||||
|  | import java.util.Arrays; | ||||||
|  | import java.util.HashSet; | ||||||
|  | import java.util.List; | ||||||
|  | import java.util.stream.Collectors; | ||||||
|  |  | ||||||
|  | import javax.annotation.Resource; | ||||||
|  |  | ||||||
|  | import org.springframework.stereotype.Service; | ||||||
|  |  | ||||||
|  | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | ||||||
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | ||||||
| import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | ||||||
| import com.core.common.utils.AgeCalculatorUtil; | import com.core.common.utils.AgeCalculatorUtil; | ||||||
|  | import com.core.common.utils.bean.BeanUtils; | ||||||
| import com.openhis.administration.domain.Patient; | import com.openhis.administration.domain.Patient; | ||||||
| import com.openhis.administration.mapper.PatientMapper; | import com.openhis.administration.mapper.PatientMapper; | ||||||
| import com.openhis.common.enums.AdministrativeGender; | import com.openhis.common.enums.AdministrativeGender; | ||||||
| import com.openhis.common.utils.EnumUtils; | import com.openhis.common.utils.EnumUtils; | ||||||
| import com.openhis.common.utils.HisPageUtils; | import com.openhis.common.utils.HisPageUtils; | ||||||
| import com.openhis.common.utils.HisQueryUtils; | import com.openhis.common.utils.HisQueryUtils; | ||||||
|  | import com.openhis.financial.domain.Contract; | ||||||
|  | import com.openhis.financial.mapper.ContractMapper; | ||||||
| import com.openhis.web.outpatientservice.appservice.IOutpatientRegistrationAppService; | import com.openhis.web.outpatientservice.appservice.IOutpatientRegistrationAppService; | ||||||
|  | import com.openhis.web.outpatientservice.dto.ContractMetadata; | ||||||
| import com.openhis.web.outpatientservice.dto.PatientMetadata; | import com.openhis.web.outpatientservice.dto.PatientMetadata; | ||||||
| import org.springframework.stereotype.Service; |  | ||||||
|  |  | ||||||
| import javax.annotation.Resource; |  | ||||||
| import java.util.Arrays; |  | ||||||
| import java.util.HashSet; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 门诊挂号 实现类 |  * 门诊挂号 实现类 | ||||||
| @@ -26,25 +35,27 @@ public class IOutpatientRegistrationAppServiceImpl implements IOutpatientRegistr | |||||||
|     @Resource |     @Resource | ||||||
|     PatientMapper patientMapper; |     PatientMapper patientMapper; | ||||||
|  |  | ||||||
|  |     @Resource | ||||||
|  |     ContractMapper contractMapper; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 门诊挂号 - 查询患者信息 |      * 门诊挂号 - 查询患者信息 | ||||||
|      * |      * | ||||||
|      * @param searchKey 模糊查询关键字 |      * @param searchKey 模糊查询关键字 | ||||||
|      * @param pageNo    当前页 |      * @param pageNo 当前页 | ||||||
|      * @param pageSize  每页多少条 |      * @param pageSize 每页多少条 | ||||||
|      * @return 患者信息 |      * @return 患者信息 | ||||||
|      */ |      */ | ||||||
|     @Override |     @Override | ||||||
|     public Page<PatientMetadata> getPatientMetadataBySearchKey(String searchKey, Integer pageNo, Integer pageSize) { |     public Page<PatientMetadata> getPatientMetadataBySearchKey(String searchKey, Integer pageNo, Integer pageSize) { | ||||||
|         // 构建查询条件 |         // 构建查询条件 | ||||||
|         QueryWrapper<Patient> queryWrapper = HisQueryUtils.buildQueryWrapper(null, |         QueryWrapper<Patient> queryWrapper = HisQueryUtils.buildQueryWrapper(null, searchKey, | ||||||
|                 searchKey, new HashSet<>(Arrays.asList("name", "py_str", "wb_str")), null |             new HashSet<>(Arrays.asList("name", "py_str", "wb_str")), null); | ||||||
|         ); |  | ||||||
|         // 设置排序 |         // 设置排序 | ||||||
|         queryWrapper.orderByDesc("update_time"); |         queryWrapper.orderByDesc("update_time"); | ||||||
|         // 患者信息 |         // 患者信息 | ||||||
|         Page<PatientMetadata> patientMetadataPage = HisPageUtils.selectPage(patientMapper, |         Page<PatientMetadata> patientMetadataPage = | ||||||
|                 queryWrapper, pageNo, pageSize, PatientMetadata.class); |             HisPageUtils.selectPage(patientMapper, queryWrapper, pageNo, pageSize, PatientMetadata.class); | ||||||
|  |  | ||||||
|         patientMetadataPage.getRecords().forEach(e -> { |         patientMetadataPage.getRecords().forEach(e -> { | ||||||
|             // 性别枚举 |             // 性别枚举 | ||||||
| @@ -55,5 +66,26 @@ public class IOutpatientRegistrationAppServiceImpl implements IOutpatientRegistr | |||||||
|         return patientMetadataPage; |         return patientMetadataPage; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| } |     /** | ||||||
|  |      * 查询费用性质 | ||||||
|  |      * | ||||||
|  |      * @return 费用性质 | ||||||
|  |      */ | ||||||
|  |     @Override | ||||||
|  |     public List<ContractMetadata> getContractMetadata() { | ||||||
|  |         // TODO: Contract表的基础数据维护还没做,具体不知道状态字段的取值是什么,先查询默认值为0的数据 | ||||||
|  |         List<Contract> ContractList = | ||||||
|  |             contractMapper.selectList(new LambdaQueryWrapper<Contract>().eq(Contract::getStatusEnum, 0)); | ||||||
|  |         // 复制同名字段并 return | ||||||
|  |         return ContractList.stream().map(contract -> { | ||||||
|  |             ContractMetadata metadata = new ContractMetadata(); | ||||||
|  |             try { | ||||||
|  |                 BeanUtils.copyProperties(contract, metadata); | ||||||
|  |             } catch (Exception e) { | ||||||
|  |                 e.printStackTrace(); | ||||||
|  |             } | ||||||
|  |             return metadata; | ||||||
|  |         }).collect(Collectors.toList()); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
|   | |||||||
| @@ -3,21 +3,23 @@ | |||||||
|  */ |  */ | ||||||
| package com.openhis.web.outpatientservice.controller; | package com.openhis.web.outpatientservice.controller; | ||||||
|  |  | ||||||
|  | import java.util.List; | ||||||
|  | import java.util.stream.Collectors; | ||||||
|  | import java.util.stream.Stream; | ||||||
|  |  | ||||||
|  | import org.springframework.web.bind.annotation.GetMapping; | ||||||
|  | import org.springframework.web.bind.annotation.RequestMapping; | ||||||
|  | import org.springframework.web.bind.annotation.RequestParam; | ||||||
|  | import org.springframework.web.bind.annotation.RestController; | ||||||
|  |  | ||||||
| import com.core.common.core.domain.R; | import com.core.common.core.domain.R; | ||||||
| import com.openhis.common.enums.PriorityLevel; | import com.openhis.common.enums.PriorityLevel; | ||||||
| import com.openhis.web.basedatamanage.appservice.IOrganizationAppService; | import com.openhis.web.basedatamanage.appservice.IOrganizationAppService; | ||||||
| import com.openhis.web.outpatientservice.appservice.IOutpatientRegistrationAppService; | import com.openhis.web.outpatientservice.appservice.IOutpatientRegistrationAppService; | ||||||
| import com.openhis.web.outpatientservice.dto.OutpatientRegistrationInitDto; | import com.openhis.web.outpatientservice.dto.OutpatientRegistrationInitDto; | ||||||
|  |  | ||||||
| import lombok.AllArgsConstructor; | import lombok.AllArgsConstructor; | ||||||
| import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||||
| import org.springframework.web.bind.annotation.GetMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestMapping; |  | ||||||
| import org.springframework.web.bind.annotation.RequestParam; |  | ||||||
| import org.springframework.web.bind.annotation.RestController; |  | ||||||
|  |  | ||||||
| import java.util.List; |  | ||||||
| import java.util.stream.Collectors; |  | ||||||
| import java.util.stream.Stream; |  | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * 门诊挂号 controller |  * 门诊挂号 controller | ||||||
| @@ -32,13 +34,14 @@ public class OutpatientRegistrationController { | |||||||
|     private final IOrganizationAppService iOrganizationAppService; |     private final IOrganizationAppService iOrganizationAppService; | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 门诊挂号 - 基础数据初始化 |      * 基础数据初始化 | ||||||
|      */ |      */ | ||||||
|     @GetMapping(value = "/init") |     @GetMapping(value = "/init") | ||||||
|     public R<?> init() { |     public R<?> init() { | ||||||
|         OutpatientRegistrationInitDto outpatientRegistrationInitDto = new OutpatientRegistrationInitDto(); |         OutpatientRegistrationInitDto outpatientRegistrationInitDto = new OutpatientRegistrationInitDto(); | ||||||
|         // 优先级 |         // 优先级 | ||||||
|         List<OutpatientRegistrationInitDto.priorityLevelOption> priorityLevelOptionOptions = Stream.of(PriorityLevel.values()) |         List<OutpatientRegistrationInitDto.priorityLevelOption> priorityLevelOptionOptions = | ||||||
|  |             Stream.of(PriorityLevel.values()) | ||||||
|                 .map(e -> new OutpatientRegistrationInitDto.priorityLevelOption(e.getValue(), e.getInfo())) |                 .map(e -> new OutpatientRegistrationInitDto.priorityLevelOption(e.getValue(), e.getInfo())) | ||||||
|                 .collect(Collectors.toList()); |                 .collect(Collectors.toList()); | ||||||
|         outpatientRegistrationInitDto.setPriorityLevelOptionOptions(priorityLevelOptionOptions); |         outpatientRegistrationInitDto.setPriorityLevelOptionOptions(priorityLevelOptionOptions); | ||||||
| @@ -46,33 +49,44 @@ public class OutpatientRegistrationController { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 门诊挂号 - 查询患者信息 |      * 查询患者信息 | ||||||
|      * |      * | ||||||
|      * @param searchKey 模糊查询关键字 |      * @param searchKey 模糊查询关键字 | ||||||
|      * @param pageNo    当前页 |      * @param pageNo 当前页 | ||||||
|      * @param pageSize  每页多少条 |      * @param pageSize 每页多少条 | ||||||
|      * @return 患者信息 |      * @return 患者信息 | ||||||
|      */ |      */ | ||||||
|     @GetMapping(value = "/patient-metadata") |     @GetMapping(value = "/patient-metadata") | ||||||
|     public R<?> getPatientMetadata(@RequestParam(value = "searchKey", defaultValue = "") String searchKey, |     public R<?> getPatientMetadata(@RequestParam(value = "searchKey", defaultValue = "") String searchKey, | ||||||
|                                    @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, |         @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, | ||||||
|                                    @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) { |         @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) { | ||||||
|         return R.ok(iOutpatientRegistrationAppService.getPatientMetadataBySearchKey(searchKey, pageNo, pageSize)); |         return R.ok(iOutpatientRegistrationAppService.getPatientMetadataBySearchKey(searchKey, pageNo, pageSize)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     /** |     /** | ||||||
|      * 门诊挂号 - 查询机构树 |      * 查询费用性质 | ||||||
|      * |      *  | ||||||
|      * @param pageNo   当前页码 |      * @return 费用性质 | ||||||
|      * @param pageSize 查询条数 |  | ||||||
|      * @return 机构分页列表 |  | ||||||
|      */ |      */ | ||||||
|     @GetMapping(value = "/organization-tree") |     @GetMapping(value = "/contract-list") | ||||||
|     public R<?> getOrganizationTree( |     public R<?> getContractList() { | ||||||
|             @RequestParam(value = "pageNo", defaultValue = "1") Integer pageNo, |         return R.ok(iOutpatientRegistrationAppService.getContractMetadata()); | ||||||
|             @RequestParam(value = "pageSize", defaultValue = "10") Integer pageSize) { |  | ||||||
|         return R.ok(iOrganizationAppService.getOrganizationTree(pageNo, pageSize)); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询第一诊断 | ||||||
|  |      */ | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 查询就诊位置 | ||||||
|  |      */ | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 根据位置id筛选医生 | ||||||
|  |      */ | ||||||
|  |  | ||||||
|  |     /** | ||||||
|  |      * 根据机构id筛选服务项目 | ||||||
|  |      */ | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -0,0 +1,13 @@ | |||||||
|  | package com.openhis.web.outpatientservice.dto; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 诊断 元数据 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @Accessors(chain = true) | ||||||
|  | public class ConditionDefinitionMetadata { | ||||||
|  |  | ||||||
|  | } | ||||||
| @@ -0,0 +1,16 @@ | |||||||
|  | package com.openhis.web.outpatientservice.dto; | ||||||
|  |  | ||||||
|  | import lombok.Data; | ||||||
|  | import lombok.experimental.Accessors; | ||||||
|  |  | ||||||
|  | /** | ||||||
|  |  * 费用性质 元数据 | ||||||
|  |  */ | ||||||
|  | @Data | ||||||
|  | @Accessors(chain = true) | ||||||
|  | public class ContractMetadata { | ||||||
|  |     /** 合同名称 */ | ||||||
|  |     private String contractName; | ||||||
|  |     /** 合同编码 */ | ||||||
|  |     private String busNo; | ||||||
|  | } | ||||||
| @@ -43,7 +43,6 @@ | |||||||
|                     adm_healthcare_service AS T1 |                     adm_healthcare_service AS T1 | ||||||
|                         LEFT JOIN adm_charge_item_definition AS T2 ON T2.instance_id = T1.ID |                         LEFT JOIN adm_charge_item_definition AS T2 ON T2.instance_id = T1.ID | ||||||
|                         AND T2.instance_table = #{tableName} |                         AND T2.instance_table = #{tableName} | ||||||
|                         AND T1.delete_flag = '0' |  | ||||||
|                 WHERE T1.delete_flag = '0' |                 WHERE T1.delete_flag = '0' | ||||||
|                 ORDER BY |                 ORDER BY | ||||||
|                     T1.create_time DESC |                     T1.create_time DESC | ||||||
|   | |||||||
| @@ -7,6 +7,8 @@ import com.baomidou.mybatisplus.annotation.TableId; | |||||||
| import com.baomidou.mybatisplus.annotation.TableName; | import com.baomidou.mybatisplus.annotation.TableName; | ||||||
| import com.core.common.core.domain.HisBaseEntity; | import com.core.common.core.domain.HisBaseEntity; | ||||||
|  |  | ||||||
|  | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
|  | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
| import lombok.Data; | import lombok.Data; | ||||||
| import lombok.EqualsAndHashCode; | import lombok.EqualsAndHashCode; | ||||||
| import lombok.experimental.Accessors; | import lombok.experimental.Accessors; | ||||||
| @@ -25,6 +27,7 @@ public class Patient extends HisBaseEntity { | |||||||
|  |  | ||||||
|     /** ID */ |     /** ID */ | ||||||
|     @TableId(type = IdType.ASSIGN_ID) |     @TableId(type = IdType.ASSIGN_ID) | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long id; |     private Long id; | ||||||
|  |  | ||||||
|     /** 活动标记 */ |     /** 活动标记 */ | ||||||
|   | |||||||
| @@ -4,6 +4,8 @@ import com.baomidou.mybatisplus.annotation.IdType; | |||||||
| import com.baomidou.mybatisplus.annotation.TableId; | import com.baomidou.mybatisplus.annotation.TableId; | ||||||
| import com.baomidou.mybatisplus.annotation.TableName; | import com.baomidou.mybatisplus.annotation.TableName; | ||||||
| import com.core.common.core.domain.HisBaseEntity; | import com.core.common.core.domain.HisBaseEntity; | ||||||
|  | import com.fasterxml.jackson.databind.annotation.JsonSerialize; | ||||||
|  | import com.fasterxml.jackson.databind.ser.std.ToStringSerializer; | ||||||
| import com.openhis.common.enums.ConditionDefinitionSource; | import com.openhis.common.enums.ConditionDefinitionSource; | ||||||
| import com.openhis.common.enums.PublicationStatus; | import com.openhis.common.enums.PublicationStatus; | ||||||
|  |  | ||||||
| @@ -25,6 +27,7 @@ public class ConditionDefinition extends HisBaseEntity { | |||||||
|  |  | ||||||
|     /** ID */ |     /** ID */ | ||||||
|     @TableId(type = IdType.ASSIGN_ID) |     @TableId(type = IdType.ASSIGN_ID) | ||||||
|  |     @JsonSerialize(using = ToStringSerializer.class) | ||||||
|     private Long id; |     private Long id; | ||||||
|  |  | ||||||
|     /** 所属分类 */ |     /** 所属分类 */ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Wang.Huan
					Wang.Huan