Explorar el Código

预案管理相关接口开发

jichaobo hace 2 años
padre
commit
f5a8faee58

+ 1 - 1
service-fire/service-fire-biz/src/main/java/com/usky/fire/controller/MybatisGeneratorUtils.java

@@ -71,7 +71,7 @@ public class MybatisGeneratorUtils {
         // strategy.setTablePrefix("t_"); // 表名前缀
         strategy.setEntityLombokModel(true); //使用lombok
         //修改自己想要生成的表
-        strategy.setInclude("base_model");  // 逆向工程使用的表   如果要生成多个,这里可以传入String[]
+        strategy.setInclude("reserve_plan");  // 逆向工程使用的表   如果要生成多个,这里可以传入String[]
         mpg.setStrategy(strategy);
 
         // 关闭默认 xml 生成,调整生成 至 根目录

+ 86 - 0
service-fire/service-fire-biz/src/main/java/com/usky/fire/controller/web/ReservePlanController.java

@@ -0,0 +1,86 @@
+package com.usky.fire.controller.web;
+
+
+import com.usky.common.core.bean.ApiResult;
+import com.usky.common.core.bean.CommonPage;
+import com.usky.common.log.annotation.Log;
+import com.usky.common.log.enums.BusinessType;
+import com.usky.fire.domain.ReservePlan;
+import com.usky.fire.service.ReservePlanService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+/**
+ * <p>
+ * 预案管理 前端控制器
+ * </p>
+ *
+ * @author JCB
+ * @since 2022-09-05
+ */
+@RestController
+@RequestMapping("/reservePlan")
+public class ReservePlanController {
+
+    @Autowired
+    private ReservePlanService reservePlanService;
+
+    /**
+     * 预案管理-列表查询
+     *
+     * @param reserveName 预案名称
+     * @param startDate   开始时间 格式:yyyy-MM-dd HH:mm:ss
+     * @param endDate     结束时间 格式:yyyy-MM-dd HH:mm:ss
+     * @param pageNum     当前页
+     * @param pageSize    每页条数
+     * @return
+     */
+    @GetMapping("reservePlanDataList")
+    public ApiResult<CommonPage<Object>> reservePlanDataList(@RequestParam(value = "reserveName", required = false) String reserveName,
+                                                             @RequestParam(value = "startDate", required = false) String startDate,
+                                                             @RequestParam(value = "endDate", required = false) String endDate,
+                                                             @RequestParam(value = "pageNum", required = false, defaultValue = "1") Integer pageNum,
+                                                             @RequestParam(value = "pageSize", required = false, defaultValue = "10") Integer pageSize) {
+        return ApiResult.success(reservePlanService.reservePlanDataList(reserveName, startDate, endDate, pageNum, pageSize));
+    }
+
+    /**
+     * 预案管理-信息新增
+     *
+     * @param reservePlan
+     * @return
+     */
+    @Log(title = "预案管理-信息新增", businessType = BusinessType.INSERT)
+    @PutMapping("reservePlanDataAdd")
+    public ApiResult<Void> reservePlanDataAdd(@RequestBody ReservePlan reservePlan) {
+        reservePlanService.reservePlanDataAdd(reservePlan);
+        return ApiResult.success();
+    }
+
+    /**
+     * 预案管理-信息编辑
+     *
+     * @param reservePlan
+     * @return
+     */
+    @Log(title = "预案管理-信息编辑", businessType = BusinessType.UPDATE)
+    @PutMapping("reservePlanDataUpdate")
+    public ApiResult<Void> reservePlanDataUpdate(@RequestBody ReservePlan reservePlan) {
+        reservePlanService.reservePlanDataUpdate(reservePlan);
+        return ApiResult.success();
+    }
+
+    /**
+     * 预案管理-信息删除
+     *
+     * @param id 主键ID
+     * @return
+     */
+    @Log(title = "预案管理-信息删除", businessType = BusinessType.DELETE)
+    @DeleteMapping("reservePlanDataDelete")
+    public ApiResult<Void> reservePlanDataDelete(@RequestParam(value = "id") Integer id) {
+        reservePlanService.reservePlanDataDelete(id);
+        return ApiResult.success();
+    }
+}
+

+ 76 - 0
service-fire/service-fire-biz/src/main/java/com/usky/fire/domain/ReservePlan.java

@@ -0,0 +1,76 @@
+package com.usky.fire.domain;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableId;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+
+import java.io.Serializable;
+import java.time.LocalDateTime;
+
+/**
+ * <p>
+ * 预案管理
+ * </p>
+ *
+ * @author JCB
+ * @since 2022-09-05
+ */
+@Data
+@EqualsAndHashCode(callSuper = false)
+public class ReservePlan implements Serializable {
+
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * 主键ID
+     */
+    @TableId(value = "id", type = IdType.AUTO)
+    private Integer id;
+
+    /**
+     * 预案名称
+     */
+    private String reserveName;
+
+    /**
+     * 预案类型
+     */
+    private Integer reserveType;
+
+    /**
+     * 预案文件路径
+     */
+    private String reserveUrl;
+
+    /**
+     * 单位ID
+     */
+    private String companyId;
+
+    /**
+     * 创建人
+     */
+    private String creator;
+
+    /**
+     * 创建时间
+     */
+    private LocalDateTime createTime;
+
+    /**
+     * 更新人
+     */
+    private String updatePerson;
+
+    /**
+     * 更新时间
+     */
+    private LocalDateTime updateTime;
+
+    /**
+     * 使能标识(1:开通 、2:待定 、3:注销)
+     */
+    private Integer enable;
+
+}

+ 16 - 0
service-fire/service-fire-biz/src/main/java/com/usky/fire/mapper/ReservePlanMapper.java

@@ -0,0 +1,16 @@
+package com.usky.fire.mapper;
+
+import com.usky.fire.domain.ReservePlan;
+import com.usky.common.mybatis.core.CrudMapper;
+
+/**
+ * <p>
+ * 预案管理 Mapper 接口
+ * </p>
+ *
+ * @author JCB
+ * @since 2022-09-05
+ */
+public interface ReservePlanMapper extends CrudMapper<ReservePlan> {
+
+}

+ 49 - 0
service-fire/service-fire-biz/src/main/java/com/usky/fire/service/ReservePlanService.java

@@ -0,0 +1,49 @@
+package com.usky.fire.service;
+
+import com.usky.common.core.bean.CommonPage;
+import com.usky.common.mybatis.core.CrudService;
+import com.usky.fire.domain.ReservePlan;
+
+/**
+ * <p>
+ * 预案管理 服务类
+ * </p>
+ *
+ * @author JCB
+ * @since 2022-09-05
+ */
+public interface ReservePlanService extends CrudService<ReservePlan> {
+
+    /**
+     * 预案管理-信息新增
+     *
+     * @param reservePlan
+     */
+    void reservePlanDataAdd(ReservePlan reservePlan);
+
+    /**
+     * 预案管理-信息编辑
+     *
+     * @param reservePlan
+     */
+    void reservePlanDataUpdate(ReservePlan reservePlan);
+
+    /**
+     * 预案管理-信息删除
+     *
+     * @param id 主键ID
+     */
+    void reservePlanDataDelete(Integer id);
+
+    /**
+     * 预案管理-列表查询
+     *
+     * @param reserveName 预案名称
+     * @param startDate   开始时间 格式:yyyy-MM-dd HH:mm:ss
+     * @param endDate     结束时间 格式:yyyy-MM-dd HH:mm:ss
+     * @param pageNum     当前页
+     * @param pageSize    每页条数
+     * @return
+     */
+    CommonPage<Object> reservePlanDataList(String reserveName, String startDate, String endDate, Integer pageNum, Integer pageSize);
+}

+ 101 - 0
service-fire/service-fire-biz/src/main/java/com/usky/fire/service/impl/ReservePlanServiceImpl.java

@@ -0,0 +1,101 @@
+package com.usky.fire.service.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
+import com.baomidou.mybatisplus.core.toolkit.StringUtils;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.usky.common.core.bean.CommonPage;
+import com.usky.common.core.exception.BusinessException;
+import com.usky.common.mybatis.core.AbstractCrudService;
+import com.usky.common.security.utils.SecurityUtils;
+import com.usky.fire.domain.ReservePlan;
+import com.usky.fire.mapper.ReservePlanMapper;
+import com.usky.fire.service.ReservePlanService;
+import org.springframework.stereotype.Service;
+
+import java.time.LocalDateTime;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * <p>
+ * 预案管理 服务实现类
+ * </p>
+ *
+ * @author JCB
+ * @since 2022-09-05
+ */
+@Service
+public class ReservePlanServiceImpl extends AbstractCrudService<ReservePlanMapper, ReservePlan> implements ReservePlanService {
+
+    @Override
+    public void reservePlanDataAdd(ReservePlan reservePlan) {
+        LambdaQueryWrapper<ReservePlan> queryWrapper = Wrappers.lambdaQuery();
+        queryWrapper.eq(ReservePlan::getReserveName, reservePlan.getReserveName())
+                .eq(ReservePlan::getCreator, SecurityUtils.getUsername())
+                .eq(ReservePlan::getEnable, 1);
+        List<ReservePlan> list = this.list(queryWrapper);
+        if (CollectionUtils.isEmpty(list)) {
+            throw new BusinessException("预案民称重复不可添加");
+        }
+        reservePlan.setEnable(1);
+        reservePlan.setCreateTime(LocalDateTime.now());
+        reservePlan.setCreator(SecurityUtils.getUsername());
+        this.updateById(reservePlan);
+    }
+
+    @Override
+    public void reservePlanDataUpdate(ReservePlan reservePlan) {
+        LambdaQueryWrapper<ReservePlan> queryWrapper = Wrappers.lambdaQuery();
+        queryWrapper.eq(ReservePlan::getReserveName, reservePlan.getReserveName())
+                .eq(ReservePlan::getCreator, SecurityUtils.getUsername())
+                .ne(ReservePlan::getId, reservePlan.getId())
+                .eq(ReservePlan::getEnable, 1);
+        List<ReservePlan> list = this.list(queryWrapper);
+        if (CollectionUtils.isEmpty(list)) {
+            throw new BusinessException("预案民称重复不可添加");
+        }
+        reservePlan.setUpdatePerson(SecurityUtils.getUsername());
+        reservePlan.setUpdateTime(LocalDateTime.now());
+        this.updateById(reservePlan);
+    }
+
+    @Override
+    public void reservePlanDataDelete(Integer id) {
+        ReservePlan reservePlan = new ReservePlan();
+        reservePlan.setId(id);
+        reservePlan.setEnable(3);
+        this.updateById(reservePlan);
+    }
+
+    @Override
+    public CommonPage<Object> reservePlanDataList(String reserveName, String startDate, String endDate, Integer pageNum, Integer pageSize) {
+        List<Object> list = new ArrayList<>();
+        IPage<ReservePlan> page = new Page<>(pageNum, pageSize);
+        LambdaQueryWrapper<ReservePlan> queryWrapper = Wrappers.lambdaQuery();
+        queryWrapper.select(ReservePlan::getId, ReservePlan::getReserveName, ReservePlan::getReserveUrl, ReservePlan::getReserveType,
+                ReservePlan::getCreator, ReservePlan::getCreateTime)
+                .eq(ReservePlan::getCreator, SecurityUtils.getUsername())
+                .like(StringUtils.isNotBlank(reserveName), ReservePlan::getReserveName, reserveName)
+                .between(StringUtils.isNotBlank(startDate) && StringUtils.isNotBlank(endDate), ReservePlan::getCreateTime, startDate, endDate);
+        page = this.page(page, queryWrapper);
+        if (CollectionUtils.isNotEmpty(page.getRecords())) {
+            for (int i = 0; i < page.getRecords().size(); i++) {
+                Map<String, Object> map = new HashMap<>();
+                map.put("id", page.getRecords().get(i).getId());
+                map.put("reserveName", page.getRecords().get(i).getReserveName());
+                map.put("reserveType", page.getRecords().get(i).getReserveType());
+                map.put("reserveUrl", page.getRecords().get(i).getReserveUrl());
+                map.put("creator", page.getRecords().get(i).getCreator());
+                map.put("createTime", page.getRecords().get(i).getCreateTime());
+                list.add(map);
+            }
+        }
+        return new CommonPage<>(list, page.getTotal(), pageSize, pageNum);
+    }
+
+}

+ 19 - 0
service-fire/service-fire-biz/src/main/resources/mapper/fire/ReservePlanMapper.xml

@@ -0,0 +1,19 @@
+<?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="com.usky.fire.mapper.ReservePlanMapper">
+
+    <!-- 通用查询映射结果 -->
+    <resultMap id="BaseResultMap" type="com.usky.fire.domain.ReservePlan">
+        <id column="id" property="id" />
+        <result column="reserve_name" property="reserveName" />
+        <result column="reserve_type" property="reserveType" />
+        <result column="reserve_url" property="reserveUrl" />
+        <result column="company_id" property="companyId" />
+        <result column="creator" property="creator" />
+        <result column="create_time" property="createTime" />
+        <result column="update_person" property="updatePerson" />
+        <result column="update_time" property="updateTime" />
+        <result column="enable" property="enable" />
+    </resultMap>
+
+</mapper>