From 4b278300e8b3b1faabd5d080990cd3124f68612c Mon Sep 17 00:00:00 2001 From: eight <641137800@qq.com> Date: 星期二, 26 十一月 2024 13:09:28 +0800 Subject: [PATCH] 会取下一个时段的序号 --- jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java | 96 +++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 91 insertions(+), 5 deletions(-) diff --git a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java index 4216715..d48bf41 100644 --- a/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java +++ b/jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/queuesequence/QueueSequenceServiceImpl.java @@ -4,6 +4,8 @@ import cn.lihu.jh.module.ecg.dal.dataobject.checktype.CheckTypeDO; import cn.lihu.jh.module.ecg.dal.mysql.checktype.CheckTypeMapper; import cn.lihu.jh.module.infra.api.config.ConfigApi; +import cn.lihu.jh.module.system.api.dict.DictDataApi; +import cn.lihu.jh.module.system.api.dict.dto.DictDataRespDTO; import org.springframework.stereotype.Service; import org.springframework.validation.annotation.Validated; import org.springframework.transaction.annotation.Transactional; @@ -37,10 +39,22 @@ private ConfigApi configApi; @Resource + private DictDataApi dictDataApi; + + @Resource private QueueSequenceMapper queueSequenceMapper; @Resource private CheckTypeMapper checkTypeMapper; + + @Override + public void initQueueSequenceTable() { + queueSequenceMapper.clearQueueSequenceTableNotCurrent(); + Integer rowCount = queueSequenceMapper.getQueueSequenceTableRowCount(); + if (null == rowCount || 0 == rowCount) { + resetQueueSequence(); + } + } @Override public Integer createQueueSequence(QueueSequenceSaveReqVO createReqVO) { @@ -80,6 +94,11 @@ } @Override + public List<QueueSequenceDO> selectGivenCheckTypeTimeslot(Integer checkType) { + return queueSequenceMapper.selectTimeslotByCheckType( checkType ); + } + + @Override public PageResult<QueueSequenceDO> getQueueSequencePage(QueueSequencePageReqVO pageReqVO) { return queueSequenceMapper.selectPage(pageReqVO); } @@ -90,17 +109,21 @@ // 璇诲彇鏃舵閰嶇疆 String strBookTimeslotLength = configApi.getConfigValueByKey(BOOK_TIMESLOT_LENGTH); - String strBookTimeslotList = configApi.getConfigValueByKey(BOOK_TIMESLOT_LIST); + + // 鏂规1锛氶厤缃腑鍙� 7:30,8:30,9:30,10:30,11:30,12:30,13:30,14:30,15:30 + //String strBookTimeslotList = configApi.getConfigValueByKey(BOOK_TIMESLOT_LIST); + //List<LocalTime> timeslotList = Utils.parseTimeSlotList(strBookTimeslotList, Integer.valueOf(strBookTimeslotLength)); + + List<DictDataRespDTO> dictBookTimeslotList = dictDataApi.getDictDataList(ECG_BOOK_TIMESLOT); // 璇诲彇鎵�鏈夌殑妫�鏌ョ被鍨� List<CheckTypeDO> checkTypeDOList = checkTypeMapper.simpleCheckTypeList(); checkTypeDOList.forEach( checkTypeDO -> { - List<LocalTime> timeslotList = Utils.parseTimeSlotList(strBookTimeslotList, Integer.valueOf(strBookTimeslotLength)); - for (int i=0; i < timeslotList.size(); i++) { - LocalTime timeslot = timeslotList.get(i); + + for (int i=0; i < dictBookTimeslotList.size(); i++) { QueueSequenceDO queueSequenceDO = new QueueSequenceDO(); queueSequenceDO.setCheckType( checkTypeDO.getValue() ); - queueSequenceDO.setTimeSlot( timeslot.getHour()*100 + timeslot.getMinute() ); + queueSequenceDO.setTimeSlot( Integer.valueOf(dictBookTimeslotList.get(i).getValue()) ); queueSequenceDO.setQueueNo( i * checkTypeDO.getTimeslotBookNum() + checkTypeDO.getTimeslotReservedNum()); queueSequenceDO.setQueueVipNo( i * checkTypeDO.getTimeslotBookNum()); queueSequenceDO.setQueueFull( i * checkTypeDO.getTimeslotBookNum() + checkTypeDO.getTimeslotBookNum()); @@ -110,5 +133,68 @@ }); } + @Override + @Transactional + public Integer distributeSeqNo(Integer checkType, Integer timeslot) { + Integer curSeqNo = queueSequenceMapper.selectQueueNoForUpdate(checkType, timeslot); + if (null == curSeqNo) { + // 浠庝笅涓�涓椂娈� 鑾峰彇搴忓彿銆傚師鍥犵郴缁熺敤30鍒嗛挓鐨勯棿闅斿垝鍒嗛绾︽椂闂存锛孒IS鐨勯绾︽椂闂存鍙兘鏄�30鍒嗛挓鎴�60鍒嗛挓 + Integer nextTimeslot = getNextTimeSlot(timeslot, checkType); + if (null == nextTimeslot) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_FULL); + } + + curSeqNo = queueSequenceMapper.selectQueueNoForUpdate(checkType, nextTimeslot); + if (null == curSeqNo) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_FULL); + } + + Integer updateRowNum = queueSequenceMapper.updateGivenCheckTypeTimeslotSeqNo(checkType, nextTimeslot, curSeqNo); + if (null == updateRowNum || updateRowNum == 0) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_EXCEPTION); + } + + } else { + Integer updateRowNum = queueSequenceMapper.updateGivenCheckTypeTimeslotSeqNo(checkType, timeslot, curSeqNo); + if (null == updateRowNum || updateRowNum == 0) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_EXCEPTION); + } + } + + return curSeqNo + 1; + } + + @Override + @Transactional + public Integer distributeVipSeqNo(Integer checkType, Integer timeslot) { + Integer curVipSeqNo = queueSequenceMapper.selectQueueVipNoForUpdate(checkType, timeslot); + if (null == curVipSeqNo) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_FULL); + } + + Integer updateRowNum = queueSequenceMapper.updateGivenCheckTypeTimeslotVipSeqNo(checkType, timeslot, curVipSeqNo); + if (null == updateRowNum || updateRowNum == 0) { + throw exception(QUEUE_SEQUENCE_TIMESLOT_EXCEPTION); + } + + return curVipSeqNo + 1; + } + + private Integer getNextTimeSlot(Integer timeslot, Integer checkType) { + List<DictDataRespDTO> dictBookTimeslotList = dictDataApi.getDictDataList(ECG_BOOK_TIMESLOT); + Optional<Integer> index = dictBookTimeslotList.stream() + .filter(e -> e.getValue().equals(String.valueOf(timeslot))) + .findFirst() + .map(dictBookTimeslotList::indexOf); + if (!index.isPresent()) + return null; + + if (dictBookTimeslotList.size() <= (index.get() + 1)) + return null; + + DictDataRespDTO dictDataRespDTO = dictBookTimeslotList.get(index.get() + 1); + return Integer.valueOf(dictDataRespDTO.getValue()); + } + } -- Gitblit v1.9.3