From 19df67e19f23cd2a04d1c7f355e1e656f4140af4 Mon Sep 17 00:00:00 2001
From: huliguo <2023611923@qq.com>
Date: 星期四, 17 四月 2025 20:04:14 +0800
Subject: [PATCH] 后台:首页统计、系统管理、广告管理、用户管理、商品分类管理

---
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/ShopController.java |  427 ++++++++++++++++++++++++++++++++---------------------
 1 files changed, 259 insertions(+), 168 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 02e4ffc..0c8d8c1 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,13 +2,20 @@
 
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
 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;
+import com.ruoyi.account.api.model.AppUserShop;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.utils.bean.BeanUtils;
 import com.ruoyi.common.core.web.controller.BaseController;
+import com.ruoyi.common.core.web.page.PageInfo;
 import com.ruoyi.common.security.service.TokenService;
 import com.ruoyi.common.security.utils.MD5Generator;
 import com.ruoyi.common.security.utils.SecurityUtils;
@@ -16,14 +23,15 @@
 import com.ruoyi.order.vo.OrderSaleNum;
 import com.ruoyi.order.vo.VerifiableShopVo;
 import com.ruoyi.other.api.domain.*;
+import com.ruoyi.other.api.dto.ShopAnalysisDTO;
+import com.ruoyi.other.dto.AddGoodsDTO;
+import com.ruoyi.other.enums.PhoneType;
 import com.ruoyi.other.mapper.ShopMapper;
+import com.ruoyi.other.mapper.ShopScoreMapper;
 import com.ruoyi.other.service.*;
 import com.ruoyi.other.util.GeodesyUtil;
 import com.ruoyi.other.util.tencentMap.TencentMapUtil;
-import com.ruoyi.other.vo.NearbyShopVO;
-import com.ruoyi.other.vo.SaveWithdrawalAccount;
-import com.ruoyi.other.vo.ShopDetailVO;
-import com.ruoyi.other.vo.ShopStatistics;
+import com.ruoyi.other.vo.*;
 import com.ruoyi.system.api.domain.SysUser;
 import com.ruoyi.system.api.feignClient.SysUserClient;
 import com.ruoyi.system.api.feignClient.UserShopClient;
@@ -32,6 +40,8 @@
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import io.swagger.annotations.ApiParam;
+import io.swagger.models.auth.In;
+import org.springframework.format.annotation.DateTimeFormat;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.CollectionUtils;
 import org.springframework.util.StringUtils;
@@ -41,7 +51,10 @@
 import java.math.BigDecimal;
 import java.math.MathContext;
 import java.math.RoundingMode;
+import java.time.LocalDate;
 import java.time.LocalDateTime;
+import java.time.LocalTime;
+import java.time.YearMonth;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -70,7 +83,9 @@
     @Resource
     private ShopMapper shopMapper;
     @Resource
-    private UserShopClient userShopClient;
+    private ShopScoreMapper shopScoreMapper;
+    @Resource
+    private AppUserShopClient appUserShopClient;
     @Resource
     private GoodsService goodsService;
     @Resource
@@ -79,20 +94,76 @@
     private OrderClient orderClient;
     @Resource
     private ReceiverBankChannelService receiverBankChannelService;
+    @Resource
+    private ShopScoreService shopScoreService;
 
 
+    /**
+     * 门店打分
+     * @return
+     */
+    @PostMapping("/shopScore")
+    @ApiOperation(value = "门店打分", tags = {"小程序-个人中心"})
+    public R<Void> shopScore(@RequestBody ShopScore shopScore) {
+        if (null==shopScore.getShopId()){
+            return R.fail("门店不能为空");
+        }
+        if (null==shopScore.getScore()){
+            return R.fail("评分不能为空");
+        }
+        //验证门店是否存在
+        Shop one = shopService.getOne(new LambdaQueryWrapper<Shop>().eq(Shop::getId, shopScore.getShopId()).eq(Shop::getStatus, 1).eq(Shop::getDelFlag, 0));
+        if (null == one){
+            return R.fail("门店不存在");
+        }
+        LoginUser loginUserApplet = tokenService.getLoginUserApplet();
+        shopScore.setAppUserId(loginUserApplet.getUserid());
+        ShopScore one1 = shopScoreService.getOne(new LambdaQueryWrapper<ShopScore>().eq(ShopScore::getAppUserId, loginUserApplet.getUserid()));
+        if (null!=one1){
+            return  R.fail("不能重复评分");
+        }
+        shopScore.setCreateTime(LocalDateTime.now());
+        shopScoreService.save(shopScore);
+        //计算,更新到门店中
+        //总评分
+        List<BigDecimal> scores = shopScoreMapper.selectList(new LambdaQueryWrapper<ShopScore>().eq(ShopScore::getShopId, shopScore.getShopId())).stream().map(ShopScore::getScore).collect(Collectors.toList());
+        BigDecimal score = getScore(scores);
+        one.setId(shopScore.getShopId().intValue());
+        one.setScore(score.doubleValue());
+        shopMapper.updateById(one);
+        return R.ok();
+    }
 
+    /**
+     * 计算评分
+     */
+    private BigDecimal getScore(List<BigDecimal> scores) {
+        if (scores == null || scores.isEmpty()) {
+            return BigDecimal.ZERO.setScale(1, RoundingMode.HALF_UP); // 默认返回 0.0
+        }
+
+        // 计算总分
+        BigDecimal totalScore = scores.stream().reduce(BigDecimal.ZERO, BigDecimal::add);
+
+        // 计算平均值,并保留 1 位小数(四舍五入)
+        BigDecimal averageScore = totalScore.divide(
+                new BigDecimal(scores.size()),
+                1,  // 保留 1 位小数
+                RoundingMode.HALF_UP  // 四舍五入
+        );
+        return averageScore;
+    }
 
     @PostMapping
     @ApiOperation(value = "新增门店", tags = {"管理后台-门店管理"})
     @Transactional(rollbackFor = Exception.class)
     public R<Void> add(@RequestBody Shop shop){
-        String phone = shop.getPhone();
+        /*String phone = shop.getPhone();
         AppUser appUser = appUserClient.getAppUserByPhone1(phone).getData();
         if (appUser == null){
             return R.fail("该手机号未注册");
         }
-        shop.setShopAllPoint(0);
+     *//*   shop.setShopAllPoint(0);
         shop.setLowerLevelSharePoint(0);
         shop.setSharePoint(0);
         shop.setServerPoint(0);
@@ -100,20 +171,20 @@
         shop.setGiveawayAllMoney(BigDecimal.ZERO);
         shop.setGiveawayMoney(BigDecimal.ZERO);
         shop.setLowerLevelGiveawayMoney(BigDecimal.ZERO);
-        shop.setServerGiveawayMoney(BigDecimal.ZERO);
+        shop.setServerGiveawayMoney(BigDecimal.ZERO);*//*
         shop.setCanWithdrawMoney(BigDecimal.ZERO);
         shop.setWithdrawMoney(BigDecimal.ZERO);
         shop.setOrderNumber(0);
-        shop.setServerOrderNumber(0);
-        shop.setCustomOrderNumber(0);
+      *//*  shop.setServerOrderNumber(0);
+        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.setProvinceCode(city.substring(0, 2) + "0000");
         shop.setCityCode(city.substring(0, 4) + "00");
-        shop.setDistrictCode(city);
+        shop.setDistrictCode(city);*//*
         shopService.save(shop);
 
         Integer shopId = shop.getId();
@@ -183,7 +254,7 @@
         R<List<AppUser>> lowerShopR = appUserClient.setLowerUserShop(appUser.getId(), shopId);
         if (R.isError(lowerShopR)){
             throw new RuntimeException("更换下级会员绑定门店失败");
-        }
+        }*/
         return R.ok();
     }
 
@@ -192,16 +263,14 @@
     @ApiOperation(value = "门店详情", tags = {"管理后台-门店管理"})
     public R<Shop> getDetailById(@RequestParam("id") Integer id){
         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));
+        /*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));
@@ -228,30 +297,24 @@
         if(data.size() > 0){
             //删除门店后台账号和关系数据
             sysUserClient.delShopUser(shop.getId(), 2);
-        }
+        }*/
         return R.ok();
     }
 
     @PutMapping("/editShop")
     @ApiOperation(value = "门店管理-编辑门店", tags = {"管理后台-门店管理"})
     public R<Void> editShop(@RequestBody Shop shop){
-        String phone = shop.getPhone();
+        /*String phone = shop.getPhone();
         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.setProvinceCode(city.substring(0, 2) + "0000");
         shop.setCityCode(city.substring(0, 4) + "00");
-        shop.setDistrictCode(city);
+        shop.setDistrictCode(city);*//*
         Shop old_shop = shopService.getById(shop.getId());
         shopService.updateById(shop);
         //修改管理员
@@ -331,7 +394,7 @@
                 userShop.setCreateTime(LocalDateTime.now());
                 userShopClient.saveUserShop(userShop);
             }
-        }
+        }*/
         return R.ok();
     }
 
@@ -343,7 +406,7 @@
     @PutMapping("/freezingOrThawing")
     @ApiOperation(value = "门店管理-冻结/解冻门店", tags = {"管理后台-门店管理"})
     public R freezingOrThawing(@RequestParam("id") Integer id, @RequestParam("status") Integer status){
-        Shop shop = shopService.getById(id);
+       /* Shop shop = shopService.getById(id);
         if(shop.getStatus().equals(status)){
             return R.fail("不能重复操作");
         }
@@ -394,7 +457,7 @@
                     }
                 }
             }
-        }
+        }*/
         
         return R.ok();
     }
@@ -404,11 +467,11 @@
 
     @GetMapping("/list")
     @ApiOperation(value = "门店列表", tags = {"管理后台-门店管理"})
-    public R<IPage<Shop>> list(@ApiParam("页码") @RequestParam Integer pageNum,@ApiParam("每一页数据大小") Integer pageSize,Shop shop){
+    public R<IPage<Shop>> list(@ApiParam("页码") @RequestParam("pageNum") Integer pageNum,@ApiParam("每一页数据大小") @RequestParam("pageSize") Integer pageSize,Shop shop){
         IPage<Shop> shopIPage = shopService.getShopList(pageNum, pageSize, shop);
-        for (Shop record : shopIPage.getRecords()) {
+        /*for (Shop record : shopIPage.getRecords()) {
             record.setLaveUsePoint(record.getLavePoint());
-        }
+        }*/
         return R.ok(shopIPage);
     }
 
@@ -427,7 +490,7 @@
     @GetMapping ("/resetPassword")
     @ApiOperation(value = "重置密码", tags = {"管理后台-门店管理"})
     public R<Void> resetPassword(@RequestParam(value = "ids") String ids) {
-        String[] idsArr = ids.split(",");
+       /* String[] idsArr = ids.split(",");
         for (String id : idsArr) {
             Shop shop = shopService.getById(Integer.valueOf(id));
             UserShop userShop = new UserShop();
@@ -438,7 +501,7 @@
             String s = MD5Generator.generateMD5(userData.getPhonenumber().substring(5));
             userData.setPassword(s);
             sysUserClient.resetPassword(userData);
-        }
+        }*/
         return R.ok();
     }
 
@@ -459,23 +522,29 @@
 
 
     /**
-     * 附近门店列表
+     * 附近门店列表/更多门店
      */
     @GetMapping("/nearbyShopList")
-    @ApiOperation(value = "附近门店列表", tags = {"小程序-首页"})
+    @ApiOperation(value = "附近门店列表/更多门店", tags = {"小程序-首页"})
     public R<List<NearbyShopVO>> nearbyShopList(@ApiParam("经度") @RequestParam BigDecimal longitude,
-                                                @ApiParam("纬度") @RequestParam BigDecimal latitude) {
-        return R.ok(shopService.nearbyShopList(longitude, latitude));
+                                                @ApiParam("纬度") @RequestParam BigDecimal latitude,
+                                                Shop shop) {
+        return R.ok(shopService.nearbyShopList(longitude, latitude,shop));
     }
 
-
+    /**
+     * 门店详情
+     */
     @GetMapping("/shopDetail")
     @ApiOperation(value = "门店详情", tags = {"小程序-首页"})
     public R<ShopDetailVO> shopDetail(@ApiParam("门店id") @RequestParam Integer shopId,
-                                      @ApiParam("经度") @RequestParam BigDecimal longitude,
-                                      @ApiParam("纬度") @RequestParam BigDecimal latitude) {
+                                      @ApiParam("经度") @RequestParam(required = false) BigDecimal longitude,
+                                      @ApiParam("纬度") @RequestParam(required = false)  BigDecimal latitude) {
         return R.ok(shopService.getShopDetail(shopId, longitude, latitude));
     }
+
+
+
 
 
     /**
@@ -501,8 +570,6 @@
 
     /**
      * 根据id获取门店信息
-     * @param id
-     * @return
      */
     @ResponseBody
     @PostMapping("/getShopById")
@@ -511,6 +578,9 @@
         return R.ok(shop);
     }
 
+    /**
+     * 根据店长id获取门店列表
+     */
     @ResponseBody
     @PostMapping("/getShopByUserId")
     public R<List<Shop>> getShopByUserId(@RequestParam("id") Long id){
@@ -518,11 +588,8 @@
         return R.ok(list);
     }
     
-    
     /**
      * 根据店铺管理员电话获取门店数据
-     * @param phone
-     * @return
      */
     @ResponseBody
     @PostMapping("/getShopByPhone")
@@ -531,11 +598,7 @@
         return R.ok(one);
     }
 
-    @PostMapping("/getShopByUserIds")
-    public R<List<Shop>> getShopByUserIds(@RequestBody List<Long> userIds){
-        List<Shop> list = shopService.list(new LambdaQueryWrapper<Shop>().in(Shop::getAppUserId, userIds));
-        return R.ok(list);
-    }
+
 
     /**
      * 根据名称查询门店id
@@ -585,7 +648,6 @@
     
     /**
      * 编辑门店
-     * @param shop
      */
     @PostMapping("/updateShop")
     public void updateShop(@RequestBody Shop shop){
@@ -593,74 +655,70 @@
     }
 
 
-
-
-    @ResponseBody
-    @GetMapping("/getVerifiableShop")
-    @ApiOperation(value = "获取可核销门店列表", tags = {"购物车-小程序"})
-    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";
-        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);
-        }
-        verifiableShopVoList.sort(new Comparator<VerifiableShopVo>() {
-            @Override
-            public int compare(VerifiableShopVo o1, VerifiableShopVo o2) {
-                return o1.getDistance().compareTo(o2.getDistance());
-            }
-        });
-        return R.ok(verifiableShopVoList);
-    }
-
-
-
     @ResponseBody
     @GetMapping("/getSysUserShop")
     @ApiOperation(value = "获取可切换的门店列表", tags = {"门店后台-首页"})
-    public R<List<VerifiableShopVo>> getSysUserShop(){
-        Long userid = tokenService.getLoginUser().getUserid();
-        UserShop userShop = new UserShop();
-        userShop.setUserId(userid);
-        List<UserShop> data = userShopClient.getUserShop(userShop).getData();
-        List<Integer> collect = data.stream().map(UserShop::getShopId).collect(Collectors.toList());
+    public R<List<VerifiableShopVo>> getSysUserShop(@ApiParam("经度") @RequestParam(required = false) BigDecimal longitude,
+                                                    @ApiParam("纬度") @RequestParam(required = false) BigDecimal latitude){
+        Long userid = tokenService.getLoginUserApplet().getUserid();
+
+        List<AppUserShop> data = appUserShopClient.getUserShopListByUserId(userid).getData();
+        if (null == data || data.isEmpty()) {
+            return R.fail("暂无其他门店可切换");
+        }
+        List<Integer> collect = data.stream().map(AppUserShop::getShopId).collect(Collectors.toList());
         List<Shop> shops = shopService.list(new LambdaQueryWrapper<Shop>()
                 .in(!CollectionUtils.isEmpty(collect),Shop::getId, collect)
                 .eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1));
+        if (shops == null || shops.isEmpty()) {
+            return  R.fail("暂无其他门店可切换");
+        }
         List<VerifiableShopVo> list = new ArrayList<>();
         for (Shop shop : shops) {
             VerifiableShopVo vo = new VerifiableShopVo();
+            BeanUtils.copyProperties(shop, vo);
             vo.setId(shop.getId());
             vo.setName(shop.getName());
+
+            vo.setHomePicture(shop.getHomePicture());
+            if (null != latitude && null != longitude) {
+                Double wgs84 = GeodesyUtil.getDistance(longitude + "," + latitude, shop.getLongitude() + "," + shop.getLatitude()).get("WGS84");
+                vo.setDistance(wgs84.longValue());
+            }
             list.add(vo);
         }
         return R.ok(list);
     }
-    
-    
+
+    @ResponseBody
+    @GetMapping("/getShopBalance")
+    @ApiOperation(value = "获取门店余额", tags = {"门店后台-首页"})
+    public R<ShopBalanceVO> getShopBalance(@ApiParam("门店id") @RequestParam Integer shopId){
+        return R.ok(shopService.getShopBalance(shopId));
+    }
+
+    @ResponseBody
+    @GetMapping("/getShopBalanceStatementList")
+    @ApiOperation(value = "获取门店余额变动明细", tags = {"门店后台-首页"})
+    public R<PageInfo<ShopBalanceStatementVO>> getShopBalanceStatementList(@ApiParam("变动类型(4=提现,5=订单收入,6=订单退款)") Integer type,
+                                                                         @ApiParam("门店id") Integer shopId,
+                                                                         @ApiParam("指定日期") @DateTimeFormat(pattern = "yyyy-MM-dd") LocalDate date,
+                                                                         Integer pageCurr, Integer pageSize){
+        LocalDateTime startTime = null;
+        LocalDateTime endTime = null;
+        if (date != null) {
+            // 将 createTime 设置为当天的开始时间 (00:00)
+            startTime = date.atStartOfDay();
+
+            // 使用 YearMonth 来获取该月的最后一天
+            YearMonth yearMonth = YearMonth.from(date);
+            LocalDate lastDayOfMonth = yearMonth.atEndOfMonth();
+
+            // 将最后一天转换为 LocalDateTime,并设置为当天的最后一秒 (23:59:59.999)
+            endTime = lastDayOfMonth.atTime(LocalTime.MAX);
+        }
+        return R.ok(shopService.getShopBalanceStatementList(shopId,startTime, endTime, type, pageCurr, pageSize));
+    }
     
     @PostMapping("/saveWithdrawalAccount")
     @ApiOperation(value = "保存提现账户", tags = {"门店后台-财务统计-提现明细"})
@@ -670,9 +728,8 @@
     }
 
     @PostMapping("/saveWithdrawalAppletAccount")
-    @ApiOperation(value = "保存提现账户", tags = {"小程序-个人中心-门店管理-门店钱包"})
+    @ApiOperation(value = "保存提现账户", tags = {"门店后台-首页"})
     public R saveWithdrawalAppletAccount(@RequestBody SaveWithdrawalAccount saveWithdrawalAccount){
-
         Shop shop = shopService.getById(saveWithdrawalAccount.getShopId());
         if(null != shop){
             shop.setReceiverAccountNoEnc(saveWithdrawalAccount.getReceiverAccountNoEnc());
@@ -686,18 +743,92 @@
 
 
     /**
+     * 指定门店商品
+     */
+    @ResponseBody
+    @GetMapping("/getGoodsListByShopId")
+    @ApiOperation(value = "获取门店内商品列表", tags = {"门店后台-首页"})
+    public R<PageInfo<GoodsVO>> getGoodsListByShopId(@ApiParam("门店id")@RequestParam("shopId") Integer shopId,
+                                                     @ApiParam("门店id")@RequestParam("pageCurr") Integer pageCurr,
+                                                     @ApiParam("门店id")@RequestParam("pageSize") Integer pageSize) {
+        PageInfo<GoodsVO> pageInfo = new PageInfo<>(pageCurr, pageSize);
+        List<GoodsVO> goodsList = shopService.getGoodsListByShopId(pageInfo, shopId);
+        return R.ok(pageInfo.setRecords(goodsList));
+    }
+
+    /**
+     * 商品详情
+     */
+    @GetMapping("/goodsDetail/{goodsId}")
+    @ApiOperation(value = "商品详情", tags = {"门店后台-首页"})
+    public R<GoodsVO> goodsDetail(@PathVariable("goodsId") Long goodsId) {
+        return R.ok(shopService.goodsDetail(goodsId));
+    }
+
+    /**
+     * 添加商品
+     */
+    @PostMapping("/addGoods")
+    @ApiOperation(value = "发布商品", tags = {"门店后台-商品管理"})
+    public R<Integer> addGoods(@RequestBody AddGoodsDTO addGoodsDTO) {
+        return R.ok( shopService.addGoodsByShop(addGoodsDTO));
+    }
+
+    /**
+     * 编辑商品
+     */
+    @PostMapping("/editGoods")
+    @ApiOperation(value = "编辑商品", tags = {"门店后台-商品管理"})
+    public R<Integer> editGoods(@RequestBody AddGoodsDTO addGoodsDTO) {
+        return R.ok( shopService.editGoodsByShop(addGoodsDTO));
+    }
+
+
+    /**
+     * 上、下架商品
+     */
+    @PostMapping("/status/{goodsId}")
+    @ApiOperation(value = "上、下架商品", tags = {"门店后台-商品管理"})
+    public R<Void> status(@PathVariable Integer goodsId) {
+        Goods goods = goodsService.getById(goodsId);
+        if (goods == null) {
+            return R.fail("商品不存在");
+        }
+        goodsService.update(new UpdateWrapper<Goods>()
+                .setSql("status = CASE status WHEN 1 THEN 2 WHEN 2 THEN 1 ELSE status END")
+                .eq("id", goodsId));
+        return R.ok();
+    }
+
+    /**
+     * 删除商品
+     */
+    @DeleteMapping("/del/{goodsId}")
+    @ApiOperation(value = "删除商品", tags = {"门店后台-商品管理"})
+    public R<Void> delGoods(@PathVariable Integer goodsId) {
+        Goods goods = goodsService.getOne(new LambdaQueryWrapper<Goods>().eq(Goods::getId, goodsId)
+                .eq(Goods::getStatus, 2).eq(Goods::getDelFlag,0));
+        if (goods == null) {
+            return R.fail("商品不存在");
+        }
+        goodsService.update(new LambdaUpdateWrapper<Goods>().eq(Goods::getId, goodsId).set(Goods::getDelFlag,1));
+
+        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));
+        List<Shop> list = shopService.list(new LambdaQueryWrapper<Shop>().eq(Shop::getDelFlag, 0));
         return R.ok(list);
     }
 
     @ResponseBody
     @GetMapping("/verifyAccountConfiguration")
-    @ApiOperation(value = "判断是否有提现账户", tags = {"门店后台-财务管理-提现明细"})
+    @ApiOperation(value = "判断是否有提现账户", tags = {"门店后台-首页"})
     public R verifyAccountConfiguration(){
         Long userid = tokenService.getLoginUser().getUserid();
         SysUser sysUser = sysUserClient.getSysUser(userid).getData();
@@ -735,6 +866,7 @@
     }
 
 
+/*
     @GetMapping("/getShopStatistics")
     public R<Map<String, BigDecimal> > getShopStatistics(@RequestParam("shopId") Integer shopId){
         LambdaQueryWrapper<Shop> queryWrapper = new LambdaQueryWrapper<Shop>().eq(Shop::getDelFlag, 0).eq(Shop::getStatus, 1);
@@ -744,76 +876,35 @@
         List<Shop> shopList = shopService.list(queryWrapper);
         BigDecimal serverGiveawayMoney = BigDecimal.ZERO;
         BigDecimal giveawayMoney = BigDecimal.ZERO;
-        for (Shop shop : shopList) {
+       */
+/* for (Shop shop : shopList) {
             serverGiveawayMoney = serverGiveawayMoney.add(shop.getServerGiveawayMoney());
             giveawayMoney = giveawayMoney.add(shop.getGiveawayMoney().add(shop.getLowerLevelGiveawayMoney()));
-        }
+        }*//*
+
         Map<String, BigDecimal> map = new HashMap<>();
         map.put("serverGiveawayMoney", serverGiveawayMoney);
         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;
+    @PostMapping("/getIncomeAnalysis")
+    R<Map<String, Object>> getIncomeAnalysis(@RequestBody ShopAnalysisDTO shopAnalysisDTO){
+        QueryWrapper<Shop> queryWrapper=new QueryWrapper<>();
+        //余额  已提现 提现中 可提现
+        queryWrapper.select("sum(balance) as balance","sum(withdraw_money) as withdrawMoney"
+                ,"sum(withdraw_audit_money) as withdrawAuditMoney","sum(can_withdraw_money) as canWithdrawMoney");
+        queryWrapper.eq("del_flag",0);
+        if (shopAnalysisDTO.getShopId() != null) {
+            queryWrapper.eq("id", shopAnalysisDTO.getShopId());
         }
-        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 R.ok(shopService.getMap(queryWrapper));
     }
 
-
-
-
-
-
-
-
-
-
-    /**
-     * 获取指定用户的高级服务商
-     * @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