From ce19680b98669f8b4e66b2ce82fe0dcebe178445 Mon Sep 17 00:00:00 2001
From: luodangjia <luodangjia>
Date: 星期二, 10 九月 2024 09:46:16 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TParkingRecordController.java |  122 +++++++++++++++++++++++++++++++++++++++-
 1 files changed, 117 insertions(+), 5 deletions(-)

diff --git a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TParkingRecordController.java b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TParkingRecordController.java
index dab0830..fec52ef 100644
--- a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TParkingRecordController.java
+++ b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TParkingRecordController.java
@@ -1,18 +1,41 @@
 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.query.ParkingRecordQuery;
+import com.ruoyi.chargingPile.api.vo.GetParkingRecord;
+import com.ruoyi.chargingPile.api.vo.TParkingRecordPageInfoVO;
+import com.ruoyi.chargingPile.api.vo.TParkingRecordVO;
 import com.ruoyi.chargingPile.dto.ParkingRecordPageQuery;
+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.order.api.query.TOrderInvoiceQuery;
+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.net.URLEncoder;
+import java.util.ArrayList;
+import java.util.List;
 
 /**
  * <p>
@@ -47,12 +70,59 @@
         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")
+    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 = "出场")
@@ -64,8 +134,50 @@
         return R.ok();
 
     }
-
-
-
+    
+    
+    /**
+     * 根据车牌和状态查询停车数据
+     * @param query
+     * @return
+     */
+    @PostMapping("/getParkingRecord")
+    public R<TParkingRecord> getParkingRecord(@RequestBody GetParkingRecord query){
+        TParkingRecord one = parkingRecordService.getOne(new LambdaQueryWrapper<TParkingRecord>()
+                .eq(TParkingRecord::getLicensePlate, query.getLicensePlate()).eq(TParkingRecord::getStatus, query.getStatus()));
+        return R.ok(one);
+    }
+    
+    
+    /**
+     * 修改停车数据
+     * @param parkingRecord
+     */
+    @PostMapping("/updateParkingRecord")
+    public void updateParkingRecord(@RequestBody TParkingRecord parkingRecord){
+        parkingRecordService.updateById(parkingRecord);
+    }
+    
+    
+    /**
+     * 根据id获取数据
+     * @param id
+     * @return
+     */
+    @PostMapping("/getParkingRecordById")
+    public R<TParkingRecord> getParkingRecordById(@RequestParam("id") Long id){
+        TParkingRecord parkingRecord = parkingRecordService.getById(id);
+        return R.ok(parkingRecord);
+    }
+    
+    
+    /**
+     * 添加数据
+     * @param parkingRecord
+     */
+    @PostMapping("/addParkingRecord")
+    public void addParkingRecord(@RequestBody TParkingRecord parkingRecord){
+        parkingRecordService.save(parkingRecord);
+    }
 }
 

--
Gitblit v1.7.1