From dea02f2b19f2558acddca07fcd47e7154282c520 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期三, 22 一月 2025 11:36:32 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/tool/TencentCosUtil.java        |  108 ++++++++++++
 ruoyi-admin/src/main/resources/application-test.yml                                |    7 
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/COSController.java          |   40 ++++
 ruoyi-system/src/main/java/com/ruoyi/system/dto/TContractDTO.java                  |   29 +++
 ruoyi-system/src/main/java/com/ruoyi/system/mapper/TContractMapper.java            |    6 
 ruoyi-system/pom.xml                                                               |    6 
 ruoyi-system/src/main/resources/mapper/system/TContractMapper.xml                  |   17 +
 ruoyi-system/src/main/java/com/ruoyi/system/vo/TContractVO.java                    |   35 +++
 /dev/null                                                                          |   51 -----
 ruoyi-system/src/main/java/com/ruoyi/system/model/TContractRentType.java           |    7 
 ruoyi-system/src/main/java/com/ruoyi/system/service/TContractService.java          |    3 
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java    |  125 ++++++++++---
 ruoyi-admin/src/main/resources/application-prod.yml                                |    7 
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/THouseServiceImpl.java    |   18 +
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TContractServiceImpl.java |   13 +
 ruoyi-system/src/main/java/com/ruoyi/system/query/TContractQuery.java              |   19 ++
 ruoyi-system/src/main/java/com/ruoyi/system/model/TContract.java                   |    4 
 ruoyi-system/src/main/java/com/ruoyi/system/model/THouse.java                      |    5 
 18 files changed, 409 insertions(+), 91 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/COSController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/COSController.java
new file mode 100644
index 0000000..eeba769
--- /dev/null
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/COSController.java
@@ -0,0 +1,40 @@
+package com.ruoyi.web.controller.api;
+
+import com.ruoyi.common.core.domain.R;
+import com.ruoyi.web.controller.tool.TencentCosUtil;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiImplicitParam;
+import io.swagger.annotations.ApiImplicitParams;
+import io.swagger.annotations.ApiOperation;
+import org.springframework.web.bind.annotation.PostMapping;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestParam;
+import org.springframework.web.bind.annotation.RestController;
+import org.springframework.web.multipart.MultipartFile;
+
+import javax.annotation.Resource;
+
+/**
+ * @author HJL
+ * @version 1.0
+ * @since 2024-05-30 9:27
+ */
+@RestController
+@RequestMapping("/cos")
+@Api(tags = "公共-文件上传")
+public class COSController {
+
+    @Resource
+    private TencentCosUtil tencentCosUtil;
+
+    @PostMapping("/upload")
+    @ApiOperation(value = "文件上传", tags = "公共-文件上传")
+    @ApiImplicitParams({
+            @ApiImplicitParam(value = "文件", name = "file", dataType = "MultipartFile", required = true)
+    })
+    public R<String> upload(@RequestParam("file") MultipartFile file) {
+        String s = tencentCosUtil.upLoadFile(file);
+        return R.ok(s, s);
+    }
+
+}
diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OssController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OssController.java
deleted file mode 100644
index d84919e..0000000
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/OssController.java
+++ /dev/null
@@ -1,51 +0,0 @@
-package com.ruoyi.web.controller.api;
-
-import com.aliyun.oss.OSSClient;
-import com.aliyun.oss.model.ObjectMetadata;
-import com.aliyun.oss.model.PutObjectRequest;
-import com.aliyun.oss.model.PutObjectResult;
-import io.swagger.annotations.ApiOperation;
-import org.springframework.http.ResponseEntity;
-import org.springframework.web.bind.annotation.*;
-import org.springframework.web.multipart.MultipartFile;
-
-import java.io.IOException;
-
-@CrossOrigin
-@RestController
-@RequestMapping("/base/oss")
-class OssController {
-
-    private static final String endpoint = "oss-cn-chengdu.aliyuncs.com";
-    private static final String accessKeyId = "LTAI5tCQHjSsP7TXuyjSG1PJ";
-    private static final String accessKeySecret = "RIDXxzOrdMS0V8vQDT53MGvAgsegRV";
-    private static final String bucketName = "inspectionbucket";
-
-    @PostMapping("/upload")
-    @ApiOperation(value = "文件上传",tags = "文件上传")
-    public ResponseEntity<String> upload(@RequestParam("file") MultipartFile file) throws IOException {
-        // 创建 OSSClient 实例
-        OSSClient ossClient = new OSSClient(endpoint, accessKeyId, accessKeySecret);
-
-
-        // 创建 PutObjectRequest 对象
-        PutObjectRequest putObjectRequest = new PutObjectRequest(bucketName, file.getOriginalFilename(), file.getInputStream());
-
-        ObjectMetadata metadata = new ObjectMetadata();
-        // 取消文件缓存,文件每次都会从OSS服务器获取
-        metadata.setHeader("Cache-Control", "no-cache");
-        metadata.setHeader("Expires", "0");
-
-
-        // 上传文件
-        PutObjectResult putObjectResult = ossClient.putObject(putObjectRequest);
-
-        // 关闭 OSSClient 实例
-        ossClient.shutdown();
-
-        String fileUrl = "https://" + bucketName + "." + endpoint + "/" + file.getOriginalFilename();
-        return ResponseEntity.ok(fileUrl);
-    }
-
-
-}
diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java
index fc28438..cddd624 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java
@@ -1,22 +1,36 @@
 package com.ruoyi.web.controller.api;
 
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.ruoyi.common.annotation.Log;
 import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.common.core.domain.AjaxResult;
 import com.ruoyi.common.enums.BusinessType;
+import com.ruoyi.common.utils.StringUtils;
+import com.ruoyi.system.dto.TContractDTO;
 import com.ruoyi.system.dto.THouseDTO;
+import com.ruoyi.system.model.TContract;
+import com.ruoyi.system.model.TContractRentType;
 import com.ruoyi.system.model.THouse;
+import com.ruoyi.system.query.TContractQuery;
 import com.ruoyi.system.query.THouseQuery;
 import com.ruoyi.system.query.TUserHistoryQuery;
+import com.ruoyi.system.service.TContractRentTypeService;
 import com.ruoyi.system.service.TContractService;
 import com.ruoyi.system.service.THouseService;
 import com.ruoyi.system.vo.HouseVO;
 import io.swagger.annotations.Api;
+import com.ruoyi.system.vo.TContractVO;
+import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.validation.annotation.Validated;
 import org.springframework.web.bind.annotation.*;
+
+import java.time.LocalDateTime;
+import java.util.Arrays;
+import java.util.List;
 
 /**
  * <p>
@@ -32,39 +46,82 @@
 public class TContractController {
     @Autowired
     private TContractService contractService;
-//    @Log(title = "房屋基础信息管理-新增房屋", businessType = BusinessType.INSERT)
-//    @ApiOperation(value = "新增房屋")
-//    @PostMapping(value = "/addHouse")
-//    public AjaxResult<Boolean> addHouse(@Validated @RequestBody THouseDTO dto) {
-//        return AjaxResult.success(contractService.save(dto));
-//    }
-//    @Log(title = "房屋基础信息管理-编辑房屋", businessType = BusinessType.UPDATE)
-//    @ApiOperation(value = "编辑房屋")
-//    @PostMapping(value = "/updateHouse")
-//    public AjaxResult<Boolean> updateHouse(@Validated @RequestBody THouseDTO dto) {
-//        return AjaxResult.success(contractService.updateById(dto));
-//    }
-//    @Log(title = "房屋基础信息管理-查询房屋信息", businessType = BusinessType.DELETE)
-//    @ApiOperation(value = "查询房屋信息")
-//    @GetMapping(value = "/getHouseById")
-//    public AjaxResult<THouse> getHouseById(@RequestParam Long id) {
-//        return AjaxResult.success(contractService.getById(id));
-//    }
-//    @Log(title = "房屋基础信息管理-删除房屋", businessType = BusinessType.DELETE)
-//    @ApiOperation(value = "删除房屋")
-//    @DeleteMapping(value = "/deleteHouseById")
-//    public AjaxResult<Boolean> deleteHouseById(@RequestParam Long id) {
-//        return AjaxResult.success(contractService.removeById(id));
-//    }
-//    @ApiOperation(value = "获取房屋分页列表")
-//    @PostMapping(value = "/houseList")
-//    public AjaxResult<PageInfo<THouse>> houseList(@RequestBody THouseQuery query) {
-//        return AjaxResult.success(contractService.houseList(query));
-//    }
-//    @ApiOperation(value = "历史租户列表")
-//    @PostMapping(value = "/userHistoryList")
-//    public AjaxResult<PageInfo<HouseVO>> userHistoryList(@RequestBody TUserHistoryQuery query) {
-//        return AjaxResult.success(contractService.userHistoryList(query));
-//    }
+    @Autowired
+    private TContractRentTypeService contractRentTypeService;
+    @Autowired
+    private THouseService houseService;
+    @ApiOperation(value = "获取合同分页列表")
+    @PostMapping(value = "/contractList")
+    public AjaxResult<PageInfo<TContract>> contractList(@RequestBody TContractQuery query) {
+        return AjaxResult.success(contractService.contractList(query));
+    }
+    @Log(title = "合同管理-新增合同", businessType = BusinessType.INSERT)
+    @ApiOperation(value = "新增合同")
+    @PostMapping(value = "/addContract")
+    public AjaxResult<Boolean> addContract(@Validated @RequestBody TContractDTO dto) {
+        contractService.save(dto);
+        if (dto.getIsIncreasing()==1){
+            TContractRentType tContractRentType = new TContractRentType();
+            tContractRentType.setContractId(dto.getId());
+            tContractRentType.setIncreasingDecreasing(dto.getIncreasingDecreasing());
+            tContractRentType.setIncreasingDecreasingType(dto.getIncreasingDecreasingType());
+            tContractRentType.setNumericalValue(dto.getNumericalValue());
+            tContractRentType.setChangeTime(dto.getChangeTime());
+            contractRentTypeService.save(tContractRentType);
+        }
+        return AjaxResult.success();
+    }
+    @Log(title = "合同管理-编辑合同", businessType = BusinessType.UPDATE)
+    @ApiOperation(value = "编辑合同")
+    @PostMapping(value = "/updateContract")
+    public AjaxResult<Boolean> updateContract(@Validated @RequestBody TContractDTO dto) {
+        contractService.updateById(dto);
+        contractRentTypeService.remove(new LambdaQueryWrapper<TContractRentType>()
+                .eq(TContractRentType::getContractId,dto.getId()));
+        if (dto.getIsIncreasing()==1){
+            TContractRentType tContractRentType = new TContractRentType();
+            tContractRentType.setContractId(dto.getId());
+            tContractRentType.setIncreasingDecreasing(dto.getIncreasingDecreasing());
+            tContractRentType.setIncreasingDecreasingType(dto.getIncreasingDecreasingType());
+            tContractRentType.setNumericalValue(dto.getNumericalValue());
+            tContractRentType.setChangeTime(dto.getChangeTime());
+            contractRentTypeService.save(tContractRentType);
+        }
+        return AjaxResult.success();
+    }
+    @Log(title = "合同管理-批量删除合同", businessType = BusinessType.DELETE)
+    @ApiOperation(value = "批量删除合同")
+    @DeleteMapping(value = "/deleteContractByIds")
+    public AjaxResult<Boolean> deleteContractByIds3
+            (@RequestParam String ids) {
+        if (StringUtils.isNotEmpty(ids)){
+            contractService.removeBatchByIds(Arrays.asList(ids.split(",")));
+        }
+        return AjaxResult.success();
+    }
+
+    @ApiOperation(value = "查询合同信息信息")
+    @GetMapping(value = "/getContractById")
+    public AjaxResult<TContractVO> getContractById(@RequestParam Long id) {
+        TContractVO res = new TContractVO();
+        TContract contract = contractService.getById(id);
+        BeanUtils.copyProperties(contract,res);
+        TContractRentType contractRentType = contractRentTypeService.lambdaQuery().eq(TContractRentType::getContractId, id).one();
+        if (contractRentType!=null){
+            BeanUtils.copyProperties(contractRentType,res);
+        }
+        TContract oldContract = contractService.getOne(new LambdaQueryWrapper<TContract>()
+                        .eq(TContract::getHouseId,contract.getHouseId())
+                .eq(TContract::getStatus, 4)
+                .le(TContract::getStartTime, LocalDateTime.now())
+                .ge(TContract::getEndTime, LocalDateTime.now()));
+        THouse house = houseService.getById(contract.getHouseId());
+        if (oldContract!=null){
+            house.setTenantType(oldContract.getPayType());
+        }
+        res.setHouse(house);
+        return AjaxResult.success();
+    }
+
 }
 
diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/tool/TencentCosUtil.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/tool/TencentCosUtil.java
new file mode 100644
index 0000000..a492575
--- /dev/null
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/tool/TencentCosUtil.java
@@ -0,0 +1,108 @@
+package com.ruoyi.web.controller.tool;
+
+import com.qcloud.cos.COSClient;
+import com.qcloud.cos.ClientConfig;
+import com.qcloud.cos.auth.BasicCOSCredentials;
+import com.qcloud.cos.auth.COSCredentials;
+import com.qcloud.cos.http.HttpProtocol;
+import com.qcloud.cos.model.ObjectMetadata;
+import com.qcloud.cos.model.PutObjectResult;
+import com.qcloud.cos.region.Region;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.stereotype.Component;
+import org.springframework.web.multipart.MultipartFile;
+
+import java.io.InputStream;
+import java.util.UUID;
+
+/**
+ * @author HJL
+ */
+@Component
+public class TencentCosUtil {
+
+    /**
+     * COS的SecretId
+     */
+    @Value("${cos.client.accessKey}")
+    private String secretId;
+    /**
+     * COS的SecretKey
+     */
+    @Value("${cos.client.secretKey}")
+    private String secretKey;
+    /**
+     * 文件上传后访问路径的根路径,后面要最佳文件名字与类型
+     */
+    @Value("${cos.client.rootSrc}")
+    private String rootSrc;
+    /**
+     * 上传的存储桶的地域
+     */
+    @Value("${cos.client.bucketAddr}")
+    private String bucketAddr;
+    /**
+     * 存储桶的名字,是自己在存储空间自己创建的,我创建的名字是:qq-test-1303******
+     */
+    @Value("${cos.client.bucket}")
+    private String bucketName;
+
+    /**
+     * 1.调用静态方法getCosClient()就会获得COSClient实例
+     * 2.本方法根据永久密钥初始化 COSClient的,官方是不推荐,官方推荐使用临时密钥,是可以限制密钥使用权限,创建cred时有些区别
+     *
+     * @return COSClient实例
+     */
+    private COSClient getCosClient() {
+        // 1 初始化用户身份信息(secretId, secretKey)。
+        COSCredentials cred = new BasicCOSCredentials(secretId, secretKey);
+        // 2.1 设置存储桶的地域(上文获得)
+        Region region = new Region(bucketAddr);
+        ClientConfig clientConfig = new ClientConfig(region);
+        // 2.2 使用https协议传输
+        clientConfig.setHttpProtocol(HttpProtocol.https);
+        // 生成 cos 客户端
+        return new COSClient(cred, clientConfig);
+    }
+
+    /**
+     * 只要调用静态方法upLoadFile(MultipartFile multipartFile)就可以获取上传后文件的全路径
+     *
+     * @param file
+     * @return 返回文件的浏览全路径
+     */
+    public String upLoadFile(MultipartFile file) {
+        try {
+            // 获取上传的文件的输入流
+            InputStream inputStream = file.getInputStream();
+            // 避免文件覆盖,获取文件的原始名称,如123.jpg,然后通过截取获得文件的后缀,也就是文件的类型
+            String originalFilename = file.getOriginalFilename();
+            //获取文件的类型
+            String fileType = originalFilename.substring(originalFilename.lastIndexOf("."));
+            //使用UUID工具  创建唯一名称,放置文件重名被覆盖,在拼接上上命令获取的文件类型
+            String fileName = UUID.randomUUID() + fileType;
+            // 指定文件上传到 COS 上的路径,即对象键。最终文件会传到存储桶名字中的images文件夹下的fileName名字
+            String key = "xizang/" + fileName;
+            // 创建上传Object的Metadata
+            ObjectMetadata objectMetadata = new ObjectMetadata();
+            // - 使用输入流存储,需要设置请求长度
+            objectMetadata.setContentLength(inputStream.available());
+            // - 设置缓存
+            objectMetadata.setCacheControl("no-cache");
+            // - 设置Content-Type
+            objectMetadata.setContentType(fileType);
+            //上传文件
+            PutObjectResult putResult = getCosClient().putObject(bucketName, key, inputStream, objectMetadata);
+            // 创建文件的网络访问路径
+            String url = rootSrc + key;
+            //关闭 cosClient,并释放 HTTP 连接的后台管理线程
+            getCosClient().shutdown();
+            return url;
+        } catch (Exception e) {
+            e.printStackTrace();
+            // 发生IO异常、COS连接异常等,返回空
+            return null;
+        }
+    }
+
+}
\ No newline at end of file
diff --git a/ruoyi-admin/src/main/resources/application-prod.yml b/ruoyi-admin/src/main/resources/application-prod.yml
index d12c582..b90646c 100644
--- a/ruoyi-admin/src/main/resources/application-prod.yml
+++ b/ruoyi-admin/src/main/resources/application-prod.yml
@@ -206,3 +206,10 @@
     accessKeySecret: 0SRb6XGkciQDPWn2rYqbJtq2qRMDY8
     signName: "四川金达通信工程"
     templateCode: "SMS_293985284"
+cos:
+  client:
+    accessKey: AKIDCF5EF2c0DE1e5JK8r4EGJF4mNsMgp26x
+    secretKey: lLl184rUyFOOE0d5KNGC3kmfNsCWk4GU
+    bucket: xzgttest-1305134071
+    bucketAddr: ap-nanjing
+    rootSrc: https://cdn.hyhsbqgc.com/
\ No newline at end of file
diff --git a/ruoyi-admin/src/main/resources/application-test.yml b/ruoyi-admin/src/main/resources/application-test.yml
index 237700e..29bfa28 100644
--- a/ruoyi-admin/src/main/resources/application-test.yml
+++ b/ruoyi-admin/src/main/resources/application-test.yml
@@ -205,3 +205,10 @@
     accessKeySecret: 0SRb6XGkciQDPWn2rYqbJtq2qRMDY8
     signName: "四川金达通信工程"
     templateCode: "SMS_293985284"
+cos:
+  client:
+    accessKey: AKIDHVcchrvvtBiRJB25bHFFJc2Laq4NnHsY
+    secretKey: pgUGwX4Z1SrAPXYk1PxgXVem2HlRJG9k
+    bucketAddr: ap-nanjing
+    bucket: huishou-1323682843
+    rootSrc: https://cdn.hyhsbqgc.com/
\ No newline at end of file
diff --git a/ruoyi-system/pom.xml b/ruoyi-system/pom.xml
index 10998d3..f4f7c3b 100644
--- a/ruoyi-system/pom.xml
+++ b/ruoyi-system/pom.xml
@@ -16,7 +16,11 @@
     </description>
 
     <dependencies>
-
+        <dependency>
+            <groupId>com.qcloud</groupId>
+            <artifactId>cos_api</artifactId>
+            <version>5.6.227</version>
+        </dependency>
         <!-- 通用工具-->
         <dependency>
             <groupId>com.ruoyi</groupId>
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/dto/TContractDTO.java b/ruoyi-system/src/main/java/com/ruoyi/system/dto/TContractDTO.java
new file mode 100644
index 0000000..8bf0052
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/dto/TContractDTO.java
@@ -0,0 +1,29 @@
+package com.ruoyi.system.dto;
+
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.ruoyi.system.model.TContract;
+import com.ruoyi.system.model.TTenant;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+@Data
+@ApiModel(value = "合同新增编辑DTO")
+public class TContractDTO extends TContract {
+    @ApiModelProperty(value = "递增递减 1=递增 2=递减")
+    private Integer increasingDecreasing;
+
+    @ApiModelProperty(value = "递增递减形式 1=百分比 2=金额元")
+    private Integer increasingDecreasingType;
+
+    @ApiModelProperty(value = "数值")
+    private BigDecimal numericalValue;
+
+    @ApiModelProperty(value = "递增或递减时点")
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    private LocalDateTime changeTime;
+}
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/mapper/TContractMapper.java b/ruoyi-system/src/main/java/com/ruoyi/system/mapper/TContractMapper.java
index d5bc9f9..c1e5ef6 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/mapper/TContractMapper.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/mapper/TContractMapper.java
@@ -1,7 +1,12 @@
 package com.ruoyi.system.mapper;
 
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.system.model.TContract;
+import com.ruoyi.system.query.TContractQuery;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
 
 /**
  * <p>
@@ -13,4 +18,5 @@
  */
 public interface TContractMapper extends BaseMapper<TContract> {
 
+    List<TContract> contractList(@Param("req") TContractQuery query, @Param("pageInfo") PageInfo<TContract> pageInfo);
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/model/TContract.java b/ruoyi-system/src/main/java/com/ruoyi/system/model/TContract.java
index 6dc8972..6de4952 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/model/TContract.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/model/TContract.java
@@ -114,7 +114,7 @@
     @TableField("party_two_phone")
     private String partyTwoPhone;
 
-    @ApiModelProperty(value = "合同附件")
+    @ApiModelProperty(value = "合同附件,多个逗号拼接")
     @TableField("contract_file")
     private String contractFile;
 
@@ -122,7 +122,7 @@
     @TableField("remark")
     private String remark;
 
-    @ApiModelProperty(value = "状态 1=待审批 2=未签订 3=已签订")
+    @ApiModelProperty(value = "状态 1=待提交 2=待审批 3=未签订 4=已签订")
     @TableField("status")
     private Integer status;
 
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/model/TContractRentType.java b/ruoyi-system/src/main/java/com/ruoyi/system/model/TContractRentType.java
index 35d8311..f3f45ae 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/model/TContractRentType.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/model/TContractRentType.java
@@ -6,7 +6,9 @@
 import com.baomidou.mybatisplus.annotation.TableField;
 import java.io.Serializable;
 import java.math.BigDecimal;
+import java.time.LocalDateTime;
 
+import com.fasterxml.jackson.annotation.JsonFormat;
 import io.swagger.annotations.ApiModel;
 import io.swagger.annotations.ApiModelProperty;
 import lombok.Data;
@@ -47,5 +49,10 @@
     @TableField("numerical_value")
     private BigDecimal numericalValue;
 
+    @ApiModelProperty(value = "递增或递减时点")
+    @TableField("change_time")
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    private LocalDateTime changeTime;
+
 
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/model/THouse.java b/ruoyi-system/src/main/java/com/ruoyi/system/model/THouse.java
index 9655c8e..5c30185 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/model/THouse.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/model/THouse.java
@@ -87,7 +87,8 @@
     @ApiModelProperty(value = "房号")
     @TableField("room_number")
     private String roomNumber;
-    @ApiModelProperty(value = "租户类型 1月付 2季付 3年付")
+
+    @ApiModelProperty(value = "住户类型 1月租 2季租 3年租")
     @TableField(exist = false)
-    private String tenantType;
+    private Integer tenantType;
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/query/TContractQuery.java b/ruoyi-system/src/main/java/com/ruoyi/system/query/TContractQuery.java
new file mode 100644
index 0000000..5d90194
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/query/TContractQuery.java
@@ -0,0 +1,19 @@
+package com.ruoyi.system.query;
+
+import com.ruoyi.common.core.domain.BasePage;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "合同分页列表查询Query")
+public class TContractQuery extends BasePage {
+    @ApiModelProperty(value = "乙方名称")
+    private String partyTwoName;
+    @ApiModelProperty(value = "合同编号")
+    private String contractNumber;
+    @ApiModelProperty(value = "合同名称")
+    private Integer contractName;
+    @ApiModelProperty(value = "合同状态 1=待提交 2=待审批 3=未签订 4=已签订")
+    private Integer status;
+}
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/TContractService.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/TContractService.java
index 1cb1fd5..b580ba2 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/TContractService.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/TContractService.java
@@ -1,7 +1,9 @@
 package com.ruoyi.system.service;
 
 import com.baomidou.mybatisplus.extension.service.IService;
+import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.system.model.TContract;
+import com.ruoyi.system.query.TContractQuery;
 
 /**
  * <p>
@@ -13,4 +15,5 @@
  */
 public interface TContractService extends IService<TContract> {
 
+    PageInfo<TContract> contractList(TContractQuery query);
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TContractServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TContractServiceImpl.java
index f598310..1cb2a34 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TContractServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TContractServiceImpl.java
@@ -1,10 +1,15 @@
 package com.ruoyi.system.service.impl;
 
+import com.ruoyi.common.basic.PageInfo;
 import com.ruoyi.system.mapper.TContractMapper;
 import com.ruoyi.system.model.TContract;
+import com.ruoyi.system.model.TTenant;
+import com.ruoyi.system.query.TContractQuery;
 import com.ruoyi.system.service.TContractService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import org.springframework.stereotype.Service;
+
+import java.util.List;
 
 /**
  * <p>
@@ -17,4 +22,12 @@
 @Service
 public class TContractServiceImpl extends ServiceImpl<TContractMapper, TContract> implements TContractService {
 
+    @Override
+    public PageInfo<TContract> contractList(TContractQuery query) {
+        PageInfo<TContract> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
+        List<TContract> list = this.baseMapper.contractList(query,pageInfo);
+        pageInfo.setRecords(list);
+        return pageInfo;
+
+    }
 }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/THouseServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/THouseServiceImpl.java
index 594e1e1..436ae5f 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/THouseServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/THouseServiceImpl.java
@@ -1,7 +1,10 @@
 package com.ruoyi.system.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.ruoyi.common.basic.PageInfo;
+import com.ruoyi.system.mapper.TContractMapper;
 import com.ruoyi.system.mapper.THouseMapper;
+import com.ruoyi.system.model.TContract;
 import com.ruoyi.system.model.THouse;
 import com.ruoyi.system.query.THouseQuery;
 import com.ruoyi.system.query.TUserHistoryQuery;
@@ -10,6 +13,8 @@
 import com.ruoyi.system.vo.HouseVO;
 import org.springframework.stereotype.Service;
 
+import javax.annotation.Resource;
+import java.time.LocalDateTime;
 import java.util.List;
 
 /**
@@ -22,11 +27,22 @@
  */
 @Service
 public class THouseServiceImpl extends ServiceImpl<THouseMapper, THouse> implements THouseService {
-
+    @Resource
+    private TContractMapper contractMapper;
     @Override
     public PageInfo<THouse> houseList(THouseQuery query) {
         PageInfo<THouse> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
         List<THouse> list = this.baseMapper.houseList(query,pageInfo);
+        List<TContract> tContracts = contractMapper.selectList(new LambdaQueryWrapper<TContract>()
+                .eq(TContract::getStatus, 4)
+                .le(TContract::getStartTime, LocalDateTime.now())
+                .ge(TContract::getEndTime, LocalDateTime.now()));
+        for (THouse tHouse : list) {
+            TContract tContract = tContracts.stream().filter(e -> e.getHouseId().equals(tHouse.getId())).findFirst().orElse(null);
+            if (tContract!=null){
+                tHouse.setTenantType(tContract.getPayType());
+            }
+        }
         pageInfo.setRecords(list);
         return pageInfo;
     }
diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/vo/TContractVO.java b/ruoyi-system/src/main/java/com/ruoyi/system/vo/TContractVO.java
new file mode 100644
index 0000000..ce55215
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/vo/TContractVO.java
@@ -0,0 +1,35 @@
+package com.ruoyi.system.vo;
+
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.ruoyi.system.model.TContract;
+import com.ruoyi.system.model.THouse;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.time.LocalDateTime;
+
+@Data
+@ApiModel(value = "合同详情页VO")
+public class TContractVO extends TContract {
+
+
+    @ApiModelProperty(value = "递增递减 1=递增 2=递减")
+    private Integer increasingDecreasing;
+
+    @ApiModelProperty(value = "递增递减形式 1=百分比 2=金额元")
+    private Integer increasingDecreasingType;
+
+    @ApiModelProperty(value = "数值")
+    private BigDecimal numericalValue;
+
+    @ApiModelProperty(value = "递增或递减时点")
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    private LocalDateTime changeTime;
+
+    @ApiModelProperty(value = "房屋信息")
+    private THouse house;
+}
diff --git a/ruoyi-system/src/main/resources/mapper/system/TContractMapper.xml b/ruoyi-system/src/main/resources/mapper/system/TContractMapper.xml
index 6531e6f..27b7137 100644
--- a/ruoyi-system/src/main/resources/mapper/system/TContractMapper.xml
+++ b/ruoyi-system/src/main/resources/mapper/system/TContractMapper.xml
@@ -38,5 +38,22 @@
     <sql id="Base_Column_List">
         id, contract_number, contract_name, start_time, end_time, total_rent, deposit, pay_type, first_pay_time, isIncreasing, isIncreasing_deposit, proportion, house_id, party_one_name, party_one_person, party_one_phone, tenant_id, party_two_name, party_two_person, party_two_phone, contract_file, remark, status, create_time, update_time, create_by, update_by, disabled
     </sql>
+    <select id="contractList" resultType="com.ruoyi.system.model.TContract">
+        select t1.* from t_contract t1
+        <where>
+            <if test="query.partyTwoName != null and query.partyTwoName != ''">
+                and t1.party_two_name like concat('%',#{query.partyTwoName},'%')
+            </if>
+            <if test="query.contractNumber != null and query.contractNumber != ''">
+                and t1.contract_number like concat('%',#{query.contractNumber},'%')
+            </if>
+             <if test="query.contractName != null and query.contractName != ''">
+                and t1.contract_name like concat('%',#{query.contractName},'%')
+            </if>
+            <if test="query.status != null">
+                and t1.status = #{query.status}
+            </if>
+        </where>
+    </select>
 
 </mapper>

--
Gitblit v1.7.1