From e6fa0149e0c8690efc9c444650c6ef82f04ba54b Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期二, 14 一月 2025 19:38:19 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java |   25 ++++++++++++++++++++++---
 1 files changed, 22 insertions(+), 3 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 ffbdf33..d564c72 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
@@ -114,6 +114,9 @@
         shop.setCustomOrderNumber(0);
         shop.setAppUserId(appUser.getId());
         String city = TencentMapUtil.inverseGeographicalAnalysis(shop.getLongitude(), shop.getLatitude(), false);
+        if(!StringUtils.hasLength(city)){
+            city = "510100";
+        }
         shop.setProvinceCode(city.substring(0, 2) + "0000");
         shop.setCityCode(city.substring(0, 4) + "00");
         shop.setDistrictCode(city);
@@ -216,9 +219,10 @@
         // 查询有没有门店绑定这个被删除的门店
         List<Shop> shops = shopService.lambdaQuery().eq(Shop::getPid, shop.getId()).list();
         for (Shop shop1 : shops) {
-            shop1.setPid(0);
+            LambdaUpdateWrapper<Shop> set = new LambdaUpdateWrapper<Shop>().set(Shop::getPid, null)
+                    .eq(Shop::getId,shop1.getId());
+            shopService.update(set);
         }
-        shopService.updateBatchById(shops);
         appUserClient.clearBindShop(shop.getId());
         UserShop userShop = new UserShop();
         userShop.setShopId(shop.getId());
@@ -266,7 +270,7 @@
         if (!shopService.cheUserByPhone(phone)) {
             return R.fail("该手机号未注册");
         }
-        if (shop.getPid()!=null){
+        if (shop.getPid() != null && shop.getPid() != 0){
             Shop shopP = shopService.getById(shop.getPid());
             if (shopP.getPid()!=null&&shopP.getPid()!=0&& shopP.getPid().equals(shop.getId())){
                 return R.fail("门店之间不能互相作为上级门店");
@@ -363,6 +367,21 @@
         }
         shop.setStatus(status);
         shopService.updateById(shop);
+        //处理员工等数据
+        UserShop userSh = new UserShop();
+        userSh.setShopId(id);
+        List<UserShop> data = userShopClient.getUserShop(userSh).getData();
+        for (UserShop datum : data) {
+            UserShop userShop = new UserShop();
+            userShop.setUserId(datum.getUserId());
+            List<UserShop> data1 = userShopClient.getUserShop(userShop).getData();
+            long count = data1.stream().filter(s -> !s.getShopId().equals(id)).count();
+            if(0 == count){
+                SysUser sysUser = sysUserClient.getSysUser(datum.getUserId()).getData();
+                sysUser.setStatus(status == 1 ? "0" : "1");
+                sysUserClient.updateUser(sysUser);
+            }
+        }
         return R.ok();
     }
 

--
Gitblit v1.7.1