package com.dsh.account.service.impl;
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
import com.dsh.account.entity.Coach;
|
import com.dsh.account.entity.TAppUser;
|
import com.dsh.account.entity.TStudent;
|
import com.dsh.account.feignclient.activity.IntroduceRewardsClient;
|
import com.dsh.account.feignclient.activity.UserConponClient;
|
import com.dsh.account.feignclient.competition.DeductionCompetitionsClient;
|
import com.dsh.account.feignclient.competition.model.PurchaseRecordVo;
|
import com.dsh.account.feignclient.course.CancelListClient;
|
import com.dsh.account.feignclient.course.CoursePaymentClient;
|
import com.dsh.account.feignclient.course.CourseRecordClient;
|
import com.dsh.account.feignclient.course.CourseSessionNameClient;
|
import com.dsh.account.feignclient.course.model.StuSessionDetailsVo;
|
import com.dsh.account.feignclient.course.model.StuWithCoursesListVo;
|
import com.dsh.account.feignclient.course.model.StudentOfCourseVo;
|
import com.dsh.account.feignclient.other.NoticeClient;
|
import com.dsh.account.feignclient.other.QuestionClient;
|
import com.dsh.account.feignclient.other.StoreClient;
|
import com.dsh.account.feignclient.other.model.StoreDetailOfCourse;
|
import com.dsh.account.feignclient.other.model.StoreInfo;
|
import com.dsh.account.feignclient.other.model.StoreLonLatList;
|
import com.dsh.account.feignclient.other.model.SysNotice;
|
import com.dsh.account.mapper.CoachMapper;
|
import com.dsh.account.mapper.TAppUserMapper;
|
import com.dsh.account.mapper.TStudentMapper;
|
import com.dsh.account.model.vo.classDetails.ClasspaymentRequest;
|
import com.dsh.account.model.vo.classDetails.classInsVo.ClassDetailsInsVo;
|
import com.dsh.account.model.vo.classDetails.classInsVo.StuDetailsReq;
|
import com.dsh.account.model.vo.classDetails.classInsVo.StuListVo;
|
import com.dsh.account.model.vo.exploreDetail.ExploreDatasVo;
|
import com.dsh.account.model.vo.exploreDetail.LonLatRequest;
|
import com.dsh.account.model.vo.exploreDetails.QuestionDetailsVo;
|
import com.dsh.account.model.vo.exploreDetails.QuestionIns;
|
import com.dsh.account.model.vo.sourceDetail.CouponStuAvailableVo;
|
import com.dsh.account.model.vo.sourceDetail.CourseDetailsOfContinuationResp;
|
import com.dsh.account.model.vo.sourceDetail.RecordTimeRequest;
|
import com.dsh.account.service.TStudentService;
|
import com.dsh.account.util.DateTimeHelper;
|
import com.dsh.account.util.DateUtil;
|
import com.dsh.account.util.ResultUtil;
|
import com.dsh.account.util.ToolUtil;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Service;
|
|
import java.math.BigDecimal;
|
import java.text.ParseException;
|
import java.text.SimpleDateFormat;
|
import java.util.*;
|
import java.util.stream.Collectors;
|
|
/**
|
* <p>
|
* 学员信息 服务实现类
|
* </p>
|
*
|
* @author administrator
|
* @since 2023-06-14
|
*/
|
@Service
|
public class TStudentServiceImpl extends ServiceImpl<TStudentMapper, TStudent> implements TStudentService {
|
|
@Autowired
|
private CourseSessionNameClient sessionNameClient;
|
|
@Autowired
|
private DeductionCompetitionsClient dcttClient;
|
|
@Autowired
|
private CancelListClient cancelcClient;
|
|
@Autowired
|
private IntroduceRewardsClient idrClient;
|
|
@Autowired
|
private CourseRecordClient crClient;
|
|
@Autowired
|
private CoursePaymentClient couPayClient;
|
|
@Autowired
|
private UserConponClient userCClient;
|
|
@Autowired
|
private StoreClient storeClient;
|
|
@Autowired
|
private NoticeClient noClient;
|
|
@Autowired
|
private QuestionClient quesClient;
|
|
@Autowired
|
private TAppUserMapper tauMapper;
|
|
@Autowired
|
private CoachMapper coachMapper;
|
|
@Override
|
public void addStuOfAppUser(StuDetailsReq stu,Integer appUserId) {
|
TStudent student = new TStudent();
|
student.setAppUserId(appUserId);
|
student.setName(stu.getName());
|
student.setHeadImg(stu.getHeadImg());
|
student.setPhone(ToolUtil.isNotEmpty(stu.getPhone()) ? stu.getPhone() : "");
|
student.setSex(stu.getSex());
|
student.setIdCard(ToolUtil.isNotEmpty(stu.getIdCard())?stu.getIdCard() : "");
|
student.setBirthday(new Date(stu.getBirthday()));
|
student.setHeight(stu.getHeight());
|
student.setWeight(stu.getWeight());
|
BigDecimal bigDecimal = BigDecimal.valueOf(stu.getWeight());
|
BigDecimal multiply = bigDecimal.subtract(BigDecimal.valueOf(stu.getHeight())).multiply(bigDecimal.subtract(BigDecimal.valueOf(stu.getHeight())));
|
multiply.setScale(2);
|
student.setBmi(multiply.doubleValue());
|
student.setInsertTime(new Date());
|
student.setState(1);
|
this.baseMapper.insert(student);
|
}
|
|
@Override
|
public ClassDetailsInsVo querySessionDetailsDt(Integer userIdFormRedis, Integer lessonId, Integer stuId) {
|
ClassDetailsInsVo insVo = new ClassDetailsInsVo();
|
Date localMonthStart = DateTimeHelper.getCurrentMouthStart();
|
Date localMonthEnd = DateTimeHelper.getCurrentMouthEnd();
|
List<StuSessionDetailsVo> stuSessionList = sessionNameClient.getStuSessionList(localMonthStart,localMonthEnd,stuId,userIdFormRedis);
|
TStudent tStudent = this.baseMapper.selectById(stuId);
|
if (ToolUtil.isNotEmpty(tStudent)){
|
insVo.setStuId(tStudent.getId());
|
insVo.setStuName(tStudent.getName());
|
insVo.setStuImage(tStudent.getHeadImg());
|
|
List<PurchaseRecordVo> purchaseRecordVoList = new ArrayList<>();
|
|
List<PurchaseRecordVo> stuSourseList = dcttClient.getStuSourseList(localMonthStart,localMonthEnd,userIdFormRedis);
|
purchaseRecordVoList.addAll(stuSourseList);
|
List<PurchaseRecordVo> cancelCourseList = cancelcClient.getCancelCourseList(localMonthStart,localMonthEnd,stuId,userIdFormRedis);
|
purchaseRecordVoList.addAll(cancelCourseList);
|
List<PurchaseRecordVo> purchaseRecordVos = sessionNameClient.queryCourseDetails(localMonthStart,localMonthEnd,stuId,userIdFormRedis);
|
purchaseRecordVoList.addAll(purchaseRecordVos);
|
List<TAppUser> tAppUsers = tauMapper.selectList(new QueryWrapper<TAppUser>()
|
.eq("referralUserId",userIdFormRedis )
|
.between("insertTime",localMonthStart ,localMonthEnd));
|
List<Integer> userIds = tAppUsers.stream().map(TAppUser::getId).collect(Collectors.toList());
|
List<PurchaseRecordVo> purchaseRecordVos1 = idrClient.queryAppUsersofIntroduce(localMonthStart, localMonthEnd, userIds);
|
purchaseRecordVoList.addAll(purchaseRecordVos1);
|
insVo.setSessionNames(stuSessionList);
|
insVo.setDetails(dealDataOfTime(purchaseRecordVoList));
|
StuWithCoursesListVo stuOfCoursesDetails = couPayClient.getStuOfCoursesDetails(stuId, userIdFormRedis);
|
insVo.setTotalNums(stuOfCoursesDetails.getTotalNums());
|
insVo.setDeductedNums(stuOfCoursesDetails.getDeductedNums());
|
insVo.setRemainingNums(stuOfCoursesDetails.getRemainingNums());
|
Integer deductionClassHour = crClient.getDeductionClassHour(lessonId, stuId, userIdFormRedis);
|
insVo.setDeductionClassHours(deductionClassHour);
|
}
|
|
return insVo;
|
}
|
|
@Override
|
public List<PurchaseRecordVo> queryDeduRecordDetails(RecordTimeRequest timeRequest,Integer appUserId) {
|
List<PurchaseRecordVo> purchaseRecordVoList = new ArrayList<>();
|
Date startTime = DateTimeHelper.getCurrentIdetMouthStart(timeRequest.getStartTime());
|
Date endTime = DateTimeHelper.getCurrentIdeaMouthEnd(timeRequest.getEndTime());
|
|
List<PurchaseRecordVo> stuSourseList = dcttClient.getStuSourseList(startTime,endTime,appUserId);
|
purchaseRecordVoList.addAll(stuSourseList);
|
List<PurchaseRecordVo> cancelCourseList = cancelcClient.getCancelCourseList(startTime,endTime,timeRequest.getStuId(),appUserId);
|
purchaseRecordVoList.addAll(cancelCourseList);
|
List<PurchaseRecordVo> purchaseRecordVos = sessionNameClient.queryCourseDetails(startTime,endTime,timeRequest.getStuId(),appUserId);
|
purchaseRecordVoList.addAll(purchaseRecordVos);
|
List<TAppUser> tAppUsers = tauMapper.selectList(new QueryWrapper<TAppUser>()
|
.eq("referralUserId",appUserId )
|
.between("insertTime",startTime ,endTime));
|
List<Integer> userIds = tAppUsers.stream().map(TAppUser::getId).collect(Collectors.toList());
|
List<PurchaseRecordVo> purchaseRecordVos1 = idrClient.queryAppUsersofIntroduce(startTime, endTime, userIds);
|
purchaseRecordVoList.addAll(purchaseRecordVos1);
|
|
purchaseRecordVoList = dealDataOfTime(purchaseRecordVoList);
|
return purchaseRecordVoList;
|
}
|
|
@Override
|
public List<CouponStuAvailableVo> queryStuOfConponDetails(Integer appUserId) {
|
List<CouponStuAvailableVo> availableVos = new ArrayList<>();
|
availableVos = userCClient.queryUserWithConponList(appUserId);
|
return availableVos;
|
}
|
|
@Override
|
public CourseDetailsOfContinuationResp queryStuOfCourseDetails(Integer lessonId, Integer stuId, Integer appUserId) {
|
CourseDetailsOfContinuationResp resp = new CourseDetailsOfContinuationResp();
|
|
StudentOfCourseVo studentCourse = couPayClient.getStudentCourse(lessonId,stuId,appUserId);
|
resp.setCoursePackageId(studentCourse.getCoursePackageId());
|
resp.setStuId(stuId);
|
resp.setPackageImg(studentCourse.getPackageImg());
|
resp.setCourseName(studentCourse.getCourseName());
|
Coach coach = coachMapper.selectById(studentCourse.getCoachId());
|
resp.setTeacherName(coach.getName());
|
resp.setCourseWeek(studentCourse.getCourseWeek());
|
resp.setCourseTime(studentCourse.getCourseTime());
|
|
StoreDetailOfCourse courseOfStore = storeClient.getCourseOfStore(studentCourse.getStoreId());
|
resp.setStoreName(courseOfStore.getStoreName());
|
resp.setStoreAddr(courseOfStore.getStoreAddr());
|
|
resp.setTypeList(studentCourse.getTypeList());
|
TStudent tStudent = this.baseMapper.selectById(stuId);
|
resp.setStuName(tStudent.getName());
|
resp.setStuPhone(tStudent.getPhone());
|
resp.setStuAge(DateUtil.age(tStudent.getBirthday()));
|
resp.setAmount(studentCourse.getAmount());
|
resp.setVipAmount(studentCourse.getVipAmount());
|
resp.setWpGold(studentCourse.getWpGold());
|
return resp;
|
}
|
|
@Override
|
public List<SysNotice> querySystemNoticeDetails() {
|
return noClient.getSysNoticeDetails();
|
}
|
|
@Override
|
public SysNotice queryNoticeData(Integer noId) {
|
return noClient.getSysNoticeBuId(noId);
|
}
|
|
@Override
|
public QuestionDetailsVo queryQuestionData() {
|
return quesClient.getSysQuestionDetails();
|
}
|
|
@Override
|
public QuestionIns queryQuestionDataInfo(Integer quesId) {
|
return quesClient.getSysQuestionBuId(quesId);
|
}
|
|
@Override
|
public List<String> queryCustomerDetails() {
|
return noClient.queryCustomerTel();
|
}
|
|
@Override
|
public ExploreDatasVo queryIndexOfExplores(LonLatRequest llrequest) {
|
ExploreDatasVo datasVo = new ExploreDatasVo();
|
List<StoreInfo> allNearbyStoreList = storeClient.getAllNearbyStoreList(llrequest.getLongitude(),llrequest.getLatitude());
|
List<StoreLonLatList> allStoreLonLats = storeClient.getAllStoreLonLats(llrequest.getLongitude(), llrequest.getLatitude());
|
datasVo.setStoreLists(allNearbyStoreList);
|
datasVo.setLonLatLists(allStoreLonLats);
|
return datasVo;
|
}
|
|
@Override
|
public List<StuListVo> switchStudentActions(Integer appUserId, Integer stuId) {
|
List<StuListVo> stuListVos = new ArrayList<>();
|
List<TStudent> tStudents = this.baseMapper.selectList(new QueryWrapper<TStudent>()
|
.eq("appUserId", appUserId)
|
.eq("state",1));
|
if (tStudents.size() > 0) {
|
tStudents.forEach(sts -> {
|
if (Objects.equals(sts.getId(), stuId)) {
|
sts.setIsDefault(1);
|
} else {
|
sts.setIsDefault(2);
|
}
|
this.baseMapper.updateById(sts);
|
|
StuListVo vo = new StuListVo();
|
vo.setStuId(sts.getId());
|
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
|
vo.setBirthday(simpleDateFormat.format(sts.getBirthday()));
|
vo.setStuName(sts.getName());
|
vo.setStuAge(DateUtil.age(sts.getBirthday()));
|
vo.setStuHeight(sts.getHeight());
|
vo.setStuWeight(sts.getWeight());
|
vo.setIsNot(sts.getIsDefault());
|
stuListVos.add(vo);
|
});
|
}
|
return stuListVos;
|
}
|
|
|
public static List<PurchaseRecordVo> dealDataOfTime(List<PurchaseRecordVo> purchaseRecords) {
|
Collections.sort(purchaseRecords, new Comparator<PurchaseRecordVo>() {
|
@Override
|
public int compare(PurchaseRecordVo record1, PurchaseRecordVo record2) {
|
SimpleDateFormat dateFormat = new SimpleDateFormat("MM-dd HH:mm");
|
Date date1 = null;
|
Date date2 = null;
|
try {
|
date1 = dateFormat.parse(record1.getPurchaseTime());
|
date2 = dateFormat.parse(record2.getPurchaseTime());
|
} catch (ParseException e) {
|
e.printStackTrace();
|
}
|
// 倒序排序
|
return date2.compareTo(date1);
|
}
|
});
|
return purchaseRecords;
|
}
|
|
@Override
|
public ResultUtil renewClassPayment(Integer userIdFormRedis, ClasspaymentRequest request) {
|
// TODO: 2023/7/5
|
switch (request.getPayType()){
|
case 1:
|
WeChatPayment();
|
break;
|
case 2:
|
AlipayPayment();
|
break;
|
case 3:
|
PlaypaiGoldPayment();
|
break;
|
default:
|
break;
|
}
|
return ResultUtil.success();
|
}
|
|
|
public void WeChatPayment(){
|
|
}
|
|
public void AlipayPayment(){
|
|
}
|
|
public void PlaypaiGoldPayment(){
|
|
}
|
|
|
}
|