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