From b880058e6ded5169ed38bb214d2da3b841d51bdd Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期五, 14 三月 2025 16:27:36 +0800
Subject: [PATCH] 修改bug

---
 ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/factory/SiteFallbackFactory.java    |    2 
 ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/SiteController.java          |    3 +
 ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TChargingPileController.java |    9 +++-
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java              |   73 +++++++++++++++++++++++++-----------
 4 files changed, 59 insertions(+), 28 deletions(-)

diff --git a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/factory/SiteFallbackFactory.java b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/factory/SiteFallbackFactory.java
index 0f723d3..d6c922f 100644
--- a/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/factory/SiteFallbackFactory.java
+++ b/ruoyi-api/ruoyi-api-chargingPile/src/main/java/com/ruoyi/chargingPile/api/factory/SiteFallbackFactory.java
@@ -46,7 +46,7 @@
 
             @Override
             public R<List<GetSiteListDTO>> getSiteListByUserId(Long userId) {
-                return null;
+                return R.fail("获取数据失败");
             }
 
             @Override
diff --git a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/SiteController.java b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/SiteController.java
index 0629a06..9efce5e 100644
--- a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/SiteController.java
+++ b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/SiteController.java
@@ -619,7 +619,8 @@
 	 * @return
 	 */
 	@PostMapping("/getSiteListPaging")
-	public PageInfo<Site> getSiteListPaging(@RequestParam("PageNo") Integer PageNo, @RequestParam("PageSize") Integer PageSize, @RequestParam("ids") List<String> ids){
+	public PageInfo<Site> getSiteListPaging(@RequestParam("PageNo") Integer PageNo, @RequestParam("PageSize") Integer PageSize,
+	                                        @RequestParam("ids") List<String> ids){
 		PageInfo<Site> pageInfo = new PageInfo<>(PageNo, PageSize);
 		PageInfo<Site> page = siteService.lambdaQuery().eq(Site::getStatus, 1).in(ids.size() > 0, Site::getId, ids).page(pageInfo);
 		return page;
diff --git a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TChargingPileController.java b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TChargingPileController.java
index 9fc876b..8ae8366 100644
--- a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TChargingPileController.java
+++ b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/controller/TChargingPileController.java
@@ -321,16 +321,19 @@
 					TChargingGun tChargingGun1 = new TChargingGun();
 					if(Arrays.asList(1, 2, 5).contains(chargingOrder.getStatus())){
 						tChargingGun1.setStatus(3);
+						tChargingGun1.setId(tChargingGun.getId());
+						chargingGunService.updateById(tChargingGun1);
 					}
 					if(Arrays.asList(3).contains(chargingOrder.getStatus())){
 						tChargingGun1.setStatus(4);
+						tChargingGun1.setId(tChargingGun.getId());
+						chargingGunService.updateById(tChargingGun1);
 					}
 					if(Arrays.asList(4).contains(chargingOrder.getStatus()) && chargingOrder.getEndMode() == 2){
 						tChargingGun1.setStatus(5);
+						tChargingGun1.setId(tChargingGun.getId());
+						chargingGunService.updateById(tChargingGun1);
 					}
-					tChargingGun1.setId(tChargingGun.getId());
-					chargingGunService.updateById(tChargingGun1);
-					
 					//推送状态给三方平台
 					tcecClient.pushChargingGunStatus(tChargingGun.getFullNumber(), tChargingGun1.getStatus());
 				}else{
diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java
index 46f6c7d..b9c35e2 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/TChargingOrderController.java
@@ -400,15 +400,37 @@
     @GetMapping(value = "/pay/order/charging/details")
     @ApiOperation(value = "充电明细", tags = {"管理后台-支付订单-订单信息"})
     public R<List<TChargingOrderAccountingStrategy>> chargingDetail(Long orderId) {
-        List<TChargingOrderAccountingStrategy> list = chargingOrderAccountingStrategyService.lambdaQuery().eq(TChargingOrderAccountingStrategy::getChargingOrderId, orderId).orderByDesc(TChargingOrderAccountingStrategy::getStartTime).list();
+        List<TChargingOrderAccountingStrategy> list = chargingOrderAccountingStrategyService.lambdaQuery().eq(TChargingOrderAccountingStrategy::getChargingOrderId, orderId)
+                .orderByDesc(TChargingOrderAccountingStrategy::getStartTime).list();
         DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
         for (TChargingOrderAccountingStrategy tChargingOrderAccountingStrategy : list) {
-            String format = tChargingOrderAccountingStrategy.getCreateTime().format(formatter);
+            LocalDateTime createTime = tChargingOrderAccountingStrategy.getCreateTime();
+            String format = createTime.format(formatter);
+            String startTime = tChargingOrderAccountingStrategy.getStartTime();
+            if("00:00".equals(startTime)){
+                createTime = createTime.plusDays(1);
+                format = createTime.format(formatter);
+            }
             tChargingOrderAccountingStrategy.setStartTime(format+" "+tChargingOrderAccountingStrategy.getStartTime());
             tChargingOrderAccountingStrategy.setEndTime(format+" "+tChargingOrderAccountingStrategy.getEndTime());
         }
-
-
+        //从新排序
+        list.sort(new Comparator<TChargingOrderAccountingStrategy>() {
+            @Override
+            public int compare(TChargingOrderAccountingStrategy o1, TChargingOrderAccountingStrategy o2) {
+                String startTime = o1.getStartTime();
+                String startTime1 = o2.getStartTime();
+                LocalDateTime localDateTime = LocalDateTime.parse(startTime, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm"));
+                LocalDateTime localDateTime1 = LocalDateTime.parse(startTime1, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm"));
+                if(localDateTime.isBefore(localDateTime1)){
+                    return -1;
+                }
+                if(localDateTime.isAfter(localDateTime1)){
+                    return 1;
+                }
+                return 0;
+            }
+        });
         return R.ok(list);
     }
     
@@ -548,27 +570,15 @@
         List<TChargingOrderAccountingStrategy> list = chargingOrderAccountingStrategyService.lambdaQuery().eq(TChargingOrderAccountingStrategy::getChargingOrderId, strategyId).orderByDesc(TChargingOrderAccountingStrategy::getStartTime).list();
         DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd");
         for (TChargingOrderAccountingStrategy tChargingOrderAccountingStrategy : list) {
-            String format = "";
-            String format1 = "";
-            String temp1=list.get(0).getStartTime().split(":")[0];
-            System.err.println("订单详情时间第一条"+list.get(0).getStartTime());
-            System.err.println("订单详情时间开始"+tChargingOrderAccountingStrategy.getStartTime());
-            System.err.println("订单详情时间结束"+tChargingOrderAccountingStrategy.getEndTime());
-//            String temp1=list.get(0).getStartTime().split(":")[0];
-            String[] split = tChargingOrderAccountingStrategy.getStartTime().split(":");
-            if (Integer.parseInt(split[0])>=Integer.parseInt(temp1)){
-                format = byId.getCreateTime().format(formatter);
-            }else {
-                format = byId.getEndTime().format(formatter);
-            }
-            String[] split1 = tChargingOrderAccountingStrategy.getEndTime().split(":");
-            if (Integer.parseInt(split1[0])<Integer.parseInt(temp1)){
-                format1 = byId.getCreateTime().format(formatter);
-            }else {
-                format1 = byId.getEndTime().format(formatter);
+            LocalDateTime createTime = tChargingOrderAccountingStrategy.getCreateTime();
+            String format = createTime.format(formatter);
+            String startTime = tChargingOrderAccountingStrategy.getStartTime();
+            if("00:00".equals(startTime)){
+                createTime = createTime.plusDays(1);
+                format = createTime.format(formatter);
             }
             tChargingOrderAccountingStrategy.setStartTime(format+" "+tChargingOrderAccountingStrategy.getStartTime());
-            tChargingOrderAccountingStrategy.setEndTime(format1+" "+tChargingOrderAccountingStrategy.getEndTime());
+            tChargingOrderAccountingStrategy.setEndTime(format+" "+tChargingOrderAccountingStrategy.getEndTime());
             if (byId.getVipDiscountAmount()!=null && byId.getServiceCharge().compareTo(BigDecimal.ZERO) != 0){
                 BigDecimal multiply = byId.getVipDiscountAmount().divide(byId.getServiceCharge(), 2)
                         .multiply(tChargingOrderAccountingStrategy.getPeriodOriginalServicePrice());
@@ -580,6 +590,23 @@
                 tChargingOrderAccountingStrategy.setCouponDiscount(multiply);
             }
         }
+        //从新排序
+        list.sort(new Comparator<TChargingOrderAccountingStrategy>() {
+            @Override
+            public int compare(TChargingOrderAccountingStrategy o1, TChargingOrderAccountingStrategy o2) {
+                String startTime = o1.getStartTime();
+                String startTime1 = o2.getStartTime();
+                LocalDateTime localDateTime = LocalDateTime.parse(startTime, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm"));
+                LocalDateTime localDateTime1 = LocalDateTime.parse(startTime1, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm"));
+                if(localDateTime.isBefore(localDateTime1)){
+                    return -1;
+                }
+                if(localDateTime.isAfter(localDateTime1)){
+                    return 1;
+                }
+                return 0;
+            }
+        });
         chargingOrderInfoVO.setList(list);
         return AjaxResult.success(chargingOrderInfoVO);
     }

--
Gitblit v1.7.1