From acccff9860b271d55c55dc87486f7c20b9896e6c Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期一, 13 一月 2025 16:19:54 +0800
Subject: [PATCH] 修改bug

---
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java |  106 ++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 81 insertions(+), 25 deletions(-)

diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java
index 900ea22..64e4910 100644
--- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java
+++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java
@@ -4,6 +4,7 @@
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper;
 import com.ruoyi.account.api.feignClient.AppUserClient;
 import com.ruoyi.account.api.feignClient.AppUserShopClient;
 import com.ruoyi.account.api.model.AppUser;
@@ -33,10 +34,13 @@
 import io.swagger.annotations.ApiParam;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.CollectionUtils;
+import org.springframework.util.StringUtils;
 import org.springframework.web.bind.annotation.*;
 
 import javax.annotation.Resource;
 import java.math.BigDecimal;
+import java.math.MathContext;
+import java.math.RoundingMode;
 import java.time.LocalDateTime;
 import java.util.*;
 import java.util.stream.Collectors;
@@ -79,6 +83,8 @@
     private TechnicianSubscribeService technicianSubscribeService;
     @Resource
     private TechnicianService technicianService;
+    @Resource
+    private ReceiverBankChannelService receiverBankChannelService;
 
 
 
@@ -88,10 +94,10 @@
     @Transactional(rollbackFor = Exception.class)
     public R<Void> add(@RequestBody Shop shop){
         String phone = shop.getPhone();
-        if (!shopService.cheUserByPhone(phone)) {
+        AppUser appUser = appUserClient.getAppUserByPhone1(phone).getData();
+        if (appUser == null){
             return R.fail("该手机号未注册");
         }
-        AppUser appUser = appUserClient.getAppUserByPhone1(phone).getData();
         shop.setShopAllPoint(0);
         shop.setLowerLevelSharePoint(0);
         shop.setSharePoint(0);
@@ -113,9 +119,11 @@
         shop.setDistrictCode(city);
         shopService.save(shop);
 
+        Integer shopId = shop.getId();
+
         AppUserShop appUserShop = new AppUserShop();
         appUserShop.setAppUserId(appUser.getId());
-        appUserShop.setShopId(shop.getId());
+        appUserShop.setShopId(shopId);
         R<Void> r = appUserClient.addAppUserShop(appUserShop);
         if (R.isError(r)){
             throw new RuntimeException("添加失败");
@@ -130,14 +138,14 @@
         if(null != sysUser){
             UserShop userShop = new UserShop();
             userShop.setUserId(sysUser.getUserId());
-            userShop.setShopId(shop.getId());
+            userShop.setShopId(shopId);
             userShop.setRoleType(1);
             userShop.setNickName(sysUser.getNickName());
             List<UserShop> data = userShopClient.getUserShop(userShop).getData();
             if(null == data || data.size() == 0){
                 userShop = new UserShop();
                 userShop.setUserId(sysUser.getUserId());
-                userShop.setShopId(shop.getId());
+                userShop.setShopId(shopId);
                 userShop.setRoleType(1);
                 userShop.setRoleId(2L);
                 userShop.setCreateTime(LocalDateTime.now());
@@ -154,7 +162,7 @@
             user.setStatus("0");
             user.setDelFlag("0");
             user.setRoleType(2);
-            user.setObjectId(shop.getId());
+            user.setObjectId(shopId);
             user.setAppUserId(appUser.getId());
             user.setPassword(phone.substring(5));
             user.setCreateTime(new Date());
@@ -162,10 +170,16 @@
 
             UserShop userShop = new UserShop();
             userShop.setUserId(userId);
-            userShop.setShopId(shop.getId());
+            userShop.setShopId(shopId);
             userShop.setRoleType(1);
             userShop.setRoleId(2L);
             userShopClient.saveUserShop(userShop);
+        }
+
+        // 更换下级会员绑定门店
+        R<List<AppUser>> lowerShopR = appUserClient.setLowerUserShop(appUser.getId(), shopId);
+        if (R.isError(lowerShopR)){
+            throw new RuntimeException("更换下级会员绑定门店失败");
         }
         return R.ok();
     }
@@ -181,21 +195,18 @@
     @DeleteMapping("/deleteShop")
     @ApiOperation(value = "删除门店", tags = {"管理后台-门店管理"})
     public R<Void> deleteShop(@ApiParam("门店id") @RequestParam("id") Integer id){
+        List<Goods> list1 = goodsService.list(new LambdaQueryWrapper<Goods>().eq(Goods::getDelFlag, 0).eq(Goods::getAppointStore, 1).eq(Goods::getStatus, 2));
+        if(list1.size() > 0){
+            Set<Integer> collect1 = list1.stream().map(Goods::getId).collect(Collectors.toSet());
+            long count = goodsShopService.count(new LambdaQueryWrapper<GoodsShop>().eq(GoodsShop::getShopId, id).in(GoodsShop::getGoodsId, collect1));
+            if(0 < count){
+                return R.fail("门店已被商品使用,不能删除");
+            }
+        }
         Shop shop = shopService.getById(id);
         shop.setDelFlag(1);
         shopService.updateById(shop);
-        // 查询有没有门店绑定了该门店为上级门店
-        List<Shop> shops = shopService.lambdaQuery()
-                .eq(Shop::getPid, id).list();
-        if(!shops.isEmpty()){
-            for (Shop shop1 : shops) {
-                shop1.setPid(0);
-            }
-        }
-        AppUser appUserById = appUserClient.getAppUserById(shop.getAppUserId());
-        appUserById.setUserType(1);
-        appUserClient.editAppUserById(appUserById);
-        shopService.updateBatchById(shops);
+        appUserClient.clearBindShop(shop.getId());
         UserShop userShop = new UserShop();
         userShop.setShopId(shop.getId());
         List<UserShop> data = userShopClient.getUserShop(userShop).getData();
@@ -426,7 +437,7 @@
                 return R.ok(new ArrayList<>());
             }
             List<Integer> shopIds = appUserShopList.stream().map(AppUserShop::getShopId).collect(Collectors.toList());
-            List<Shop> shopList = shopService.listByIds(shopIds);
+            List<Shop> shopList = shopService.list(new LambdaQueryWrapper<Shop>().in(Shop::getId, shopIds).eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1));
             if(null != appUser.getShopId()){
                 Optional<Shop> first = shopList.stream().filter(s -> s.getId().equals(appUser.getShopId())).findFirst();
                 if(first.isPresent()){
@@ -444,8 +455,14 @@
                 Double wgs84 = GeodesyUtil.getDistance(longitude + "," + latitude, shop.getLongitude() + "," + shop.getLatitude()).get("WGS84");
                 shop.setDistance(wgs84);
                 List<ShopScore> list = shopScoreService.list(new LambdaQueryWrapper<ShopScore>().eq(ShopScore::getShopId, shop.getId()));
-                double v = list.stream().map(ShopScore::getScore).reduce(BigDecimal.ZERO, BigDecimal::add).doubleValue();
+                double v = 5;
+                if(list.size() > 0){
+                    v = list.stream().map(ShopScore::getScore).reduce(BigDecimal.ZERO, BigDecimal::add)
+                            .divide(new BigDecimal(list.size()), new MathContext(2, RoundingMode.HALF_EVEN)).doubleValue();
+                }
                 shop.setScore(v);
+                ShopScore one = shopScoreService.getOne(new LambdaQueryWrapper<ShopScore>().eq(ShopScore::getAppUserId, userid).eq(ShopScore::getShopId, shop.getId()).last(" order by create_time desc limit 0, 1"));
+                shop.setMyScore(null == one ? "0" : one.getScore().toString());
             }
             return R.ok(shopList);
         }
@@ -458,6 +475,13 @@
     @GetMapping("/bindShop")
     @ApiOperation(value = "绑定门店", tags = {"小程序-个人中心"})
     public R<Void> bindShop(@ApiParam("门店id") @RequestParam Integer shopId) {
+        Shop shop = shopService.getById(shopId);
+        if(null == shop || shop.getDelFlag() == 1){
+            return R.fail("绑定店铺不存在");
+        }
+        if(2 == shop.getStatus()){
+            return R.fail("绑定店铺已被冻结");
+        }
         AppUser appUser = appUserClient.getAppUserById(SecurityUtils.getUserId());
         appUser.setShopId(shopId);
         return appUserClient.editAppUserById(appUser);
@@ -517,8 +541,13 @@
         return R.ok(list);
     }
 
-    @GetMapping("/getShopIdByName")
-    R<Set<Integer>> getShopIdByName(@RequestParam String shopName){
+    /**
+     * 根据名称查询门店id
+     * @param shopName
+     * @return
+     */
+    @PostMapping("/getShopIdByName")
+    public R<Set<Integer>> getShopIdByName(@RequestParam("shopName") String shopName){
         List<Shop> list = shopService.list(new LambdaQueryWrapper<Shop>()
                 .like(Shop::getName, shopName));
         return R.ok(list.stream().map(Shop::getId).collect(Collectors.toSet()));
@@ -564,7 +593,7 @@
             city = "510100";
         }
         city = city.substring(0, 4) + "00";
-        LambdaQueryWrapper<Shop> wrapper = new LambdaQueryWrapper<Shop>().eq(Shop::getDelFlag, 0).eq(Shop::getCityCode, city);
+        LambdaQueryWrapper<Shop> wrapper = new LambdaQueryWrapper<Shop>().eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1).eq(Shop::getCityCode, city);
         if(null != goodsId){
             Goods goods = goodsService.getById(goodsId);
             if(1 == goods.getType() && 1 == goods.getAppointStore()){
@@ -607,7 +636,9 @@
         userShop.setUserId(userid);
         List<UserShop> data = userShopClient.getUserShop(userShop).getData();
         List<Integer> collect = data.stream().map(UserShop::getShopId).collect(Collectors.toList());
-        List<Shop> shops = shopService.listByIds(collect);
+        List<Shop> shops = shopService.list(new LambdaQueryWrapper<Shop>()
+                .in(!CollectionUtils.isEmpty(collect),Shop::getId, collect)
+                .eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1));
         List<VerifiableShopVo> list = new ArrayList<>();
         for (Shop shop : shops) {
             VerifiableShopVo vo = new VerifiableShopVo();
@@ -637,5 +668,30 @@
         List<Shop> list = shopService.list(new LambdaQueryWrapper<Shop>().eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1));
         return R.ok(list);
     }
+
+    @ResponseBody
+    @GetMapping("/verifyAccountConfiguration")
+    @ApiOperation(value = "判断是否有提现账户", tags = {"门店后台-财务管理-提现明细"})
+    public R verifyAccountConfiguration(){
+        Long userid = tokenService.getLoginUser().getUserid();
+        SysUser sysUser = sysUserClient.getSysUser(userid).getData();
+        Shop shop = shopService.getById(sysUser.getObjectId());
+        if(StringUtils.hasLength(shop.getReceiverAccountNoEnc())){
+            return R.ok();
+        }
+        return R.fail("请先配置收款账户");
+    }
+
+
+
+    @ResponseBody
+    @GetMapping("/getBankSerialNumber")
+    @ApiOperation(value = "获取行联号", tags = {"门店后台-财务管理-提现明细"})
+    public R<List<ReceiverBankChannel>> getBankSerialNumber(String name){
+        List<ReceiverBankChannel> list = receiverBankChannelService.list(new LambdaQueryWrapper<ReceiverBankChannel>()
+                .like(ReceiverBankChannel::getName, name));
+        return R.ok(list);
+    }
+
 }
 

--
Gitblit v1.7.1