123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335 |
- package com.bofeng.service;
- import com.baomidou.mybatisplus.toolkit.IdWorker;
- import com.bofeng.dao.*;
- import com.bofeng.entity.*;
- import com.yvan.platform.Conv;
- import org.joda.time.DateTime;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import org.springframework.transaction.annotation.Propagation;
- import org.springframework.transaction.annotation.Transactional;
- import java.math.BigDecimal;
- import java.text.SimpleDateFormat;
- import java.util.Date;
- import java.util.List;
- /**
- * @Author: xielianghe
- * @Date: 2020/2/22 13:33
- */
- @Service
- @Transactional(readOnly = true)
- public class MsTripService {
- @Autowired
- private MsSuspectedMapper msSuspectedMapper;
- @Autowired
- private MsReportMapper msReportMapper;
- @Autowired
- private MsTripMapper msTripMapper;
- @Autowired
- private MsTripDetMapper msTripDetMapper;
- @Autowired
- private MsSuspectedService msSuspectedService;
- @Autowired
- private MsReportService msReportService;
- @Autowired
- private UptownUnitMapper uptownUnitMapper;
- //添加家人
- @Transactional(rollbackFor = Exception.class, propagation = Propagation.REQUIRED)
- public Long addSuspectedTrip(Long suspectedId, String userName, Integer grender, Integer age, String familyStatus,
- String statusDesp, Integer medical, BigDecimal temperature, Integer cough, Integer muscle,
- Integer dyspnea, Integer fatigue, Integer diarrhea, Integer singleRoom, String others, Long userCreate, Integer scoreRezult, Integer temperatureScore, Integer scoreHistroy, Integer score
- , Integer workLocal, String workLocalOther, Integer todayLocal, String todayLocalOther, Integer isTrip, List<MsTripDet> listTripDet) {
- Long reportId = 0L;
- //如果是当前日期 已经添加
- Date t = new Date();
- SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");
- String reportDate = df.format(t);
- List<MsReport> listReport = msReportMapper.selectByReportDate(reportDate, userCreate);
- Long houseId = msReportMapper.selectHouseIdByUserId(userCreate);
- //首次进入。没有今日报告
- if (listReport == null || listReport.size() == 0) {
- MsReport msReport = new MsReport();
- msReport.setReportId(IdWorker.getId());
- msReport.setHouseId(houseId);
- msReport.setSafetyNum(0);
- msReport.setSureNum(0);
- msReport.setSuspectedNum(0);
- msReport.setNormalNum(0);
- msReport.setSingleNum(0);
- msReport.setRemarks("");
- msReport.setReportDate(DateTime.now().toDate());
- msReport.setMsStatus(0);
- msReport.setUserCreate(userCreate);
- msReport.setTimeCreate(DateTime.now());
- msReport.setUserUpdate(userCreate);
- msReport.setTimeUpdate(DateTime.now());
- msReportMapper.insert(msReport);
- reportId = msReport.getReportId();
- } else {
- reportId = listReport.get(0).getReportId();
- }
- //判断是否疑似
- Integer suspectedStatus = 0;
- //确诊
- if (medical == 1)
- suspectedStatus = 1;
- //隔离
- if (singleRoom == 1)
- suspectedStatus = 1;
- //体温
- if (Conv.NFloat(temperature) < Conv.NFloat(35) || Conv.NFloat(temperature) > Conv.NFloat(37.3))
- suspectedStatus = 1;
- //咳嗽
- if (cough > 0)
- suspectedStatus = 1;
- //肌肉酸痛
- if (muscle > 0)
- suspectedStatus = 1;
- //呼吸困难
- if (dyspnea > 0)
- suspectedStatus = 1;
- //乏力
- if (fatigue > 0)
- suspectedStatus = 1;
- //腹泻
- if (diarrhea > 0)
- suspectedStatus = 1;
- if (suspectedId == 0L) {
- //判断家人是否同名
- List<MsSuspected> list = msSuspectedMapper.selectUserNameNum(reportId, userName, reportDate);
- if (list != null && list.size() > 0)
- return 2L;
- //判断是否评估
- if (scoreRezult == 0) {
- MsSuspected msSuspected1 = msSuspectedService.getScore(0L, userName, medical, temperature, cough, muscle, dyspnea, fatigue, diarrhea, userCreate);
- if (msSuspected1 != null) {
- scoreRezult = msSuspected1.getScoreRezult();
- score = msSuspected1.getScore();
- temperatureScore = msSuspected1.getTemperatureScore();
- scoreHistroy = msSuspected1.getScoreHistroy();
- }
- }
- MsSuspected msSuspected = new MsSuspected();
- msSuspected.setSuspectedId(IdWorker.getId());
- msSuspected.setReportId(reportId);
- msSuspected.setUserName(userName);
- msSuspected.setGrender(grender);//默认为家人
- msSuspected.setAge(age);
- msSuspected.setFamilyStatus(familyStatus);
- msSuspected.setStatusDesp(statusDesp);
- msSuspected.setMedical(medical);
- msSuspected.setTemperature(temperature);
- msSuspected.setCough(cough);
- msSuspected.setMuscle(muscle);
- msSuspected.setDiarrhea(dyspnea);
- msSuspected.setFatigue(fatigue);
- msSuspected.setDiarrhea(diarrhea);
- msSuspected.setSingleRoom(singleRoom);
- msSuspected.setOthers(others);
- msSuspected.setSuspectedStatus(suspectedStatus);
- msSuspected.setScoreRezult(scoreRezult);
- msSuspected.setScore(score);
- msSuspected.setScoreHistroy(scoreHistroy);
- msSuspected.setTemperatureScore(temperatureScore);
- msSuspected.setUserCreate(userCreate);
- msSuspected.setTimeCreate(DateTime.now());
- msSuspected.setUserUpdate(userCreate);
- msSuspected.setTimeUpdate(DateTime.now());
- msSuspectedMapper.insert(msSuspected);
- //添加出行
- if (todayLocal > 0 && workLocal > 0) {
- MsTrip msTrip = new MsTrip();
- msTrip.setTripId(msSuspected.getSuspectedId());
- msTrip.setIsTrip(isTrip);
- msTrip.setTodayLocal(todayLocal);
- msTrip.setTodayLocalOther(todayLocalOther);
- msTrip.setWorkLocal(workLocal);
- msTrip.setWorkLocalOther(workLocalOther);
- msTripMapper.insert(msTrip);
- //添加出行详细
- if (listTripDet != null && listTripDet.size() > 0) {
- for (MsTripDet msTripDet : listTripDet) {
- MsTripDet msTripDet1 = new MsTripDet();
- msTripDet1.setTripDetId(IdWorker.getId());
- msTripDet1.setTripId(msSuspected.getSuspectedId());
- msTripDet1.setSort(msTripDet.getSort());
- msTripDet1.setStartLocal(msTripDet.getStartLocal());
- msTripDet1.setStartLocalOther(msTripDet.getStartLocalOther());
- msTripDet1.setEndLocal(msTripDet.getEndLocal());
- msTripDet1.setEndLocalOther(msTripDet.getEndLocalOther());
- msTripDet1.setTripType(msTripDet.getTripType());
- msTripDet1.setTripTypeDesp(msTripDet.getTripTypeDesp());
- msTripDet1.setTimeCreate(DateTime.now());
- msTripDet1.setUserCreate(userCreate);
- msTripDet1.setTimeUpdate(DateTime.now());
- msTripDet1.setUserUpdate(userCreate);
- msTripDetMapper.insert(msTripDet1);
- }
- }
- }
- //更新今日日报,直接上报
- msSuspectedService.updateReport(reportId, medical, singleRoom, temperature);
- } else {
- //判断家人是否同名
- List<MsSuspected> list = msSuspectedMapper.selectUserNameNum(reportId, userName, reportDate);
- if (list != null && list.size() > 0) {
- if (list.size() > 1)
- return 2L;
- else {
- if (list.get(0).getSuspectedId().longValue() != suspectedId.longValue())
- return 2L;
- }
- }
- MsSuspected msSuspected2 = msSuspectedService.getScore(suspectedId, userName, medical, temperature, cough, muscle, dyspnea, fatigue, diarrhea, userCreate);
- if (msSuspected2 != null) {
- scoreRezult = msSuspected2.getScoreRezult();
- score = msSuspected2.getScore();
- temperatureScore = msSuspected2.getTemperatureScore();
- scoreHistroy = msSuspected2.getScoreHistroy();
- }
- MsSuspected msSuspected1 = msSuspectedMapper.selectById(suspectedId);
- if (msSuspected1 != null) {
- msSuspected1.setUserName(userName);
- msSuspected1.setGrender(grender);//默认为家人
- msSuspected1.setAge(age);
- msSuspected1.setFamilyStatus(familyStatus);
- msSuspected1.setStatusDesp(statusDesp);
- msSuspected1.setMedical(medical);
- msSuspected1.setTemperature(temperature);
- msSuspected1.setCough(cough);
- msSuspected1.setMuscle(muscle);
- msSuspected1.setDiarrhea(dyspnea);
- msSuspected1.setFatigue(fatigue);
- msSuspected1.setDiarrhea(diarrhea);
- msSuspected1.setSingleRoom(singleRoom);
- msSuspected1.setOthers(others);
- msSuspected1.setScoreRezult(scoreRezult);
- msSuspected1.setScore(score);
- msSuspected1.setScoreHistroy(scoreHistroy);
- msSuspected1.setTemperatureScore(temperatureScore);
- msSuspected1.setSuspectedStatus(suspectedStatus);
- msSuspectedMapper.updateById(msSuspected1);
- }
- //编辑行程
- MsTrip msTrip = msTripMapper.selectById(suspectedId);
- if (msTrip != null) {
- msTrip.setWorkLocalOther(workLocalOther);
- msTrip.setWorkLocal(workLocal);
- msTrip.setTodayLocalOther(todayLocalOther);
- msTrip.setTodayLocal(todayLocal);
- msTrip.setIsTrip(isTrip);
- msTripMapper.updateById(msTrip);
- } else {
- msTrip = new MsTrip();
- msTrip.setTripId(suspectedId);
- msTrip.setIsTrip(isTrip);
- msTrip.setTodayLocal(todayLocal);
- msTrip.setTodayLocalOther(todayLocalOther);
- msTrip.setWorkLocal(workLocal);
- msTrip.setWorkLocalOther(workLocalOther);
- msTripMapper.insert(msTrip);
- }
- //删除行程详细
- msTripDetMapper.deleteByTripId(suspectedId);
- //添加出行详细
- if (listTripDet != null && listTripDet.size() > 0) {
- for (MsTripDet msTripDet : listTripDet) {
- MsTripDet msTripDet1 = new MsTripDet();
- msTripDet1.setTripDetId(IdWorker.getId());
- msTripDet1.setTripId(suspectedId);
- msTripDet1.setSort(msTripDet.getSort());
- msTripDet1.setStartLocal(msTripDet.getStartLocal());
- msTripDet1.setStartLocalOther(msTripDet.getStartLocalOther());
- msTripDet1.setEndLocal(msTripDet.getEndLocal());
- msTripDet1.setEndLocalOther(msTripDet.getEndLocalOther());
- msTripDet1.setTripType(msTripDet.getTripType());
- msTripDet1.setTripTypeDesp(msTripDet.getTripTypeDesp());
- msTripDet1.setTimeCreate(DateTime.now());
- msTripDet1.setUserCreate(userCreate);
- msTripDet1.setTimeUpdate(DateTime.now());
- msTripDet1.setUserUpdate(userCreate);
- msTripDetMapper.insert(msTripDet1);
- }
- }
- //更新今日日报,直接上报
- msSuspectedService.updateReport(reportId, medical, singleRoom, temperature);
- //是领域
- UptownUnit unit = uptownUnitMapper.getUptownUnitByUser(userCreate);
- if (unit != null) {
- if (unit.getUptownId() == 1238790987234L || unit.getUptownId() == 5) {
- Integer rezuitNum = msReportService.addReportLy(reportId,suspectedId,userCreate);
- if (rezuitNum == 4)
- reportId = 4L;
- }
- }
- }
- return reportId;
- }
- @Transactional(rollbackFor = Exception.class, propagation = Propagation.REQUIRED)
- public Integer deleteTrip(Long suspectedId) {
- msTripDetMapper.deleteByTripId(suspectedId);
- msTripMapper.deleteById(suspectedId);
- return 0;
- }
- //上报
- @Transactional(rollbackFor = Exception.class, propagation = Propagation.REQUIRED)
- public Integer addReportTest(Long userCreate, String reportDate) {
- List<MsReport> listReport = msReportMapper.selectByReportDate(reportDate, userCreate);
- if (listReport == null || listReport.size() == 0)
- return 0;
- //判断体温是否填写
- List<MsSuspected> listSuspected = msSuspectedMapper.selectByReportId(Long.parseLong(listReport.get(0).getReportId().toString()));
- if (listSuspected == null || listSuspected.size() == 0)
- return 3;
- else {
- for (MsSuspected msSuspected : listSuspected) {
- //体温是否填写
- if (msSuspected.getTemperature().compareTo(new BigDecimal(0)) == 0)
- return 2;
- //如果是凌云,判断出行是否填写异常
- UptownUnit unit = uptownUnitMapper.getUptownUnitByUser(userCreate);
- if (unit != null) {
- if (unit.getUptownId() == 1238790987234L || unit.getUptownId() == 5) {
- //上一天的上报记录.3天内
- List<MsSuspected> listSuspected1 = msSuspectedMapper.selectNext3Suspected(userCreate);
- if (listSuspected1 != null && listSuspected1.size() > 0) {
- if (listSuspected1.get(0).getTodayLocal() != 0 && msSuspected.getTodayLocal() != 0) {
- if (listSuspected1.get(0).getTodayLocalOther() != msSuspected.getTodayLocalOther() && listSuspected1.get(0).getTodayLocal() != msSuspected.getTodayLocal() && msSuspected.getIsTrip() == 0) {
- return 4;
- }
- }
- }
- }
- }
- }
- }
- MsReport msReport = msReportMapper.selectById(Long.parseLong(listReport.get(0).getReportId().toString()));
- if (msReport != null) {
- msReport.setReportStatus(1);
- msReport.setUserUpdate(userCreate);
- msReport.setTimeUpdate(DateTime.now());
- msReportMapper.updateById(msReport);
- }
- return 1;
- }
- }
|