Skip to content
项目
群组
代码片段
帮助
正在加载...
登录
切换导航
B
byh-family-doctor
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
包
包
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
杨凯
byh-family-doctor
Commits
0bfaa2ca
提交
0bfaa2ca
authored
3月 22, 2024
作者:
杨凯
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat:家庭医生初始化
上级
abc6f7c8
显示空白字符变更
内嵌
并排
正在显示
10 个修改的文件
包含
248 行增加
和
66 行删除
+248
-66
DoctorListForScheduleReqDTO.java
...family/doctor/common/dto/DoctorListForScheduleReqDTO.java
+17
-0
DoctorListForScheduleResVo.java
...i/family/doctor/common/vo/DoctorListForScheduleResVo.java
+21
-0
DoctorController.java
...hui/family/doctor/server/controller/DoctorController.java
+13
-0
DepartmentFeignClient.java
...hui/family/doctor/server/feign/DepartmentFeignClient.java
+14
-0
ScheduleRecordMapper.java
...hui/family/doctor/server/mapper/ScheduleRecordMapper.java
+9
-0
DoctorService.java
...ebaiyihui/family/doctor/server/service/DoctorService.java
+6
-0
DoctorServiceImpl.java
.../family/doctor/server/service/impl/DoctorServiceImpl.java
+89
-5
PatientServiceImpl.java
...family/doctor/server/service/impl/PatientServiceImpl.java
+61
-61
ScheduleRecordMapper.xml
...server/src/main/resources/mapper/ScheduleRecordMapper.xml
+18
-0
ServiceConfigServiceMapper.xml
.../src/main/resources/mapper/ServiceConfigServiceMapper.xml
+0
-0
没有找到文件。
family-doctor-common/src/main/java/com/ebaiyihui/family/doctor/common/dto/DoctorListForScheduleReqDTO.java
0 → 100644
浏览文件 @
0bfaa2ca
package
com
.
ebaiyihui
.
family
.
doctor
.
common
.
dto
;
import
lombok.Data
;
/**
* @ClassName: DoctorListForScheduleReqDTO
* @Author:yanliang
* @Date:2024/3/22 09:07
* @Description
*/
@Data
public
class
DoctorListForScheduleReqDTO
{
private
Long
hospitalId
;
private
Integer
servType
;
}
family-doctor-common/src/main/java/com/ebaiyihui/family/doctor/common/vo/DoctorListForScheduleResVo.java
0 → 100644
浏览文件 @
0bfaa2ca
package
com
.
ebaiyihui
.
family
.
doctor
.
common
.
vo
;
import
lombok.Data
;
/**
* @ClassName: DoctorListForScheduleResVo
* @Author:yanliang
* @Date:2024/3/22 09:08
* @Description
*/
@Data
public
class
DoctorListForScheduleResVo
{
private
String
doctorId
;
private
String
doctorName
;
private
String
deptName
;
private
String
deptId
;
}
family-doctor-server/src/main/java/com/ebaiyihui/family/doctor/server/controller/DoctorController.java
浏览文件 @
0bfaa2ca
package
com
.
ebaiyihui
.
family
.
doctor
.
server
.
controller
;
import
com.ebaiyihui.family.doctor.common.dto.DoctorListForScheduleReqDTO
;
import
com.ebaiyihui.family.doctor.common.dto.QueryDoctorsDTO
;
import
com.ebaiyihui.family.doctor.common.vo.DoctorListForScheduleResVo
;
import
com.ebaiyihui.family.doctor.common.vo.DoctorListVo
;
import
com.ebaiyihui.family.doctor.server.service.DoctorService
;
import
com.ebaiyihui.framework.page.PageResult
;
...
...
@@ -15,6 +17,8 @@ import org.springframework.web.bind.annotation.RequestMapping;
import
org.springframework.web.bind.annotation.RequestMethod
;
import
org.springframework.web.bind.annotation.RestController
;
import
java.util.List
;
/**
* @ClassName: DoctorController
* @Author:yanliang
...
...
@@ -46,4 +50,13 @@ public class DoctorController {
}
@ApiOperation
(
value
=
"管理端分类获取开通在线问诊的医生列表"
)
@RequestMapping
(
value
=
"/getDoctorListForSchedule"
,
method
=
RequestMethod
.
POST
)
public
BaseResponse
<
List
<
DoctorListForScheduleResVo
>>
getDoctorListForSchedule
(
@RequestBody
DoctorListForScheduleReqDTO
req
)
{
return
doctorService
.
getDoctorListForSchedule
(
req
);
}
}
family-doctor-server/src/main/java/com/ebaiyihui/family/doctor/server/feign/DepartmentFeignClient.java
0 → 100644
浏览文件 @
0bfaa2ca
package
com
.
ebaiyihui
.
family
.
doctor
.
server
.
feign
;
import
com.doctor.basedata.api.DepartmentInfoApi
;
import
org.springframework.cloud.openfeign.FeignClient
;
/**
* @ClassName: DepartmentFeignClient
* @Author:yanliang
* @Date:2024/3/22 09:24
* @Description
*/
@FeignClient
(
name
=
"doctoruser-service-api"
,
url
=
"${cloudDoctorUrl}"
)
public
interface
DepartmentFeignClient
extends
DepartmentInfoApi
{
}
family-doctor-server/src/main/java/com/ebaiyihui/family/doctor/server/mapper/ScheduleRecordMapper.java
浏览文件 @
0bfaa2ca
...
...
@@ -3,6 +3,9 @@ package com.ebaiyihui.family.doctor.server.mapper;
import
com.baomidou.mybatisplus.core.mapper.BaseMapper
;
import
com.ebaiyihui.family.doctor.server.entity.ScheduleRecordEntity
;
import
org.apache.ibatis.annotations.Mapper
;
import
org.apache.ibatis.annotations.Param
;
import
java.util.List
;
/**
* @ClassName: ScheduleRecordMapper
...
...
@@ -12,4 +15,10 @@ import org.apache.ibatis.annotations.Mapper;
*/
@Mapper
public
interface
ScheduleRecordMapper
extends
BaseMapper
<
ScheduleRecordEntity
>
{
List
<
ScheduleRecordEntity
>
selectByDate
(
@Param
(
"hospitalId"
)
String
hospitalId
,
@Param
(
"servType"
)
Integer
servType
,
@Param
(
"scheduleDate"
)
String
scheduleDate
,
@Param
(
"status"
)
Integer
status
,
@Param
(
"endStart"
)
String
endStart
);
}
family-doctor-server/src/main/java/com/ebaiyihui/family/doctor/server/service/DoctorService.java
浏览文件 @
0bfaa2ca
package
com
.
ebaiyihui
.
family
.
doctor
.
server
.
service
;
import
com.ebaiyihui.family.doctor.common.dto.DoctorListForScheduleReqDTO
;
import
com.ebaiyihui.family.doctor.common.dto.QueryDoctorsDTO
;
import
com.ebaiyihui.family.doctor.common.vo.DoctorListForScheduleResVo
;
import
com.ebaiyihui.family.doctor.common.vo.DoctorListVo
;
import
com.ebaiyihui.framework.page.PageResult
;
import
com.ebaiyihui.framework.response.BaseResponse
;
import
java.util.List
;
/**
* @ClassName: DoctorService
* @Author:yanliang
...
...
@@ -15,4 +19,6 @@ import com.ebaiyihui.framework.response.BaseResponse;
public
interface
DoctorService
{
BaseResponse
<
PageResult
<
DoctorListVo
>>
getSignedDoctorList
(
QueryDoctorsDTO
reqVo
);
BaseResponse
<
List
<
DoctorListForScheduleResVo
>>
getDoctorListForSchedule
(
DoctorListForScheduleReqDTO
req
);
}
family-doctor-server/src/main/java/com/ebaiyihui/family/doctor/server/service/impl/DoctorServiceImpl.java
浏览文件 @
0bfaa2ca
...
...
@@ -4,19 +4,26 @@ import com.alibaba.fastjson.JSON;
import
com.alibaba.fastjson.JSONObject
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
com.doctor.basedata.api.vo.BusinessDoctorPageReqVo
;
import
com.doctor.basedata.api.vo.DepartmentDetailVo
;
import
com.doctor.basedata.api.vo.DoctorBasicRespVO
;
import
com.doctor.basedata.api.vo.ServiceCheckReqVo
;
import
com.ebaiyihui.family.doctor.common.dto.DoctorListForScheduleReqDTO
;
import
com.ebaiyihui.family.doctor.common.dto.QueryDoctorsDTO
;
import
com.ebaiyihui.family.doctor.common.vo.DoctorListForScheduleResVo
;
import
com.ebaiyihui.family.doctor.common.vo.DoctorListVo
;
import
com.ebaiyihui.family.doctor.server.common.constants.ImConstants
;
import
com.ebaiyihui.family.doctor.server.common.enums.SignStatus
;
import
com.ebaiyihui.family.doctor.server.entity.PatientSignEntity
;
import
com.ebaiyihui.family.doctor.server.entity.ServiceConfigEntity
;
import
com.ebaiyihui.family.doctor.server.feign.DepartmentFeignClient
;
import
com.ebaiyihui.family.doctor.server.feign.DoctorWorkingServiceClient
;
import
com.ebaiyihui.family.doctor.server.mapper.PatientSignMapper
;
import
com.ebaiyihui.family.doctor.server.mapper.S
cheduleRecord
Mapper
;
import
com.ebaiyihui.family.doctor.server.mapper.S
erviceConfig
Mapper
;
import
com.ebaiyihui.family.doctor.server.service.DoctorService
;
import
com.ebaiyihui.family.doctor.server.service.ServiceConfigService
;
import
com.ebaiyihui.framework.page.PageResult
;
import
com.ebaiyihui.framework.response.BaseResponse
;
import
lombok.extern.slf4j.Slf4j
;
import
org.apache.commons.lang.StringUtils
;
import
org.springframework.beans.BeanUtils
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
...
...
@@ -40,10 +47,10 @@ public class DoctorServiceImpl implements DoctorService {
private
PatientSignMapper
patientSignMapper
;
@Autowired
private
ScheduleRecordMapper
scheduleRecordMapper
;
private
DepartmentFeignClient
departmentInfoApi
;
@Autowired
private
ServiceConfig
Service
serviceConfigService
;
private
ServiceConfig
Mapper
serviceConfigMapper
;
@Autowired
private
DoctorWorkingServiceClient
doctorWorkingServiceClient
;
...
...
@@ -135,6 +142,84 @@ public class DoctorServiceImpl implements DoctorService {
return
BaseResponse
.
success
(
pageResult
);
}
@Override
public
BaseResponse
<
List
<
DoctorListForScheduleResVo
>>
getDoctorListForSchedule
(
DoctorListForScheduleReqDTO
req
)
{
//通过医院ID和服务查找开通服务 开通排班 的医生
BusinessDoctorPageReqVo
businessDoctorPageReqVo
=
new
BusinessDoctorPageReqVo
();
businessDoctorPageReqVo
.
setSeq
(
1
);
businessDoctorPageReqVo
.
setStatus
(
1
);
businessDoctorPageReqVo
.
setOrganId
(
req
.
getHospitalId
());
businessDoctorPageReqVo
.
setPageNum
(
1
);
businessDoctorPageReqVo
.
setPageSize
(
9999
);
businessDoctorPageReqVo
.
setServiceCode
(
ImConstants
.
IM_QUERY_ACCOUNT_CODE
);
BaseResponse
<
PageResult
<
DoctorBasicRespVO
>>
result
=
doctorWorkingServiceClient
.
getBusinessDoctorBaseInfoPage
(
businessDoctorPageReqVo
);
if
(!
result
.
isSuccess
())
{
return
BaseResponse
.
error
(
"医生查询失败"
);
}
if
(
null
==
result
||
null
==
result
.
getData
())
{
return
BaseResponse
.
error
(
"无开通家庭医生的医生"
);
}
log
.
info
(
"查询开通家庭医生医生列表{}"
,
JSON
.
toJSONString
(
result
.
getData
().
getContent
()));
ArrayList
<
DoctorListForScheduleResVo
>
listForScheduleVos
=
new
ArrayList
<>();
for
(
DoctorBasicRespVO
doctorBasicRespVO
:
result
.
getData
().
getContent
())
{
QueryWrapper
<
ServiceConfigEntity
>
queryWrapper
=
new
QueryWrapper
<>();
ServiceConfigEntity
serviceConfig
=
new
ServiceConfigEntity
();
serviceConfig
.
setServiceCode
(
ImConstants
.
IM_QUERY_ACCOUNT_CODE
);
serviceConfig
.
setDeptId
(
doctorBasicRespVO
.
getDeptId
());
serviceConfig
.
setDoctorId
(
doctorBasicRespVO
.
getXId
().
toString
());
serviceConfig
.
setOrganId
(
doctorBasicRespVO
.
getOrganId
().
toString
());
serviceConfig
.
setStatus
(
1
);
queryWrapper
.
setEntity
(
serviceConfig
);
List
list
=
new
ArrayList
<>();
list
.
add
(
2
);
list
.
add
(
3
);
queryWrapper
.
in
(
"is_schedule"
,
list
);
List
<
ServiceConfigEntity
>
serviceConfigEntities
=
serviceConfigMapper
.
selectList
(
queryWrapper
);
if
(
CollectionUtils
.
isEmpty
(
serviceConfigEntities
))
{
log
.
info
(
"未查询到医生服务信息,或此医生未开通排班"
);
continue
;
}
serviceConfigEntities
.
stream
().
forEach
(
one
->
{
//查在线医生服务是否开通
ServiceCheckReqVo
serviceCheckReqVo
=
new
ServiceCheckReqVo
();
serviceCheckReqVo
.
setDoctorId
(
doctorBasicRespVO
.
getXId
());
serviceCheckReqVo
.
setOrganId
(
doctorBasicRespVO
.
getOrganId
());
serviceCheckReqVo
.
setDeptId
(
one
.
getDeptId
());
serviceCheckReqVo
.
setServiceCode
(
serviceConfig
.
getServiceCode
());
BaseResponse
<
Boolean
>
response
=
doctorWorkingServiceClient
.
checkDoctorServiceByCode
(
serviceCheckReqVo
);
if
(!
response
.
isSuccess
()
||
!
response
.
getData
())
{
log
.
info
(
"医生该科室未开通家庭医生服务:{}"
,
one
.
getDeptId
());
return
;
}
if
(
StringUtils
.
isEmpty
(
one
.
getDoctorPortrait
())
||
StringUtils
.
isEmpty
(
one
.
getDoctorProfession
()))
{
//把医生头像和职称更新进去
ServiceConfigEntity
serviceUpdate
=
new
ServiceConfigEntity
();
serviceUpdate
.
setDoctorPortrait
(
doctorBasicRespVO
.
getPortrait
());
serviceUpdate
.
setDoctorProfession
(
doctorBasicRespVO
.
getStandardTitle
());
serviceUpdate
.
setId
(
one
.
getId
());
serviceConfigMapper
.
updateById
(
serviceUpdate
);
}
DoctorListForScheduleResVo
doctorForScheduleVo
=
new
DoctorListForScheduleResVo
();
doctorForScheduleVo
.
setDoctorId
(
doctorBasicRespVO
.
getXId
().
toString
());
doctorForScheduleVo
.
setDoctorName
(
doctorBasicRespVO
.
getDoctorName
());
BaseResponse
<
DepartmentDetailVo
>
departmentDetail
=
departmentInfoApi
.
getDepartmentDetail
(
Long
.
valueOf
(
one
.
getDeptId
()));
doctorForScheduleVo
.
setDeptName
(
departmentDetail
.
getData
().
getDeptName
());
doctorForScheduleVo
.
setDeptId
(
one
.
getDeptId
().
toString
());
listForScheduleVos
.
add
(
doctorForScheduleVo
);
});
}
return
BaseResponse
.
success
(
listForScheduleVos
);
}
// private void redisHistory(QueryFamousDotDTO reqVo) {
//
// //把搜索的数据存在map中
...
...
@@ -250,7 +335,6 @@ public class DoctorServiceImpl implements DoctorService {
if
(
CollectionUtils
.
isEmpty
(
resultData
))
{
return
new
ArrayList
<>();
}
//List<DoctorBasicRespVO> content = businessDoctorPage.getData().getContent();
List
<
DoctorBasicRespVO
>
collect
=
resultData
.
stream
().
filter
(
vo
->
(
"5"
).
equals
(
vo
.
getAduitStatus
())).
collect
(
Collectors
.
toList
());
docBaseList
.
addAll
(
collect
);
}
...
...
family-doctor-server/src/main/java/com/ebaiyihui/family/doctor/server/service/impl/PatientServiceImpl.java
浏览文件 @
0bfaa2ca
package
com
.
ebaiyihui
.
family
.
doctor
.
server
.
service
.
impl
;
import
com.alibaba.fastjson.JSON
;
import
com.baomidou.mybatisplus.core.conditions.query.QueryWrapper
;
import
com.ebaiyihui.family.doctor.common.dto.NotifyConsultDataDTO
;
import
com.ebaiyihui.family.doctor.common.dto.SendImMsgDTO
;
...
...
@@ -10,9 +11,11 @@ import com.ebaiyihui.family.doctor.server.common.enums.SignStatus;
import
com.ebaiyihui.family.doctor.server.common.enums.StatusEnum
;
import
com.ebaiyihui.family.doctor.server.entity.MobileBenefitPackageEntity
;
import
com.ebaiyihui.family.doctor.server.entity.PatientSignEntity
;
import
com.ebaiyihui.family.doctor.server.entity.ScheduleRecordEntity
;
import
com.ebaiyihui.family.doctor.server.exception.BusinessException
;
import
com.ebaiyihui.family.doctor.server.mapper.MobileBenefitPackageMapper
;
import
com.ebaiyihui.family.doctor.server.mapper.PatientSignMapper
;
import
com.ebaiyihui.family.doctor.server.mapper.ScheduleRecordMapper
;
import
com.ebaiyihui.family.doctor.server.rabbitmq.RabbitProduct
;
import
com.ebaiyihui.family.doctor.server.service.GoEasyPushService
;
import
com.ebaiyihui.family.doctor.server.service.ImChatTemplate
;
...
...
@@ -26,12 +29,14 @@ import com.ebaiyihui.framework.response.BaseResponse;
import
lombok.extern.slf4j.Slf4j
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.stereotype.Service
;
import
org.springframework.util.CollectionUtils
;
import
org.springframework.util.ObjectUtils
;
import
org.springframework.util.StringUtils
;
import
java.util.Date
;
import
java.util.List
;
import
java.util.Objects
;
import
java.util.Random
;
/**
* @ClassName: PatientServiceImpl
...
...
@@ -49,8 +54,8 @@ public class PatientServiceImpl implements PatientService {
@Autowired
private
MobileBenefitPackageMapper
mobileBenefitPackageMapper
;
//
@Autowired
// private
@Autowired
private
ScheduleRecordMapper
scheduleRecordMapper
;
@Autowired
private
ImMsgTemplateService
imMsgTemplateService
;
...
...
@@ -88,7 +93,10 @@ public class PatientServiceImpl implements PatientService {
}
catch
(
Exception
e
)
{
return
BaseResponse
.
error
(
"没有查询到有关权益"
);
}
Long
doctorId
=
reqVo
.
getDoctorId
();
String
doctorName
=
reqVo
.
getDoctorName
();
Long
deptId
=
reqVo
.
getDeptId
();
String
deptName
=
reqVo
.
getDeptName
();
if
(!
SignStatus
.
NORMAL
.
getValue
().
equals
(
reqVo
.
getSignStatus
()))
{
QueryWrapper
<
PatientSignEntity
>
psWrapper
=
new
QueryWrapper
<>();
PatientSignEntity
patientSign
=
new
PatientSignEntity
();
...
...
@@ -100,6 +108,13 @@ public class PatientServiceImpl implements PatientService {
if
(!
patientSignEntities
.
isEmpty
())
{
return
BaseResponse
.
error
(
"已经有进行中的签约的医生,不能在进行签约!!!"
);
}
}
else
{
// 查询排班医生信息
ScheduleRecordEntity
scheduleRecordEntity
=
getScheduleDoctor
(
reqVo
.
getPatientId
());
doctorId
=
Long
.
valueOf
(
scheduleRecordEntity
.
getDoctorId
());
doctorName
=
scheduleRecordEntity
.
getDoctorName
();
deptId
=
Long
.
valueOf
(
scheduleRecordEntity
.
getDeptId
());
deptName
=
scheduleRecordEntity
.
getDeptName
();
}
if
(
SignStatus
.
CANCEL
.
getValue
().
equals
(
reqVo
.
getSignStatus
()))
{
QueryWrapper
<
PatientSignEntity
>
psWrapper
=
new
QueryWrapper
<>();
...
...
@@ -140,10 +155,10 @@ public class PatientServiceImpl implements PatientService {
patientSignEntity
.
setAppCode
(
CommonConstants
.
APP_CODE
);
patientSignEntity
.
setOrganId
(
CommonConstants
.
ORGAN_CODE
);
patientSignEntity
.
setOrganName
(
CommonConstants
.
ORGAN_NAME
);
patientSignEntity
.
setDoctorId
(
reqVo
.
getDoctorId
()
);
patientSignEntity
.
setDoctorName
(
reqVo
.
getDoctorName
()
);
patientSignEntity
.
setDeptId
(
reqVo
.
getDeptId
()
);
patientSignEntity
.
setDeptName
(
reqVo
.
getDeptName
()
);
patientSignEntity
.
setDoctorId
(
doctorId
);
patientSignEntity
.
setDoctorName
(
doctorName
);
patientSignEntity
.
setDeptId
(
deptId
);
patientSignEntity
.
setDeptName
(
deptName
);
patientSignEntity
.
setSignStatus
(
SignStatus
.
CANCEL
.
getValue
().
equals
(
reqVo
.
getSignStatus
())
?
SignStatus
.
SIGNED
.
getValue
()
:
reqVo
.
getSignStatus
());
patientSignEntity
.
setPatientPhone
(
reqVo
.
getPhone
());
patientSignEntity
.
setCredNo
(
reqVo
.
getCredNo
());
...
...
@@ -247,58 +262,43 @@ public class PatientServiceImpl implements PatientService {
return
BaseResponse
.
success
(
patientSignEntity
);
}
// public ScheduleRecordEntity getScheduleDoctorInfo(String patientId){
// String date = DateUtils.dateToSimpleString(new Date());
// String hourAndSecond = DateUtils.getHourAndSecond();
// QueryWrapper<PatientSignEntity> psWrapper = new QueryWrapper<>();
// PatientSignEntity patientSign = new PatientSignEntity();
// patientSign.setPatientId(patientId);
// patientSign.setStatus(StatusEnum.IN_CONSULTATION.getValue());
// psWrapper.setEntity(patientSign);
// List<PatientSignEntity> patientSignEntities = patientSignMapper.selectList(psWrapper);
// List<Long> doctorIdsFastBuy = patientSignEntities.stream().map(PatientSignEntity::getDoctorId).collect(Collectors.toList());
// log.info("患者已下单医生:{}", doctorIdsFastBuy);
//
// List<ScheduleRecordEntity> scheduleRecordEntities = scheduleRecordMapper.selectByDate(CommonConstants.APP_CODE, 3, date, 1, hourAndSecond);
// List<String> doctorIds = new ArrayList<>();
// log.info("当前排班医生:{}", JSON.toJSONString(scheduleRecordEntities));
//
// if (CollectionUtils.isEmpty(scheduleRecordEntities)) {
// throw new BusinessException("暂无排班医生,请稍后下单");
// }
//
// //过滤该患者已下过单的医生
// if (!CollectionUtils.isEmpty(doctorIdsFastBuy)) {
// scheduleRecordEntities = scheduleRecordEntities.stream().filter(v -> !doctorIdsFastBuy.contains(v.getDoctorId())).collect(Collectors.toList());
// }
//
// if (CollectionUtils.isEmpty(scheduleRecordEntities)) {
// throw new BusinessException("已有订单进行中,请勿重复下单");
// }
//
// doctorIds = scheduleRecordEntities.stream().map(ScheduleRecordEntity::getDoctorId).collect(Collectors.toList());
//
// List<String> doctorByOrderCount = orderMapper.findDoctorByOrderCount(doctorIds, type);
//
// ScheduleRecordEntity scheduleRecordEntity = new ScheduleRecordEntity();
//
// //有极速购药订单的医生(d1)数量等于有排班的医生(d2)数量,取d1数量最少的(第一个)
// //有极速购药订单的医生(d1)数量小于有排班的医生(d2)数量,d2-d1,剩下随机取
// if (doctorByOrderCount.size() == scheduleRecordEntities.size()) {
// String doctorId = doctorByOrderCount.get(0);
// Optional<ScheduleRecordEntity> first = scheduleRecordEntities.stream().filter(v -> Objects.equals(v.getDoctorId(), doctorId)).findFirst();
// scheduleRecordEntity = first.get();
// } else if (doctorByOrderCount.size() < scheduleRecordEntities.size()) {
// scheduleRecordEntities = scheduleRecordEntities.stream().filter(v -> !doctorByOrderCount.contains(v.getDoctorId())).collect(Collectors.toList());
// Random random = new Random();
// int i = random.nextInt(scheduleRecordEntities.size() + 1);
// if (i == 0) {
// i = i + 1;
// }
// scheduleRecordEntity = scheduleRecordEntities.get(i - 1);
// }
//
// log.info("当前下单的医生:{}", JSON.toJSONString(scheduleRecordEntity));
// return scheduleRecordEntity;
// }
/**
* 随访查询一个排班医生
*
* @param patientId
* @return
*/
public
ScheduleRecordEntity
getScheduleDoctor
(
String
patientId
)
{
String
date
=
DateUtils
.
dateToSimpleString
(
new
Date
());
String
hourAndSecond
=
DateUtils
.
getHourAndSecond
();
QueryWrapper
<
PatientSignEntity
>
psWrapper
=
new
QueryWrapper
<>();
PatientSignEntity
patientSign
=
new
PatientSignEntity
();
patientSign
.
setPatientId
(
patientId
);
patientSign
.
setSignStatus
(
SignStatus
.
NORMAL
.
getValue
());
patientSign
.
setStatus
(
StatusEnum
.
IN_CONSULTATION
.
getValue
());
psWrapper
.
setEntity
(
patientSign
);
List
<
PatientSignEntity
>
patientSignEntities
=
patientSignMapper
.
selectList
(
psWrapper
);
if
(
CollectionUtils
.
isEmpty
(
patientSignEntities
))
{
throw
new
BusinessException
(
"已有进行中排班医生沟通,请勿重复点击"
);
}
// 查询排班医生信息
List
<
ScheduleRecordEntity
>
scheduleRecordEntities
=
scheduleRecordMapper
.
selectByDate
(
CommonConstants
.
APP_CODE
,
4
,
date
,
1
,
hourAndSecond
);
log
.
info
(
"当前排班医生:{}"
,
JSON
.
toJSONString
(
scheduleRecordEntities
));
if
(
CollectionUtils
.
isEmpty
(
scheduleRecordEntities
))
{
throw
new
BusinessException
(
"暂无排班医生,请稍后重试"
);
}
ScheduleRecordEntity
scheduleRecordEntity
=
new
ScheduleRecordEntity
();
Random
random
=
new
Random
();
int
i
=
random
.
nextInt
(
scheduleRecordEntities
.
size
()
+
1
);
if
(
i
==
0
)
{
i
=
i
+
1
;
}
scheduleRecordEntity
=
scheduleRecordEntities
.
get
(
i
-
1
);
log
.
info
(
"当前下单的医生:{}"
,
JSON
.
toJSONString
(
scheduleRecordEntity
));
return
scheduleRecordEntity
;
}
}
family-doctor-server/src/main/resources/mapper/ScheduleRecordMapper.xml
0 → 100644
浏览文件 @
0bfaa2ca
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper
namespace=
"com.ebaiyihui.family.doctor.server.mapper.ScheduleRecordMapper"
>
<select
id=
"selectByDate"
resultType=
"com.ebaiyihui.family.doctor.server.entity.ScheduleRecordEntity"
>
SELECT
*
FROM schedule_record
<where>
schedule_date = #{scheduleDate}
and hospital_id = #{hospitalId}
and serv_type = #{servType}
and status =1
and start_time
<![CDATA[<= ]]>
#{endStart}
and end_time
<![CDATA[>= ]]>
#{endStart}
</where>
</select>
</mapper>
\ No newline at end of file
family-doctor-server/src/main/resources/mapper/ServiceConfigService.xml
→
family-doctor-server/src/main/resources/mapper/ServiceConfigService
Mapper
.xml
浏览文件 @
0bfaa2ca
File moved
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论