From 2dc084ab3aa5f95cf8317c9d24b7611f8b85bcfa Mon Sep 17 00:00:00 2001 From: luofl <1442745593@qq.com> Date: 星期一, 31 三月 2025 14:04:11 +0800 Subject: [PATCH] 1.租户数量趋势统计 --- ruoyi-admin/src/main/java/com/ruoyi/web/controller/api/ScreenController.java | 189 +++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 156 insertions(+), 33 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 b7ad97b..b426f37 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,33 +1,36 @@ 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; +import com.ruoyi.system.model.TBill; import com.ruoyi.system.model.TContract; +import com.ruoyi.system.model.THouse; +import com.ruoyi.system.model.TStreet; +import com.ruoyi.system.service.ITStreetService; +import com.ruoyi.system.service.TBillService; import com.ruoyi.system.service.TContractService; -import com.ruoyi.common.core.domain.R; +import com.ruoyi.system.service.THouseService; import com.ruoyi.system.service.impl.ScreenService; -import com.ruoyi.system.vo.TenantCountTrendVO; -import com.ruoyi.system.vo.ScreenRentRankVO; -import com.ruoyi.system.vo.ScreenTopStaticsDataVO; +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.web.bind.annotation.GetMapping; import org.springframework.context.annotation.Lazy; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; -import java.text.DateFormat; +import java.math.BigDecimal; +import java.time.LocalDate; import java.time.LocalDateTime; +import java.time.YearMonth; import java.time.format.DateTimeFormatter; -import java.time.format.DateTimeFormatterBuilder; -import java.util.List; -import java.util.Map; +import java.time.temporal.ChronoUnit; +import java.util.*; import java.util.stream.Collectors; - -import java.util.List; /** * @author mitao @@ -39,42 +42,162 @@ @RequiredArgsConstructor(onConstructor_ = {@Lazy}) public class ScreenController { private final ScreenService screenService; + private final TContractService contractService; + private final THouseService houseService; + private final ITStreetService streetService; + private final TBillService billService; + @GetMapping("/statics-data") @ApiOperation(value = "获取顶部统计数据") public R<ScreenTopStaticsDataVO> getTopStaticsData() { return R.ok(screenService.getTopStaticsData()); } - @ApiOperation("区域租金排名") - @GetMapping("/rent-rank") - public R<List<ScreenRentRankVO>> rentRank() { - return R.ok(screenService.rentRank()); - } - private final TContractService contractService; + @GetMapping("/rent-rank") + @ApiOperation("区域租金排名") + public R<List<ScreenRentRankVO>> rentRank() { + return R.ok(screenService.streetRentRank()); + } + + @GetMapping("/rent-income-trend") + @ApiOperation("租金收入趋势") + public R<ScreenRentIncomeTrendVO> rentIncomeTrend() { + return R.ok(screenService.rentIncomeTrend()); + } @GetMapping("/getTenantCountTrend") - @ApiModelProperty(value = "租户数量趋势统计") - public R<?> getTenantCountTrend() { - // 获取所有签约时间不为空的合同 - List<TContract> contracts = contractService.list(new LambdaQueryWrapper<TContract>() - .isNotNull(TContract::getSignTime)); + @ApiOperation(value = "租户数量趋势统计") + public R<List<TenantCountTrendVO>> getTenantCountTrend() { - // 使用年-月格式化日期,并按此分组计算每个时间段的合同数量 - DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yy-M"); + Date currentDate = new Date(); + Date targetDate = DateUtils.addMonths(currentDate, -3 * 6); + Map<String, Date> startQuarterDate = DateUtils.getQuarterDate(targetDate); + + Date targetDate2 = DateUtils.addMonths(currentDate, 0); + Map<String, Date> endQuarterDate = DateUtils.getQuarterDate(targetDate2); + + List<TContract> contracts = contractService.list(new LambdaQueryWrapper<TContract>() + .isNotNull(TContract::getSignTime) + .between(TContract::getSignTime, startQuarterDate.get("first"), endQuarterDate.get("last")) + .orderByAsc(TContract::getSignTime)); + + // 创建季度格式化工具(示例:2025-Q1) + DateTimeFormatter quarterFormatter = DateTimeFormatter.ofPattern("yyyy-'Q'Q"); List<TenantCountTrendVO> trendData = contracts.stream() - .collect(Collectors.groupingBy(contract -> contract.getSignTime().toLocalDate() - .withDayOfMonth(1) // 将日期调整为该月的第一天,以便正确分组 - .atStartOfDay())) + .collect(Collectors.groupingBy(contract -> { + LocalDate date = contract.getSignTime().toLocalDate(); + int quarter = (date.getMonthValue() - 1) / 3 + 1; + return YearQuarter.from(date.withMonth(quarter * 3 - 2)); + }, TreeMap::new, Collectors.counting())) .entrySet().stream() - .map(entry -> { - String period = entry.getKey().format(formatter); - long count = entry.getValue().size(); - return new TenantCountTrendVO(period, count); - }) + .map(entry -> new TenantCountTrendVO( + entry.getKey().format(quarterFormatter), + entry.getValue())) .collect(Collectors.toList()); return R.ok(trendData); } + + /** + * 实时租赁数据 + */ + @GetMapping("/getRealTimeRentData") + @ApiOperation("获取实时租赁数据") + public R<List<RealTimeRentDataVO>> getRealTimeRentData() { + // 随机获取十条房源 + List<THouse> houses = houseService.list(new LambdaQueryWrapper<THouse>() + .last("ORDER BY RAND() LIMIT 10")); + + + // 提取streetIds + List<String> streetIds = houses.stream() + .map(THouse::getStreetId) + .collect(Collectors.toList()); + + // 获取街道信息 + Map<String, String> streetMap = streetService.listByIds(streetIds).stream() + .collect(Collectors.toMap(TStreet::getId, TStreet::getStreetName)); + + // 转换为返回格式 + List<RealTimeRentDataVO> result = houses.stream().map(house -> { + RealTimeRentDataVO vo = new RealTimeRentDataVO(); + vo.setStreetName(streetMap.getOrDefault(house.getStreetId(), "未知")); + vo.setRoomName(house.getRoomNumber()); + vo.setLeaseStatus(house.getLeaseStatus()); + return vo; + }).collect(Collectors.toList()); + + return R.ok(result); + } + + /** + * 获取房屋地图分布 + */ + @GetMapping("/getHouseMapDistribution") + @ApiOperation("获取房屋地图分布") + public R<List<HouseMapDistributionVO>> getHouseMapDistribution() { + // 获取所有房屋信息 + List<THouse> houses = houseService.list(); + List<HouseMapDistributionVO> result = new ArrayList<>(); + for (THouse house : houses) { + HouseMapDistributionVO houseMapDistributionVO = new HouseMapDistributionVO(); + houseMapDistributionVO.setHouseName(house.getHouseName()); + houseMapDistributionVO.setHouseAddress(house.getHouseAddress()); + houseMapDistributionVO.setHouseStatus(house.getLeaseStatus()); + houseMapDistributionVO.setLongitude(house.getLongitude()); + houseMapDistributionVO.setLatitude(house.getLatitude()); + TContract contract = contractService.getOne(new LambdaQueryWrapper<TContract>() + .gt(TContract::getEndTime, LocalDate.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, LocalDate.now()) + .ge(TBill::getEndTime, LocalDate.now()) + .eq(TBill::getBillType, 1) + .eq(TBill::getContractId, contract.getId())); + + if (one != null && "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); + } } -- Gitblit v1.7.1