jh-module-ecg/jh-module-ecg-api/src/main/java/cn/lihu/jh/module/ecg/enums/ErrorCodeConstants.java
@@ -54,4 +54,6 @@ ErrorCode CALL_NOT_EXISTS = new ErrorCode(1_010_008_000, "å«å·ä¸åå¨"); ErrorCode CHECK_TYPE_NOT_EXISTS = new ErrorCode(1_010_009_000, "æ£æ¥ç±»åä¸åå¨"); ErrorCode SEQUENCE_NOT_EXISTS = new ErrorCode(1_010_010_000, "å½å¤©åºå·ä¸åå¨"); } jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/queue/controller/admin/sequence/SequenceController.java
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,95 @@ package cn.lihu.jh.module.queue.controller.admin.sequence; import org.springframework.web.bind.annotation.*; import jakarta.annotation.Resource; import org.springframework.validation.annotation.Validated; import org.springframework.security.access.prepost.PreAuthorize; import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.Parameter; import io.swagger.v3.oas.annotations.Operation; import jakarta.validation.constraints.*; import jakarta.validation.*; import jakarta.servlet.http.*; import java.util.*; import java.io.IOException; import cn.lihu.jh.framework.common.pojo.PageParam; import cn.lihu.jh.framework.common.pojo.PageResult; import cn.lihu.jh.framework.common.pojo.CommonResult; import cn.lihu.jh.framework.common.util.object.BeanUtils; import static cn.lihu.jh.framework.common.pojo.CommonResult.success; import cn.lihu.jh.framework.excel.core.util.ExcelUtils; import cn.lihu.jh.framework.apilog.core.annotation.ApiAccessLog; import static cn.lihu.jh.framework.apilog.core.enums.OperateTypeEnum.*; import cn.lihu.jh.module.queue.controller.admin.sequence.vo.*; import cn.lihu.jh.module.queue.dal.dataobject.sequence.SequenceDO; import cn.lihu.jh.module.queue.service.sequence.SequenceService; @Tag(name = "管çåå° - å½å¤©åºå·") @RestController @RequestMapping("/queue/sequence") @Validated public class SequenceController { @Resource private SequenceService sequenceService; @PostMapping("/create") @Operation(summary = "å建å½å¤©åºå·") @PreAuthorize("@ss.hasPermission('queue:sequence:create')") public CommonResult<Integer> createSequence(@Valid @RequestBody SequenceSaveReqVO createReqVO) { return success(sequenceService.createSequence(createReqVO)); } @PutMapping("/update") @Operation(summary = "æ´æ°å½å¤©åºå·") @PreAuthorize("@ss.hasPermission('queue:sequence:update')") public CommonResult<Boolean> updateSequence(@Valid @RequestBody SequenceSaveReqVO updateReqVO) { sequenceService.updateSequence(updateReqVO); return success(true); } @DeleteMapping("/delete") @Operation(summary = "å é¤å½å¤©åºå·") @Parameter(name = "id", description = "ç¼å·", required = true) @PreAuthorize("@ss.hasPermission('queue:sequence:delete')") public CommonResult<Boolean> deleteSequence(@RequestParam("id") Integer id) { sequenceService.deleteSequence(id); return success(true); } @GetMapping("/get") @Operation(summary = "è·å¾å½å¤©åºå·") @Parameter(name = "id", description = "ç¼å·", required = true, example = "1024") @PreAuthorize("@ss.hasPermission('queue:sequence:query')") public CommonResult<SequenceRespVO> getSequence(@RequestParam("id") Integer id) { SequenceDO sequence = sequenceService.getSequence(id); return success(BeanUtils.toBean(sequence, SequenceRespVO.class)); } @GetMapping("/page") @Operation(summary = "è·å¾å½å¤©åºå·å页") @PreAuthorize("@ss.hasPermission('queue:sequence:query')") public CommonResult<PageResult<SequenceRespVO>> getSequencePage(@Valid SequencePageReqVO pageReqVO) { PageResult<SequenceDO> pageResult = sequenceService.getSequencePage(pageReqVO); return success(BeanUtils.toBean(pageResult, SequenceRespVO.class)); } @GetMapping("/export-excel") @Operation(summary = "导åºå½å¤©åºå· Excel") @PreAuthorize("@ss.hasPermission('queue:sequence:export')") @ApiAccessLog(operateType = EXPORT) public void exportSequenceExcel(@Valid SequencePageReqVO pageReqVO, HttpServletResponse response) throws IOException { pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE); List<SequenceDO> list = sequenceService.getSequencePage(pageReqVO).getList(); // å¯¼åº Excel ExcelUtils.write(response, "å½å¤©åºå·.xls", "æ°æ®", SequenceRespVO.class, BeanUtils.toBean(list, SequenceRespVO.class)); } } jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/queue/controller/admin/sequence/vo/SequencePageReqVO.java
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,40 @@ package cn.lihu.jh.module.queue.controller.admin.sequence.vo; import lombok.*; import java.util.*; import io.swagger.v3.oas.annotations.media.Schema; import cn.lihu.jh.framework.common.pojo.PageParam; import org.springframework.format.annotation.DateTimeFormat; import java.time.LocalDateTime; import static cn.lihu.jh.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND; @Schema(description = "管çåå° - å½å¤©åºå·å页 Request VO") @Data @EqualsAndHashCode(callSuper = true) @ToString(callSuper = true) public class SequencePageReqVO extends PageParam { @Schema(description = "æ£æ¥ç±»å", example = "2") private Integer checkType; @Schema(description = "æ¶æ®µ") private Integer timeSlot; @Schema(description = "è¯¥æ¶æ®µ æ®éæ£è åºå·") private Integer queueNo; @Schema(description = "è¯¥æ¶æ®µ vip åºå·") private Integer queueVipNo; @Schema(description = "è¯¥æ¶æ®µ æ®éæ£è åºå·æ»¡") private Integer queueFull; @Schema(description = "è¯¥æ¶æ®µ vip åºå·æ»¡") private Integer queueVipFull; @Schema(description = "å建æ¶é´") @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND) private LocalDateTime[] createTime; } jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/queue/controller/admin/sequence/vo/SequenceRespVO.java
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,47 @@ package cn.lihu.jh.module.queue.controller.admin.sequence.vo; import io.swagger.v3.oas.annotations.media.Schema; import lombok.*; import java.util.*; import org.springframework.format.annotation.DateTimeFormat; import java.time.LocalDateTime; import com.alibaba.excel.annotation.*; @Schema(description = "管çåå° - å½å¤©åºå· Response VO") @Data @ExcelIgnoreUnannotated public class SequenceRespVO { @Schema(description = "DB 主é®", requiredMode = Schema.RequiredMode.REQUIRED, example = "11958") @ExcelProperty("DB 主é®") private Integer id; @Schema(description = "æ£æ¥ç±»å", example = "2") @ExcelProperty("æ£æ¥ç±»å") private Integer checkType; @Schema(description = "æ¶æ®µ") @ExcelProperty("æ¶æ®µ") private Integer timeSlot; @Schema(description = "è¯¥æ¶æ®µ æ®éæ£è åºå·") @ExcelProperty("è¯¥æ¶æ®µ æ®éæ£è åºå·") private Integer queueNo; @Schema(description = "è¯¥æ¶æ®µ vip åºå·") @ExcelProperty("è¯¥æ¶æ®µ vip åºå·") private Integer queueVipNo; @Schema(description = "è¯¥æ¶æ®µ æ®éæ£è åºå·æ»¡") @ExcelProperty("è¯¥æ¶æ®µ æ®éæ£è åºå·æ»¡") private Integer queueFull; @Schema(description = "è¯¥æ¶æ®µ vip åºå·æ»¡") @ExcelProperty("è¯¥æ¶æ®µ vip åºå·æ»¡") private Integer queueVipFull; @Schema(description = "å建æ¶é´", requiredMode = Schema.RequiredMode.REQUIRED) @ExcelProperty("å建æ¶é´") private LocalDateTime createTime; } jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/queue/controller/admin/sequence/vo/SequenceSaveReqVO.java
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,33 @@ package cn.lihu.jh.module.queue.controller.admin.sequence.vo; import io.swagger.v3.oas.annotations.media.Schema; import lombok.*; import java.util.*; import jakarta.validation.constraints.*; @Schema(description = "管çåå° - å½å¤©åºå·æ°å¢/ä¿®æ¹ Request VO") @Data public class SequenceSaveReqVO { @Schema(description = "DB 主é®", requiredMode = Schema.RequiredMode.REQUIRED, example = "11958") private Integer id; @Schema(description = "æ£æ¥ç±»å", example = "2") private Integer checkType; @Schema(description = "æ¶æ®µ") private Integer timeSlot; @Schema(description = "è¯¥æ¶æ®µ æ®éæ£è åºå·") private Integer queueNo; @Schema(description = "è¯¥æ¶æ®µ vip åºå·") private Integer queueVipNo; @Schema(description = "è¯¥æ¶æ®µ æ®éæ£è åºå·æ»¡") private Integer queueFull; @Schema(description = "è¯¥æ¶æ®µ vip åºå·æ»¡") private Integer queueVipFull; } jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/queue/dal/dataobject/sequence/SequenceDO.java
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,55 @@ package cn.lihu.jh.module.queue.dal.dataobject.sequence; import lombok.*; import java.util.*; import java.time.LocalDateTime; import java.time.LocalDateTime; import com.baomidou.mybatisplus.annotation.*; import cn.lihu.jh.framework.mybatis.core.dataobject.BaseDO; /** * å½å¤©åºå· DO * * @author éåå»é¢ */ @TableName("queue_sequence") @KeySequence("queue_sequence_seq") // ç¨äº OracleãPostgreSQLãKingbaseãDB2ãH2 æ°æ®åºç主é®èªå¢ãå¦ææ¯ MySQL çæ°æ®åºï¼å¯ä¸åã @Data @EqualsAndHashCode(callSuper = true) @ToString(callSuper = true) @Builder @NoArgsConstructor @AllArgsConstructor public class SequenceDO extends BaseDO { /** * DB ä¸»é® */ @TableId private Integer id; /** * æ£æ¥ç±»å */ private Integer checkType; /** * æ¶æ®µ */ private Integer timeSlot; /** * è¯¥æ¶æ®µ æ®éæ£è åºå· */ private Integer queueNo; /** * è¯¥æ¶æ®µ vip åºå· */ private Integer queueVipNo; /** * è¯¥æ¶æ®µ æ®éæ£è åºå·æ»¡ */ private Integer queueFull; /** * è¯¥æ¶æ®µ vip åºå·æ»¡ */ private Integer queueVipFull; } jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/queue/dal/mysql/sequence/SequenceMapper.java
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,32 @@ package cn.lihu.jh.module.queue.dal.mysql.sequence; import java.util.*; import cn.lihu.jh.framework.common.pojo.PageResult; import cn.lihu.jh.framework.mybatis.core.query.LambdaQueryWrapperX; import cn.lihu.jh.framework.mybatis.core.mapper.BaseMapperX; import cn.lihu.jh.module.queue.dal.dataobject.sequence.SequenceDO; import org.apache.ibatis.annotations.Mapper; import cn.lihu.jh.module.queue.controller.admin.sequence.vo.*; /** * å½å¤©åºå· Mapper * * @author éåå»é¢ */ @Mapper public interface SequenceMapper extends BaseMapperX<SequenceDO> { default PageResult<SequenceDO> selectPage(SequencePageReqVO reqVO) { return selectPage(reqVO, new LambdaQueryWrapperX<SequenceDO>() .eqIfPresent(SequenceDO::getCheckType, reqVO.getCheckType()) .eqIfPresent(SequenceDO::getTimeSlot, reqVO.getTimeSlot()) .eqIfPresent(SequenceDO::getQueueNo, reqVO.getQueueNo()) .eqIfPresent(SequenceDO::getQueueVipNo, reqVO.getQueueVipNo()) .eqIfPresent(SequenceDO::getQueueFull, reqVO.getQueueFull()) .eqIfPresent(SequenceDO::getQueueVipFull, reqVO.getQueueVipFull()) .betweenIfPresent(SequenceDO::getCreateTime, reqVO.getCreateTime()) .orderByDesc(SequenceDO::getId)); } } jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/queue/service/sequence/SequenceService.java
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,55 @@ package cn.lihu.jh.module.queue.service.sequence; import java.util.*; import jakarta.validation.*; import cn.lihu.jh.module.queue.controller.admin.sequence.vo.*; import cn.lihu.jh.module.queue.dal.dataobject.sequence.SequenceDO; import cn.lihu.jh.framework.common.pojo.PageResult; import cn.lihu.jh.framework.common.pojo.PageParam; /** * å½å¤©åºå· Service æ¥å£ * * @author éåå»é¢ */ public interface SequenceService { /** * å建å½å¤©åºå· * * @param createReqVO åå»ºä¿¡æ¯ * @return ç¼å· */ Integer createSequence(@Valid SequenceSaveReqVO createReqVO); /** * æ´æ°å½å¤©åºå· * * @param updateReqVO æ´æ°ä¿¡æ¯ */ void updateSequence(@Valid SequenceSaveReqVO updateReqVO); /** * å é¤å½å¤©åºå· * * @param id ç¼å· */ void deleteSequence(Integer id); /** * è·å¾å½å¤©åºå· * * @param id ç¼å· * @return å½å¤©åºå· */ SequenceDO getSequence(Integer id); /** * è·å¾å½å¤©åºå·å页 * * @param pageReqVO å页æ¥è¯¢ * @return å½å¤©åºå·å页 */ PageResult<SequenceDO> getSequencePage(SequencePageReqVO pageReqVO); } jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/queue/service/sequence/SequenceServiceImpl.java
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,74 @@ package cn.lihu.jh.module.queue.service.sequence; import org.springframework.stereotype.Service; import jakarta.annotation.Resource; import org.springframework.validation.annotation.Validated; import org.springframework.transaction.annotation.Transactional; import java.util.*; import cn.lihu.jh.module.queue.controller.admin.sequence.vo.*; import cn.lihu.jh.module.queue.dal.dataobject.sequence.SequenceDO; import cn.lihu.jh.framework.common.pojo.PageResult; import cn.lihu.jh.framework.common.pojo.PageParam; import cn.lihu.jh.framework.common.util.object.BeanUtils; import cn.lihu.jh.module.queue.dal.mysql.sequence.SequenceMapper; import static cn.lihu.jh.framework.common.exception.util.ServiceExceptionUtil.exception; import static cn.lihu.jh.module.queue.enums.ErrorCodeConstants.*; /** * å½å¤©åºå· Service å®ç°ç±» * * @author éåå»é¢ */ @Service @Validated public class SequenceServiceImpl implements SequenceService { @Resource private SequenceMapper sequenceMapper; @Override public Integer createSequence(SequenceSaveReqVO createReqVO) { // æå ¥ SequenceDO sequence = BeanUtils.toBean(createReqVO, SequenceDO.class); sequenceMapper.insert(sequence); // è¿å return sequence.getId(); } @Override public void updateSequence(SequenceSaveReqVO updateReqVO) { // æ ¡éªåå¨ validateSequenceExists(updateReqVO.getId()); // æ´æ° SequenceDO updateObj = BeanUtils.toBean(updateReqVO, SequenceDO.class); sequenceMapper.updateById(updateObj); } @Override public void deleteSequence(Integer id) { // æ ¡éªåå¨ validateSequenceExists(id); // å é¤ sequenceMapper.deleteById(id); } private void validateSequenceExists(Integer id) { if (sequenceMapper.selectById(id) == null) { throw exception(SEQUENCE_NOT_EXISTS); } } @Override public SequenceDO getSequence(Integer id) { return sequenceMapper.selectById(id); } @Override public PageResult<SequenceDO> getSequencePage(SequencePageReqVO pageReqVO) { return sequenceMapper.selectPage(pageReqVO); } } jh-module-ecg/jh-module-ecg-biz/src/main/resources/mapper/sequence/SequenceMapper.xml
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,12 @@ <?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="cn.lihu.jh.module.queue.dal.mysql.sequence.SequenceMapper"> <!-- ä¸è¬æ åµä¸ï¼å°½å¯è½ä½¿ç¨ Mapper è¿è¡ CRUD å¢å æ¹æ¥å³å¯ã æ æ³æ»¡è¶³çåºæ¯ï¼ä¾å¦è¯´å¤è¡¨å ³èæ¥è¯¢ï¼æä½¿ç¨ XML ç¼å SQLã 代ç çæå¨ææ¶åªçæ Mapper XML æä»¶æ¬èº«ï¼æ´å¤æ¨è MybatisX å¿«éå¼åæä»¶æ¥çææ¥è¯¢ã ææ¡£å¯è§ï¼https://www.iocoder.cn/MyBatis/x-plugins/ --> </mapper>