From 790c2ba4a0b46edf191e3bac84931f796bd42b8f Mon Sep 17 00:00:00 2001
From: zhangf <1603559716@qq.com>
Date: 星期三, 24 七月 2024 09:02:49 +0800
Subject: [PATCH] 三方对接接口优化

---
 exam-system/src/main/java/com/gkhy/exam/institutionalaccess/service/serviceImpl/ThBatchManagerServiceImpl.java |   74 +++++++++++++++++++++++++++++--------
 1 files changed, 58 insertions(+), 16 deletions(-)

diff --git a/exam-system/src/main/java/com/gkhy/exam/institutionalaccess/service/serviceImpl/ThBatchManagerServiceImpl.java b/exam-system/src/main/java/com/gkhy/exam/institutionalaccess/service/serviceImpl/ThBatchManagerServiceImpl.java
index 6cc4a93..2c4f659 100644
--- a/exam-system/src/main/java/com/gkhy/exam/institutionalaccess/service/serviceImpl/ThBatchManagerServiceImpl.java
+++ b/exam-system/src/main/java/com/gkhy/exam/institutionalaccess/service/serviceImpl/ThBatchManagerServiceImpl.java
@@ -1,10 +1,14 @@
 package com.gkhy.exam.institutionalaccess.service.serviceImpl;
 
 
+import com.gkhy.exam.institutionalaccess.entity.ThBatchCourse;
+import com.gkhy.exam.institutionalaccess.entity.ThBatchCourseChapter;
+import com.gkhy.exam.institutionalaccess.entity.ThStudentBatch;
 import com.gkhy.exam.institutionalaccess.entity.ThStudyDetail;
 import com.gkhy.exam.institutionalaccess.enums.FinishStatus;
 import com.gkhy.exam.institutionalaccess.model.query.ThBatchQuery;
 import com.gkhy.exam.institutionalaccess.model.resp.ThBatchCourseRespDTO;
+import com.gkhy.exam.institutionalaccess.model.resp.ThCourseChapterRespDTO;
 import com.gkhy.exam.institutionalaccess.model.resp.ThStudentCourseRespDTO;
 import com.gkhy.exam.institutionalaccess.model.resp.ThStudentStudyRespDTO;
 import com.gkhy.exam.institutionalaccess.model.vo.*;
@@ -29,21 +33,44 @@
     @Autowired
     private ThBatchCourseService thBatchCourseService;
     @Autowired
-    private ThStudentCourseService thStudentCourseService;
+    private ThStudentBatchService thStudentBatchService;
     @Autowired
     private ThStudyDetailService thStudyDetailService;
+    @Autowired
+    private ThBatchCourseChapterService thBatchCourseChapterService;
 
     @Override
     public List<ThBatchVO> listByPage(ThBatchQuery query) {
         List<ThBatchVO> thBatchVOS = thBatchService.listByPage(query);
         //统计学员
-        List<ThStatisticStudentVO> thStatisticStudentVOS = thStudentCourseService.statisticByBatchUuid();
+        List<ThStatisticStudentVO> thStatisticStudentVOS = thStudentBatchService.statisticByBatchUuid();
         if (!CollectionUtils.isEmpty(thBatchVOS)) {
             List<String> batchUuids = thBatchVOS.stream().map(ThBatchVO::getUuid).collect(Collectors.toList());
-            List<ThBatchCourseVO> batchCourseVOS = thBatchCourseService.getListByBatchUuids(batchUuids);
+            List<ThBatchCourse> batchCourseList = thBatchCourseService.getListByBatchUuids(batchUuids);
+            //章节
+            List<ThBatchCourseChapter> chapterList = thBatchCourseChapterService.getListByBatchUuids(batchUuids);
+
             for (ThBatchVO thBatchVO : thBatchVOS) {
                 //课程
-                List<ThBatchCourseVO> collect = batchCourseVOS.stream().filter(bc -> bc.getBatchUuid().equals(thBatchVO.getUuid())).collect(Collectors.toList());
+                List<ThBatchCourseVO> collect = batchCourseList.stream()
+                        .filter(bc -> bc.getBatchUuid().equals(thBatchVO.getUuid()))
+                        .map(bc -> {
+                            ThBatchCourseVO thBatchCourseVO = new ThBatchCourseVO();
+                            BeanUtils.copyProperties(bc, thBatchCourseVO);
+
+                            List<ThBatchCourseChapterVO> chapterVOs = chapterList.stream().
+                                    filter(cc -> cc.getCourseUuid().equals(bc.getCourseUuid()) && cc.getParentUuid().equals("0"))
+                                    .map(cc -> {
+                                        ThBatchCourseChapterVO thBatchCourseChapterVO = new ThBatchCourseChapterVO();
+                                        BeanUtils.copyProperties(cc, thBatchCourseChapterVO);
+                                        thBatchCourseChapterVO.setChildren(getChildren(chapterList,cc.getChapterUuid()));
+                                        return thBatchCourseChapterVO;
+                                    })
+                                    .collect(Collectors.toList());
+                            thBatchCourseVO.setChapterList(chapterVOs);
+                            return thBatchCourseVO;
+                        })
+                        .collect(Collectors.toList());
                 //学员
                 List<ThStatisticStudentVO> ssList = thStatisticStudentVOS.stream().filter(ss -> ss.getBatchUuid().equals(thBatchVO.getUuid())).collect(Collectors.toList());
                 if(ssList.size() > 0) {
@@ -57,12 +84,27 @@
         return thBatchVOS;
     }
 
+    //获取章节
+    private List<ThBatchCourseChapterVO> getChildren(List<ThBatchCourseChapter> chapterList, String parentUuid) {
+        List<ThBatchCourseChapterVO> sectionList = chapterList
+                .stream()
+                .filter(cc -> cc.getParentUuid().equals(parentUuid))
+                .map(cc -> {
+                    ThBatchCourseChapterVO thBatchCourseChapterVO = new ThBatchCourseChapterVO();
+                    BeanUtils.copyProperties(cc, thBatchCourseChapterVO);
+                    return thBatchCourseChapterVO;
+                })
+                .collect(Collectors.toList());
+        return sectionList;
+    }
+
+
     @Override
     public List<ThBatchCourseRespDTO> period(String batchUuid) {
-        //获取批次关联课程
+        //获取批次关联课程(课程的视频总时长)
         List<ThBatchCourseVO> batchCourseVOS = thBatchCourseService.getListByBatchUuid(batchUuid);
-        //获取关联学生
-        List<ThStudentCourseVO> thStudentCourseVOS = thStudentCourseService.getListByBatchUuid(batchUuid);
+        //获取关联学生(学时)
+        List<ThStudentBatchCourseVO> thStudentCourseVOS = thStudentBatchService.getStudentBatchCourseVOByBatchUuid(batchUuid);
         //根据批次获取学习记录
         List<ThStudyVO> studyVOS = thStudyDetailService.statisticDurationByIdcard(batchUuid);
         List<ThBatchCourseRespDTO> batchCourseRespDTOS = new ArrayList<>();
@@ -75,11 +117,11 @@
                 //过滤学生
                 List<ThStudentCourseRespDTO> studentList = thStudentCourseVOS
                         .stream()
-                        .filter(sc -> sc.getBatchUuid().equals(VO.getBatchUuid()))
+                        .filter(sc -> sc.getCourseUuid().equals(VO.getCourseUuid()))
                         .map(sc -> {
                             ThStudentCourseRespDTO thStudentCourseRespDTO = new ThStudentCourseRespDTO();
                             BeanUtils.copyProperties(sc, thStudentCourseRespDTO);
-                            List<ThStudyVO> collect = studyVOS.stream().filter(s -> s.getIdcard().equals(sc.getIdcard())).collect(Collectors.toList());
+                            List<ThStudyVO> collect = studyVOS.stream().filter(s -> s.getIdcard().equals(sc.getIdcard()) && s.getCourseUuid().equals(VO.getCourseUuid())).collect(Collectors.toList());
                            if(collect.size() > 0) {
                                thStudentCourseRespDTO.setDuration(collect.get(0).getDuration());
                            }else {
@@ -100,17 +142,18 @@
     @Override
     public List<ThStudentStudyRespDTO> getStudent(String batchUuid) {
         //获取学生信息
-        List<ThStudentCourseVO> thStudentCourseVOS = thStudentCourseService.getListByBatchUuid(batchUuid);
+        List<ThStudentBatchVO> thStudentBatches = thStudentBatchService.getStudentBatchVOByBatchUuid(batchUuid);
         //获取学生学习记录
         List<ThStudyDetailVO> studyDetails = thStudyDetailService.listByBatchUuid(batchUuid);
         List<ThStudentStudyRespDTO> respDTOS = new ArrayList<>();
-        if (!CollectionUtils.isEmpty(thStudentCourseVOS)) {
-            for (ThStudentCourseVO VO : thStudentCourseVOS) {
+        if (!CollectionUtils.isEmpty(thStudentBatches)) {
+            for (ThStudentBatchVO VO : thStudentBatches) {
                 ThStudentStudyRespDTO thStudentStudyRespDTO = new ThStudentStudyRespDTO();
                 thStudentStudyRespDTO.setIdcard(VO.getIdcard());
                 thStudentStudyRespDTO.setName(VO.getName());
-                thStudentStudyRespDTO.setCourseName(VO.getCourseName());
-                thStudentStudyRespDTO.setLessonTocal(VO.getLessTotal());
+                thStudentStudyRespDTO.setBatchLessonNum(VO.getBatchLessonNum());
+                thStudentStudyRespDTO.setFinishStatus(VO.getFinishStatus());
+                thStudentStudyRespDTO.setBatchUuid(VO.getBatchUuid());
                 BigDecimal lessNum = new BigDecimal(0);
 
                 List<ThStudyDetailVO> collect = studyDetails
@@ -121,7 +164,7 @@
                 for (ThStudyDetailVO studyDetail : collect) {
                     //是否完成
                     if(studyDetail.getFinishStatus().equals(FinishStatus.YES.getStatus())){
-                        lessNum.add(studyDetail.getLessonNum());
+                        lessNum = lessNum.add(studyDetail.getLessonNum());
                     }
                     //是否有学时报告
                     if(!StringUtils.isEmpty(studyDetail.getLessonReportUrl())){
@@ -132,7 +175,6 @@
                     stringBuffer.deleteCharAt(stringBuffer.length()-1);
                 }
                 thStudentStudyRespDTO.setUrl(stringBuffer.toString());
-                thStudentStudyRespDTO.setFinishStatus(VO.getFinishStatus());
                 thStudentStudyRespDTO.setLessonNum(lessNum);
                 respDTOS.add(thStudentStudyRespDTO);
             }

--
Gitblit v1.9.2