From a5c5fc7c86c37519dbe42b148b47ebfc00f89ca9 Mon Sep 17 00:00:00 2001
From: huliguo <2023611923@qq.com>
Date: 星期三, 09 七月 2025 10:56:42 +0800
Subject: [PATCH] bug修改
---
 ruoyi-modules/ruoyi-shop/src/main/java/com/ruoyi/shop/controller/console/ShopController.java |  221 +++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 205 insertions(+), 16 deletions(-)
diff --git a/ruoyi-modules/ruoyi-shop/src/main/java/com/ruoyi/shop/controller/console/ShopController.java b/ruoyi-modules/ruoyi-shop/src/main/java/com/ruoyi/shop/controller/console/ShopController.java
index 93d709c..892640a 100644
--- a/ruoyi-modules/ruoyi-shop/src/main/java/com/ruoyi/shop/controller/console/ShopController.java
+++ b/ruoyi-modules/ruoyi-shop/src/main/java/com/ruoyi/shop/controller/console/ShopController.java
@@ -1,20 +1,29 @@
 package com.ruoyi.shop.controller.console;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.common.core.constant.CacheConstants;
 import com.ruoyi.common.core.domain.R;
 import com.ruoyi.common.core.exception.ServiceException;
-import com.ruoyi.shop.domain.pojo.shop.ShopRelUser;
-import com.ruoyi.shop.domain.pojo.shop.ShopStaff;
+import com.ruoyi.common.core.utils.StringUtils;
+import com.ruoyi.common.core.utils.bean.BeanUtils;
+import com.ruoyi.common.redis.service.RedisService;
+import com.ruoyi.common.security.utils.SecurityUtils;
+import com.ruoyi.shop.domain.pojo.shop.*;
 import com.ruoyi.shop.service.shop.*;
 import com.ruoyi.shop.service.task.MemberTaskService;
 import com.ruoyi.shop.service.task.ShopTaskService;
 import com.ruoyi.system.api.constant.AppErrorConstant;
 import com.ruoyi.system.api.domain.dto.*;
+import com.ruoyi.system.api.domain.poji.config.OneClinkSyncing;
 import com.ruoyi.system.api.domain.poji.shop.Shop;
 import com.ruoyi.system.api.domain.poji.sys.SysUser;
 import com.ruoyi.system.api.domain.vo.*;
 import com.ruoyi.system.api.model.QwH5LoginVo;
 import com.ruoyi.system.api.model.QwUserDetailDto;
 import com.ruoyi.system.api.service.RemoteUserService;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.RequestBody;
 import org.springframework.web.bind.annotation.RequestMapping;
@@ -23,6 +32,7 @@
 import javax.annotation.Resource;
 import java.util.List;
 import java.util.Optional;
+import java.util.stream.Collectors;
 
 /**
  * @author jqs34
@@ -59,6 +69,29 @@
     @Resource
     private MemberTaskService memberTaskService;
 
+    @Resource
+    private ShopAuthenticationService shopAuthenticationService;
+
+    @Resource
+    private ShopProportionService shopProportionService;
+
+    @Resource
+    private RedisService redisService;
+
+    @Autowired
+    private ShopAuthenticationHftxService shopAuthenticationHftxService;
+
+    @PostMapping("/getShopIdsByUserIds")
+    public R<List<Long>> getShopIdsByUserIds(@RequestBody List<Long> userIds)
+    {
+        // 店铺ids
+        List<Long> list = shopService.list(new QueryWrapper<Shop>()
+                .in("belong_user_id", userIds)
+                .eq("del_flag", 0))
+                .stream().map(Shop::getShopId).collect(Collectors.toList());
+        return R.ok(list);
+    }
+
     /**
      * 企业微信H5登录
      * @param qwUserDetail
@@ -68,13 +101,25 @@
     public R<QwH5LoginVo> qwH5Login(@RequestBody QwUserDetailDto qwUserDetail)
     {
         String mobile = qwUserDetail.getMobile();
-        ShopStaff shopStaff = shopStaffService.getByMobile(mobile);
+        ShopStaff shopStaff = null;
+        if(StringUtils.isNotEmpty(mobile)){
+            shopStaff = shopStaffService.getByMobile(mobile);
+        }else{
+            shopStaff = shopStaffService.getOne(new QueryWrapper<ShopStaff>().eq("del_flag", 0)
+                    .eq("user_id", qwUserDetail.getUserid()));
+        }
         if(shopStaff==null){
             throw new ServiceException(AppErrorConstant.USER_NO_SHOP);
         }
         Long userId = shopStaff.getUserId();
         SysUser sysUser = remoteUserService.getSysUser(userId).getData();
         Optional.ofNullable(sysUser).orElseThrow(() -> new ServiceException("登录失败,未查询到用户"));
+        Shop shop = shopService.getByShopId(shopStaff.getShopId());
+        if(shop.getFrozenFlag()==1){
+            String userKey = SecurityUtils.getUserKey();
+            redisService.deleteObject(CacheConstants.LOGIN_TOKEN_KEY+userKey);
+            throw new ServiceException("商户已被冻结,请联系管理员",401);
+        }
         // 构造登录返回信息
         QwH5LoginVo qwH5LoginVo = new QwH5LoginVo();
         qwH5LoginVo.setUserid(qwUserDetail.getUserid());
@@ -90,25 +135,63 @@
         return R.ok(shop);
     }
 
+    @PostMapping("/getShopSubMchId")
+    public R<String> getShopSubMchId(@RequestBody Long shopId){
+        String subMchid = "";
+        ShopAuthentication authentication = shopAuthenticationService.getByShopId(shopId);
+        if(null != authentication){
+            subMchid = authentication.getSubMchid();
+        }
+        return R.ok(subMchid, "");
+    }
+
+
+    @PostMapping("/getShopHFTXSubMchId")
+    public R<ShopAuthenticationHftxVo> getShopHFTXSubMchId(@RequestBody Long shopId){
+        ShopAuthenticationHftx shopAuthenticationHftx = shopAuthenticationHftxService.getOne(new QueryWrapper<ShopAuthenticationHftx>()
+                .eq("is_delete", 0).eq("shop_id", shopId));
+        ShopAuthenticationHftxVo vo = new ShopAuthenticationHftxVo();
+        BeanUtils.copyProperties(shopAuthenticationHftx, vo);
+        return R.ok(vo, "");
+    }
+
+
+
+    /**
+     * 获取商户分成
+     * @param shopId
+     * @return
+     */
+    @PostMapping("/getShopProportion")
+    public R<ShopProportionVo> getShopProportion(@RequestBody Long shopId){
+        ShopProportion shopProportion = shopProportionService.getByShopId(shopId);
+
+        ShopProportionVo shopProportionVo = new ShopProportionVo();
+        BeanUtils.copyBeanProp(shopProportionVo, shopProportion);
+        return R.ok(shopProportionVo);
+    }
 
     @PostMapping("/getShopByUserId")
     public R<ShopRelUserVo> getShopByUserId(@RequestBody Long userId)
     {
-        ShopRelUser shopRelUser = shopRelUserService.getByUserId(userId);
-        Optional.ofNullable(shopRelUser).orElseThrow(() -> new ServiceException("未查询到商户信息"));
+        List<ShopRelUser> shopRelUser = shopRelUserService.getByUserId(userId);
+        Optional.ofNullable(shopRelUser).orElseThrow(() -> new ServiceException("未查询到用户关联商户"));
         ShopRelUserVo shopRelUserVo = new ShopRelUserVo();
-        shopRelUserVo.setShopId(shopRelUser.getShopId());
-        shopRelUserVo.setUserName(shopRelUser.getUserName());
+        ShopRelUser shopRelUser1 = shopRelUser.stream().filter(s -> s.getIsDefault() == 1).collect(Collectors.toList()).get(0);
+        shopRelUserVo.setShopId(shopRelUser1.getShopId());
+        shopRelUserVo.setUserName(shopRelUser1.getUserName());
+        Shop shop = shopService.getById(shopRelUser1.getShopId());
+        shopRelUserVo.setShopName(shop.getShopName());
+        shopRelUserVo.setShopNum(shopRelUser.size());
         return R.ok(shopRelUserVo);
     }
-
+    
     @PostMapping("/getShopByBelongUserId")
-    public R<ShopRelUserVo> getShopByBelongUserId(@RequestBody Long userId)
-    {
-        Shop shop = shopService.getShopByBelongUserId(userId);
-        Optional.ofNullable(shop).orElseThrow(() -> new ServiceException("未查询到商户信息"));
+    public R<ShopRelUserVo> getShopByBelongUserId(@RequestBody Long userId) {
+        List<Shop> shopList = shopService.getShopByBelongUserId(userId);
+        Optional.ofNullable(shopList.get(0)).orElseThrow(() -> new ServiceException("未查询到商户信息"));
         ShopRelUserVo shopRelUserVo = new ShopRelUserVo();
-        shopRelUserVo.setShopId(shop.getShopId());
+        shopRelUserVo.setShopId(shopList.get(0).getShopId());
         return R.ok(shopRelUserVo);
     }
 
@@ -176,11 +259,11 @@
      * @date 2023/6/18 16:45
      */
     @PostMapping("/boardShopTotal")
-    public R<MgtBulletinBoardVo> boardShopTotal()
+    public R<MgtBulletinBoardVo> boardShopTotal(@RequestBody BoardMemberTotalDto boardMemberTotalDto)
     {
         MgtBulletinBoardVo bulletinBoardVo = new MgtBulletinBoardVo();
-        MgtBulletinBoardVo bulletinBoardVoShop = shopService.boardShopTotal();
-        MgtBulletinBoardVo bulletinBoardVoTask = shopTaskService.boardTaskTotal();
+        MgtBulletinBoardVo bulletinBoardVoShop = shopService.boardShopTotal(boardMemberTotalDto.getUserIds());
+        MgtBulletinBoardVo bulletinBoardVoTask = shopTaskService.boardTaskTotal(boardMemberTotalDto.getUserIds());
         bulletinBoardVo.setShopTotal(bulletinBoardVoShop.getShopTotal());
         bulletinBoardVo.setDealerTotal(bulletinBoardVoShop.getDealerTotal());
         bulletinBoardVo.setAgencyTotal(bulletinBoardVoShop.getAgencyTotal());
@@ -295,4 +378,110 @@
         shopStaffService.editMgtShopStaff(mgtShopStaffEditDto);
         return R.ok();
     }
+
+    /**
+     * @description
+     * @author  jqs
+     * @date    2023/8/10 23:01
+     * @param cityCodes
+     * @return  R<List<Long>>
+     */
+    @PostMapping("/listShopIdByCityCode")
+    R<List<Long>> listShopIdByCityCode(@RequestBody List<String> cityCodes){
+        List<Long> shopIdList = shopService.listShopIdByCityCode(cityCodes);
+        return R.ok(shopIdList);
+    }
+
+    @PostMapping("/authShop")
+    R authShop(){
+        shopService.authShop();
+        return R.ok();
+    }
+
+    /**
+     * @description  获取今日任务通知列表
+     * @author  jqs
+     * @date    2023/8/29 15:03
+     * @param
+     * @return  R<List<MgtUserTaskMsgVo>>
+     */
+    @PostMapping("/getTaskMsgList")
+    R<List<MgtUserTaskMsgVo>> getTaskMsgList(){
+        List<MgtUserTaskMsgVo> userTaskMsgVoList = shopService.getTaskMsgList();
+        return R.ok(userTaskMsgVoList);
+    }
+
+
+
+    /**
+     * @description
+     * @author  jqs
+     * @date    2023/8/10 23:01
+     * @param cityCodes
+     * @return  R<List<Long>>
+     */
+    @PostMapping("/listShopByCityCode")
+    public R<List<Shop>> listShopByCityCode(@RequestBody List<String> cityCodes){
+        List<Shop> shopIdList = shopService.listShopByCityCode(cityCodes);
+        return R.ok(shopIdList);
+    }
+
+
+    /**
+     * @description
+     * @author  jqs
+     * @date    2023/8/10 23:01
+     * @return  R<List<Long>>
+     */
+    @PostMapping("/listShopByIds")
+    public R<List<Shop>> listShopByIds(@RequestBody List<String> ids){
+        List<Shop> shopIdList = shopService.listByIds(ids);
+        return R.ok(shopIdList);
+    }
+
+
+    /**
+     * 根据管理员id获取门店
+     * @return
+     */
+    @PostMapping("/getShopBySysUserIds")
+    public List<Shop> getShopBySysUserIds(@RequestBody BoardMemberTotalDto boardMemberTotalDto){
+        return shopService.getShopBySysUserIds(boardMemberTotalDto.getUserIds());
+    }
+
+    /**
+     * 根据经销商id查询加盟商ids
+     * @param shopId
+     * @return
+     */
+    @PostMapping("/getFranchiseeIdsBYDealerId")
+    List<Shop> getFranchiseeIdsBYDealerId(@RequestBody Long shopId){
+        return shopService.getFranchiseeIdsBYDealerId(shopId);
+    }
+
+    /**
+     * 根据shopIds分页查看
+     * @param dto
+     * @return
+     */
+    @PostMapping("/getMgtShopPageVoByShopIds")
+    Page<MgtOneClinkSyncingShopPageVo> getMgtShopPageVoByShopIds(@RequestBody MGtOneClinkSyncingShopPageDTO dto){
+        return  shopService.getMgtShopPageVoByShopIds(dto);
+    }
+
+    /**
+     * 一键同步商户信息
+     */
+    @PostMapping("/updateShopByOneClinkSyncing")
+    R updateShopByOneClinkSyncing(@RequestBody OneClinkSyncing oneClinkSyncing){
+        return shopService.updateShopByOneClinkSyncing(oneClinkSyncing);
+    }
+
+    /**
+     * 根据shopName模糊查询门店集合
+     */
+    @PostMapping("/getShopListByShopName")
+    List<Shop> getShopListByShopName(@RequestBody String content){
+        return  shopService.getBaseMapper().selectList(new LambdaQueryWrapper<Shop>().like(Shop::getShopName, content));
+    }
 }
--
Gitblit v1.7.1