From 158210c9f5f06e3d763bf258f66fc5aacd924733 Mon Sep 17 00:00:00 2001
From: xuhy <3313886187@qq.com>
Date: 星期四, 13 二月 2025 12:19:37 +0800
Subject: [PATCH] 后台报修,房屋验收管理

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCheckAcceptRecordController.java |  124 ++++++++++++++++++++++++++++++++++++++++
 1 files changed, 122 insertions(+), 2 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCheckAcceptRecordController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCheckAcceptRecordController.java
index 6cdd012..b6dee08 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCheckAcceptRecordController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/TCheckAcceptRecordController.java
@@ -1,9 +1,28 @@
 package com.ruoyi.web.controller.api;
 
 
-import org.springframework.web.bind.annotation.RequestMapping;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.ruoyi.common.annotation.Log;
+import com.ruoyi.common.basic.PageInfo;
+import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.enums.BusinessType;
+import com.ruoyi.system.model.TCheckAcceptRecord;
+import com.ruoyi.system.model.TContract;
+import com.ruoyi.system.model.THouse;
+import com.ruoyi.system.query.TCheckAcceptRecordQuery;
+import com.ruoyi.system.service.TCheckAcceptRecordService;
+import com.ruoyi.system.service.TContractService;
+import com.ruoyi.system.service.THouseService;
+import com.ruoyi.system.vo.TCheckAcceptRecordVO;
+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.security.access.prepost.PreAuthorize;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
 
-import org.springframework.web.bind.annotation.RestController;
+import java.util.List;
 
 /**
  * <p>
@@ -13,9 +32,110 @@
  * @author xiaochen
  * @since 2025-01-17
  */
+@Api(tags = "验收记录管理")
 @RestController
 @RequestMapping("/t-check-accept-record")
 public class TCheckAcceptRecordController {
 
+    private final TCheckAcceptRecordService checkAcceptRecordService;
+    private final TContractService contractService;
+    private final THouseService houseService;
+    @Autowired
+    public TCheckAcceptRecordController(TCheckAcceptRecordService checkAcceptRecordService, TContractService contractService, THouseService houseService) {
+        this.checkAcceptRecordService = checkAcceptRecordService;
+        this.contractService = contractService;
+        this.houseService = houseService;
+    }
+
+    /**
+     * 获取验收记录管理列表
+     */
+    @PreAuthorize("@ss.hasPermi('system:accept:list')")
+    @ApiOperation(value = "获取验收记录分页列表")
+    @PostMapping(value = "/pageList")
+    public R<PageInfo<TCheckAcceptRecordVO>> pageList(@RequestBody TCheckAcceptRecordQuery query) {
+        return R.ok(checkAcceptRecordService.pageList(query));
+    }
+
+    /**
+     * 通过合同id查询房屋信息
+     */
+    @ApiOperation(value = "通过合同id查询房屋信息")
+    @PostMapping(value = "/getHouseByContractId")
+    public R<THouse> getHouseByContractId(@RequestParam String contractId) {
+        TContract contract = contractService.getById(contractId);
+        THouse house = houseService.getById(contract.getHouseId());
+        return R.ok(house);
+    }
+
+    /**
+     * 通过房屋id查询合同信息
+     */
+    @ApiOperation(value = "通过房屋id查询合同信息")
+    @PostMapping(value = "/getContractByHouseId")
+    public R<TContract> getContractByHouseId(@RequestParam String houseId) {
+        TContract contract = contractService.getOne(Wrappers.lambdaQuery(TContract.class)
+                .eq(TContract::getHouseId, houseId)
+                .orderByDesc(TContract::getCreateTime)
+                .in(TContract::getStatus, 4, 6, 7)
+                .last("LIMIT 1"));
+        return R.ok(contract);
+    }
+
+    /**
+     * 添加验收记录管理
+     */
+    @PreAuthorize("@ss.hasPermi('system:accept:add')")
+    @Log(title = "验收记录信息-新增验收记录", businessType = BusinessType.INSERT)
+    @ApiOperation(value = "添加验收记录")
+    @PostMapping(value = "/add")
+    public R<Boolean> add(@Validated @RequestBody TCheckAcceptRecord dto) {
+        // 添加验收记录
+        checkAcceptRecordService.save(dto);
+
+        // TODO 生成结算帐单
+
+        return R.ok();
+    }
+
+    /**
+     * 查看验收记录详情
+     */
+    @PreAuthorize("@ss.hasPermi('system:accept:detail')")
+    @ApiOperation(value = "查看验收记录详情")
+    @GetMapping(value = "/getDetailById")
+    public R<TCheckAcceptRecordVO> getDetailById(@RequestParam String id) {
+        TCheckAcceptRecord checkAcceptRecord = checkAcceptRecordService.getById(id);
+        TCheckAcceptRecordVO checkAcceptRecordVO = new TCheckAcceptRecordVO();
+        BeanUtils.copyProperties(checkAcceptRecord, checkAcceptRecordVO);
+        // 查询合同信息
+        checkAcceptRecordVO.setContract(contractService.getById(checkAcceptRecord.getContractId()));
+        // 查询房屋信息
+        checkAcceptRecordVO.setHouse(houseService.getById(checkAcceptRecord.getHouseId()));
+        return R.ok(checkAcceptRecordVO);
+    }
+
+    /**
+     * 删除验收记录
+     */
+    @PreAuthorize("@ss.hasPermi('system:accept:delete')")
+    @Log(title = "验收记录信息-删除验收记录", businessType = BusinessType.DELETE)
+    @ApiOperation(value = "删除验收记录")
+    @DeleteMapping(value = "/deleteById")
+    public R<Boolean> deleteById(@RequestParam String id) {
+        return R.ok(checkAcceptRecordService.removeById(id));
+    }
+
+    /**
+     * 批量删除验收记录
+     */
+    @PreAuthorize("@ss.hasPermi('system:accept:delete')")
+    @Log(title = "验收记录信息-删除验收记录", businessType = BusinessType.DELETE)
+    @ApiOperation(value = "批量删除验收记录")
+    @DeleteMapping(value = "/deleteByIds")
+    public R<Boolean> deleteByIds(@RequestBody List<String> ids) {
+        return R.ok(checkAcceptRecordService.removeByIds(ids));
+    }
+
 }
 

--
Gitblit v1.7.1