From f6fe09539d37e44b199d6c1d09798088209d6d72 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期三, 24 七月 2024 19:34:02 +0800
Subject: [PATCH] 玩湃门店数据权限修改 收入管理增加世界杯记录

---
 cloud-server-communityWorldCup/src/main/java/com/dsh/communityWorldCup/service/impl/WorldCupServiceImpl.java |  414 ++++++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 308 insertions(+), 106 deletions(-)

diff --git a/cloud-server-communityWorldCup/src/main/java/com/dsh/communityWorldCup/service/impl/WorldCupServiceImpl.java b/cloud-server-communityWorldCup/src/main/java/com/dsh/communityWorldCup/service/impl/WorldCupServiceImpl.java
index 30e792b..4823159 100644
--- a/cloud-server-communityWorldCup/src/main/java/com/dsh/communityWorldCup/service/impl/WorldCupServiceImpl.java
+++ b/cloud-server-communityWorldCup/src/main/java/com/dsh/communityWorldCup/service/impl/WorldCupServiceImpl.java
@@ -9,7 +9,9 @@
 import com.dsh.communityWorldCup.entity.*;
 import com.dsh.communityWorldCup.feignclient.account.AppUserClient;
 import com.dsh.communityWorldCup.feignclient.account.StudentClient;
+import com.dsh.communityWorldCup.feignclient.account.UserIntegralChangesClient;
 import com.dsh.communityWorldCup.feignclient.account.model.AppUser;
+import com.dsh.communityWorldCup.feignclient.account.model.SaveUserIntegralChangesVo;
 import com.dsh.communityWorldCup.feignclient.account.model.TStudent;
 import com.dsh.communityWorldCup.feignclient.competition.ParticipantClient;
 import com.dsh.communityWorldCup.feignclient.competition.model.Participant;
@@ -73,6 +75,9 @@
     @Resource
     private GameClient gameClient;
 
+    @Resource
+    private UserIntegralChangesClient userIntegralChangesClient;
+
 
 
 
@@ -84,15 +89,22 @@
     @Override
     public List<WorldCupListCoachVo> getWorldCupListCoach(WorldCupListCoach worldCupListCoach) {
         List<WorldCupListCoachVo> worldCupListCoach1 = this.baseMapper.getWorldCupListCoach(worldCupListCoach);
+        for (WorldCupListCoachVo worldCupListCoachVo : worldCupListCoach1) {
+            String lat = worldCupListCoachVo.getLat();
+            String lon = worldCupListCoachVo.getLon();
+            if(ToolUtil.isNotEmpty(worldCupListCoach.getLon()) && ToolUtil.isNotEmpty(worldCupListCoach.getLat())){
+                Map<String, Double> distance2 = GeodesyUtil.getDistance(lon + "," + lat, worldCupListCoach.getLon() + "," + worldCupListCoach.getLat());
+                Double wgs842 = distance2.get("WGS84");
+                worldCupListCoachVo.setDistance(wgs842);
+            }else{
+                worldCupListCoachVo.setDistance(0D);
+            }
+        }
         //对查询结果进行距离排序(直线距离)
         Collections.sort(worldCupListCoach1, new Comparator<WorldCupListCoachVo>() {
             @Override
             public int compare(WorldCupListCoachVo o1, WorldCupListCoachVo o2) {
-                Map<String, Double> distance1 = GeodesyUtil.getDistance(o1.getLon() + "," + o1.getLat(), worldCupListCoach.getLon() + "," + worldCupListCoach.getLat());
-                Double wgs841 = distance1.get("WGS84");
-                Map<String, Double> distance2 = GeodesyUtil.getDistance(o2.getLon() + "," + o2.getLat(), worldCupListCoach.getLon() + "," + worldCupListCoach.getLat());
-                Double wgs842 = distance2.get("WGS84");
-                return wgs841.compareTo(wgs842);
+                return o1.getDistance().compareTo(o2.getDistance());
             }
         });
         return worldCupListCoach1;
@@ -127,11 +139,14 @@
 
         String people = startWorldCup.getPeople();
         JSONArray jsonArray = JSON.parseArray(people);
+        if(jsonArray.size() != 6){
+            return ResultUtil.error("参赛人数只能是6人");
+        }
         String timeStr = UUIDUtil.getTimeStr() + UUIDUtil.getNumberRandom(3);
         List<Long> ids = new ArrayList<>();
         for (int i = 0; i < jsonArray.size(); i++) {
             JSONObject jsonObject = jsonArray.getJSONObject(i);
-            Integer id = jsonObject.getInteger("id");
+            Long id = jsonObject.getLong("id");
             Integer participantType = jsonObject.getInteger("participantType");
             String type = jsonObject.getString("type");
             WorldCupCompetitor worldCupCompetitor = new WorldCupCompetitor();
@@ -143,25 +158,45 @@
             worldCupCompetitor.setParticipantId(id);
             worldCupCompetitor.setParticipant("blue".equals(type) ? 1 : 2);
             worldCupCompetitor.setStartTime(new Date());
+            //添加参赛奖励
+            if(null != worldCup.getParticipationIntegral() && 0 < worldCup.getParticipationIntegral()){
+                worldCupCompetitor.setParticipationIntegral(worldCup.getParticipationIntegral());
+                //增加积分明细
+                SaveUserIntegralChangesVo vo = new SaveUserIntegralChangesVo();
+                vo.setAppUserId(worldCupCompetitor.getAppUserId());
+                vo.setIntegral(worldCup.getParticipationIntegral());
+                vo.setType(6);
+                userIntegralChangesClient.saveUserIntegralChanges(vo);
+            }
+
             worldCupCompetitorService.save(worldCupCompetitor);
             ids.add(worldCupCompetitor.getId());
             //已参赛
-            worldCupPaymentParticipant.setAlreadyEntered(1);
-            worldCupPaymentParticipantService.updateById(worldCupPaymentParticipant);
+            if(0 == worldCupPaymentParticipant.getAlreadyEntered()){
+                worldCupPaymentParticipant.setWorldCupId(null);
+                worldCupPaymentParticipant.setAlreadyEntered(1);
+                worldCupPaymentParticipantService.updateById(worldCupPaymentParticipant);
+            }
         }
+        worldCup.setMatchNumber(worldCup.getMatchNumber() + 1);
+        this.updateById(worldCup);
+
+        JSONObject jsonObject = new JSONObject();
+        jsonObject.put("gameType", 1);
+        jsonObject.put("ids", ids);
         //2、调起开启游戏的接口。
         HashMap<String, String> map = new HashMap<>();
         map.put("sign", "0DB011836143EEE2C2E072967C9F4E4B");
         map.put("space_id", tGame.getSiteId() + "");
         map.put("red_sutu_id", tGame.getRed());
         map.put("blue_sutu_id", tGame.getBlue());
-        map.put("api_url", "http://221.182.45.100:56666/communityWorldCup/base/worldCup/endWorldCupCallback");
-        map.put("custom", JSON.toJSONString(ids));
+        map.put("api_url", "https://online.daowepark.com:443/communityWorldCup/base/worldCup/endWorldCupCallback");
+        map.put("custom", jsonObject.toJSONString());
 
-        String s = HttpRequestUtil.postRequest("https://try.daowepark.com/v7/user_api/general/batterGame", map);
-        JSONObject jsonObject = JSONObject.parseObject(s);
-        Integer code1 = jsonObject.getInteger("code");
-        String message = jsonObject.getString("message");
+        String s = HttpRequestUtil.postRequest("https://port.daowepark.com/v7/user_api/general/quickStart", map);
+        JSONObject jsonObject1 = JSONObject.parseObject(s);
+        Integer code1 = jsonObject1.getInteger("code");
+        String message = jsonObject1.getString("message");
         if (200 == code1) {
             return ResultUtil.success();
         } else {
@@ -177,9 +212,17 @@
      */
     @Override
     public Integer getCompletedWorldCupTips(Integer uid) {
-        int count = worldCupCompetitorService.count(new QueryWrapper<WorldCupCompetitor>()
-                .eq("appUserId", uid).eq("tips", 0).isNotNull("endTime"));
-        return count;
+        List<WorldCupCompetitor> list = worldCupCompetitorService.list(new QueryWrapper<WorldCupCompetitor>()
+                .eq("appUserId", uid).eq("tips", 0).isNotNull("endTime")
+                .orderByDesc("endTime").last(" limit 0, 1"));
+        list.forEach(v->{
+            v.setWorldCupId(null);
+            v.setTips(1);
+        });
+        if(list.size() > 0){
+            worldCupCompetitorService.updateBatchById(list);
+        }
+        return list.size();
     }
 
 
@@ -190,9 +233,8 @@
      */
     @Override
     public List<WorldCupListVo> getWorldCupList(WorldCupList worldCupList) {
-        //没有筛选门店,默认使用当前门店
-        if(null == worldCupList.getStoreId()){
-            worldCupList.setStoreId(worldCupList.getStoreId());
+        if(null != worldCupList.getGender() && 0 == worldCupList.getGender()){
+            worldCupList.setGender(null);
         }
         List<WorldCupListVo> worldCupList1 = this.baseMapper.getWorldCupList(worldCupList);
         for (WorldCupListVo worldCupListVo : worldCupList1) {
@@ -207,8 +249,12 @@
             worldCupListVo.setHeat(heat);
             String lat = worldCupListVo.getLat();
             String lon = worldCupListVo.getLon();
-            Map<String, Double> distance = GeodesyUtil.getDistance(lon + "," + lat, worldCupList.getLon() + "," + worldCupList.getLat());
-            worldCupListVo.setDistance(distance.get("WGS84"));
+            if(ToolUtil.isNotEmpty(lat) && ToolUtil.isNotEmpty(lon)){
+                Map<String, Double> distance = GeodesyUtil.getDistance(lon + "," + lat, worldCupList.getLon() + "," + worldCupList.getLat());
+                worldCupListVo.setDistance(distance.get("WGS84"));
+            }else{
+                worldCupListVo.setDistance(0D);
+            }
         }
 
 
@@ -229,7 +275,7 @@
             Collections.sort(worldCupList1, new Comparator<WorldCupListVo>() {
                 @Override
                 public int compare(WorldCupListVo o1, WorldCupListVo o2) {
-                    return o1.getDistance().compareTo(o2.getDistance()) * -1;
+                    return o1.getDistance().compareTo(o2.getDistance());
                 }
             });
         }
@@ -261,6 +307,14 @@
             int count = worldCupPaymentParticipantService.count(new QueryWrapper<WorldCupPaymentParticipant>().in("worldCupPaymentId", collect));
             heat += count;
         }
+        String infoImg = worldCupInfo.getInfoImg();
+        JSONArray jsonArray1 = JSON.parseArray(infoImg);
+        String imgs = "";
+        for (int i = 0; i < jsonArray1.size(); i++) {
+            String url = jsonArray1.getJSONObject(i).getString("url");
+            imgs += url + ",";
+        }
+        worldCupInfo.setInfoImg(imgs.substring(0,imgs.length() - 1));
         worldCupInfo.setHeat(heat);
         ArrayList<Map<String, Object>> objects = new ArrayList<>();
         for (WorldCupStore worldCupStore : worldCupStores) {
@@ -290,6 +344,25 @@
             objects.add(map);
         }
         worldCupInfo.setStoreInfos(objects);
+        String address = worldCupInfo.getAddress();
+        String province = worldCupInfo.getProvince();
+        String city = worldCupInfo.getCity();
+        int index = address.indexOf("市");
+        if(index != -1){
+            address = address.substring(index + 1);
+            worldCupInfo.setAddress(address);
+        }
+        index = province.indexOf("省");
+        if(index != -1){
+            province = province.substring(0, index - 1);
+            worldCupInfo.setProvince(province);
+        }
+        index = city.indexOf("市");
+        if(index != -1){
+            city = city.substring(0, index - 1);
+            worldCupInfo.setCity(city);
+        }
+
         return worldCupInfo;
     }
 
@@ -302,8 +375,14 @@
     @Override
     public CheckPaymentMethodVo checkPaymentMethod(CheckPaymentMethod checkPaymentMethod) {
         WorldCup worldCup = this.getById(checkPaymentMethod.getId());
-        JSONArray jsonArray = JSON.parseArray(checkPaymentMethod.getIds());
+        String[] split = worldCup.getPayType().split(",");
         CheckPaymentMethodVo checkPaymentMethodVo = new CheckPaymentMethodVo();
+        if(split.length == 1 && "0".equals(split[0])){
+            checkPaymentMethodVo.setPaiCoin(0);
+            checkPaymentMethodVo.setClassHour(0);
+            return checkPaymentMethodVo;
+        }
+        JSONArray jsonArray = JSON.parseArray(checkPaymentMethod.getIds());
         AppUser appUser = appUserClient.getAppUser(checkPaymentMethod.getUid());
         BigDecimal multiply = new BigDecimal(jsonArray.size()).multiply(new BigDecimal(worldCup.getPaiCoin()));
         if(appUser.getPlayPaiCoins() < multiply.intValue()){
@@ -348,34 +427,75 @@
         if(null == worldCup){
             return ResultUtil.error("报名数据异常");
         }
-        if(System.currentTimeMillis() > worldCup.getRegistrationClosingTime().getTime()){
+        if(null != worldCup.getRegistrationClosingTime() && System.currentTimeMillis() > worldCup.getRegistrationClosingTime().getTime()){
             return ResultUtil.error("报名时间已结束,无法完成报名");
         }
         if(System.currentTimeMillis() > worldCup.getEndTime().getTime()){
             return ResultUtil.error("世界杯赛事已结束,无法完成报名");
         }
-        String ids = paymentWorldCup.getIds();
-        JSONArray jsonArray = JSON.parseArray(ids);
+
+        String cupIds = paymentWorldCup.getIds();
+        JSONArray jsonArray = JSON.parseArray(cupIds);
+        List<WorldCupPayment> payments = worldCupPaymentService.list(new QueryWrapper<WorldCupPayment>().eq("worldCupId", worldCup.getId())
+                .eq("payStatus", 2).eq("state", 1));
+        List<Long> ids = payments.stream().map(WorldCupPayment::getId).collect(Collectors.toList());
+        if(ids.size() > 0){
+            int count = worldCupPaymentParticipantService.count(new QueryWrapper<WorldCupPaymentParticipant>().eq("worldCupId", worldCup.getId())
+                    .eq("worldCupPaymentId", ids));
+            if((count + jsonArray.size()) >= worldCup.getMaxPeople()){
+                return ResultUtil.error("已超出最大报名人数");
+            }
+        }else{
+            if(jsonArray.size() > worldCup.getMaxPeople()){
+                return ResultUtil.error("已超出最大报名人数");
+            }
+        }
+
+        List<WorldCupPayment> list = worldCupPaymentService.list(new QueryWrapper<WorldCupPayment>().eq("worldCupId", worldCup.getId()).eq("appUserId", paymentWorldCup.getUid())
+                .eq("payStatus", 2).eq("state", 1));
+        List<Long> collect = list.stream().map(WorldCupPayment::getId).collect(Collectors.toList());
         SimpleDateFormat sdf = new SimpleDateFormat("yyyy");
         for (int i = 0; i < jsonArray.size(); i++) {
             JSONObject jsonObject = jsonArray.getJSONObject(i);
-            Integer id = jsonObject.getInteger("id");
+            Long id = jsonObject.getLong("id");
             //是否是学员(0=否,1=是)
             Integer isStudent = jsonObject.getInteger("isStudent");
             if(isStudent == 1){
-                TStudent tStudent = studentClient.queryById(id);
-                if(worldCup.getStartAge() > Integer.valueOf(sdf.format(tStudent.getBirthday()))){
+                TStudent tStudent = studentClient.queryById(id.intValue());
+                if(worldCup.getGender() != 0 && !tStudent.getSex().equals(worldCup.getGender())){
+                    return ResultUtil.error("此比赛只能是" + (worldCup.getGender() == 1 ? "男" : "女") + "性参加");
+                }
+                if(collect.size() > 0){
+                    WorldCupPaymentParticipant one = worldCupPaymentParticipantService.getOne(new QueryWrapper<WorldCupPaymentParticipant>().eq("worldCupId", worldCup.getId())
+                            .eq("participantId", id).eq("participantType", isStudent == 0 ? 2 : 1).in("worldCupPaymentId", collect));
+                    if(null != one){
+                        return ResultUtil.error("【" + tStudent.getName() + "】已报过名了");
+                    }
+                }
+
+                if(worldCup.getStartAge() > (Integer.valueOf(sdf.format(new Date())) - Integer.valueOf(sdf.format(tStudent.getBirthday())))){
                     return ResultUtil.error("【" + tStudent.getName() + "】年龄不符合要求");
                 }
-                if(worldCup.getEndAge() < Integer.valueOf(sdf.format(tStudent.getBirthday()))){
+                if(worldCup.getEndAge() < (Integer.valueOf(sdf.format(new Date())) - Integer.valueOf(sdf.format(tStudent.getBirthday())))){
                     return ResultUtil.error("【" + tStudent.getName() + "】年龄不符合要求");
                 }
             }else{
                 Participant participant = participantClient.getParticipant(id);
-                if(worldCup.getStartAge() > Integer.valueOf(sdf.format(participant.getBirthday()))){
+                if(worldCup.getGender() != 0 && !participant.getGender().equals(worldCup.getGender())){
+                    return ResultUtil.error("此比赛只能是" + (worldCup.getGender() == 1 ? "男" : "女") + "性参加");
+                }
+                if(collect.size() > 0){
+                    WorldCupPaymentParticipant one = worldCupPaymentParticipantService.getOne(new QueryWrapper<WorldCupPaymentParticipant>().eq("worldCupId", worldCup.getId())
+                            .eq("participantId", id).eq("participantType", isStudent == 0 ? 2 : 1).in("worldCupPaymentId", collect));
+                    if(null != one){
+                        return ResultUtil.error("【" + participant.getName() + "】已报过名了");
+                    }
+                }
+
+                if(worldCup.getStartAge() > (Integer.valueOf(sdf.format(new Date())) - Integer.valueOf(sdf.format(participant.getBirthday())))){
                     return ResultUtil.error("【" + participant.getName() + "】年龄不符合要求");
                 }
-                if(worldCup.getEndAge() < Integer.valueOf(sdf.format(participant.getBirthday()))){
+                if(worldCup.getEndAge() < (Integer.valueOf(sdf.format(new Date())) - Integer.valueOf(sdf.format(participant.getBirthday())))){
                     return ResultUtil.error("【" + participant.getName() + "】年龄不符合要求");
                 }
             }
@@ -411,7 +531,8 @@
         worldCupPayment.setEntrant(paymentWorldCup.getIds());
         int num = JSON.parseArray(paymentWorldCup.getIds()).size();
         //不免费
-        if(worldCup.getPayType() != 0){
+        String payType1 = worldCup.getPayType().split(",")[0];
+        if(!"0".equals(payType1)){
             Integer payType = paymentWorldCup.getPayType();
             //微信
             if(payType == 1){
@@ -419,7 +540,7 @@
                 worldCupPayment.setUnitPrice(worldCupPayment.getAmount().divide(new BigDecimal(num)));
                 worldCupPaymentService.save(worldCupPayment);
                 return payMoneyUtil.weixinpay("社区世界杯报名", "", worldCupPayment.getCode(),
-                        worldCup.getCash().toString(), "/base/worldCup/wxPayWorldCupCallback", "APP", "");
+                        worldCupPayment.getAmount().toString(), "/base/worldCup/wxPayWorldCupCallback", "APP", "");
             }
             //支付宝
             if(payType == 2){
@@ -427,7 +548,7 @@
                 worldCupPayment.setUnitPrice(worldCupPayment.getAmount().divide(new BigDecimal(num)));
                 worldCupPaymentService.save(worldCupPayment);
                 return payMoneyUtil.alipay("2088330203191220", "社区世界杯报名", "世界杯报名", "", worldCupPayment.getCode(),
-                        worldCup.getCash().toString(), "/base/worldCup/aliPayWorldCupCallback");
+                        worldCupPayment.getAmount().toString(), "/base/worldCup/aliPayWorldCupCallback");
             }
             //玩湃币
             if(payType == 3){
@@ -444,13 +565,14 @@
 
                 appUser.setPlayPaiCoins(appUser.getPlayPaiCoins() - multiply.intValue());
                 appUserClient.updateAppUser(appUser);
+                //
 
                 //添加报名明细
                 String ids = paymentWorldCup.getIds();
                 JSONArray jsonArray = JSON.parseArray(ids);
                 for (int i = 0; i < jsonArray.size(); i++) {
                     JSONObject jsonObject = jsonArray.getJSONObject(i);
-                    Integer id = jsonObject.getInteger("id");
+                    Long id = jsonObject.getLong("id");
                     //是否是学员(0=否,1=是)
                     Integer isStudent = jsonObject.getInteger("isStudent");
 
@@ -471,25 +593,43 @@
                 BigDecimal multiply = new BigDecimal(num).multiply(new BigDecimal(worldCup.getClassHour()));
                 String ids = paymentWorldCup.getIds();
                 JSONArray jsonArray = JSON.parseArray(ids);
-                List<DeductionClassHour> list = new ArrayList<>();
+
+
+                List<CoursePackageOrderStudent> coursePackageOrderStudent = coursePackageOrderStudentClient.getCoursePackageOrderUser(paymentWorldCup.getUid());
+                int sum = coursePackageOrderStudent.stream().mapToInt(CoursePackageOrderStudent::getLaveClassHours).sum();
+                if(sum < worldCup.getClassHour() * num){
+                    return ResultUtil.error("报名失败,课时不足,请续课!");
+                }
+
                 for (int i = 0; i < jsonArray.size(); i++) {
                     JSONObject jsonObject = jsonArray.getJSONObject(i);
-                    Integer id = jsonObject.getInteger("id");
                     //是否是学员(0=否,1=是)
                     Integer isStudent = jsonObject.getInteger("isStudent");
                     if(0 == isStudent){
                         return ResultUtil.error("非学员无法使用课时报名");
                     }
-                    List<CoursePackageOrderStudent> coursePackageOrderStudent = coursePackageOrderStudentClient.getCoursePackageOrderStudent(id);
-                    int sum = coursePackageOrderStudent.stream().mapToInt(CoursePackageOrderStudent::getLaveClassHours).sum();
-                    if(sum < worldCup.getClassHour()){
-                        return ResultUtil.error("报名失败,课时不足,请续课!");
-                    }
+                }
 
+                worldCupPayment.setAmount(multiply);
+                worldCupPayment.setPayStatus(2);
+                worldCupPayment.setPayTime(new Date());
+                worldCupPayment.setUnitPrice(worldCupPayment.getAmount().divide(new BigDecimal(num)));
+                worldCupPaymentService.save(worldCupPayment);
+
+                //添加报名明细
+                for (int i = 0; i < jsonArray.size(); i++) {
+                    JSONObject jsonObject = jsonArray.getJSONObject(i);
+                    Long id = jsonObject.getLong("id");
+                    //是否是学员(0=否,1=是)
+                    Integer isStudent = jsonObject.getInteger("isStudent");
+                    List<DeductionClassHour> list = new ArrayList<>();
                     //构建扣减课时数据
                     Integer classHour = worldCup.getClassHour();
                     for (CoursePackageOrderStudent packageOrderStudent : coursePackageOrderStudent) {
                         Integer laveClassHours = packageOrderStudent.getLaveClassHours();
+                        if(laveClassHours == 0){
+                            continue;
+                        }
 
                         DeductionClassHour deductionClassHour = new DeductionClassHour();
                         if(classHour.compareTo(laveClassHours) > 0){
@@ -499,6 +639,7 @@
                             deductionClassHour.setClassHour(laveClassHours);
                             deductionClassHour.setStudentId(packageOrderStudent.getStudentId());
                             deductionClassHour.setCoursePackageId(packageOrderStudent.getCoursePackageId());
+                            packageOrderStudent.setLaveClassHours(0);
                             list.add(deductionClassHour);
                         }else{
                             //够扣除直接跳出进行下个学员
@@ -506,6 +647,7 @@
                             deductionClassHour.setClassHour(classHour);
                             deductionClassHour.setStudentId(packageOrderStudent.getStudentId());
                             deductionClassHour.setCoursePackageId(packageOrderStudent.getCoursePackageId());
+                            packageOrderStudent.setLaveClassHours(laveClassHours - classHour);
                             list.add(deductionClassHour);
                             break;
                         }
@@ -515,7 +657,6 @@
                     DeductionClassHourList deductionClassHourList = new DeductionClassHourList();
                     deductionClassHourList.setDeductionClassHourList(list);
                     DeductionClassHourList deductionClassHourList1 = coursePackageOrderStudentClient.deductionClassHour(deductionClassHourList);
-                    List<DeductionClassHour> deductionClassHourList2 = deductionClassHourList1.getDeductionClassHourList();
 
                     WorldCupPaymentParticipant worldCupPaymentParticipant = new WorldCupPaymentParticipant();
                     worldCupPaymentParticipant.setWorldCupId(paymentWorldCup.getId());
@@ -525,15 +666,10 @@
                     worldCupPaymentParticipant.setParticipantId(id);
                     worldCupPaymentParticipant.setAlreadyEntered(0);
                     worldCupPaymentParticipant.setCreateTime(new Date());
-                    worldCupPaymentParticipant.setContent(JSON.toJSONString(deductionClassHourList2));
+                    worldCupPaymentParticipant.setContent(JSON.toJSONString(deductionClassHourList1));
                     worldCupPaymentParticipantService.save(worldCupPaymentParticipant);
                 }
 
-                worldCupPayment.setAmount(multiply);
-                worldCupPayment.setPayStatus(2);
-                worldCupPayment.setPayTime(new Date());
-                worldCupPayment.setUnitPrice(worldCupPayment.getAmount().divide(new BigDecimal(num)));
-                worldCupPaymentService.save(worldCupPayment);
                 return ResultUtil.success();
             }
         }else{
@@ -549,7 +685,7 @@
             JSONArray jsonArray = JSON.parseArray(ids);
             for (int i = 0; i < jsonArray.size(); i++) {
                 JSONObject jsonObject = jsonArray.getJSONObject(i);
-                Integer id = jsonObject.getInteger("id");
+                Long id = jsonObject.getLong("id");
                 //是否是学员(0=否,1=是)
                 Integer isStudent = jsonObject.getInteger("isStudent");
 
@@ -578,8 +714,11 @@
     @Override
     public ResultUtil paymentWorldCupCallback(String code, String outTradeNo) {
         WorldCupPayment worldCupPayment = worldCupPaymentService.getOne(new QueryWrapper<WorldCupPayment>().eq("code", code));
+        Integer worldCupId = worldCupPayment.getWorldCupId();
         worldCupPayment.setPayStatus(2);
+        worldCupPayment.setPayOrderNo(outTradeNo);
         worldCupPayment.setPayTime(new Date());
+        worldCupPayment.setWorldCupId(null);
         worldCupPaymentService.updateById(worldCupPayment);
 
         //添加报名明细
@@ -587,12 +726,12 @@
         JSONArray jsonArray = JSON.parseArray(ids);
         for (int i = 0; i < jsonArray.size(); i++) {
             JSONObject jsonObject = jsonArray.getJSONObject(i);
-            Integer id = jsonObject.getInteger("id");
+            Long id = jsonObject.getLong("id");
             //是否是学员(0=否,1=是)
             Integer isStudent = jsonObject.getInteger("isStudent");
 
             WorldCupPaymentParticipant worldCupPaymentParticipant = new WorldCupPaymentParticipant();
-            worldCupPaymentParticipant.setWorldCupId(worldCupPayment.getWorldCupId());
+            worldCupPaymentParticipant.setWorldCupId(worldCupId);
             worldCupPaymentParticipant.setWorldCupPaymentId(worldCupPayment.getId());
             worldCupPaymentParticipant.setAppUserId(worldCupPayment.getAppUserId());
             worldCupPaymentParticipant.setParticipantType(isStudent == 0 ? 2 : 1);
@@ -606,19 +745,45 @@
 
 
     /**
+     * 获取比赛管理列表数据
+     * @param worldCupListAll
+     * @return
+     */
+    @Override
+    public Map<String, Object> getWorldCupListAll(WorldCupListAll worldCupListAll) {
+        Map<String, Object> map = new HashMap<>();
+        List<Map<String, Object>> list = this.baseMapper.getWorldCupListAll(worldCupListAll);
+        for (Map<String, Object> map1 : list) {
+            String maxPeople = map1.get("maxPeople").toString();
+            Integer id = Integer.valueOf(map1.get("id").toString());
+            List<WorldCupPayment> lists = worldCupPaymentService.list(new QueryWrapper<WorldCupPayment>().eq("worldCupId", id).eq("payStatus", 2).eq("state", 1));
+            List<Long> collect = lists.stream().map(WorldCupPayment::getId).collect(Collectors.toList());
+            Integer count = 0;
+            if(collect.size() > 0){
+                count = worldCupPaymentParticipantService.count(new QueryWrapper<WorldCupPaymentParticipant>().in("worldCupPaymentId", collect));
+            }
+            map1.put("maxPeople", maxPeople + " - " + count);
+        }
+        Integer count = this.baseMapper.getWorldCupListAllCount(worldCupListAll);
+        map.put("rows", list);
+        map.put("total", count);
+        return map;
+    }
+
+
+    /**
      * 取消赛事后退还费用
      * @param id
      */
     @Override
     public void cancelWorldCupRefund(Integer id) {
-        List<WorldCupPaymentParticipant> list = worldCupPaymentParticipantService.list(new QueryWrapper<WorldCupPaymentParticipant>()
-                .eq("worldCupId", id).eq("alreadyEntered", 0));
-        Set<Long> collect = list.stream().map(WorldCupPaymentParticipant::getWorldCupPaymentId).collect(Collectors.toSet());
-        for (Long worldCupPaymentId : collect) {
-
+        //免费除外
+        List<WorldCupPayment> list2 = worldCupPaymentService.list(new QueryWrapper<WorldCupPayment>().eq("worldCupId", id)
+                .ne("payType", 0).eq("payStatus", 2).eq("state", 1));
+        for (WorldCupPayment worldCupPayment : list2) {
             List<WorldCupPaymentParticipant> list1 = worldCupPaymentParticipantService.list(new QueryWrapper<WorldCupPaymentParticipant>()
-                    .eq("worldCupPaymentId", worldCupPaymentId).eq("alreadyEntered", 0));
-            WorldCupPayment worldCupPayment = worldCupPaymentService.getById(worldCupPaymentId);
+                    .eq("worldCupId", id).eq("worldCupPaymentId", worldCupPayment.getId()).eq("alreadyEntered", 0));
+            //总支付金额
             BigDecimal multiply = worldCupPayment.getUnitPrice().multiply(new BigDecimal(list1.size()));
             //微信支付
             if(worldCupPayment.getPayType() == 1){
@@ -627,6 +792,9 @@
                 if(!"SUCCESS".equals(map.get("return_code"))){
                     System.err.println("-------------微信退款失败---------");
                     System.err.println(map.get("return_msg"));
+                }else{
+                    worldCupPayment.setRefundAmount(multiply);
+                    worldCupPaymentService.updateById(worldCupPayment);
                 }
             }
             //支付宝支付
@@ -639,8 +807,10 @@
                 }
                 if("10000".equals(map.get("code"))){
                     String trade_no = map.get("trade_no");
+                    worldCupPayment.setWorldCupId(null);
                     worldCupPayment.setRefundTime(new Date());
                     worldCupPayment.setRefundOrderNo(trade_no);
+                    worldCupPayment.setRefundAmount(multiply);
                     worldCupPayment.setPayStatus(3);
                     worldCupPaymentService.updateById(worldCupPayment);
                 }
@@ -651,62 +821,94 @@
                 AppUser appUser = appUserClient.getAppUser(appUserId);
                 appUser.setPlayPaiCoins(appUser.getPlayPaiCoins() + multiply.intValue());
                 appUserClient.updateAppUser(appUser);
+                worldCupPayment.setWorldCupId(null);
+                worldCupPayment.setRefundTime(new Date());
+                worldCupPayment.setRefundOrderNo("");
+                worldCupPayment.setRefundAmount(multiply);
+                worldCupPayment.setPayStatus(3);
+                worldCupPaymentService.updateById(worldCupPayment);
+            }
+            //课时支付
+            if(worldCupPayment.getPayType() == 4){
+                for (WorldCupPaymentParticipant worldCupPaymentParticipant1 : list1) {
+                    String content = worldCupPaymentParticipant1.getContent();
+                    DeductionClassHourList deductionClassHourList = JSON.parseObject(content, DeductionClassHourList.class);
+                    coursePackageOrderStudentClient.backspaceClassHour(deductionClassHourList);
+                }
+                worldCupPayment.setWorldCupId(null);
                 worldCupPayment.setRefundTime(new Date());
                 worldCupPayment.setRefundOrderNo("");
                 worldCupPayment.setPayStatus(3);
+                worldCupPayment.setRefundAmount(multiply);
                 worldCupPaymentService.updateById(worldCupPayment);
-            }//课时支付
-            if(worldCupPayment.getPayType() == 4){
-                for (WorldCupPaymentParticipant worldCupPaymentParticipant : list1) {
-                    Integer studentId = worldCupPaymentParticipant.getParticipantId();//构建扣减课时数据
-                    String content = worldCupPaymentParticipant.getContent();
-                    List<DeductionClassHour> list2 = JSON.parseArray(content, DeductionClassHour.class);
-
-
-
-
-
-//                    Integer classHour = worldCup.getClassHour();
-//                    for (CoursePackageOrderStudent packageOrderStudent : coursePackageOrderStudent) {
-//                        Integer laveClassHours = packageOrderStudent.getLaveClassHours();
-//
-//                        DeductionClassHour deductionClassHour = new DeductionClassHour();
-//                        if(classHour.compareTo(laveClassHours) > 0){
-//                            //不够扣除,轮询直到扣除完
-//                            classHour = classHour - laveClassHours;
-//                            deductionClassHour.setId(packageOrderStudent.getId());
-//                            deductionClassHour.setClassHour(laveClassHours);
-//                            deductionClassHour.setStudentId(packageOrderStudent.getStudentId());
-//                            deductionClassHour.setCoursePackageId(packageOrderStudent.getCoursePackageId());
-//                            list.add(deductionClassHour);
-//                        }else{
-//                            //够扣除直接跳出进行下个学员
-//                            deductionClassHour.setId(packageOrderStudent.getId());
-//                            deductionClassHour.setClassHour(classHour);
-//                            deductionClassHour.setStudentId(packageOrderStudent.getStudentId());
-//                            deductionClassHour.setCoursePackageId(packageOrderStudent.getCoursePackageId());
-//                            list.add(deductionClassHour);
-//                            break;
-//                        }
-//                    }
-                }
-
-                //扣减课时操作
-                DeductionClassHourList deductionClassHourList = new DeductionClassHourList();
-//                deductionClassHourList.setDeductionClassHourList(list);
-                coursePackageOrderStudentClient.deductionClassHour(deductionClassHourList);
             }
 
-
         }
 
-
-        for (WorldCupPaymentParticipant worldCupPaymentParticipant : list) {
+        WorldCup worldCup = this.getById(id);
+        worldCup.setStatus(4);
+        this.updateById(worldCup);
+    }
 
 
-
-
+    /**
+     * 定时任务修改状态
+     */
+    @Override
+    public void taskUpdateStatus() {
+        List<WorldCup> worldCups = this.list(new QueryWrapper<WorldCup>().eq("status", 1).last(" and startTime <= now()"));
+        for (WorldCup worldCup : worldCups) {
+            worldCup.setStatus(2);
         }
+        if(worldCups.size() > 0){
+            this.updateBatchById(worldCups);
+        }
+        worldCups = this.list(new QueryWrapper<WorldCup>().eq("status", 2).last(" and endTime <= now()"));
+        for (WorldCup worldCup : worldCups) {
+            worldCup.setStatus(3);
+        }
+        if(worldCups.size() > 0){
+            this.updateBatchById(worldCups);
+        }
+    }
 
+
+    /**
+     * 获取比赛统计列表数据
+     * @param worldCupGameStatistics
+     * @return
+     */
+    @Override
+    public Map<String, Object> worldCupGameStatistics(WorldCupGameStatistics worldCupGameStatistics) {
+        Map<String, Object> map = new HashMap<>();
+        List<Map<String, Object>> mapList = this.baseMapper.worldCupGameStatistics(worldCupGameStatistics);
+        for (Map<String, Object> stringObjectMap : mapList) {
+            Integer id = Integer.valueOf(stringObjectMap.get("id").toString());
+            int count = worldCupCompetitorService.getMatchTime(id);
+            stringObjectMap.put("matchTime", count);
+
+            List<WorldCupPayment> list = worldCupPaymentService.list(new QueryWrapper<WorldCupPayment>().eq("worldCupId", id)
+                    .eq("payStatus", 2).eq("state", 1));
+            List<Long> collect = list.stream().map(WorldCupPayment::getId).collect(Collectors.toList());
+            if(collect.size() == 0){
+                stringObjectMap.put("applicants", 0);
+            }else{
+                int count1 = worldCupPaymentParticipantService.getCount(id, collect);
+                stringObjectMap.put("applicants", count1);
+            }
+        }
+        map.put("rows", mapList);
+        int count = this.baseMapper.worldCupGameStatisticsCount(worldCupGameStatistics);
+        map.put("total", count);
+        return map;
+    }
+
+    /**
+     * 修改所有参数
+     * @param worldCup
+     */
+    @Override
+    public void updateWorldCupAll(WorldCup worldCup) {
+        this.baseMapper.updateWorldCupAll(worldCup);
     }
 }

--
Gitblit v1.7.1