|  |  |  | 
|---|
|  |  |  | package com.ruoyi.chargingPile.controller; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import cn.afterturn.easypoi.excel.ExcelExportUtil; | 
|---|
|  |  |  | import cn.afterturn.easypoi.excel.entity.ExportParams; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | 
|---|
|  |  |  | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.model.TParkingLot; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.model.TParkingRecord; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.vo.GetParkingRecord; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.query.ParkingRecordQuery; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.api.vo.*; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.dto.ParkingRecordPageQuery; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.dto.ParkingRecordQueryDto; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.export.TParkingRecordExport; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.service.TParkingLotService; | 
|---|
|  |  |  | import com.ruoyi.chargingPile.service.TParkingRecordService; | 
|---|
|  |  |  | import com.ruoyi.common.core.domain.R; | 
|---|
|  |  |  | import com.ruoyi.common.core.utils.DateUtils; | 
|---|
|  |  |  | import com.ruoyi.common.core.utils.WebUtils; | 
|---|
|  |  |  | import com.ruoyi.common.core.web.domain.AjaxResult; | 
|---|
|  |  |  | import com.ruoyi.common.core.web.page.PageInfo; | 
|---|
|  |  |  | import com.ruoyi.common.log.annotation.Log; | 
|---|
|  |  |  | import com.ruoyi.common.log.enums.BusinessType; | 
|---|
|  |  |  | import com.ruoyi.common.log.enums.OperatorType; | 
|---|
|  |  |  | import com.ruoyi.order.api.query.TOrderInvoiceQuery; | 
|---|
|  |  |  | import com.ruoyi.order.api.vo.TCharingUserEquimentVO; | 
|---|
|  |  |  | import com.ruoyi.order.api.vo.TOrderInvoiceVO; | 
|---|
|  |  |  | import io.swagger.annotations.ApiOperation; | 
|---|
|  |  |  | import org.apache.poi.ss.usermodel.Workbook; | 
|---|
|  |  |  | import org.springframework.beans.BeanUtils; | 
|---|
|  |  |  | import org.springframework.web.bind.annotation.*; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  | import javax.servlet.ServletOutputStream; | 
|---|
|  |  |  | import javax.servlet.http.HttpServletResponse; | 
|---|
|  |  |  | import java.io.IOException; | 
|---|
|  |  |  | import java.math.BigDecimal; | 
|---|
|  |  |  | import java.net.URLEncoder; | 
|---|
|  |  |  | import java.time.LocalDate; | 
|---|
|  |  |  | import java.time.format.DateTimeFormatter; | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.HashMap; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * <p> | 
|---|
|  |  |  | 
|---|
|  |  |  | return R.ok(page); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @ApiOperation(tags = {"后台-订单管理-停车记录"},value = "停车缴费订单列表") | 
|---|
|  |  |  | @PostMapping(value = "/pageList") | 
|---|
|  |  |  | public R<TParkingRecordPageInfoVO> pageList(@RequestBody ParkingRecordQuery query) { | 
|---|
|  |  |  | return R.ok(parkingRecordService.pageList(query)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @ApiOperation(tags = {"后台-订单管理-停车记录"},value = "导出") | 
|---|
|  |  |  | @PutMapping("/export") | 
|---|
|  |  |  | @Log(title = "【停车记录】导出停车记录", businessType = BusinessType.EXPORT,operatorType = OperatorType.MANAGE) | 
|---|
|  |  |  | public void export(@RequestBody ParkingRecordQuery query) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | List<TParkingRecordVO> records = parkingRecordService.pageList(query).getParkingRecordVOS().getRecords(); | 
|---|
|  |  |  | List<TParkingRecordExport> orderInvoiceExports = new ArrayList<>(); | 
|---|
|  |  |  | for (TParkingRecordVO orderInvoiceVO : records) { | 
|---|
|  |  |  | TParkingRecordExport orderInvoiceExport = new TParkingRecordExport(); | 
|---|
|  |  |  | BeanUtils.copyProperties(orderInvoiceVO,orderInvoiceExport); | 
|---|
|  |  |  | if (orderInvoiceVO.getFreeDuration()!=null){ | 
|---|
|  |  |  | orderInvoiceExport.setParkingDuration(orderInvoiceVO.getParkingDuration()-orderInvoiceVO.getFreeDuration()); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | orderInvoiceExport.setParkingDuration(orderInvoiceVO.getParkingDuration()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (orderInvoiceVO.getTimeoutAmount()!=null){ | 
|---|
|  |  |  | orderInvoiceExport.setAmount(orderInvoiceVO.getOrderAmount().subtract(orderInvoiceVO.getTimeoutAmount())); | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | orderInvoiceExport.setAmount(orderInvoiceVO.getOrderAmount()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | orderInvoiceExports.add(orderInvoiceExport); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams(), TParkingRecordExport.class, orderInvoiceExports); | 
|---|
|  |  |  | HttpServletResponse response = WebUtils.response(); | 
|---|
|  |  |  | response.setContentType("application/vnd.ms-excel"); | 
|---|
|  |  |  | response.setCharacterEncoding("utf-8"); | 
|---|
|  |  |  | ServletOutputStream outputStream = null; | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | String fileName = URLEncoder.encode("停车记录.xls", "utf-8"); | 
|---|
|  |  |  | response.setHeader("Content-Disposition", "attachment;filename=" + fileName); | 
|---|
|  |  |  | response.setContentType("application/vnd.ms-excel;charset=UTF-8"); | 
|---|
|  |  |  | response.setHeader("Pragma", "no-cache"); | 
|---|
|  |  |  | response.setHeader("Cache-Control", "no-cache"); | 
|---|
|  |  |  | outputStream = response.getOutputStream(); | 
|---|
|  |  |  | workbook.write(outputStream); | 
|---|
|  |  |  | } catch (IOException e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } finally { | 
|---|
|  |  |  | try { | 
|---|
|  |  |  | outputStream.close(); | 
|---|
|  |  |  | } catch (IOException e) { | 
|---|
|  |  |  | e.printStackTrace(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @ApiOperation(tags = {"后台-订单管理-停车记录"},value = "详情") | 
|---|
|  |  |  | @GetMapping(value = "/detail") | 
|---|
|  |  |  | public R<TParkingRecord> detail(Long id) { | 
|---|
|  |  |  | return R.ok(parkingRecordService.getById(id)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @ApiOperation(tags = {"后台-订单管理-停车记录"},value = "出场") | 
|---|
|  |  |  | @GetMapping(value = "/out") | 
|---|
|  |  |  | @Log(title = "【停车记录】修改出场状态", businessType = BusinessType.UPDATE,operatorType = OperatorType.MANAGE) | 
|---|
|  |  |  | public R out(Long id) { | 
|---|
|  |  |  | TParkingRecord byId = parkingRecordService.getById(id); | 
|---|
|  |  |  | byId.setStatus(2); | 
|---|
|  |  |  | 
|---|
|  |  |  | public void addParkingRecord(@RequestBody TParkingRecord parkingRecord){ | 
|---|
|  |  |  | parkingRecordService.save(parkingRecord); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @ResponseBody | 
|---|
|  |  |  | @PostMapping(value = "/parking/data") | 
|---|
|  |  |  | @ApiOperation(value = "统计", tags = {"管理后台-数据分析-车场运营分析"}) | 
|---|
|  |  |  | public R<TParkLotRecordVO> data(@RequestBody ParkingRecordQueryDto parkingRecordQueryDto){ | 
|---|
|  |  |  | //上方折线图 | 
|---|
|  |  |  | TParkLotRecordVO tParkLotRecordVO = new TParkLotRecordVO(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (parkingRecordQueryDto.getDayType()==1) { | 
|---|
|  |  |  | List<Map<String, Object>> maps = parkingRecordService.parkingData(parkingRecordQueryDto); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<Map<String, Object>> charMap = new ArrayList<>(); | 
|---|
|  |  |  | // 生成从 "00:00" 到 "23:00" 的时间数据 | 
|---|
|  |  |  | for (int hour = 0; hour < 24; hour++) { | 
|---|
|  |  |  | String time = String.format("%02d:00", hour); | 
|---|
|  |  |  | Map<String, Object> mapWithTimeValue = findMapWithTimeValue(maps, time); | 
|---|
|  |  |  | if (mapWithTimeValue!=null){ | 
|---|
|  |  |  | charMap.add(mapWithTimeValue); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | Map<String, Object> timeMap = new HashMap<>(); | 
|---|
|  |  |  | timeMap.put("time", time); // 初始化值为 null | 
|---|
|  |  |  | timeMap.put("orders", 0); | 
|---|
|  |  |  | timeMap.put("timeoutAmount", 0); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | charMap.add(timeMap); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | tParkLotRecordVO.setMaps(charMap); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | List<Map<String, Object>> maps = parkingRecordService.parkingDataByDate(parkingRecordQueryDto); | 
|---|
|  |  |  | if(parkingRecordQueryDto.getDayType()==2||parkingRecordQueryDto.getDayType()==3){ | 
|---|
|  |  |  | //按日 | 
|---|
|  |  |  | // 解析 startTime 和 endTime 为 LocalDate | 
|---|
|  |  |  | LocalDate startDate = parkingRecordQueryDto.getStartTime(); | 
|---|
|  |  |  | LocalDate endDate = parkingRecordQueryDto.getEndTime(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<Map<String, Object>> dateRangeStatistics = new ArrayList<>(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 遍历日期范围 | 
|---|
|  |  |  | while (!startDate.isAfter(endDate)) { | 
|---|
|  |  |  | String formattedDate = startDate.format(DateTimeFormatter.ofPattern("yyyy-MM-dd")); | 
|---|
|  |  |  | Map<String, Object> dailyStats = findMapWithDateValue(maps, formattedDate); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (dailyStats != null) { | 
|---|
|  |  |  | dateRangeStatistics.add(dailyStats); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | Map<String, Object> dateMap = new HashMap<>(); | 
|---|
|  |  |  | dateMap.put("time", formattedDate); | 
|---|
|  |  |  | dateMap.put("electrovalence", 0); | 
|---|
|  |  |  | dateMap.put("orderCount", 0); | 
|---|
|  |  |  | dateMap.put("servicecharge", 0); | 
|---|
|  |  |  | dateMap.put("electricity", 0); | 
|---|
|  |  |  | dateRangeStatistics.add(dateMap); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 移动到下一天 | 
|---|
|  |  |  | startDate = startDate.plusDays(1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | tParkLotRecordVO.setMaps(dateRangeStatistics); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | tParkLotRecordVO.setMaps(maps); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //车辆类型饼图 | 
|---|
|  |  |  | List<Map<String, Object>> carColor  =   parkingRecordService.getCarColor(parkingRecordQueryDto); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //出场类型 | 
|---|
|  |  |  | List<Map<String, Object>> outType  =   parkingRecordService.getOutType(parkingRecordQueryDto); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //进场充电占比 | 
|---|
|  |  |  | List<Map<String, Object>> isCharge  =   parkingRecordService.getIsCharge(parkingRecordQueryDto); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | tParkLotRecordVO.setCarColor(carColor); | 
|---|
|  |  |  | tParkLotRecordVO.setOutType(outType); | 
|---|
|  |  |  | tParkLotRecordVO.setIsCharge(isCharge); | 
|---|
|  |  |  | return R.ok(tParkLotRecordVO); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | private static Map<String, Object> findMapWithTimeValue(List<Map<String, Object>> charMap1,String timeValue) { | 
|---|
|  |  |  | for (Map<String, Object> map : charMap1) { | 
|---|
|  |  |  | if (map.containsKey("time") && map.get("time").equals(timeValue)) { | 
|---|
|  |  |  | return map; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return null; // 如果没有找到,返回 null | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private Map<String, Object> findMapWithDateValue(List<Map<String, Object>> list, String date) { | 
|---|
|  |  |  | for (Map<String, Object> map : list) { | 
|---|
|  |  |  | if (date.equals(map.get("time"))) { | 
|---|
|  |  |  | return map; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return null; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | @ResponseBody | 
|---|
|  |  |  | @PostMapping(value = "/parking/work") | 
|---|
|  |  |  | @ApiOperation(value = "停车订单统计", tags = {"管理后台-工作台"}) | 
|---|
|  |  |  | public R<TParkLotRecordCountVo> work(@RequestBody ParkingRecordQueryDto parkingRecordQueryDto){ | 
|---|
|  |  |  | List<TParkingRecord> list = parkingRecordService.lambdaQuery().eq(parkingRecordQueryDto.getParkingLotId() != null, TParkingRecord::getParkingLotId, parkingRecordQueryDto.getParkingLotId()) | 
|---|
|  |  |  | .between(TParkingRecord::getCreateTime, parkingRecordQueryDto.getStartTime(), parkingRecordQueryDto.getEndTime()).list(); | 
|---|
|  |  |  | int count1 = list.size(); | 
|---|
|  |  |  | //统计出list中chargingOrderId为null的数据个数 | 
|---|
|  |  |  | int count2 = list.stream().filter(item -> item.getChargingOrderId() == null).collect(Collectors.toList()).size(); | 
|---|
|  |  |  | int count3 = count1-count2; | 
|---|
|  |  |  | //计算出list中parkingDuration的总和 | 
|---|
|  |  |  | int count4 = 0; | 
|---|
|  |  |  | for (TParkingRecord tParkingRecord : list) { | 
|---|
|  |  |  | count4 = count4+tParkingRecord.getParkingDuration(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //计算出list中orderAmount的总和 | 
|---|
|  |  |  | BigDecimal count5 = list.stream().map(TParkingRecord::getOrderAmount).reduce(BigDecimal.ZERO, BigDecimal::add); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | TParkLotRecordCountVo tParkLotRecordCountVo = new TParkLotRecordCountVo(); | 
|---|
|  |  |  | tParkLotRecordCountVo.setCount1(count1); | 
|---|
|  |  |  | tParkLotRecordCountVo.setCount2(count2); | 
|---|
|  |  |  | tParkLotRecordCountVo.setCount3(count3); | 
|---|
|  |  |  | tParkLotRecordCountVo.setCount4(count4); | 
|---|
|  |  |  | tParkLotRecordCountVo.setCount5(count5); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return R.ok(tParkLotRecordCountVo); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @ResponseBody | 
|---|
|  |  |  | @PostMapping(value = "/parking/income") | 
|---|
|  |  |  | @ApiOperation(value = "停车收入统计", tags = {"管理后台-工作台"}) | 
|---|
|  |  |  | public R income(@RequestBody ParkingRecordQueryDto parkingRecordQueryDto){ | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<Map<String,Object>>  maps =  parkingRecordService.income(parkingRecordQueryDto); | 
|---|
|  |  |  | return R.ok(maps); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|