From c6040880b0da8834dbcb92d6def7d4dd0cd6c40e Mon Sep 17 00:00:00 2001
From: cuida <xiaocuijustsoso@163.com>
Date: 星期三, 29 四月 2026 16:57:50 +0800
Subject: [PATCH] feat:合同,合同标的物,收款基础代码

---
 platformx-business-finance-biz/src/main/java/com/by4cloud/platformx/business/controller/ContractController.java |  117 +++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 106 insertions(+), 11 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 dc4df91..ecef49e 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
@@ -1,24 +1,119 @@
 package com.by4cloud.platformx.business.controller;
 
+import cn.hutool.core.util.ArrayUtil;
+import cn.hutool.core.collection.CollUtil;
+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.entity.Contract;
+import com.by4cloud.platformx.common.core.util.R;
+import com.by4cloud.platformx.common.log.annotation.SysLog;
 import com.by4cloud.platformx.business.service.ContractService;
+import org.springframework.security.access.prepost.PreAuthorize;
+import com.by4cloud.platformx.common.excel.annotation.ResponseExcel;
 import io.swagger.v3.oas.annotations.security.SecurityRequirement;
-import io.swagger.v3.oas.annotations.tags.Tag;
-import lombok.RequiredArgsConstructor;
+import org.springdoc.core.annotations.ParameterObject;
 import org.springframework.http.HttpHeaders;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import io.swagger.v3.oas.annotations.Operation;
+import lombok.RequiredArgsConstructor;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.List;
+import java.util.Objects;
 
 /**
- * @author cd
- * @description
- * @date 2026/4/29 14:05
- **/
+ * 鍚堝悓绠$悊
+ *
+ * @author platformx
+ * @date 2026-04-29 16:46:26
+ */
 @RestController
 @RequiredArgsConstructor
 @RequestMapping("/contract" )
-@Tag(description = "contract" , name = "鍚堝悓琛ㄧ鐞�" )
+@Tag(description = "contract" , name = "鍚堝悓绠$悊绠$悊" )
 @SecurityRequirement(name = HttpHeaders.AUTHORIZATION)
 public class ContractController {
 
-    private final ContractService contractService;
-}
+    private final  ContractService contractService;
+
+    /**
+     * 鍒嗛〉鏌ヨ
+     * @param page 鍒嗛〉瀵硅薄
+     * @param contract 鍚堝悓绠$悊
+     * @return
+     */
+    @Operation(summary = "鍒嗛〉鏌ヨ" , description = "鍒嗛〉鏌ヨ" )
+    @GetMapping("/page" )
+    @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));
+    }
+
+
+    /**
+     * 閫氳繃id鏌ヨ鍚堝悓绠$悊
+     * @param id id
+     * @return R
+     */
+    @Operation(summary = "閫氳繃id鏌ヨ" , description = "閫氳繃id鏌ヨ" )
+    @GetMapping("/{id}" )
+    @PreAuthorize("@pms.hasPermission('business_contract_view')" )
+    public R getById(@PathVariable("id" ) Long id) {
+        return R.ok(contractService.getById(id));
+    }
+
+    /**
+     * 鏂板鍚堝悓绠$悊
+     * @param contract 鍚堝悓绠$悊
+     * @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));
+    }
+
+    /**
+     * 淇敼鍚堝悓绠$悊
+     * @param contract 鍚堝悓绠$悊
+     * @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));
+    }
+
+    /**
+     * 閫氳繃id鍒犻櫎鍚堝悓绠$悊
+     * @param ids id鍒楄〃
+     * @return R
+     */
+    @Operation(summary = "閫氳繃id鍒犻櫎鍚堝悓绠$悊" , description = "閫氳繃id鍒犻櫎鍚堝悓绠$悊" )
+    @SysLog("閫氳繃id鍒犻櫎鍚堝悓绠$悊" )
+    @DeleteMapping
+    @PreAuthorize("@pms.hasPermission('business_contract_del')" )
+    public R removeById(@RequestBody Long[] ids) {
+        return R.ok(contractService.removeBatchByIds(CollUtil.toList(ids)));
+    }
+
+
+    /**
+     * 瀵煎嚭excel 琛ㄦ牸
+     * @param contract 鏌ヨ鏉′欢
+   	 * @param ids 瀵煎嚭鎸囧畾ID
+     * @return excel 鏂囦欢娴�
+     */
+    @ResponseExcel
+    @GetMapping("/export")
+    @PreAuthorize("@pms.hasPermission('business_contract_export')" )
+    public List<Contract> export(Contract contract,Long[] ids) {
+        return contractService.list(Wrappers.lambdaQuery(contract).in(ArrayUtil.isNotEmpty(ids), Contract::getId, ids));
+    }
+}
\ No newline at end of file

--
Gitblit v1.9.1