|
@@ -12,10 +12,16 @@ import cn.iocoder.yudao.module.pms.controller.admin.qhse.hazard.vo.IotHazardPage
|
|
|
import cn.iocoder.yudao.module.pms.controller.admin.qhse.hazard.vo.IotHazardRectifyVO;
|
|
import cn.iocoder.yudao.module.pms.controller.admin.qhse.hazard.vo.IotHazardRectifyVO;
|
|
|
import cn.iocoder.yudao.module.pms.controller.admin.qhse.hazard.vo.IotHazardRespVO;
|
|
import cn.iocoder.yudao.module.pms.controller.admin.qhse.hazard.vo.IotHazardRespVO;
|
|
|
import cn.iocoder.yudao.module.pms.controller.admin.qhse.hazard.vo.IotHazardSaveReqVO;
|
|
import cn.iocoder.yudao.module.pms.controller.admin.qhse.hazard.vo.IotHazardSaveReqVO;
|
|
|
|
|
+import cn.iocoder.yudao.module.pms.controller.admin.qhse.measure.IotMeasureBookController;
|
|
|
import cn.iocoder.yudao.module.pms.dal.dataobject.qhse.hazard.IotHazardDO;
|
|
import cn.iocoder.yudao.module.pms.dal.dataobject.qhse.hazard.IotHazardDO;
|
|
|
|
|
+import cn.iocoder.yudao.module.pms.dal.mysql.qhse.hazard.IotHazardMapper;
|
|
|
import cn.iocoder.yudao.module.pms.service.qhse.hazard.IotHazardService;
|
|
import cn.iocoder.yudao.module.pms.service.qhse.hazard.IotHazardService;
|
|
|
import cn.iocoder.yudao.module.system.api.dept.DeptApi;
|
|
import cn.iocoder.yudao.module.system.api.dept.DeptApi;
|
|
|
import cn.iocoder.yudao.module.system.api.dept.dto.DeptRespDTO;
|
|
import cn.iocoder.yudao.module.system.api.dept.dto.DeptRespDTO;
|
|
|
|
|
+import cn.iocoder.yudao.module.system.dal.dataobject.dict.DictDataDO;
|
|
|
|
|
+import cn.iocoder.yudao.module.system.service.dept.DeptService;
|
|
|
|
|
+import cn.iocoder.yudao.module.system.service.dict.DictDataService;
|
|
|
|
|
+import com.google.common.collect.ImmutableMap;
|
|
|
import io.swagger.v3.oas.annotations.Operation;
|
|
import io.swagger.v3.oas.annotations.Operation;
|
|
|
import io.swagger.v3.oas.annotations.Parameter;
|
|
import io.swagger.v3.oas.annotations.Parameter;
|
|
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
import io.swagger.v3.oas.annotations.tags.Tag;
|
|
@@ -26,11 +32,11 @@ import org.springframework.validation.annotation.Validated;
|
|
|
import org.springframework.web.bind.annotation.*;
|
|
import org.springframework.web.bind.annotation.*;
|
|
|
|
|
|
|
|
import javax.annotation.Resource;
|
|
import javax.annotation.Resource;
|
|
|
|
|
+import javax.annotation.security.PermitAll;
|
|
|
import javax.servlet.http.HttpServletResponse;
|
|
import javax.servlet.http.HttpServletResponse;
|
|
|
import javax.validation.Valid;
|
|
import javax.validation.Valid;
|
|
|
import java.io.IOException;
|
|
import java.io.IOException;
|
|
|
-import java.util.List;
|
|
|
|
|
-import java.util.Objects;
|
|
|
|
|
|
|
+import java.util.*;
|
|
|
import java.util.stream.Collectors;
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
import static cn.iocoder.yudao.framework.apilog.core.enums.OperateTypeEnum.EXPORT;
|
|
import static cn.iocoder.yudao.framework.apilog.core.enums.OperateTypeEnum.EXPORT;
|
|
@@ -47,6 +53,12 @@ public class IotHazardController {
|
|
|
private IotHazardService iotHazardService;
|
|
private IotHazardService iotHazardService;
|
|
|
@Autowired
|
|
@Autowired
|
|
|
private DeptApi deptApi;
|
|
private DeptApi deptApi;
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private IotHazardMapper iotHazardMapper;
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private DeptService deptService;
|
|
|
|
|
+ @Autowired
|
|
|
|
|
+ private DictDataService dictDataService;
|
|
|
|
|
|
|
|
@PostMapping("/create")
|
|
@PostMapping("/create")
|
|
|
@Operation(summary = "创建QHSE隐患排查及整改")
|
|
@Operation(summary = "创建QHSE隐患排查及整改")
|
|
@@ -125,4 +137,33 @@ public class IotHazardController {
|
|
|
BeanUtils.toBean(list, IotHazardRespVO.class));
|
|
BeanUtils.toBean(list, IotHazardRespVO.class));
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+ @GetMapping("/stat")
|
|
|
|
|
+ @PermitAll
|
|
|
|
|
+ public CommonResult<ImmutableMap<String, Object>> statHazard(Long deptId) {
|
|
|
|
|
+ Set<Long> ids = new HashSet<>();
|
|
|
|
|
+ if (Objects.nonNull(deptId)) {
|
|
|
|
|
+ ids = deptService.getChildDeptIdListFromCache(deptId);
|
|
|
|
|
+ ids.add(deptId);
|
|
|
|
|
+ }
|
|
|
|
|
+ IotHazardPageReqVO pageReqVO = new IotHazardPageReqVO();
|
|
|
|
|
+ List<IotHazardDO> iotHazardDOS = iotHazardMapper.selectListByDept(pageReqVO, ids);
|
|
|
|
|
+ int total = iotHazardDOS.size();
|
|
|
|
|
+ pageReqVO.setStatus("todo");
|
|
|
|
|
+ int todoSize = iotHazardMapper.selectListByDept(pageReqVO, ids).size();
|
|
|
|
|
+ List<IotMeasureBookController.ClassifyMeasureBookStatVo> results = new ArrayList<>();
|
|
|
|
|
+ List<DictDataDO> dictType = dictDataService.getDictDataListByDictType("hazard_soure");
|
|
|
|
|
+ Map<String, Long> sourceMap = iotHazardDOS.stream().filter(it -> Objects.nonNull(it.getSource()))
|
|
|
|
|
+ .collect(Collectors.groupingBy(
|
|
|
|
|
+ IotHazardDO::getSource,
|
|
|
|
|
+ Collectors.counting() // 直接统计每个分组的数量
|
|
|
|
|
+ ));
|
|
|
|
|
+ sourceMap.forEach((key, value) -> dictType.stream().filter(e -> e.getValue().equals(key)).findFirst().ifPresent(f ->{
|
|
|
|
|
+ IotMeasureBookController.ClassifyMeasureBookStatVo statVo = new IotMeasureBookController.ClassifyMeasureBookStatVo();
|
|
|
|
|
+ statVo.setClassify(f.getLabel());
|
|
|
|
|
+ statVo.setCount(value);
|
|
|
|
|
+ results.add(statVo);
|
|
|
|
|
+ }));
|
|
|
|
|
+ return success(ImmutableMap.of("total",total,"todo",todoSize,"source", results));
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
}
|
|
}
|