分包
This commit is contained in:
@ -4,13 +4,16 @@ import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
import javax.validation.constraints.NotNull;
|
||||
|
||||
@Data
|
||||
@ApiModel("app申请/取消项目任务")
|
||||
@ApiModel("包工头申请/取消项目任务")
|
||||
public class BgtTaskApplyDTO {
|
||||
|
||||
@ApiModelProperty("任务ID")
|
||||
@NotNull(message = "任务ID不能为空")
|
||||
private Long taskId;
|
||||
|
||||
@ApiModelProperty("包工头用户ID")
|
||||
private Long userId;
|
||||
// @ApiModelProperty("包工头用户ID")
|
||||
// private Long userId;
|
||||
}
|
||||
|
@ -92,7 +92,7 @@ public interface IBgtMessageService extends IServicePlus<BgtMessage> {
|
||||
TableDataInfo<BgtMessageDetailVO> unAuditList(BgtMessageUnAuditDetailDTO dto);
|
||||
|
||||
/**
|
||||
* operation
|
||||
* 已操作
|
||||
*/
|
||||
void operation(String senderType,Long senderId,String recipientType,Long recipientId,Long tableId,String tableName);
|
||||
|
||||
|
@ -70,4 +70,8 @@ public interface IBgtProjectTaskProgressService extends IServicePlus<BgtProjectT
|
||||
* 获取最新项目进度
|
||||
*/
|
||||
Integer getLastProgress(Long taskId);
|
||||
/**
|
||||
* 分包商审核
|
||||
*/
|
||||
Boolean fbsAudit(BgtProjectTaskProgress bo);
|
||||
}
|
||||
|
@ -73,10 +73,13 @@ public interface IBgtWageApplicationService extends IServicePlus<BgtWageApplicat
|
||||
*/
|
||||
List<BgtWageApplicationListVO> appQueryList(BgtWageApplicationQueryDTO dto);
|
||||
|
||||
|
||||
/**
|
||||
* 分包商查询审核列表
|
||||
*/
|
||||
TableDataInfo<BgtWageApplicationVO> fbsAuditPageList(FbsWageAuditListDTO dto);
|
||||
|
||||
/**
|
||||
* 分包商审核
|
||||
*/
|
||||
Boolean fbsAudit(BgtWageApplication bo);
|
||||
}
|
||||
|
@ -8,8 +8,6 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.ruoyi.bgt.bo.BgtMessageQueryBo;
|
||||
import com.ruoyi.bgt.domain.BgtMessage;
|
||||
import com.ruoyi.bgt.domain.BgtProjectRecruit;
|
||||
import com.ruoyi.bgt.domain.BgtProjectRecruitApply;
|
||||
import com.ruoyi.bgt.domain.BgtWageApplication;
|
||||
import com.ruoyi.bgt.domain.dto.BgtMessageDetailDTO;
|
||||
import com.ruoyi.bgt.domain.dto.BgtMessageMyListDTO;
|
||||
@ -28,10 +26,11 @@ import com.ruoyi.common.enums.BgtMessageType;
|
||||
import com.ruoyi.common.utils.PageUtils;
|
||||
import com.ruoyi.common.utils.SecurityUtils;
|
||||
import com.ruoyi.fbs.domain.FbsProjectTask;
|
||||
import com.ruoyi.fbs.domain.FbsProjectTaskApply;
|
||||
import com.ruoyi.fbs.service.IFbsProjectTaskApplyService;
|
||||
import com.ruoyi.fbs.service.IFbsProjectTaskService;
|
||||
import com.ruoyi.wgz.domain.WgzDailyClock;
|
||||
import com.ruoyi.wgz.domain.WgzLeave;
|
||||
import com.ruoyi.wgz.domain.WgzPayCalculation;
|
||||
import com.ruoyi.wgz.domain.WgzReissueacard;
|
||||
import com.ruoyi.wgz.service.*;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
@ -85,6 +84,10 @@ public class BgtMessageServiceImpl extends ServicePlusImpl<BgtMessageMapper, Bgt
|
||||
@Lazy
|
||||
private IFbsProjectTaskService taskService;
|
||||
|
||||
@Autowired
|
||||
@Lazy
|
||||
private IFbsProjectTaskApplyService taskApplyService;
|
||||
|
||||
@Autowired
|
||||
@Lazy
|
||||
private IWgzDailyClockService dailyClockService;
|
||||
@ -220,48 +223,49 @@ public class BgtMessageServiceImpl extends ServicePlusImpl<BgtMessageMapper, Bgt
|
||||
|
||||
for (BgtMessage message : result.getRecords()) {
|
||||
BgtMessageDetailVO bgtMessageDetailVO = BeanUtil.copyProperties(message, BgtMessageDetailVO.class);
|
||||
if (BGT_LARGE_TASK.equals(message.getMessageLargeType())) {
|
||||
FbsProjectTask task = taskService.getById(message.getTableId());
|
||||
bgtMessageDetailVO.setTaskName(task.getTaskName());
|
||||
} else if (BGT_LARGE_SETTLEMENT.equals(message.getMessageLargeType())) {
|
||||
BgtWageApplication wageApplication = wageApplicationService.getById(message.getTableId());
|
||||
FbsProjectTask task = taskService.getById(wageApplication.getTaskId());
|
||||
bgtMessageDetailVO.setTaskName(task.getTaskName());
|
||||
} else if (BGT_LARGE_OTHER.equals(message.getMessageLargeType())) {
|
||||
switch (message.getMessageSmallType()) {
|
||||
case BGT_SMALL_SIGN_UP:
|
||||
BgtProjectRecruitApply recruitApply = recruitApplyService.getById(message.getTableId());
|
||||
BgtProjectRecruit recruit = recruitService.getById(recruitApply.getRecruitId());
|
||||
bgtMessageDetailVO.setRecruitName(recruit.getRecruitName());
|
||||
break;
|
||||
case BGT_SMALL_PAY:
|
||||
WgzPayCalculation payCalculation = payCalculationService.getById(message.getTableId());
|
||||
BgtProjectRecruit recruitPay = recruitService.getById(payCalculation.getRecruitId());
|
||||
bgtMessageDetailVO.setRecruitName(recruitPay.getRecruitName());
|
||||
break;
|
||||
case BGT_SMALL_LEAVE:
|
||||
WgzLeave wgzLeave = leaveService.getById(message.getTableId());
|
||||
bgtMessageDetailVO.setReason(wgzLeave.getReason());
|
||||
bgtMessageDetailVO.setUsername(wgzUserService.findByUserId(wgzLeave.getUserId()).getUsername());
|
||||
bgtMessageDetailVO.setStartTime(wgzLeave.getStartTime());
|
||||
bgtMessageDetailVO.setEndTime(wgzLeave.getEndTime());
|
||||
break;
|
||||
case BGT_SMALL_MAKE_UP:
|
||||
WgzReissueacard reissueCard = reissueacardService.getById(message.getTableId());
|
||||
bgtMessageDetailVO.setReason(reissueCard.getReason());
|
||||
bgtMessageDetailVO.setUsername(wgzUserService.findByUserId(reissueCard.getUserId()).getUsername());
|
||||
bgtMessageDetailVO.setNowTime(reissueCard.getNowTime());
|
||||
break;
|
||||
case BGT_SMALL_REPORT_MAKE_UP:
|
||||
WgzDailyClock dailyClock = dailyClockService.getById(message.getTableId());
|
||||
BgtProjectRecruit recruitClock = recruitService.getById(dailyClock.getRecruitId());
|
||||
bgtMessageDetailVO.setUsername(wgzUserService.findByUserId(dailyClock.getUserId()).getUsername());
|
||||
bgtMessageDetailVO.setRecruitName(recruitClock.getRecruitName());
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
// if (BGT_LARGE_TASK.equals(message.getMessageLargeType())) {
|
||||
// FbsProjectTaskApply taskApply = taskApplyService.getById(message.getTableId());
|
||||
// FbsProjectTask task = taskService.getById(taskApply.getTaskId());
|
||||
// bgtMessageDetailVO.setTaskName(task.getTaskName());
|
||||
// } else if (BGT_LARGE_SETTLEMENT.equals(message.getMessageLargeType())) {
|
||||
// BgtWageApplication wageApplication = wageApplicationService.getById(message.getTableId());
|
||||
// FbsProjectTask task = taskService.getById(wageApplication.getTaskId());
|
||||
// bgtMessageDetailVO.setTaskName(task.getTaskName());
|
||||
// } else if (BGT_LARGE_OTHER.equals(message.getMessageLargeType())) {
|
||||
// switch (message.getMessageSmallType()) {
|
||||
// case BGT_SMALL_SIGN_UP:
|
||||
// BgtProjectRecruitApply recruitApply = recruitApplyService.getById(message.getTableId());
|
||||
// BgtProjectRecruit recruit = recruitService.getById(recruitApply.getRecruitId());
|
||||
// bgtMessageDetailVO.setRecruitName(recruit.getRecruitName());
|
||||
// break;
|
||||
// case BGT_SMALL_PAY:
|
||||
// WgzPayCalculation payCalculation = payCalculationService.getById(message.getTableId());
|
||||
// BgtProjectRecruit recruitPay = recruitService.getById(payCalculation.getRecruitId());
|
||||
// bgtMessageDetailVO.setRecruitName(recruitPay.getRecruitName());
|
||||
// break;
|
||||
// case BGT_SMALL_LEAVE:
|
||||
// WgzLeave wgzLeave = leaveService.getById(message.getTableId());
|
||||
// bgtMessageDetailVO.setReason(wgzLeave.getReason());
|
||||
// bgtMessageDetailVO.setUsername(wgzUserService.findByUserId(wgzLeave.getUserId()).getUsername());
|
||||
// bgtMessageDetailVO.setStartTime(wgzLeave.getStartTime());
|
||||
// bgtMessageDetailVO.setEndTime(wgzLeave.getEndTime());
|
||||
// break;
|
||||
// case BGT_SMALL_MAKE_UP:
|
||||
// WgzReissueacard reissueCard = reissueacardService.getById(message.getTableId());
|
||||
// bgtMessageDetailVO.setReason(reissueCard.getReason());
|
||||
// bgtMessageDetailVO.setUsername(wgzUserService.findByUserId(reissueCard.getUserId()).getUsername());
|
||||
// bgtMessageDetailVO.setNowTime(reissueCard.getNowTime());
|
||||
// break;
|
||||
// case BGT_SMALL_REPORT_MAKE_UP:
|
||||
// WgzDailyClock dailyClock = dailyClockService.getById(message.getTableId());
|
||||
// BgtProjectRecruit recruitClock = recruitService.getById(dailyClock.getRecruitId());
|
||||
// bgtMessageDetailVO.setUsername(wgzUserService.findByUserId(dailyClock.getUserId()).getUsername());
|
||||
// bgtMessageDetailVO.setRecruitName(recruitClock.getRecruitName());
|
||||
// break;
|
||||
// default:
|
||||
// break;
|
||||
// }
|
||||
// }
|
||||
bgtMessageVOS.add(bgtMessageDetailVO);
|
||||
}
|
||||
bgtMessageVOPage.setRecords(bgtMessageVOS);
|
||||
@ -304,7 +308,8 @@ public class BgtMessageServiceImpl extends ServicePlusImpl<BgtMessageMapper, Bgt
|
||||
for (BgtMessage message : result.getRecords()) {
|
||||
BgtMessageDetailVO bgtMessageDetailVO = BeanUtil.copyProperties(message, BgtMessageDetailVO.class);
|
||||
if (BGT_LARGE_TASK.equals(message.getMessageLargeType())) {
|
||||
FbsProjectTask task = taskService.getById(message.getTableId());
|
||||
FbsProjectTaskApply taskApply = taskApplyService.getById(message.getTableId());
|
||||
FbsProjectTask task = taskService.getById(taskApply.getTaskId());
|
||||
bgtMessageDetailVO.setTaskName(task.getTaskName());
|
||||
} else if (BGT_LARGE_SETTLEMENT.equals(message.getMessageLargeType())) {
|
||||
BgtWageApplication wageApplication = wageApplicationService.getById(message.getTableId());
|
||||
|
@ -6,12 +6,15 @@ 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.baomidou.mybatisplus.extension.toolkit.SqlHelper;
|
||||
import com.ruoyi.bgt.bo.BgtProjectTaskProgressQueryBo;
|
||||
import com.ruoyi.bgt.domain.BgtMessage;
|
||||
import com.ruoyi.bgt.domain.BgtProjectTaskProgress;
|
||||
import com.ruoyi.bgt.domain.dto.BgtProjectTaskProgressQueryDTO;
|
||||
import com.ruoyi.bgt.domain.vo.BgtProjectTaskProgressDetailVO;
|
||||
import com.ruoyi.bgt.domain.vo.BgtProjectTaskProgressVO;
|
||||
import com.ruoyi.bgt.mapper.BgtProjectTaskProgressMapper;
|
||||
import com.ruoyi.bgt.service.IBgtMessageService;
|
||||
import com.ruoyi.bgt.service.IBgtProjectTaskProgressService;
|
||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
@ -19,12 +22,22 @@ import com.ruoyi.common.enums.AuditStatus;
|
||||
import com.ruoyi.common.exception.BaseException;
|
||||
import com.ruoyi.common.utils.PageUtils;
|
||||
import com.ruoyi.common.utils.SecurityUtils;
|
||||
import com.ruoyi.fbs.domain.FbsMessage;
|
||||
import com.ruoyi.fbs.domain.FbsProjectTask;
|
||||
import com.ruoyi.fbs.service.IFbsMessageService;
|
||||
import com.ruoyi.fbs.service.IFbsProjectTaskService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import static com.ruoyi.common.constants.BgtMessageConstant.*;
|
||||
import static com.ruoyi.common.constants.FbsMessageConstant.*;
|
||||
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.*;
|
||||
|
||||
/**
|
||||
* 包工头项目任务进度Service业务层处理
|
||||
*
|
||||
@ -34,6 +47,13 @@ import java.util.Map;
|
||||
@Service
|
||||
public class BgtProjectTaskProgressServiceImpl extends ServicePlusImpl<BgtProjectTaskProgressMapper, BgtProjectTaskProgress> implements IBgtProjectTaskProgressService {
|
||||
|
||||
@Autowired
|
||||
private IFbsProjectTaskService taskService;
|
||||
@Autowired
|
||||
private IFbsMessageService fbsMessageService;
|
||||
@Autowired
|
||||
private IBgtMessageService bgtMessageService;
|
||||
|
||||
@Override
|
||||
public BgtProjectTaskProgress queryById(Long id){
|
||||
return getById(id);
|
||||
@ -79,8 +99,32 @@ public class BgtProjectTaskProgressServiceImpl extends ServicePlusImpl<BgtProjec
|
||||
// //批量退场
|
||||
// recruitApplyService.quitBatch(bo.getTaskId());
|
||||
// }
|
||||
|
||||
bo.setUploaderId(SecurityUtils.getAppUserId());
|
||||
return save(bo);
|
||||
boolean save = save(bo);
|
||||
|
||||
FbsProjectTask task = taskService.getById(bo.getTaskId());
|
||||
|
||||
//包工头发消息到分包商
|
||||
HashMap<String, String> fmp = new HashMap<>();
|
||||
fmp.put("projectName", task.getTaskName());
|
||||
fmp.put("auditor", SecurityUtils.getUsername());
|
||||
Map<String, String> fmap = bgtMessage(fmp, BGT_TYPE_PROGRESS_TO_FBS, true);
|
||||
FbsMessage fbsMessage = new FbsMessage()
|
||||
.setSenderType(USERTYPE_BGT)
|
||||
.setSenderId(SecurityUtils.getAppUserId())
|
||||
.setRecipientType(USERTYPE_FBS)
|
||||
.setRecipientId(task.getCreateId())
|
||||
.setHeadline(fmap.get(HEADLINE))
|
||||
.setSubheading(fmap.get(SUBHEADING))
|
||||
.setTableId(bo.getId())
|
||||
.setTableName(SqlHelper.table(BgtProjectTaskProgress.class).getTableName())
|
||||
.setMessageLargeType(FBS_LARGE_OTHER)
|
||||
.setMessageSmallType(FBS_SMALL_PROGRESS)
|
||||
.setIsOperation(OPERATION_NEED);
|
||||
fbsMessageService.sendAMessage(fbsMessage);
|
||||
|
||||
return save;
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -129,9 +173,38 @@ public class BgtProjectTaskProgressServiceImpl extends ServicePlusImpl<BgtProjec
|
||||
public Integer getLastProgress(Long taskId) {
|
||||
LambdaQueryWrapper<BgtProjectTaskProgress> wrapper = new LambdaQueryWrapper<>();
|
||||
wrapper.eq(BgtProjectTaskProgress::getTaskId, taskId);
|
||||
wrapper.eq(BgtProjectTaskProgress::getAuditStatus, AuditStatus.PASS.getCode());
|
||||
wrapper.orderByDesc(BgtProjectTaskProgress::getProgress);
|
||||
List<BgtProjectTaskProgress> list = baseMapper.selectList(wrapper);
|
||||
return CollectionUtil.isEmpty(list)?0:list.get(0).getProgress();
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean fbsAudit(BgtProjectTaskProgress bo) {
|
||||
boolean b = updateById(bo);
|
||||
|
||||
FbsProjectTask task = taskService.getById(bo.getTaskId());
|
||||
|
||||
//分包商发消息到包工头
|
||||
HashMap<String, String> mp = new HashMap<>();
|
||||
mp.put("projectName", task.getTaskName());
|
||||
mp.put("auditor", SecurityUtils.getUsername());
|
||||
Map<String, String> map = fbsMessage(mp, FBS_TYPE_PROGRESS, AuditStatus.PASS.getCode().equals(bo.getAuditStatus()));
|
||||
BgtMessage bgtMessage = new BgtMessage()
|
||||
.setSenderType(USERTYPE_FBS)
|
||||
.setSenderId(SecurityUtils.getAppUserId())
|
||||
.setRecipientType(USERTYPE_BGT)
|
||||
.setRecipientId(bo.getUploaderId())
|
||||
.setHeadline(map.get(HEADLINE))
|
||||
.setSubheading(map.get(SUBHEADING))
|
||||
.setTableId(bo.getId())
|
||||
.setTableName(SqlHelper.table(BgtProjectTaskProgress.class).getTableName())
|
||||
.setMessageLargeType(BGT_LARGE_OTHER)
|
||||
.setMessageSmallType(BGT_SMALL_PROGRESS)
|
||||
.setIsOperation(OPERATION_NO);
|
||||
bgtMessageService.sendAMessage(bgtMessage);
|
||||
|
||||
fbsMessageService.operation(USERTYPE_BGT, bo.getUploaderId(), USERTYPE_FBS, SecurityUtils.getAppUserId(), bo.getId(), SqlHelper.table(BgtProjectTaskProgress.class).getTableName());
|
||||
|
||||
return b;
|
||||
}
|
||||
}
|
||||
|
@ -8,6 +8,7 @@ import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.extension.toolkit.SqlHelper;
|
||||
import com.ruoyi.bgt.bo.BgtWageApplicationQueryBo;
|
||||
import com.ruoyi.bgt.domain.BgtMessage;
|
||||
import com.ruoyi.bgt.domain.BgtProjectTaskProgress;
|
||||
import com.ruoyi.bgt.domain.BgtWageApplication;
|
||||
import com.ruoyi.bgt.domain.dto.BgtWageApplicationQueryDTO;
|
||||
import com.ruoyi.bgt.domain.vo.BgtWageApplicationDetailVO;
|
||||
@ -18,23 +19,28 @@ import com.ruoyi.bgt.service.IBgtMessageService;
|
||||
import com.ruoyi.bgt.service.IBgtWageApplicationService;
|
||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.enums.AuditStatus;
|
||||
import com.ruoyi.common.exception.BaseException;
|
||||
import com.ruoyi.common.utils.PageUtils;
|
||||
import com.ruoyi.common.utils.SecurityUtils;
|
||||
import com.ruoyi.fbs.domain.FbsMessage;
|
||||
import com.ruoyi.fbs.domain.FbsProjectTask;
|
||||
import com.ruoyi.fbs.domain.dto.FbsWageAuditListDTO;
|
||||
import com.ruoyi.fbs.service.IFbsMessageService;
|
||||
import com.ruoyi.fbs.service.IFbsProjectTaskService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import static com.ruoyi.common.constants.BgtMessageConstant.*;
|
||||
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.USERTYPE_BGT;
|
||||
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.USERTYPE_SYSTEM;
|
||||
import static com.ruoyi.common.constants.FbsMessageConstant.*;
|
||||
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.*;
|
||||
|
||||
/**
|
||||
* 包工头工资申请Service业务层处理
|
||||
@ -51,6 +57,9 @@ public class BgtWageApplicationServiceImpl extends ServicePlusImpl<BgtWageApplic
|
||||
@Autowired
|
||||
private IBgtMessageService bgtMessageService;
|
||||
|
||||
@Autowired
|
||||
private IFbsMessageService fbsMessageService;
|
||||
|
||||
|
||||
@Override
|
||||
public BgtWageApplication queryById(Long id){
|
||||
@ -88,25 +97,61 @@ public class BgtWageApplicationServiceImpl extends ServicePlusImpl<BgtWageApplic
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public Boolean insert(BgtWageApplication bo) {
|
||||
BgtWageApplication add = BeanUtil.toBean(bo, BgtWageApplication.class);
|
||||
validEntityBeforeSave(add);
|
||||
//判断申请金额
|
||||
List<BgtWageApplication> list = list(Wrappers.<BgtWageApplication>lambdaQuery().eq(BgtWageApplication::getTaskId, bo.getTaskId())
|
||||
.eq(BgtWageApplication::getUserId, SecurityUtils.getAppUserId())
|
||||
.eq(BgtWageApplication::getAuditStatus, AuditStatus.getUse()));
|
||||
//收款金额
|
||||
int taskUseAmount = list.stream()
|
||||
.map(BgtWageApplication::getApplicantAmount)
|
||||
.reduce(BigDecimal.ZERO, BigDecimal::add).intValue();
|
||||
|
||||
//任务金额单位是万元,工资申请金额单位是元
|
||||
FbsProjectTask task = taskService.getById(bo.getTaskId());
|
||||
BigDecimal taskAmount = task.getTaskAmount();
|
||||
taskAmount = taskAmount.multiply(new BigDecimal(10000));
|
||||
|
||||
BigDecimal subtract = taskAmount.subtract(new BigDecimal(String.valueOf(taskUseAmount)));
|
||||
if(subtract.compareTo(bo.getApplicantAmount()) < 0){
|
||||
throw new BaseException("申请金额已超出,剩余申请金额:"+subtract+"元");
|
||||
}
|
||||
|
||||
BgtWageApplication add = BeanUtil.toBean(bo, BgtWageApplication.class);
|
||||
boolean save = save(add);
|
||||
//发消息
|
||||
FbsProjectTask task = taskService.getById(add.getTaskId());
|
||||
HashMap<String, String> mp = new HashMap<>();
|
||||
mp.put("projectName", task.getTaskName());
|
||||
mp.put("amount", add.getApplicantAmount().toString());
|
||||
Map<String, String> map = bgtMessage(mp, BGT_TYPE_SETTLEMENT, true);
|
||||
BgtMessage bgtMessage = new BgtMessage()
|
||||
.setSenderType(USERTYPE_SYSTEM)
|
||||
.setRecipientType(USERTYPE_BGT)
|
||||
.setRecipientId(add.getUserId())
|
||||
.setHeadline(map.get(HEADLINE))
|
||||
.setSubheading(map.get(SUBHEADING))
|
||||
//系统发消息到包工头
|
||||
// HashMap<String, String> mp = new HashMap<>();
|
||||
// mp.put("projectName", task.getTaskName());
|
||||
// mp.put("amount", add.getApplicantAmount().toString());
|
||||
// Map<String, String> map = bgtMessage(mp, BGT_TYPE_SETTLEMENT, true);
|
||||
// BgtMessage bgtMessage = new BgtMessage()
|
||||
// .setSenderType(USERTYPE_SYSTEM)
|
||||
// .setRecipientType(USERTYPE_BGT)
|
||||
// .setRecipientId(add.getUserId())
|
||||
// .setHeadline(map.get(HEADLINE))
|
||||
// .setSubheading(map.get(SUBHEADING))
|
||||
// .setTableId(add.getId())
|
||||
// .setTableName(SqlHelper.table(BgtWageApplication.class).getTableName())
|
||||
// .setMessageLargeType(BGT_LARGE_SETTLEMENT);
|
||||
// bgtMessageService.sendAMessage(bgtMessage);
|
||||
|
||||
//包工头发消息到分包商
|
||||
HashMap<String, String> fmp = new HashMap<>();
|
||||
fmp.put("projectName", task.getTaskName());
|
||||
fmp.put("auditor", SecurityUtils.getUsername());
|
||||
Map<String, String> fmap = bgtMessage(fmp, BGT_TYPE_SETTLEMENT_TO_FBS, true);
|
||||
FbsMessage fbsMessage = new FbsMessage()
|
||||
.setSenderType(USERTYPE_BGT)
|
||||
.setSenderId(SecurityUtils.getAppUserId())
|
||||
.setRecipientType(USERTYPE_FBS)
|
||||
.setRecipientId(task.getCreateId())
|
||||
.setHeadline(fmap.get(HEADLINE))
|
||||
.setSubheading(fmap.get(SUBHEADING))
|
||||
.setTableId(add.getId())
|
||||
.setTableName(SqlHelper.table(BgtWageApplication.class).getTableName())
|
||||
.setMessageLargeType(BGT_LARGE_SETTLEMENT);
|
||||
bgtMessageService.sendAMessage(bgtMessage);
|
||||
.setMessageLargeType(FBS_LARGE_OTHER)
|
||||
.setMessageSmallType(FBS_SMALL_PAY)
|
||||
.setIsOperation(OPERATION_NEED);
|
||||
fbsMessageService.sendAMessage(fbsMessage);
|
||||
return save;
|
||||
}
|
||||
|
||||
@ -163,4 +208,31 @@ public class BgtWageApplicationServiceImpl extends ServicePlusImpl<BgtWageApplic
|
||||
Page<BgtWageApplicationVO> queryVOPage = baseMapper.fbsAuditPageList(queryDTOPage, dto);
|
||||
return PageUtils.buildDataInfo(queryVOPage);
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public Boolean fbsAudit(BgtWageApplication bo) {
|
||||
boolean b = updateById(bo);
|
||||
FbsProjectTask task = taskService.getById(bo.getTaskId());
|
||||
|
||||
//分包商发消息到包工头
|
||||
HashMap<String, String> mp = new HashMap<>();
|
||||
mp.put("projectName", task.getTaskName());
|
||||
mp.put("auditor", SecurityUtils.getUsername());
|
||||
Map<String, String> map = fbsMessage(mp, FBS_TYPE_PAY,AuditStatus.PASS.getCode().equals(bo.getAuditStatus()));
|
||||
BgtMessage bgtMessage = new BgtMessage()
|
||||
.setSenderType(USERTYPE_FBS)
|
||||
.setSenderId(SecurityUtils.getAppUserId())
|
||||
.setRecipientType(USERTYPE_BGT)
|
||||
.setRecipientId(bo.getUserId())
|
||||
.setHeadline(map.get(HEADLINE))
|
||||
.setSubheading(map.get(SUBHEADING))
|
||||
.setTableId(bo.getId())
|
||||
.setTableName(SqlHelper.table(BgtWageApplication.class).getTableName())
|
||||
.setMessageLargeType(BGT_LARGE_SETTLEMENT)
|
||||
.setIsOperation(OPERATION_NO);
|
||||
bgtMessageService.sendAMessage(bgtMessage);
|
||||
fbsMessageService.operation(USERTYPE_BGT, bo.getUserId(), USERTYPE_FBS, SecurityUtils.getAppUserId(), bo.getId(), SqlHelper.table(BgtProjectTaskProgress.class).getTableName());
|
||||
return b;
|
||||
}
|
||||
}
|
||||
|
@ -17,6 +17,7 @@ public class BgtMessageConstant {
|
||||
public static final String BGT_SMALL_LEAVE = "3"; //小类型-请假
|
||||
public static final String BGT_SMALL_MAKE_UP = "4"; //小类型-补卡
|
||||
public static final String BGT_SMALL_REPORT_MAKE_UP = "5"; //小类型-日报补卡
|
||||
public static final String BGT_SMALL_PROGRESS = "5"; //小类型-任务进度
|
||||
|
||||
public static final List<String> AUDIT_TYPE = Arrays.asList("2", "3", "4", "5");
|
||||
/**
|
||||
@ -65,13 +66,13 @@ public class BgtMessageConstant {
|
||||
* ============================================系统->包工头 模板==================================================
|
||||
*/
|
||||
//承接任务
|
||||
public static final String BGT_TASK_APPLY_HEADLINE = "您已申请【%s】项目";
|
||||
public static final String BGT_TASK_APPLY_SUBHEADING = "您已成功申请到【%s】项目,请耐心等待回复!";
|
||||
public static final String BGT_TASK_APPLY_HEADLINE = "您已申请【%s】任务";
|
||||
public static final String BGT_TASK_APPLY_SUBHEADING = "您已成功申请到【%s】任务,请耐心等待回复!";
|
||||
//取消承接任务
|
||||
public static final String BGT_TASK_APPLY_CANCEL_HEADLINE = "您已申请取消【%s】项目!";
|
||||
public static final String BGT_TASK_APPLY_CANCEL_SUBHEADING = "您已成功取消【%s】项目";
|
||||
public static final String BGT_TASK_APPLY_CANCEL_HEADLINE = "您已取消【%s】任务申请!";
|
||||
public static final String BGT_TASK_APPLY_CANCEL_SUBHEADING = "您已成功取消【%s】项目申请!";
|
||||
//工资结算
|
||||
public static final String BGT_SETTLEMENT_APPLY_HEADLINE = "您正在申请【%s】项目,总共【%s】元的工资结算操作!";
|
||||
public static final String BGT_SETTLEMENT_APPLY_HEADLINE = "您正在申请【%s】任务,总共【%s】元的工资结算操作!";
|
||||
public static final String BGT_SETTLEMENT_APPLY_SUBHEADING = "您已成功发起金额为【%s】元的工资结算操作,请耐心等待回复!";
|
||||
|
||||
|
||||
@ -92,10 +93,14 @@ public class BgtMessageConstant {
|
||||
//工资结算
|
||||
public static final String BGT_TO_FBG_SETTLEMENT_APPLY_HEADLINE = "包工头【%s】正在向你发起工资结算!";
|
||||
public static final String BGT_TO_FBG_SETTLEMENT_APPLY_SUBHEADING = "包工头【%s】向你发起金额为【%s】元的工资结算操作!";
|
||||
//任务进度
|
||||
public static final String BGT_TO_FBG_PROGRESS_HEADLINE = "包工头【%s】已提交【%s】任务的新进度!";
|
||||
public static final String BGT_TO_FBG_PROGRESS_SUBHEADING = "包工头【%s】已提交【%s】任务的新进度,请查看!";
|
||||
|
||||
//包工头->分包商 消息类型
|
||||
public static final String BGT_TYPE_TASK_TO_FBG = "9"; //任务
|
||||
public static final String BGT_TYPE_SETTLEMEN_TO_FBGT = "10"; //结算
|
||||
public static final String BGT_TYPE_TASK_TO_FBS = "9"; //任务
|
||||
public static final String BGT_TYPE_SETTLEMENT_TO_FBS = "10"; //结算
|
||||
public static final String BGT_TYPE_PROGRESS_TO_FBS = "13"; //结算
|
||||
|
||||
|
||||
/**
|
||||
@ -167,6 +172,10 @@ public class BgtMessageConstant {
|
||||
map.put(HEADLINE, String.format(BGT_LEAVE_REPORT_MAKE_UP_HEADLINE, projectName));
|
||||
map.put(SUBHEADING, String.format(BGT_LEAVE_REPORT_MAKE_UP_SUBHEADING_ONE, projectName,auditor,pass));
|
||||
break;
|
||||
case "13":
|
||||
map.put(HEADLINE, String.format(BGT_TO_FBG_PROGRESS_HEADLINE,auditor, projectName));
|
||||
map.put(SUBHEADING, String.format(BGT_TO_FBG_PROGRESS_SUBHEADING, auditor,projectName));
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
@ -5,6 +5,9 @@ import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import static com.ruoyi.common.constants.BgtMessageConstant.HEADLINE;
|
||||
import static com.ruoyi.common.constants.BgtMessageConstant.SUBHEADING;
|
||||
|
||||
public class FbsMessageConstant {
|
||||
// 公共常量
|
||||
|
||||
@ -14,7 +17,7 @@ public class FbsMessageConstant {
|
||||
|
||||
public static final String FBS_SMALL_SIGN_UP = "1"; //小类型-包工头报名
|
||||
public static final String FBS_SMALL_PAY = "2"; //小类型-付款
|
||||
public static final String FBS_SMALL_LEAVE = "3"; //小类型-进度
|
||||
public static final String FBS_SMALL_PROGRESS = "3"; //小类型-进度
|
||||
|
||||
public static final List<String> AUDIT_TYPE = Arrays.asList("2", "3");
|
||||
/**
|
||||
@ -77,7 +80,7 @@ public class FbsMessageConstant {
|
||||
|
||||
//分包商->总包方 消息类型
|
||||
public static final String FBS_TYPE_SUB_TO_ZBF = "7"; //任务
|
||||
public static final String FBS_TYPE_SETTLEMEN_TO_FBGT = "8"; //结算
|
||||
public static final String FBS_TYPE_SETTLEMENT_TO_ZBF = "8"; //结算
|
||||
|
||||
|
||||
/**
|
||||
@ -85,12 +88,9 @@ public class FbsMessageConstant {
|
||||
* ============================================调用方法==================================================
|
||||
* ============================================调用方法==================================================
|
||||
*/
|
||||
//主副标志
|
||||
public static final String HEADLINE = "headline"; //主标题
|
||||
public static final String SUBHEADING = "subheading"; //副标题
|
||||
|
||||
//包工头消息返回
|
||||
public static Map<String, String> bgtMessage(Map<String, String> mp, String type, Boolean isPass) {
|
||||
public static Map<String, String> fbsMessage(Map<String, String> mp, String type, Boolean isPass) {
|
||||
Map<String, String> map = new HashMap<>();
|
||||
String pass = isPass ? "通过" : "拒绝";
|
||||
String projectName = mp.get("projectName");
|
||||
|
@ -8,7 +8,10 @@ public class WgzAndBgtMessageConstant {
|
||||
public static final String USERTYPE_WGZ = "1"; //务工者
|
||||
public static final String USERTYPE_BGT = "2"; //包工头
|
||||
public static final String USERTYPE_FBS = "3"; //分包商
|
||||
public static final String USERTYPE_ZBF = "4"; //分包商
|
||||
|
||||
//系统ID
|
||||
public static final Long SYSTEM_ID = 0L;
|
||||
|
||||
public static final String OPERATION_NO = "0"; //不需要操作
|
||||
public static final String OPERATION_NEED = "1"; //需要操作
|
||||
|
@ -0,0 +1,93 @@
|
||||
package com.ruoyi.common.constants;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import static com.ruoyi.common.constants.BgtMessageConstant.HEADLINE;
|
||||
import static com.ruoyi.common.constants.BgtMessageConstant.SUBHEADING;
|
||||
|
||||
public class ZbfMessageConstant {
|
||||
// 公共常量
|
||||
|
||||
public static final String ZBF_LARGE_TASK = "1"; //大类型-任务
|
||||
public static final String ZBF_LARGE_SETTLEMENT = "2"; //大类型-结算
|
||||
public static final String ZBF_LARGE_OTHER = "3"; //大类型-其它
|
||||
|
||||
public static final String ZBF_SMALL_SIGN_UP = "1"; //小类型-分包商报名
|
||||
public static final String ZBF_SMALL_PAY = "2"; //小类型-付款
|
||||
public static final String ZBF_SMALL_PROGRESS = "3"; //小类型-进度
|
||||
|
||||
public static final List<String> AUDIT_TYPE = Arrays.asList("2", "3");
|
||||
/**
|
||||
* ============================================总包方->分包商 模板==================================================
|
||||
* ============================================总包方->分包商 模板==================================================
|
||||
* ============================================总包方->分包商 模板==================================================
|
||||
*/
|
||||
|
||||
//任务审批
|
||||
public static final String ZBF_SIGN_UP_APPLY_HEADLINE = "您申请的【%s】项目【%s】分包,已得到回复!";
|
||||
public static final String ZBF_SIGN_UP_APPLY_SUBHEADING = "您申请的【%s】任务【%s】分包,审核人【%s】已%s!";
|
||||
//工资审批
|
||||
public static final String ZBF_PAY_APPLY_HEADLINE = "您【%s】任务【%s】分包工资申请已审批!";
|
||||
public static final String ZBF_PAY_APPLY_SUBHEADING = "您申请的【%s】任务【%s】分包工资,审核人【%s】已%s!";
|
||||
|
||||
|
||||
//分包商->包工头 消息类型
|
||||
public static final String ZBF_TYPE_SIGN_UP = "1"; //包工头报名
|
||||
public static final String ZBF_TYPE_PAY = "2"; //付款
|
||||
|
||||
/**
|
||||
* ============================================系统->分包商 模板==================================================
|
||||
* ============================================系统->分包商 模板==================================================
|
||||
* ============================================系统->分包商 模板==================================================
|
||||
*/
|
||||
// //承接任务
|
||||
// public static final String FBS_SUB_APPLY_HEADLINE = "您已成功申请【%s】项目【%s】分包";
|
||||
// public static final String FBS_SUB_APPLY_SUBHEADING = "您已成功申请到【%s】项目【%s】分包,请耐心等待回复!";
|
||||
// //取消承接任务
|
||||
// public static final String FBS_TASK_APPLY_CANCEL_HEADLINE = "您已成功取消【%s】项目【%s】分包申请!";
|
||||
// public static final String FBS_TASK_APPLY_CANCEL_SUBHEADING = "您已成功取消【%s】项目【%s】分包申请";
|
||||
// //工资结算
|
||||
// public static final String FBS_SETTLEMENT_APPLY_HEADLINE = "您正在申请【%s】项目【%s】分包,总共【%s】元的工资结算操作!";
|
||||
// public static final String FBS_SETTLEMENT_APPLY_SUBHEADING = "您已成功发起金额为【%s】元的工资结算操作,请耐心等待回复!";
|
||||
//
|
||||
//
|
||||
// //系统->包工头 消息类型
|
||||
// public static final String FBS_TYPE_TASK = "4"; //任务报名
|
||||
// public static final String FBS_TYPE_TASK_CANCEL = "5"; //任务取消
|
||||
// public static final String FBS_TYPE_SETTLEMENT = "6"; //结算
|
||||
|
||||
|
||||
/**
|
||||
* ============================================调用方法==================================================
|
||||
* ============================================调用方法==================================================
|
||||
* ============================================调用方法==================================================
|
||||
*/
|
||||
|
||||
//包工头消息返回
|
||||
public static Map<String, String> zbfMessage(Map<String, String> mp, String type, Boolean isPass) {
|
||||
Map<String, String> map = new HashMap<>();
|
||||
String pass = isPass ? "通过" : "拒绝";
|
||||
String projectName = mp.get("projectName");
|
||||
String subName = mp.get("subName");
|
||||
String auditor = mp.get("auditor");
|
||||
String amount = mp.get("amount");
|
||||
switch (type) {
|
||||
case "1":
|
||||
map.put(HEADLINE, String.format(ZBF_SIGN_UP_APPLY_HEADLINE, projectName,subName));
|
||||
map.put(SUBHEADING, String.format(ZBF_SIGN_UP_APPLY_SUBHEADING, projectName,subName, auditor, pass));
|
||||
break;
|
||||
case "2":
|
||||
map.put(HEADLINE, String.format(ZBF_PAY_APPLY_HEADLINE, projectName,subName));
|
||||
map.put(SUBHEADING, String.format(ZBF_PAY_APPLY_SUBHEADING, projectName,subName, auditor, pass));
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return map;
|
||||
}
|
||||
|
||||
|
||||
}
|
@ -1,108 +0,0 @@
|
||||
package com.ruoyi.common.controller;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Arrays;
|
||||
|
||||
import com.ruoyi.common.domain.Company;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import javax.validation.constraints.*;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import com.ruoyi.common.annotation.RepeatSubmit;
|
||||
import com.ruoyi.common.annotation.Log;
|
||||
import com.ruoyi.common.core.controller.BaseController;
|
||||
import com.ruoyi.common.core.domain.AjaxResult;
|
||||
import com.ruoyi.common.enums.BusinessType;
|
||||
import com.ruoyi.common.bo.CompanyQueryBo;
|
||||
import com.ruoyi.common.service.ICompanyService;
|
||||
import com.ruoyi.common.utils.poi.ExcelUtil;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import io.swagger.annotations.Api;
|
||||
import io.swagger.annotations.ApiOperation;
|
||||
|
||||
/**
|
||||
* 企业认证Controller
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-26
|
||||
*/
|
||||
@Api(value = "企业认证控制器", tags = {"企业认证管理"})
|
||||
@RequiredArgsConstructor(onConstructor_ = @Autowired)
|
||||
@RestController
|
||||
@RequestMapping("/common/company")
|
||||
public class CompanyController extends BaseController {
|
||||
|
||||
private final ICompanyService iCommonCompanyService;
|
||||
|
||||
/**
|
||||
* 查询企业认证列表
|
||||
*/
|
||||
@ApiOperation("查询企业认证列表")
|
||||
@PreAuthorize("@ss.hasPermi('common:company:list')")
|
||||
@GetMapping("/list")
|
||||
public TableDataInfo<Company> list(@Validated CompanyQueryBo bo) {
|
||||
return iCommonCompanyService.queryPageList(bo);
|
||||
}
|
||||
|
||||
/**
|
||||
* 导出企业认证列表
|
||||
*/
|
||||
@ApiOperation("导出企业认证列表")
|
||||
@PreAuthorize("@ss.hasPermi('common:company:export')")
|
||||
@Log(title = "企业认证", businessType = BusinessType.EXPORT)
|
||||
@GetMapping("/export")
|
||||
public AjaxResult<Company> export(@Validated CompanyQueryBo bo) {
|
||||
List<Company> list = iCommonCompanyService.queryList(bo);
|
||||
ExcelUtil<Company> util = new ExcelUtil<Company>(Company.class);
|
||||
return util.exportExcel(list, "企业认证");
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取企业认证详细信息
|
||||
*/
|
||||
@ApiOperation("获取企业认证详细信息")
|
||||
@PreAuthorize("@ss.hasPermi('common:company:query')")
|
||||
@GetMapping("/{id}")
|
||||
public AjaxResult<Company> getInfo(@NotNull(message = "主键不能为空")
|
||||
@PathVariable("id") Long id) {
|
||||
return AjaxResult.success(iCommonCompanyService.queryById(id));
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增企业认证
|
||||
*/
|
||||
@ApiOperation("新增企业认证")
|
||||
@PreAuthorize("@ss.hasPermi('common:company:add')")
|
||||
@Log(title = "企业认证", businessType = BusinessType.INSERT)
|
||||
@RepeatSubmit
|
||||
@PostMapping()
|
||||
public AjaxResult<Void> add(@Validated @RequestBody Company bo) {
|
||||
return toAjax(iCommonCompanyService.insert(bo) ? 1 : 0);
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改企业认证
|
||||
*/
|
||||
@ApiOperation("修改企业认证")
|
||||
@PreAuthorize("@ss.hasPermi('common:company:edit')")
|
||||
@Log(title = "企业认证", businessType = BusinessType.UPDATE)
|
||||
@RepeatSubmit
|
||||
@PutMapping()
|
||||
public AjaxResult<Void> edit(@Validated @RequestBody Company bo) {
|
||||
return toAjax(iCommonCompanyService.update(bo) ? 1 : 0);
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除企业认证
|
||||
*/
|
||||
@ApiOperation("删除企业认证")
|
||||
@PreAuthorize("@ss.hasPermi('common:company:remove')")
|
||||
@Log(title = "企业认证" , businessType = BusinessType.DELETE)
|
||||
@DeleteMapping("/{ids}")
|
||||
public AjaxResult<Void> remove(@NotEmpty(message = "主键不能为空")
|
||||
@PathVariable Long[] ids) {
|
||||
return toAjax(iCommonCompanyService.deleteWithValidByIds(Arrays.asList(ids), true) ? 1 : 0);
|
||||
}
|
||||
}
|
@ -1,9 +1,6 @@
|
||||
package com.ruoyi.common.domain;
|
||||
|
||||
import com.baomidou.mybatisplus.annotation.FieldFill;
|
||||
import com.baomidou.mybatisplus.annotation.TableField;
|
||||
import com.baomidou.mybatisplus.annotation.TableId;
|
||||
import com.baomidou.mybatisplus.annotation.TableName;
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import com.ruoyi.common.annotation.Excel;
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
@ -33,7 +30,7 @@ public class Company implements Serializable {
|
||||
|
||||
/** 主键ID */
|
||||
@ApiModelProperty("主键ID")
|
||||
@TableId(value = "id")
|
||||
@TableId(value = "id", type = IdType.AUTO)
|
||||
private Long id;
|
||||
|
||||
/** 企业名称 */
|
||||
@ -66,6 +63,19 @@ public class Company implements Serializable {
|
||||
@ApiModelProperty("注册资本")
|
||||
private BigDecimal registrationAmount;
|
||||
|
||||
|
||||
@ApiModelProperty("联系人")
|
||||
private String contact;
|
||||
|
||||
@ApiModelProperty("联系电话")
|
||||
private String contactPhone;
|
||||
|
||||
@ApiModelProperty("银行")
|
||||
private String bank;
|
||||
|
||||
@ApiModelProperty("银行卡号")
|
||||
private String cardNo;
|
||||
|
||||
/** 企业简介 */
|
||||
@Excel(name = "企业简介")
|
||||
@ApiModelProperty("企业简介")
|
||||
|
@ -40,6 +40,18 @@ public class CompanyAuthenticateDTO {
|
||||
@ApiModelProperty("注册资本")
|
||||
private BigDecimal registrationAmount;
|
||||
|
||||
@ApiModelProperty("联系人")
|
||||
private String contact;
|
||||
|
||||
@ApiModelProperty("联系电话")
|
||||
private String contactPhone;
|
||||
|
||||
@ApiModelProperty("银行")
|
||||
private String bank;
|
||||
|
||||
@ApiModelProperty("银行卡号")
|
||||
private String cardNo;
|
||||
|
||||
@ApiModelProperty("企业简介")
|
||||
private String introduce;
|
||||
|
||||
|
@ -52,4 +52,9 @@ public interface ICompanyService extends IServicePlus<Company> {
|
||||
* @return
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
|
||||
/**
|
||||
* 获取公司的名称
|
||||
*/
|
||||
String getCompanyNameById(Long id);
|
||||
}
|
||||
|
@ -89,4 +89,13 @@ public class CompanyServiceImpl extends ServicePlusImpl<CommonCompanyMapper, Com
|
||||
}
|
||||
return removeByIds(ids);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String getCompanyNameById(Long id) {
|
||||
if(id == null) {
|
||||
return "";
|
||||
}
|
||||
Company byId = getById(id);
|
||||
return byId.getCompanyName();
|
||||
}
|
||||
}
|
||||
|
@ -53,4 +53,7 @@ public class FbsProjectTaskUpdateDTO {
|
||||
|
||||
@ApiModelProperty("资质要求")
|
||||
private String qualification;
|
||||
|
||||
@ApiModelProperty("备注")
|
||||
private String remark;
|
||||
}
|
||||
|
@ -23,12 +23,21 @@ public class AppTaskDetailVO {
|
||||
@ApiModelProperty("项目ID")
|
||||
private Long projectId;
|
||||
|
||||
@ApiModelProperty("项目名")
|
||||
private String projectName;
|
||||
|
||||
@ApiModelProperty("标段ID")
|
||||
private Long sectionId;
|
||||
|
||||
@ApiModelProperty("标段名称")
|
||||
private String sectionName;
|
||||
|
||||
@ApiModelProperty("分包ID")
|
||||
private Long subId;
|
||||
|
||||
@ApiModelProperty("分包主题")
|
||||
private String subName;
|
||||
|
||||
/** 任务名称 */
|
||||
@ApiModelProperty("任务名称")
|
||||
private String taskName;
|
||||
@ -82,9 +91,6 @@ public class AppTaskDetailVO {
|
||||
@ApiModelProperty("备注")
|
||||
private String remark;
|
||||
|
||||
@ApiModelProperty("项目名")
|
||||
private String projectName;
|
||||
|
||||
@ApiModelProperty("发布时间")
|
||||
@JsonFormat(pattern = "yyyy-MM-dd")
|
||||
private LocalDateTime createTime;
|
||||
|
@ -0,0 +1,21 @@
|
||||
package com.ruoyi.fbs.domain.vo;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
@ApiModel("分包商项目列表统计")
|
||||
public class FbsProjectListCountVO {
|
||||
|
||||
|
||||
@ApiModelProperty("申请中数量")
|
||||
private Integer applyCount;
|
||||
|
||||
@ApiModelProperty("已加入数量")
|
||||
private Integer joinCount;
|
||||
|
||||
@ApiModelProperty("已竣工数量")
|
||||
private Integer completeCount;
|
||||
|
||||
}
|
@ -22,6 +22,9 @@ public class FbsProjectListVO {
|
||||
@ApiModelProperty("项目地址")
|
||||
private String projectAddress;
|
||||
|
||||
@ApiModelProperty("项目图片")
|
||||
private String projectImg;
|
||||
|
||||
@ApiModelProperty("项目状态(0-未开工,1-已开工,2已竣工,3已停工)")
|
||||
private String projectStatus;
|
||||
|
||||
|
@ -19,6 +19,9 @@ public class FbsProjectSectionListVO {
|
||||
@ApiModelProperty("标段名称")
|
||||
private String sectionName;
|
||||
|
||||
@ApiModelProperty("项目地址")
|
||||
private String projectAddress;
|
||||
|
||||
@ApiModelProperty("分包列表")
|
||||
private List<FbsProjectSubcontractingListVO> subList;
|
||||
|
||||
|
@ -0,0 +1,71 @@
|
||||
package com.ruoyi.fbs.domain.vo;
|
||||
|
||||
import com.baomidou.mybatisplus.annotation.IdType;
|
||||
import com.baomidou.mybatisplus.annotation.TableId;
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
import lombok.experimental.Accessors;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.time.LocalDateTime;
|
||||
|
||||
/**
|
||||
* 总包方项目分包对象 zbf_project_subcontracting
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-02-17
|
||||
*/
|
||||
@Data
|
||||
@Accessors(chain = true)
|
||||
@ApiModel("分包商查询项目分包详情视图对象")
|
||||
public class FbsProjectSubcontractingDetailVO {
|
||||
|
||||
/** 主键ID */
|
||||
@ApiModelProperty("主键ID")
|
||||
@TableId(value = "id", type = IdType.AUTO)
|
||||
private Long id;
|
||||
|
||||
@ApiModelProperty("项目ID")
|
||||
private Long projectId;
|
||||
|
||||
@ApiModelProperty("标段ID")
|
||||
private Long sectionId;
|
||||
|
||||
@ApiModelProperty("标段名")
|
||||
private String sectionName;
|
||||
|
||||
@ApiModelProperty("分包主题")
|
||||
private String subName;
|
||||
|
||||
@ApiModelProperty("分包描述")
|
||||
private String subDescribe;
|
||||
|
||||
@ApiModelProperty("分包金额")
|
||||
private BigDecimal subAmount;
|
||||
|
||||
@ApiModelProperty("资质要求")
|
||||
private String qualification;
|
||||
|
||||
@ApiModelProperty("分包商用户ID")
|
||||
private Long userId;
|
||||
|
||||
@ApiModelProperty("删除标志(0代表存在 2代表删除)")
|
||||
private String delFlag;
|
||||
|
||||
@ApiModelProperty("创建者")
|
||||
private String createBy;
|
||||
|
||||
@ApiModelProperty("创建时间")
|
||||
private LocalDateTime createTime;
|
||||
|
||||
@ApiModelProperty("更新者")
|
||||
private String updateBy;
|
||||
|
||||
@ApiModelProperty("更新时间")
|
||||
private LocalDateTime updateTime;
|
||||
|
||||
@ApiModelProperty("备注")
|
||||
private String remark;
|
||||
|
||||
}
|
@ -16,6 +16,10 @@ public class FbsProjectSubcontractingListVO {
|
||||
|
||||
@ApiModelProperty("项目ID")
|
||||
private Long projectId;
|
||||
|
||||
@ApiModelProperty("项目地址")
|
||||
private String projectAddress;
|
||||
|
||||
/** 标段ID */
|
||||
@ApiModelProperty("标段ID")
|
||||
private Long sectionId;
|
||||
@ -32,7 +36,7 @@ public class FbsProjectSubcontractingListVO {
|
||||
@ApiModelProperty("资质要求")
|
||||
private String qualification;
|
||||
|
||||
|
||||
|
||||
@ApiModelProperty("申请状态(0=申请中,1=已同意,2=已拒绝,3=已取消)")
|
||||
private String applyStatus;
|
||||
|
||||
}
|
||||
|
@ -0,0 +1,25 @@
|
||||
package com.ruoyi.fbs.domain.vo;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
import lombok.NoArgsConstructor;
|
||||
|
||||
/**
|
||||
* 分包商项目任务对象 fbs_project_task
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-02-17
|
||||
*/
|
||||
@Data
|
||||
@NoArgsConstructor
|
||||
@ApiModel("分包商任务列表数量统计视图对象")
|
||||
public class FbsProjectTaskListCountVO {
|
||||
|
||||
@ApiModelProperty("已发布数量")
|
||||
private Integer releaseCount;
|
||||
|
||||
@ApiModelProperty("已完成数量")
|
||||
private Integer completeCount;
|
||||
|
||||
}
|
@ -72,4 +72,23 @@ public interface IFbsMessageService extends IServicePlus<FbsMessage> {
|
||||
* 消息详情列表
|
||||
*/
|
||||
TableDataInfo<FbsMessageDetailVO> queryDetailPageList(FbsMessageDetailDTO dto);
|
||||
|
||||
/**
|
||||
* 发送消息
|
||||
*/
|
||||
Boolean sendAMessage(FbsMessage bo);
|
||||
|
||||
/**
|
||||
* 已操作
|
||||
*/
|
||||
void operation(String senderType,Long senderId,String recipientType,Long recipientId,Long tableId,String tableName);
|
||||
|
||||
/**
|
||||
* 批量已操作
|
||||
*/
|
||||
void operationBatch(String recipientType,Long recipientId,List<Long> tableIds,String tableName);
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
|
@ -75,4 +75,9 @@ public interface IFbsProjectTaskApplyService extends IServicePlus<FbsProjectTask
|
||||
* 查询任务下的包工头申请列表
|
||||
*/
|
||||
TableDataInfo<FbsProjectTaskApplyListVO> queryPageListByTaskId(FbsTaskApplyListDTO dto);
|
||||
|
||||
/**
|
||||
* 分包商选择包工头
|
||||
*/
|
||||
Boolean choose(Long id);
|
||||
}
|
||||
|
@ -116,6 +116,11 @@ public interface IFbsProjectTaskService extends IServicePlus<FbsProjectTask> {
|
||||
*/
|
||||
TableDataInfo<FbsProjectTaskListVO> fbsPageList(FbsTaskListDTO dto);
|
||||
|
||||
/**
|
||||
* 分包商查询任务列表数量统计
|
||||
*/
|
||||
FbsProjectTaskListCountVO fbsListCount();
|
||||
|
||||
/**
|
||||
* 分包商查询任务详情-工资结算审批
|
||||
*/
|
||||
|
@ -62,7 +62,7 @@ public interface IFbsUserService extends IServicePlus<FbsUser> {
|
||||
/**
|
||||
* 企业认证
|
||||
*/
|
||||
Boolean authenticate(CompanyAuthenticateDTO dto);
|
||||
Long authenticate(CompanyAuthenticateDTO dto);
|
||||
|
||||
/**
|
||||
* 企业认证
|
||||
|
@ -3,6 +3,7 @@ package com.ruoyi.fbs.service.impl;
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import cn.hutool.core.util.StrUtil;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||
@ -28,6 +29,7 @@ import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.OPERATION_ALREADY;
|
||||
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.OPERATION_NEED;
|
||||
|
||||
/**
|
||||
@ -204,4 +206,32 @@ public class FbsMessageServiceImpl extends ServicePlusImpl<FbsMessageMapper, Fbs
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public Boolean sendAMessage(FbsMessage bo) {
|
||||
return save(bo);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void operation(String senderType, Long senderId, String recipientType, Long recipientId, Long tableId, String tableName) {
|
||||
LambdaUpdateWrapper<FbsMessage> wrapper = new LambdaUpdateWrapper<>();
|
||||
wrapper.eq(FbsMessage::getRecipientId, recipientId);
|
||||
wrapper.eq(FbsMessage::getRecipientType, recipientType);
|
||||
wrapper.eq(FbsMessage::getSenderId, senderId);
|
||||
wrapper.eq(FbsMessage::getSenderType, senderType);
|
||||
wrapper.eq(FbsMessage::getTableId, tableId);
|
||||
wrapper.eq(FbsMessage::getTableName, tableName);
|
||||
wrapper.set(FbsMessage::getIsOperation, OPERATION_ALREADY);
|
||||
update(wrapper);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void operationBatch(String recipientType, Long recipientId, List<Long> tableIds, String tableName) {
|
||||
LambdaUpdateWrapper<FbsMessage> wrapper = new LambdaUpdateWrapper<>();
|
||||
wrapper.eq(FbsMessage::getRecipientId, recipientId);
|
||||
wrapper.eq(FbsMessage::getRecipientType, recipientType);
|
||||
wrapper.in(FbsMessage::getTableId, tableIds);
|
||||
wrapper.eq(FbsMessage::getTableName, tableName);
|
||||
wrapper.set(FbsMessage::getIsOperation, OPERATION_ALREADY);
|
||||
update(wrapper);
|
||||
}
|
||||
}
|
||||
|
@ -11,30 +11,30 @@ import com.ruoyi.bgt.domain.dto.BgtTaskApplyDTO;
|
||||
import com.ruoyi.bgt.service.IBgtMessageService;
|
||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.enums.TaskApplyStatus;
|
||||
import com.ruoyi.common.exception.BaseException;
|
||||
import com.ruoyi.common.utils.PageUtils;
|
||||
import com.ruoyi.common.utils.SecurityUtils;
|
||||
import com.ruoyi.fbs.bo.FbsProjectTaskApplyQueryBo;
|
||||
import com.ruoyi.fbs.domain.FbsMessage;
|
||||
import com.ruoyi.fbs.domain.FbsProjectTask;
|
||||
import com.ruoyi.fbs.domain.FbsProjectTaskApply;
|
||||
import com.ruoyi.fbs.domain.dto.FbsTaskApplyListDTO;
|
||||
import com.ruoyi.fbs.domain.vo.FbsProjectTaskApplyListVO;
|
||||
import com.ruoyi.fbs.mapper.FbsProjectTaskApplyMapper;
|
||||
import com.ruoyi.fbs.service.IFbsMessageService;
|
||||
import com.ruoyi.fbs.service.IFbsProjectTaskApplyService;
|
||||
import com.ruoyi.fbs.service.IFbsProjectTaskService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.*;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
import static com.ruoyi.common.constants.BgtMessageConstant.*;
|
||||
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.USERTYPE_BGT;
|
||||
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.USERTYPE_SYSTEM;
|
||||
import static com.ruoyi.common.constants.FbsMessageConstant.*;
|
||||
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.*;
|
||||
|
||||
/**
|
||||
* 分包商项目任务申请Service业务层处理
|
||||
@ -49,7 +49,8 @@ public class FbsProjectTaskApplyServiceImpl extends ServicePlusImpl<FbsProjectTa
|
||||
private IBgtMessageService bgtMessageService;
|
||||
@Autowired
|
||||
private IFbsProjectTaskService taskService;
|
||||
|
||||
@Autowired
|
||||
private IFbsMessageService fbsMessageService;
|
||||
@Override
|
||||
public FbsProjectTaskApply queryById(Long id){
|
||||
return getById(id);
|
||||
@ -84,7 +85,7 @@ public class FbsProjectTaskApplyServiceImpl extends ServicePlusImpl<FbsProjectTa
|
||||
@Override
|
||||
public Boolean update(FbsProjectTaskApply bo) {
|
||||
FbsProjectTaskApply update = BeanUtil.toBean(bo, FbsProjectTaskApply.class);
|
||||
validEntityBeforeSave(update);
|
||||
// validEntityBeforeSave(update);
|
||||
return updateById(update);
|
||||
}
|
||||
|
||||
@ -97,6 +98,7 @@ public class FbsProjectTaskApplyServiceImpl extends ServicePlusImpl<FbsProjectTa
|
||||
LambdaQueryWrapper<FbsProjectTaskApply> wrapper = new LambdaQueryWrapper<>();
|
||||
wrapper.eq(FbsProjectTaskApply::getTaskId, entity.getTaskId());
|
||||
wrapper.eq(FbsProjectTaskApply::getUserId, entity.getUserId());
|
||||
wrapper.eq(FbsProjectTaskApply::getApplyStatus, TaskApplyStatus.APPLY.getCode());
|
||||
List<FbsProjectTaskApply> list = baseMapper.selectList(wrapper);
|
||||
if (CollUtil.isNotEmpty(list)) {
|
||||
throw new BaseException("该任务已申请");
|
||||
@ -115,24 +117,46 @@ public class FbsProjectTaskApplyServiceImpl extends ServicePlusImpl<FbsProjectTa
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public Boolean appTaskApply(BgtTaskApplyDTO dto) {
|
||||
FbsProjectTaskApply fbsProjectTaskApply = BeanUtil.copyProperties(dto, FbsProjectTaskApply.class);
|
||||
fbsProjectTaskApply.setUserId(SecurityUtils.getAppUserId());
|
||||
validEntityBeforeSave(fbsProjectTaskApply);
|
||||
|
||||
//发消息
|
||||
//系统发消息到包工头
|
||||
FbsProjectTask task = taskService.getById(dto.getTaskId());
|
||||
HashMap<String, String> mp = new HashMap<>();
|
||||
mp.put("projectName", task.getTaskName());
|
||||
mp.put("auditor", SecurityUtils.getUsername());
|
||||
Map<String, String> map = bgtMessage(mp, BGT_TYPE_TASK, true);
|
||||
BgtMessage bgtMessage = new BgtMessage()
|
||||
.setSenderType(USERTYPE_SYSTEM)
|
||||
.setRecipientType(USERTYPE_BGT)
|
||||
.setRecipientId(dto.getUserId())
|
||||
.setHeadline(map.get(HEADLINE))
|
||||
.setSubheading(map.get(SUBHEADING))
|
||||
.setTableId(task.getId())
|
||||
.setTableName(SqlHelper.table(FbsProjectTask.class).getTableName())
|
||||
.setMessageLargeType(BGT_LARGE_TASK);
|
||||
bgtMessageService.sendAMessage(bgtMessage);
|
||||
// HashMap<String, String> mp = new HashMap<>();
|
||||
// mp.put("projectName", task.getTaskName());
|
||||
// mp.put("auditor", SecurityUtils.getUsername());
|
||||
// Map<String, String> map = bgtMessage(mp, BGT_TYPE_TASK, true);
|
||||
// BgtMessage bgtMessage = new BgtMessage()
|
||||
// .setSenderType(USERTYPE_SYSTEM)
|
||||
// .setSenderId(SYSTEM_ID)
|
||||
// .setRecipientType(USERTYPE_BGT)
|
||||
// .setRecipientId(dto.getUserId())
|
||||
// .setHeadline(map.get(HEADLINE))
|
||||
// .setSubheading(map.get(SUBHEADING))
|
||||
// .setTableId(fbsProjectTaskApply.getId())
|
||||
// .setTableName(SqlHelper.table(FbsProjectTaskApply.class).getTableName())
|
||||
// .setMessageLargeType(BGT_LARGE_TASK);
|
||||
// bgtMessageService.sendAMessage(bgtMessage);
|
||||
|
||||
//包工头发消息到分包商
|
||||
HashMap<String, String> fmp = new HashMap<>();
|
||||
fmp.put("projectName", task.getTaskName());
|
||||
fmp.put("auditor", SecurityUtils.getUsername());
|
||||
Map<String, String> fmap = bgtMessage(fmp, BGT_TYPE_TASK_TO_FBS, true);
|
||||
FbsMessage fbsMessage = new FbsMessage()
|
||||
.setSenderType(USERTYPE_BGT)
|
||||
.setSenderId(SecurityUtils.getAppUserId())
|
||||
.setRecipientType(USERTYPE_FBS)
|
||||
.setRecipientId(task.getCreateId())
|
||||
.setHeadline(fmap.get(HEADLINE))
|
||||
.setSubheading(fmap.get(SUBHEADING))
|
||||
.setTableId(fbsProjectTaskApply.getId())
|
||||
.setTableName(SqlHelper.table(FbsProjectTaskApply.class).getTableName())
|
||||
.setMessageLargeType(FBS_LARGE_OTHER)
|
||||
.setMessageSmallType(FBS_SMALL_SIGN_UP)
|
||||
.setIsOperation(OPERATION_NEED);
|
||||
fbsMessageService.sendAMessage(fbsMessage);
|
||||
|
||||
return save(fbsProjectTaskApply);
|
||||
}
|
||||
|
||||
@ -144,25 +168,42 @@ public class FbsProjectTaskApplyServiceImpl extends ServicePlusImpl<FbsProjectTa
|
||||
|
||||
@Override
|
||||
public Boolean cancelApply(BgtTaskApplyDTO dto) {
|
||||
int delete = baseMapper.delete(Wrappers.<FbsProjectTaskApply>lambdaQuery().eq(FbsProjectTaskApply::getTaskId, dto.getTaskId())
|
||||
.eq(FbsProjectTaskApply::getUserId, dto.getUserId()));
|
||||
//发消息
|
||||
|
||||
LambdaQueryWrapper<FbsProjectTaskApply> wrapper = new LambdaQueryWrapper<>();
|
||||
wrapper.eq(FbsProjectTaskApply::getTaskId, dto.getTaskId());
|
||||
wrapper.eq(FbsProjectTaskApply::getUserId, SecurityUtils.getAppUserId());
|
||||
wrapper.eq(FbsProjectTaskApply::getApplyStatus, TaskApplyStatus.APPLY.getCode());
|
||||
List<FbsProjectTaskApply> list = baseMapper.selectList(wrapper);
|
||||
if (CollUtil.isEmpty(list)) {
|
||||
throw new BaseException("该任务尚未申请");
|
||||
}
|
||||
FbsProjectTaskApply fbsProjectTaskApply = list.get(0);
|
||||
fbsProjectTaskApply.setApplyStatus(TaskApplyStatus.CANCEL.getCode());
|
||||
boolean update = updateById(fbsProjectTaskApply);
|
||||
|
||||
FbsProjectTask task = taskService.getById(dto.getTaskId());
|
||||
HashMap<String, String> mp = new HashMap<>();
|
||||
mp.put("projectName", task.getTaskName());
|
||||
mp.put("auditor", SecurityUtils.getUsername());
|
||||
Map<String, String> map = bgtMessage(mp, BGT_TYPE_TASK_CANCEL, true);
|
||||
BgtMessage bgtMessage = new BgtMessage()
|
||||
.setSenderType(USERTYPE_SYSTEM)
|
||||
.setRecipientType(USERTYPE_BGT)
|
||||
.setRecipientId(dto.getUserId())
|
||||
.setHeadline(map.get(HEADLINE))
|
||||
.setSubheading(map.get(SUBHEADING))
|
||||
.setTableId(task.getId())
|
||||
.setTableName(SqlHelper.table(FbsProjectTask.class).getTableName())
|
||||
.setMessageLargeType(BGT_LARGE_TASK);
|
||||
bgtMessageService.sendAMessage(bgtMessage);
|
||||
return delete>0;
|
||||
|
||||
//修改消息操作
|
||||
fbsMessageService.operation(USERTYPE_BGT,SecurityUtils.getAppUserId(),USERTYPE_FBS,task.getCreateId()
|
||||
,fbsProjectTaskApply.getId(),SqlHelper.table(FbsProjectTaskApply.class).getTableName());
|
||||
|
||||
//发消息
|
||||
// FbsProjectTask task = taskService.getById(dto.getTaskId());
|
||||
// HashMap<String, String> mp = new HashMap<>();
|
||||
// mp.put("projectName", task.getTaskName());
|
||||
// mp.put("auditor", SecurityUtils.getUsername());
|
||||
// Map<String, String> map = bgtMessage(mp, BGT_TYPE_TASK_CANCEL, true);
|
||||
// BgtMessage bgtMessage = new BgtMessage()
|
||||
// .setSenderType(USERTYPE_SYSTEM)
|
||||
// .setRecipientType(USERTYPE_BGT)
|
||||
// .setRecipientId(dto.getUserId())
|
||||
// .setHeadline(map.get(HEADLINE))
|
||||
// .setSubheading(map.get(SUBHEADING))
|
||||
// .setTableId(task.getId())
|
||||
// .setTableName(SqlHelper.table(FbsProjectTask.class).getTableName())
|
||||
// .setMessageLargeType(BGT_LARGE_TASK);
|
||||
// bgtMessageService.sendAMessage(bgtMessage);
|
||||
return update;
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -173,4 +214,57 @@ public class FbsProjectTaskApplyServiceImpl extends ServicePlusImpl<FbsProjectTa
|
||||
Page<FbsProjectTaskApplyListVO> voPage = baseMapper.queryPageListByTaskId(page, dto);
|
||||
return PageUtils.buildDataInfo(voPage);
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public Boolean choose(Long id) {
|
||||
FbsProjectTaskApply taskApply = getById(id);
|
||||
if(taskApply == null || TaskApplyStatus.CANCEL.getCode().equals(taskApply.getApplyStatus())){
|
||||
throw new BaseException("该申请已取消");
|
||||
}
|
||||
FbsProjectTask task = taskService.getById(taskApply.getTaskId());
|
||||
if(task!=null && task.getUserId()!=null){
|
||||
throw new BaseException("该任务已被承接");
|
||||
}
|
||||
|
||||
//拒绝其余包工头
|
||||
LambdaQueryWrapper<FbsProjectTaskApply> wrapper = new LambdaQueryWrapper<>();
|
||||
wrapper.eq(FbsProjectTaskApply::getTaskId, taskApply.getTaskId());
|
||||
wrapper.eq(FbsProjectTaskApply::getApplyStatus, TaskApplyStatus.APPLY.getCode());
|
||||
List<FbsProjectTaskApply> list = baseMapper.selectList(wrapper);
|
||||
|
||||
|
||||
ArrayList<BgtMessage> bgtMessages = new ArrayList<>();
|
||||
|
||||
|
||||
for (FbsProjectTaskApply fbsProjectTaskApply : list){
|
||||
boolean equals = fbsProjectTaskApply.getId().equals(id);
|
||||
if (equals){
|
||||
fbsProjectTaskApply.setApplyStatus(TaskApplyStatus.PASS.getCode());
|
||||
}else{
|
||||
fbsProjectTaskApply.setApplyStatus(TaskApplyStatus.REFUSE.getCode());
|
||||
}
|
||||
|
||||
//分包商发消息到包工头
|
||||
HashMap<String, String> mp = new HashMap<>();
|
||||
mp.put("projectName", task.getTaskName());
|
||||
mp.put("auditor", SecurityUtils.getUsername());
|
||||
Map<String, String> map = fbsMessage(mp, FBS_TYPE_SIGN_UP, equals);
|
||||
BgtMessage bgtMessage = new BgtMessage()
|
||||
.setSenderType(USERTYPE_FBS)
|
||||
.setSenderId(SecurityUtils.getAppUserId())
|
||||
.setRecipientType(USERTYPE_BGT)
|
||||
.setRecipientId(fbsProjectTaskApply.getUserId())
|
||||
.setHeadline(map.get(HEADLINE))
|
||||
.setSubheading(map.get(SUBHEADING))
|
||||
.setTableId(fbsProjectTaskApply.getId())
|
||||
.setTableName(SqlHelper.table(FbsProjectTaskApply.class).getTableName())
|
||||
.setMessageLargeType(BGT_LARGE_TASK)
|
||||
.setIsOperation(OPERATION_NO);
|
||||
bgtMessages.add(bgtMessage);
|
||||
}
|
||||
bgtMessageService.saveBatch(bgtMessages);
|
||||
fbsMessageService.operationBatch(USERTYPE_FBS,SecurityUtils.getAppUserId(),list.stream().map(FbsProjectTaskApply::getId).collect(Collectors.toList()),SqlHelper.table(FbsProjectTaskApply.class).getTableName());
|
||||
return super.updateBatchById(list);
|
||||
}
|
||||
}
|
||||
|
@ -37,6 +37,8 @@ import com.ruoyi.fbs.service.IFbsProjectTaskService;
|
||||
import com.ruoyi.wgz.service.IWgzAttendanceService;
|
||||
import com.ruoyi.wgz.service.IWgzPayCalculationService;
|
||||
import com.ruoyi.zbf.domain.ZbfProject;
|
||||
import com.ruoyi.zbf.domain.ZbfProjectSection;
|
||||
import com.ruoyi.zbf.service.IZbfProjectSectionService;
|
||||
import com.ruoyi.zbf.service.IZbfProjectService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
@ -72,6 +74,8 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
|
||||
private IWgzPayCalculationService payCalculationService;
|
||||
@Autowired
|
||||
private IFbsProjectTaskApplyService fbsProjectTaskApplyService;
|
||||
@Autowired
|
||||
private IZbfProjectSectionService zbfProjectSectionService;
|
||||
|
||||
@Override
|
||||
public FbsProjectTask queryById(Long id){
|
||||
@ -163,34 +167,22 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
|
||||
|
||||
@Override
|
||||
public AppTaskDetailVO appQueryById(Long id) {
|
||||
FbsProjectTask byId = getById(id);
|
||||
AppTaskDetailVO appTaskDetailVO = BeanUtil.copyProperties(byId, AppTaskDetailVO.class);
|
||||
FbsProjectTask projectTask = getById(id);
|
||||
AppTaskDetailVO appTaskDetailVO = BeanUtil.copyProperties(projectTask, AppTaskDetailVO.class);
|
||||
//项目信息
|
||||
ZbfProject project = zbfProjectService.getById(byId.getProjectId());
|
||||
ZbfProject project = zbfProjectService.getById(projectTask.getProjectId());
|
||||
appTaskDetailVO.setProjectName(project.getProjectName());
|
||||
//标段信息
|
||||
ZbfProjectSection projectSection = zbfProjectSectionService.getById(projectTask.getSectionId());
|
||||
appTaskDetailVO.setSectionName(projectSection.getSectionName());
|
||||
|
||||
if(ProjectTaskStatus.PROGRESS.getCode().equals(byId.getStatus())
|
||||
|| ProjectTaskStatus.COMPLETE.getCode().equals(byId.getStatus())){
|
||||
if(ProjectTaskStatus.PROGRESS.getCode().equals(projectTask.getStatus())
|
||||
|| ProjectTaskStatus.COMPLETE.getCode().equals(projectTask.getStatus())){
|
||||
//任务进度
|
||||
Integer lastProgress = progressService.getLastProgress(id);
|
||||
appTaskDetailVO.setProgress(lastProgress);
|
||||
BigDecimal bd = new BigDecimal(lastProgress).divide(new BigDecimal(100), 2, RoundingMode.HALF_UP);
|
||||
appTaskDetailVO.setProgressDouble(bd.doubleValue());
|
||||
// //结算情况
|
||||
// //收款申请列表
|
||||
// BgtWageApplicationQueryDTO wageDTO = new BgtWageApplicationQueryDTO();
|
||||
// wageDTO.setTaskId(id);
|
||||
// List<BgtWageApplicationListVO> wageList = wageApplicationService.appQueryList(wageDTO);
|
||||
// appTaskDetailVO.setWageApplication(CollectionUtil.isEmpty(wageList)?null:wageList.get(0));
|
||||
// //收款金额
|
||||
// Integer taskReceiveAmount = wageList.stream().filter(wage -> AuditStatus.PASS.getCode().equals(wage.getAuditStatus()))
|
||||
// .map(BgtWageApplicationListVO::getApplicantAmount)
|
||||
// .reduce(BigDecimal.ZERO, BigDecimal::add).intValue();
|
||||
// appTaskDetailVO.setTaskReceiveAmount(taskReceiveAmount);
|
||||
// //付款金额
|
||||
// BigDecimal payByTaskAndBgt = payCalculationService.getPayByTaskAndBgt(byId.getId(), byId.getUserId());
|
||||
// appTaskDetailVO.setTaskPaymentAmount(payByTaskAndBgt);
|
||||
|
||||
}
|
||||
return appTaskDetailVO;
|
||||
}
|
||||
@ -198,7 +190,7 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
|
||||
@Override
|
||||
public AppTaskDetailAttendanceVO attendance(Long id) {
|
||||
FbsProjectTask task = getById(id);
|
||||
LocalDate taskBeginTime = DateUtils.str2Localdate(task.getTaskBeginTime(), DateUtils.YYYY_MM_DD);
|
||||
// LocalDate taskBeginTime = DateUtils.str2Localdate(task.getTaskBeginTime(), DateUtils.YYYY_MM_DD);
|
||||
LocalDate taskEndTime = DateUtils.str2Localdate(task.getTaskEndTime(), DateUtils.YYYY_MM_DD);
|
||||
//考勤情况
|
||||
AppTaskDetailAttendanceVO appTaskDetailVO = new AppTaskDetailAttendanceVO();
|
||||
@ -310,6 +302,7 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
|
||||
public TableDataInfo<FbsProjectTaskListVO> fbsPageList(FbsTaskListDTO dto) {
|
||||
|
||||
LambdaQueryWrapper<FbsProjectTask> wrapper = new LambdaQueryWrapper<>();
|
||||
wrapper.eq(FbsProjectTask::getCreateId,SecurityUtils.getAppUserId());
|
||||
wrapper.in(dto.getType()==0,FbsProjectTask::getStatus,ProjectTaskStatus.getRelease());
|
||||
wrapper.eq(dto.getType()==1,FbsProjectTask::getStatus,ProjectTaskStatus.COMPLETE.getCode());
|
||||
wrapper.orderByDesc(FbsProjectTask::getId);
|
||||
@ -339,6 +332,24 @@ public class FbsProjectTaskServiceImpl extends ServicePlusImpl<FbsProjectTaskMap
|
||||
return PageUtils.buildDataInfo(fbsProjectTaskListVOPage);
|
||||
}
|
||||
|
||||
@Override
|
||||
public FbsProjectTaskListCountVO fbsListCount() {
|
||||
LambdaQueryWrapper<FbsProjectTask> releaseWrapper = new LambdaQueryWrapper<>();
|
||||
releaseWrapper.eq(FbsProjectTask::getCreateId,SecurityUtils.getAppUserId());
|
||||
releaseWrapper.in(FbsProjectTask::getStatus,ProjectTaskStatus.getRelease());
|
||||
Integer releaseCount = baseMapper.selectCount(releaseWrapper);
|
||||
|
||||
LambdaQueryWrapper<FbsProjectTask> completeWrapper = new LambdaQueryWrapper<>();
|
||||
completeWrapper.eq(FbsProjectTask::getCreateId,SecurityUtils.getAppUserId());
|
||||
completeWrapper.eq(FbsProjectTask::getStatus,ProjectTaskStatus.COMPLETE.getCode());
|
||||
Integer completeCount = baseMapper.selectCount(completeWrapper);
|
||||
|
||||
FbsProjectTaskListCountVO fbsProjectTaskListCountVO = new FbsProjectTaskListCountVO();
|
||||
fbsProjectTaskListCountVO.setReleaseCount(releaseCount);
|
||||
fbsProjectTaskListCountVO.setCompleteCount(completeCount);
|
||||
return fbsProjectTaskListCountVO;
|
||||
}
|
||||
|
||||
@Override
|
||||
public FbsTaskDetailWageVO fbsWage(Long id) {
|
||||
FbsTaskDetailWageVO fbsTaskDetailWageVO = new FbsTaskDetailWageVO();
|
||||
|
@ -18,6 +18,7 @@ import com.ruoyi.fbs.mapper.FbsUserMapper;
|
||||
import com.ruoyi.fbs.service.IFbsUserService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
@ -113,12 +114,14 @@ public class FbsUserServiceImpl extends ServicePlusImpl<FbsUserMapper, FbsUser>
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean authenticate(CompanyAuthenticateDTO dto) {
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public Long authenticate(CompanyAuthenticateDTO dto) {
|
||||
Company company = BeanUtil.copyProperties(dto, Company.class);
|
||||
companyService.insert(company);
|
||||
companyService.save(company);
|
||||
FbsUser fbsUser = selectUserByUserId(SecurityUtils.getAppUserId());
|
||||
fbsUser.setCompanyId(company.getId());
|
||||
return updateById(fbsUser);
|
||||
updateById(fbsUser);
|
||||
return company.getId();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -5,6 +5,7 @@ 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.baomidou.mybatisplus.extension.toolkit.SqlHelper;
|
||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.enums.AuditStatus;
|
||||
@ -15,12 +16,26 @@ import com.ruoyi.fbs.domain.FbsWageApplication;
|
||||
import com.ruoyi.fbs.domain.dto.FbsWageApplicationListDTO;
|
||||
import com.ruoyi.fbs.mapper.FbsWageApplicationMapper;
|
||||
import com.ruoyi.fbs.service.IFbsWageApplicationService;
|
||||
import com.ruoyi.zbf.domain.ZbfMessage;
|
||||
import com.ruoyi.zbf.service.IZbfMessageService;
|
||||
import com.ruoyi.zbf.service.IZbfProjectService;
|
||||
import com.ruoyi.zbf.service.IZbfProjectSubcontractingService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
import static com.ruoyi.common.constants.BgtMessageConstant.HEADLINE;
|
||||
import static com.ruoyi.common.constants.BgtMessageConstant.SUBHEADING;
|
||||
import static com.ruoyi.common.constants.FbsMessageConstant.FBS_TYPE_SETTLEMENT_TO_ZBF;
|
||||
import static com.ruoyi.common.constants.FbsMessageConstant.fbsMessage;
|
||||
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.*;
|
||||
import static com.ruoyi.common.constants.ZbfMessageConstant.ZBF_LARGE_SETTLEMENT;
|
||||
|
||||
/**
|
||||
* 分包商工资申请Service业务层处理
|
||||
*
|
||||
@ -30,6 +45,13 @@ import java.util.Map;
|
||||
@Service
|
||||
public class FbsWageApplicationServiceImpl extends ServicePlusImpl<FbsWageApplicationMapper, FbsWageApplication> implements IFbsWageApplicationService {
|
||||
|
||||
@Autowired
|
||||
private IZbfMessageService zbfMessageService;
|
||||
@Autowired
|
||||
private IZbfProjectService projectService;
|
||||
@Autowired
|
||||
private IZbfProjectSubcontractingService projectSubcontractingService;
|
||||
|
||||
@Override
|
||||
public FbsWageApplication queryById(Long id){
|
||||
return getById(id);
|
||||
@ -72,10 +94,30 @@ public class FbsWageApplicationServiceImpl extends ServicePlusImpl<FbsWageApplic
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public Boolean insert(FbsWageApplication bo) {
|
||||
FbsWageApplication add = BeanUtil.toBean(bo, FbsWageApplication.class);
|
||||
validEntityBeforeSave(add);
|
||||
return save(add);
|
||||
boolean save = save(add);
|
||||
|
||||
//分包商发消息到总包方
|
||||
HashMap<String, String> fmp = new HashMap<>();
|
||||
fmp.put("auditor", SecurityUtils.getUsername());
|
||||
fmp.put("amount", bo.getApplicantAmount().toString());
|
||||
Map<String, String> fmap = fbsMessage(fmp, FBS_TYPE_SETTLEMENT_TO_ZBF, true);
|
||||
ZbfMessage zbfMessage = new ZbfMessage()
|
||||
.setSenderType(USERTYPE_FBS)
|
||||
.setSenderId(SecurityUtils.getAppUserId())
|
||||
.setRecipientType(USERTYPE_ZBF)
|
||||
.setRecipientId(add.getReviewerId())
|
||||
.setHeadline(fmap.get(HEADLINE))
|
||||
.setSubheading(fmap.get(SUBHEADING))
|
||||
.setTableId(add.getId())
|
||||
.setTableName(SqlHelper.table(FbsWageApplication.class).getTableName())
|
||||
.setMessageLargeType(ZBF_LARGE_SETTLEMENT)
|
||||
.setIsOperation(OPERATION_NEED);
|
||||
zbfMessageService.sendAMessage(zbfMessage);
|
||||
return save;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -0,0 +1,79 @@
|
||||
package com.ruoyi.zbf.bo;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
import java.time.LocalDateTime;
|
||||
import java.time.LocalTime;
|
||||
import java.time.LocalDate;
|
||||
import lombok.EqualsAndHashCode;
|
||||
|
||||
import java.util.Date;
|
||||
|
||||
import com.ruoyi.common.core.domain.BaseEntity;
|
||||
|
||||
/**
|
||||
* 消息分页查询对象 zbf_message
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-31
|
||||
*/
|
||||
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ApiModel("消息分页查询对象")
|
||||
public class ZbfMessageQueryBo extends BaseEntity {
|
||||
|
||||
/** 分页大小 */
|
||||
@ApiModelProperty("分页大小")
|
||||
private Integer pageSize;
|
||||
/** 当前页数 */
|
||||
@ApiModelProperty("当前页数")
|
||||
private Integer pageNum;
|
||||
/** 排序列 */
|
||||
@ApiModelProperty("排序列")
|
||||
private String orderByColumn;
|
||||
/** 排序的方向desc或者asc */
|
||||
@ApiModelProperty(value = "排序的方向", example = "asc,desc")
|
||||
private String isAsc;
|
||||
|
||||
|
||||
/** 发送类型(0系统 1务工者 2包工头 3分包商 4总包方) */
|
||||
@ApiModelProperty("发送类型(0系统 1务工者 2包工头 3分包商 4总包方)")
|
||||
private String senderType;
|
||||
/** 发送人 */
|
||||
@ApiModelProperty("发送人")
|
||||
private Long senderId;
|
||||
/** 接收类型(1务工者 2包工头 3分包商 4总包方) */
|
||||
@ApiModelProperty("接收类型(1务工者 2包工头 3分包商 4总包方)")
|
||||
private String recipientType;
|
||||
/** 接收人 */
|
||||
@ApiModelProperty("接收人")
|
||||
private Long recipientId;
|
||||
/** 标题 */
|
||||
@ApiModelProperty("标题")
|
||||
private String headline;
|
||||
/** 副标题 */
|
||||
@ApiModelProperty("副标题")
|
||||
private String subheading;
|
||||
/** 表ID */
|
||||
@ApiModelProperty("表ID")
|
||||
private Long tableId;
|
||||
/** 表名 */
|
||||
@ApiModelProperty("表名")
|
||||
private String tableName;
|
||||
/** 大类型(字典bgt_message_large_type) */
|
||||
@ApiModelProperty("大类型(字典bgt_message_large_type)")
|
||||
private String messageLargeType;
|
||||
/** 小类型(字典bgt_message_small_type) */
|
||||
@ApiModelProperty("小类型(字典bgt_message_small_type)")
|
||||
private String messageSmallType;
|
||||
/** 读状态(0未读 1已读) */
|
||||
@ApiModelProperty("读状态(0未读 1已读)")
|
||||
private String readStatus;
|
||||
/** 是否需要操作(0不需要 1需要 2已操作) */
|
||||
@ApiModelProperty("是否需要操作(0不需要 1需要 2已操作)")
|
||||
private String isOperation;
|
||||
|
||||
}
|
@ -0,0 +1,97 @@
|
||||
package com.ruoyi.zbf.bo;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
import java.time.LocalDateTime;
|
||||
import java.time.LocalTime;
|
||||
import java.time.LocalDate;
|
||||
import lombok.EqualsAndHashCode;
|
||||
|
||||
import java.util.Date;
|
||||
|
||||
import com.ruoyi.common.core.domain.BaseEntity;
|
||||
|
||||
/**
|
||||
* APP总包方用户分页查询对象 zbf_user
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-31
|
||||
*/
|
||||
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@ApiModel("APP总包方用户分页查询对象")
|
||||
public class ZbfUserQueryBo extends BaseEntity {
|
||||
|
||||
/** 分页大小 */
|
||||
@ApiModelProperty("分页大小")
|
||||
private Integer pageSize;
|
||||
/** 当前页数 */
|
||||
@ApiModelProperty("当前页数")
|
||||
private Integer pageNum;
|
||||
/** 排序列 */
|
||||
@ApiModelProperty("排序列")
|
||||
private String orderByColumn;
|
||||
/** 排序的方向desc或者asc */
|
||||
@ApiModelProperty(value = "排序的方向", example = "asc,desc")
|
||||
private String isAsc;
|
||||
|
||||
|
||||
/** 唯一标识 */
|
||||
@ApiModelProperty("唯一标识")
|
||||
private Long userId;
|
||||
/** 联系电话 */
|
||||
@ApiModelProperty("联系电话")
|
||||
private String phone;
|
||||
/** 姓名 */
|
||||
@ApiModelProperty("姓名")
|
||||
private String username;
|
||||
/** 性别(0男 1女 2未知) */
|
||||
@ApiModelProperty("性别(0男 1女 2未知)")
|
||||
private String gender;
|
||||
/** 民族 */
|
||||
@ApiModelProperty("民族")
|
||||
private String nation;
|
||||
/** 出生日期 */
|
||||
@ApiModelProperty("出生日期")
|
||||
private String birthdate;
|
||||
/** 身份证号码 */
|
||||
@ApiModelProperty("身份证号码")
|
||||
private String identityCard;
|
||||
/** 所在区域 */
|
||||
@ApiModelProperty("所在区域")
|
||||
private String area;
|
||||
/** 地址 */
|
||||
@ApiModelProperty("地址")
|
||||
private String site;
|
||||
/** 银行 */
|
||||
@ApiModelProperty("银行")
|
||||
private String bank;
|
||||
/** 银行卡号 */
|
||||
@ApiModelProperty("银行卡号")
|
||||
private String cardNo;
|
||||
/** 头像地址 */
|
||||
@ApiModelProperty("头像地址")
|
||||
private String avatarName;
|
||||
/** 密码 */
|
||||
@ApiModelProperty("密码")
|
||||
private String password;
|
||||
/** 身份证正面图路径 */
|
||||
@ApiModelProperty("身份证正面图路径")
|
||||
private String frontPath;
|
||||
/** 身份证反面图路径 */
|
||||
@ApiModelProperty("身份证反面图路径")
|
||||
private String reverseSidePath;
|
||||
/** 银行卡图路径 */
|
||||
@ApiModelProperty("银行卡图路径")
|
||||
private String bankCardPath;
|
||||
/** 关联公司Id */
|
||||
@ApiModelProperty("关联公司Id")
|
||||
private Long companyId;
|
||||
/** 帐号状态(0正常 1停用) */
|
||||
@ApiModelProperty("帐号状态(0正常 1停用)")
|
||||
private String status;
|
||||
|
||||
}
|
@ -0,0 +1,108 @@
|
||||
package com.ruoyi.zbf.controller;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Arrays;
|
||||
|
||||
import com.ruoyi.zbf.domain.ZbfMessage;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import javax.validation.constraints.*;
|
||||
import org.springframework.security.access.prepost.PreAuthorize;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import com.ruoyi.common.annotation.RepeatSubmit;
|
||||
import com.ruoyi.common.annotation.Log;
|
||||
import com.ruoyi.common.core.controller.BaseController;
|
||||
import com.ruoyi.common.core.domain.AjaxResult;
|
||||
import com.ruoyi.common.enums.BusinessType;
|
||||
import com.ruoyi.zbf.bo.ZbfMessageQueryBo;
|
||||
import com.ruoyi.zbf.service.IZbfMessageService;
|
||||
import com.ruoyi.common.utils.poi.ExcelUtil;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import io.swagger.annotations.Api;
|
||||
import io.swagger.annotations.ApiOperation;
|
||||
|
||||
/**
|
||||
* 消息Controller
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-31
|
||||
*/
|
||||
@Api(value = "消息控制器", tags = {"消息管理"})
|
||||
@RequiredArgsConstructor(onConstructor_ = @Autowired)
|
||||
@RestController
|
||||
@RequestMapping("/zbf/message")
|
||||
public class ZbfMessageController extends BaseController {
|
||||
|
||||
private final IZbfMessageService iZbfMessageService;
|
||||
|
||||
/**
|
||||
* 查询消息列表
|
||||
*/
|
||||
@ApiOperation("查询消息列表")
|
||||
@PreAuthorize("@ss.hasPermi('zbf:message:list')")
|
||||
@GetMapping("/list")
|
||||
public TableDataInfo<ZbfMessage> list(@Validated ZbfMessageQueryBo bo) {
|
||||
return iZbfMessageService.queryPageList(bo);
|
||||
}
|
||||
|
||||
/**
|
||||
* 导出消息列表
|
||||
*/
|
||||
@ApiOperation("导出消息列表")
|
||||
@PreAuthorize("@ss.hasPermi('zbf:message:export')")
|
||||
@Log(title = "消息", businessType = BusinessType.EXPORT)
|
||||
@GetMapping("/export")
|
||||
public AjaxResult<ZbfMessage> export(@Validated ZbfMessageQueryBo bo) {
|
||||
List<ZbfMessage> list = iZbfMessageService.queryList(bo);
|
||||
ExcelUtil<ZbfMessage> util = new ExcelUtil<ZbfMessage>(ZbfMessage.class);
|
||||
return util.exportExcel(list, "消息");
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取消息详细信息
|
||||
*/
|
||||
@ApiOperation("获取消息详细信息")
|
||||
@PreAuthorize("@ss.hasPermi('zbf:message:query')")
|
||||
@GetMapping("/{id}")
|
||||
public AjaxResult<ZbfMessage> getInfo(@NotNull(message = "主键不能为空")
|
||||
@PathVariable("id") Long id) {
|
||||
return AjaxResult.success(iZbfMessageService.queryById(id));
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增消息
|
||||
*/
|
||||
@ApiOperation("新增消息")
|
||||
@PreAuthorize("@ss.hasPermi('zbf:message:add')")
|
||||
@Log(title = "消息", businessType = BusinessType.INSERT)
|
||||
@RepeatSubmit
|
||||
@PostMapping()
|
||||
public AjaxResult<Void> add(@Validated @RequestBody ZbfMessage bo) {
|
||||
return toAjax(iZbfMessageService.insert(bo) ? 1 : 0);
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改消息
|
||||
*/
|
||||
@ApiOperation("修改消息")
|
||||
@PreAuthorize("@ss.hasPermi('zbf:message:edit')")
|
||||
@Log(title = "消息", businessType = BusinessType.UPDATE)
|
||||
@RepeatSubmit
|
||||
@PutMapping()
|
||||
public AjaxResult<Void> edit(@Validated @RequestBody ZbfMessage bo) {
|
||||
return toAjax(iZbfMessageService.update(bo) ? 1 : 0);
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除消息
|
||||
*/
|
||||
@ApiOperation("删除消息")
|
||||
@PreAuthorize("@ss.hasPermi('zbf:message:remove')")
|
||||
@Log(title = "消息" , businessType = BusinessType.DELETE)
|
||||
@DeleteMapping("/{ids}")
|
||||
public AjaxResult<Void> remove(@NotEmpty(message = "主键不能为空")
|
||||
@PathVariable Long[] ids) {
|
||||
return toAjax(iZbfMessageService.deleteWithValidByIds(Arrays.asList(ids), true) ? 1 : 0);
|
||||
}
|
||||
}
|
133
ruoyi-system/src/main/java/com/ruoyi/zbf/domain/ZbfMessage.java
Normal file
133
ruoyi-system/src/main/java/com/ruoyi/zbf/domain/ZbfMessage.java
Normal file
@ -0,0 +1,133 @@
|
||||
package com.ruoyi.zbf.domain;
|
||||
|
||||
import com.ruoyi.common.annotation.Excel;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import lombok.Data;
|
||||
import lombok.NoArgsConstructor;
|
||||
import lombok.experimental.Accessors;
|
||||
import java.io.Serializable;
|
||||
import java.util.Date;
|
||||
import java.math.BigDecimal;
|
||||
|
||||
import java.time.LocalDateTime;
|
||||
import java.time.LocalTime;
|
||||
import java.time.LocalDate;
|
||||
|
||||
/**
|
||||
* 消息对象 zbf_message
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-31
|
||||
*/
|
||||
@Data
|
||||
@NoArgsConstructor
|
||||
@Accessors(chain = true)
|
||||
@TableName("zbf_message")
|
||||
@ApiModel("消息视图对象")
|
||||
public class ZbfMessage implements Serializable {
|
||||
|
||||
private static final long serialVersionUID=1L;
|
||||
|
||||
/** 主键自增ID */
|
||||
@ApiModelProperty("主键自增ID")
|
||||
@TableId(value = "id")
|
||||
private Long id;
|
||||
|
||||
/** 发送类型(0系统 1务工者 2包工头 3分包商 4总包方) */
|
||||
@Excel(name = "发送类型" , readConverterExp = "0=系统,1=务工者,2=包工头,3=分包商,4=总包方")
|
||||
@ApiModelProperty("发送类型(0系统 1务工者 2包工头 3分包商 4总包方)")
|
||||
private String senderType;
|
||||
|
||||
/** 发送人 */
|
||||
@Excel(name = "发送人")
|
||||
@ApiModelProperty("发送人")
|
||||
private Long senderId;
|
||||
|
||||
/** 接收类型(1务工者 2包工头 3分包商 4总包方) */
|
||||
@Excel(name = "接收类型" , readConverterExp = "1=务工者,2=包工头,3=分包商,4=总包方")
|
||||
@ApiModelProperty("接收类型(1务工者 2包工头 3分包商 4总包方)")
|
||||
private String recipientType;
|
||||
|
||||
/** 接收人 */
|
||||
@Excel(name = "接收人")
|
||||
@ApiModelProperty("接收人")
|
||||
private Long recipientId;
|
||||
|
||||
/** 标题 */
|
||||
@Excel(name = "标题")
|
||||
@ApiModelProperty("标题")
|
||||
private String headline;
|
||||
|
||||
/** 副标题 */
|
||||
@Excel(name = "副标题")
|
||||
@ApiModelProperty("副标题")
|
||||
private String subheading;
|
||||
|
||||
/** 表ID */
|
||||
@Excel(name = "表ID")
|
||||
@ApiModelProperty("表ID")
|
||||
private Long tableId;
|
||||
|
||||
/** 表名 */
|
||||
@Excel(name = "表名")
|
||||
@ApiModelProperty("表名")
|
||||
private String tableName;
|
||||
|
||||
/** 大类型(字典bgt_message_large_type) */
|
||||
@Excel(name = "大类型" , readConverterExp = "字=典bgt_message_large_type")
|
||||
@ApiModelProperty("大类型(字典bgt_message_large_type)")
|
||||
private String messageLargeType;
|
||||
|
||||
/** 小类型(字典bgt_message_small_type) */
|
||||
@Excel(name = "小类型" , readConverterExp = "字=典bgt_message_small_type")
|
||||
@ApiModelProperty("小类型(字典bgt_message_small_type)")
|
||||
private String messageSmallType;
|
||||
|
||||
/** 读状态(0未读 1已读) */
|
||||
@Excel(name = "读状态" , readConverterExp = "0=未读,1=已读")
|
||||
@ApiModelProperty("读状态(0未读 1已读)")
|
||||
private String readStatus;
|
||||
|
||||
/** 删除标志(0代表存在 2代表删除) */
|
||||
@Excel(name = "删除标志" , readConverterExp = "0=代表存在,2=代表删除")
|
||||
@ApiModelProperty("删除标志(0代表存在 2代表删除)")
|
||||
private String delFlag;
|
||||
|
||||
/** 创建者 */
|
||||
@Excel(name = "创建者")
|
||||
@ApiModelProperty("创建者")
|
||||
@TableField(fill = FieldFill.INSERT)
|
||||
private String createBy;
|
||||
|
||||
/** 创建时间 */
|
||||
@Excel(name = "创建时间" , width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
|
||||
@ApiModelProperty("创建时间")
|
||||
@TableField(fill = FieldFill.INSERT)
|
||||
private LocalDateTime createTime;
|
||||
|
||||
/** 更新者 */
|
||||
@Excel(name = "更新者")
|
||||
@ApiModelProperty("更新者")
|
||||
@TableField(fill = FieldFill.INSERT_UPDATE)
|
||||
private String updateBy;
|
||||
|
||||
/** 更新时间 */
|
||||
@Excel(name = "更新时间" , width = 30, dateFormat = "yyyy-MM-dd HH:mm:ss")
|
||||
@ApiModelProperty("更新时间")
|
||||
@TableField(fill = FieldFill.INSERT_UPDATE)
|
||||
private LocalDateTime updateTime;
|
||||
|
||||
/** 备注 */
|
||||
@Excel(name = "备注")
|
||||
@ApiModelProperty("备注")
|
||||
private String remark;
|
||||
|
||||
/** 是否需要操作(0不需要 1需要 2已操作) */
|
||||
@Excel(name = "是否需要操作" , readConverterExp = "0=不需要,1=需要,2=已操作")
|
||||
@ApiModelProperty("是否需要操作(0不需要 1需要 2已操作)")
|
||||
private String isOperation;
|
||||
|
||||
}
|
@ -0,0 +1,48 @@
|
||||
package com.ruoyi.zbf.domain.dto;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
import lombok.experimental.Accessors;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 总包方项目对象 zbf_project
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-02-17
|
||||
*/
|
||||
@Data
|
||||
@Accessors(chain = true)
|
||||
@ApiModel("总包方项目新增视图对象")
|
||||
public class ZbfProjectAddDTO {
|
||||
|
||||
@ApiModelProperty("单位名称")
|
||||
private String unitName;
|
||||
|
||||
@ApiModelProperty("统一社会信用代码")
|
||||
private String creditCode;
|
||||
|
||||
@ApiModelProperty("项目名称")
|
||||
private String projectName;
|
||||
|
||||
@ApiModelProperty("项目图片")
|
||||
private String projectImg;
|
||||
|
||||
@ApiModelProperty("项目地址")
|
||||
private String projectAddress;
|
||||
|
||||
@ApiModelProperty("联系人")
|
||||
private String contactPerson;
|
||||
|
||||
@ApiModelProperty("联系电话")
|
||||
private String contactPhone;
|
||||
|
||||
@ApiModelProperty("备注")
|
||||
private String remark;
|
||||
|
||||
@ApiModelProperty("标段列表")
|
||||
private List<ZbfProjectSectionAddDTO> sectionList;
|
||||
|
||||
}
|
@ -0,0 +1,32 @@
|
||||
package com.ruoyi.zbf.domain.dto;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
import lombok.experimental.Accessors;
|
||||
|
||||
/**
|
||||
* 总包方项目对象 zbf_project
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-02-17
|
||||
*/
|
||||
@Data
|
||||
@Accessors(chain = true)
|
||||
@ApiModel("总包方项目列表视图对象")
|
||||
public class ZbfProjectListDTO {
|
||||
|
||||
/** 分页大小 */
|
||||
@ApiModelProperty("分页大小")
|
||||
private Integer pageSize;
|
||||
/** 当前页数 */
|
||||
@ApiModelProperty("当前页数")
|
||||
private Integer pageNum;
|
||||
|
||||
@ApiModelProperty("项目名称")
|
||||
private String projectName;
|
||||
|
||||
@ApiModelProperty("项目状态(0-未开工,1-已开工,2已竣工,3已停工)")
|
||||
private String projectStatus;
|
||||
|
||||
}
|
@ -0,0 +1,30 @@
|
||||
package com.ruoyi.zbf.domain.dto;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
import lombok.experimental.Accessors;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 总包方项目标段对象 zbf_project_section
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-02-17
|
||||
*/
|
||||
@Data
|
||||
@Accessors(chain = true)
|
||||
@ApiModel("总包方项目标段新增视图对象")
|
||||
public class ZbfProjectSectionAddDTO {
|
||||
|
||||
@ApiModelProperty("标段名称")
|
||||
private String sectionName;
|
||||
|
||||
@ApiModelProperty("标段描述")
|
||||
private String sectionDescribe;
|
||||
|
||||
@ApiModelProperty("分包列表")
|
||||
private List<ZbfProjectSubcontractingAddDTO> subList;
|
||||
|
||||
}
|
@ -0,0 +1,37 @@
|
||||
package com.ruoyi.zbf.domain.dto;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
import lombok.experimental.Accessors;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
|
||||
/**
|
||||
* 总包方项目分包对象 zbf_project_subcontracting
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-02-17
|
||||
*/
|
||||
@Data
|
||||
@Accessors(chain = true)
|
||||
@ApiModel("总包方项目分包新增视图对象")
|
||||
public class ZbfProjectSubcontractingAddDTO {
|
||||
|
||||
|
||||
@ApiModelProperty("分包主题")
|
||||
private String subName;
|
||||
|
||||
@ApiModelProperty("分包描述")
|
||||
private String subDescribe;
|
||||
|
||||
@ApiModelProperty("分包金额")
|
||||
private BigDecimal subAmount;
|
||||
|
||||
@ApiModelProperty("资质要求")
|
||||
private String qualification;
|
||||
|
||||
@ApiModelProperty("备注")
|
||||
private String remark;
|
||||
|
||||
}
|
@ -0,0 +1,22 @@
|
||||
package com.ruoyi.zbf.domain.vo;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
@Data
|
||||
@ApiModel("包工头项目统计")
|
||||
public class ZbfProjectCountVO {
|
||||
|
||||
@ApiModelProperty("项目总数")
|
||||
private Integer allCount;
|
||||
|
||||
@ApiModelProperty("在建总数")
|
||||
private Integer startCount;
|
||||
|
||||
@ApiModelProperty("完成总数")
|
||||
private Integer completeCount;
|
||||
|
||||
|
||||
|
||||
}
|
@ -0,0 +1,34 @@
|
||||
package com.ruoyi.zbf.domain.vo;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Data
|
||||
@ApiModel("分包商项目列表")
|
||||
public class ZbfProjectListVO {
|
||||
|
||||
@ApiModelProperty("主键ID")
|
||||
private Long id;
|
||||
|
||||
@ApiModelProperty("项目名称")
|
||||
private String projectName;
|
||||
|
||||
@ApiModelProperty("单位名称")
|
||||
private String unitName;
|
||||
|
||||
@ApiModelProperty("项目地址")
|
||||
private String projectAddress;
|
||||
|
||||
@ApiModelProperty("项目图片")
|
||||
private String projectImg;
|
||||
|
||||
@ApiModelProperty("项目状态(0-未开工,1-已开工,2已竣工,3已停工)")
|
||||
private String projectStatus;
|
||||
|
||||
@ApiModelProperty("标段列表")
|
||||
private List<ZbfProjectSectionListVO> sectionList;
|
||||
|
||||
}
|
@ -0,0 +1,29 @@
|
||||
package com.ruoyi.zbf.domain.vo;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
@Data
|
||||
@ApiModel("分包商项目标段列表")
|
||||
public class ZbfProjectSectionListVO {
|
||||
|
||||
@ApiModelProperty("主键ID")
|
||||
private Long id;
|
||||
|
||||
@ApiModelProperty("项目ID")
|
||||
private Long projectId;
|
||||
/** 标段名称 */
|
||||
@ApiModelProperty("标段名称")
|
||||
private String sectionName;
|
||||
|
||||
@ApiModelProperty("项目地址")
|
||||
private String projectAddress;
|
||||
|
||||
@ApiModelProperty("分包列表")
|
||||
private List<ZbfProjectSubcontractingListVO> subList;
|
||||
|
||||
|
||||
}
|
@ -0,0 +1,42 @@
|
||||
package com.ruoyi.zbf.domain.vo;
|
||||
|
||||
import io.swagger.annotations.ApiModel;
|
||||
import io.swagger.annotations.ApiModelProperty;
|
||||
import lombok.Data;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
|
||||
@Data
|
||||
@ApiModel("分包商项目分包列表")
|
||||
public class ZbfProjectSubcontractingListVO {
|
||||
|
||||
|
||||
@ApiModelProperty("主键ID")
|
||||
private Long id;
|
||||
|
||||
@ApiModelProperty("项目ID")
|
||||
private Long projectId;
|
||||
|
||||
@ApiModelProperty("项目地址")
|
||||
private String projectAddress;
|
||||
|
||||
/** 标段ID */
|
||||
@ApiModelProperty("标段ID")
|
||||
private Long sectionId;
|
||||
/** 分包主题 */
|
||||
@ApiModelProperty("分包主题")
|
||||
private String subName;
|
||||
/** 分包描述 */
|
||||
@ApiModelProperty("分包描述")
|
||||
private String subDescribe;
|
||||
/** 分包金额 */
|
||||
@ApiModelProperty("分包金额")
|
||||
private BigDecimal subAmount;
|
||||
/** 资质要求 */
|
||||
@ApiModelProperty("资质要求")
|
||||
private String qualification;
|
||||
|
||||
@ApiModelProperty("申请状态(0=申请中,1=已同意,2=已拒绝,3=已取消)")
|
||||
private String applyStatus;
|
||||
|
||||
}
|
@ -0,0 +1,18 @@
|
||||
package com.ruoyi.zbf.mapper;
|
||||
|
||||
import com.ruoyi.zbf.domain.ZbfMessage;
|
||||
import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus;
|
||||
import com.ruoyi.common.core.mybatisplus.cache.MybatisPlusRedisCache;
|
||||
import org.apache.ibatis.annotations.CacheNamespace;
|
||||
|
||||
/**
|
||||
* 消息Mapper接口
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-31
|
||||
*/
|
||||
// 如使需切换数据源 请勿使用缓存 会造成数据不一致现象
|
||||
@CacheNamespace(implementation = MybatisPlusRedisCache.class, eviction = MybatisPlusRedisCache.class)
|
||||
public interface ZbfMessageMapper extends BaseMapperPlus<ZbfMessage> {
|
||||
|
||||
}
|
@ -31,4 +31,18 @@ public interface ZbfProjectMapper extends BaseMapperPlus<ZbfProject> {
|
||||
|
||||
// 查询分包商已竣工的项目列表
|
||||
Page<FbsProjectListVO> completeList(@Param("page") Page<FbsProjectListDTO> page, @Param("dto") FbsProjectListDTO dto);
|
||||
|
||||
// 查询分包商项目切换列表
|
||||
Page<FbsProjectListVO> switchList(@Param("page") Page<FbsProjectListDTO> page, @Param("dto") FbsProjectListDTO dto);
|
||||
|
||||
// 申请中的项目列表统计
|
||||
Integer applyCount(@Param("fbsUserId") Long fbsUserId);
|
||||
|
||||
// 已加入的项目列表统计
|
||||
Integer joinCount(@Param("fbsUserId") Long fbsUserId);
|
||||
|
||||
// 已竣工的项目列表统计
|
||||
Integer completeCount(@Param("fbsUserId") Long fbsUserId);
|
||||
|
||||
|
||||
}
|
||||
|
@ -0,0 +1,18 @@
|
||||
package com.ruoyi.zbf.mapper;
|
||||
|
||||
import com.ruoyi.common.core.domain.entity.ZbfUser;
|
||||
import com.ruoyi.common.core.mybatisplus.core.BaseMapperPlus;
|
||||
import com.ruoyi.common.core.mybatisplus.cache.MybatisPlusRedisCache;
|
||||
import org.apache.ibatis.annotations.CacheNamespace;
|
||||
|
||||
/**
|
||||
* APP总包方用户Mapper接口
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-31
|
||||
*/
|
||||
// 如使需切换数据源 请勿使用缓存 会造成数据不一致现象
|
||||
@CacheNamespace(implementation = MybatisPlusRedisCache.class, eviction = MybatisPlusRedisCache.class)
|
||||
public interface ZbfUserMapper extends BaseMapperPlus<ZbfUser> {
|
||||
|
||||
}
|
@ -0,0 +1,60 @@
|
||||
package com.ruoyi.zbf.service;
|
||||
|
||||
import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.zbf.bo.ZbfMessageQueryBo;
|
||||
import com.ruoyi.zbf.domain.ZbfMessage;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 消息Service接口
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-31
|
||||
*/
|
||||
public interface IZbfMessageService extends IServicePlus<ZbfMessage> {
|
||||
/**
|
||||
* 查询单个
|
||||
* @return
|
||||
*/
|
||||
ZbfMessage queryById(Long id);
|
||||
|
||||
/**
|
||||
* 查询列表
|
||||
*/
|
||||
TableDataInfo<ZbfMessage> queryPageList(ZbfMessageQueryBo bo);
|
||||
|
||||
/**
|
||||
* 查询列表
|
||||
*/
|
||||
List<ZbfMessage> queryList(ZbfMessageQueryBo bo);
|
||||
|
||||
/**
|
||||
* 根据新增业务对象插入消息
|
||||
* @param bo 消息新增业务对象
|
||||
* @return
|
||||
*/
|
||||
Boolean insert(ZbfMessage bo);
|
||||
|
||||
/**
|
||||
* 根据编辑业务对象修改消息
|
||||
* @param bo 消息编辑业务对象
|
||||
* @return
|
||||
*/
|
||||
Boolean update(ZbfMessage bo);
|
||||
|
||||
/**
|
||||
* 校验并删除数据
|
||||
* @param ids 主键集合
|
||||
* @param isValid 是否校验,true-删除前校验,false-不校验
|
||||
* @return
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
|
||||
/**
|
||||
* 发送消息
|
||||
*/
|
||||
Boolean sendAMessage(ZbfMessage bo);
|
||||
}
|
@ -5,9 +5,14 @@ import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.fbs.domain.dto.FbsProjectListDTO;
|
||||
import com.ruoyi.fbs.domain.vo.FbsProjectDetailVO;
|
||||
import com.ruoyi.fbs.domain.vo.FbsProjectListCountVO;
|
||||
import com.ruoyi.fbs.domain.vo.FbsProjectListVO;
|
||||
import com.ruoyi.zbf.bo.ZbfProjectQueryBo;
|
||||
import com.ruoyi.zbf.domain.ZbfProject;
|
||||
import com.ruoyi.zbf.domain.dto.ZbfProjectAddDTO;
|
||||
import com.ruoyi.zbf.domain.dto.ZbfProjectListDTO;
|
||||
import com.ruoyi.zbf.domain.vo.ZbfProjectCountVO;
|
||||
import com.ruoyi.zbf.domain.vo.ZbfProjectListVO;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
@ -77,6 +82,16 @@ public interface IZbfProjectService extends IServicePlus<ZbfProject> {
|
||||
*/
|
||||
TableDataInfo<FbsProjectListVO> completeList(FbsProjectListDTO dto);
|
||||
|
||||
/**
|
||||
* 分包商查询我的项目列表-项目切换
|
||||
*/
|
||||
TableDataInfo<FbsProjectListVO> switchList(FbsProjectListDTO dto);
|
||||
|
||||
/**
|
||||
* 分包商查询自己的项目列表数量统计
|
||||
*/
|
||||
FbsProjectListCountVO myListCount();
|
||||
|
||||
/**
|
||||
* 分包商查看可报名项目详情
|
||||
*/
|
||||
@ -92,4 +107,18 @@ public interface IZbfProjectService extends IServicePlus<ZbfProject> {
|
||||
*/
|
||||
FbsProjectDetailVO joinOrCompleteDetail(Long projectId);
|
||||
|
||||
/**
|
||||
* 总包方新增项目
|
||||
*/
|
||||
Boolean add(ZbfProjectAddDTO dto);
|
||||
|
||||
/**
|
||||
* 总包方查询我的项目列表
|
||||
*/
|
||||
TableDataInfo<ZbfProjectListVO> queryZbfList(ZbfProjectListDTO dto);
|
||||
|
||||
/**
|
||||
* 总包方查询自建项目统计
|
||||
*/
|
||||
ZbfProjectCountVO projectCount();
|
||||
}
|
||||
|
@ -52,4 +52,9 @@ public interface IZbfProjectSubcontractingApplyService extends IServicePlus<ZbfP
|
||||
* @return
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
|
||||
/**
|
||||
* 总包方选择分包商
|
||||
*/
|
||||
Boolean choose(Long id);
|
||||
}
|
||||
|
@ -0,0 +1,60 @@
|
||||
package com.ruoyi.zbf.service;
|
||||
|
||||
import com.ruoyi.common.core.domain.entity.ZbfUser;
|
||||
import com.ruoyi.common.core.mybatisplus.core.IServicePlus;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.zbf.bo.ZbfUserQueryBo;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* APP总包方用户Service接口
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-31
|
||||
*/
|
||||
public interface IZbfUserService extends IServicePlus<ZbfUser> {
|
||||
/**
|
||||
* 查询单个
|
||||
* @return
|
||||
*/
|
||||
ZbfUser queryById(Long id);
|
||||
|
||||
/**
|
||||
* 查询列表
|
||||
*/
|
||||
TableDataInfo<ZbfUser> queryPageList(ZbfUserQueryBo bo);
|
||||
|
||||
/**
|
||||
* 查询列表
|
||||
*/
|
||||
List<ZbfUser> queryList(ZbfUserQueryBo bo);
|
||||
|
||||
/**
|
||||
* 根据新增业务对象插入APP总包方用户
|
||||
* @param bo APP总包方用户新增业务对象
|
||||
* @return
|
||||
*/
|
||||
Boolean insert(ZbfUser bo);
|
||||
|
||||
/**
|
||||
* 根据编辑业务对象修改APP总包方用户
|
||||
* @param bo APP总包方用户编辑业务对象
|
||||
* @return
|
||||
*/
|
||||
Boolean update(ZbfUser bo);
|
||||
|
||||
/**
|
||||
* 校验并删除数据
|
||||
* @param ids 主键集合
|
||||
* @param isValid 是否校验,true-删除前校验,false-不校验
|
||||
* @return
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
|
||||
/**
|
||||
* 通过电话查询用户
|
||||
*/
|
||||
ZbfUser selectUserByPhone(String phone);
|
||||
}
|
@ -0,0 +1,99 @@
|
||||
package com.ruoyi.zbf.service.impl;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
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.common.core.mybatisplus.core.ServicePlusImpl;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.utils.PageUtils;
|
||||
import com.ruoyi.zbf.bo.ZbfMessageQueryBo;
|
||||
import com.ruoyi.zbf.domain.ZbfMessage;
|
||||
import com.ruoyi.zbf.mapper.ZbfMessageMapper;
|
||||
import com.ruoyi.zbf.service.IZbfMessageService;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* 消息Service业务层处理
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-31
|
||||
*/
|
||||
@Service
|
||||
public class ZbfMessageServiceImpl extends ServicePlusImpl<ZbfMessageMapper, ZbfMessage> implements IZbfMessageService {
|
||||
|
||||
@Override
|
||||
public ZbfMessage queryById(Long id){
|
||||
return getById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public TableDataInfo<ZbfMessage> queryPageList(ZbfMessageQueryBo bo) {
|
||||
Page<ZbfMessage> result = page(PageUtils.buildPage(), buildQueryWrapper(bo));
|
||||
return PageUtils.buildDataInfo(result);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<ZbfMessage> queryList(ZbfMessageQueryBo bo) {
|
||||
return list(buildQueryWrapper(bo));
|
||||
}
|
||||
|
||||
private LambdaQueryWrapper<ZbfMessage> buildQueryWrapper(ZbfMessageQueryBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<ZbfMessage> lqw = Wrappers.lambdaQuery();
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getSenderType()), ZbfMessage::getSenderType, bo.getSenderType());
|
||||
lqw.eq(bo.getSenderId() != null, ZbfMessage::getSenderId, bo.getSenderId());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getRecipientType()), ZbfMessage::getRecipientType, bo.getRecipientType());
|
||||
lqw.eq(bo.getRecipientId() != null, ZbfMessage::getRecipientId, bo.getRecipientId());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getHeadline()), ZbfMessage::getHeadline, bo.getHeadline());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getSubheading()), ZbfMessage::getSubheading, bo.getSubheading());
|
||||
lqw.eq(bo.getTableId() != null, ZbfMessage::getTableId, bo.getTableId());
|
||||
lqw.like(StrUtil.isNotBlank(bo.getTableName()), ZbfMessage::getTableName, bo.getTableName());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getMessageLargeType()), ZbfMessage::getMessageLargeType, bo.getMessageLargeType());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getMessageSmallType()), ZbfMessage::getMessageSmallType, bo.getMessageSmallType());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getReadStatus()), ZbfMessage::getReadStatus, bo.getReadStatus());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getIsOperation()), ZbfMessage::getIsOperation, bo.getIsOperation());
|
||||
return lqw;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean insert(ZbfMessage bo) {
|
||||
ZbfMessage add = BeanUtil.toBean(bo, ZbfMessage.class);
|
||||
validEntityBeforeSave(add);
|
||||
return save(add);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean update(ZbfMessage bo) {
|
||||
ZbfMessage update = BeanUtil.toBean(bo, ZbfMessage.class);
|
||||
validEntityBeforeSave(update);
|
||||
return updateById(update);
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*
|
||||
* @param entity 实体类数据
|
||||
*/
|
||||
private void validEntityBeforeSave(ZbfMessage entity){
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if(isValid){
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return removeByIds(ids);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean sendAMessage(ZbfMessage bo) {
|
||||
return save(bo);
|
||||
}
|
||||
}
|
@ -113,6 +113,7 @@ public class ZbfProjectSectionServiceImpl extends ServicePlusImpl<ZbfProjectSect
|
||||
for (ZbfProjectSubcontracting sub : subList){
|
||||
FbsProjectSubcontractingListVO fbsProjectSubcontractingListVO = new FbsProjectSubcontractingListVO();
|
||||
BeanUtil.copyProperties(sub, fbsProjectSubcontractingListVO);
|
||||
fbsProjectSubcontractingListVO.setProjectAddress(sectionListVO.getProjectAddress());
|
||||
subListVO.add(fbsProjectSubcontractingListVO);
|
||||
}
|
||||
sectionListVO.setSubList(subListVO);
|
||||
|
@ -8,19 +8,25 @@ 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.enums.ProjectStatus;
|
||||
import com.ruoyi.common.enums.SubcontractingApplyStatus;
|
||||
import com.ruoyi.common.utils.PageUtils;
|
||||
import com.ruoyi.common.utils.SecurityUtils;
|
||||
import com.ruoyi.fbs.domain.dto.FbsProjectListDTO;
|
||||
import com.ruoyi.fbs.domain.vo.FbsProjectDetailVO;
|
||||
import com.ruoyi.fbs.domain.vo.FbsProjectListVO;
|
||||
import com.ruoyi.fbs.domain.vo.FbsProjectSectionListVO;
|
||||
import com.ruoyi.fbs.domain.vo.FbsProjectSubcontractingListVO;
|
||||
import com.ruoyi.fbs.domain.vo.*;
|
||||
import com.ruoyi.zbf.bo.ZbfProjectQueryBo;
|
||||
import com.ruoyi.zbf.domain.ZbfProject;
|
||||
import com.ruoyi.zbf.domain.ZbfProjectSection;
|
||||
import com.ruoyi.zbf.domain.ZbfProjectSubcontracting;
|
||||
import com.ruoyi.zbf.domain.ZbfProjectSubcontractingApply;
|
||||
import com.ruoyi.zbf.domain.dto.ZbfProjectAddDTO;
|
||||
import com.ruoyi.zbf.domain.dto.ZbfProjectListDTO;
|
||||
import com.ruoyi.zbf.domain.dto.ZbfProjectSectionAddDTO;
|
||||
import com.ruoyi.zbf.domain.dto.ZbfProjectSubcontractingAddDTO;
|
||||
import com.ruoyi.zbf.domain.vo.ZbfProjectCountVO;
|
||||
import com.ruoyi.zbf.domain.vo.ZbfProjectListVO;
|
||||
import com.ruoyi.zbf.domain.vo.ZbfProjectSectionListVO;
|
||||
import com.ruoyi.zbf.domain.vo.ZbfProjectSubcontractingListVO;
|
||||
import com.ruoyi.zbf.mapper.ZbfProjectMapper;
|
||||
import com.ruoyi.zbf.service.IZbfProjectSectionService;
|
||||
import com.ruoyi.zbf.service.IZbfProjectService;
|
||||
@ -28,11 +34,9 @@ import com.ruoyi.zbf.service.IZbfProjectSubcontractingApplyService;
|
||||
import com.ruoyi.zbf.service.IZbfProjectSubcontractingService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.*;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
@ -47,70 +51,70 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
@Autowired
|
||||
private IZbfProjectSectionService zbfProjectSectionService;
|
||||
@Autowired
|
||||
private IZbfProjectSubcontractingService zbfProjectSubcontractingService;
|
||||
private IZbfProjectSubcontractingService zbfProjectSubcontractingService;
|
||||
@Autowired
|
||||
private IZbfProjectSubcontractingApplyService zbfProjectSubcontractingApplyService;
|
||||
|
||||
@Override
|
||||
public ZbfProject queryById(Long id){
|
||||
return getById(id);
|
||||
}
|
||||
@Override
|
||||
public ZbfProject queryById(Long id) {
|
||||
return getById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public TableDataInfo<ZbfProject> queryPageList(ZbfProjectQueryBo bo) {
|
||||
Page<ZbfProject> result = page(PageUtils.buildPage(), buildQueryWrapper(bo));
|
||||
return PageUtils.buildDataInfo(result);
|
||||
}
|
||||
@Override
|
||||
public TableDataInfo<ZbfProject> queryPageList(ZbfProjectQueryBo bo) {
|
||||
Page<ZbfProject> result = page(PageUtils.buildPage(), buildQueryWrapper(bo));
|
||||
return PageUtils.buildDataInfo(result);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<ZbfProject> queryList(ZbfProjectQueryBo bo) {
|
||||
return list(buildQueryWrapper(bo));
|
||||
}
|
||||
@Override
|
||||
public List<ZbfProject> queryList(ZbfProjectQueryBo bo) {
|
||||
return list(buildQueryWrapper(bo));
|
||||
}
|
||||
|
||||
private LambdaQueryWrapper<ZbfProject> buildQueryWrapper(ZbfProjectQueryBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<ZbfProject> lqw = Wrappers.lambdaQuery();
|
||||
lqw.eq(bo.getUserId() != null, ZbfProject::getUserId, bo.getUserId());
|
||||
lqw.like(StrUtil.isNotBlank(bo.getUnitName()), ZbfProject::getUnitName, bo.getUnitName());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getCreditCode()), ZbfProject::getCreditCode, bo.getCreditCode());
|
||||
lqw.like(StrUtil.isNotBlank(bo.getProjectName()), ZbfProject::getProjectName, bo.getProjectName());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getProjectImg()), ZbfProject::getProjectImg, bo.getProjectImg());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getProjectAddress()), ZbfProject::getProjectAddress, bo.getProjectAddress());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getContactPerson()), ZbfProject::getContactPerson, bo.getContactPerson());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getContactPhone()), ZbfProject::getContactPhone, bo.getContactPhone());
|
||||
return lqw;
|
||||
}
|
||||
private LambdaQueryWrapper<ZbfProject> buildQueryWrapper(ZbfProjectQueryBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<ZbfProject> lqw = Wrappers.lambdaQuery();
|
||||
lqw.eq(bo.getUserId() != null, ZbfProject::getUserId, bo.getUserId());
|
||||
lqw.like(StrUtil.isNotBlank(bo.getUnitName()), ZbfProject::getUnitName, bo.getUnitName());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getCreditCode()), ZbfProject::getCreditCode, bo.getCreditCode());
|
||||
lqw.like(StrUtil.isNotBlank(bo.getProjectName()), ZbfProject::getProjectName, bo.getProjectName());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getProjectImg()), ZbfProject::getProjectImg, bo.getProjectImg());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getProjectAddress()), ZbfProject::getProjectAddress, bo.getProjectAddress());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getContactPerson()), ZbfProject::getContactPerson, bo.getContactPerson());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getContactPhone()), ZbfProject::getContactPhone, bo.getContactPhone());
|
||||
return lqw;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean insert(ZbfProject bo) {
|
||||
ZbfProject add = BeanUtil.toBean(bo, ZbfProject.class);
|
||||
validEntityBeforeSave(add);
|
||||
return save(add);
|
||||
}
|
||||
@Override
|
||||
public Boolean insert(ZbfProject bo) {
|
||||
ZbfProject add = BeanUtil.toBean(bo, ZbfProject.class);
|
||||
validEntityBeforeSave(add);
|
||||
return save(add);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean update(ZbfProject bo) {
|
||||
ZbfProject update = BeanUtil.toBean(bo, ZbfProject.class);
|
||||
validEntityBeforeSave(update);
|
||||
return updateById(update);
|
||||
}
|
||||
@Override
|
||||
public Boolean update(ZbfProject bo) {
|
||||
ZbfProject update = BeanUtil.toBean(bo, ZbfProject.class);
|
||||
validEntityBeforeSave(update);
|
||||
return updateById(update);
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*
|
||||
* @param entity 实体类数据
|
||||
*/
|
||||
private void validEntityBeforeSave(ZbfProject entity){
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
}
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*
|
||||
* @param entity 实体类数据
|
||||
*/
|
||||
private void validEntityBeforeSave(ZbfProject entity) {
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if(isValid){
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return removeByIds(ids);
|
||||
}
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if (isValid) {
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return removeByIds(ids);
|
||||
}
|
||||
|
||||
@Override
|
||||
public TableDataInfo<FbsProjectListVO> signUpList(FbsProjectListDTO dto) {
|
||||
@ -121,34 +125,44 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
Page<FbsProjectListVO> queryVOPage = baseMapper.signUpList(queryDTOPage, dto);
|
||||
//处理标段和分包
|
||||
for (FbsProjectListVO fbsProjectListVO : queryVOPage.getRecords()) {
|
||||
Long projectId = fbsProjectListVO.getId();
|
||||
Long projectId = fbsProjectListVO.getId();
|
||||
//查询项目下的所有申请
|
||||
List<ZbfProjectSubcontractingApply> applyList = zbfProjectSubcontractingApplyService.list(Wrappers.<ZbfProjectSubcontractingApply>lambdaQuery()
|
||||
.eq(ZbfProjectSubcontractingApply::getProjectId, projectId).eq(ZbfProjectSubcontractingApply::getFbsUserId, SecurityUtils.getAppUserId()));
|
||||
List<Long> applyIds = applyList.stream().map(ZbfProjectSubcontractingApply::getSubId).collect(Collectors.toList());
|
||||
.eq(ZbfProjectSubcontractingApply::getProjectId, projectId)
|
||||
.eq(ZbfProjectSubcontractingApply::getFbsUserId, SecurityUtils.getAppUserId()));
|
||||
HashMap<Long, String> map = applyList.stream()
|
||||
.collect(Collectors.toMap(
|
||||
ZbfProjectSubcontractingApply::getSubId,
|
||||
ZbfProjectSubcontractingApply::getApplyStatus,
|
||||
(existing, replacement) -> replacement,
|
||||
HashMap::new
|
||||
));
|
||||
|
||||
//标段处理
|
||||
List<FbsProjectSectionListVO> sectionListVO = new ArrayList<>();
|
||||
//查询项目下的所有标段
|
||||
List<ZbfProjectSection> sectionList = zbfProjectSectionService.list(Wrappers.<ZbfProjectSection>lambdaQuery()
|
||||
.eq(ZbfProjectSection::getProjectId, projectId));
|
||||
for (ZbfProjectSection zbfProjectSection : sectionList){
|
||||
for (ZbfProjectSection zbfProjectSection : sectionList) {
|
||||
//分包处理
|
||||
List<FbsProjectSubcontractingListVO> subListVO = new ArrayList<>();
|
||||
//查询标段下的所有未承接的分包
|
||||
//查询标段下的所有的分包
|
||||
List<ZbfProjectSubcontracting> subList = zbfProjectSubcontractingService.list(Wrappers.<ZbfProjectSubcontracting>lambdaQuery()
|
||||
.eq(ZbfProjectSubcontracting::getSectionId, zbfProjectSection.getId())
|
||||
.isNull(ZbfProjectSubcontracting::getUserId));
|
||||
.eq(ZbfProjectSubcontracting::getSectionId, zbfProjectSection.getId())
|
||||
//.isNull(ZbfProjectSubcontracting::getUserId)
|
||||
);
|
||||
//排除掉已申请的分包
|
||||
for (ZbfProjectSubcontracting sub : subList){
|
||||
if(applyIds.contains(sub.getId())){
|
||||
continue;
|
||||
}
|
||||
for (ZbfProjectSubcontracting sub : subList) {
|
||||
FbsProjectSubcontractingListVO fbsProjectSubcontractingListVO = new FbsProjectSubcontractingListVO();
|
||||
BeanUtil.copyProperties(sub, fbsProjectSubcontractingListVO);
|
||||
String applyStatus = map.get(sub.getId());
|
||||
fbsProjectSubcontractingListVO.setApplyStatus(applyStatus);
|
||||
if (sub.getUserId() != null && !sub.getUserId().equals(SecurityUtils.getAppUserId())) {
|
||||
fbsProjectSubcontractingListVO.setApplyStatus(SubcontractingApplyStatus.CHOOSE.getCode());
|
||||
}
|
||||
subListVO.add(fbsProjectSubcontractingListVO);
|
||||
}
|
||||
if(CollectionUtil.isEmpty(subListVO)){
|
||||
if (CollectionUtil.isEmpty(subListVO)) {
|
||||
continue;
|
||||
}
|
||||
FbsProjectSectionListVO fbsProjectSectionListVO = new FbsProjectSectionListVO();
|
||||
@ -158,7 +172,7 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
sectionListVO.add(fbsProjectSectionListVO);
|
||||
}
|
||||
fbsProjectListVO.setSectionList(sectionListVO);
|
||||
}
|
||||
}
|
||||
return PageUtils.buildDataInfo(queryVOPage);
|
||||
}
|
||||
|
||||
@ -172,7 +186,7 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
Page<FbsProjectListVO> queryVOPage = baseMapper.applyList(queryDTOPage, dto);
|
||||
//处理标段和分包
|
||||
for (FbsProjectListVO fbsProjectListVO : queryVOPage.getRecords()) {
|
||||
Long projectId = fbsProjectListVO.getId();
|
||||
Long projectId = fbsProjectListVO.getId();
|
||||
//查询项目下的所有已申请和已拒绝申请
|
||||
List<ZbfProjectSubcontractingApply> applyList = zbfProjectSubcontractingApplyService.list(Wrappers.<ZbfProjectSubcontractingApply>lambdaQuery()
|
||||
.eq(ZbfProjectSubcontractingApply::getProjectId, projectId)
|
||||
@ -185,22 +199,22 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
//查询项目下的所有标段
|
||||
List<ZbfProjectSection> sectionList = zbfProjectSectionService.list(Wrappers.<ZbfProjectSection>lambdaQuery()
|
||||
.eq(ZbfProjectSection::getProjectId, projectId));
|
||||
for (ZbfProjectSection zbfProjectSection : sectionList){
|
||||
for (ZbfProjectSection zbfProjectSection : sectionList) {
|
||||
//分包处理
|
||||
List<FbsProjectSubcontractingListVO> subListVO = new ArrayList<>();
|
||||
//查询标段下的所有的分包
|
||||
List<ZbfProjectSubcontracting> subList = zbfProjectSubcontractingService.list(Wrappers.<ZbfProjectSubcontracting>lambdaQuery()
|
||||
.eq(ZbfProjectSubcontracting::getSectionId, zbfProjectSection.getId()));
|
||||
//排除掉未申请和已同意的分包
|
||||
for (ZbfProjectSubcontracting sub : subList){
|
||||
if(!applyIds.contains(sub.getId())){
|
||||
for (ZbfProjectSubcontracting sub : subList) {
|
||||
if (!applyIds.contains(sub.getId())) {
|
||||
continue;
|
||||
}
|
||||
FbsProjectSubcontractingListVO fbsProjectSubcontractingListVO = new FbsProjectSubcontractingListVO();
|
||||
BeanUtil.copyProperties(sub, fbsProjectSubcontractingListVO);
|
||||
subListVO.add(fbsProjectSubcontractingListVO);
|
||||
}
|
||||
if(CollectionUtil.isEmpty(subListVO)){
|
||||
if (CollectionUtil.isEmpty(subListVO)) {
|
||||
continue;
|
||||
}
|
||||
FbsProjectSectionListVO fbsProjectSectionListVO = new FbsProjectSectionListVO();
|
||||
@ -223,7 +237,7 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
Page<FbsProjectListVO> queryVOPage = baseMapper.joinList(queryDTOPage, dto);
|
||||
//处理标段和分包
|
||||
for (FbsProjectListVO fbsProjectListVO : queryVOPage.getRecords()) {
|
||||
Long projectId = fbsProjectListVO.getId();
|
||||
Long projectId = fbsProjectListVO.getId();
|
||||
fbsProjectListVO.setSectionList(handleSection(projectId));
|
||||
}
|
||||
return PageUtils.buildDataInfo(queryVOPage);
|
||||
@ -238,12 +252,32 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
Page<FbsProjectListVO> queryVOPage = baseMapper.completeList(queryDTOPage, dto);
|
||||
//处理标段和分包
|
||||
for (FbsProjectListVO fbsProjectListVO : queryVOPage.getRecords()) {
|
||||
Long projectId = fbsProjectListVO.getId();
|
||||
Long projectId = fbsProjectListVO.getId();
|
||||
fbsProjectListVO.setSectionList(handleSection(projectId));
|
||||
}
|
||||
return PageUtils.buildDataInfo(queryVOPage);
|
||||
}
|
||||
|
||||
@Override
|
||||
public TableDataInfo<FbsProjectListVO> switchList(FbsProjectListDTO dto) {
|
||||
Page<FbsProjectListDTO> queryDTOPage = new Page<>();
|
||||
queryDTOPage.setCurrent(dto.getPageNum());
|
||||
queryDTOPage.setSize(dto.getPageSize());
|
||||
dto.setFbsUserId(SecurityUtils.getAppUserId());
|
||||
Page<FbsProjectListVO> queryVOPage = baseMapper.switchList(queryDTOPage, dto);
|
||||
return PageUtils.buildDataInfo(queryVOPage);
|
||||
}
|
||||
|
||||
@Override
|
||||
public FbsProjectListCountVO myListCount() {
|
||||
FbsProjectListCountVO fbsProjectListCountVO = new FbsProjectListCountVO();
|
||||
Long appUserId = SecurityUtils.getAppUserId();
|
||||
fbsProjectListCountVO.setApplyCount(baseMapper.applyCount(appUserId));
|
||||
fbsProjectListCountVO.setJoinCount(baseMapper.joinCount(appUserId));
|
||||
fbsProjectListCountVO.setCompleteCount(baseMapper.completeCount(appUserId));
|
||||
return fbsProjectListCountVO;
|
||||
}
|
||||
|
||||
@Override
|
||||
public FbsProjectDetailVO signUpDetail(Long projectId) {
|
||||
ZbfProject byId = getById(projectId);
|
||||
@ -251,31 +285,41 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
|
||||
//查询项目下的所有申请
|
||||
List<ZbfProjectSubcontractingApply> applyList = zbfProjectSubcontractingApplyService.list(Wrappers.<ZbfProjectSubcontractingApply>lambdaQuery()
|
||||
.eq(ZbfProjectSubcontractingApply::getProjectId, projectId).eq(ZbfProjectSubcontractingApply::getFbsUserId, SecurityUtils.getAppUserId()));
|
||||
List<Long> applyIds = applyList.stream().map(ZbfProjectSubcontractingApply::getSubId).collect(Collectors.toList());
|
||||
|
||||
.eq(ZbfProjectSubcontractingApply::getProjectId, projectId)
|
||||
.eq(ZbfProjectSubcontractingApply::getFbsUserId, SecurityUtils.getAppUserId()));
|
||||
HashMap<Long, String> map = applyList.stream()
|
||||
.collect(Collectors.toMap(
|
||||
ZbfProjectSubcontractingApply::getSubId,
|
||||
ZbfProjectSubcontractingApply::getApplyStatus,
|
||||
(existing, replacement) -> replacement,
|
||||
HashMap::new
|
||||
));
|
||||
//标段处理
|
||||
List<FbsProjectSectionListVO> sectionListVO = new ArrayList<>();
|
||||
//查询项目下的所有标段
|
||||
List<ZbfProjectSection> sectionList = zbfProjectSectionService.list(Wrappers.<ZbfProjectSection>lambdaQuery()
|
||||
.eq(ZbfProjectSection::getProjectId, projectId));
|
||||
for (ZbfProjectSection zbfProjectSection : sectionList){
|
||||
for (ZbfProjectSection zbfProjectSection : sectionList) {
|
||||
//分包处理
|
||||
List<FbsProjectSubcontractingListVO> subListVO = new ArrayList<>();
|
||||
//查询标段下的所有未承接的分包
|
||||
//查询标段下的所有的分包
|
||||
List<ZbfProjectSubcontracting> subList = zbfProjectSubcontractingService.list(Wrappers.<ZbfProjectSubcontracting>lambdaQuery()
|
||||
.eq(ZbfProjectSubcontracting::getSectionId, zbfProjectSection.getId())
|
||||
.isNull(ZbfProjectSubcontracting::getUserId));
|
||||
.eq(ZbfProjectSubcontracting::getSectionId, zbfProjectSection.getId())
|
||||
//.isNull(ZbfProjectSubcontracting::getUserId)
|
||||
);
|
||||
//排除掉已申请的分包
|
||||
for (ZbfProjectSubcontracting sub : subList){
|
||||
if(applyIds.contains(sub.getId())){
|
||||
continue;
|
||||
}
|
||||
for (ZbfProjectSubcontracting sub : subList) {
|
||||
|
||||
FbsProjectSubcontractingListVO fbsProjectSubcontractingListVO = new FbsProjectSubcontractingListVO();
|
||||
BeanUtil.copyProperties(sub, fbsProjectSubcontractingListVO);
|
||||
String applyStatus = map.get(sub.getId());
|
||||
fbsProjectSubcontractingListVO.setApplyStatus(applyStatus);
|
||||
if (sub.getUserId() != null && !sub.getUserId().equals(SecurityUtils.getAppUserId())) {
|
||||
fbsProjectSubcontractingListVO.setApplyStatus(SubcontractingApplyStatus.CHOOSE.getCode());
|
||||
}
|
||||
subListVO.add(fbsProjectSubcontractingListVO);
|
||||
}
|
||||
if(CollectionUtil.isEmpty(subListVO)){
|
||||
if (CollectionUtil.isEmpty(subListVO)) {
|
||||
continue;
|
||||
}
|
||||
FbsProjectSectionListVO fbsProjectSectionListVO = new FbsProjectSectionListVO();
|
||||
@ -304,22 +348,22 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
//查询项目下的所有标段
|
||||
List<ZbfProjectSection> sectionList = zbfProjectSectionService.list(Wrappers.<ZbfProjectSection>lambdaQuery()
|
||||
.eq(ZbfProjectSection::getProjectId, projectId));
|
||||
for (ZbfProjectSection zbfProjectSection : sectionList){
|
||||
for (ZbfProjectSection zbfProjectSection : sectionList) {
|
||||
//分包处理
|
||||
List<FbsProjectSubcontractingListVO> subListVO = new ArrayList<>();
|
||||
//查询标段下的所有的分包
|
||||
List<ZbfProjectSubcontracting> subList = zbfProjectSubcontractingService.list(Wrappers.<ZbfProjectSubcontracting>lambdaQuery()
|
||||
.eq(ZbfProjectSubcontracting::getSectionId, zbfProjectSection.getId()));
|
||||
//排除掉未申请和已同意的分包
|
||||
for (ZbfProjectSubcontracting sub : subList){
|
||||
if(!applyIds.contains(sub.getId())){
|
||||
for (ZbfProjectSubcontracting sub : subList) {
|
||||
if (!applyIds.contains(sub.getId())) {
|
||||
continue;
|
||||
}
|
||||
FbsProjectSubcontractingListVO fbsProjectSubcontractingListVO = new FbsProjectSubcontractingListVO();
|
||||
BeanUtil.copyProperties(sub, fbsProjectSubcontractingListVO);
|
||||
subListVO.add(fbsProjectSubcontractingListVO);
|
||||
}
|
||||
if(CollectionUtil.isEmpty(subListVO)){
|
||||
if (CollectionUtil.isEmpty(subListVO)) {
|
||||
continue;
|
||||
}
|
||||
FbsProjectSectionListVO fbsProjectSectionListVO = new FbsProjectSectionListVO();
|
||||
@ -350,7 +394,7 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
//查询项目下的所有标段
|
||||
List<ZbfProjectSection> sectionList = zbfProjectSectionService.list(Wrappers.<ZbfProjectSection>lambdaQuery()
|
||||
.eq(ZbfProjectSection::getProjectId, projectId));
|
||||
for (ZbfProjectSection zbfProjectSection : sectionList){
|
||||
for (ZbfProjectSection zbfProjectSection : sectionList) {
|
||||
//分包处理
|
||||
List<FbsProjectSubcontractingListVO> subListVO = new ArrayList<>();
|
||||
//查询标段下的所有已承接的分包
|
||||
@ -358,12 +402,12 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
.eq(ZbfProjectSubcontracting::getSectionId, zbfProjectSection.getId())
|
||||
.eq(ZbfProjectSubcontracting::getUserId, SecurityUtils.getAppUserId()));
|
||||
|
||||
for (ZbfProjectSubcontracting sub : subList){
|
||||
for (ZbfProjectSubcontracting sub : subList) {
|
||||
FbsProjectSubcontractingListVO fbsProjectSubcontractingListVO = new FbsProjectSubcontractingListVO();
|
||||
BeanUtil.copyProperties(sub, fbsProjectSubcontractingListVO);
|
||||
subListVO.add(fbsProjectSubcontractingListVO);
|
||||
}
|
||||
if(CollectionUtil.isEmpty(subListVO)){
|
||||
if (CollectionUtil.isEmpty(subListVO)) {
|
||||
continue;
|
||||
}
|
||||
FbsProjectSectionListVO fbsProjectSectionListVO = new FbsProjectSectionListVO();
|
||||
@ -374,4 +418,79 @@ public class ZbfProjectServiceImpl extends ServicePlusImpl<ZbfProjectMapper, Zbf
|
||||
}
|
||||
return sectionListVO;
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public Boolean add(ZbfProjectAddDTO dto) {
|
||||
ZbfProject project = BeanUtil.copyProperties(dto, ZbfProject.class);
|
||||
project.setUserId(SecurityUtils.getAppUserId());
|
||||
boolean save = save(project);
|
||||
|
||||
for (ZbfProjectSectionAddDTO section : dto.getSectionList()) {
|
||||
ZbfProjectSection projectSection = BeanUtil.copyProperties(section, ZbfProjectSection.class);
|
||||
projectSection.setProjectId(project.getId());
|
||||
zbfProjectSectionService.save(projectSection);
|
||||
List<ZbfProjectSubcontracting> addList = new ArrayList<>();
|
||||
for (ZbfProjectSubcontractingAddDTO sub : section.getSubList()) {
|
||||
ZbfProjectSubcontracting projectSubcontracting = BeanUtil.copyProperties(sub, ZbfProjectSubcontracting.class);
|
||||
projectSubcontracting.setProjectId(project.getId());
|
||||
projectSubcontracting.setSectionId(projectSection.getId());
|
||||
addList.add(projectSubcontracting);
|
||||
}
|
||||
zbfProjectSubcontractingService.saveBatch(addList);
|
||||
}
|
||||
return save;
|
||||
}
|
||||
|
||||
@Override
|
||||
public TableDataInfo<ZbfProjectListVO> queryZbfList(ZbfProjectListDTO dto) {
|
||||
LambdaQueryWrapper<ZbfProject> wrapper = new LambdaQueryWrapper<>();
|
||||
wrapper.eq(ZbfProject::getUserId, SecurityUtils.getAppUserId());
|
||||
wrapper.like(StrUtil.isNotBlank(dto.getProjectName()), ZbfProject::getProjectName, dto.getProjectName());
|
||||
|
||||
Page<ZbfProject> result = page(PageUtils.buildPage(), wrapper);
|
||||
List<ZbfProjectListVO> zbfProjectListVOS = BeanUtil.copyToList(result.getRecords(), ZbfProjectListVO.class);
|
||||
|
||||
for (ZbfProjectListVO zbfProjectListVO : zbfProjectListVOS){
|
||||
//标段处理
|
||||
List<ZbfProjectSectionListVO> sectionListVO = new ArrayList<>();
|
||||
//查询项目下的所有标段
|
||||
List<ZbfProjectSection> sectionList = zbfProjectSectionService.list(Wrappers.<ZbfProjectSection>lambdaQuery()
|
||||
.eq(ZbfProjectSection::getProjectId, zbfProjectListVO.getId()));
|
||||
for (ZbfProjectSection zbfProjectSection : sectionList) {
|
||||
//分包处理
|
||||
List<ZbfProjectSubcontractingListVO> subListVO = new ArrayList<>();
|
||||
//查询标段下的所有的分包
|
||||
List<ZbfProjectSubcontracting> subList = zbfProjectSubcontractingService.list(Wrappers.<ZbfProjectSubcontracting>lambdaQuery()
|
||||
.eq(ZbfProjectSubcontracting::getSectionId, zbfProjectSection.getId()));
|
||||
|
||||
ZbfProjectSectionListVO zbfProjectSectionListVO = new ZbfProjectSectionListVO();
|
||||
BeanUtil.copyProperties(zbfProjectSection, zbfProjectSectionListVO);
|
||||
zbfProjectSectionListVO.setSubList(subListVO);
|
||||
sectionListVO.add(zbfProjectSectionListVO);
|
||||
}
|
||||
zbfProjectListVO.setSectionList(sectionListVO);
|
||||
}
|
||||
|
||||
Page<ZbfProjectListVO> zbfProjectListVOPage = new Page<>();
|
||||
zbfProjectListVOPage.setTotal(result.getTotal());
|
||||
zbfProjectListVOPage.setRecords(zbfProjectListVOS);
|
||||
|
||||
return PageUtils.buildDataInfo(zbfProjectListVOPage);
|
||||
}
|
||||
|
||||
@Override
|
||||
public ZbfProjectCountVO projectCount() {
|
||||
ZbfProjectCountVO zbfProjectCountVO = new ZbfProjectCountVO();
|
||||
|
||||
LambdaQueryWrapper<ZbfProject> wrapper = new LambdaQueryWrapper<>();
|
||||
wrapper.eq(ZbfProject::getUserId, SecurityUtils.getAppUserId());
|
||||
List<ZbfProject> list = list(wrapper);
|
||||
zbfProjectCountVO.setAllCount(list.size());
|
||||
long startCount = list.stream().filter(zbfProject -> StrUtil.equals(zbfProject.getProjectStatus(), ProjectStatus.START.getCode())).count();
|
||||
long completeCcount = list.stream().filter(zbfProject -> StrUtil.equals(zbfProject.getProjectStatus(), ProjectStatus.COMPLETE.getCode())).count();
|
||||
zbfProjectCountVO.setStartCount((int) startCount);
|
||||
zbfProjectCountVO.setCompleteCount((int) completeCcount);
|
||||
return zbfProjectCountVO;
|
||||
}
|
||||
}
|
||||
|
@ -1,23 +1,43 @@
|
||||
package com.ruoyi.zbf.service.impl;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import cn.hutool.core.collection.CollectionUtil;
|
||||
import cn.hutool.core.util.StrUtil;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.ruoyi.common.utils.PageUtils;
|
||||
import com.ruoyi.common.core.page.PagePlus;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import org.springframework.stereotype.Service;
|
||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||
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.baomidou.mybatisplus.extension.toolkit.SqlHelper;
|
||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.enums.ProjectStatus;
|
||||
import com.ruoyi.common.enums.SubcontractingApplyStatus;
|
||||
import com.ruoyi.common.enums.TaskApplyStatus;
|
||||
import com.ruoyi.common.exception.BaseException;
|
||||
import com.ruoyi.common.utils.PageUtils;
|
||||
import com.ruoyi.common.utils.SecurityUtils;
|
||||
import com.ruoyi.fbs.domain.FbsMessage;
|
||||
import com.ruoyi.fbs.service.IFbsMessageService;
|
||||
import com.ruoyi.zbf.bo.ZbfProjectSubcontractingApplyQueryBo;
|
||||
import com.ruoyi.zbf.domain.ZbfMessage;
|
||||
import com.ruoyi.zbf.domain.ZbfProject;
|
||||
import com.ruoyi.zbf.domain.ZbfProjectSubcontracting;
|
||||
import com.ruoyi.zbf.domain.ZbfProjectSubcontractingApply;
|
||||
import com.ruoyi.zbf.mapper.ZbfProjectSubcontractingApplyMapper;
|
||||
import com.ruoyi.zbf.service.IZbfMessageService;
|
||||
import com.ruoyi.zbf.service.IZbfProjectService;
|
||||
import com.ruoyi.zbf.service.IZbfProjectSubcontractingApplyService;
|
||||
import com.ruoyi.zbf.service.IZbfProjectSubcontractingService;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Collection;
|
||||
import java.util.*;
|
||||
|
||||
import static com.ruoyi.common.constants.BgtMessageConstant.HEADLINE;
|
||||
import static com.ruoyi.common.constants.BgtMessageConstant.SUBHEADING;
|
||||
import static com.ruoyi.common.constants.FbsMessageConstant.*;
|
||||
import static com.ruoyi.common.constants.WgzAndBgtMessageConstant.*;
|
||||
import static com.ruoyi.common.constants.ZbfMessageConstant.*;
|
||||
|
||||
/**
|
||||
* 总包方项目分包申请Service业务层处理
|
||||
@ -28,6 +48,16 @@ import java.util.Collection;
|
||||
@Service
|
||||
public class ZbfProjectSubcontractingApplyServiceImpl extends ServicePlusImpl<ZbfProjectSubcontractingApplyMapper, ZbfProjectSubcontractingApply> implements IZbfProjectSubcontractingApplyService {
|
||||
|
||||
@Autowired
|
||||
private IZbfProjectService projectService;
|
||||
@Autowired
|
||||
private IZbfProjectSubcontractingService projectSubcontractingService;
|
||||
@Autowired
|
||||
private IFbsMessageService fbsMessageService;
|
||||
@Autowired
|
||||
private IZbfMessageService zbfMessageService;
|
||||
|
||||
|
||||
@Override
|
||||
public ZbfProjectSubcontractingApply queryById(Long id){
|
||||
return getById(id);
|
||||
@ -56,10 +86,65 @@ public class ZbfProjectSubcontractingApplyServiceImpl extends ServicePlusImpl<Zb
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public Boolean insert(ZbfProjectSubcontractingApply bo) {
|
||||
ZbfProjectSubcontractingApply add = BeanUtil.toBean(bo, ZbfProjectSubcontractingApply.class);
|
||||
Long appUserId = SecurityUtils.getAppUserId();
|
||||
add.setFbsUserId(appUserId);
|
||||
validEntityBeforeSave(add);
|
||||
return save(add);
|
||||
ZbfProjectSubcontracting sub = projectSubcontractingService.getById(bo.getSubId());
|
||||
if(sub!=null && sub.getUserId()!=null){
|
||||
throw new BaseException("该分包已被承接");
|
||||
}
|
||||
|
||||
List<ZbfProjectSubcontractingApply> list = list(Wrappers.<ZbfProjectSubcontractingApply>lambdaQuery()
|
||||
.eq(ZbfProjectSubcontractingApply::getSubId, bo.getSubId())
|
||||
.eq(ZbfProjectSubcontractingApply::getApplyStatus, SubcontractingApplyStatus.APPLY.getCode())
|
||||
.eq(ZbfProjectSubcontractingApply::getFbsUserId, appUserId)
|
||||
);
|
||||
if(CollectionUtil.isNotEmpty(list)){
|
||||
throw new BaseException("您已经申请过该分包");
|
||||
}
|
||||
boolean save = save(add);
|
||||
//给分包商自己发消息
|
||||
// HashMap<String, String> mp = new HashMap<>();
|
||||
// mp.put("projectName", projectService.getById(bo.getProjectId()).getProjectName());
|
||||
// mp.put("subName", projectSubcontractingService.getById(bo.getSubId()).getSubName());
|
||||
// mp.put("auditor", SecurityUtils.getUsername());
|
||||
// Map<String, String> map = fbsMessage(mp, FBS_TYPE_TASK, true);
|
||||
// FbsMessage fbsMessage = new FbsMessage()
|
||||
// .setSenderType(USERTYPE_SYSTEM)
|
||||
// .setSenderId(SYSTEM_ID)
|
||||
// .setRecipientType(USERTYPE_FBS)
|
||||
// .setRecipientId(SecurityUtils.getAppUserId())
|
||||
// .setHeadline(map.get(HEADLINE))
|
||||
// .setSubheading(map.get(SUBHEADING))
|
||||
// .setTableId(add.getId())
|
||||
// .setTableName(SqlHelper.table(ZbfProjectSubcontractingApply.class).getTableName())
|
||||
// .setMessageLargeType(FBS_LARGE_TASK)
|
||||
// .setIsOperation(OPERATION_NO);
|
||||
// fbsMessageService.sendAMessage(fbsMessage);
|
||||
|
||||
ZbfProject project = projectService.getById(sub.getProjectId());
|
||||
//分包商发消息到总包方
|
||||
HashMap<String, String> fmp = new HashMap<>();
|
||||
fmp.put("projectName", project.getProjectName());
|
||||
fmp.put("subName", sub.getSubName());
|
||||
fmp.put("auditor", SecurityUtils.getUsername());
|
||||
Map<String, String> fmap = fbsMessage(fmp, FBS_TYPE_SUB_TO_ZBF, true);
|
||||
ZbfMessage zbfMessage = new ZbfMessage()
|
||||
.setSenderType(USERTYPE_FBS)
|
||||
.setSenderId(SecurityUtils.getAppUserId())
|
||||
.setRecipientType(USERTYPE_ZBF)
|
||||
.setRecipientId(project.getUserId())
|
||||
.setHeadline(fmap.get(HEADLINE))
|
||||
.setSubheading(fmap.get(SUBHEADING))
|
||||
.setTableId(add.getId())
|
||||
.setTableName(SqlHelper.table(ZbfProjectSubcontractingApply.class).getTableName())
|
||||
.setMessageLargeType(ZBF_LARGE_TASK)
|
||||
.setIsOperation(OPERATION_NEED);
|
||||
zbfMessageService.sendAMessage(zbfMessage);
|
||||
return save;
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -85,4 +170,65 @@ public class ZbfProjectSubcontractingApplyServiceImpl extends ServicePlusImpl<Zb
|
||||
}
|
||||
return removeByIds(ids);
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public Boolean choose(Long id) {
|
||||
ZbfProjectSubcontractingApply subApply = getById(id);
|
||||
if(subApply == null || TaskApplyStatus.CANCEL.getCode().equals(subApply.getApplyStatus())){
|
||||
throw new BaseException("该申请已取消");
|
||||
}
|
||||
ZbfProjectSubcontracting sub = projectSubcontractingService.getById(subApply.getSubId());
|
||||
if(sub!=null && sub.getUserId()!=null){
|
||||
throw new BaseException("该分包已被承接");
|
||||
}
|
||||
|
||||
ZbfProject project = projectService.getById(sub.getProjectId());
|
||||
|
||||
//修改分包
|
||||
sub.setUserId(subApply.getFbsUserId());
|
||||
projectSubcontractingService.updateById(sub);
|
||||
//修改项目状态
|
||||
if(ProjectStatus.NOT_START.getCode().equals(project.getProjectStatus())){
|
||||
project.setProjectStatus(ProjectStatus.START.getCode());
|
||||
projectService.updateById(project);
|
||||
}
|
||||
//拒绝其余分包商
|
||||
LambdaQueryWrapper<ZbfProjectSubcontractingApply> wrapper = new LambdaQueryWrapper<>();
|
||||
wrapper.eq(ZbfProjectSubcontractingApply::getSubId, subApply.getSubId());
|
||||
wrapper.eq(ZbfProjectSubcontractingApply::getApplyStatus, TaskApplyStatus.APPLY.getCode());
|
||||
List<ZbfProjectSubcontractingApply> list = baseMapper.selectList(wrapper);
|
||||
|
||||
ArrayList<FbsMessage> fbsMessages = new ArrayList<>();
|
||||
for (ZbfProjectSubcontractingApply subcontractApply : list){
|
||||
boolean equals = subcontractApply.getId().equals(id);
|
||||
if (equals){
|
||||
subcontractApply.setApplyStatus(TaskApplyStatus.PASS.getCode());
|
||||
}else{
|
||||
subcontractApply.setApplyStatus(TaskApplyStatus.REFUSE.getCode());
|
||||
}
|
||||
|
||||
//总包方发消息到分包商
|
||||
HashMap<String, String> zmp = new HashMap<>();
|
||||
zmp.put("projectName", project.getProjectName());
|
||||
zmp.put("subName", sub.getSubName());
|
||||
zmp.put("auditor", SecurityUtils.getUsername());
|
||||
Map<String, String> zmap = zbfMessage(zmp, ZBF_TYPE_SIGN_UP, equals);
|
||||
FbsMessage fbsMessage = new FbsMessage()
|
||||
.setSenderType(USERTYPE_ZBF)
|
||||
.setSenderId(SecurityUtils.getAppUserId())
|
||||
.setRecipientType(USERTYPE_FBS)
|
||||
.setRecipientId(subcontractApply.getFbsUserId())
|
||||
.setHeadline(zmap.get(HEADLINE))
|
||||
.setSubheading(zmap.get(SUBHEADING))
|
||||
.setTableId(subcontractApply.getId())
|
||||
.setTableName(SqlHelper.table(ZbfProjectSubcontractingApply.class).getTableName())
|
||||
.setMessageLargeType(FBS_LARGE_TASK)
|
||||
.setIsOperation(OPERATION_NO);
|
||||
fbsMessages.add(fbsMessage);
|
||||
}
|
||||
fbsMessageService.saveBatch(fbsMessages);
|
||||
// fbsMessageService.operationBatch(USERTYPE_FBS,SecurityUtils.getAppUserId(),list.stream().map(FbsProjectTaskApply::getId).collect(Collectors.toList()),SqlHelper.table(FbsProjectTaskApply.class).getTableName());
|
||||
return super.updateBatchById(list);
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,105 @@
|
||||
package com.ruoyi.zbf.service.impl;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
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.common.core.domain.entity.ZbfUser;
|
||||
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.utils.PageUtils;
|
||||
import com.ruoyi.zbf.bo.ZbfUserQueryBo;
|
||||
import com.ruoyi.zbf.mapper.ZbfUserMapper;
|
||||
import com.ruoyi.zbf.service.IZbfUserService;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* APP总包方用户Service业务层处理
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-31
|
||||
*/
|
||||
@Service
|
||||
public class ZbfUserServiceImpl extends ServicePlusImpl<ZbfUserMapper, ZbfUser> implements IZbfUserService {
|
||||
|
||||
@Override
|
||||
public ZbfUser queryById(Long id){
|
||||
return getById(id);
|
||||
}
|
||||
|
||||
@Override
|
||||
public TableDataInfo<ZbfUser> queryPageList(ZbfUserQueryBo bo) {
|
||||
Page<ZbfUser> result = page(PageUtils.buildPage(), buildQueryWrapper(bo));
|
||||
return PageUtils.buildDataInfo(result);
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<ZbfUser> queryList(ZbfUserQueryBo bo) {
|
||||
return list(buildQueryWrapper(bo));
|
||||
}
|
||||
|
||||
private LambdaQueryWrapper<ZbfUser> buildQueryWrapper(ZbfUserQueryBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<ZbfUser> lqw = Wrappers.lambdaQuery();
|
||||
lqw.eq(bo.getUserId() != null, ZbfUser::getUserId, bo.getUserId());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getPhone()), ZbfUser::getPhone, bo.getPhone());
|
||||
lqw.like(StrUtil.isNotBlank(bo.getUsername()), ZbfUser::getUsername, bo.getUsername());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getGender()), ZbfUser::getGender, bo.getGender());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getNation()), ZbfUser::getNation, bo.getNation());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getBirthdate()), ZbfUser::getBirthdate, bo.getBirthdate());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getIdentityCard()), ZbfUser::getIdentityCard, bo.getIdentityCard());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getArea()), ZbfUser::getArea, bo.getArea());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getSite()), ZbfUser::getSite, bo.getSite());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getBank()), ZbfUser::getBank, bo.getBank());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getCardNo()), ZbfUser::getCardNo, bo.getCardNo());
|
||||
lqw.like(StrUtil.isNotBlank(bo.getAvatarName()), ZbfUser::getAvatarName, bo.getAvatarName());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getPassword()), ZbfUser::getPassword, bo.getPassword());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getFrontPath()), ZbfUser::getFrontPath, bo.getFrontPath());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getReverseSidePath()), ZbfUser::getReverseSidePath, bo.getReverseSidePath());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getBankCardPath()), ZbfUser::getBankCardPath, bo.getBankCardPath());
|
||||
lqw.eq(bo.getCompanyId() != null, ZbfUser::getCompanyId, bo.getCompanyId());
|
||||
lqw.eq(StrUtil.isNotBlank(bo.getStatus()), ZbfUser::getStatus, bo.getStatus());
|
||||
return lqw;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean insert(ZbfUser bo) {
|
||||
ZbfUser add = BeanUtil.toBean(bo, ZbfUser.class);
|
||||
validEntityBeforeSave(add);
|
||||
return save(add);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean update(ZbfUser bo) {
|
||||
ZbfUser update = BeanUtil.toBean(bo, ZbfUser.class);
|
||||
validEntityBeforeSave(update);
|
||||
return updateById(update);
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*
|
||||
* @param entity 实体类数据
|
||||
*/
|
||||
private void validEntityBeforeSave(ZbfUser entity){
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
}
|
||||
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if(isValid){
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return removeByIds(ids);
|
||||
}
|
||||
|
||||
@Override
|
||||
public ZbfUser selectUserByPhone(String phone) {
|
||||
return baseMapper.selectOne(new LambdaQueryWrapper<ZbfUser>().eq(ZbfUser::getPhone, phone));
|
||||
}
|
||||
}
|
@ -0,0 +1,30 @@
|
||||
<?xml version="1.0" encoding="UTF-8" ?>
|
||||
<!DOCTYPE mapper
|
||||
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||
<mapper namespace="com.ruoyi.zbf.mapper.ZbfMessageMapper">
|
||||
|
||||
<resultMap type="com.ruoyi.zbf.domain.ZbfMessage" id="ZbfMessageResult">
|
||||
<result property="id" column="id"/>
|
||||
<result property="senderType" column="sender_type"/>
|
||||
<result property="senderId" column="sender_id"/>
|
||||
<result property="recipientType" column="recipient_type"/>
|
||||
<result property="recipientId" column="recipient_id"/>
|
||||
<result property="headline" column="headline"/>
|
||||
<result property="subheading" column="subheading"/>
|
||||
<result property="tableId" column="table_id"/>
|
||||
<result property="tableName" column="table_name"/>
|
||||
<result property="messageLargeType" column="message_large_type"/>
|
||||
<result property="messageSmallType" column="message_small_type"/>
|
||||
<result property="readStatus" column="read_status"/>
|
||||
<result property="delFlag" column="del_flag"/>
|
||||
<result property="createBy" column="create_by"/>
|
||||
<result property="createTime" column="create_time"/>
|
||||
<result property="updateBy" column="update_by"/>
|
||||
<result property="updateTime" column="update_time"/>
|
||||
<result property="remark" column="remark"/>
|
||||
<result property="isOperation" column="is_operation"/>
|
||||
</resultMap>
|
||||
|
||||
|
||||
</mapper>
|
@ -27,15 +27,9 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||
unit_name,
|
||||
project_name,
|
||||
project_address,
|
||||
project_img,
|
||||
project_status
|
||||
FROM zbf_project zp
|
||||
WHERE EXISTS (
|
||||
SELECT 1
|
||||
FROM zbf_project_subcontracting zps
|
||||
WHERE zps.user_id IS NULL
|
||||
AND zp.id = zps.project_id
|
||||
and zps.id NOT EXISTS(select zpsa.sub_id from zbf_project_subcontracting_apply zpsa where zpsa.fbs_user_id = #{dto.fbsUserId})
|
||||
)
|
||||
order by zp.id desc
|
||||
</select>
|
||||
|
||||
@ -44,12 +38,13 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||
unit_name,
|
||||
project_name,
|
||||
project_address,
|
||||
project_img,
|
||||
project_status
|
||||
FROM zbf_project zp
|
||||
WHERE EXISTS (
|
||||
SELECT 1
|
||||
FROM zbf_project_subcontracting_apply zpsa
|
||||
WHERE zpsa.fbs_user_id = #{dto.fbsUserId} and zpsa.apply_status in('0','2')
|
||||
WHERE zpsa.fbs_user_id = #{dto.fbsUserId} and zpsa.apply_status ='0'
|
||||
AND zp.id = zpsa.project_id
|
||||
) order by zp.id desc
|
||||
</select>
|
||||
@ -59,13 +54,14 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||
unit_name,
|
||||
project_name,
|
||||
project_address,
|
||||
project_img,
|
||||
project_status
|
||||
FROM zbf_project zp
|
||||
WHERE zp.project_status = '1' and
|
||||
EXISTS (
|
||||
SELECT 1
|
||||
FROM zbf_project_subcontracting zps
|
||||
WHERE zps.user_id = 1 AND zp.id = zps.project_id
|
||||
WHERE zps.user_id = #{dto.fbsUserId} AND zp.id = zps.project_id
|
||||
)
|
||||
order by zp.id desc
|
||||
</select>
|
||||
@ -75,15 +71,66 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||
unit_name,
|
||||
project_name,
|
||||
project_address,
|
||||
project_img,
|
||||
project_status
|
||||
FROM zbf_project zp
|
||||
WHERE zp.project_status = '2' and
|
||||
EXISTS (
|
||||
SELECT 1
|
||||
FROM zbf_project_subcontracting zps
|
||||
WHERE zps.user_id = 1 AND zp.id = zps.project_id
|
||||
WHERE zps.user_id = #{dto.fbsUserId} AND zp.id = zps.project_id
|
||||
)
|
||||
order by zp.id desc
|
||||
</select>
|
||||
|
||||
<select id="switchList" resultType="com.ruoyi.fbs.domain.vo.FbsProjectListVO">
|
||||
SELECT zp.id,
|
||||
unit_name,
|
||||
project_name,
|
||||
project_address,
|
||||
project_img,
|
||||
project_status
|
||||
FROM zbf_project zp
|
||||
zp.id in (select zpsa.project_id from zbf_project_subcontracting_apply zpsa where zpsa.fbs_user_id = #{dto.fbsUserId})
|
||||
order by zp.id desc
|
||||
</select>
|
||||
|
||||
<select id="applyCount" resultType="integer">
|
||||
SELECT count(1)
|
||||
FROM zbf_project zp
|
||||
WHERE EXISTS (
|
||||
SELECT 1
|
||||
FROM zbf_project_subcontracting_apply zpsa
|
||||
WHERE zpsa.fbs_user_id = #{fbsUserId} and zpsa.apply_status ='0'
|
||||
AND zp.id = zpsa.project_id
|
||||
)
|
||||
</select>
|
||||
|
||||
<select id="joinCount" resultType="integer">
|
||||
SELECT count(1)
|
||||
FROM zbf_project zp
|
||||
WHERE zp.project_status = '1' and
|
||||
EXISTS (
|
||||
SELECT 1
|
||||
FROM zbf_project_subcontracting zps
|
||||
WHERE zps.user_id = #{fbsUserId} AND zp.id = zps.project_id
|
||||
)
|
||||
</select>
|
||||
|
||||
<select id="completeCount" resultType="integer">
|
||||
SELECT zp.id,
|
||||
unit_name,
|
||||
project_name,
|
||||
project_address,
|
||||
project_img,
|
||||
project_status
|
||||
FROM zbf_project zp
|
||||
WHERE zp.project_status = '2' and
|
||||
EXISTS (
|
||||
SELECT 1
|
||||
FROM zbf_project_subcontracting zps
|
||||
WHERE zps.user_id = #{fbsUserId} AND zp.id = zps.project_id
|
||||
)
|
||||
order by zp.id desc;
|
||||
</select>
|
||||
|
||||
</mapper>
|
||||
|
@ -18,7 +18,7 @@ PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||
</resultMap>
|
||||
|
||||
<select id="joinSectionList" resultType="com.ruoyi.fbs.domain.vo.FbsProjectSectionListVO">
|
||||
SELECT zps.id, zps.project_id, zps.section_name
|
||||
SELECT zps.id, zps.project_id, zps.section_name,zp.project_address
|
||||
from zbf_project_section zps
|
||||
left join zbf_project zp on zps.project_id = zp.id
|
||||
where EXISTS (SELECT 1
|
||||
|
36
ruoyi-system/src/main/resources/mapper/zbf/ZbfUserMapper.xml
Normal file
36
ruoyi-system/src/main/resources/mapper/zbf/ZbfUserMapper.xml
Normal file
@ -0,0 +1,36 @@
|
||||
<?xml version="1.0" encoding="UTF-8" ?>
|
||||
<!DOCTYPE mapper
|
||||
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||
<mapper namespace="com.ruoyi.zbf.mapper.ZbfUserMapper">
|
||||
|
||||
<resultMap type="com.ruoyi.common.core.domain.entity.ZbfUser" id="ZbfUserResult">
|
||||
<result property="id" column="id"/>
|
||||
<result property="userId" column="user_id"/>
|
||||
<result property="phone" column="phone"/>
|
||||
<result property="username" column="username"/>
|
||||
<result property="gender" column="gender"/>
|
||||
<result property="nation" column="nation"/>
|
||||
<result property="birthdate" column="birthdate"/>
|
||||
<result property="identityCard" column="identity_card"/>
|
||||
<result property="area" column="area"/>
|
||||
<result property="site" column="site"/>
|
||||
<result property="bank" column="bank"/>
|
||||
<result property="cardNo" column="card_no"/>
|
||||
<result property="avatarName" column="avatar_name"/>
|
||||
<result property="password" column="password"/>
|
||||
<result property="frontPath" column="front_path"/>
|
||||
<result property="reverseSidePath" column="reverse_side_path"/>
|
||||
<result property="bankCardPath" column="bank_card_path"/>
|
||||
<result property="companyId" column="company_id"/>
|
||||
<result property="status" column="status"/>
|
||||
<result property="delFlag" column="del_flag"/>
|
||||
<result property="createBy" column="create_by"/>
|
||||
<result property="createTime" column="create_time"/>
|
||||
<result property="updateBy" column="update_by"/>
|
||||
<result property="updateTime" column="update_time"/>
|
||||
<result property="remark" column="remark"/>
|
||||
</resultMap>
|
||||
|
||||
|
||||
</mapper>
|
Reference in New Issue
Block a user