提交 913f0850 authored 作者: 杨凯's avatar 杨凯

feat:家庭医生初始化

上级 e11965b6
......@@ -23,6 +23,9 @@ public class RequestGetScheduleForWeekDTO {
@ApiModelProperty("第几周")
private Integer week;
@ApiModelProperty("更多周")
private Integer[] weeks;
@ApiModelProperty("医生id")
private String doctorId;
......
package com.ebaiyihui.family.doctor.common.dto;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
/**
* @ClassName: RequestUpdateScheduleStatusDTO
* @Author:yanliang
* @Date:2024/3/25 11:21
* @Description
*/
@Data
public class RequestUpdateScheduleStatusDTO {
@ApiModelProperty("排班id")
private Long id;
@ApiModelProperty("停诊复诊:正常—— 1 停诊—— -1")
private Integer scheduleStatus;
@ApiModelProperty("需要停诊的日期 yyyy-MM-dd")
private String scheduleTime;
@ApiModelProperty("是否开启循环排班 1开启 -1关闭")
private Integer isCycleSchedule;
}
......@@ -2,6 +2,7 @@ package com.ebaiyihui.family.doctor.server.controller;
import com.ebaiyihui.family.doctor.common.dto.InsertScheduleRecordReqDTO;
import com.ebaiyihui.family.doctor.common.dto.RequestGetScheduleForWeekDTO;
import com.ebaiyihui.family.doctor.common.dto.RequestUpdateScheduleStatusDTO;
import com.ebaiyihui.family.doctor.common.dto.ScheduleForWeekReqDTO;
import com.ebaiyihui.family.doctor.common.vo.ResponseGetScheduleForWeekVo;
import com.ebaiyihui.family.doctor.common.vo.ScheduleForWeekResVo;
......@@ -56,4 +57,10 @@ public class ScheduleRecordController {
return scheduleRecordService.scheduleForWeekNew(scheduleForWeekReqDTO);
}
@RequestMapping(value = "/updateStatus", method = RequestMethod.POST)
@ApiOperation("更新或者删除排班")
public BaseResponse<String> updateStatus(@RequestBody RequestUpdateScheduleStatusDTO updateScheduleStatusDTO) {
return scheduleRecordService.updateStatus(updateScheduleStatusDTO);
}
}
......@@ -2,6 +2,7 @@ package com.ebaiyihui.family.doctor.server.service;
import com.ebaiyihui.family.doctor.common.dto.InsertScheduleRecordReqDTO;
import com.ebaiyihui.family.doctor.common.dto.RequestGetScheduleForWeekDTO;
import com.ebaiyihui.family.doctor.common.dto.RequestUpdateScheduleStatusDTO;
import com.ebaiyihui.family.doctor.common.dto.ScheduleForWeekReqDTO;
import com.ebaiyihui.family.doctor.common.vo.ResponseGetScheduleForWeekVo;
import com.ebaiyihui.family.doctor.common.vo.ScheduleForWeekResVo;
......@@ -23,4 +24,6 @@ public interface ScheduleRecordService {
BaseResponse<List<ResponseGetScheduleForWeekVo>> getScheduleForWeek(RequestGetScheduleForWeekDTO requestGetScheduleForWeekDTO);
BaseResponse<List<ScheduleForWeekResVo>> scheduleForWeekNew(ScheduleForWeekReqDTO scheduleForWeekReqDTO);
BaseResponse<String> updateStatus(RequestUpdateScheduleStatusDTO updateScheduleStatusDTO);
}
......@@ -125,54 +125,57 @@ public class ScheduleRecordServiceImpl implements ScheduleRecordService {
Date intEndDate = DateUtils.dateToDateAsFormat(DateUtils.getEndDayOfWeek());
Integer week = requestGetScheduleForWeekDTO.getWeek();
Date startDate = null;
Date endDate = null;
startDate = DateUtils.getDateAfter(intStartDate, 7 * week);
endDate = DateUtils.getDateAfter(intEndDate, 7 * week);
QueryWrapper<ScheduleRecordEntity> wrapper = new QueryWrapper();
ScheduleRecordEntity entity = new ScheduleRecordEntity();
entity.setDoctorId(requestGetScheduleForWeekDTO.getDoctorId());
entity.setDeptId(String.valueOf(requestGetScheduleForWeekDTO.getDeptId()));
entity.setHospitalId(String.valueOf(requestGetScheduleForWeekDTO.getHospitalId()));
wrapper.setEntity(entity);
wrapper.between("schedule_date", startDate, endDate);
List<ScheduleRecordEntity> recordEntityList = scheduleRecordMapper.selectList(wrapper);
log.info("查询排班结果{}", recordEntityList.toString());
List<ResponseGetScheduleForWeekVo> list = new ArrayList<>();
for (int i = 0; i < 7; i++) {
ResponseGetScheduleForWeekVo scheduleForWeekVo = new ResponseGetScheduleForWeekVo();
Date weekDay = DateUtils.getDateAfter(startDate, i);
scheduleForWeekVo.setScheduleDate(weekDay);
List<ScheduleOfDayVo> scheduleOfDayVoList = new ArrayList<>();
for (int j = 1; j <= 3; j++) {
ScheduleOfDayVo scheduleOfDayVo = new ScheduleOfDayVo();
QueryWrapper<ScheduleRecordEntity> queryWrapper = new QueryWrapper<>();
ScheduleRecordEntity timeIntervalEntity = new ScheduleRecordEntity();
timeIntervalEntity.setHospitalId(String.valueOf(requestGetScheduleForWeekDTO.getHospitalId()));
timeIntervalEntity.setDoctorId(requestGetScheduleForWeekDTO.getDoctorId());
timeIntervalEntity.setDeptId(String.valueOf(requestGetScheduleForWeekDTO.getDeptId()));
timeIntervalEntity.setScheduleDate(weekDay);
timeIntervalEntity.setScheduleRange(j);
queryWrapper.setEntity(timeIntervalEntity);
List<ScheduleRecordEntity> scheduleTimeIntervalEntities = scheduleRecordMapper.selectList(queryWrapper);
List<ScheduleTimeSaveListVo> scheduleTimeSaveListVos = new ArrayList<>();
if (null != scheduleTimeIntervalEntities) {
scheduleTimeIntervalEntities.forEach(scheduleTimeIntervalEntitie -> {
ScheduleTimeSaveListVo saveListVo = new ScheduleTimeSaveListVo();
BeanUtils.copyProperties(scheduleTimeIntervalEntitie, saveListVo);
scheduleTimeSaveListVos.add(saveListVo);
});
}
scheduleOfDayVo.setScheduleTimeSaveListVo(scheduleTimeSaveListVos);
Integer[] weeks = requestGetScheduleForWeekDTO.getWeeks();
List<ResponseGetScheduleForWeekVo> resList = new ArrayList<>();
for (Integer week : weeks) {
Date startDate = null;
Date endDate = null;
startDate = DateUtils.getDateAfter(intStartDate, 7 * week);
endDate = DateUtils.getDateAfter(intEndDate, 7 * week);
QueryWrapper<ScheduleRecordEntity> wrapper = new QueryWrapper();
ScheduleRecordEntity entity = new ScheduleRecordEntity();
entity.setDoctorId(requestGetScheduleForWeekDTO.getDoctorId());
entity.setDeptId(String.valueOf(requestGetScheduleForWeekDTO.getDeptId()));
entity.setHospitalId(String.valueOf(requestGetScheduleForWeekDTO.getHospitalId()));
wrapper.setEntity(entity);
wrapper.between("schedule_date", startDate, endDate);
List<ScheduleRecordEntity> recordEntityList = scheduleRecordMapper.selectList(wrapper);
log.info("查询排班结果{}", recordEntityList.toString());
List<ResponseGetScheduleForWeekVo> list = new ArrayList<>();
for (int i = 0; i < 7; i++) {
ResponseGetScheduleForWeekVo scheduleForWeekVo = new ResponseGetScheduleForWeekVo();
Date weekDay = DateUtils.getDateAfter(startDate, i);
scheduleForWeekVo.setScheduleDate(weekDay);
List<ScheduleOfDayVo> scheduleOfDayVoList = new ArrayList<>();
for (int j = 1; j <= 3; j++) {
ScheduleOfDayVo scheduleOfDayVo = new ScheduleOfDayVo();
QueryWrapper<ScheduleRecordEntity> queryWrapper = new QueryWrapper<>();
ScheduleRecordEntity timeIntervalEntity = new ScheduleRecordEntity();
timeIntervalEntity.setHospitalId(String.valueOf(requestGetScheduleForWeekDTO.getHospitalId()));
timeIntervalEntity.setDoctorId(requestGetScheduleForWeekDTO.getDoctorId());
timeIntervalEntity.setDeptId(String.valueOf(requestGetScheduleForWeekDTO.getDeptId()));
timeIntervalEntity.setScheduleDate(weekDay);
timeIntervalEntity.setScheduleRange(j);
queryWrapper.setEntity(timeIntervalEntity);
List<ScheduleRecordEntity> scheduleTimeIntervalEntities = scheduleRecordMapper.selectList(queryWrapper);
List<ScheduleTimeSaveListVo> scheduleTimeSaveListVos = new ArrayList<>();
if (null != scheduleTimeIntervalEntities) {
scheduleTimeIntervalEntities.forEach(scheduleTimeIntervalEntitie -> {
ScheduleTimeSaveListVo saveListVo = new ScheduleTimeSaveListVo();
BeanUtils.copyProperties(scheduleTimeIntervalEntitie, saveListVo);
scheduleTimeSaveListVos.add(saveListVo);
});
}
scheduleOfDayVo.setScheduleTimeSaveListVo(scheduleTimeSaveListVos);
// List<ScheduleRecordVo> scheduleRecordVoList = new ArrayList<>();
// if (!recordEntityList.isEmpty()) {
......@@ -193,12 +196,14 @@ public class ScheduleRecordServiceImpl implements ScheduleRecordService {
// }
// }
// scheduleOfDayVo.setRecordVoList(scheduleRecordVoList);
scheduleOfDayVoList.add(scheduleOfDayVo);
scheduleOfDayVoList.add(scheduleOfDayVo);
}
scheduleForWeekVo.setScheduleOfDayVoList(scheduleOfDayVoList);
list.add(scheduleForWeekVo);
resList.addAll(list);
}
scheduleForWeekVo.setScheduleOfDayVoList(scheduleOfDayVoList);
list.add(scheduleForWeekVo);
}
return BaseResponse.success(list);
return BaseResponse.success(resList);
}
@Override
......@@ -305,6 +310,111 @@ public class ScheduleRecordServiceImpl implements ScheduleRecordService {
return BaseResponse.success(list);
}
@Override
public BaseResponse<String> updateStatus(RequestUpdateScheduleStatusDTO updateScheduleStatusDTO) {
ScheduleRecordEntity entity = scheduleRecordMapper.selectById(updateScheduleStatusDTO.getId());
if (null == entity) {
return BaseResponse.error("排班信息不存在");
}
//操作循环排班
if (null != updateScheduleStatusDTO.getIsCycleSchedule()) {
closeCycle(updateScheduleStatusDTO, entity);
log.info("======循环排班操作成功======");
return BaseResponse.success();
}
//操作停诊
BaseResponse<String> baseResponse = closeSchedule(updateScheduleStatusDTO, entity);
return baseResponse;
}
/**
* Discreption: 关闭循环排班:该排班之后的循环排班停诊
*/
private void closeCycle(RequestUpdateScheduleStatusDTO updateScheduleStatusDTO, ScheduleRecordEntity entity) {
ScheduleRecordEntity entityUpdate = new ScheduleRecordEntity();
entityUpdate.setIsCycleSchedule(updateScheduleStatusDTO.getIsCycleSchedule());
entityUpdate.setId(updateScheduleStatusDTO.getId());
scheduleRecordMapper.updateById(entityUpdate);
String date = DateUtils.dateToSimpleString(entity.getScheduleDate());
//查询循环排班日期
List<String> nextDays = DateUtils.getOneDayNextWeekTwo(new ArrayList<String>() {{
add(date);
}}, 5);
List<ScheduleRecordEntity> list = scheduleRecordMapper.selectList(new QueryWrapper<ScheduleRecordEntity>().lambda()
.eq(ScheduleRecordEntity::getDeptId, entity.getDeptId())
.eq(ScheduleRecordEntity::getDoctorId, entity.getDoctorId())
.eq(ScheduleRecordEntity::getHospitalId, entity.getHospitalId())
.eq(ScheduleRecordEntity::getServType, entity.getServType())
.eq(ScheduleRecordEntity::getStartTime, entity.getStartTime())
.eq(ScheduleRecordEntity::getEndTime, entity.getEndTime())
.in(ScheduleRecordEntity::getScheduleDate, nextDays));
//停诊
for (ScheduleRecordEntity scheduleRecordEntity : list) {
if (!scheduleRecordEntity.getId().equals(entity.getId())) {
closeSchedule(updateScheduleStatusDTO, scheduleRecordEntity);
}
}
}
/**
* Discreption:停诊取消排班
*/
private BaseResponse<String> closeSchedule(RequestUpdateScheduleStatusDTO updateScheduleStatusDTO, ScheduleRecordEntity entity) {
//查询排班
BaseResponse<String> x = getStringBaseResponse(entity);
if (x != null) {
return x;
}
ScheduleRecordEntity entityUpdate = new ScheduleRecordEntity();
entityUpdate.setStatus(-1);
if (Objects.nonNull(updateScheduleStatusDTO.getIsCycleSchedule())) {
entityUpdate.setIsCycleSchedule(updateScheduleStatusDTO.getIsCycleSchedule());
}
entityUpdate.setId(entity.getId());
scheduleRecordMapper.updateById(entityUpdate);
return BaseResponse.success("医生排班停诊成功");
}
private BaseResponse<String> getStringBaseResponse(ScheduleRecordEntity entity) {
String nowDateStr = DateUtils.getCurrentDateSimpleToString();
log.info("nowDateStr{}", nowDateStr);
String hourAndSecond = DateUtils.getHourAndSecond();
log.info("hourAndSecond{}", hourAndSecond);
Date now = null;
Date endEntity = null;
Date hourAndSec = null;
try {
now = DateUtils.strToDate(nowDateStr, "yyyy-MM-dd");
endEntity = DateUtils.strToDate(entity.getEndTime(), "HH:mm");
hourAndSec = DateUtils.strToDate(hourAndSecond, "HH:mm");
} catch (ParseException e) {
e.printStackTrace();
}
if (entity.getStatus().equals(WhetherEnum.FORBID.getValue())) {
return BaseResponse.error("已停诊,请勿重复停诊");
}
if (isBoolean(entity, now, endEntity, hourAndSec)) {
return BaseResponse.error("超时不能停诊");
}
return null;
}
private boolean isBoolean(ScheduleRecordEntity entity, Date now, Date endEntity, Date hourAndSec) {
return entity.getScheduleDate().equals(now) && hourAndSec.after(endEntity) || entity.getScheduleDate().before(now);
}
private void getInsertSchedule(InsertScheduleRecordReqDTO record, DoctorInfoForScheduleDTO doctorInfo, ScheduleRangeAndTimeDTO rangeRes, String s) {
ScheduleRecordEntity schedule = new ScheduleRecordEntity();
BeanUtils.copyProperties(record, schedule);
......
......@@ -34,7 +34,6 @@ public class ScheduleTask {
@Autowired
private ScheduleRecordMapper scheduleRecordMapper;
// @Scheduled(cron = "0 0/2 * * * ?")
@Scheduled(cron = "0 0 0 * * ?")
public void regularTimeExport() {
......
......@@ -22,6 +22,7 @@ import com.ebaiyihui.imforward.client.vo.IMQueryUserLoginRspVO;
import com.ebaiyihui.imforward.client.vo.IMSingleMsgResultVO;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import java.util.ArrayList;
......@@ -50,9 +51,11 @@ public class SignedTask {
@Autowired
private ThirdOrderPushUtil thirdOrderPushUtil;
// @Scheduled(cron = "0 0 10 * * ?")
@Scheduled(cron = "0 0 10 * * ?")
public void healthRecordWhetherUpdate() {
List<PatientSignEntity> patientSignEntities = patientSignSevice.selectList(new PatientSignEntity());
PatientSignEntity patientSignEntity = new PatientSignEntity();
patientSignEntity.setStatus(StatusEnum.IN_CONSULTATION.getValue());
List<PatientSignEntity> patientSignEntities = patientSignSevice.selectList(patientSignEntity);
if (!patientSignEntities.isEmpty()) {
for (PatientSignEntity ps : patientSignEntities) {
HealthInfoDTO healthInfoDTO = new HealthInfoDTO();
......@@ -128,7 +131,7 @@ public class SignedTask {
}
// @Scheduled(cron = "0 0 20 * * ?")
@Scheduled(cron = "0 0 20 * * ?")
public void holidayPush() {
List<PatientSignEntity> patientSignEntities = patientSignSevice.selectList(new PatientSignEntity());
try {
......@@ -177,7 +180,7 @@ public class SignedTask {
}
}
// @Scheduled(cron = "0 0 1 * * ?")
@Scheduled(cron = "0 0 1 * * ?")
public void orderInvalidation() {
List<MobileBenefitPackageEntity> mobileBenefitPackageEntities = mobileBenefitPackageMapper.queryMaxOneList();
try {
......
......@@ -59,6 +59,7 @@
mobile_benefit_package
WHERE
phone = #{mobile} and activateOrderId = #{activateOrderId}
and NOW() BETWEEN STR_TO_DATE(benefitsStartTime, '%Y-%m-%d %H:%i:%s') AND STR_TO_DATE(benefitsEndTime, '%Y-%m-%d %H:%i:%s')
ORDER BY
x_create_time DESC
LIMIT 0,1
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论