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/api/TContractController.java | 125 ++++++++++++++++++++++++++++++----------- 1 files changed, 91 insertions(+), 34 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..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(); + } + } -- Gitblit v1.7.1