项目成本分析模块后端代码完成
This commit is contained in:
@@ -0,0 +1,64 @@
|
||||
package com.ruoyi.oa.service;
|
||||
|
||||
import com.ruoyi.oa.domain.vo.SysOaCostAllVo;
|
||||
import com.ruoyi.oa.domain.vo.SysOaCostRow;
|
||||
import com.ruoyi.oa.domain.vo.SysOaCostVo;
|
||||
import com.ruoyi.oa.domain.bo.SysOaCostBo;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.core.domain.PageQuery;
|
||||
|
||||
import javax.validation.constraints.NotNull;
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 项目成本分析Service接口
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-04
|
||||
*/
|
||||
public interface ISysOaCostService {
|
||||
|
||||
/**
|
||||
* 查询项目成本分析
|
||||
*/
|
||||
SysOaCostVo queryById(Long costId);
|
||||
|
||||
/**
|
||||
* 查询项目成本分析列表
|
||||
*/
|
||||
TableDataInfo<SysOaCostVo> queryPageList(SysOaCostBo bo, PageQuery pageQuery);
|
||||
|
||||
/**
|
||||
* 查询项目成本分析列表
|
||||
*/
|
||||
List<SysOaCostVo> queryList(SysOaCostBo bo);
|
||||
|
||||
/**
|
||||
* 新增项目成本分析
|
||||
*/
|
||||
Boolean insertByBo(SysOaCostBo bo);
|
||||
|
||||
/**
|
||||
* 修改项目成本分析
|
||||
*/
|
||||
Boolean updateByBo(SysOaCostBo bo);
|
||||
|
||||
/**
|
||||
* 校验并批量删除项目成本分析信息
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
|
||||
/**
|
||||
* 查询所有项目成本
|
||||
*/
|
||||
TableDataInfo<SysOaCostAllVo> AllList(String projectName, String createTime);
|
||||
|
||||
/**
|
||||
* 查询详情
|
||||
*/
|
||||
TableDataInfo<SysOaCostRow> getDetail(Long projectId);
|
||||
|
||||
|
||||
|
||||
}
|
||||
@@ -0,0 +1,212 @@
|
||||
package com.ruoyi.oa.service.impl;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import com.ruoyi.common.core.domain.entity.SysUser;
|
||||
import com.ruoyi.common.exception.ServiceException;
|
||||
import com.ruoyi.common.utils.StringUtils;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.core.domain.PageQuery;
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
||||
import com.ruoyi.oa.domain.SysOaProject;
|
||||
import com.ruoyi.oa.domain.vo.*;
|
||||
import com.ruoyi.oa.mapper.*;
|
||||
import com.ruoyi.system.mapper.SysUserMapper;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import lombok.extern.slf4j.Slf4j;
|
||||
import org.springframework.beans.BeanUtils;
|
||||
import org.springframework.stereotype.Service;
|
||||
import com.ruoyi.oa.domain.bo.SysOaCostBo;
|
||||
import com.ruoyi.oa.domain.SysOaCost;
|
||||
import com.ruoyi.oa.service.ISysOaCostService;
|
||||
|
||||
import java.util.*;
|
||||
|
||||
/**
|
||||
* 项目成本分析Service业务层处理
|
||||
*
|
||||
* @author ruoyi
|
||||
* @date 2025-03-04
|
||||
*/
|
||||
@RequiredArgsConstructor
|
||||
@Slf4j
|
||||
@Service
|
||||
public class SysOaCostServiceImpl implements ISysOaCostService {
|
||||
|
||||
private final SysOaCostMapper baseMapper;
|
||||
|
||||
private final SysUserMapper userMapper;
|
||||
|
||||
private final SysOaClaimMapper claimMapper;
|
||||
|
||||
private final SysOaWarehouseMapper warehouseMapper;
|
||||
|
||||
|
||||
/**
|
||||
* 查询项目成本分析
|
||||
*/
|
||||
@Override
|
||||
public SysOaCostVo queryById(Long costId){
|
||||
return baseMapper.selectVoById(costId);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询项目成本分析列表
|
||||
*/
|
||||
@Override
|
||||
public TableDataInfo<SysOaCostVo> queryPageList(SysOaCostBo bo, PageQuery pageQuery) {
|
||||
LambdaQueryWrapper<SysOaCost> lqw = buildQueryWrapper(bo);
|
||||
Page<SysOaCostVo> result = baseMapper.selectVoPage(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询项目成本分析列表
|
||||
*/
|
||||
@Override
|
||||
public List<SysOaCostVo> queryList(SysOaCostBo bo) {
|
||||
LambdaQueryWrapper<SysOaCost> lqw = buildQueryWrapper(bo);
|
||||
return baseMapper.selectVoList(lqw);
|
||||
}
|
||||
|
||||
private LambdaQueryWrapper<SysOaCost> buildQueryWrapper(SysOaCostBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
LambdaQueryWrapper<SysOaCost> lqw = Wrappers.lambdaQuery();
|
||||
lqw.eq(bo.getProjectId() != null, SysOaCost::getProjectId, bo.getProjectId());
|
||||
lqw.eq(bo.getCost() != null, SysOaCost::getCost, bo.getCost());
|
||||
lqw.eq(bo.getCostType() != null, SysOaCost::getCostType, bo.getCostType());
|
||||
lqw.like(StringUtils.isNotBlank(bo.getRemark()), SysOaCost::getRemark, bo.getRemark());
|
||||
lqw.eq(bo.getMaterialId() != null, SysOaCost::getMaterialId, bo.getMaterialId());
|
||||
lqw.eq(bo.getUserId() != null, SysOaCost::getUserId, bo.getUserId());
|
||||
lqw.eq(bo.getFinanceId() != null, SysOaCost::getFinanceId, bo.getFinanceId());
|
||||
lqw.eq(bo.getClaimId() != null, SysOaCost::getClaimId, bo.getClaimId());
|
||||
return lqw;
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增项目成本分析
|
||||
*/
|
||||
@Override
|
||||
public Boolean insertByBo(SysOaCostBo bo) {
|
||||
SysOaCost add = BeanUtil.toBean(bo, SysOaCost.class);
|
||||
validEntityBeforeSave(add);
|
||||
boolean flag = baseMapper.insert(add) > 0;
|
||||
if (flag) {
|
||||
bo.setCostId(add.getCostId());
|
||||
}
|
||||
return flag;
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改项目成本分析
|
||||
*/
|
||||
@Override
|
||||
public Boolean updateByBo(SysOaCostBo bo) {
|
||||
SysOaCost update = BeanUtil.toBean(bo, SysOaCost.class);
|
||||
validEntityBeforeSave(update);
|
||||
return baseMapper.updateById(update) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*/
|
||||
private void validEntityBeforeSave(SysOaCost entity){
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 批量删除项目成本分析
|
||||
*/
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if(isValid){
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return baseMapper.deleteBatchIds(ids) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询所有项目成本
|
||||
*/
|
||||
|
||||
@Override
|
||||
public TableDataInfo<SysOaCostAllVo> AllList(String projectName, String createTime) {
|
||||
|
||||
List<SysOaCostAll> alls = baseMapper.AllList(projectName,createTime);
|
||||
List<SysOaCostAllVo> allVos = new java.util.ArrayList<>(Collections.emptyList());
|
||||
if (alls.isEmpty()) return TableDataInfo.build(allVos);
|
||||
for (SysOaCostAll all : alls) {
|
||||
SysOaCostAllVo allVo = BeanUtil.toBean(all, SysOaCostAllVo.class);
|
||||
|
||||
// 车间用工
|
||||
if (allVo.getCostType() == 1) {
|
||||
allVo.setUserVo(userMapper.selectUserById(allVo.getUserId()));
|
||||
} else if (allVo.getCostType() == 2) { // 差旅花费
|
||||
allVo.setClaimVo(claimMapper.selectSysOaClaimVoById(allVo.getClaimId()));
|
||||
|
||||
} else if (allVo.getCostType() == 3) { // 库房物料
|
||||
allVo.setMaterialVo(warehouseMapper.selectVoById(allVo.getMaterialId()));
|
||||
|
||||
} else if (allVo.getCostType() == 4) { // 其他
|
||||
|
||||
|
||||
} else if (allVo.getCostType() == 5) { // 接待
|
||||
|
||||
}
|
||||
allVos.add(allVo);
|
||||
}
|
||||
return TableDataInfo.build(allVos);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询详情
|
||||
*/
|
||||
@Override
|
||||
public TableDataInfo<SysOaCostRow> getDetail(Long projectId) {
|
||||
log.info("查询projectId = {}", projectId);
|
||||
// LambdaQueryWrapper<SysOaCost> lqw = Wrappers.lambdaQuery(SysOaCost.class);
|
||||
// lqw.eq(SysOaCost::getProjectId,projectId);
|
||||
// List<SysOaCost> costs = baseMapper.selectList(lqw);
|
||||
List<SysOaCost> costs = baseMapper.getListByProjectId(projectId);
|
||||
log.info("查询costs = {}", costs);
|
||||
|
||||
if (costs.isEmpty()) {
|
||||
return TableDataInfo.build();
|
||||
}
|
||||
SysOaCostRow sysOaCostRow = new SysOaCostRow();
|
||||
sysOaCostRow.setUserCostList(new ArrayList<>());
|
||||
sysOaCostRow.setMaterialList(new ArrayList<>());
|
||||
sysOaCostRow.setClaimList(new ArrayList<>());
|
||||
sysOaCostRow.setOtherList(new ArrayList<>());
|
||||
for(SysOaCost cost : costs) {
|
||||
SysOaCostList sysOaCostList = BeanUtil.toBean(cost,SysOaCostList.class);
|
||||
log.info("查询cost = {}", cost);
|
||||
log.info("sysOaCostList = {}", sysOaCostList);
|
||||
|
||||
if(cost.getCostType() == 1) {
|
||||
log.info("查询useVo = {}", userMapper.selectUserById(cost.getUserId()));
|
||||
sysOaCostList.setUserVo(userMapper.selectUserById(cost.getUserId()));
|
||||
sysOaCostRow.getUserCostList().add(sysOaCostList);
|
||||
} else if(cost.getCostType() == 2) {
|
||||
log.info("查询claimMapperVo = {}", claimMapper.selectSysOaClaimVoById(cost.getClaimId()));
|
||||
sysOaCostList.setClaimVo(claimMapper.selectSysOaClaimVoById(cost.getClaimId()));
|
||||
sysOaCostRow.getClaimList().add(sysOaCostList);
|
||||
} else if(cost.getCostType() == 3) {
|
||||
log.info("查询warehouseMapperVo = {}",warehouseMapper.selectVoById(cost.getMaterialId()));
|
||||
sysOaCostList.setMaterialVo(warehouseMapper.selectVoById(cost.getMaterialId()));
|
||||
sysOaCostRow.getMaterialList().add(sysOaCostList);
|
||||
} else{
|
||||
sysOaCostRow.getOtherList().add(sysOaCostList);
|
||||
}
|
||||
|
||||
}
|
||||
log.info("sysOaCostRow = {}", sysOaCostRow);
|
||||
List<SysOaCostRow> rows = new java.util.ArrayList<>(Collections.singletonList(sysOaCostRow));
|
||||
return TableDataInfo.build(rows);
|
||||
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user