Explorar el Código

Merge remote-tracking branch 'origin/master'

lipenghui hace 5 meses
padre
commit
1e1e21297a
Se han modificado 23 ficheros con 1092 adiciones y 0 borrados
  1. 2 0
      yudao-module-pms/yudao-module-pms-api/src/main/java/cn/iocoder/yudao/module/pms/enums/ErrorCodeConstant.java
  2. 29 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotbom/IotBomController.java
  3. 18 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotbom/vo/IotBomListReqVO.java
  4. 23 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotbom/vo/IotBomSimpleRespVO.java
  5. 93 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicebom/IotDeviceBomController.java
  6. 63 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicebom/vo/IotDeviceBomPageReqVO.java
  7. 75 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicebom/vo/IotDeviceBomRespVO.java
  8. 52 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicebom/vo/IotDeviceBomSaveReqVO.java
  9. 93 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicematerial/IotDeviceMaterialController.java
  10. 49 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicematerial/vo/IotDeviceMaterialPageReqVO.java
  11. 56 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicematerial/vo/IotDeviceMaterialRespVO.java
  12. 39 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicematerial/vo/IotDeviceMaterialSaveReqVO.java
  13. 82 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/dal/dataobject/iotdevicebom/IotDeviceBomDO.java
  14. 64 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/dal/dataobject/iotdevicematerial/IotDeviceMaterialDO.java
  15. 10 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/dal/mysql/iotbom/IotBomMapper.java
  16. 37 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/dal/mysql/iotdevicebom/IotDeviceBomMapper.java
  17. 32 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/dal/mysql/iotdevicematerial/IotDeviceMaterialMapper.java
  18. 9 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotbom/IotBomService.java
  19. 12 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotbom/IotBomServiceImpl.java
  20. 55 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotdevicebom/IotDeviceBomService.java
  21. 72 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotdevicebom/IotDeviceBomServiceImpl.java
  22. 55 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotdevicematerial/IotDeviceMaterialService.java
  23. 72 0
      yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotdevicematerial/IotDeviceMaterialServiceImpl.java

+ 2 - 0
yudao-module-pms/yudao-module-pms-api/src/main/java/cn/iocoder/yudao/module/pms/enums/ErrorCodeConstant.java

@@ -14,5 +14,7 @@ public interface ErrorCodeConstant{
     ErrorCode IOT_DEVICE_TEMPLATE_ATTRS_NOT_EXISTS = new ErrorCode(105, "设备模板属性不存在");
     ErrorCode IOT_DEVICE_TEMPLATE_NOT_EXISTS = new ErrorCode(106, "设备模板不存在");
     ErrorCode IOT_BOM_NOT_EXISTS = new ErrorCode(107, "BOM 关系不存在");
+    ErrorCode IOT_DEVICE_MATERIAL_NOT_EXISTS = new ErrorCode(108, "设备BOM物料关联不存在");
+    ErrorCode IOT_DEVICE_BOM_NOT_EXISTS = new ErrorCode(109, "设备BOM 关系不存在");
     ErrorCode IOT_INFO_NOT_EXISTS = new ErrorCode( 122, "资料数据不存在");
 }

+ 29 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotbom/IotBomController.java

@@ -1,6 +1,9 @@
 package cn.iocoder.yudao.module.pms.controller.admin.iotbom;
 
+import cn.hutool.core.collection.CollectionUtil;
+import cn.hutool.core.util.ObjectUtil;
 import cn.iocoder.yudao.framework.apilog.core.annotation.ApiAccessLog;
+import cn.iocoder.yudao.framework.common.enums.CommonStatusEnum;
 import cn.iocoder.yudao.framework.common.pojo.CommonResult;
 import cn.iocoder.yudao.framework.common.pojo.PageParam;
 import cn.iocoder.yudao.framework.common.pojo.PageResult;
@@ -9,6 +12,10 @@ import cn.iocoder.yudao.framework.excel.core.util.ExcelUtils;
 import cn.iocoder.yudao.module.pms.controller.admin.iotbom.vo.*;
 import cn.iocoder.yudao.module.pms.dal.dataobject.iotbom.IotBomDO;
 import cn.iocoder.yudao.module.pms.service.iotbom.IotBomService;
+import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptListReqVO;
+import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptRespVO;
+import cn.iocoder.yudao.module.system.controller.admin.dept.vo.dept.DeptSimpleRespVO;
+import cn.iocoder.yudao.module.system.dal.dataobject.dept.DeptDO;
 import io.swagger.v3.oas.annotations.Operation;
 import io.swagger.v3.oas.annotations.Parameter;
 import io.swagger.v3.oas.annotations.tags.Tag;
@@ -75,6 +82,28 @@ public class IotBomController {
         return success(BeanUtils.toBean(pageResult, IotBomRespVO.class));
     }
 
+    @GetMapping("/list")
+    @Operation(summary = "获取 Bom树 列表")
+    @PreAuthorize("@ss.hasPermission('rq:iot-bom:query')")
+    public CommonResult<List<IotBomRespVO>> getBomList(IotBomListReqVO reqVO) {
+        if (ObjectUtil.isEmpty(reqVO.getDeviceCategoryId())) {
+            return success(CollectionUtil.newArrayList());
+        }
+        List<IotBomDO> list = iotBomService.getBomList(reqVO);
+        return success(BeanUtils.toBean(list, IotBomRespVO.class));
+    }
+
+    @GetMapping(value = {"/list-all-simple", "/simple-list"})
+    @Operation(summary = "获取Bom精简信息列表", description = "只包含被开启的Bom节点,主要用于前端的下拉选项")
+    public CommonResult<List<IotBomSimpleRespVO>> getSimpleBomList(IotBomListReqVO reqVO) {
+        if (ObjectUtil.isEmpty(reqVO.getDeviceCategoryId())) {
+            return success(CollectionUtil.newArrayList());
+        }
+        reqVO.setStatus(CommonStatusEnum.ENABLE.getStatus());
+        List<IotBomDO> list = iotBomService.getBomList(reqVO);
+        return success(BeanUtils.toBean(list, IotBomSimpleRespVO.class));
+    }
+
     @GetMapping("/export-excel")
     @Operation(summary = "导出PMS BOM 关系 Excel")
     @PreAuthorize("@ss.hasPermission('rq:iot-bom:export')")

+ 18 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotbom/vo/IotBomListReqVO.java

@@ -0,0 +1,18 @@
+package cn.iocoder.yudao.module.pms.controller.admin.iotbom.vo;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+@Schema(description = "管理后台 - Bom树 列表 Request VO")
+@Data
+public class IotBomListReqVO {
+
+    @Schema(description = "部门名称,模糊匹配", example = "pms")
+    private String name;
+
+    @Schema(description = "展示状态,参见 CommonStatusEnum 枚举类", example = "1")
+    private Integer status;
+
+    @Schema(description = "所属设备分类", example = "23419")
+    private Long deviceCategoryId;
+}

+ 23 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotbom/vo/IotBomSimpleRespVO.java

@@ -0,0 +1,23 @@
+package cn.iocoder.yudao.module.pms.controller.admin.iotbom.vo;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+@Schema(description = "管理后台 - Bom精简信息 Response VO")
+@Data
+@NoArgsConstructor
+@AllArgsConstructor
+public class IotBomSimpleRespVO {
+
+    @Schema(description = "Bom节点id", requiredMode = Schema.RequiredMode.REQUIRED, example = "1024")
+    private Long id;
+
+    @Schema(description = "Bom节点名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "pms")
+    private String name;
+
+    @Schema(description = "父Bom节点 ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "1024")
+    private Long parentId;
+
+}

+ 93 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicebom/IotDeviceBomController.java

@@ -0,0 +1,93 @@
+package cn.iocoder.yudao.module.pms.controller.admin.iotdevicebom;
+
+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.pms.controller.admin.iotdevicebom.vo.IotDeviceBomPageReqVO;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicebom.vo.IotDeviceBomRespVO;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicebom.vo.IotDeviceBomSaveReqVO;
+import cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicebom.IotDeviceBomDO;
+import cn.iocoder.yudao.module.pms.service.iotdevicebom.IotDeviceBomService;
+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 = "管理后台 - PMS 设备BOM 关系")
+@RestController
+@RequestMapping("/pms/iot-device-bom")
+@Validated
+public class IotDeviceBomController {
+
+    @Resource
+    private IotDeviceBomService iotDeviceBomService;
+
+    @PostMapping("/create")
+    @Operation(summary = "创建PMS 设备BOM 关系")
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-bom:create')")
+    public CommonResult<Long> createIotDeviceBom(@Valid @RequestBody IotDeviceBomSaveReqVO createReqVO) {
+        return success(iotDeviceBomService.createIotDeviceBom(createReqVO));
+    }
+
+    @PutMapping("/update")
+    @Operation(summary = "更新PMS 设备BOM 关系")
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-bom:update')")
+    public CommonResult<Boolean> updateIotDeviceBom(@Valid @RequestBody IotDeviceBomSaveReqVO updateReqVO) {
+        iotDeviceBomService.updateIotDeviceBom(updateReqVO);
+        return success(true);
+    }
+
+    @DeleteMapping("/delete")
+    @Operation(summary = "删除PMS 设备BOM 关系")
+    @Parameter(name = "id", description = "编号", required = true)
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-bom:delete')")
+    public CommonResult<Boolean> deleteIotDeviceBom(@RequestParam("id") Long id) {
+        iotDeviceBomService.deleteIotDeviceBom(id);
+        return success(true);
+    }
+
+    @GetMapping("/get")
+    @Operation(summary = "获得PMS 设备BOM 关系")
+    @Parameter(name = "id", description = "编号", required = true, example = "1024")
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-bom:query')")
+    public CommonResult<IotDeviceBomRespVO> getIotDeviceBom(@RequestParam("id") Long id) {
+        IotDeviceBomDO iotDeviceBom = iotDeviceBomService.getIotDeviceBom(id);
+        return success(BeanUtils.toBean(iotDeviceBom, IotDeviceBomRespVO.class));
+    }
+
+    @GetMapping("/page")
+    @Operation(summary = "获得PMS 设备BOM 关系分页")
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-bom:query')")
+    public CommonResult<PageResult<IotDeviceBomRespVO>> getIotDeviceBomPage(@Valid IotDeviceBomPageReqVO pageReqVO) {
+        PageResult<IotDeviceBomDO> pageResult = iotDeviceBomService.getIotDeviceBomPage(pageReqVO);
+        return success(BeanUtils.toBean(pageResult, IotDeviceBomRespVO.class));
+    }
+
+    @GetMapping("/export-excel")
+    @Operation(summary = "导出PMS 设备BOM 关系 Excel")
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-bom:export')")
+    @ApiAccessLog(operateType = EXPORT)
+    public void exportIotDeviceBomExcel(@Valid IotDeviceBomPageReqVO pageReqVO,
+              HttpServletResponse response) throws IOException {
+        pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
+        List<IotDeviceBomDO> list = iotDeviceBomService.getIotDeviceBomPage(pageReqVO).getList();
+        // 导出 Excel
+        ExcelUtils.write(response, "PMS 设备BOM 关系.xls", "数据", IotDeviceBomRespVO.class,
+                        BeanUtils.toBean(list, IotDeviceBomRespVO.class));
+    }
+
+}

+ 63 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicebom/vo/IotDeviceBomPageReqVO.java

@@ -0,0 +1,63 @@
+package cn.iocoder.yudao.module.pms.controller.admin.iotdevicebom.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 = "管理后台 - PMS 设备BOM 关系分页 Request VO")
+@Data
+@EqualsAndHashCode(callSuper = true)
+@ToString(callSuper = true)
+public class IotDeviceBomPageReqVO extends PageParam {
+
+    @Schema(description = "所属设备分类", example = "29983")
+    private Long deviceCategoryId;
+
+    @Schema(description = "所属设备", example = "11465")
+    private Long deviceId;
+
+    @Schema(description = "BOM名称", example = "张三")
+    private String name;
+
+    @Schema(description = "BOM编码")
+    private String code;
+
+    @Schema(description = "父BOM id 顶级为0", example = "25524")
+    private Long parentId;
+
+    @Schema(description = "子节点id 逗号分隔")
+    private String childIds;
+
+    @Schema(description = "层级")
+    private Integer level;
+
+    @Schema(description = "是否叶子节点 0是 1否")
+    private Integer leafFlag;
+
+    @Schema(description = "显示顺序")
+    private Integer sort;
+
+    @Schema(description = "M维修 S保养 A维修+保养", example = "1")
+    private String type;
+
+    @Schema(description = "状态 0启用  1停用", example = "2")
+    private Integer status;
+
+    @Schema(description = "备注", example = "你猜")
+    private String remark;
+
+    @Schema(description = "版本")
+    private Integer version;
+
+    @Schema(description = "创建时间")
+    @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
+    private LocalDateTime[] createTime;
+
+}

+ 75 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicebom/vo/IotDeviceBomRespVO.java

@@ -0,0 +1,75 @@
+package cn.iocoder.yudao.module.pms.controller.admin.iotdevicebom.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 = "管理后台 - PMS 设备BOM 关系 Response VO")
+@Data
+@ExcelIgnoreUnannotated
+public class IotDeviceBomRespVO {
+
+    @Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "6538")
+    @ExcelProperty("主键")
+    private Long id;
+
+    @Schema(description = "所属设备分类", example = "29983")
+    @ExcelProperty("所属设备分类")
+    private Long deviceCategoryId;
+
+    @Schema(description = "所属设备", example = "11465")
+    @ExcelProperty("所属设备")
+    private Long deviceId;
+
+    @Schema(description = "BOM名称", example = "张三")
+    @ExcelProperty("BOM名称")
+    private String name;
+
+    @Schema(description = "BOM编码")
+    @ExcelProperty("BOM编码")
+    private String code;
+
+    @Schema(description = "父BOM id 顶级为0", example = "25524")
+    @ExcelProperty("父BOM id 顶级为0")
+    private Long parentId;
+
+    @Schema(description = "子节点id 逗号分隔")
+    @ExcelProperty("子节点id 逗号分隔")
+    private String childIds;
+
+    @Schema(description = "层级")
+    @ExcelProperty("层级")
+    private Integer level;
+
+    @Schema(description = "是否叶子节点 0是 1否")
+    @ExcelProperty("是否叶子节点 0是 1否")
+    private Integer leafFlag;
+
+    @Schema(description = "显示顺序")
+    @ExcelProperty("显示顺序")
+    private Integer sort;
+
+    @Schema(description = "M维修 S保养 A维修+保养", example = "1")
+    @ExcelProperty("M维修 S保养 A维修+保养")
+    private String type;
+
+    @Schema(description = "状态 0启用  1停用", example = "2")
+    @ExcelProperty("状态 0启用  1停用")
+    private Integer status;
+
+    @Schema(description = "备注", example = "你猜")
+    @ExcelProperty("备注")
+    private String remark;
+
+    @Schema(description = "版本")
+    @ExcelProperty("版本")
+    private Integer version;
+
+    @Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
+    @ExcelProperty("创建时间")
+    private LocalDateTime createTime;
+
+}

+ 52 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicebom/vo/IotDeviceBomSaveReqVO.java

@@ -0,0 +1,52 @@
+package cn.iocoder.yudao.module.pms.controller.admin.iotdevicebom.vo;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+@Schema(description = "管理后台 - PMS 设备BOM 关系新增/修改 Request VO")
+@Data
+public class IotDeviceBomSaveReqVO {
+
+    @Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "6538")
+    private Long id;
+
+    @Schema(description = "所属设备分类", example = "29983")
+    private Long deviceCategoryId;
+
+    @Schema(description = "所属设备", example = "11465")
+    private Long deviceId;
+
+    @Schema(description = "BOM名称", example = "张三")
+    private String name;
+
+    @Schema(description = "BOM编码")
+    private String code;
+
+    @Schema(description = "父BOM id 顶级为0", example = "25524")
+    private Long parentId;
+
+    @Schema(description = "子节点id 逗号分隔")
+    private String childIds;
+
+    @Schema(description = "层级")
+    private Integer level;
+
+    @Schema(description = "是否叶子节点 0是 1否")
+    private Integer leafFlag;
+
+    @Schema(description = "显示顺序")
+    private Integer sort;
+
+    @Schema(description = "M维修 S保养 A维修+保养", example = "1")
+    private String type;
+
+    @Schema(description = "状态 0启用  1停用", example = "2")
+    private Integer status;
+
+    @Schema(description = "备注", example = "你猜")
+    private String remark;
+
+    @Schema(description = "版本")
+    private Integer version;
+
+}

+ 93 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicematerial/IotDeviceMaterialController.java

@@ -0,0 +1,93 @@
+package cn.iocoder.yudao.module.pms.controller.admin.iotdevicematerial;
+
+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.pms.controller.admin.iotdevicematerial.vo.IotDeviceMaterialPageReqVO;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicematerial.vo.IotDeviceMaterialRespVO;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicematerial.vo.IotDeviceMaterialSaveReqVO;
+import cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicematerial.IotDeviceMaterialDO;
+import cn.iocoder.yudao.module.pms.service.iotdevicematerial.IotDeviceMaterialService;
+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 = "管理后台 - PMS 设备BOM物料关联")
+@RestController
+@RequestMapping("/pms/iot-device-material")
+@Validated
+public class IotDeviceMaterialController {
+
+    @Resource
+    private IotDeviceMaterialService iotDeviceMaterialService;
+
+    @PostMapping("/create")
+    @Operation(summary = "创建PMS 设备BOM物料关联")
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-material:create')")
+    public CommonResult<Long> createIotDeviceMaterial(@Valid @RequestBody IotDeviceMaterialSaveReqVO createReqVO) {
+        return success(iotDeviceMaterialService.createIotDeviceMaterial(createReqVO));
+    }
+
+    @PutMapping("/update")
+    @Operation(summary = "更新PMS 设备BOM物料关联")
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-material:update')")
+    public CommonResult<Boolean> updateIotDeviceMaterial(@Valid @RequestBody IotDeviceMaterialSaveReqVO updateReqVO) {
+        iotDeviceMaterialService.updateIotDeviceMaterial(updateReqVO);
+        return success(true);
+    }
+
+    @DeleteMapping("/delete")
+    @Operation(summary = "删除PMS 设备BOM物料关联")
+    @Parameter(name = "id", description = "编号", required = true)
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-material:delete')")
+    public CommonResult<Boolean> deleteIotDeviceMaterial(@RequestParam("id") Long id) {
+        iotDeviceMaterialService.deleteIotDeviceMaterial(id);
+        return success(true);
+    }
+
+    @GetMapping("/get")
+    @Operation(summary = "获得PMS 设备BOM物料关联")
+    @Parameter(name = "id", description = "编号", required = true, example = "1024")
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-material:query')")
+    public CommonResult<IotDeviceMaterialRespVO> getIotDeviceMaterial(@RequestParam("id") Long id) {
+        IotDeviceMaterialDO iotDeviceMaterial = iotDeviceMaterialService.getIotDeviceMaterial(id);
+        return success(BeanUtils.toBean(iotDeviceMaterial, IotDeviceMaterialRespVO.class));
+    }
+
+    @GetMapping("/page")
+    @Operation(summary = "获得PMS 设备BOM物料关联分页")
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-material:query')")
+    public CommonResult<PageResult<IotDeviceMaterialRespVO>> getIotDeviceMaterialPage(@Valid IotDeviceMaterialPageReqVO pageReqVO) {
+        PageResult<IotDeviceMaterialDO> pageResult = iotDeviceMaterialService.getIotDeviceMaterialPage(pageReqVO);
+        return success(BeanUtils.toBean(pageResult, IotDeviceMaterialRespVO.class));
+    }
+
+    @GetMapping("/export-excel")
+    @Operation(summary = "导出PMS 设备BOM物料关联 Excel")
+    @PreAuthorize("@ss.hasPermission('pms:iot-device-material:export')")
+    @ApiAccessLog(operateType = EXPORT)
+    public void exportIotDeviceMaterialExcel(@Valid IotDeviceMaterialPageReqVO pageReqVO,
+              HttpServletResponse response) throws IOException {
+        pageReqVO.setPageSize(PageParam.PAGE_SIZE_NONE);
+        List<IotDeviceMaterialDO> list = iotDeviceMaterialService.getIotDeviceMaterialPage(pageReqVO).getList();
+        // 导出 Excel
+        ExcelUtils.write(response, "PMS 设备BOM物料关联.xls", "数据", IotDeviceMaterialRespVO.class,
+                        BeanUtils.toBean(list, IotDeviceMaterialRespVO.class));
+    }
+
+}

+ 49 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicematerial/vo/IotDeviceMaterialPageReqVO.java

@@ -0,0 +1,49 @@
+package cn.iocoder.yudao.module.pms.controller.admin.iotdevicematerial.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.math.BigDecimal;
+import java.time.LocalDateTime;
+
+import static cn.iocoder.yudao.framework.common.util.date.DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND;
+
+@Schema(description = "管理后台 - PMS 设备BOM物料关联分页 Request VO")
+@Data
+@EqualsAndHashCode(callSuper = true)
+@ToString(callSuper = true)
+public class IotDeviceMaterialPageReqVO extends PageParam {
+
+    @Schema(description = "所属设备分类", example = "739")
+    private Long deviceCategoryId;
+
+    @Schema(description = "所属设备", example = "10736")
+    private Long deviceId;
+
+    @Schema(description = "设备BOM节点名称", example = "芋艿")
+    private String name;
+
+    @Schema(description = "设备BOM节点编码")
+    private String code;
+
+    @Schema(description = "物料id", example = "27947")
+    private Long materialId;
+
+    @Schema(description = "数量")
+    private BigDecimal quantity;
+
+    @Schema(description = "状态 0启用  1停用", example = "2")
+    private Integer status;
+
+    @Schema(description = "备注", example = "你说的对")
+    private String remark;
+
+    @Schema(description = "创建时间")
+    @DateTimeFormat(pattern = FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND)
+    private LocalDateTime[] createTime;
+
+}

+ 56 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicematerial/vo/IotDeviceMaterialRespVO.java

@@ -0,0 +1,56 @@
+package cn.iocoder.yudao.module.pms.controller.admin.iotdevicematerial.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.math.BigDecimal;
+import java.time.LocalDateTime;
+
+@Schema(description = "管理后台 - PMS 设备BOM物料关联 Response VO")
+@Data
+@ExcelIgnoreUnannotated
+public class IotDeviceMaterialRespVO {
+
+    @Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "13960")
+    @ExcelProperty("主键")
+    private Long id;
+
+    @Schema(description = "所属设备分类", example = "739")
+    @ExcelProperty("所属设备分类")
+    private Long deviceCategoryId;
+
+    @Schema(description = "所属设备", example = "10736")
+    @ExcelProperty("所属设备")
+    private Long deviceId;
+
+    @Schema(description = "设备BOM节点名称", example = "芋艿")
+    @ExcelProperty("设备BOM节点名称")
+    private String name;
+
+    @Schema(description = "设备BOM节点编码")
+    @ExcelProperty("设备BOM节点编码")
+    private String code;
+
+    @Schema(description = "物料id", example = "27947")
+    @ExcelProperty("物料id")
+    private Long materialId;
+
+    @Schema(description = "数量")
+    @ExcelProperty("数量")
+    private BigDecimal quantity;
+
+    @Schema(description = "状态 0启用  1停用", example = "2")
+    @ExcelProperty("状态 0启用  1停用")
+    private Integer status;
+
+    @Schema(description = "备注", example = "你说的对")
+    @ExcelProperty("备注")
+    private String remark;
+
+    @Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
+    @ExcelProperty("创建时间")
+    private LocalDateTime createTime;
+
+}

+ 39 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/controller/admin/iotdevicematerial/vo/IotDeviceMaterialSaveReqVO.java

@@ -0,0 +1,39 @@
+package cn.iocoder.yudao.module.pms.controller.admin.iotdevicematerial.vo;
+
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+
+import java.math.BigDecimal;
+
+@Schema(description = "管理后台 - PMS 设备BOM物料关联新增/修改 Request VO")
+@Data
+public class IotDeviceMaterialSaveReqVO {
+
+    @Schema(description = "主键", requiredMode = Schema.RequiredMode.REQUIRED, example = "13960")
+    private Long id;
+
+    @Schema(description = "所属设备分类", example = "739")
+    private Long deviceCategoryId;
+
+    @Schema(description = "所属设备", example = "10736")
+    private Long deviceId;
+
+    @Schema(description = "设备BOM节点名称", example = "芋艿")
+    private String name;
+
+    @Schema(description = "设备BOM节点编码")
+    private String code;
+
+    @Schema(description = "物料id", example = "27947")
+    private Long materialId;
+
+    @Schema(description = "数量")
+    private BigDecimal quantity;
+
+    @Schema(description = "状态 0启用  1停用", example = "2")
+    private Integer status;
+
+    @Schema(description = "备注", example = "你说的对")
+    private String remark;
+
+}

+ 82 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/dal/dataobject/iotdevicebom/IotDeviceBomDO.java

@@ -0,0 +1,82 @@
+package cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicebom;
+
+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.*;
+
+/**
+ * PMS 设备BOM 关系 DO
+ *
+ * @author ruiqi
+ */
+@TableName("rq_iot_device_bom")
+@KeySequence("rq_iot_device_bom_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
+@Data
+@EqualsAndHashCode(callSuper = true)
+@ToString(callSuper = true)
+@Builder
+@NoArgsConstructor
+@AllArgsConstructor
+public class IotDeviceBomDO extends BaseDO {
+
+    /**
+     * 主键
+     */
+    @TableId
+    private Long id;
+    /**
+     * 所属设备分类
+     */
+    private Long deviceCategoryId;
+    /**
+     * 所属设备
+     */
+    private Long deviceId;
+    /**
+     * BOM名称
+     */
+    private String name;
+    /**
+     * BOM编码
+     */
+    private String code;
+    /**
+     * 父BOM id 顶级为0
+     */
+    private Long parentId;
+    /**
+     * 子节点id 逗号分隔
+     */
+    private String childIds;
+    /**
+     * 层级
+     */
+    private Integer level;
+    /**
+     * 是否叶子节点 0是 1否
+     */
+    private Integer leafFlag;
+    /**
+     * 显示顺序
+     */
+    private Integer sort;
+    /**
+     * M维修 S保养 A维修+保养
+     */
+    private String type;
+    /**
+     * 状态 0启用  1停用
+     */
+    private Integer status;
+    /**
+     * 备注
+     */
+    private String remark;
+    /**
+     * 版本
+     */
+    private Integer version;
+
+}

+ 64 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/dal/dataobject/iotdevicematerial/IotDeviceMaterialDO.java

@@ -0,0 +1,64 @@
+package cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicematerial;
+
+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.*;
+
+import java.math.BigDecimal;
+
+/**
+ * PMS 设备BOM物料关联 DO
+ *
+ * @author ruiqi
+ */
+@TableName("rq_iot_device_material")
+@KeySequence("rq_iot_device_material_seq") // 用于 Oracle、PostgreSQL、Kingbase、DB2、H2 数据库的主键自增。如果是 MySQL 等数据库,可不写。
+@Data
+@EqualsAndHashCode(callSuper = true)
+@ToString(callSuper = true)
+@Builder
+@NoArgsConstructor
+@AllArgsConstructor
+public class IotDeviceMaterialDO extends BaseDO {
+
+    /**
+     * 主键
+     */
+    @TableId
+    private Long id;
+    /**
+     * 所属设备分类
+     */
+    private Long deviceCategoryId;
+    /**
+     * 所属设备
+     */
+    private Long deviceId;
+    /**
+     * 设备BOM节点名称
+     */
+    private String name;
+    /**
+     * 设备BOM节点编码
+     */
+    private String code;
+    /**
+     * 物料id
+     */
+    private Long materialId;
+    /**
+     * 数量
+     */
+    private BigDecimal quantity;
+    /**
+     * 状态 0启用  1停用
+     */
+    private Integer status;
+    /**
+     * 备注
+     */
+    private String remark;
+
+}

+ 10 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/dal/mysql/iotbom/IotBomMapper.java

@@ -3,10 +3,13 @@ package cn.iocoder.yudao.module.pms.dal.mysql.iotbom;
 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.pms.controller.admin.iotbom.vo.IotBomListReqVO;
 import cn.iocoder.yudao.module.pms.controller.admin.iotbom.vo.IotBomPageReqVO;
 import cn.iocoder.yudao.module.pms.dal.dataobject.iotbom.IotBomDO;
 import org.apache.ibatis.annotations.Mapper;
 
+import java.util.List;
+
 /**
  * PMS BOM 关系 Mapper
  *
@@ -33,4 +36,11 @@ public interface IotBomMapper extends BaseMapperX<IotBomDO> {
                 .orderByDesc(IotBomDO::getId));
     }
 
+    default List<IotBomDO> selectList(IotBomListReqVO reqVO) {
+        return selectList(new LambdaQueryWrapperX<IotBomDO>()
+                .likeIfPresent(IotBomDO::getName, reqVO.getName())
+                .eqIfPresent(IotBomDO::getDeviceCategoryId, reqVO.getDeviceCategoryId())
+                .eqIfPresent(IotBomDO::getStatus, reqVO.getStatus()));
+    }
+
 }

+ 37 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/dal/mysql/iotdevicebom/IotDeviceBomMapper.java

@@ -0,0 +1,37 @@
+package cn.iocoder.yudao.module.pms.dal.mysql.iotdevicebom;
+
+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.pms.controller.admin.iotdevicebom.vo.IotDeviceBomPageReqVO;
+import cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicebom.IotDeviceBomDO;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+ * PMS 设备BOM 关系 Mapper
+ *
+ * @author ruiqi
+ */
+@Mapper
+public interface IotDeviceBomMapper extends BaseMapperX<IotDeviceBomDO> {
+
+    default PageResult<IotDeviceBomDO> selectPage(IotDeviceBomPageReqVO reqVO) {
+        return selectPage(reqVO, new LambdaQueryWrapperX<IotDeviceBomDO>()
+                .eqIfPresent(IotDeviceBomDO::getDeviceCategoryId, reqVO.getDeviceCategoryId())
+                .eqIfPresent(IotDeviceBomDO::getDeviceId, reqVO.getDeviceId())
+                .likeIfPresent(IotDeviceBomDO::getName, reqVO.getName())
+                .eqIfPresent(IotDeviceBomDO::getCode, reqVO.getCode())
+                .eqIfPresent(IotDeviceBomDO::getParentId, reqVO.getParentId())
+                .eqIfPresent(IotDeviceBomDO::getChildIds, reqVO.getChildIds())
+                .eqIfPresent(IotDeviceBomDO::getLevel, reqVO.getLevel())
+                .eqIfPresent(IotDeviceBomDO::getLeafFlag, reqVO.getLeafFlag())
+                .eqIfPresent(IotDeviceBomDO::getSort, reqVO.getSort())
+                .eqIfPresent(IotDeviceBomDO::getType, reqVO.getType())
+                .eqIfPresent(IotDeviceBomDO::getStatus, reqVO.getStatus())
+                .eqIfPresent(IotDeviceBomDO::getRemark, reqVO.getRemark())
+                .eqIfPresent(IotDeviceBomDO::getVersion, reqVO.getVersion())
+                .betweenIfPresent(IotDeviceBomDO::getCreateTime, reqVO.getCreateTime())
+                .orderByDesc(IotDeviceBomDO::getId));
+    }
+
+}

+ 32 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/dal/mysql/iotdevicematerial/IotDeviceMaterialMapper.java

@@ -0,0 +1,32 @@
+package cn.iocoder.yudao.module.pms.dal.mysql.iotdevicematerial;
+
+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.pms.controller.admin.iotdevicematerial.vo.IotDeviceMaterialPageReqVO;
+import cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicematerial.IotDeviceMaterialDO;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+ * PMS 设备BOM物料关联 Mapper
+ *
+ * @author ruiqi
+ */
+@Mapper
+public interface IotDeviceMaterialMapper extends BaseMapperX<IotDeviceMaterialDO> {
+
+    default PageResult<IotDeviceMaterialDO> selectPage(IotDeviceMaterialPageReqVO reqVO) {
+        return selectPage(reqVO, new LambdaQueryWrapperX<IotDeviceMaterialDO>()
+                .eqIfPresent(IotDeviceMaterialDO::getDeviceCategoryId, reqVO.getDeviceCategoryId())
+                .eqIfPresent(IotDeviceMaterialDO::getDeviceId, reqVO.getDeviceId())
+                .likeIfPresent(IotDeviceMaterialDO::getName, reqVO.getName())
+                .eqIfPresent(IotDeviceMaterialDO::getCode, reqVO.getCode())
+                .eqIfPresent(IotDeviceMaterialDO::getMaterialId, reqVO.getMaterialId())
+                .eqIfPresent(IotDeviceMaterialDO::getQuantity, reqVO.getQuantity())
+                .eqIfPresent(IotDeviceMaterialDO::getStatus, reqVO.getStatus())
+                .eqIfPresent(IotDeviceMaterialDO::getRemark, reqVO.getRemark())
+                .betweenIfPresent(IotDeviceMaterialDO::getCreateTime, reqVO.getCreateTime())
+                .orderByDesc(IotDeviceMaterialDO::getId));
+    }
+
+}

+ 9 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotbom/IotBomService.java

@@ -1,11 +1,13 @@
 package cn.iocoder.yudao.module.pms.service.iotbom;
 
 import cn.iocoder.yudao.framework.common.pojo.PageResult;
+import cn.iocoder.yudao.module.pms.controller.admin.iotbom.vo.IotBomListReqVO;
 import cn.iocoder.yudao.module.pms.controller.admin.iotbom.vo.IotBomPageReqVO;
 import cn.iocoder.yudao.module.pms.controller.admin.iotbom.vo.IotBomSaveReqVO;
 import cn.iocoder.yudao.module.pms.dal.dataobject.iotbom.IotBomDO;
 
 import javax.validation.Valid;
+import java.util.List;
 
 /**
  * PMS BOM 关系 Service 接口
@@ -52,4 +54,11 @@ public interface IotBomService {
      */
     PageResult<IotBomDO> getIotBomPage(IotBomPageReqVO pageReqVO);
 
+    /**
+     * 获得PMS BOM树列表
+     *
+     * @param reqVO 编号
+     * @return BOM列表
+     */
+    List<IotBomDO> getBomList(IotBomListReqVO reqVO);
 }

+ 12 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotbom/IotBomServiceImpl.java

@@ -2,15 +2,20 @@ package cn.iocoder.yudao.module.pms.service.iotbom;
 
 import cn.iocoder.yudao.framework.common.pojo.PageResult;
 import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
+import cn.iocoder.yudao.module.pms.controller.admin.iotbom.vo.IotBomListReqVO;
 import cn.iocoder.yudao.module.pms.controller.admin.iotbom.vo.IotBomPageReqVO;
 import cn.iocoder.yudao.module.pms.controller.admin.iotbom.vo.IotBomSaveReqVO;
 import cn.iocoder.yudao.module.pms.dal.dataobject.iotbom.IotBomDO;
 import cn.iocoder.yudao.module.pms.dal.mysql.iotbom.IotBomMapper;
+import cn.iocoder.yudao.module.system.dal.dataobject.dept.DeptDO;
 import org.springframework.stereotype.Service;
 import org.springframework.validation.annotation.Validated;
 
 import javax.annotation.Resource;
 
+import java.util.Comparator;
+import java.util.List;
+
 import static cn.iocoder.yudao.framework.common.exception.util.ServiceExceptionUtil.exception;
 import static cn.iocoder.yudao.module.pms.enums.ErrorCodeConstant.IOT_BOM_NOT_EXISTS;
 
@@ -68,4 +73,11 @@ public class IotBomServiceImpl implements IotBomService {
         return iotBomMapper.selectPage(pageReqVO);
     }
 
+    @Override
+    public List<IotBomDO> getBomList(IotBomListReqVO reqVO) {
+        List<IotBomDO> list = iotBomMapper.selectList(reqVO);
+        list.sort(Comparator.comparing(IotBomDO::getSort));
+        return list;
+    }
+
 }

+ 55 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotdevicebom/IotDeviceBomService.java

@@ -0,0 +1,55 @@
+package cn.iocoder.yudao.module.pms.service.iotdevicebom;
+
+import cn.iocoder.yudao.framework.common.pojo.PageResult;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicebom.vo.IotDeviceBomPageReqVO;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicebom.vo.IotDeviceBomSaveReqVO;
+import cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicebom.IotDeviceBomDO;
+
+import javax.validation.Valid;
+
+/**
+ * PMS 设备BOM 关系 Service 接口
+ *
+ * @author ruiqi
+ */
+public interface IotDeviceBomService {
+
+    /**
+     * 创建PMS 设备BOM 关系
+     *
+     * @param createReqVO 创建信息
+     * @return 编号
+     */
+    Long createIotDeviceBom(@Valid IotDeviceBomSaveReqVO createReqVO);
+
+    /**
+     * 更新PMS 设备BOM 关系
+     *
+     * @param updateReqVO 更新信息
+     */
+    void updateIotDeviceBom(@Valid IotDeviceBomSaveReqVO updateReqVO);
+
+    /**
+     * 删除PMS 设备BOM 关系
+     *
+     * @param id 编号
+     */
+    void deleteIotDeviceBom(Long id);
+
+    /**
+     * 获得PMS 设备BOM 关系
+     *
+     * @param id 编号
+     * @return PMS 设备BOM 关系
+     */
+    IotDeviceBomDO getIotDeviceBom(Long id);
+
+    /**
+     * 获得PMS 设备BOM 关系分页
+     *
+     * @param pageReqVO 分页查询
+     * @return PMS 设备BOM 关系分页
+     */
+    PageResult<IotDeviceBomDO> getIotDeviceBomPage(IotDeviceBomPageReqVO pageReqVO);
+
+}

+ 72 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotdevicebom/IotDeviceBomServiceImpl.java

@@ -0,0 +1,72 @@
+package cn.iocoder.yudao.module.pms.service.iotdevicebom;
+
+import cn.iocoder.yudao.framework.common.pojo.PageResult;
+import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicebom.vo.IotDeviceBomPageReqVO;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicebom.vo.IotDeviceBomSaveReqVO;
+import cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicebom.IotDeviceBomDO;
+import cn.iocoder.yudao.module.pms.dal.mysql.iotdevicebom.IotDeviceBomMapper;
+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.pms.enums.ErrorCodeConstant.IOT_DEVICE_BOM_NOT_EXISTS;
+
+
+/**
+ * PMS 设备BOM 关系 Service 实现类
+ *
+ * @author ruiqi
+ */
+@Service
+@Validated
+public class IotDeviceBomServiceImpl implements IotDeviceBomService {
+
+    @Resource
+    private IotDeviceBomMapper iotDeviceBomMapper;
+
+    @Override
+    public Long createIotDeviceBom(IotDeviceBomSaveReqVO createReqVO) {
+        // 插入
+        IotDeviceBomDO iotDeviceBom = BeanUtils.toBean(createReqVO, IotDeviceBomDO.class);
+        iotDeviceBomMapper.insert(iotDeviceBom);
+        // 返回
+        return iotDeviceBom.getId();
+    }
+
+    @Override
+    public void updateIotDeviceBom(IotDeviceBomSaveReqVO updateReqVO) {
+        // 校验存在
+        validateIotDeviceBomExists(updateReqVO.getId());
+        // 更新
+        IotDeviceBomDO updateObj = BeanUtils.toBean(updateReqVO, IotDeviceBomDO.class);
+        iotDeviceBomMapper.updateById(updateObj);
+    }
+
+    @Override
+    public void deleteIotDeviceBom(Long id) {
+        // 校验存在
+        validateIotDeviceBomExists(id);
+        // 删除
+        iotDeviceBomMapper.deleteById(id);
+    }
+
+    private void validateIotDeviceBomExists(Long id) {
+        if (iotDeviceBomMapper.selectById(id) == null) {
+            throw exception(IOT_DEVICE_BOM_NOT_EXISTS);
+        }
+    }
+
+    @Override
+    public IotDeviceBomDO getIotDeviceBom(Long id) {
+        return iotDeviceBomMapper.selectById(id);
+    }
+
+    @Override
+    public PageResult<IotDeviceBomDO> getIotDeviceBomPage(IotDeviceBomPageReqVO pageReqVO) {
+        return iotDeviceBomMapper.selectPage(pageReqVO);
+    }
+
+}

+ 55 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotdevicematerial/IotDeviceMaterialService.java

@@ -0,0 +1,55 @@
+package cn.iocoder.yudao.module.pms.service.iotdevicematerial;
+
+import cn.iocoder.yudao.framework.common.pojo.PageResult;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicematerial.vo.IotDeviceMaterialPageReqVO;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicematerial.vo.IotDeviceMaterialSaveReqVO;
+import cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicematerial.IotDeviceMaterialDO;
+
+import javax.validation.Valid;
+
+/**
+ * PMS 设备BOM物料关联 Service 接口
+ *
+ * @author ruiqi
+ */
+public interface IotDeviceMaterialService {
+
+    /**
+     * 创建PMS 设备BOM物料关联
+     *
+     * @param createReqVO 创建信息
+     * @return 编号
+     */
+    Long createIotDeviceMaterial(@Valid IotDeviceMaterialSaveReqVO createReqVO);
+
+    /**
+     * 更新PMS 设备BOM物料关联
+     *
+     * @param updateReqVO 更新信息
+     */
+    void updateIotDeviceMaterial(@Valid IotDeviceMaterialSaveReqVO updateReqVO);
+
+    /**
+     * 删除PMS 设备BOM物料关联
+     *
+     * @param id 编号
+     */
+    void deleteIotDeviceMaterial(Long id);
+
+    /**
+     * 获得PMS 设备BOM物料关联
+     *
+     * @param id 编号
+     * @return PMS 设备BOM物料关联
+     */
+    IotDeviceMaterialDO getIotDeviceMaterial(Long id);
+
+    /**
+     * 获得PMS 设备BOM物料关联分页
+     *
+     * @param pageReqVO 分页查询
+     * @return PMS 设备BOM物料关联分页
+     */
+    PageResult<IotDeviceMaterialDO> getIotDeviceMaterialPage(IotDeviceMaterialPageReqVO pageReqVO);
+
+}

+ 72 - 0
yudao-module-pms/yudao-module-pms-biz/src/main/java/cn/iocoder/yudao/module/pms/service/iotdevicematerial/IotDeviceMaterialServiceImpl.java

@@ -0,0 +1,72 @@
+package cn.iocoder.yudao.module.pms.service.iotdevicematerial;
+
+import cn.iocoder.yudao.framework.common.pojo.PageResult;
+import cn.iocoder.yudao.framework.common.util.object.BeanUtils;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicematerial.vo.IotDeviceMaterialPageReqVO;
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicematerial.vo.IotDeviceMaterialSaveReqVO;
+import cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicematerial.IotDeviceMaterialDO;
+import cn.iocoder.yudao.module.pms.dal.mysql.iotdevicematerial.IotDeviceMaterialMapper;
+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.pms.enums.ErrorCodeConstant.IOT_DEVICE_MATERIAL_NOT_EXISTS;
+
+
+/**
+ * PMS 设备BOM物料关联 Service 实现类
+ *
+ * @author ruiqi
+ */
+@Service
+@Validated
+public class IotDeviceMaterialServiceImpl implements IotDeviceMaterialService {
+
+    @Resource
+    private IotDeviceMaterialMapper iotDeviceMaterialMapper;
+
+    @Override
+    public Long createIotDeviceMaterial(IotDeviceMaterialSaveReqVO createReqVO) {
+        // 插入
+        IotDeviceMaterialDO iotDeviceMaterial = BeanUtils.toBean(createReqVO, IotDeviceMaterialDO.class);
+        iotDeviceMaterialMapper.insert(iotDeviceMaterial);
+        // 返回
+        return iotDeviceMaterial.getId();
+    }
+
+    @Override
+    public void updateIotDeviceMaterial(IotDeviceMaterialSaveReqVO updateReqVO) {
+        // 校验存在
+        validateIotDeviceMaterialExists(updateReqVO.getId());
+        // 更新
+        IotDeviceMaterialDO updateObj = BeanUtils.toBean(updateReqVO, IotDeviceMaterialDO.class);
+        iotDeviceMaterialMapper.updateById(updateObj);
+    }
+
+    @Override
+    public void deleteIotDeviceMaterial(Long id) {
+        // 校验存在
+        validateIotDeviceMaterialExists(id);
+        // 删除
+        iotDeviceMaterialMapper.deleteById(id);
+    }
+
+    private void validateIotDeviceMaterialExists(Long id) {
+        if (iotDeviceMaterialMapper.selectById(id) == null) {
+            throw exception(IOT_DEVICE_MATERIAL_NOT_EXISTS);
+        }
+    }
+
+    @Override
+    public IotDeviceMaterialDO getIotDeviceMaterial(Long id) {
+        return iotDeviceMaterialMapper.selectById(id);
+    }
+
+    @Override
+    public PageResult<IotDeviceMaterialDO> getIotDeviceMaterialPage(IotDeviceMaterialPageReqVO pageReqVO) {
+        return iotDeviceMaterialMapper.selectPage(pageReqVO);
+    }
+
+}