zuoxiao
2025-04-23 d20d38e22b06559d758c568769017e2acf632583
pipIrr-platform/pipIrr-web/pipIrr-web-irrigate/src/main/java/com/dy/pipIrrIrrigate/project/ProjectCtrl.java
@@ -3,8 +3,15 @@
import com.dy.common.aop.SsoAop;
import com.dy.common.webUtil.BaseResponse;
import com.dy.common.webUtil.BaseResponseUtils;
import com.dy.common.webUtil.QueryResultVo;
import com.dy.common.webUtil.ResultCodeMsg;
import com.dy.pipIrrGlobal.pojoIr.IrProject;
import com.dy.pipIrrGlobal.voIr.VoProject;
import com.dy.pipIrrGlobal.voIr.VoProjectDetail;
import com.dy.pipIrrGlobal.voIr.VoProjectOne;
import com.dy.pipIrrGlobal.voIr.VoProjectSimple;
import com.dy.pipIrrGlobal.voSe.VoActiveCard;
import com.dy.pipIrrIrrigate.project.dto.IrrigateProject;
import com.dy.pipIrrIrrigate.result.IrrigateResultCode;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.media.Content;
@@ -15,17 +22,15 @@
import jakarta.validation.Valid;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.apache.ibatis.annotations.Param;
import org.springframework.http.MediaType;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.validation.BindingResult;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.bind.annotation.*;
import java.lang.reflect.Array;
import java.util.*;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.Optional;
/**
 * @author :WuZeYu
@@ -42,8 +47,7 @@
    private final ProjectSv projectSv;
    /**
     * 添加项目
     *
     * 添加项目,旧版本,原则上废弃
     * @param po            项目实体对象
     * @param bindingResult
     * @return 添加是否成功
@@ -77,7 +81,7 @@
    }
    /**
     * 逻辑删除项目
     * 逻辑删除项目,旧版本,原则上废弃
     * @param map
     * @return
     */
@@ -118,12 +122,13 @@
    @PostMapping(path = "delete_batch", consumes = MediaType.APPLICATION_JSON_VALUE)
    @Transactional(rollbackFor = Exception.class)
    @SsoAop()
    public BaseResponse<Boolean> delete_batch(@RequestBody List<Long> projectIds) {
    public BaseResponse<Boolean> delete_batch(@RequestBody Map<String,List> projectIds) {
        if (projectIds == null || projectIds.size() <= 0) {
            BaseResponseUtils.buildFail(IrrigateResultCode.PLEASE_INPUT_PROJECT_ID.getMessage());
        }
        for (int i = 0; i < projectIds.size(); i++) {
            Long projectId = projectIds.get(i);
        List ids = projectIds.get("projectIds");
        for (int i = 0; i < ids.size(); i++) {
            long projectId = Long.parseLong(ids.get(i).toString());
            try {
                Integer rows = projectSv.deleteProject(projectId);
                if (rows == 0) {
@@ -138,7 +143,7 @@
    }
    /**
     * 修改项目信息
     * 修改项目信息,旧版本,原则上废弃
     * @param po
     * @param bindingResult
     * @return
@@ -172,7 +177,7 @@
    }
    /**
     * 修改项目状态
     * 修改项目状态,无用接口,原则上废弃
     * @param po
     * @param
     * @return
@@ -201,4 +206,190 @@
        }
        return BaseResponseUtils.buildSuccess(true);
    }
    /**
     * 获取一个项目数据,旧版本,原则上废弃
     * @return 获取一个项目数据
     */
    @Operation(summary = "获取一个项目数据", description = "获取一个项目数据")
    @ApiResponses(value = {
            @ApiResponse(
                    responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE,
                    description = "获取一个项目数据(BaseResponse.content:{})",
                    content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE,
                            schema = @Schema(implementation = IrProject.class))}
            )
    })
    @GetMapping(path = "one")
    @SsoAop()
    public BaseResponse<VoProjectOne> one(@RequestParam Long id) {
        VoProjectOne irProject = this.projectSv.selectById(id);
            return BaseResponseUtils.buildSuccess(irProject);
    }
    /**
     * 分页查询,旧版本,原则上废弃
     * @param vo
     * @return
     */
    @Operation(summary = "获得一页项目记录", description = "获得一页项目记录")
    @ApiResponses(value = {
            @ApiResponse(
                    responseCode = ResultCodeMsg.RsCode.SUCCESS_CODE,
                    description = "获得一页项目记录(BaseResponse.content:QueryResultVo[{}])",
                    content = {@Content(mediaType = MediaType.APPLICATION_JSON_VALUE,
                            schema = @Schema(implementation = VoActiveCard.class))}
            )
    })
    @GetMapping(path = "some")
    @SsoAop()
    public BaseResponse<QueryResultVo<List<VoProject>>> getProjects(QueryVo vo) {
        try {
            QueryResultVo<List<VoProject>> res = projectSv.getProjects(vo);
            return BaseResponseUtils.buildSuccess(res);
        } catch (Exception e) {
            log.error("获取项目记录异常", e);
            return BaseResponseUtils.buildException(e.getMessage());
        }
    }
    /**
     * 添加项目,新版本,使用这个
     * @param po            项目实体对象
     * @param bindingResult
     * @return 添加是否成功
     */
    @PostMapping(path = "addIrrigateProject", consumes = MediaType.APPLICATION_JSON_VALUE)
    @Transactional(rollbackFor = Exception.class)
    @SsoAop()
    public BaseResponse<Boolean> addIrrigateProject(@RequestBody @Valid IrrigateProject po, BindingResult bindingResult) {
        if (bindingResult != null && bindingResult.hasErrors()) {
            return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());
        }
        Map map_result = projectSv.addIrrigateProject(po);
        if(map_result.get("success").equals(false)) {
            return BaseResponseUtils.buildErrorMsg(map_result.get("msg").toString());
        }
        return BaseResponseUtils.buildSuccess() ;
        //String projectName = po.getProjectName();
        //String irrigateGroups = po.getIrrigateGroups();
        //Long operatorId = po.getOperatorId();
        //
        //IrProject irProject = new IrProject();
        //irProject.setProjectName(projectName);
        //irProject.setProjectState((byte)1);
        //irProject.setOperator(operatorId);
        //irProject.setOperateTime(new Date());
        //irProject.setDeleted((byte)0);
        //Long projectId = projectSv.addIrrigateProject(irProject);
        //if(projectId == null) {
        //    return BaseResponseUtils.buildErrorMsg("创建灌溉项目失败");
        //}
        //
        //String[] irrigateGroupArr = irrigateGroups.split(",");
        //Integer sort = 1;
        //for(String irrigateGroupId : irrigateGroupArr) {
        //    String trimmed = irrigateGroupId.trim();
        //    if(trimmed.isEmpty()) {
        //        continue;
        //    }
        //    try {
        //        Long irrigateGroupIdLong = Long.parseLong(trimmed);
        //        IrProjectGroup irProjectGroup = new IrProjectGroup();
        //        irProjectGroup.setProjectId(projectId);
        //        irProjectGroup.setGroupId(irrigateGroupIdLong);
        //        irProjectGroup.setSort(sort++);
        //        projectSv.projectBindGroup(irProjectGroup);
        //
        //    } catch (NumberFormatException  e) {
        //        return BaseResponseUtils.buildErrorMsg("灌溉组ID格式错误");
        //    }
        //}
    }
    /**
     * 删除项目,新版本,使用这个
     * @param projectId
     * @return
     */
    @PostMapping(path = "deleteIrrigateProject")
    @Transactional(rollbackFor = Exception.class)
    @SsoAop()
    public BaseResponse<Boolean> deleteIrrigateProject(@RequestParam(required = false) Long projectId) {
        if(projectId == null) {
            return BaseResponseUtils.buildErrorMsg("项目ID不能为空");
        }
        Map map_result = projectSv.deleteIrrigateProject(projectId);
        if(map_result.get("success").equals(false)) {
            return BaseResponseUtils.buildErrorMsg(map_result.get("msg").toString());
        }
        return BaseResponseUtils.buildSuccess() ;
    }
    /**
     * 修改项目,新版本,使用这个
     * @param po
     * @param bindingResult
     * @return
     */
    @PostMapping(path = "updateIrrigateProject", consumes = MediaType.APPLICATION_JSON_VALUE)
    @Transactional(rollbackFor = Exception.class)
    @SsoAop()
    public BaseResponse<Boolean> updateIrrigateProject(@RequestBody @Valid IrrigateProject po, BindingResult bindingResult){
        if (bindingResult != null && bindingResult.hasErrors()) {
            return BaseResponseUtils.buildFail(Objects.requireNonNull(bindingResult.getFieldError()).getDefaultMessage());
        }
        if(po.getProjectId() == null) {
            return BaseResponseUtils.buildErrorMsg("项目ID不能为空");
        }
        Map map_result = projectSv.updateIrrigateProject(po);
        if(map_result.get("success").equals(false)) {
            return BaseResponseUtils.buildErrorMsg(map_result.get("msg").toString());
        }
        return BaseResponseUtils.buildSuccess() ;
    }
    /**
     * 分页查询项目,新版本,目前使用
     * @param qo
     * @return
     */
    @GetMapping(path = "/getSimpleProjects")
    @SsoAop()
    public BaseResponse<QueryResultVo<List<VoProjectSimple>>> getSimpleProjects(QueryVo qo) {
        try {
            QueryResultVo<List<VoProjectSimple>> res = projectSv.getSimpleProjects(qo);
            return BaseResponseUtils.buildSuccess(res);
        } catch (Exception e) {
            log.error("获取项目记录异常", e);
            return BaseResponseUtils.buildException(e.getMessage());
        }
    }
    /**
     * 根据项目Id获取项目详情,编辑项目信息使用
     * @param projectId
     * @return
     */
    @GetMapping(path = "getProject")
    @SsoAop()
    public BaseResponse<VoProjectDetail> getProject(@RequestParam Long projectId) {
        if(projectId == null) {
            return BaseResponseUtils.buildErrorMsg("项目ID不能为空");
        }
        Map map_result = projectSv.getProjectDetail(projectId);
        if(map_result.get("success").equals(false)) {
            return BaseResponseUtils.buildErrorMsg(map_result.get("msg").toString());
        }
        return BaseResponseUtils.buildSuccess(map_result.get("content")) ;
    }
}