From e899587f6d4abdc299b82bed0c043f88276a64c3 Mon Sep 17 00:00:00 2001
From: puzhibing <393733352@qq.com>
Date: 星期一, 10 七月 2023 19:08:45 +0800
Subject: [PATCH] 更新赛事模块剩余接口

---
 cloud-server-competition/src/main/java/com/dsh/competition/service/impl/PaymentCompetitionServiceImpl.java |  207 +++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 207 insertions(+), 0 deletions(-)

diff --git a/cloud-server-competition/src/main/java/com/dsh/competition/service/impl/PaymentCompetitionServiceImpl.java b/cloud-server-competition/src/main/java/com/dsh/competition/service/impl/PaymentCompetitionServiceImpl.java
index ec3eed7..6db453b 100644
--- a/cloud-server-competition/src/main/java/com/dsh/competition/service/impl/PaymentCompetitionServiceImpl.java
+++ b/cloud-server-competition/src/main/java/com/dsh/competition/service/impl/PaymentCompetitionServiceImpl.java
@@ -1,10 +1,40 @@
 package com.dsh.competition.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.dsh.competition.entity.Competition;
+import com.dsh.competition.entity.Participant;
 import com.dsh.competition.entity.PaymentCompetition;
+import com.dsh.competition.entity.UserCompetition;
+import com.dsh.competition.feignclient.account.AppUserClient;
+import com.dsh.competition.feignclient.account.StudentClient;
+import com.dsh.competition.feignclient.account.model.AppUser;
+import com.dsh.competition.feignclient.account.model.Student;
+import com.dsh.competition.feignclient.course.CoursePackagePaymentClient;
+import com.dsh.competition.feignclient.course.model.PaymentDeductionClassHour;
+import com.dsh.competition.feignclient.other.StoreClient;
+import com.dsh.competition.feignclient.other.model.Store;
 import com.dsh.competition.mapper.PaymentCompetitionMapper;
+import com.dsh.competition.model.CompetitionInfo;
+import com.dsh.competition.model.CompetitionListVo;
+import com.dsh.competition.model.ParticipantVo;
+import com.dsh.competition.service.CompetitionService;
+import com.dsh.competition.service.IParticipantService;
 import com.dsh.competition.service.IPaymentCompetitionService;
+import com.dsh.competition.service.UserCompetitionService;
+import com.dsh.competition.util.*;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+
+import javax.annotation.Resource;
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.text.SimpleDateFormat;
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.List;
+import java.util.Map;
+import java.util.stream.Collectors;
 
 /**
  * @author zhibing.pu
@@ -12,4 +42,181 @@
  */
 @Service
 public class PaymentCompetitionServiceImpl extends ServiceImpl<PaymentCompetitionMapper, PaymentCompetition> implements IPaymentCompetitionService {
+
+    @Autowired
+    private CompetitionService competitionService;
+
+    @Resource
+    private StoreClient storeClient;
+
+    @Autowired
+    private UserCompetitionService userCompetitionService;
+
+    @Autowired
+    private IParticipantService participantService;
+
+    @Autowired
+    private PayMoneyUtil payMoneyUtil;
+
+    @Resource
+    private AppUserClient appUserClient;
+
+    @Resource
+    private CoursePackagePaymentClient coursePackagePaymentClient;
+
+    @Resource
+    private StudentClient studentClient;
+
+
+
+
+    /**
+     * 获取我的报名赛事记录
+     * @param uid
+     * @param type
+     * @param pageSize
+     * @param pageNo
+     * @return
+     * @throws Exception
+     */
+    @Override
+    public List<CompetitionListVo> queryMyCompetitionList(Integer uid, Integer type, Integer pageSize, Integer pageNo) throws Exception {
+        pageSize = (pageSize - 1) * pageNo;
+        return this.baseMapper.queryMyCompetitionList(uid, type, pageSize, pageNo);
+    }
+
+
+    /**
+     * 获取我报名的赛事详情
+     * @param id
+     * @return
+     * @throws Exception
+     */
+    @Override
+    public CompetitionInfo queryMyCompetitionInfo(Long id) throws Exception {
+        PaymentCompetition paymentCompetition = this.getById(id);
+        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm");
+        Competition competition = competitionService.getById(paymentCompetition.getCompetitionId());
+        CompetitionInfo competitionInfo = new CompetitionInfo();
+        competitionInfo.setId(id);
+        competitionInfo.setImgs(competition.getImgs());
+        competitionInfo.setName(competition.getName());
+        competitionInfo.setRegisterCondition(competition.getRegisterCondition());
+        Store store = storeClient.queryStoreById(competition.getStoreId());
+        competitionInfo.setStoreName(store.getName());
+        competitionInfo.setStoreAddress(store.getAddress());
+        competitionInfo.setStoreLon(store.getLon());
+        competitionInfo.setStoreLat(store.getLat());
+        competitionInfo.setStoreCoverDrawing(store.getCoverDrawing());
+        competitionInfo.setRegisterEndTime(sdf.format(competition.getRegisterEndTime()));
+        competitionInfo.setStartTime(sdf.format(competition.getStartTime()));
+        competitionInfo.setEndTime(sdf.format(competition.getEndTime()));
+        competitionInfo.setAge(competition.getStartAge() + "-" + competition.getEndAge());
+        competitionInfo.setProvince(competition.getEntryProvince());
+        competitionInfo.setCity(competition.getEntryCity());
+        competitionInfo.setAddress(competition.getEntryAddress());
+        competitionInfo.setPayType(competition.getPayType());
+        competitionInfo.setPrice(competition.getPrice().doubleValue());
+        competitionInfo.setIntroduction(competition.getIntroduction());
+        competitionInfo.setRegistrationNotes(competition.getRegistrationNotes());
+        competitionInfo.setApply(1);
+        List<ParticipantVo> participant = new ArrayList<>();
+        List<UserCompetition> list = userCompetitionService.list(new QueryWrapper<UserCompetition>().eq("paymentCompetitionId", paymentCompetition.getId()));
+        List<Integer> collect = list.stream().map(UserCompetition::getParticipantId).collect(Collectors.toList());
+        List<Participant> participants = participantService.listByIds(collect);
+        SimpleDateFormat sdf_year = new SimpleDateFormat("yyyy");
+        for (Participant participant1 : participants) {
+            ParticipantVo participantVo = new ParticipantVo();
+            participantVo.setId(participant1.getId());
+            participantVo.setName(participant1.getName());
+            participantVo.setIdcard(participant1.getIdcard());
+            Integer age = Integer.valueOf(sdf_year.format(new Date())) - Integer.valueOf(sdf_year.format(participant1.getBirthday()));
+            participantVo.setAge(age);
+            participant.add(participantVo);
+        }
+        competitionInfo.setParticipant(participant);
+        return competitionInfo;
+    }
+
+
+    /**
+     * 取消赛事报名
+     * @param id
+     * @return
+     * @throws Exception
+     */
+    @Override
+    public ResultUtil cancelMyCompetition(Long id) throws Exception {
+        PaymentCompetition paymentCompetition = this.getById(id);
+        if(paymentCompetition.getPayStatus() == 3){
+            return ResultUtil.error("不能重复取消");
+        }
+        String code = paymentCompetition.getCode();
+        Double amount = paymentCompetition.getAmount();
+        Competition competition = competitionService.getById(paymentCompetition.getCompetitionId());
+        if(System.currentTimeMillis() >= competition.getRegisterEndTime().getTime()){
+            return ResultUtil.error("赛事已结束报名,无法取消");
+        }
+
+        String payOrderNo = paymentCompetition.getPayOrderNo();
+        if(paymentCompetition.getPayType() == 1){//微信支付
+            Map<String, String> map = payMoneyUtil.wxRefund(payOrderNo, code, amount.toString(), amount.toString(), "/base/competition/weChatCancelPaymentCompetitionCallback");
+            String return_code = map.get("return_code");
+            if(!"SUCCESS".equals(return_code)){
+                return ResultUtil.error(map.get("return_msg"));
+            }
+            String refund_id = map.get("refund_id");
+            paymentCompetition.setRefundOrderNo(refund_id);
+            this.updateById(paymentCompetition);
+        }
+        if(paymentCompetition.getPayType() == 2){//支付宝支付
+            Map<String, String> map = payMoneyUtil.aliRefund(payOrderNo, amount.toString());
+            String return_code = map.get("code");
+            if(!"10000".equals(return_code)){
+                return ResultUtil.error(map.get("msg"));
+            }
+            String refund_id = map.get("trade_no");
+            paymentCompetition.setRefundOrderNo(refund_id);
+            paymentCompetition.setRefundTime(new Date());
+            paymentCompetition.setPayStatus(3);
+            this.updateById(paymentCompetition);
+
+            competition.setApplicantsNumber(competition.getApplicantsNumber() - 1);
+            competitionService.updateById(competition);
+        }
+        if(paymentCompetition.getPayType() == 3){//玩湃币支付
+            AppUser appUser = appUserClient.queryAppUser(paymentCompetition.getAppUserId());
+            appUser.setPlayPaiCoins(appUser.getPlayPaiCoins() + amount.intValue());
+            appUserClient.updateAppUser(appUser);
+
+            paymentCompetition.setRefundOrderNo("");
+            paymentCompetition.setRefundTime(new Date());
+            paymentCompetition.setPayStatus(3);
+            this.updateById(paymentCompetition);
+
+            competition.setApplicantsNumber(competition.getApplicantsNumber() - 1);
+            competitionService.updateById(competition);
+        }
+        if(paymentCompetition.getPayType() == 4){//课程支付
+            List<UserCompetition> list = userCompetitionService.list(new QueryWrapper<UserCompetition>().eq("paymentCompetitionId", paymentCompetition.getId()));
+            for (UserCompetition userCompetition : list) {
+                Participant participant = participantService.getById(userCompetition.getId());
+                Student student = studentClient.queryStudentByPhone(participant.getPhone());
+                PaymentDeductionClassHour paymentDeductionClassHour = new PaymentDeductionClassHour();
+                paymentDeductionClassHour.setId(student.getId());
+                paymentDeductionClassHour.setClassHour(competition.getPrice().intValue());
+                paymentDeductionClassHour.setCode(code);
+                coursePackagePaymentClient.rollbackPaymentDeductionClassHour(paymentDeductionClassHour);
+            }
+
+            paymentCompetition.setRefundOrderNo("");
+            paymentCompetition.setRefundTime(new Date());
+            paymentCompetition.setPayStatus(3);
+            this.updateById(paymentCompetition);
+
+            competition.setApplicantsNumber(competition.getApplicantsNumber() - 1);
+            competitionService.updateById(competition);
+        }
+        return ResultUtil.success();
+    }
 }

--
Gitblit v1.7.1