ソースを参照

1、会议室管理代码生成

dongpo 7 ヶ月 前
コミット
85f89e300d

+ 2 - 0
yudao-module-bpm/yudao-module-bpm-api/src/main/java/cn/iocoder/yudao/module/bpm/enums/ErrorCodeConstants.java

@@ -113,6 +113,8 @@ public interface ErrorCodeConstants {
     ErrorCode OA_EXPENSE_NOT_EXISTS = new ErrorCode(1_009_017_010, "报销流程信息不存在");
     // ========== 用印流程信息 1_009_017_011 ==========
     ErrorCode OA_STAMP_NOT_EXISTS = new ErrorCode(1_009_017_011, "用印流程信息不存在");
+    // ========== 会议室信息管理 1_009_017_012 ==========
+    ErrorCode OA_MEETING_ROOM_NOT_EXISTS = new ErrorCode(1_009_017_012, "会议室信息管理不存在");
 
     // ========== 员工信息 1_009_018_000 ==========
     ErrorCode OA_EMPLOYEE_NOT_EXISTS = new ErrorCode(1_009_018_000, "员工信息不存在");

+ 93 - 0
yudao-module-bpm/yudao-module-bpm-biz/src/main/java/cn/iocoder/yudao/module/bpm/controller/admin/meeting/room/OaMeetingRoomController.java

@@ -0,0 +1,93 @@
+package cn.iocoder.yudao.module.bpm.controller.admin.meeting.room;
+
+import cn.iocoder.yudao.framework.apilog.core.annotation.ApiAccessLog;
+import cn.iocoder.yudao.framework.common.pojo.CommonResult;
+import cn.iocoder.yudao.framework.common.pojo.PageParam;
+import cn.iocoder.yudao.framework.common.pojo.PageResult;
+import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
+import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
+import cn.iocoder.yudao.module.bpm.controller.admin.meeting.room.vo.OaMeetingRoomPageReqVO;
+import cn.iocoder.yudao.module.bpm.controller.admin.meeting.room.vo.OaMeetingRoomRespVO;
+import cn.iocoder.yudao.module.bpm.controller.admin.meeting.room.vo.OaMeetingRoomSaveReqVO;
+import cn.iocoder.yudao.module.bpm.dal.dataobject.meeting.room.OaMeetingRoomDO;
+import cn.iocoder.yudao.module.bpm.service.meeting.room.OaMeetingRoomService;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.Parameter;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import org.springframework.security.access.prepost.PreAuthorize;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import javax.annotation.Resource;
+import javax.servlet.http.HttpServletResponse;
+import javax.validation.Valid;
+import java.io.IOException;
+import java.util.List;
+
+import static cn.iocoder.yudao.framework.apilog.core.enums.OperateTypeEnum.EXPORT;
+import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
+
+@Tag(name = "管理后台 - 会议室信息管理")
+@RestController
+@RequestMapping("/bpm/oa-meeting-room")
+@Validated
+public class OaMeetingRoomController {
+
+    @Resource
+    private OaMeetingRoomService oaMeetingRoomService;
+
+    @PostMapping("/create")
+    @Operation(summary = "创建会议室信息管理")
+    // @PreAuthorize("@ss.hasPermission('bpm:oa-meeting-room:create')")
+    public CommonResult<Long> createOaMeetingRoom(@Valid @RequestBody OaMeetingRoomSaveReqVO createReqVO) {
+        return success(oaMeetingRoomService.createOaMeetingRoom(createReqVO));
+    }
+
+    @PutMapping("/update")
+    @Operation(summary = "更新会议室信息管理")
+    // @PreAuthorize("@ss.hasPermission('bpm:oa-meeting-room:update')")
+    public CommonResult<Boolean> updateOaMeetingRoom(@Valid @RequestBody OaMeetingRoomSaveReqVO updateReqVO) {
+        oaMeetingRoomService.updateOaMeetingRoom(updateReqVO);
+        return success(true);
+    }
+
+    @DeleteMapping("/delete")
+    @Operation(summary = "删除会议室信息管理")
+    @Parameter(name = "id", description = "编号", required = true)
+    // @PreAuthorize("@ss.hasPermission('bpm:oa-meeting-room:delete')")
+    public CommonResult<Boolean> deleteOaMeetingRoom(@RequestParam("id") Long id) {
+        oaMeetingRoomService.deleteOaMeetingRoom(id);
+        return success(true);
+    }
+
+    @GetMapping("/get")
+    @Operation(summary = "获得会议室信息管理")
+    @Parameter(name = "id", description = "编号", required = true, example = "1024")
+    // @PreAuthorize("@ss.hasPermission('bpm:oa-meeting-room:query')")
+    public CommonResult<OaMeetingRoomRespVO> getOaMeetingRoom(@RequestParam("id") Long id) {
+        OaMeetingRoomDO oaMeetingRoom = oaMeetingRoomService.getOaMeetingRoom(id);
+        return success(BeanUtils.toBean(oaMeetingRoom, OaMeetingRoomRespVO.class));
+    }
+
+    @GetMapping("/page")
+    @Operation(summary = "获得会议室信息管理分页")
+    // @PreAuthorize("@ss.hasPermission('bpm:oa-meeting-room:query')")
+    public CommonResult<PageResult<OaMeetingRoomRespVO>> getOaMeetingRoomPage(@Valid OaMeetingRoomPageReqVO pageReqVO) {
+        PageResult<OaMeetingRoomDO> pageResult = oaMeetingRoomService.getOaMeetingRoomPage(pageReqVO);
+        return success(BeanUtils.toBean(pageResult, OaMeetingRoomRespVO.class));
+    }
+
+    @GetMapping("/export-excel")
+    @Operation(summary = "导出会议室信息管理 Excel")
+    // @PreAuthorize("@ss.hasPermission('bpm:oa-meeting-room:export')")
+    @ApiAccessLog(operateType = EXPORT)
+    public void exportOaMeetingRoomExcel(@Valid OaMeetingRoomPageReqVO pageReqVO,
+              HttpServletResponse response) throws IOException {
+        pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
+        List<OaMeetingRoomDO> list = oaMeetingRoomService.getOaMeetingRoomPage(pageReqVO).getList();
+        // 导出 Excel
+        ExcelUtils.write(response, "会议室信息管理.xls", "数据", OaMeetingRoomRespVO.class,
+                        BeanUtils.toBean(list, OaMeetingRoomRespVO.class));
+    }
+
+}

+ 45 - 0
yudao-module-bpm/yudao-module-bpm-biz/src/main/java/cn/iocoder/yudao/module/bpm/controller/admin/meeting/room/vo/OaMeetingRoomPageReqVO.java

@@ -0,0 +1,45 @@
+package cn.iocoder.yudao.module.bpm.controller.admin.meeting.room.vo;
+
+import cn.iocoder.yudao.framework.common.pojo.PageParam;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import lombok.ToString;
+import org.springframework.format.annotation.DateTimeFormat;
+
+import java.time.LocalDateTime;
+
+import static cn.iocoder.yudao.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 OaMeetingRoomPageReqVO extends PageParam {
+
+    @Schema(description = "会议室uuid", example = "3660")
+    private String roomUuid;
+
+    @Schema(description = "会议室名称", example = "张三")
+    private String name;
+
+    @Schema(description = "可容纳人数")
+    private String size;
+
+    @Schema(description = "管理员id", example = "30682")
+    private Long managerId;
+
+    @Schema(description = "管理员uuid", example = "29079")
+    private String managerUuid;
+
+    @Schema(description = "管理员姓名", example = "赵六")
+    private String managerName;
+
+    @Schema(description = "备注")
+    private String remarks;
+
+    @Schema(description = "创建时间")
+    @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
+    private LocalDateTime[] createTime;
+
+}

+ 51 - 0
yudao-module-bpm/yudao-module-bpm-biz/src/main/java/cn/iocoder/yudao/module/bpm/controller/admin/meeting/room/vo/OaMeetingRoomRespVO.java

@@ -0,0 +1,51 @@
+package cn.iocoder.yudao.module.bpm.controller.admin.meeting.room.vo;
+
+import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
+import com.alibaba.excel.annotation.ExcelProperty;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.time.LocalDateTime;
+
+@Schema(description = "管理后台 - 会议室信息管理 Response VO")
+@Data
+@ExcelIgnoreUnannotated
+public class OaMeetingRoomRespVO {
+
+    @Schema(description = "主键id", requiredMode = Schema.RequiredMode.REQUIRED, example = "28863")
+    @ExcelProperty("主键id")
+    private Long id;
+
+    @Schema(description = "会议室uuid", example = "3660")
+    @ExcelProperty("会议室uuid")
+    private String roomUuid;
+
+    @Schema(description = "会议室名称", example = "张三")
+    @ExcelProperty("会议室名称")
+    private String name;
+
+    @Schema(description = "可容纳人数")
+    @ExcelProperty("可容纳人数")
+    private String size;
+
+    @Schema(description = "管理员id", example = "30682")
+    @ExcelProperty("管理员id")
+    private Long managerId;
+
+    @Schema(description = "管理员uuid", example = "29079")
+    @ExcelProperty("管理员uuid")
+    private String managerUuid;
+
+    @Schema(description = "管理员姓名", example = "赵六")
+    @ExcelProperty("管理员姓名")
+    private String managerName;
+
+    @Schema(description = "备注")
+    @ExcelProperty("备注")
+    private String remarks;
+
+    @Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
+    @ExcelProperty("创建时间")
+    private LocalDateTime createTime;
+
+}

+ 31 - 0
yudao-module-bpm/yudao-module-bpm-biz/src/main/java/cn/iocoder/yudao/module/bpm/controller/admin/meeting/room/vo/OaMeetingRoomSaveReqVO.java

@@ -0,0 +1,31 @@
+package cn.iocoder.yudao.module.bpm.controller.admin.meeting.room.vo;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import javax.validation.constraints.NotBlank;
+import javax.validation.constraints.NotNull;
+
+@Schema(description = "管理后台 - 会议室信息管理新增/修改 Request VO")
+@Data
+public class OaMeetingRoomSaveReqVO {
+
+    @Schema(description = "主键id")
+    private Long id;
+
+    @Schema(description = "会议室名称", example = "会议室1")
+    @NotBlank(message = "会议室名称不能为空")
+    private String name;
+
+    @Schema(description = "可容纳人数")
+    @NotBlank(message = "可容纳人数不能为空")
+    private String size;
+
+    @Schema(description = "管理员id", example = "1")
+    @NotNull(message = "管理员不能为空")
+    private Long managerId;
+
+    @Schema(description = "备注")
+    private String remarks;
+
+}

+ 58 - 0
yudao-module-bpm/yudao-module-bpm-biz/src/main/java/cn/iocoder/yudao/module/bpm/dal/dataobject/meeting/room/OaMeetingRoomDO.java

@@ -0,0 +1,58 @@
+package cn.iocoder.yudao.module.bpm.dal.dataobject.meeting.room;
+
+import cn.iocoder.yudao.framework.mybatis.core.dataobject.BaseDO;
+import com.baomidou.mybatisplus.annotation.KeySequence;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import lombok.*;
+
+/**
+ * 会议室信息管理 DO
+ *
+ * @author dp
+ */
+@TableName("bpm_oa_meeting_room")
+@KeySequence("bpm_oa_meeting_room_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
+@Data
+@EqualsAndHashCode(callSuper = true)
+@ToString(callSuper = true)
+@Builder
+@NoArgsConstructor
+@AllArgsConstructor
+public class OaMeetingRoomDO extends BaseDO {
+
+    /**
+     * 主键id
+     */
+    @TableId
+    private Long id;
+    /**
+     * 会议室uuid
+     */
+    private String roomUuid;
+    /**
+     * 会议室名称
+     */
+    private String name;
+    /**
+     * 可容纳人数
+     */
+    private String size;
+    /**
+     * 管理员id
+     */
+    private Long managerId;
+    /**
+     * 管理员uuid
+     */
+    private String managerUuid;
+    /**
+     * 管理员姓名
+     */
+    private String managerName;
+    /**
+     * 备注
+     */
+    private String remarks;
+
+}

+ 31 - 0
yudao-module-bpm/yudao-module-bpm-biz/src/main/java/cn/iocoder/yudao/module/bpm/dal/mysql/meeting/room/OaMeetingRoomMapper.java

@@ -0,0 +1,31 @@
+package cn.iocoder.yudao.module.bpm.dal.mysql.meeting.room;
+
+import cn.iocoder.yudao.framework.common.pojo.PageResult;
+import cn.iocoder.yudao.framework.mybatis.core.mapper.BaseMapperX;
+import cn.iocoder.yudao.framework.mybatis.core.query.LambdaQueryWrapperX;
+import cn.iocoder.yudao.module.bpm.controller.admin.meeting.room.vo.OaMeetingRoomPageReqVO;
+import cn.iocoder.yudao.module.bpm.dal.dataobject.meeting.room.OaMeetingRoomDO;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+ * 会议室信息管理 Mapper
+ *
+ * @author dp
+ */
+@Mapper
+public interface OaMeetingRoomMapper extends BaseMapperX<OaMeetingRoomDO> {
+
+    default PageResult<OaMeetingRoomDO> selectPage(OaMeetingRoomPageReqVO reqVO) {
+        return selectPage(reqVO, new LambdaQueryWrapperX<OaMeetingRoomDO>()
+                .eqIfPresent(OaMeetingRoomDO::getRoomUuid, reqVO.getRoomUuid())
+                .likeIfPresent(OaMeetingRoomDO::getName, reqVO.getName())
+                .eqIfPresent(OaMeetingRoomDO::getSize, reqVO.getSize())
+                .eqIfPresent(OaMeetingRoomDO::getManagerId, reqVO.getManagerId())
+                .eqIfPresent(OaMeetingRoomDO::getManagerUuid, reqVO.getManagerUuid())
+                .likeIfPresent(OaMeetingRoomDO::getManagerName, reqVO.getManagerName())
+                .eqIfPresent(OaMeetingRoomDO::getRemarks, reqVO.getRemarks())
+                .betweenIfPresent(OaMeetingRoomDO::getCreateTime, reqVO.getCreateTime())
+                .orderByDesc(OaMeetingRoomDO::getId));
+    }
+
+}

+ 55 - 0
yudao-module-bpm/yudao-module-bpm-biz/src/main/java/cn/iocoder/yudao/module/bpm/service/meeting/room/OaMeetingRoomService.java

@@ -0,0 +1,55 @@
+package cn.iocoder.yudao.module.bpm.service.meeting.room;
+
+import cn.iocoder.yudao.framework.common.pojo.PageResult;
+import cn.iocoder.yudao.module.bpm.controller.admin.meeting.room.vo.OaMeetingRoomPageReqVO;
+import cn.iocoder.yudao.module.bpm.controller.admin.meeting.room.vo.OaMeetingRoomSaveReqVO;
+import cn.iocoder.yudao.module.bpm.dal.dataobject.meeting.room.OaMeetingRoomDO;
+
+import javax.validation.Valid;
+
+/**
+ * 会议室信息管理 Service 接口
+ *
+ * @author dp
+ */
+public interface OaMeetingRoomService {
+
+    /**
+     * 创建会议室信息管理
+     *
+     * @param createReqVO 创建信息
+     * @return 编号
+     */
+    Long createOaMeetingRoom(@Valid OaMeetingRoomSaveReqVO createReqVO);
+
+    /**
+     * 更新会议室信息管理
+     *
+     * @param updateReqVO 更新信息
+     */
+    void updateOaMeetingRoom(@Valid OaMeetingRoomSaveReqVO updateReqVO);
+
+    /**
+     * 删除会议室信息管理
+     *
+     * @param id 编号
+     */
+    void deleteOaMeetingRoom(Long id);
+
+    /**
+     * 获得会议室信息管理
+     *
+     * @param id 编号
+     * @return 会议室信息管理
+     */
+    OaMeetingRoomDO getOaMeetingRoom(Long id);
+
+    /**
+     * 获得会议室信息管理分页
+     *
+     * @param pageReqVO 分页查询
+     * @return 会议室信息管理分页
+     */
+    PageResult<OaMeetingRoomDO> getOaMeetingRoomPage(OaMeetingRoomPageReqVO pageReqVO);
+
+}

+ 71 - 0
yudao-module-bpm/yudao-module-bpm-biz/src/main/java/cn/iocoder/yudao/module/bpm/service/meeting/room/OaMeetingRoomServiceImpl.java

@@ -0,0 +1,71 @@
+package cn.iocoder.yudao.module.bpm.service.meeting.room;
+
+import cn.iocoder.yudao.framework.common.pojo.PageResult;
+import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
+import cn.iocoder.yudao.module.bpm.controller.admin.meeting.room.vo.OaMeetingRoomPageReqVO;
+import cn.iocoder.yudao.module.bpm.controller.admin.meeting.room.vo.OaMeetingRoomSaveReqVO;
+import cn.iocoder.yudao.module.bpm.dal.dataobject.meeting.room.OaMeetingRoomDO;
+import cn.iocoder.yudao.module.bpm.dal.mysql.meeting.room.OaMeetingRoomMapper;
+import org.springframework.stereotype.Service;
+import org.springframework.validation.annotation.Validated;
+
+import javax.annotation.Resource;
+
+import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
+import static cn.iocoder.yudao.module.bpm.enums.ErrorCodeConstants.OA_MEETING_ROOM_NOT_EXISTS;
+
+/**
+ * 会议室信息管理 Service 实现类
+ *
+ * @author dp
+ */
+@Service
+@Validated
+public class OaMeetingRoomServiceImpl implements OaMeetingRoomService {
+
+    @Resource
+    private OaMeetingRoomMapper oaMeetingRoomMapper;
+
+    @Override
+    public Long createOaMeetingRoom(OaMeetingRoomSaveReqVO createReqVO) {
+        // 插入
+        OaMeetingRoomDO oaMeetingRoom = BeanUtils.toBean(createReqVO, OaMeetingRoomDO.class);
+        oaMeetingRoomMapper.insert(oaMeetingRoom);
+        // 返回
+        return oaMeetingRoom.getId();
+    }
+
+    @Override
+    public void updateOaMeetingRoom(OaMeetingRoomSaveReqVO updateReqVO) {
+        // 校验存在
+        validateOaMeetingRoomExists(updateReqVO.getId());
+        // 更新
+        OaMeetingRoomDO updateObj = BeanUtils.toBean(updateReqVO, OaMeetingRoomDO.class);
+        oaMeetingRoomMapper.updateById(updateObj);
+    }
+
+    @Override
+    public void deleteOaMeetingRoom(Long id) {
+        // 校验存在
+        validateOaMeetingRoomExists(id);
+        // 删除
+        oaMeetingRoomMapper.deleteById(id);
+    }
+
+    private void validateOaMeetingRoomExists(Long id) {
+        if (oaMeetingRoomMapper.selectById(id) == null) {
+            throw exception(OA_MEETING_ROOM_NOT_EXISTS);
+        }
+    }
+
+    @Override
+    public OaMeetingRoomDO getOaMeetingRoom(Long id) {
+        return oaMeetingRoomMapper.selectById(id);
+    }
+
+    @Override
+    public PageResult<OaMeetingRoomDO> getOaMeetingRoomPage(OaMeetingRoomPageReqVO pageReqVO) {
+        return oaMeetingRoomMapper.selectPage(pageReqVO);
+    }
+
+}

+ 12 - 0
yudao-module-bpm/yudao-module-bpm-biz/src/main/resources/mapper/meeting/room/OaMeetingRoomMapper.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.iocoder.yudao.module.bpm.dal.mysql.meeting.room.OaMeetingRoomMapper">
+
+    <!--
+        一般情况下,尽可能使用 Mapper 进行 CRUD 增删改查即可。
+        无法满足的场景,例如说多表关联查询,才使用 XML 编写 SQL。
+        代码生成器暂时只生成 Mapper XML 文件本身,更多推荐 MybatisX 快速开发插件来生成查询。
+        文档可见:https://www.iocoder.cn/MyBatis/x-plugins/
+     -->
+
+</mapper>