eight
2024-09-06 857372192248bd9daf6fdf5906c7621555b21cc6
设备型号功能
已添加9个文件
已修改2个文件
404 ■■■■■ 文件已修改
jh-module-ecg/jh-module-ecg-api/src/main/java/cn/lihu/jh/module/ecg/enums/ErrorCodeConstants.java 2 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devmanage/DevModelController.java 95 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devmanage/vo/DevModelPageReqVO.java 31 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devmanage/vo/DevModelRespVO.java 35 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devmanage/vo/DevModelSaveReqVO.java 27 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/dataobject/devmanage/DevModelDO.java 43 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/devmanage/DevModelMapper.java 29 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/devmanage/DevModelService.java 54 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/devmanage/DevModelServiceImpl.java 72 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-biz/src/main/resources/mapper/devmanage/DevModelMapper.xml 12 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
sql/mysql/jh.sql 4 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
jh-module-ecg/jh-module-ecg-api/src/main/java/cn/lihu/jh/module/ecg/enums/ErrorCodeConstants.java
@@ -22,4 +22,6 @@
    ErrorCode QUEUE_HAVE_PATIENT = new ErrorCode(1_010_003_002, "队列中有患者");
    ErrorCode QUEUE_NOT_READY_PATIENT = new ErrorCode(1_010_003_003, "没有准备中的患者");
    ErrorCode PATIENT_NOT_EXISTS = new ErrorCode(1_010_004_000, "患者不存在");
    ErrorCode DEV_MODEL_NOT_EXISTS = new ErrorCode(1_010_005_000, "设备型号不存在");
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devmanage/DevModelController.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,95 @@
package cn.lihu.jh.module.ecg.controller.admin.devmanage;
import org.springframework.web.bind.annotation.*;
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 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.ecg.controller.admin.devmanage.vo.*;
import cn.lihu.jh.module.ecg.dal.dataobject.devmanage.DevModelDO;
import cn.lihu.jh.module.ecg.service.devmanage.DevModelService;
import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid;
@Tag(name = "管理后台 - è®¾å¤‡åž‹å·")
@RestController
@RequestMapping("/ecg/dev-model")
@Validated
public class DevModelController {
    @Resource
    private DevModelService devModelService;
    @PostMapping("/create")
    @Operation(summary = "创建设备型号")
    @PreAuthorize("@ss.hasPermission('ecg:dev-model:create')")
    public CommonResult<Integer> createDevModel(@Valid @RequestBody DevModelSaveReqVO createReqVO) {
        return success(devModelService.createDevModel(createReqVO));
    }
    @PutMapping("/update")
    @Operation(summary = "更新设备型号")
    @PreAuthorize("@ss.hasPermission('ecg:dev-model:update')")
    public CommonResult<Boolean> updateDevModel(@Valid @RequestBody DevModelSaveReqVO updateReqVO) {
        devModelService.updateDevModel(updateReqVO);
        return success(true);
    }
    @DeleteMapping("/delete")
    @Operation(summary = "删除设备型号")
    @Parameter(name = "id", description = "编号", required = true)
    @PreAuthorize("@ss.hasPermission('ecg:dev-model:delete')")
    public CommonResult<Boolean> deleteDevModel(@RequestParam("id") Integer id) {
        devModelService.deleteDevModel(id);
        return success(true);
    }
    @GetMapping("/get")
    @Operation(summary = "获得设备型号")
    @Parameter(name = "id", description = "编号", required = true, example = "1024")
    @PreAuthorize("@ss.hasPermission('ecg:dev-model:query')")
    public CommonResult<DevModelRespVO> getDevModel(@RequestParam("id") Integer id) {
        DevModelDO devModel = devModelService.getDevModel(id);
        return success(BeanUtils.toBean(devModel, DevModelRespVO.class));
    }
    @GetMapping("/page")
    @Operation(summary = "获得设备型号分页")
    @PreAuthorize("@ss.hasPermission('ecg:dev-model:query')")
    public CommonResult<PageResult<DevModelRespVO>> getDevModelPage(@Valid DevModelPageReqVO pageReqVO) {
        PageResult<DevModelDO> pageResult = devModelService.getDevModelPage(pageReqVO);
        return success(BeanUtils.toBean(pageResult, DevModelRespVO.class));
    }
    @GetMapping("/export-excel")
    @Operation(summary = "导出设备型号 Excel")
    @PreAuthorize("@ss.hasPermission('ecg:dev-model:export')")
    @ApiAccessLog(operateType = EXPORT)
    public void exportDevModelExcel(@Valid DevModelPageReqVO pageReqVO,
              HttpServletResponse response) throws IOException {
        pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
        List<DevModelDO> list = devModelService.getDevModelPage(pageReqVO).getList();
        // å¯¼å‡º Excel
        ExcelUtils.write(response, "设备型号.xls", "数据", DevModelRespVO.class,
                        BeanUtils.toBean(list, DevModelRespVO.class));
    }
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devmanage/vo/DevModelPageReqVO.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,31 @@
package cn.lihu.jh.module.ecg.controller.admin.devmanage.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 DevModelPageReqVO extends PageParam {
    @Schema(description = "分类名")
    private String category;
    @Schema(description = "品牌")
    private String brand;
    @Schema(description = "型号")
    private String model;
    @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/ecg/controller/admin/devmanage/vo/DevModelRespVO.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,35 @@
package cn.lihu.jh.module.ecg.controller.admin.devmanage.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 DevModelRespVO {
    @Schema(description = "id", requiredMode = Schema.RequiredMode.REQUIRED, example = "14922")
    @ExcelProperty("id")
    private Integer id;
    @Schema(description = "分类名", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("分类名")
    private String category;
    @Schema(description = "品牌", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("品牌")
    private String brand;
    @Schema(description = "型号", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("型号")
    private String model;
    @Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("创建时间")
    private LocalDateTime createTime;
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/controller/admin/devmanage/vo/DevModelSaveReqVO.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,27 @@
package cn.lihu.jh.module.ecg.controller.admin.devmanage.vo;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import javax.validation.constraints.NotEmpty;
import javax.validation.constraints.NotNull;
@Schema(description = "管理后台 - è®¾å¤‡åž‹å·æ–°å¢ž/修改 Request VO")
@Data
public class DevModelSaveReqVO {
    private Integer id;
    @Schema(description = "分类名", requiredMode = Schema.RequiredMode.REQUIRED)
    @NotEmpty(message = "分类名不能为空")
    private String category;
    @Schema(description = "品牌", requiredMode = Schema.RequiredMode.REQUIRED)
    @NotEmpty(message = "品牌不能为空")
    private String brand;
    @Schema(description = "型号", requiredMode = Schema.RequiredMode.REQUIRED)
    @NotEmpty(message = "型号不能为空")
    private String model;
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/dataobject/devmanage/DevModelDO.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,43 @@
package cn.lihu.jh.module.ecg.dal.dataobject.devmanage;
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 majianbo
 */
@TableName("device_model")
@KeySequence("device_model_seq") // ç”¨äºŽ Oracle、PostgreSQL、Kingbase、DB2、H2 æ•°æ®åº“的主键自增。如果是 MySQL ç­‰æ•°æ®åº“,可不写。
@Data
@EqualsAndHashCode(callSuper = true)
@ToString(callSuper = true)
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class DevModelDO extends BaseDO {
    /**
     * id
     */
    @TableId
    private Integer id;
    /**
     * åˆ†ç±»å
     */
    private String category;
    /**
     * å“ç‰Œ
     */
    private String brand;
    /**
     * åž‹å·
     */
    private String model;
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/dal/mysql/devmanage/DevModelMapper.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,29 @@
package cn.lihu.jh.module.ecg.dal.mysql.devmanage;
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.ecg.dal.dataobject.devmanage.DevModelDO;
import org.apache.ibatis.annotations.Mapper;
import cn.lihu.jh.module.ecg.controller.admin.devmanage.vo.*;
/**
 * è®¾å¤‡åž‹å· Mapper
 *
 * @author majianbo
 */
@Mapper
public interface DevModelMapper extends BaseMapperX<DevModelDO> {
    default PageResult<DevModelDO> selectPage(DevModelPageReqVO reqVO) {
        return selectPage(reqVO, new LambdaQueryWrapperX<DevModelDO>()
                .eqIfPresent(DevModelDO::getCategory, reqVO.getCategory())
                .eqIfPresent(DevModelDO::getBrand, reqVO.getBrand())
                .eqIfPresent(DevModelDO::getModel, reqVO.getModel())
                .betweenIfPresent(DevModelDO::getCreateTime, reqVO.getCreateTime())
                .orderByDesc(DevModelDO::getId));
    }
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/devmanage/DevModelService.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,54 @@
package cn.lihu.jh.module.ecg.service.devmanage;
import cn.lihu.jh.module.ecg.controller.admin.devmanage.vo.*;
import cn.lihu.jh.module.ecg.dal.dataobject.devmanage.DevModelDO;
import cn.lihu.jh.framework.common.pojo.PageResult;
import javax.validation.Valid;
/**
 * è®¾å¤‡åž‹å· Service æŽ¥å£
 *
 * @author majianbo
 */
public interface DevModelService {
    /**
     * åˆ›å»ºè®¾å¤‡åž‹å·
     *
     * @param createReqVO åˆ›å»ºä¿¡æ¯
     * @return ç¼–号
     */
    Integer createDevModel(@Valid DevModelSaveReqVO createReqVO);
    /**
     * æ›´æ–°è®¾å¤‡åž‹å·
     *
     * @param updateReqVO æ›´æ–°ä¿¡æ¯
     */
    void updateDevModel(@Valid DevModelSaveReqVO updateReqVO);
    /**
     * åˆ é™¤è®¾å¤‡åž‹å·
     *
     * @param id ç¼–号
     */
    void deleteDevModel(Integer id);
    /**
     * èŽ·å¾—è®¾å¤‡åž‹å·
     *
     * @param id ç¼–号
     * @return è®¾å¤‡åž‹å·
     */
    DevModelDO getDevModel(Integer id);
    /**
     * èŽ·å¾—è®¾å¤‡åž‹å·åˆ†é¡µ
     *
     * @param pageReqVO åˆ†é¡µæŸ¥è¯¢
     * @return è®¾å¤‡åž‹å·åˆ†é¡µ
     */
    PageResult<DevModelDO> getDevModelPage(DevModelPageReqVO pageReqVO);
}
jh-module-ecg/jh-module-ecg-biz/src/main/java/cn/lihu/jh/module/ecg/service/devmanage/DevModelServiceImpl.java
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,72 @@
package cn.lihu.jh.module.ecg.service.devmanage;
import org.springframework.stereotype.Service;
import org.springframework.validation.annotation.Validated;
import cn.lihu.jh.module.ecg.controller.admin.devmanage.vo.*;
import cn.lihu.jh.module.ecg.dal.dataobject.devmanage.DevModelDO;
import cn.lihu.jh.framework.common.pojo.PageResult;
import cn.lihu.jh.framework.common.util.object.BeanUtils;
import cn.lihu.jh.module.ecg.dal.mysql.devmanage.DevModelMapper;
import javax.annotation.Resource;
import static cn.lihu.jh.framework.common.exception.util.ServiceExceptionUtil.exception;
import static cn.lihu.jh.module.ecg.enums.ErrorCodeConstants.*;
/**
 * è®¾å¤‡åž‹å· Service å®žçŽ°ç±»
 *
 * @author majianbo
 */
@Service
@Validated
public class DevModelServiceImpl implements DevModelService {
    @Resource
    private DevModelMapper devModelMapper;
    @Override
    public Integer createDevModel(DevModelSaveReqVO createReqVO) {
        // æ’å…¥
        DevModelDO devModel = BeanUtils.toBean(createReqVO, DevModelDO.class);
        devModelMapper.insert(devModel);
        // è¿”回
        return devModel.getId();
    }
    @Override
    public void updateDevModel(DevModelSaveReqVO updateReqVO) {
        // æ ¡éªŒå­˜åœ¨
        validateDevModelExists(updateReqVO.getId());
        // æ›´æ–°
        DevModelDO updateObj = BeanUtils.toBean(updateReqVO, DevModelDO.class);
        devModelMapper.updateById(updateObj);
    }
    @Override
    public void deleteDevModel(Integer id) {
        // æ ¡éªŒå­˜åœ¨
        validateDevModelExists(id);
        // åˆ é™¤
        devModelMapper.deleteById(id);
    }
    private void validateDevModelExists(Integer id) {
        if (devModelMapper.selectById(id) == null) {
            throw exception(DEV_MODEL_NOT_EXISTS);
        }
    }
    @Override
    public DevModelDO getDevModel(Integer id) {
        return devModelMapper.selectById(id);
    }
    @Override
    public PageResult<DevModelDO> getDevModelPage(DevModelPageReqVO pageReqVO) {
        return devModelMapper.selectPage(pageReqVO);
    }
}
jh-module-ecg/jh-module-ecg-biz/src/main/resources/mapper/devmanage/DevModelMapper.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.ecg.dal.mysql.devmanage.DevModelMapper">
    <!--
        ä¸€èˆ¬æƒ…况下,尽可能使用 Mapper è¿›è¡Œ CRUD å¢žåˆ æ”¹æŸ¥å³å¯ã€‚
        æ— æ³•满足的场景,例如说多表关联查询,才使用 XML ç¼–写 SQL。
        ä»£ç ç”Ÿæˆå™¨æš‚时只生成 Mapper XML æ–‡ä»¶æœ¬èº«ï¼Œæ›´å¤šæŽ¨è MybatisX å¿«é€Ÿå¼€å‘插件来生成查询。
        æ–‡æ¡£å¯è§ï¼šhttps://www.iocoder.cn/MyBatis/x-plugins/
     -->
</mapper>
sql/mysql/jh.sql
@@ -99,12 +99,14 @@
-- ----------------------------
DROP TABLE IF EXISTS `device_model`;
CREATE TABLE `device_model` (
  `id` int NOT NULL COMMENT 'id',
  `id` int NOT NULL AUTO_INCREMENT COMMENT 'id',
  `category` varchar(45) DEFAULT NULL COMMENT '分类名',
  `brand` varchar(45) DEFAULT NULL COMMENT '品牌',
  `model` varchar(45) DEFAULT NULL COMMENT '型号',
  `tenant_id` int DEFAULT 1 COMMENT '租户编号',
  `creator` varchar(10) DEFAULT '' COMMENT '创建者',
  `create_time` datetime NOT NULL COMMENT '创建时间',
  `updater` varchar(10) DEFAULT '' COMMENT '更新者',
  `update_time` datetime NOT NULL COMMENT '更新时间',
  `deleted` bit(1) DEFAULT 0 COMMENT '删除标记',
  PRIMARY KEY (`id`)