付款进度代码同步
This commit is contained in:
@@ -0,0 +1,98 @@
|
||||
package com.ruoyi.oa.controller;
|
||||
|
||||
|
||||
import com.ruoyi.common.core.controller.BaseController;
|
||||
import com.ruoyi.common.core.domain.PageQuery;
|
||||
import com.ruoyi.common.core.domain.R;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.oa.domain.OaPaymentProgress;
|
||||
import com.ruoyi.oa.domain.SysOaFinance;
|
||||
import com.ruoyi.oa.domain.bo.OaPaymentProgressBo;
|
||||
import com.ruoyi.oa.domain.bo.SysOaFinanceBo;
|
||||
import com.ruoyi.oa.domain.vo.OaPaymentProgressVo;
|
||||
import com.ruoyi.oa.domain.vo.SysOaFinanceVo;
|
||||
import com.ruoyi.oa.service.IOaPaymentProgressService;
|
||||
import com.ruoyi.oa.service.ISysOaFinanceService;
|
||||
import liquibase.pro.packaged.A;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
|
||||
import javax.validation.constraints.NotEmpty;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 付款进度
|
||||
*/
|
||||
@RestController
|
||||
@RequestMapping("/oa/payment-progress")
|
||||
public class OaPaymentProgressController extends BaseController {
|
||||
|
||||
@Autowired
|
||||
private IOaPaymentProgressService progressService;
|
||||
@Autowired
|
||||
private ISysOaFinanceService financeService;
|
||||
|
||||
|
||||
/** 1. 创建付款进度 **/
|
||||
@PostMapping
|
||||
public R<Boolean> createProgress(@RequestBody OaPaymentProgressBo p) {
|
||||
|
||||
return R.ok(progressService.insertByBo(p));
|
||||
}
|
||||
|
||||
/** 2. 修改付款进度(不可改主键/项目ID) **/
|
||||
@PutMapping
|
||||
public R<Boolean> updateProgress(@RequestBody OaPaymentProgressBo p) {
|
||||
|
||||
return R.ok(progressService.updateByBo(p));
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询项目付款进度列表
|
||||
*/
|
||||
@GetMapping("/list")
|
||||
public TableDataInfo<OaPaymentProgressVo> list(OaPaymentProgressBo bo, PageQuery pageQuery) {
|
||||
return progressService.queryPageList(bo, pageQuery);
|
||||
}
|
||||
|
||||
/** 4. 查询某个进度下的所有明细(finance 记录) **/
|
||||
@GetMapping("/{progressId}/details")
|
||||
public R<List<SysOaFinanceVo>> listDetails(@PathVariable("progressId") Long progressId) {
|
||||
return R.ok(financeService.getByProgressId(progressId));
|
||||
}
|
||||
|
||||
/** 5. 为某个进度添加明细 **/
|
||||
@PostMapping("/{progressId}/details")
|
||||
public R<Boolean> addDetail(@PathVariable("progressId") Long progressId,
|
||||
@RequestBody SysOaFinanceBo f) {
|
||||
f.setPaymentProgressId(progressId);
|
||||
|
||||
return R.ok(financeService.insertByBo(f));
|
||||
}
|
||||
|
||||
/** 6. 修改明细(不可改主键/进度ID) **/
|
||||
@PutMapping("/details")
|
||||
public R<Boolean> updateDetail(@RequestBody SysOaFinanceBo f) {
|
||||
SysOaFinanceVo exist = financeService.queryById(f.getFinanceId());
|
||||
f.setPaymentProgressId(exist.getPaymentProgressId());
|
||||
return R.ok(financeService.updateByBo(f));
|
||||
}
|
||||
|
||||
/** 7. 删除某条明细(并级联删 detail 记录) **/
|
||||
@DeleteMapping("/details/{financeId}")
|
||||
public void deleteDetail(@PathVariable Long financeId) {
|
||||
financeService.deleteDetail(financeId);
|
||||
}
|
||||
|
||||
/**
|
||||
* 删除项目付款进度
|
||||
*
|
||||
* @param paymentProgressIds 主键串
|
||||
*/
|
||||
@DeleteMapping("/{paymentProgressIds}")
|
||||
public R<Void> remove(@NotEmpty(message = "主键不能为空")
|
||||
@PathVariable Long[] paymentProgressIds) {
|
||||
return toAjax(progressService.deleteWithValidByIds(Arrays.asList(paymentProgressIds), true));
|
||||
}
|
||||
}
|
||||
@@ -64,6 +64,14 @@ public class SysOaFinanceController extends BaseController {
|
||||
return sysOaFinanceList;
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询进出账管理列表
|
||||
*/
|
||||
@GetMapping("/progress-list")
|
||||
public TableDataInfo<SysOaFinanceVo> progressList(SysOaFinanceBo bo, PageQuery pageQuery) {
|
||||
TableDataInfo<SysOaFinanceVo> sysOaFinanceVoTableDataInfo = iSysOaFinanceService.progressList(bo, pageQuery);
|
||||
return sysOaFinanceVoTableDataInfo;
|
||||
}
|
||||
|
||||
@GetMapping("/barData")
|
||||
public R<List<SysOaFinanceVo>> pieData(SysOaFinanceBo bo) {
|
||||
|
||||
@@ -0,0 +1,70 @@
|
||||
package com.ruoyi.oa.domain;
|
||||
|
||||
import com.baomidou.mybatisplus.annotation.*;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import java.io.Serializable;
|
||||
import java.util.Date;
|
||||
import java.math.BigDecimal;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.util.Date;
|
||||
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||
import com.ruoyi.common.core.domain.BaseEntity;
|
||||
|
||||
/**
|
||||
* 项目付款进度对象 oa_payment_progress
|
||||
*
|
||||
* @author hdka
|
||||
* @date 2025-05-23
|
||||
*/
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@TableName("oa_payment_progress")
|
||||
public class OaPaymentProgress extends BaseEntity {
|
||||
|
||||
private static final long serialVersionUID=1L;
|
||||
|
||||
/**
|
||||
* 付款进度ID
|
||||
*/
|
||||
@TableId(value = "payment_progress_id")
|
||||
private Long paymentProgressId;
|
||||
/**
|
||||
* 关联项目ID,引用 oa_project.project_id
|
||||
*/
|
||||
private Long projectId;
|
||||
/**
|
||||
* 付款开始时间
|
||||
*/
|
||||
private Date startTime;
|
||||
/**
|
||||
* 付款结束时间
|
||||
*/
|
||||
private Date endTime;
|
||||
/**
|
||||
* 付款金额
|
||||
*/
|
||||
private BigDecimal amount;
|
||||
/**
|
||||
* 是否作废:0正常;1作废
|
||||
*/
|
||||
private Integer isVoid;
|
||||
/**
|
||||
* 删除标志:0正常;1已删除
|
||||
*/
|
||||
@TableLogic
|
||||
private Integer delFlag;
|
||||
/**
|
||||
* 备注
|
||||
*/
|
||||
private String remark;
|
||||
|
||||
|
||||
/**
|
||||
* 完成标志
|
||||
*/
|
||||
private Long complete;
|
||||
|
||||
|
||||
}
|
||||
@@ -107,4 +107,20 @@ public class SysOaFinance extends BaseEntity {
|
||||
@TableField(exist = false)
|
||||
private List<SysOaDetail> detailList;
|
||||
|
||||
private Long paymentProgressId;
|
||||
|
||||
/**
|
||||
* 开始时间
|
||||
*/
|
||||
private Date beginTime;
|
||||
|
||||
/**
|
||||
* 结束时间
|
||||
*/
|
||||
private Date endTime;
|
||||
|
||||
/**
|
||||
* 完成状态
|
||||
*/
|
||||
private Long status;
|
||||
}
|
||||
|
||||
@@ -0,0 +1,71 @@
|
||||
package com.ruoyi.oa.domain.bo;
|
||||
|
||||
|
||||
import com.fasterxml.jackson.annotation.JsonFormat;
|
||||
import com.ruoyi.common.core.domain.BaseEntity;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
import org.springframework.format.annotation.DateTimeFormat;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.util.Date;
|
||||
|
||||
@Data
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
public class OaPaymentProgressBo extends BaseEntity {
|
||||
|
||||
/**
|
||||
* 付款进度ID
|
||||
*/
|
||||
private Long paymentProgressId;
|
||||
|
||||
/**
|
||||
* 关联项目ID,引用 oa_project.project_id
|
||||
*/
|
||||
private Long projectId;
|
||||
|
||||
/**
|
||||
* 付款开始时间
|
||||
*/
|
||||
@JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")
|
||||
@DateTimeFormat(pattern = "yyyy-MM-dd")
|
||||
private Date startTime;
|
||||
|
||||
/**
|
||||
* 付款结束时间
|
||||
*/
|
||||
@JsonFormat(pattern = "yyyy-MM-dd", timezone = "GMT+8")
|
||||
@DateTimeFormat(pattern = "yyyy-MM-dd")
|
||||
private Date endTime;
|
||||
|
||||
/**
|
||||
* 付款金额
|
||||
*/
|
||||
private BigDecimal amount;
|
||||
|
||||
/**
|
||||
* 是否作废:0正常;1作废
|
||||
*/
|
||||
private Integer isVoid;
|
||||
|
||||
/**
|
||||
* 备注
|
||||
*/
|
||||
private String remark;
|
||||
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 完成标志
|
||||
*/
|
||||
private Long complete;
|
||||
|
||||
private String projectName;
|
||||
|
||||
private String projectCode;
|
||||
|
||||
private String projectNum;
|
||||
|
||||
|
||||
}
|
||||
@@ -120,5 +120,24 @@ public class SysOaFinanceBo extends BaseEntity {
|
||||
*/
|
||||
private String outType;
|
||||
|
||||
/**
|
||||
* 开始时间
|
||||
*/
|
||||
private Date beginTime;
|
||||
|
||||
/**
|
||||
* 结束时间
|
||||
*/
|
||||
private Date endTime;
|
||||
|
||||
/**
|
||||
* 付款进度id
|
||||
*/
|
||||
private Long paymentProgressId;
|
||||
|
||||
/**
|
||||
* 完成状态
|
||||
*/
|
||||
private Long status;
|
||||
|
||||
}
|
||||
|
||||
@@ -0,0 +1,81 @@
|
||||
package com.ruoyi.oa.domain.vo;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
|
||||
import com.alibaba.excel.annotation.ExcelProperty;
|
||||
import lombok.Data;
|
||||
import java.util.Date;
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 项目付款进度视图对象 oa_payment_progress
|
||||
*
|
||||
* @author hdka
|
||||
* @date 2025-05-23
|
||||
*/
|
||||
@Data
|
||||
@ExcelIgnoreUnannotated
|
||||
public class OaPaymentProgressVo {
|
||||
|
||||
private static final long serialVersionUID = 1L;
|
||||
|
||||
/**
|
||||
* 付款进度ID
|
||||
*/
|
||||
@ExcelProperty(value = "付款进度ID")
|
||||
private Long paymentProgressId;
|
||||
|
||||
/**
|
||||
* 关联项目ID,引用 oa_project.project_id
|
||||
*/
|
||||
@ExcelProperty(value = "关联项目ID,引用 oa_project.project_id")
|
||||
private Long projectId;
|
||||
|
||||
/**
|
||||
* 付款开始时间
|
||||
*/
|
||||
@ExcelProperty(value = "付款开始时间")
|
||||
private Date startTime;
|
||||
|
||||
/**
|
||||
* 付款结束时间
|
||||
*/
|
||||
@ExcelProperty(value = "付款结束时间")
|
||||
private Date endTime;
|
||||
|
||||
/**
|
||||
* 付款金额
|
||||
*/
|
||||
@ExcelProperty(value = "付款金额")
|
||||
private BigDecimal amount;
|
||||
|
||||
/**
|
||||
* 是否作废:0正常;1作废
|
||||
*/
|
||||
@ExcelProperty(value = "是否作废:0正常;1作废")
|
||||
private Integer isVoid;
|
||||
|
||||
/**
|
||||
* 备注
|
||||
*/
|
||||
@ExcelProperty(value = "备注")
|
||||
private String remark;
|
||||
|
||||
private String projectName;
|
||||
private String projectCode;
|
||||
private String projectNum;
|
||||
|
||||
private Date earliestEndTime;
|
||||
|
||||
|
||||
/**
|
||||
* 完成标志
|
||||
*/
|
||||
private Long complete;
|
||||
|
||||
/**
|
||||
* 完成资格
|
||||
*/
|
||||
private Long qualified;
|
||||
}
|
||||
@@ -140,6 +140,16 @@ public class SysOaFinanceVo extends SysOaFinance {
|
||||
*/
|
||||
private String outType;
|
||||
|
||||
/**
|
||||
* 开始时间
|
||||
*/
|
||||
private Date beginTime;
|
||||
|
||||
/**
|
||||
* 结束时间
|
||||
*/
|
||||
private Date endTime;
|
||||
|
||||
/**
|
||||
* 类型金钱综合用于饼图数据
|
||||
*/
|
||||
@@ -151,4 +161,9 @@ public class SysOaFinanceVo extends SysOaFinance {
|
||||
|
||||
private String month;
|
||||
|
||||
/**
|
||||
* 完成状态
|
||||
*/
|
||||
private Long status;
|
||||
|
||||
}
|
||||
|
||||
@@ -31,7 +31,7 @@ public interface SysOaFinanceMapper extends BaseMapperPlus<SysOaFinanceMapper, S
|
||||
*/
|
||||
@DataPermission({
|
||||
@DataColumn(key = "detailTitle", value = "b.detail_id"),
|
||||
@DataColumn(key = "financeTitle", value = "a.finance_id")
|
||||
@DataColumn(key = "financeTitle", value = "sof.finance_id")
|
||||
})
|
||||
Page<SysOaFinanceVo> selectPageFinanceList(@Param("page") Page<SysOaFinanceVo> page, @Param(Constants.WRAPPER) Wrapper<SysOaFinance> queryWrapper);
|
||||
|
||||
@@ -72,6 +72,9 @@ public interface SysOaFinanceMapper extends BaseMapperPlus<SysOaFinanceMapper, S
|
||||
*/
|
||||
List<SysOaFinanceVo> getBarData(SysOaFinanceBo bo);
|
||||
|
||||
List<SysOaFinanceVo> selectByPaymentProgressId(Long progressId);
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* 项目资金管理,根据时间范围查询列表数据
|
||||
|
||||
@@ -0,0 +1,49 @@
|
||||
package com.ruoyi.oa.service;
|
||||
|
||||
import com.ruoyi.oa.domain.OaPaymentProgress;
|
||||
import com.ruoyi.oa.domain.vo.OaPaymentProgressVo;
|
||||
import com.ruoyi.oa.domain.bo.OaPaymentProgressBo;
|
||||
import com.ruoyi.common.core.page.TableDataInfo;
|
||||
import com.ruoyi.common.core.domain.PageQuery;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 项目付款进度Service接口
|
||||
*
|
||||
* @author hdka
|
||||
* @date 2025-05-23
|
||||
*/
|
||||
public interface IOaPaymentProgressService {
|
||||
|
||||
/**
|
||||
* 查询项目付款进度
|
||||
*/
|
||||
OaPaymentProgressVo queryById(Long paymentProgressId);
|
||||
|
||||
/**
|
||||
* 查询项目付款进度列表
|
||||
*/
|
||||
TableDataInfo<OaPaymentProgressVo> queryPageList(OaPaymentProgressBo bo, PageQuery pageQuery);
|
||||
|
||||
/**
|
||||
* 查询项目付款进度列表
|
||||
*/
|
||||
List<OaPaymentProgressVo> queryList(OaPaymentProgressBo bo);
|
||||
|
||||
/**
|
||||
* 新增项目付款进度
|
||||
*/
|
||||
Boolean insertByBo(OaPaymentProgressBo bo);
|
||||
|
||||
/**
|
||||
* 修改项目付款进度
|
||||
*/
|
||||
Boolean updateByBo(OaPaymentProgressBo bo);
|
||||
|
||||
/**
|
||||
* 校验并批量删除项目付款进度信息
|
||||
*/
|
||||
Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid);
|
||||
}
|
||||
@@ -91,4 +91,11 @@ public interface ISysOaFinanceService {
|
||||
Boolean deleteSysOaFinanceById(Long financeId);
|
||||
|
||||
List<SysOaFinanceVo> getBarData(SysOaFinanceBo bo);
|
||||
|
||||
public List<SysOaFinanceVo> getByProgressId(Long progressId);
|
||||
|
||||
public void deleteDetail(Long financeId);
|
||||
|
||||
TableDataInfo<SysOaFinanceVo> progressList(SysOaFinanceBo bo, PageQuery pageQuery);
|
||||
|
||||
}
|
||||
|
||||
@@ -0,0 +1,117 @@
|
||||
package com.ruoyi.oa.service.impl;
|
||||
|
||||
import cn.hutool.core.bean.BeanUtil;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||
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 lombok.RequiredArgsConstructor;
|
||||
import org.springframework.stereotype.Service;
|
||||
import com.ruoyi.oa.domain.bo.OaPaymentProgressBo;
|
||||
import com.ruoyi.oa.domain.vo.OaPaymentProgressVo;
|
||||
import com.ruoyi.oa.domain.OaPaymentProgress;
|
||||
import com.ruoyi.oa.mapper.OaPaymentProgressMapper;
|
||||
import com.ruoyi.oa.service.IOaPaymentProgressService;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Collection;
|
||||
|
||||
/**
|
||||
* 项目付款进度Service业务层处理
|
||||
*
|
||||
* @author hdka
|
||||
* @date 2025-05-23
|
||||
*/
|
||||
@RequiredArgsConstructor
|
||||
@Service
|
||||
public class OaPaymentProgressServiceImpl implements IOaPaymentProgressService {
|
||||
|
||||
private final OaPaymentProgressMapper baseMapper;
|
||||
|
||||
/**
|
||||
* 查询项目付款进度
|
||||
*/
|
||||
@Override
|
||||
public OaPaymentProgressVo queryById(Long paymentProgressId){
|
||||
return baseMapper.selectVoById(paymentProgressId);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询项目付款进度列表
|
||||
*/
|
||||
@Override
|
||||
public TableDataInfo<OaPaymentProgressVo> queryPageList(OaPaymentProgressBo bo, PageQuery pageQuery) {
|
||||
QueryWrapper<OaPaymentProgress> lqw = buildQueryWrapper(bo);
|
||||
Page<OaPaymentProgressVo> result = baseMapper.selectVoPagePlus(pageQuery.build(), lqw);
|
||||
return TableDataInfo.build(result);
|
||||
}
|
||||
|
||||
/**
|
||||
* 查询项目付款进度列表
|
||||
*/
|
||||
@Override
|
||||
public List<OaPaymentProgressVo> queryList(OaPaymentProgressBo bo) {
|
||||
QueryWrapper<OaPaymentProgress> lqw = buildQueryWrapper(bo);
|
||||
return baseMapper.selectVoList(lqw);
|
||||
}
|
||||
|
||||
private QueryWrapper<OaPaymentProgress> buildQueryWrapper(OaPaymentProgressBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
QueryWrapper<OaPaymentProgress> lqw = Wrappers.query();
|
||||
lqw.like(bo.getProjectId() != null,"opp.project_id", bo.getProjectId());
|
||||
lqw.ge(bo.getStartTime() != null, "opp.start_time", bo.getStartTime());
|
||||
lqw.le(bo.getEndTime() != null,"opp.end_time", bo.getEndTime());
|
||||
lqw.eq(bo.getIsVoid() != null, "opp.is_void", bo.getIsVoid());
|
||||
lqw.eq(bo.getProjectName()!=null,"sop.project_name",bo.getProjectName());
|
||||
lqw.eq(bo.getProjectNum()!=null,"sop.project_num",bo.getProjectNum());
|
||||
lqw.eq(bo.getProjectCode()!=null,"sop.project_code",bo.getProjectCode());
|
||||
lqw.eq("opp.del_flag",0);
|
||||
return lqw;
|
||||
}
|
||||
|
||||
/**
|
||||
* 新增项目付款进度
|
||||
*/
|
||||
@Override
|
||||
public Boolean insertByBo(OaPaymentProgressBo bo) {
|
||||
OaPaymentProgress add = BeanUtil.toBean(bo, OaPaymentProgress.class);
|
||||
validEntityBeforeSave(add);
|
||||
boolean flag = baseMapper.insert(add) > 0;
|
||||
if (flag) {
|
||||
bo.setPaymentProgressId(add.getPaymentProgressId());
|
||||
}
|
||||
return flag;
|
||||
}
|
||||
|
||||
/**
|
||||
* 修改项目付款进度
|
||||
*/
|
||||
@Override
|
||||
public Boolean updateByBo(OaPaymentProgressBo bo) {
|
||||
OaPaymentProgress update = BeanUtil.toBean(bo, OaPaymentProgress.class);
|
||||
validEntityBeforeSave(update);
|
||||
return baseMapper.updateById(update) > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* 保存前的数据校验
|
||||
*/
|
||||
private void validEntityBeforeSave(OaPaymentProgress entity){
|
||||
//TODO 做一些数据校验,如唯一约束
|
||||
}
|
||||
|
||||
/**
|
||||
* 批量删除项目付款进度
|
||||
*/
|
||||
@Override
|
||||
public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
||||
if(isValid){
|
||||
//TODO 做一些业务上的校验,判断是否需要校验
|
||||
}
|
||||
return baseMapper.deleteBatchIds(ids) > 0;
|
||||
}
|
||||
}
|
||||
@@ -23,6 +23,7 @@ import com.ruoyi.oa.domain.vo.SysOaFinanceVo;
|
||||
import com.ruoyi.oa.domain.SysOaFinance;
|
||||
import com.ruoyi.oa.mapper.SysOaFinanceMapper;
|
||||
import com.ruoyi.oa.service.ISysOaFinanceService;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
import java.util.*;
|
||||
@@ -70,14 +71,25 @@ public class SysOaFinanceServiceImpl implements ISysOaFinanceService {
|
||||
return TableDataInfo.build(sysOaFinanceVoList);
|
||||
}
|
||||
|
||||
@Override
|
||||
public TableDataInfo<SysOaFinanceVo> progressList(SysOaFinanceBo bo, PageQuery pageQuery) {
|
||||
QueryWrapper<SysOaFinance> lqw = Wrappers.query();
|
||||
lqw.eq(ObjectUtil.isNotNull(bo.getProjectId()), "sof.project_id", bo.getProjectId());
|
||||
lqw.eq(ObjectUtil.isNotNull(bo.getPaymentProgressId()), "sof.payment_progress_id", bo.getPaymentProgressId());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getFinanceType()), "sof.finance_type", bo.getFinanceType());
|
||||
lqw.orderByDesc("sof.create_time");
|
||||
Page<SysOaFinanceVo> sysOaFinanceVoList = baseMapper.selectFinanceList(pageQuery.build(),lqw );
|
||||
return TableDataInfo.build(sysOaFinanceVoList);
|
||||
}
|
||||
|
||||
private Wrapper<SysOaFinance> buildQueryWrapperByFinance(SysOaFinanceBo bo) {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
QueryWrapper<SysOaFinance> lqw = Wrappers.query();
|
||||
lqw.isNull("sof.payment_progress_id");
|
||||
//前端设定了projectId的值为0和1,0:非项目进出账(添加时候默认为0),1:项目进出账(项目的id是数字串整数,添加时候该字段存储;gt大于0表示项目字段值
|
||||
// lqw.ge("a.project_id ",bo.getProjectId());
|
||||
lqw.eq(ObjectUtil.isNotNull(bo.getProjectId()), "a.project_id", bo.getProjectId());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getFinanceType()), "a.finance_type", bo.getFinanceType());
|
||||
lqw.orderByDesc("a.create_time");
|
||||
lqw.eq(ObjectUtil.isNotNull(bo.getProjectId()), "sof.project_id", bo.getProjectId());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getFinanceType()), "sof.finance_type", bo.getFinanceType());
|
||||
lqw.orderByDesc("sof.create_time");
|
||||
return lqw;
|
||||
}
|
||||
|
||||
@@ -127,23 +139,16 @@ public class SysOaFinanceServiceImpl implements ISysOaFinanceService {
|
||||
@Override
|
||||
public BigDecimal selectFinanceByProjectId(SysOaFinanceBo bo) {
|
||||
List<SysOaFinance> sysOaFinances = baseMapper.selectFinanceByProjectId(bo);
|
||||
System.out.println("sysOaFinances===" + sysOaFinances);
|
||||
System.out.println("sysOaFinances000===" + sysOaFinances.size());
|
||||
if (sysOaFinances.size() > 0) {
|
||||
ArrayList<BigDecimal> objects = new ArrayList<>();
|
||||
sysOaFinances.forEach(v -> {
|
||||
System.out.println("vvvv" + v.getDetailList());
|
||||
BigDecimal reduce = v.getDetailList().stream().map(s -> s.getPrice() == null ? new BigDecimal(0) : s.getPrice()).reduce(BigDecimal.ZERO, BigDecimal::add);
|
||||
objects.add(reduce);
|
||||
});
|
||||
//主表再次求和
|
||||
BigDecimal reduce = objects.stream().reduce(BigDecimal.ZERO, BigDecimal::add);
|
||||
System.out.println("hehehehe999===" + reduce);
|
||||
return reduce;
|
||||
return objects.stream().reduce(BigDecimal.ZERO, BigDecimal::add);
|
||||
} else {
|
||||
BigDecimal reduce = new BigDecimal(0);
|
||||
System.out.println("hehehehe===" + reduce);
|
||||
return reduce;
|
||||
return new BigDecimal(0);
|
||||
|
||||
}
|
||||
|
||||
@@ -182,13 +187,13 @@ public class SysOaFinanceServiceImpl implements ISysOaFinanceService {
|
||||
Map<String, Object> params = bo.getParams();
|
||||
QueryWrapper<SysOaFinance> lqw = Wrappers.query();
|
||||
//前端设定了projectId的值为0和1,0:非项目进出账(添加时候默认为0),1:项目进出账(项目的id是数字串整数,添加时候该字段存储;gt大于0表示项目字段值
|
||||
lqw.eq("a.project_id", bo.getProjectId());
|
||||
lqw.like(StringUtils.isNotBlank(bo.getFinanceTitle()), "a.finance_title", bo.getFinanceTitle());
|
||||
lqw.like(StringUtils.isNotBlank(bo.getFinanceParties()), "a.finance_parties", bo.getFinanceParties());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getFinanceType()), "a.finance_type", bo.getFinanceType());
|
||||
lqw.eq(Objects.nonNull(bo.getReceiveAccountId()) && bo.getReceiveAccountId()!=-1L, "a.receive_account_id", bo.getReceiveAccountId());
|
||||
lqw.eq("sof.project_id", bo.getProjectId());
|
||||
lqw.like(StringUtils.isNotBlank(bo.getFinanceTitle()), "sof.finance_title", bo.getFinanceTitle());
|
||||
lqw.like(StringUtils.isNotBlank(bo.getFinanceParties()), "sof.finance_parties", bo.getFinanceParties());
|
||||
lqw.eq(StringUtils.isNotBlank(bo.getFinanceType()), "sof.finance_type", bo.getFinanceType());
|
||||
lqw.eq(Objects.nonNull(bo.getReceiveAccountId()) && bo.getReceiveAccountId()!=-1L, "sof.receive_account_id", bo.getReceiveAccountId());
|
||||
lqw.between(params.get("beginCreateTime") != null && params.get("endCreateTime") != null,
|
||||
"a.create_time", params.get("beginCreateTime"), params.get("endCreateTime"));
|
||||
"sof.create_time", params.get("beginCreateTime"), params.get("endCreateTime"));
|
||||
lqw.orderByDesc("create_time");
|
||||
return lqw;
|
||||
}
|
||||
@@ -284,4 +289,21 @@ public class SysOaFinanceServiceImpl implements ISysOaFinanceService {
|
||||
}
|
||||
return baseMapper.deleteBatchIds(ids) > 0;
|
||||
}*/
|
||||
|
||||
@Override
|
||||
public List<SysOaFinanceVo> getByProgressId(Long progressId) {
|
||||
return baseMapper.selectByPaymentProgressId(progressId);
|
||||
}
|
||||
|
||||
@Override
|
||||
@Transactional
|
||||
public void deleteDetail(Long financeId) {
|
||||
// 先删掉 sys_oa_detail 中的行
|
||||
sysOaDetailMapper.delete(new QueryWrapper<SysOaDetail>()
|
||||
.eq("finance_id", financeId));
|
||||
// 再删 sys_oa_finance
|
||||
baseMapper.deleteById(financeId);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user