From 6b969ca247b98e5a793e61ec5b0d89f4fccb3318 Mon Sep 17 00:00:00 2001
From: shiyunteng <shiyunteng@example.com>
Date: 星期三, 10 六月 2026 16:25:18 +0800
Subject: [PATCH] feat:抵抹账条件新增付款金额小于开票金额,红票审核拒绝后蓝票可重新开红票
---
platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ContractController.java | 149 ++++++++++++++++++++++++++++++++++++++++++++-----
1 files changed, 133 insertions(+), 16 deletions(-)
diff --git a/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ContractController.java b/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ContractController.java
index 5910bc1..64f1152 100644
--- a/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ContractController.java
+++ b/platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ContractController.java
@@ -2,15 +2,22 @@
import cn.hutool.core.util.ArrayUtil;
import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.util.ObjUtil;
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.by4cloud.platformx.business.dto.ContracQueryDTO;
+import com.by4cloud.platformx.business.dto.ContractAddDTO;
+import com.by4cloud.platformx.business.dto.ContractUpdateDTO;
+import com.by4cloud.platformx.business.dto.DelayOutApprovalDTO;
import com.by4cloud.platformx.business.entity.Contract;
import com.by4cloud.platformx.common.core.util.R;
import com.by4cloud.platformx.common.data.mybatis.BaseModel;
import com.by4cloud.platformx.common.log.annotation.SysLog;
import com.by4cloud.platformx.business.service.ContractService;
+import com.by4cloud.platformx.common.security.annotation.Inner;
import com.by4cloud.platformx.common.security.util.SecurityUtils;
+import jakarta.servlet.http.HttpServletResponse;
import org.apache.commons.lang3.StringUtils;
import org.springframework.security.access.prepost.PreAuthorize;
import com.by4cloud.platformx.common.excel.annotation.ResponseExcel;
@@ -22,6 +29,7 @@
import lombok.RequiredArgsConstructor;
import org.springframework.web.bind.annotation.*;
+import java.math.BigDecimal;
import java.util.List;
import java.util.Objects;
@@ -43,18 +51,19 @@
/**
* 鍒嗛〉鏌ヨ
* @param page 鍒嗛〉瀵硅薄
- * @param contract 鍚堝悓绠$悊
+ * @param queryDTO 鍚堝悓绠$悊
* @return
*/
@Operation(summary = "鍒嗛〉鏌ヨ" , description = "鍒嗛〉鏌ヨ" )
@GetMapping("/page" )
@PreAuthorize("@pms.hasPermission('business_contract_view')" )
- public R getContractPage(@ParameterObject Page page, @ParameterObject Contract contract) {
+ public R getContractPage(@ParameterObject Page page, @ParameterObject ContracQueryDTO queryDTO) {
LambdaQueryWrapper<Contract> wrapper = Wrappers.lambdaQuery();
- wrapper.like(StringUtils.isNotBlank(contract.getContractName()),Contract::getContractName,contract.getContractName());
- wrapper.like(StringUtils.isNotBlank(contract.getPartyA()),Contract::getPartyA,contract.getPartyA());
- wrapper.orderByDesc(BaseModel::getCreateTime);
- return R.ok(contractService.pageByScope(page, wrapper));
+// wrapper.like(StringUtils.isNotBlank(contract.getContractName()),Contract::getContractName,contract.getContractName());
+// wrapper.like(StringUtils.isNotBlank(contract.getPartyA()),Contract::getPartyA,contract.getPartyA());
+// wrapper.eq(ObjUtil.isNotNull(contract.getContractStatus()),Contract::getContractStatus,contract.getContractStatus());
+// wrapper.orderByDesc(Contract::getCreateTime);
+ return R.ok(contractService.pageScope(page, queryDTO));
}
@@ -67,36 +76,33 @@
@GetMapping("/{id}" )
@PreAuthorize("@pms.hasPermission('business_contract_view')" )
public R getById(@PathVariable("id" ) Long id) {
- return R.ok(contractService.getById(id));
+ return R.ok(contractService.detail(id));
}
/**
* 鏂板鍚堝悓绠$悊
- * @param contract 鍚堝悓绠$悊
+ * @param addDTO 鍚堝悓绠$悊
* @return R
*/
@Operation(summary = "鏂板鍚堝悓绠$悊" , description = "鏂板鍚堝悓绠$悊" )
@SysLog("鏂板鍚堝悓绠$悊" )
@PostMapping
@PreAuthorize("@pms.hasPermission('business_contract_add')" )
- public R save(@RequestBody Contract contract) {
- Long compId = SecurityUtils.getUser().getCompId();
- contract.setPartyBId(contract.getCompId());
- contract.setPartyB(contract.getCompName());
- return R.ok(contractService.save(contract));
+ public R save(@RequestBody ContractAddDTO addDTO) {
+ return contractService.add(addDTO);
}
/**
* 淇敼鍚堝悓绠$悊
- * @param contract 鍚堝悓绠$悊
+ * @param updateDTO 鍚堝悓绠$悊
* @return R
*/
@Operation(summary = "淇敼鍚堝悓绠$悊" , description = "淇敼鍚堝悓绠$悊" )
@SysLog("淇敼鍚堝悓绠$悊" )
@PutMapping
@PreAuthorize("@pms.hasPermission('business_contract_edit')" )
- public R updateById(@RequestBody Contract contract) {
- return R.ok(contractService.updateById(contract));
+ public R updateById(@RequestBody ContractUpdateDTO updateDTO) {
+ return contractService.edit(updateDTO);
}
/**
@@ -125,4 +131,115 @@
public List<Contract> export(Contract contract,Long[] ids) {
return contractService.list(Wrappers.lambdaQuery(contract).in(ArrayUtil.isNotEmpty(ids), Contract::getId, ids));
}
+
+ /**
+ * 鍚姩瀹℃牳娴佺▼
+ * @param id id
+ * @return R
+ */
+ @Operation(summary = "閫氳繃id鍚姩瀹℃牳娴佺▼" , description = "閫氳繃id鍚堝悓鐢熸晥" )
+ @GetMapping("/startApproval/{id}" )
+ public R startApproval(@PathVariable("id" ) Long id) {
+ return contractService.startApproval(id);
+ }
+
+
+ /**
+ * 瀹氭椂鐢熸垚搴旀敹閫炬湡
+ * @return R
+ */
+ @GetMapping("/genCurrentOverdue" )
+ @Inner(value = false)
+ public R genCurrentOverdue() {
+ return contractService.genCurrentOverdue();
+ }
+
+ /**
+ * 瀹氭椂鐢熸垚鍛ㄦ湡鎬у簲鏀�
+ * @return R
+ */
+ @GetMapping("/genCycleReceiced" )
+ @Inner(value = false)
+ public R genCycleReceiced() {
+ return contractService.genCycleReceiced();
+ }
+
+ /**
+ * 鐢熸垚鏂板悎鍚�
+ * @param id id
+ * @return R
+ */
+ @Operation(summary = "閫氳繃id鐢熸垚鏂板悎鍚�" , description = "閫氳繃id鐢熸垚鏂板悎鍚�" )
+ @GetMapping("/copyNewContract/{id}" )
+ public R copyNewContract(@PathVariable("id" ) Long id) {
+ return contractService.copyNewContract(id);
+ }
+
+ /**
+ * 鏍规嵁瀹㈠晢鏌ヨ鍚堝悓
+ * @param busId id
+ * @return R
+ */
+ @Operation(summary = "鏍规嵁瀹㈠晢鏌ヨ鍚堝悓" , description = "鏍规嵁瀹㈠晢鏌ヨ鍚堝悓" )
+ @GetMapping("/listByBusId/{busId}" )
+ public R listByBusId(@PathVariable("busId" ) Long busId) {
+ return R.ok(contractService.listByScope(Wrappers.<Contract>lambdaQuery().eq(Contract::getPartyAId,busId)
+ .eq(Contract::getPartyBId,SecurityUtils.getUser().getCompId())
+ .gt(Contract::getBillingAmout,new BigDecimal("0"))
+ .apply("paid_amount < billing_amout")));
+ }
+
+ /**
+ * 鏍规嵁妯$増鐢熸垚word涓�鐓ゆ満鍔犲伐鎵挎徑鍚堝悓
+ * @param id id
+ * @return R
+ */
+ @Operation(summary = "鏍规嵁妯$増鐢熸垚word鍚堝悓" , description = "鏍规嵁妯$増鐢熸垚word鍚堝悓" )
+ @GetMapping("/exportContractYMJJGCLWord/{id}" )
+ public void exportContractYMJJGCLWord(@PathVariable("id" ) Long id, HttpServletResponse response) {
+ contractService.exportContractYMJJGCLWord(id,response);
+ }
+
+ /**
+ * 鏍规嵁妯$増鐢熸垚word涓�鐓ゆ満宸ヤ笟鍝佷拱鍗栧悎鍚�
+ * @param id id
+ * @return R
+ */
+ @Operation(summary = "鏍规嵁妯$増鐢熸垚word鍚堝悓" , description = "鏍规嵁妯$増鐢熸垚word鍚堝悓" )
+ @GetMapping("/exportContractYMJGYPMMWord/{id}" )
+ public void exportContractYMJGYPMMWord(@PathVariable("id" ) Long id, HttpServletResponse response) {
+ contractService.exportContractYMJGYPMMWord(id,response);
+ }
+
+ /**
+ * 鏍规嵁妯$増鐢熸垚word涓�鐓ゆ満宸ョ熆浜у搧涔板崠鍚堝悓
+ * @param id id
+ * @return R
+ */
+ @Operation(summary = "鏍规嵁妯$増鐢熸垚word鍚堝悓" , description = "鏍规嵁妯$増鐢熸垚word鍚堝悓" )
+ @GetMapping("/exportContractYMJGKCPMMWord/{id}" )
+ public void exportContractYMJGKCPMMWord(@PathVariable("id" ) Long id, HttpServletResponse response) {
+ contractService.exportContractYMJGKCPMMWord(id,response);
+ }
+
+ /**
+ * 鏍规嵁妯$増鐢熸垚word涓�鐓ゆ満閲囪喘鍚堝悓
+ * @param id id
+ * @return R
+ */
+ @Operation(summary = "鏍规嵁妯$増鐢熸垚word鍚堝悓" , description = "鏍规嵁妯$増鐢熸垚word鍚堝悓" )
+ @GetMapping("/exportContractYMJCGWord/{id}" )
+ public void exportContractYMJCGWord(@PathVariable("id" ) Long id, HttpServletResponse response) {
+ contractService.exportContractYMJCGWord(id,response);
+ }
+
+ /**
+ * 寤舵湡鍑鸿揣瀹℃壒
+ */
+
+ @PostMapping("/delayOutApproval")
+ public R delayOutApproval(@RequestBody DelayOutApprovalDTO dto) {
+ return contractService.delayOutApproval(dto);
+ }
+
}
\ No newline at end of file
--
Gitblit v1.9.1