任务
This commit is contained in:
@ -4,6 +4,8 @@ import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Data
|
||||
@ApiModel("app项目任务列表查询条件")
|
||||
public class AppTaskDTO {
|
||||
@ -19,6 +21,12 @@ public class AppTaskDTO {
|
||||
@ApiModelProperty("承接人")
|
||||
private Long userId;
|
||||
|
||||
@ApiModelProperty("任务状态(1进行中 2已完成)")
|
||||
@ApiModelProperty("任务状态(0申请中 1进行中 2已完成)")
|
||||
private String status;
|
||||
|
||||
@ApiModelProperty("是否我的任务")
|
||||
private Boolean myTask;
|
||||
|
||||
@ApiModelProperty(value = "申请任务ID",hidden = true)
|
||||
private List<Long> taskIds;
|
||||
}
|
||||
|
||||
@ -5,7 +5,7 @@ import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
@ApiModel("app申请承接任务")
|
||||
@ApiModel("app申请/取消项目任务")
|
||||
public class TaskApplyDTO {
|
||||
|
||||
@ApiModelProperty("任务ID")
|
||||
|
||||
@ -1,11 +1,13 @@
|
||||
package com.ruoyi.fbs.domain.vo;
|
||||
|
||||
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||
import com.ruoyi.bgt.domain.vo.BgtProjectRecruitApplyVO;
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
import java.time.LocalDateTime;
|
||||
import java.util.List;
|
||||
|
||||
|
||||
@Data
|
||||
@ -66,4 +68,9 @@ public class AppTaskDetailVO {
|
||||
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
|
||||
private LocalDateTime createTime;
|
||||
|
||||
|
||||
@ApiModelProperty("申请者列表")
|
||||
List<BgtProjectRecruitApplyVO> applylist;
|
||||
|
||||
|
||||
}
|
||||
|
||||
@ -54,5 +54,18 @@ public interface IFbsProjectTaskApplyService extends IServicePlus<FbsProjectTask
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
|
||||
/**
|
||||
* 申请承接
|
||||
*/
|
||||
Boolean appTaskApply(TaskApplyDTO dto);
|
||||
|
||||
/**
|
||||
* 获取包工头申请的所有任务ID
|
||||
*/
|
||||
List<Long> getTaskIdsByUserId(Long userId);
|
||||
|
||||
/**
|
||||
* 取消申请
|
||||
*/
|
||||
Boolean cancelApply(TaskApplyDTO dto);
|
||||
}
|
||||
|
||||
@ -63,5 +63,8 @@ public interface IFbsProjectTaskService extends IServicePlus<FbsProjectTask> {
|
||||
*/
|
||||
TableDataInfo<AppTaskVO> appQueryPageList(AppTaskDTO dto);
|
||||
|
||||
/**
|
||||
* 任务详情
|
||||
*/
|
||||
AppTaskDetailVO appQueryById(Long id);
|
||||
}
|
||||
|
||||
@ -1,11 +1,13 @@
|
||||
package com.ruoyi.fbs.service.impl;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import cn.hutool.core.collection.CollUtil;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.exception.BaseException;
|
||||
import com.ruoyi.common.utils.PageUtils;
|
||||
import com.ruoyi.fbs.bo.FbsProjectTaskApplyQueryBo;
|
||||
import com.ruoyi.fbs.domain.FbsProjectTaskApply;
|
||||
@ -17,6 +19,7 @@ import org.springframework.stereotype.Service;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
* 分包商项目任务申请Service业务层处理
|
||||
@ -75,8 +78,9 @@ public class FbsProjectTaskApplyServiceImpl extends ServicePlusImpl<FbsProjectTa
|
||||
wrapper.eq(FbsProjectTaskApply::getTaskId, entity.getTaskId());
|
||||
wrapper.eq(FbsProjectTaskApply::getUserId, entity.getUserId());
|
||||
List<FbsProjectTaskApply> list = baseMapper.selectList(wrapper);
|
||||
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
if (CollUtil.isNotEmpty(list)) {
|
||||
throw new BaseException("该任务已申请");
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -91,6 +95,19 @@ public class FbsProjectTaskApplyServiceImpl extends ServicePlusImpl<FbsProjectTa
|
||||
public Boolean appTaskApply(TaskApplyDTO dto) {
|
||||
FbsProjectTaskApply fbsProjectTaskApply = BeanUtil.copyProperties(dto, FbsProjectTaskApply.class);
|
||||
validEntityBeforeSave(fbsProjectTaskApply);
|
||||
return null;
|
||||
return save(fbsProjectTaskApply);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<Long> getTaskIdsByUserId(Long userId) {
|
||||
List<FbsProjectTaskApply> list = baseMapper.selectList(Wrappers.<FbsProjectTaskApply>lambdaQuery().eq(FbsProjectTaskApply::getUserId, userId));
|
||||
return list.stream().map(FbsProjectTaskApply::getTaskId).collect(Collectors.toList());
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean cancelApply(TaskApplyDTO dto) {
|
||||
int delete = baseMapper.delete(Wrappers.<FbsProjectTaskApply>lambdaQuery().eq(FbsProjectTaskApply::getTaskId, dto.getTaskId())
|
||||
.eq(FbsProjectTaskApply::getUserId, dto.getUserId()));
|
||||
return delete>0;
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,12 +1,20 @@
|
||||
package com.ruoyi.fbs.service.impl;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import cn.hutool.core.util.ObjectUtil;
|
||||
import cn.hutool.core.util.StrUtil;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.ruoyi.bgt.bo.BgtProjectRecruitQueryBo;
|
||||
import com.ruoyi.bgt.domain.BgtProjectRecruit;
|
||||
import com.ruoyi.bgt.domain.dto.BgtProjectRecruitApplyQueryDTO;
|
||||
import com.ruoyi.bgt.service.IBgtProjectRecruitApplyService;
|
||||
import com.ruoyi.bgt.service.IBgtProjectRecruitService;
|
||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.enums.ProjectTaskStatus;
|
||||
import com.ruoyi.common.enums.RecruitApplyStatus;
|
||||
import com.ruoyi.common.utils.PageUtils;
|
||||
import com.ruoyi.fbs.bo.FbsProjectTaskQueryBo;
|
||||
import com.ruoyi.fbs.domain.FbsProjectTask;
|
||||
@ -14,15 +22,18 @@ import com.ruoyi.fbs.domain.dto.AppTaskDTO;
|
||||
import com.ruoyi.fbs.domain.vo.AppTaskDetailVO;
|
||||
import com.ruoyi.fbs.domain.vo.AppTaskVO;
|
||||
import com.ruoyi.fbs.mapper.FbsProjectTaskMapper;
|
||||
import com.ruoyi.fbs.service.IFbsProjectTaskApplyService;
|
||||
import com.ruoyi.fbs.service.IFbsProjectTaskService;
|
||||
import com.ruoyi.zbf.domain.ZbfProject;
|
||||
import com.ruoyi.zbf.service.IZbfProjectService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.context.annotation.Lazy;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
* 分包商项目任务Service业务层处理
|
||||
@ -36,6 +47,16 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
|
||||
@Autowired
|
||||
private IZbfProjectService zbfProjectService;
|
||||
|
||||
@Autowired
|
||||
private IFbsProjectTaskApplyService taskApplyService;
|
||||
|
||||
@Autowired
|
||||
@Lazy
|
||||
private IBgtProjectRecruitService recruitService;
|
||||
|
||||
@Autowired
|
||||
private IBgtProjectRecruitApplyService recruitApplyService;
|
||||
|
||||
@Override
|
||||
public FbsProjectTask queryById(Long id){
|
||||
return getById(id);
|
||||
@ -108,6 +129,10 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
|
||||
Page<AppTaskDTO> appTaskDTOPage = new Page<>();
|
||||
appTaskDTOPage.setCurrent(dto.getPageNum());
|
||||
appTaskDTOPage.setSize(dto.getPageSize());
|
||||
if(dto.getMyTask() && ObjectUtil.equals(ProjectTaskStatus.APPLY.getCode(),dto.getStatus())){
|
||||
List<Long> taskIds = taskApplyService.getTaskIdsByUserId(dto.getUserId());
|
||||
dto.setTaskIds(taskIds);
|
||||
}
|
||||
Page<AppTaskVO> appTaskVOPage = baseMapper.appQueryPageList(appTaskDTOPage, dto);
|
||||
return PageUtils.buildDataInfo(appTaskVOPage);
|
||||
}
|
||||
@ -116,8 +141,21 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
|
||||
public AppTaskDetailVO appQueryById(Long id) {
|
||||
FbsProjectTask byId = getById(id);
|
||||
AppTaskDetailVO appTaskDetailVO = BeanUtil.copyProperties(byId, AppTaskDetailVO.class);
|
||||
//项目信息
|
||||
ZbfProject project = zbfProjectService.getById(byId.getProjectId());
|
||||
appTaskDetailVO.setProjectName(project.getProjectName());
|
||||
//申请者信息
|
||||
BgtProjectRecruitQueryBo bgtProjectRecruitQueryBo = new BgtProjectRecruitQueryBo();
|
||||
bgtProjectRecruitQueryBo.setTaskId(id);
|
||||
List<Long> recruitIds = recruitService.queryList(bgtProjectRecruitQueryBo).stream().map(BgtProjectRecruit::getId).collect(Collectors.toList());
|
||||
|
||||
BgtProjectRecruitApplyQueryDTO bgtProjectRecruitApplyQueryDTO = new BgtProjectRecruitApplyQueryDTO();
|
||||
bgtProjectRecruitApplyQueryDTO.setRecruitIds(recruitIds);
|
||||
bgtProjectRecruitApplyQueryDTO.setStatus(RecruitApplyStatus.PASS.getCode());
|
||||
appTaskDetailVO.setApplylist(recruitApplyService.appQueryList(bgtProjectRecruitApplyQueryDTO));
|
||||
|
||||
|
||||
|
||||
return appTaskDetailVO;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user