From a422a984cfa2a5a2bbe89c6fa6947363e559bb4f Mon Sep 17 00:00:00 2001
From: shiyunteng <shiyunteng@example.com>
Date: 星期五, 22 五月 2026 09:29:14 +0800
Subject: [PATCH] feat:faet:出库加批次号,合同履约加销方购方履约,到货单据必填校验,验收单据必填校验,单位新增法人、委托代理人字段 、合同出库新增erp出库ID

---
 platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ContractController.java |   85 ++++++++++++++++++++++++++++++++++++++----
 1 files changed, 77 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 ecef49e..1608d7e 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,13 +2,21 @@
 
 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.ContractAddDTO;
+import com.by4cloud.platformx.business.dto.ContractUpdateDTO;
 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;
 import io.swagger.v3.oas.annotations.security.SecurityRequirement;
@@ -19,6 +27,7 @@
 import lombok.RequiredArgsConstructor;
 import org.springframework.web.bind.annotation.*;
 
+import java.math.BigDecimal;
 import java.util.List;
 import java.util.Objects;
 
@@ -48,7 +57,11 @@
     @PreAuthorize("@pms.hasPermission('business_contract_view')" )
     public R getContractPage(@ParameterObject Page page, @ParameterObject Contract contract) {
         LambdaQueryWrapper<Contract> wrapper = Wrappers.lambdaQuery();
-        return R.ok(contractService.page(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(BaseModel::getCreateTime);
+        return R.ok(contractService.pageByScope(page, wrapper));
     }
 
 
@@ -61,33 +74,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) {
-        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);
     }
 
     /**
@@ -116,4 +129,60 @@
     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();
+	}
+
+	/**
+	 * 鐢熸垚鏂板悎鍚�
+	 * @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)
+				.gt(Contract::getBillingAmout,new BigDecimal("0"))));
+	}
+
+	/**
+	 * 鏍规嵁妯$増鐢熸垚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);
+	}
 }
\ No newline at end of file

--
Gitblit v1.9.1