|
@@ -1,5 +1,6 @@
|
|
|
package cn.iocoder.yudao.module.pms.controller.admin.iotdevicebom;
|
|
|
|
|
|
+import cn.hutool.core.collection.CollUtil;
|
|
|
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;
|
|
@@ -8,8 +9,11 @@ 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.*;
|
|
|
+import cn.iocoder.yudao.module.pms.controller.admin.iotdevicematerial.vo.IotDeviceMaterialSaveReqVO;
|
|
|
import cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicebom.IotDeviceBomDO;
|
|
|
+import cn.iocoder.yudao.module.pms.dal.dataobject.iotdevicematerial.IotDeviceMaterialDO;
|
|
|
import cn.iocoder.yudao.module.pms.service.iotdevicebom.IotDeviceBomService;
|
|
|
+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;
|
|
@@ -21,7 +25,11 @@ import javax.annotation.Resource;
|
|
|
import javax.servlet.http.HttpServletResponse;
|
|
|
import javax.validation.Valid;
|
|
|
import java.io.IOException;
|
|
|
+import java.util.Collections;
|
|
|
+import java.util.HashMap;
|
|
|
import java.util.List;
|
|
|
+import java.util.Map;
|
|
|
+import java.util.stream.Collectors;
|
|
|
|
|
|
import static cn.iocoder.yudao.framework.apilog.core.enums.OperateTypeEnum.EXPORT;
|
|
|
import static cn.iocoder.yudao.framework.common.pojo.CommonResult.success;
|
|
@@ -34,6 +42,8 @@ public class IotDeviceBomController {
|
|
|
|
|
|
@Resource
|
|
|
private IotDeviceBomService iotDeviceBomService;
|
|
|
+ @Resource
|
|
|
+ private IotDeviceMaterialService iotDeviceMaterialService;
|
|
|
|
|
|
@PostMapping("/create")
|
|
|
@Operation(summary = "创建PMS 设备BOM 关系")
|
|
@@ -89,7 +99,31 @@ public class IotDeviceBomController {
|
|
|
@PreAuthorize("@ss.hasPermission('rq:iot-material-group:query')")
|
|
|
public CommonResult<List<IotDeviceBomRespVO>> getDeviceBomList(IotDeviceBomListReqVO reqVO) {
|
|
|
List<IotDeviceBomDO> list = iotDeviceBomService.getDeviceBomList(reqVO);
|
|
|
- return success(BeanUtils.toBean(list, IotDeviceBomRespVO.class));
|
|
|
+ if (CollUtil.isEmpty(list)) {
|
|
|
+ return success(Collections.emptyList());
|
|
|
+ }
|
|
|
+ // 当前设备 设备类别 下所有BOM节点
|
|
|
+ List<Long> bomNodeIds = list.stream()
|
|
|
+ .map(IotDeviceBomDO::getId)
|
|
|
+ .collect(Collectors.toList());
|
|
|
+ IotDeviceMaterialSaveReqVO saveReqVO = new IotDeviceMaterialSaveReqVO();
|
|
|
+ saveReqVO.setBomNodeIds(bomNodeIds);
|
|
|
+ // 查询所有bom节点已经绑定的物料列表
|
|
|
+ List<IotDeviceMaterialDO> deviceMaterials = iotDeviceMaterialService.getIotDeviceMaterials(saveReqVO);
|
|
|
+ Map<Long, Integer> bomMaterialCount = new HashMap<>();
|
|
|
+ if (CollUtil.isNotEmpty(deviceMaterials)) {
|
|
|
+ deviceMaterials.forEach(material -> {
|
|
|
+ if (bomMaterialCount.containsKey(material.getBomNodeId())) {
|
|
|
+ bomMaterialCount.put(material.getBomNodeId(), bomMaterialCount.get(material.getBomNodeId())+1);
|
|
|
+ } else {
|
|
|
+ bomMaterialCount.put(material.getBomNodeId(), 1);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+ return success(BeanUtils.toBean(list, IotDeviceBomRespVO.class, bom -> {
|
|
|
+ Integer materialCount = bomMaterialCount.getOrDefault(bom.getId(), 0);
|
|
|
+ bom.setMaterials(materialCount);
|
|
|
+ }));
|
|
|
}
|
|
|
|
|
|
@GetMapping("/export-excel")
|