From 109cbb50d48867083e1a2c746a7ebc3c95cf3569 Mon Sep 17 00:00:00 2001
From: zepengdev <lzpsmith@outlook.com>
Date: Thu, 26 Jun 2025 22:54:12 +0800
Subject: [PATCH] fix: 修正分页查询返回错误总数的问题

---
 oying-system/src/main/java/com/oying/modules/pc/store/rest/StoreCustomerController.java |   63 +++++++++++++++++++++++++++----
 1 files changed, 55 insertions(+), 8 deletions(-)

diff --git a/oying-system/src/main/java/com/oying/modules/pc/store/rest/StoreCustomerController.java b/oying-system/src/main/java/com/oying/modules/pc/store/rest/StoreCustomerController.java
index dbf828d..59900e0 100644
--- a/oying-system/src/main/java/com/oying/modules/pc/store/rest/StoreCustomerController.java
+++ b/oying-system/src/main/java/com/oying/modules/pc/store/rest/StoreCustomerController.java
@@ -1,14 +1,30 @@
 package com.oying.modules.pc.store.rest;
 
-import com.oying.modules.pc.common.core.domain.R;
-import com.oying.modules.pc.store.domain.dto.StoreCustomerDetailDto;
-import com.oying.modules.pc.store.domain.dto.StoreCustomerQueryCriteria;
+import cn.hutool.core.util.ObjUtil;
+import com.oying.modules.pc.product.domain.Product;
+import com.oying.modules.pc.product.domain.dto.ProductQueryCriteria;
+import com.oying.modules.pc.product.domain.enums.ProductStatusEnum;
+import com.oying.modules.pc.product.service.ProductService;
+import com.oying.modules.pc.store.domain.Store;
+import com.oying.modules.pc.store.domain.dto.StoreQueryCriteria;
+import com.oying.modules.pc.store.service.StoreQualificationService;
 import com.oying.modules.pc.store.service.StoreQueryService;
+import com.oying.modules.pc.store.service.StoreService;
+import com.oying.modules.pc.store.view.CustomerStoreView;
+import com.oying.modules.pc.utils.BusinessHoursUtils;
+import com.oying.utils.PageResult;
+import com.oying.utils.R;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import lombok.RequiredArgsConstructor;
+import org.springframework.beans.BeanUtils;
 import org.springframework.http.ResponseEntity;
-import org.springframework.web.bind.annotation.*;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.PathVariable;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RestController;
+
+import java.util.List;
 
 /**
  * 店铺
@@ -22,15 +38,46 @@
 @RequiredArgsConstructor
 public class StoreCustomerController {
 
+    private final StoreService storeService;
     private final StoreQueryService storeQueryService;
+    private final StoreQualificationService storeQualificationService;
+    private final ProductService productService;
+
+    @GetMapping(value = "/page")
+    @ApiOperation("查询店铺")
+    public ResponseEntity<?> getStoresByPage(StoreQueryCriteria criteria) {
+        criteria.setLimit(1000);
+        PageResult<Store> pagedStores = storeQueryService.findPagedStores(criteria);
+        pagedStores.getContent().forEach(store -> store.setProducts(this.getProductsByStoreId(store.getStoreId())));
+        return ResponseEntity.ok(R.success(pagedStores));
+    }
 
     @GetMapping(value = "/{storeId}")
     @ApiOperation("查询店铺")
-    public ResponseEntity<?> getCustomerStoreById(@PathVariable("storeId") Long storeId) {
-        StoreCustomerQueryCriteria criteria = new StoreCustomerQueryCriteria();
+    public ResponseEntity<?> getStoreById(@PathVariable("storeId") Long storeId) {
+        Store store = storeService.getById(storeId);
+        CustomerStoreView view = new CustomerStoreView();
+        BeanUtils.copyProperties(store, view);
+        view.setBusinessHours(BusinessHoursUtils.formatBusinessHours(store.getOpenTime(), store.getCloseTime()));
+        return ResponseEntity.ok(R.success(view));
+    }
+
+    @GetMapping(value = "/{storeId}/details")
+    @ApiOperation("查询店铺")
+    public ResponseEntity<?> getStoreDetailsById(@PathVariable("storeId") Long storeId) {
+        Store store = storeService.getById(storeId);
+        if (ObjUtil.isNotEmpty(store)) {
+            store.setQualifications(storeQualificationService.queryByStoreId(storeId));
+        }
+        return ResponseEntity.ok(R.success(store));
+    }
+
+    private List<Product> getProductsByStoreId(Long storeId) {
+        ProductQueryCriteria criteria = new ProductQueryCriteria();
         criteria.setStoreId(storeId);
-        StoreCustomerDetailDto detailDto = storeQueryService.getCustomerStoreDetail(criteria);
-        return ResponseEntity.ok(R.success(detailDto));
+        criteria.setStatus(ProductStatusEnum.AVAILABLE.getValue());
+        criteria.setLimit(3);
+        return productService.queryAll(criteria);
     }
 
 }

--
Gitblit v1.9.3