From 2ed6444f45d227e2acc6de65c3e8b582440fb83a Mon Sep 17 00:00:00 2001
From: luofl <1442745593@qq.com>
Date: 星期四, 06 三月 2025 09:20:40 +0800
Subject: [PATCH] 迭代版本:2.28

---
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java |  312 +++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 270 insertions(+), 42 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..ac1f16a 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
@@ -12,8 +12,10 @@
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.web.controller.BaseController;
 import com.ruoyi.common.security.service.TokenService;
+import com.ruoyi.common.security.utils.MD5Generator;
 import com.ruoyi.common.security.utils.SecurityUtils;
 import com.ruoyi.order.feignClient.OrderClient;
+import com.ruoyi.order.vo.OrderSaleNum;
 import com.ruoyi.order.vo.VerifiableShopVo;
 import com.ruoyi.other.api.domain.*;
 import com.ruoyi.other.mapper.ShopMapper;
@@ -44,6 +46,8 @@
 import java.time.LocalDateTime;
 import java.util.*;
 import java.util.stream.Collectors;
+
+import static javax.swing.UIManager.get;
 
 /**
  * <p>
@@ -114,6 +118,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);
@@ -168,7 +175,8 @@
             user.setRoleType(2);
             user.setObjectId(shopId);
             user.setAppUserId(appUser.getId());
-            user.setPassword(phone.substring(5));
+            String s = MD5Generator.generateMD5(phone.substring(5));
+            user.setPassword(s);
             user.setCreateTime(new Date());
             Long userId = sysUserClient.saveShopUser(user).getData();
 
@@ -176,10 +184,17 @@
             userShop.setUserId(userId);
             userShop.setShopId(shopId);
             userShop.setRoleType(1);
-            userShop.setRoleId(2L);
-            userShop.setNickName(user.getNickName());
-            userShop.setCreateTime(LocalDateTime.now());
-            userShopClient.saveUserShop(userShop);
+            List<UserShop> data = userShopClient.getUserShop(userShop).getData();
+            if(null == data || data.size() == 0){
+                userShop = new UserShop();
+                userShop.setUserId(userId);
+                userShop.setShopId(shopId);
+                userShop.setRoleType(1);
+                userShop.setRoleId(2L);
+                userShop.setNickName(user.getNickName());
+                userShop.setCreateTime(LocalDateTime.now());
+                userShopClient.saveUserShop(userShop);
+            }
         }
 
         // 更换下级会员绑定门店
@@ -194,8 +209,11 @@
     @GetMapping("/getDetailById")
     @ApiOperation(value = "门店详情", tags = {"管理后台-门店管理"})
     public R<Shop> getDetailById(@RequestParam("id") Integer id){
-        Shop byId = shopService.getById(id);
-        return R.ok(byId);
+        Shop shop = shopService.getById(id);
+        if (null != shop.getPid() && shop.getPid()==0){
+            shop.setPid(null);
+        }
+        return R.ok(shop);
     }
 
     @DeleteMapping("/deleteShop")
@@ -211,24 +229,27 @@
         }
         Shop shop = shopService.getById(id);
         shop.setDelFlag(1);
-
         shopService.updateById(shop);
         // 查询有没有门店绑定这个被删除的门店
         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());
         List<UserShop> data = userShopClient.getUserShop(userShop).getData();
         if(data.size() > 0){
+            //删除门店后台账号和关系数据
+            sysUserClient.delShopUser(shop.getId(), 2);
+    
+            //修改小程序用户类型和门店数据
             List<Integer> collect = data.stream().map(UserShop::getUserId).collect(Collectors.toList()).stream().map(Long::intValue).collect(Collectors.toList());
             List<SysUser> sysUserList = sysUserClient.getUserList(collect).getData();
-            //删除门店下的所有员工
-            sysUserClient.delShopUser(shop.getId(), 2);
-            //修改小程序用户类型和门店数据
             for (SysUser sysUser : sysUserList) {
                 //通过电话号码查询小程序用户和门店关系数据
                 AppUser appUser = appUserClient.getAppUserByPhone1(sysUser.getUserName()).getData();
@@ -238,10 +259,10 @@
                     appUser.setUserType(1);
                     appUserClient.editAppUserById(appUser);
                 }
-                //删除用户门店关系表数据
+                //删除用户门店关系数据
                 AppUserShop appUserShop = new AppUserShop();
-                appUserShop.setAppUserId(appUser.getId());
                 appUserShop.setShopId(shop.getId());
+                appUserShop.setAppUserId(appUser.getId());
                 appUserShopClient.delAppUserShop(appUserShop);
             }
         }
@@ -252,6 +273,14 @@
                 technician.setDelFlag(1);
             }
             technicianService.updateBatchById(list);
+            //删除技师和门店关系数据
+            //删除用户门店关系数据
+            AppUserShop appUserShop = new AppUserShop();
+            appUserShop.setShopId(shop.getId());
+            appUserShop.setRoleType(3);
+            appUserShopClient.delAppUserShop(appUserShop);
+            
+            //取消门店预约技师数据
             Set<Integer> collect = list.stream().map(Technician::getId).collect(Collectors.toSet());
             technicianSubscribeService.update(new LambdaUpdateWrapper<TechnicianSubscribe>().in(TechnicianSubscribe::getTechnicianId, collect).eq(TechnicianSubscribe::getDelFlag, 0)
                     .eq(TechnicianSubscribe::getStatus, 0).set(TechnicianSubscribe::getStatus, 2));
@@ -266,7 +295,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("门店之间不能互相作为上级门店");
@@ -285,15 +314,33 @@
         AppUser appUser = appUserClient.getAppUserById(old_shop.getAppUserId());
         //需要先判断用户是否没有关联任何门店
         List<AppUserShop> userShops = appUserShopClient.getAppUserShop(appUser.getId()).getData();
+        //当前小程序账号如果关联的店铺是最后一个,则将其修改为普通用户
         if(userShops.size() == 1 && userShops.get(0).getShopId().equals(shop.getId())){
             appUser.setUserType(1);
             appUserClient.editAppUserById(appUser);
         }
+        //删除原店长关系数据
         AppUserShop appUserShop = new AppUserShop();
         appUserShop.setAppUserId(appUser.getId());
         appUserShop.setShopId(shop.getId());
         appUserShop.setRoleType(1);
         appUserShopClient.delAppUserShop(appUserShop);
+        //删除后台用户和店铺关系数据
+        UserShop userShop = new UserShop();
+        userShop.setShopId(shop.getId());
+        userShop.setRoleType(1);
+        List<UserShop> data = userShopClient.getUserShop(userShop).getData();
+        if(null != data && data.size() > 0){
+            UserShop userShop1 = data.get(0);
+            userShopClient.delUserShop(userShop1);
+            //如果当前后台账户关联的店铺是最后一个,删除后台账户
+            userShop = new UserShop();
+            userShop.setUserId(userShop1.getUserId());
+            data = userShopClient.getUserShop(userShop).getData();
+            if(data.size() == 0){
+                sysUserClient.delSysUserById(userShop1.getUserId());
+            }
+        }
 
         //添加新管理员
         appUser = appUserClient.getAppUserByPhone1(phone).getData();
@@ -305,25 +352,25 @@
         appUser.setUserType(2);
         appUserClient.editAppUserById(appUser);
         
-
         //修改管理员
         shop.setAppUserId(appUser.getId());
         shopService.updateById(shop);
-
+        
         //添加门店后台账号和门店关系数据
         SysUser sysUser = sysUserClient.queryUserByUserName(phone).getData();
         if(null != sysUser){
-            UserShop userShop = new UserShop();
-            userShop.setUserId(sysUser.getUserId());
+            userShop = new UserShop();
             userShop.setShopId(shop.getId());
-            userShop.setRoleType(1);
-            List<UserShop> data = userShopClient.getUserShop(userShop).getData();
+            userShop.setUserId(sysUser.getUserId());
+            data = userShopClient.getUserShop(userShop).getData();
             if(null == data || data.size() == 0){
                 userShop = new UserShop();
                 userShop.setUserId(sysUser.getUserId());
                 userShop.setShopId(shop.getId());
                 userShop.setRoleType(1);
                 userShop.setRoleId(2L);
+                userShop.setNickName(sysUser.getNickName());
+                userShop.setCreateTime(LocalDateTime.now());
                 userShopClient.saveUserShop(userShop);
             }
         }else{
@@ -342,13 +389,21 @@
             user.setPassword(phone.substring(5));
             user.setCreateTime(new Date());
             Long userId = sysUserClient.saveShopUser(user).getData();
-
-            UserShop userShop = new UserShop();
-            userShop.setUserId(userId);
+    
+            userShop = new UserShop();
             userShop.setShopId(shop.getId());
-            userShop.setRoleType(1);
-            userShop.setRoleId(2L);
-            userShopClient.saveUserShop(userShop);
+            userShop.setUserId(userId);
+            data = userShopClient.getUserShop(userShop).getData();
+            if(null == data || data.size() == 0){
+                userShop = new UserShop();
+                userShop.setUserId(userId);
+                userShop.setShopId(shop.getId());
+                userShop.setRoleType(1);
+                userShop.setRoleId(2L);
+                userShop.setNickName(appUser.getName());
+                userShop.setCreateTime(LocalDateTime.now());
+                userShopClient.saveUserShop(userShop);
+            }
         }
         return R.ok();
     }
@@ -363,6 +418,53 @@
         }
         shop.setStatus(status);
         shopService.updateById(shop);
+        //处理员工等数据
+        if(status == 1){
+            UserShop userSh = new UserShop();
+            userSh.setShopId(id);
+            List<UserShop> data = userShopClient.getUserShop(userSh).getData();
+            for (UserShop datum : data) {
+                SysUser sysUser = sysUserClient.getSysUser(datum.getUserId()).getData();
+                sysUser.setStatus("0");
+                sysUserClient.updateUser(sysUser);
+            }
+        }else{
+            //查询门店所有关联数据
+            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();
+                List<UserShop> collect = data1.stream().filter(s -> !s.getShopId().equals(id)).collect(Collectors.toList());
+                if(collect.size() == 0){
+                    //如果没有其他店铺,则将用户禁用
+                    SysUser sysUser = sysUserClient.getSysUser(datum.getUserId()).getData();
+                    sysUser.setStatus("1");
+                    sysUserClient.updateUser(sysUser);
+                }else{
+                    List<Integer> shopIds = collect.stream().map(UserShop::getShopId).collect(Collectors.toList());
+                    List<Shop> list = shopService.list(new LambdaQueryWrapper<Shop>().eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1)
+                            .in(Shop::getId, shopIds));
+                    //如果用户关联的其他门店都禁用了,将用户禁用
+                    if(list.size() == 0){
+                        SysUser sysUser = sysUserClient.getSysUser(datum.getUserId()).getData();
+                        sysUser.setStatus("1");
+                        sysUserClient.updateUser(sysUser);
+                    }else{
+                        //修改默认门店
+                        SysUser sysUser = sysUserClient.getSysUser(datum.getUserId()).getData();
+                        if(sysUser.getObjectId().equals(id)){
+                            sysUser.setObjectId(list.get(0).getId());
+                            sysUserClient.updateUser(sysUser);
+                        }
+                    }
+                }
+            }
+        }
+        
         return R.ok();
     }
 
@@ -402,7 +504,8 @@
             userShop.setRoleType(1);
             List<UserShop> data = userShopClient.getUserShop(userShop).getData();
             SysUser userData = sysUserClient.getSysUser(data.get(0).getUserId()).getData();
-            userData.setPassword(userData.getPhonenumber().substring(5));
+            String s = MD5Generator.generateMD5(userData.getPhonenumber().substring(5));
+            userData.setPassword(s);
             sysUserClient.resetPassword(userData);
         }
         return R.ok();
@@ -575,8 +678,17 @@
     @PostMapping("/getShopIdByName")
     public R<Set<Integer>> getShopIdByName(@RequestParam("shopName") String shopName){
         List<Shop> list = shopService.list(new LambdaQueryWrapper<Shop>()
-                .like(Shop::getName, shopName));
+                .like(Shop::getName, shopName)
+                .eq(Shop::getDelFlag, 0));
         return R.ok(list.stream().map(Shop::getId).collect(Collectors.toSet()));
+    }
+
+    @PostMapping("/getManagerByManagerName")
+    public R<Set<Long>> getManagerByManagerName(@RequestParam("managerName") String managerName){
+        List<Shop> list = shopService.list(new LambdaQueryWrapper<Shop>()
+                .like(Shop::getShopManager, managerName)
+                .eq(Shop::getDelFlag, 0));
+        return R.ok(list.stream().map(Shop::getAppUserId).collect(Collectors.toSet()));
     }
 
     /**
@@ -586,14 +698,35 @@
     @ApiOperation(value = "门店统计", tags = {"管理后台-首页统计"})
     public R<ShopStatistics> shopStatistics(@ApiParam("门店id") Integer shopId) {
         ShopStatistics shopStatistics = shopMapper.getShopStatistics(shopId);
-        if(null == shopId){
-            shopId = 0;
+        List<Integer> shopIds;
+
+        shopIds = shopService.list(new LambdaQueryWrapper<Shop>()
+                        .eq(Shop::getDelFlag, 0)
+                        .eq(shopId !=null,Shop::getId, shopId))
+                .stream()
+                .map(Shop::getId)
+                .collect(Collectors.toList());
+
+
+        if (CollectionUtils.isEmpty(shopIds)){
+            shopStatistics.setTotalOrder(0);
+            shopStatistics.setServiceOrder(0);
+            shopStatistics.setGoodsOrder(0);
+        }else {
+            OrderSaleNum serviceOrderSaleNum = new OrderSaleNum();
+            serviceOrderSaleNum.setShopIds(shopIds);
+            serviceOrderSaleNum.setType(1);
+            Integer serviceOrder = orderClient.getShopSaleNumByShopIds(serviceOrderSaleNum).getData();
+
+            OrderSaleNum goodsOrderSaleNum = new OrderSaleNum();
+            goodsOrderSaleNum.setShopIds(shopIds);
+            goodsOrderSaleNum.setType(2);
+            Integer goodsOrder = orderClient.getShopSaleNumByShopIds(goodsOrderSaleNum).getData();
+
+            shopStatistics.setTotalOrder(serviceOrder + goodsOrder);
+            shopStatistics.setServiceOrder(serviceOrder);
+            shopStatistics.setGoodsOrder(goodsOrder);
         }
-        Integer serviceOrder = orderClient.getShopSaleNum(shopId, 1).getData();
-        Integer goodsOrder = orderClient.getShopSaleNum(shopId, 2).getData();
-        shopStatistics.setTotalOrder(serviceOrder + goodsOrder);
-        shopStatistics.setServiceOrder(serviceOrder);
-        shopStatistics.setGoodsOrder(goodsOrder);
         return R.ok(shopStatistics);
     }
     
@@ -684,6 +817,21 @@
         return R.ok();
     }
 
+    @PostMapping("/saveWithdrawalAppletAccount")
+    @ApiOperation(value = "保存提现账户", tags = {"小程序-个人中心-门店管理-门店钱包"})
+    public R saveWithdrawalAppletAccount(@RequestBody SaveWithdrawalAccount saveWithdrawalAccount){
+
+        Shop shop = shopService.getById(saveWithdrawalAccount.getShopId());
+        if(null != shop){
+            shop.setReceiverAccountNoEnc(saveWithdrawalAccount.getReceiverAccountNoEnc());
+            shop.setReceiverNameEnc(saveWithdrawalAccount.getReceiverNameEnc());
+            shop.setReceiverAccountType(saveWithdrawalAccount.getReceiverAccountType());
+            shop.setReceiverBankChannelNo(saveWithdrawalAccount.getReceiverBankChannelNo());
+            shopService.updateById(shop);
+        }
+        return R.ok();
+    }
+
 
     /**
      * 获取所有门店
@@ -709,6 +857,21 @@
     }
 
 
+    @ResponseBody
+    @GetMapping("/verifyAppletConfiguration")
+    @ApiOperation(value = "判断是否有提现账户", tags = {"门店后台-财务管理-提现明细","小程序-个人中心-门店管理-门店钱包"})
+    public R verifyAppletConfiguration(Integer shopId){
+        Shop shop = shopService.getById(shopId);
+        if(StringUtils.hasLength(shop.getReceiverAccountNoEnc())){
+            return R.ok(true);
+        }
+        return R.ok(false);
+    }
+
+
+
+
+
 
     @ResponseBody
     @GetMapping("/getBankSerialNumber")
@@ -721,19 +884,84 @@
 
 
     @GetMapping("/getShopStatistics")
-    public R<Map<String, BigDecimal> > getShopStatistics(){
-        List<Shop> shopList = shopService.list();
+    public R<Map<String, BigDecimal> > getShopStatistics(@RequestParam("shopId") Integer shopId){
+        LambdaQueryWrapper<Shop> queryWrapper = new LambdaQueryWrapper<Shop>().eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1);
+        if(null != shopId && 0 != shopId){
+            queryWrapper.eq(Shop::getId, shopId);
+        }
+        List<Shop> shopList = shopService.list(queryWrapper);
         BigDecimal serverGiveawayMoney = BigDecimal.ZERO;
-        BigDecimal lowerLevelGiveawayMoney = BigDecimal.ZERO;
+        BigDecimal giveawayMoney = BigDecimal.ZERO;
         for (Shop shop : shopList) {
             serverGiveawayMoney = serverGiveawayMoney.add(shop.getServerGiveawayMoney());
-            lowerLevelGiveawayMoney = lowerLevelGiveawayMoney.add(shop.getLowerLevelGiveawayMoney());
+            giveawayMoney = giveawayMoney.add(shop.getGiveawayMoney());
         }
         Map<String, BigDecimal> map = new HashMap<>();
         map.put("serverGiveawayMoney", serverGiveawayMoney);
-        map.put("lowerLevelGiveawayMoney", lowerLevelGiveawayMoney);
+        map.put("giveawayMoney", giveawayMoney);
         return R.ok(map);
     }
 
+    /**
+     * 获取指定用户的服务商
+     * @return
+     */
+    @GetMapping("/getServiceProvider")
+    public R<Shop> getServiceProvider(@RequestParam("appUserId") Long appUserId){
+        //向上找获取第一个开店的门店
+        List<Shop> list = shopService.list(new LambdaQueryWrapper<Shop>().eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1));
+        AppUser appUser = appUserClient.getAppUserById(appUserId);
+        //上级集合,防止循环关联
+        Set<Long> pid = new HashSet<>();
+        Shop shop = getSuperiorStore(appUser, list, 1, 1, pid);
+        return R.ok(shop);
+    }
+    
+    
+    
+    public Shop getSuperiorStore(AppUser appUser, List<Shop> list, Integer hierarchy, Integer num, Set<Long> pid){
+        if(null == appUser.getInviteUserId()){
+            return null;
+        }
+        if(pid.contains(appUser.getInviteUserId())){
+            return null;
+        }
+        AppUser appUser1 = appUserClient.getAppUserById(appUser.getInviteUserId());
+        if(null != appUser1){
+            Optional<Shop> first = list.stream().filter(shop -> shop.getAppUserId().equals(appUser1.getId())).findFirst();
+            if(first.isPresent()){
+                if(hierarchy.equals(num)){
+                    return first.get();
+                }
+                num++;
+            }
+        }
+        return getSuperiorStore(appUser1, list, hierarchy, num, pid);
+    }
+
+
+
+
+
+
+
+
+
+
+    /**
+     * 获取指定用户的高级服务商
+     * @return
+     */
+    @GetMapping("/getSuperiorServiceProvider")
+    public R<Shop> getSuperiorServiceProvider(@RequestParam("appUserId") Long appUserId){
+        //向上找获取第一个开店的门店
+        List<Shop> list = shopService.list(new LambdaQueryWrapper<Shop>().eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1));
+        AppUser appUser = appUserClient.getAppUserById(appUserId);
+        //上级集合,防止循环关联
+        Set<Long> pid = new HashSet<>();
+        Shop shop = getSuperiorStore(appUser, list, 2, 1, pid);
+        return R.ok(shop);
+    }
+
 }
 

--
Gitblit v1.7.1