From 3da01b2a6cf247f90aed86fc37d8cb0ab51a4b4c Mon Sep 17 00:00:00 2001
From: yanghui <2536613402@qq.com>
Date: 星期二, 29 十一月 2022 15:58:02 +0800
Subject: [PATCH] #feat .

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComBatteryCommodityOrderCollageTeamServiceImpl.java |   69 ++++++++++++++++++++++++++++------
 1 files changed, 56 insertions(+), 13 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComBatteryCommodityOrderCollageTeamServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComBatteryCommodityOrderCollageTeamServiceImpl.java
index 4fa3e88..02877ce 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComBatteryCommodityOrderCollageTeamServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComBatteryCommodityOrderCollageTeamServiceImpl.java
@@ -1,6 +1,7 @@
 package com.panzhihua.service_community.service.impl;
 
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.panzhihua.common.constants.PayCpmstant;
 import com.panzhihua.common.model.vos.common.ComBatteryCommodityOrderCollageTeamPeopleVo;
 import com.panzhihua.common.model.vos.common.ComBatteryCommodityOrderCollageTeamVo;
@@ -54,16 +55,14 @@
     private ComBatteryTradeOrderService tradeOrderService;
     @Value("${min.app.isTest}")
     private Boolean isTest;
-    @Value("${min.app.isRefundTest}")
-    private Boolean isRefundTest;
     @Value("${min.app.appid}")
     private String appid;
     @Value("${min.app.payKey}")
     private String payKey;
     @Value("${min.app.mchId}")
     private String mchId;
-    @Value("${min.app.currencyNotifyUrl}")
-    private String currencyNotifyUrl;
+//    @Value("${min.app.currencyNotifyUrl}")
+//    private String currencyNotifyUrl;
     @Resource
     private ComBatteryCommodityMapper commodityMapper;
     @Resource
@@ -81,7 +80,24 @@
      */
     @Override
     public R queryByPage(PageComBatteryCommodityOrderCollageTeamDto comBatteryCommodityOrderCollageTeam) {
-        return R.ok(this.baseMapper.queryAllByLimit(comBatteryCommodityOrderCollageTeam, new Page(comBatteryCommodityOrderCollageTeam.getPageNum(), comBatteryCommodityOrderCollageTeam.getPageSize())));
+        IPage<ComBatteryCommodityOrderCollageTeamVo> orderCollageTeamVoIPage = this.baseMapper.queryAllByLimit(comBatteryCommodityOrderCollageTeam
+                , new Page(comBatteryCommodityOrderCollageTeam.getPageNum(), comBatteryCommodityOrderCollageTeam.getPageSize()));
+        //判断该用户是否参与了以下拼团
+        if(comBatteryCommodityOrderCollageTeam.getUserId() != null && comBatteryCommodityOrderCollageTeam.getUserId() != 0L){
+            Long userId = comBatteryCommodityOrderCollageTeam.getUserId();
+            orderCollageTeamVoIPage.getRecords().forEach(orderCollageTeam -> {
+                Map<String,Object> resultMap = this.baseMapper.getUserCollageDetail(orderCollageTeam.getId(),userId);
+                if(resultMap != null){
+                    if(Integer.parseInt(resultMap.get("ktCount").toString()) > 0){
+                        orderCollageTeam.setIsPartake(2);
+                    }
+                    if(Integer.parseInt(resultMap.get("ptCount").toString()) > 0){
+                        orderCollageTeam.setIsPartake(2);
+                    }
+                }
+            });
+        }
+        return R.ok(orderCollageTeamVoIPage);
     }
 
     /**
@@ -148,11 +164,24 @@
      * @date 2022-03-29 16:06:58
      */
     @Override
-    public R detailById(Long id) {
+    public R detailById(Long id,Long userId) {
         ComBatteryCommodityOrderCollageTeamVo orderCollageTeamVo = this.baseMapper.queryById(id);
         if(orderCollageTeamVo != null){
             List<ComBatteryCommodityOrderCollageTeamPeopleVo> collageTeamPeopleList = orderCollageTeamPeopleMapper.queryAllByTeamId(id);
             orderCollageTeamVo.setOrderCollageTeamPeopleList(collageTeamPeopleList);
+            //判断该用户是否参与了以下拼团
+            if(userId != null && userId != 0L){
+                Map<String,Object> resultMap = this.baseMapper.getUserCollageDetail(orderCollageTeamVo.getId(),userId);
+                if(resultMap != null){
+                    if(Integer.parseInt(resultMap.get("ktCount").toString()) > 0){
+                        orderCollageTeamVo.setIsPartake(2);
+                    }
+                    if(Integer.parseInt(resultMap.get("ptCount").toString()) > 0){
+                        orderCollageTeamVo.setIsPartake(2);
+                    }
+                }
+            }
+
         }
         return R.ok(orderCollageTeamVo);
     }
@@ -189,9 +218,6 @@
                 || commodityActivity.getStatus().equals(ComBatteryCommodityActivity.Status.YJS)){
             return R.fail("该活动已结束");
         }
-        if(commodityActivity.getCommodityNum() <= commodityActivity.getCommoditySaleNum()){
-            return R.fail("活动商品已售空");
-        }
         if(orderDto.getType().equals(StartFightOrderDto.Type.PT)){
             //判断该团队人数是否已满
             Integer count = orderCollageTeamPeopleMapper.selectCount(new QueryWrapper<ComBatteryCommodityOrderCollageTeamPeople>().lambda()
@@ -199,10 +225,20 @@
             if(count >= commodityActivity.getCollagePeopleNum()){
                 return R.fail("拼团人数已满");
             }
+            //判断该团是否已参与
+            Integer userCount = orderCollageTeamPeopleMapper.selectCount(new QueryWrapper<ComBatteryCommodityOrderCollageTeamPeople>().lambda()
+                    .eq(ComBatteryCommodityOrderCollageTeamPeople::getTeamId,orderDto.getTeamId())
+                    .eq(ComBatteryCommodityOrderCollageTeamPeople::getUserId,orderDto.getUserId()));
+            if(userCount >= commodityActivity.getCollagePeopleNum()){
+                return R.fail("您已参与该拼团,不可重复参与");
+            }
             //查询拼团团队
             ComBatteryCommodityOrderCollageTeam orderCollageTeam = orderCollageTeamMapper.selectById(orderDto.getTeamId());
             if(orderCollageTeam == null){
                 return R.fail("该拼团不存在");
+            }
+            if(orderDto.getUserId().equals(orderCollageTeam.getUserId())){
+                return R.fail("您不可拼自己的团");
             }
             if(!orderCollageTeam.getStatus().equals(ComBatteryCommodityOrderCollageTeam.Status.DDPT)){
                 return R.fail("该拼团已成功");
@@ -210,8 +246,15 @@
         }else{
             Integer count = orderCollageTeamMapper.selectCount(new QueryWrapper<ComBatteryCommodityOrderCollageTeam>().lambda()
                     .eq(ComBatteryCommodityOrderCollageTeam::getActivityId,orderDto.getActivityId())
+                    .eq(ComBatteryCommodityOrderCollageTeam::getStatus,ComBatteryCommodityOrderCollageTeam.Status.DDPT)
+                    .eq(ComBatteryCommodityOrderCollageTeam::getUserId,orderDto.getUserId()));
+            if(count > 0){
+                return R.fail("当前活动商品您正在拼团中,不可重复开团");
+            }
+            Integer maxCount = orderCollageTeamMapper.selectCount(new QueryWrapper<ComBatteryCommodityOrderCollageTeam>().lambda()
+                    .eq(ComBatteryCommodityOrderCollageTeam::getActivityId,orderDto.getActivityId())
                     .eq(ComBatteryCommodityOrderCollageTeam::getStatus,ComBatteryCommodityOrderCollageTeam.Status.DDPT));
-            if(count >= commodityActivity.getCollageNum()){
+            if(maxCount >= commodityActivity.getCollageNum()){
                 return R.fail("当前正在拼团的数量已达到最大值,不可在开团");
             }
         }
@@ -221,7 +264,7 @@
             return R.fail("未查询到商品信息");
         }
         //查询用户信息
-        SysUser user = userMapper.selectById(orderDto.getUserId());
+        SysUser user = userMapper.selectOne(new QueryWrapper<SysUser>().lambda().eq(SysUser::getUserId,orderDto.getUserId()));
         if(user == null){
             return R.fail("未查询到用户信息");
         }
@@ -281,8 +324,8 @@
             money = BigDecimal.valueOf(0.01);
         }
         // 调用wx支付
-        result = WxPayUtils.getUnifiedorder(appid, mchId, payKey, currencyNotifyUrl + PayCpmstant.BATTERY_STORE_ACTIVITY_PAY_NOTIFY_URL
-                , remark, openId, orderNo, money,type);
+//        result = WxPayUtils.getUnifiedorder(appid, mchId, payKey, currencyNotifyUrl + PayCpmstant.BATTERY_STORE_ACTIVITY_PAY_NOTIFY_URL
+//                , remark, openId, orderNo, money,type);
         log.info("用户购买商品微信支付返回参数:" + result);
         return result;
     }

--
Gitblit v1.7.1