From a5d0c4da70f592c7ab338483cabc37816e11c3d9 Mon Sep 17 00:00:00 2001
From: lisy <linlangsur163@163.com>
Date: 星期二, 04 七月 2023 17:43:06 +0800
Subject: [PATCH] account模块:开始上课-切换学员功能接口

---
 cloud-server-account/src/main/java/com/dsh/account/service/impl/TStudentServiceImpl.java |  169 +++++++++++++++++++++++++++++++++++++++++++++-----------
 1 files changed, 136 insertions(+), 33 deletions(-)

diff --git a/cloud-server-account/src/main/java/com/dsh/account/service/impl/TStudentServiceImpl.java b/cloud-server-account/src/main/java/com/dsh/account/service/impl/TStudentServiceImpl.java
index 5be7f68..5403d29 100644
--- a/cloud-server-account/src/main/java/com/dsh/account/service/impl/TStudentServiceImpl.java
+++ b/cloud-server-account/src/main/java/com/dsh/account/service/impl/TStudentServiceImpl.java
@@ -5,6 +5,7 @@
 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;
@@ -13,12 +14,29 @@
 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.TAppUserMapper;
 import com.dsh.account.mapper.TStudentMapper;
 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.ToolUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
@@ -57,6 +75,18 @@
 
     @Autowired
     private CoursePaymentClient couPayClient;
+
+    @Autowired
+    private UserConponClient userCClient;
+
+    @Autowired
+    private StoreClient storeClient;
+
+    @Autowired
+    private NoticeClient noClient;
+
+    @Autowired
+    private QuestionClient quesClient;
 
     @Autowired
     private TAppUserMapper tauMapper;
@@ -121,6 +151,112 @@
         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",timeRequest.getStartTime() ,timeRequest.getEndTime()));
+        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);
+
+        StoreDetailOfCourse courseOfStore = storeClient.getCourseOfStore(studentCourse.getStoreId());
+
+        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>() {
@@ -142,37 +278,4 @@
         return purchaseRecords;
     }
 
-
-//    public static List<String> dealDataOfTime(List<String> timeStrings) {
-//        Collections.sort(timeStrings, new Comparator<String>() {
-//            @Override
-//            public int compare(String time1, String time2) {
-//                String[] parts1 = time1.split(" ");
-//                String[] parts2 = time2.split(" ");
-//                String[] dateParts1 = parts1[0].split("-");
-//                String[] dateParts2 = parts2[0].split("-");
-//                String[] timeParts1 = parts1[1].split(":");
-//                String[] timeParts2 = parts2[1].split(":");
-//                int month1 = Integer.parseInt(dateParts1[0]);
-//                int day1 = Integer.parseInt(dateParts1[1]);
-//                int hour1 = Integer.parseInt(timeParts1[0]);
-//                int minute1 = Integer.parseInt(timeParts1[1]);
-//                int month2 = Integer.parseInt(dateParts2[0]);
-//                int day2 = Integer.parseInt(dateParts2[1]);
-//                int hour2 = Integer.parseInt(timeParts2[0]);
-//                int minute2 = Integer.parseInt(timeParts2[1]);
-//                // 倒序排序
-//                if (month1 != month2) {
-//                    return month2 - month1;
-//                } else if (day1 != day2) {
-//                    return day2 - day1;
-//                } else if (hour1 != hour2) {
-//                    return hour2 - hour1;
-//                } else {
-//                    return minute2 - minute1;
-//                }
-//            }
-//        });
-//        return timeStrings;
-//    }
 }

--
Gitblit v1.7.1