From 592ac14eba76040426f590d8eb079fc75e968b84 Mon Sep 17 00:00:00 2001 From: luofl <1442745593@qq.com> Date: 星期五, 28 三月 2025 19:18:37 +0800 Subject: [PATCH] 1.租户数量趋势统计 --- ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/ScreenController.java | 136 ++++++++++++++++++--------------------------- 1 files changed, 54 insertions(+), 82 deletions(-) diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/ScreenController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/ScreenController.java index c65a613..d8d82e6 100644 --- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/ScreenController.java +++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/ScreenController.java @@ -1,5 +1,7 @@ package com.ruoyi.web.controller.api; +import com.alibaba.fastjson2.JSONArray; +import com.alibaba.fastjson2.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.utils.DateUtils; @@ -14,7 +16,6 @@ import com.ruoyi.system.service.impl.ScreenService; import com.ruoyi.system.vo.*; import io.swagger.annotations.Api; -import io.swagger.annotations.ApiModelProperty; import io.swagger.annotations.ApiOperation; import lombok.RequiredArgsConstructor; import org.springframework.context.annotation.Lazy; @@ -65,7 +66,7 @@ } @GetMapping("/getTenantCountTrend") - @ApiModelProperty(value = "租户数量趋势统计") + @ApiOperation(value = "租户数量趋势统计") public R<List<TenantCountTrendVO>> getTenantCountTrend() { Date currentDate = new Date(); @@ -98,10 +99,12 @@ return R.ok(trendData); } + /** * 实时租赁数据 */ @GetMapping("/getRealTimeRentData") + @ApiOperation("获取实时租赁数据") public R<List<RealTimeRentDataVO>> getRealTimeRentData() { // 随机获取十条房源 List<THouse> houses = houseService.list(new LambdaQueryWrapper<THouse>() @@ -133,6 +136,7 @@ * 获取房屋地图分布 */ @GetMapping("/getHouseMapDistribution") + @ApiOperation("获取房屋地图分布") public R<List<HouseMapDistributionVO>> getHouseMapDistribution() { // 获取所有房屋信息 List<THouse> houses = houseService.list(); @@ -142,90 +146,58 @@ houseMapDistributionVO.setHouseName(house.getHouseName()); houseMapDistributionVO.setHouseAddress(house.getHouseAddress()); houseMapDistributionVO.setHouseStatus(house.getLeaseStatus()); - TContract contract = contractService.getOne(new LambdaQueryWrapper<TContract>() - .eq(TContract::getHouseId, house.getId())); - TBill bill = billService.getOne(new LambdaQueryWrapper<TBill>() - .eq(TBill::getContractId, contract.getId()) - .eq(TBill::getBillType, 1)); - - - houseMapDistributionVO.setTenant(contract.getPartyTwoName()); - - - LocalDateTime startTime = contract.getStartTime(); - LocalDateTime endTime = contract.getEndTime(); - BigDecimal monthRent = contract.getMonthRent(); - // 计算相差月份 - long monthsBetween = ChronoUnit.MONTHS.between(startTime, endTime); - BigDecimal payableFeesMoney = monthRent.multiply(new BigDecimal(monthsBetween)); - BigDecimal remainingPayment = bill.getPayableFeesMoney(); - BigDecimal paidAlready = payableFeesMoney.subtract(remainingPayment); - String rentStatus = String.format("%.2f/%.2f", paidAlready, payableFeesMoney); - houseMapDistributionVO.setRentStatus(rentStatus); - - String payType = contract.getPayType(); - String rent = ""; - LocalDateTime payFeesTime = bill.getPayFeesTime(); - switch (payType) { - case "1": - if (isCurrentMonth(payFeesTime)) { - rent = String.format("%.2f/%.2f", monthRent, monthRent); - } else { - rent = String.format("%.2f/%.2f", new BigDecimal("0"), monthRent); - } - break; - case "2": - // 季付价格 - BigDecimal quarterRent = monthRent.multiply(new BigDecimal(3)); - if (isCurrentQuarter(payFeesTime)) { - rent = String.format("%.2f/%.2f", quarterRent, quarterRent); - } else { - rent = String.format("%.2f/%.2f", new BigDecimal("0"), quarterRent); - } - break; - case "3": - // 年付价格 - BigDecimal yearRent = monthRent.multiply(new BigDecimal(12)); - if (isCurrentYear(payFeesTime)) { - rent = String.format("%.2f/%.2f", yearRent, yearRent); - } else { - rent = String.format("%.2f/%.2f", new BigDecimal("0"), yearRent); - } - break; - } - houseMapDistributionVO.setRent(rent); houseMapDistributionVO.setLongitude(house.getLongitude()); houseMapDistributionVO.setLatitude(house.getLatitude()); + TContract contract = contractService.getOne(new LambdaQueryWrapper<TContract>() + .gt(TContract::getEndTime, LocalDateTime.now()) + .eq(TContract::getHouseId, house.getId()) + .eq(TContract::getStatus, 4) + .last("limit 1")); + + if (contract != null){ + List<TBill> tBills = billService.list(new LambdaQueryWrapper<TBill>() + .eq(TBill::getContractId, contract.getId()) + .eq(TBill::getBillType, 1)); + houseMapDistributionVO.setTenant(contract.getPartyTwoName()); + LocalDateTime startTime = contract.getStartTime(); + LocalDateTime endTime = contract.getEndTime(); + BigDecimal monthRent = contract.getMonthRent(); + // 计算相差月份 + long monthsBetween = ChronoUnit.MONTHS.between(startTime, endTime); + BigDecimal payableFeesMoney = monthRent.multiply(new BigDecimal(monthsBetween)); + + BigDecimal paidAlready = tBills.stream() + .map(TBill::getPayableFeesMoney) + .reduce(BigDecimal::add) + .orElse(BigDecimal.ZERO); + String rentStatus = String.format("%.2f/%.2f", paidAlready, payableFeesMoney); + houseMapDistributionVO.setRentStatus(rentStatus); + + + TBill one = billService.getOne(new LambdaQueryWrapper<TBill>() + .le(TBill::getStartTime, LocalDateTime.now()) + .gt(TBill::getEndTime, LocalDateTime.now()) + .eq(TBill::getBillType, 1) + .eq(TBill::getContractId, contract.getId())); + + if ("4".equals(one.getPayFeesStatus())){ + houseMapDistributionVO.setHouseStatus("4"); + } + + + + BigDecimal payFeesMoney = one.getPayFeesMoney(); + BigDecimal payableFeesMoney1 = one.getPayableFeesMoney(); + String rent = String.format("%.2f/%.2f", payFeesMoney, payableFeesMoney1); + + houseMapDistributionVO.setRent(rent); + }else { + houseMapDistributionVO.setTenant("暂无"); + houseMapDistributionVO.setRentStatus("暂无"); + houseMapDistributionVO.setRent("暂无"); + } result.add(houseMapDistributionVO); } return R.ok(result); } - - - /** - * 判断是否是当前月份 - * @param dateTime 日期时间 - * @return boolean - */ - public static boolean isCurrentMonth(LocalDateTime dateTime) { - YearMonth currentYearMonth = YearMonth.now(); - YearMonth targetYearMonth = YearMonth.from(dateTime); - return currentYearMonth.equals(targetYearMonth); - } - - public static boolean isCurrentQuarter(LocalDateTime dateTime) { - int currentMonth = LocalDateTime.now().getMonthValue(); - int targetMonth = dateTime.getMonthValue(); - - // 计算当前季度和目标时间所属季度 - int currentQuarter = (currentMonth - 1) / 3 + 1; - int targetQuarter = (targetMonth - 1) / 3 + 1; - - return LocalDateTime.now().getYear() == dateTime.getYear() && currentQuarter == targetQuarter; - } - - public static boolean isCurrentYear(LocalDateTime dateTime) { - return LocalDateTime.now().getYear() == dateTime.getYear(); - } - } -- Gitblit v1.7.1