From 4c01f95906b62248cc4428d85a323ad64b9fa255 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期三, 22 一月 2025 10:58:44 +0800
Subject: [PATCH] 房屋

---
 ruoyi-system/src/main/java/com/ruoyi/system/model/TContractRentType.java        |    7 +
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TContractController.java |   96 +++++++++++++++--------
 ruoyi-system/src/main/java/com/ruoyi/system/dto/TContractDTO.java               |   29 +++++++
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/THouseServiceImpl.java |   18 ++++
 ruoyi-system/src/main/java/com/ruoyi/system/model/TContract.java                |    4 
 ruoyi-system/src/main/java/com/ruoyi/system/vo/TContractVO.java                 |   31 +++++++
 ruoyi-system/src/main/java/com/ruoyi/system/model/THouse.java                   |    3 
 7 files changed, 151 insertions(+), 37 deletions(-)

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..e2d0e9e 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,31 @@
 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.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 com.ruoyi.system.vo.TContractVO;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.validation.annotation.Validated;
 import org.springframework.web.bind.annotation.*;
+
+import java.util.Arrays;
 
 /**
  * <p>
@@ -32,39 +41,58 @@
 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;
+    @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) {
+        return AjaxResult.success(contractService.getById(id));
+    }
+
 }
 
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/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 ba521cd..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
@@ -88,4 +88,7 @@
     @TableField("room_number")
     private String roomNumber;
 
+    @ApiModelProperty(value = "住户类型 1月租 2季租 3年租")
+    @TableField(exist = false)
+    private Integer tenantType;
 }
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..2ed5a54
--- /dev/null
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/vo/TContractVO.java
@@ -0,0 +1,31 @@
+package com.ruoyi.system.vo;
+
+import com.baomidou.mybatisplus.annotation.TableField;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import com.ruoyi.system.model.TContract;
+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;
+
+}

--
Gitblit v1.7.1