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 | 107 +++++++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 99 insertions(+), 8 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 b88aa1e..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
@@ -6,8 +6,10 @@
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;
@@ -15,6 +17,7 @@
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;
@@ -26,6 +29,7 @@
import lombok.RequiredArgsConstructor;
import org.springframework.web.bind.annotation.*;
+import java.math.BigDecimal;
import java.util.List;
import java.util.Objects;
@@ -47,19 +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.eq(ObjUtil.isNotNull(contract.getContractStatus()),Contract::getContractStatus,contract.getContractStatus());
- 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));
}
@@ -141,7 +145,7 @@
/**
- * 瀹氭椂鐢熸垚搴旀敹娆捐处鐩�
+ * 瀹氭椂鐢熸垚搴旀敹閫炬湡
* @return R
*/
@GetMapping("/genCurrentOverdue" )
@@ -150,5 +154,92 @@
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