From d1cab4b2f2690d1331f12f0d9de78bbbf926f390 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期四, 16 一月 2025 14:27:51 +0800
Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/qijisheng

---
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java |  431 +++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 377 insertions(+), 54 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 859cc37..0e81641 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
@@ -2,7 +2,9 @@
 
 
 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;
@@ -10,13 +12,13 @@
 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.VerifiableShopVo;
-import com.ruoyi.other.api.domain.Shop;
-import com.ruoyi.other.api.domain.ShopScore;
+import com.ruoyi.other.api.domain.*;
 import com.ruoyi.other.mapper.ShopMapper;
-import com.ruoyi.other.service.ShopScoreService;
-import com.ruoyi.other.service.ShopService;
+import com.ruoyi.other.service.*;
 import com.ruoyi.other.util.GeodesyUtil;
 import com.ruoyi.other.util.tencentMap.TencentMapUtil;
 import com.ruoyi.other.vo.NearbyShopVO;
@@ -33,13 +35,18 @@
 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;
+
+import static javax.swing.UIManager.get;
 
 /**
  * <p>
@@ -69,6 +76,19 @@
     private UserShopClient userShopClient;
     @Resource
     private AppUserShopClient appUserShopClient;
+    @Resource
+    private GoodsService goodsService;
+    @Resource
+    private GoodsShopService goodsShopService;
+    @Resource
+    private OrderClient orderClient;
+    @Resource
+    private TechnicianSubscribeService technicianSubscribeService;
+    @Resource
+    private TechnicianService technicianService;
+    @Resource
+    private ReceiverBankChannelService receiverBankChannelService;
+
 
 
 
@@ -77,10 +97,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);
@@ -97,14 +117,20 @@
         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);
         shopService.save(shop);
 
+        Integer shopId = shop.getId();
+
         AppUserShop appUserShop = new AppUserShop();
         appUserShop.setAppUserId(appUser.getId());
-        appUserShop.setShopId(shop.getId());
+        appUserShop.setShopId(shopId);
+        appUserShop.setRoleType(1);
         R<Void> r = appUserClient.addAppUserShop(appUserShop);
         if (R.isError(r)){
             throw new RuntimeException("添加失败");
@@ -115,18 +141,24 @@
             throw new RuntimeException("添加失败");
         }
         //添加门店后台账号和门店关系数据
-        SysUser sysUser = sysUserClient.queryUserByUserName(phone).getData();
+        SysUser sysUser = sysUserClient.queryUserByUserNameAndRoleType(phone, 2).getData();
         if(null != sysUser){
+            sysUser.setAppUserId(appUser.getId());
+            sysUserClient.updateUser(sysUser);
+            
             UserShop userShop = new UserShop();
             userShop.setUserId(sysUser.getUserId());
-            userShop.setShopId(shop.getId());
+            userShop.setShopId(shopId);
             userShop.setRoleType(1);
             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.setNickName(sysUser.getNickName());
+                userShop.setCreateTime(LocalDateTime.now());
                 userShopClient.saveUserShop(userShop);
             }
         }else{
@@ -140,17 +172,34 @@
             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));
+            String s = MD5Generator.generateMD5(phone.substring(5));
+            user.setPassword(s);
             user.setCreateTime(new Date());
             Long userId = sysUserClient.saveShopUser(user).getData();
 
             UserShop userShop = new UserShop();
             userShop.setUserId(userId);
-            userShop.setShopId(shop.getId());
+            userShop.setShopId(shopId);
             userShop.setRoleType(1);
-            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);
+            }
+        }
+
+        // 更换下级会员绑定门店
+        R<List<AppUser>> lowerShopR = appUserClient.setLowerUserShop(appUser.getId(), shopId);
+        if (R.isError(lowerShopR)){
+            throw new RuntimeException("更换下级会员绑定门店失败");
         }
         return R.ok();
     }
@@ -159,36 +208,81 @@
     @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")
     @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, shop.getId()).list();
+        for (Shop shop1 : shops) {
+            LambdaUpdateWrapper<Shop> set = new LambdaUpdateWrapper<Shop>().set(Shop::getPid, null)
+                    .eq(Shop::getId,shop1.getId());
+            shopService.update(set);
+        }
+        //清除用户绑定当前门店
+        appUserClient.clearBindShop(shop.getId());
+        //查询门店绑定的平台账号
         UserShop userShop = new UserShop();
         userShop.setShopId(shop.getId());
         List<UserShop> data = userShopClient.getUserShop(userShop).getData();
-        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) {
-            String userName = sysUser.getUserName();
-            //通过电话号码查询小程序用户和门店关系数据
-            AppUser appUser = appUserClient.getAppUserByPhone1(userName).getData();
-            //需要先判断用户是否没有关联任何门店
-            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);
+        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();
+            for (SysUser sysUser : sysUserList) {
+                //通过电话号码查询小程序用户和门店关系数据
+                AppUser appUser = appUserClient.getAppUserByPhone1(sysUser.getUserName()).getData();
+                //需要先判断用户是否没有关联任何门店
+                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.setShopId(shop.getId());
+                appUserShop.setAppUserId(appUser.getId());
+                appUserShopClient.delAppUserShop(appUserShop);
             }
-
+        }
+        //取消预约的订单
+        List<Technician> list = technicianService.list(new LambdaQueryWrapper<Technician>().eq(Technician::getShopId, shop.getId()).eq(Technician::getDelFlag, 0));
+        if(list.size() > 0){
+            for (Technician technician : list) {
+                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));
         }
         return R.ok();
     }
@@ -200,7 +294,16 @@
         if (!shopService.cheUserByPhone(phone)) {
             return R.fail("该手机号未注册");
         }
+        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("门店之间不能互相作为上级门店");
+            }
+        }
         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);
@@ -210,39 +313,63 @@
         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();
         appUserShop = new AppUserShop();
         appUserShop.setAppUserId(appUser.getId());
         appUserShop.setShopId(shop.getId());
+        appUserShop.setRoleType(1);
         appUserClient.addAppUserShop(appUserShop);
-
+        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{
@@ -261,15 +388,87 @@
             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);
-            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();
     }
+
+
+    @PutMapping("/freezingOrThawing")
+    @ApiOperation(value = "门店管理-冻结/解冻门店", tags = {"管理后台-门店管理"})
+    public R freezingOrThawing(@RequestParam("id") Integer id, @RequestParam("status") Integer status){
+        Shop shop = shopService.getById(id);
+        if(shop.getStatus().equals(status)){
+            return R.fail("不能重复操作");
+        }
+        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();
+    }
+
+
+
 
     @GetMapping("/list")
     @ApiOperation(value = "门店列表", tags = {"管理后台-门店管理"})
@@ -304,7 +503,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();
@@ -350,15 +550,48 @@
      */
     @GetMapping("/shopByUser")
     @ApiOperation(value = "查询当前店长所属门店", tags = {"小程序-个人中心"}, notes = "可绑定的门店列表")
-    public R<List<Shop>> shopByUser() {
-        R<List<AppUserShop>> r = appUserClient.getAppUserShop(SecurityUtils.getUserId());
+    public R<List<Shop>> shopByUser(@RequestParam("longitude") String longitude, @RequestParam("latitude") String latitude) {
+        Long userid = tokenService.getLoginUserApplet().getUserid();
+        AppUser appUser = appUserClient.getAppUserById(userid);
+        R<List<AppUserShop>> r = appUserClient.getAppUserShop(userid);
         if (R.isSuccess(r)){
             List<AppUserShop> appUserShopList = r.getData();
             if (CollectionUtils.isEmpty(appUserShopList)){
                 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));
+            long count = shopList.stream().filter(s -> s.getStatus() == 1).count();
+            if(shopList.size() > 0 && count == 0){
+                return R.fail("操作失败,当前门店已冻结");
+            }
+            shopList = shopList.stream().filter(s -> s.getStatus() == 1).collect(Collectors.toList());
+            if(null != appUser.getShopId()){
+                Optional<Shop> first = shopList.stream().filter(s -> s.getId().equals(appUser.getShopId())).findFirst();
+                if(first.isPresent()){
+                    Shop shop = first.get();
+                    for (Shop shop1 : shopList) {
+                        if(shop1.getId().equals(shop.getId())){
+                            shopList.remove(shop1);
+                            break;
+                        }
+                    }
+                    shopList.add(0, shop);
+                }
+            }
+            for (Shop shop : shopList) {
+                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 = 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);
         }
         return R.ok(new ArrayList<>());
@@ -370,6 +603,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);
@@ -406,7 +646,7 @@
     @ResponseBody
     @PostMapping("/getShopByUserId")
     public R<List<Shop>> getShopByUserId(@RequestParam("id") Long id){
-        List<Shop> list = shopService.lambdaQuery().eq(Shop::getAppUserId, id).list();
+        List<Shop> list = shopService.lambdaQuery().eq(Shop::getAppUserId, id).eq(Shop::getDelFlag,0).list();
         return R.ok(list);
     }
     
@@ -429,8 +669,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()));
@@ -443,6 +688,14 @@
     @ApiOperation(value = "门店统计", tags = {"管理后台-首页统计"})
     public R<ShopStatistics> shopStatistics(@ApiParam("门店id") Integer shopId) {
         ShopStatistics shopStatistics = shopMapper.getShopStatistics(shopId);
+        if(null == shopId){
+            shopId = 0;
+        }
+        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);
     }
     
@@ -462,15 +715,31 @@
     @ResponseBody
     @GetMapping("/getVerifiableShop")
     @ApiOperation(value = "获取可核销门店列表", tags = {"购物车-小程序"})
-    public R<List<VerifiableShopVo>> getVerifiableShop(String longitude, String latitude){
+    public R<List<VerifiableShopVo>> getVerifiableShop(String longitude, String latitude, Integer goodsId){
         String city = TencentMapUtil.inverseGeographicalAnalysis(longitude, latitude, false);
+        if(null == city){
+            city = "510100";
+        }
         city = city.substring(0, 4) + "00";
-        List<Shop> list = shopService.list(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()){
+                List<Integer> collect = goodsShopService.list(new LambdaQueryWrapper<GoodsShop>().eq(GoodsShop::getGoodsId, goods.getId()))
+                        .stream().map(GoodsShop::getShopId).collect(Collectors.toList());
+                if(collect.size() > 0){
+                    wrapper.in(Shop::getId, collect);
+                }
+            }
+        }
+        List<Shop> list = shopService.list(wrapper);
         List<VerifiableShopVo> verifiableShopVoList = new ArrayList<>();
         for (Shop shop : list) {
             VerifiableShopVo vo = new VerifiableShopVo();
             vo.setId(shop.getId());
             vo.setName(shop.getName());
+            vo.setAddress(shop.getAddress());
+            vo.setHomePicture(shop.getHomePicture());
             Double wgs84 = GeodesyUtil.getDistance(longitude + "," + latitude, shop.getLongitude() + "," + shop.getLatitude()).get("WGS84");
             vo.setDistance(wgs84.longValue());
             verifiableShopVoList.add(vo);
@@ -495,7 +764,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();
@@ -510,9 +781,61 @@
     
     @PostMapping("/saveWithdrawalAccount")
     @ApiOperation(value = "保存提现账户", tags = {"门店后台-财务统计-提现明细"})
-    public R saveWithdrawalAccount(SaveWithdrawalAccount saveWithdrawalAccount) {
+    public R saveWithdrawalAccount(@RequestBody SaveWithdrawalAccount saveWithdrawalAccount) {
         shopService.saveWithdrawalAccount(saveWithdrawalAccount);
         return R.ok();
     }
+
+
+    /**
+     * 获取所有门店
+     * @return
+     */
+    @PostMapping("/getAllShop")
+    public R<List<Shop>> getAllShop(){
+        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);
+    }
+
+
+    @GetMapping("/getShopStatistics")
+    public R<Map<String, BigDecimal> > getShopStatistics(){
+        List<Shop> shopList = shopService.list();
+        BigDecimal serverGiveawayMoney = BigDecimal.ZERO;
+        BigDecimal lowerLevelGiveawayMoney = BigDecimal.ZERO;
+        for (Shop shop : shopList) {
+            serverGiveawayMoney = serverGiveawayMoney.add(shop.getServerGiveawayMoney());
+            lowerLevelGiveawayMoney = lowerLevelGiveawayMoney.add(shop.getLowerLevelGiveawayMoney());
+        }
+        Map<String, BigDecimal> map = new HashMap<>();
+        map.put("serverGiveawayMoney", serverGiveawayMoney);
+        map.put("lowerLevelGiveawayMoney", lowerLevelGiveawayMoney);
+        return R.ok(map);
+    }
+
 }
 

--
Gitblit v1.7.1