diff --git a/src/main/java/com/lz/modules/app/controller/ResultRecordController.java b/src/main/java/com/lz/modules/app/controller/ResultRecordController.java index 01a8119f..d41b266b 100644 --- a/src/main/java/com/lz/modules/app/controller/ResultRecordController.java +++ b/src/main/java/com/lz/modules/app/controller/ResultRecordController.java @@ -8,6 +8,7 @@ import com.lz.modules.app.dto.RecordDetailDto; import com.lz.modules.app.dto.StaffDepartmentDto; import com.lz.modules.app.entity.DepartmentsStaffRelateEntity; import com.lz.modules.app.entity.StaffEntity; +import com.lz.modules.app.entity.StaffSimpleInfo; import com.lz.modules.app.req.ResultRecordReq; import com.lz.modules.app.resp.ResultDetailResp; import com.lz.modules.app.resp.Step; @@ -16,7 +17,9 @@ import com.lz.modules.app.service.DepartmentsStaffRelateService; import com.lz.modules.app.service.StaffService; import com.lz.modules.flow.entity.*; import com.lz.modules.flow.model.Auth; +import com.lz.modules.flow.model.ResultDetailDto; import com.lz.modules.flow.model.ResultRecordDetailDto; +import com.lz.modules.flow.model.ResultRecortModelDto; import com.lz.modules.flow.req.ResultDetailReq; import com.lz.modules.flow.service.*; import com.lz.modules.sys.controller.AbstractController; @@ -51,7 +54,7 @@ import java.util.stream.Collectors; @RestController @RequestMapping("user/lzresultrecord") @Slf4j -@Api("绩效相关-吴林") +@Api(tags = "绩效相关") public class ResultRecordController extends AbstractController { @Autowired private ResultRecordService lzResultRecordService; @@ -319,12 +322,15 @@ public class ResultRecordController extends AbstractController { * 信息 */ @GetMapping("/getDetail") - @ApiOperation("获取绩效详情") + @ApiOperation("获取绩效详情-吴林") @ApiResponses({@ApiResponse(code = 200, message = "成功", response = ResultRecordDetailDto.class)}) public R getDetail(@RequestParam @ApiParam("绩效id") Long id) { ResultRecord resultRecord = lzResultRecordService.selectResultRecordById(id); - SysUserEntity user = getUser(); + if(resultRecord == null){ + return R.error("绩效不存在"); + } + /*SysUserEntity user = getUser(); if(resultRecord.getStaffId().longValue() != user.getUserId().longValue()){ //下面判断权限,是否可读 EvaluationStartStaff evaluationStartStaff = @@ -332,10 +338,41 @@ public class ResultRecordController extends AbstractController { if(evaluationStartStaff == null){//非考核组设置的绩效管理人员,下面应在查询其他权限 return R.error("未被授权访问"); } - } + }*/ //获取考核维度等信息 + ResultRecordDetailDto resultRecordDetailDto = new ResultRecordDetailDto(); + BeanUtils.copyProperties(resultRecord, resultRecordDetailDto); List resultModels = resultModelService.selectResultModelByGroupId(resultRecord.getEvaluationId()); - return R.ok().put("data", resultRecord); + StaffEntity staffEntity = staffService.selectStaffById(resultRecord.getStaffId()); + resultRecordDetailDto.setAvatar(staffEntity.getAvatar()); + resultRecordDetailDto.setJobNumber(staffEntity.getJobNumber()); + List resultRecortModelDtos = new ArrayList<>(); + for (ResultModel model:resultModels + ) { + resultRecordDetailDto.setCalculateId(model.getCalculateId()); + resultRecordDetailDto.setGradeGroupId(model.getGradeGroupId()); + ResultRecortModelDto resultRecortModelDto = new ResultRecortModelDto(); + BeanUtils.copyProperties(model, resultRecortModelDto); + List detailDtos = resultDetailService.selectDtosByRecordId(resultRecord.getId(), model.getType()); + resultRecortModelDto.setDetailDtos(detailDtos); + resultRecortModelDtos.add(resultRecortModelDto); + } + resultRecordDetailDto.setRecortModelDtos(resultRecortModelDtos); + + return R.ok().put("data", resultRecordDetailDto); + + + } + + @PostMapping("/saveDetail") + @ApiOperation("保存绩效详情-吴林") + public R saveDetail(@RequestParam @ApiParam("绩效id") ResultRecordDetailDto dto) { + + + + return R.ok(); + + } /** diff --git a/src/main/java/com/lz/modules/app/dao/StaffDao.java b/src/main/java/com/lz/modules/app/dao/StaffDao.java index ea5a4486..e49fdf88 100644 --- a/src/main/java/com/lz/modules/app/dao/StaffDao.java +++ b/src/main/java/com/lz/modules/app/dao/StaffDao.java @@ -92,4 +92,6 @@ public interface StaffDao extends BaseMapper { List selectStaffSimpleInfos(@Param("sIds") List sIds); List selectOnJobByIds(@Param("mIds") List mIds); + + StaffSimpleInfo selectStaffSimpleInfo(@Param("staffId") Long staffId); } diff --git a/src/main/java/com/lz/modules/app/entity/StaffSimpleInfo.java b/src/main/java/com/lz/modules/app/entity/StaffSimpleInfo.java index adecad38..df8fc507 100644 --- a/src/main/java/com/lz/modules/app/entity/StaffSimpleInfo.java +++ b/src/main/java/com/lz/modules/app/entity/StaffSimpleInfo.java @@ -44,6 +44,8 @@ public class StaffSimpleInfo implements Serializable { private String departmentId; //钉钉,飞书等第三方人员id private String employeeId; + //头像 + private String avatar; } diff --git a/src/main/java/com/lz/modules/app/service/StaffService.java b/src/main/java/com/lz/modules/app/service/StaffService.java index d6731bf0..76621438 100644 --- a/src/main/java/com/lz/modules/app/service/StaffService.java +++ b/src/main/java/com/lz/modules/app/service/StaffService.java @@ -97,5 +97,7 @@ public interface StaffService extends IService { DepartManagers findLeader(Long id, Integer type); //查找在职的 List selectOnJobByIds(List mIds); + + StaffSimpleInfo selectStaffSimpleInfo(Long staffId); } diff --git a/src/main/java/com/lz/modules/app/service/impl/StaffServiceImpl.java b/src/main/java/com/lz/modules/app/service/impl/StaffServiceImpl.java index 93011dc1..aea7cd9b 100644 --- a/src/main/java/com/lz/modules/app/service/impl/StaffServiceImpl.java +++ b/src/main/java/com/lz/modules/app/service/impl/StaffServiceImpl.java @@ -514,5 +514,10 @@ public class StaffServiceImpl extends ServiceImpl impleme return staffDao.selectOnJobByIds(mIds); } + @Override + public StaffSimpleInfo selectStaffSimpleInfo(Long staffId){ + return staffDao.selectStaffSimpleInfo(staffId); + } + } diff --git a/src/main/java/com/lz/modules/flow/model/ResultRecordDetailDto.java b/src/main/java/com/lz/modules/flow/model/ResultRecordDetailDto.java index 04bbeb51..75f4a5bc 100644 --- a/src/main/java/com/lz/modules/flow/model/ResultRecordDetailDto.java +++ b/src/main/java/com/lz/modules/flow/model/ResultRecordDetailDto.java @@ -37,18 +37,30 @@ public class ResultRecordDetailDto { @ApiModelProperty(value = "员工id", name = "staffId") private Long staffId; + @ApiModelProperty(value = "lz_result_calculate 的id,计算法方法id", name = "calculateId") + private Long calculateId; + + //使用的哪个等级。等级组id,lz_result_grade的group_id + @ApiModelProperty(value = "使用的哪个等级。等级组id,lz_result_grade的group_id", name = "gradeGroupId") + private Long gradeGroupId; //当前审批流转所在员工 id @ApiModelProperty(value = "当前审批流转所在员工 id", name = "flowStaffIdRole") private Long flowStaffIdRole; //员工所在部门 id @ApiModelProperty(value = "员工所在部门 id", name = "departmentId") - private Long departmentId; + private String departmentId; //员工所在部门名称 @ApiModelProperty(value = "员工所在部门名称", name = "departmentName") private String departmentName; //员工姓名 @ApiModelProperty(value = "员工姓名", name = "staffName") private String staffName; + //员工姓名 + @ApiModelProperty(value = "员工头像", name = "avatar") + private String avatar; + //员工姓名 + @ApiModelProperty(value = "员工工号", name = "jobNumber") + private String jobNumber; //当前审批的员工 id @ApiModelProperty(value = "当前审批的员工 id", name = "currentApprovalStaffId") private Long currentApprovalStaffId; @@ -175,14 +187,14 @@ public class ResultRecordDetailDto { * 员工所在部门 id * @return */ - public Long getDepartmentId() { + public String getDepartmentId() { return departmentId; } /** * 员工所在部门 id * @param departmentId */ - public void setDepartmentId(Long departmentId) { + public void setDepartmentId(String departmentId) { this.departmentId = departmentId; } diff --git a/src/main/java/com/lz/modules/flow/model/ResultRecortModelDto.java b/src/main/java/com/lz/modules/flow/model/ResultRecortModelDto.java index efa61dad..7afe7076 100644 --- a/src/main/java/com/lz/modules/flow/model/ResultRecortModelDto.java +++ b/src/main/java/com/lz/modules/flow/model/ResultRecortModelDto.java @@ -33,12 +33,7 @@ public class ResultRecortModelDto { @ApiModelProperty(value = "考核子项目个数最大限制", name = "maxCount") private Integer maxCount; //lz_result_calculate 的id,计算法方法id - @ApiModelProperty(value = "lz_result_calculate 的id,计算法方法id", name = "calculateId") - private Long calculateId; - //使用的哪个等级。等级组id,lz_result_grade的group_id - @ApiModelProperty(value = "使用的哪个等级。等级组id,lz_result_grade的group_id", name = "gradeGroupId") - private Long gradeGroupId; //排序 @ApiModelProperty(value = "排序", name = "orderBy") private Integer orderBy; @@ -120,38 +115,8 @@ public class ResultRecortModelDto { this.maxCount = maxCount; } - /** - * lz_result_calculate 的id,计算法方法id - * @return - */ - public Long getCalculateId() { - return calculateId; - } - /** - * lz_result_calculate 的id,计算法方法id - * @param calculateId - */ - public void setCalculateId(Long calculateId) { - this.calculateId = calculateId; - } - - /** - * 使用的哪个等级。等级组id,lz_result_grade的group_id - * @return - */ - public Long getGradeGroupId() { - return gradeGroupId; - } - /** - * 使用的哪个等级。等级组id,lz_result_grade的group_id - * @param gradeGroupId - */ - public void setGradeGroupId(Long gradeGroupId) { - this.gradeGroupId = gradeGroupId; - } - /** * 排序 * @return @@ -175,8 +140,6 @@ public class ResultRecortModelDto { ",type=" + type + ",weight=" + weight + ",maxCount=" + maxCount + - ",calculateId=" + calculateId + - ",gradeGroupId=" + gradeGroupId + ",orderBy=" + orderBy + "}"; } diff --git a/src/main/java/com/lz/modules/performance/controller/EvaluationGroupController.java b/src/main/java/com/lz/modules/performance/controller/EvaluationGroupController.java index 25cc5031..6fa9fe19 100644 --- a/src/main/java/com/lz/modules/performance/controller/EvaluationGroupController.java +++ b/src/main/java/com/lz/modules/performance/controller/EvaluationGroupController.java @@ -121,6 +121,7 @@ public class EvaluationGroupController { } + @PostMapping("/update") public R update(@RequestBody @ApiParam EvaluationGroup evaluationGroup) { evaluationGroupService.updateEvaluationGroupById(evaluationGroup); diff --git a/src/main/java/com/lz/modules/sys/dao/app/ResultDetailMapper.java b/src/main/java/com/lz/modules/sys/dao/app/ResultDetailMapper.java index d82a1f58..cfa8b60e 100644 --- a/src/main/java/com/lz/modules/sys/dao/app/ResultDetailMapper.java +++ b/src/main/java/com/lz/modules/sys/dao/app/ResultDetailMapper.java @@ -9,6 +9,7 @@ package com.lz.modules.sys.dao.app; */ import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.lz.common.utils.BigDecimalUtil; +import com.lz.modules.flow.model.ResultDetailDto; import com.lz.modules.sys.entity.app.ResultDetail; import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Param; @@ -43,4 +44,6 @@ public interface ResultDetailMapper extends BaseMapper { BigDecimal calculateScore(@Param("recordId") Long recordId, @Param("staffId") Long staffId,@Param("type") Integer type); Long insertResultDetails(@Param("list") List resultDetails); + + List selectDtosByRecordId(@Param("recordResultId") Long id, @Param("type") int type); } \ No newline at end of file diff --git a/src/main/java/com/lz/modules/sys/service/app/ResultDetailService.java b/src/main/java/com/lz/modules/sys/service/app/ResultDetailService.java index 3677aa1f..f9d5213e 100644 --- a/src/main/java/com/lz/modules/sys/service/app/ResultDetailService.java +++ b/src/main/java/com/lz/modules/sys/service/app/ResultDetailService.java @@ -5,6 +5,7 @@ import com.lz.common.utils.BigDecimalUtil; import com.lz.modules.app.resp.ResultDetailResp; import com.lz.modules.app.resp.Step; import com.lz.modules.flow.model.Auth; +import com.lz.modules.flow.model.ResultDetailDto; import com.lz.modules.sys.entity.app.ResultDetail; import com.lz.modules.sys.entity.app.ResultRecord; @@ -67,4 +68,6 @@ public interface ResultDetailService extends IService { List selectByRecordIdAndType(Long id, int i); Long insertResultDetails(List resultDetails); + + List selectDtosByRecordId(Long id, int type); } \ No newline at end of file diff --git a/src/main/java/com/lz/modules/sys/service/app/impl/ResultDetailServiceImpl.java b/src/main/java/com/lz/modules/sys/service/app/impl/ResultDetailServiceImpl.java index 49998998..cd015176 100644 --- a/src/main/java/com/lz/modules/sys/service/app/impl/ResultDetailServiceImpl.java +++ b/src/main/java/com/lz/modules/sys/service/app/impl/ResultDetailServiceImpl.java @@ -12,6 +12,7 @@ import com.lz.modules.app.service.StaffService; import com.lz.modules.app.utils.t.TwoTuple; import com.lz.modules.flow.entity.*; import com.lz.modules.flow.model.Auth; +import com.lz.modules.flow.model.ResultDetailDto; import com.lz.modules.flow.model.StaffRoleDto; import com.lz.modules.flow.service.*; import com.lz.modules.sys.dao.app.ResultDetailMapper; @@ -334,4 +335,9 @@ public class ResultDetailServiceImpl extends ServiceImpl selectDtosByRecordId(Long id, int type){ + return resultDetailMapper.selectDtosByRecordId(id, type); + } + } diff --git a/src/main/resources/mapper/app/ResultDetailMapper.xml b/src/main/resources/mapper/app/ResultDetailMapper.xml index e0431bfb..9b6c2620 100644 --- a/src/main/resources/mapper/app/ResultDetailMapper.xml +++ b/src/main/resources/mapper/app/ResultDetailMapper.xml @@ -178,5 +178,9 @@ + + diff --git a/src/main/resources/mapper/generator/StaffDao.xml b/src/main/resources/mapper/generator/StaffDao.xml index ce32b558..ff9d8c71 100644 --- a/src/main/resources/mapper/generator/StaffDao.xml +++ b/src/main/resources/mapper/generator/StaffDao.xml @@ -510,4 +510,16 @@ ) and occupation.staff_status=0 and staff.is_delete=0 and occupation.is_delete=0 + +