Browse Source

获取课程任务学习进度

yangfeng 1 year ago
parent
commit
f91e446ce8

+ 9 - 0
web/src/main/java/com/ynfy/buss/course/coursecatalog/service/ICourseCatalogService.java

@@ -35,4 +35,13 @@ public interface ICourseCatalogService extends IService<CourseCatalog> {
      */
     boolean checkPreTaskComplete(String id);
 
+
+    /**
+     * 获取课程任务
+     *
+     * @param courseId
+     * @return
+     */
+    List<CourseCatalog> listCourseCatalog(String courseId);
+
 }

+ 14 - 0
web/src/main/java/com/ynfy/buss/course/coursecatalog/service/impl/CourseCatalogServiceImpl.java

@@ -197,4 +197,18 @@ public class CourseCatalogServiceImpl extends ServiceImpl<CourseCatalogMapper, C
         }
         return false;
     }
+
+
+    /**
+     * 获取课程任务
+     *
+     * @param courseId
+     * @return
+     */
+    @Override
+    public List<CourseCatalog> listCourseCatalog(String courseId) {
+        LambdaQueryWrapper<CourseCatalog> query = new LambdaQueryWrapper<CourseCatalog>().eq(CourseCatalog::getCourseId, courseId)
+                .eq(CourseCatalog::getType, CatalogType.TASK.getCode());
+        return list(query);
+    }
 }

+ 13 - 0
web/src/main/java/com/ynfy/buss/course/usercoursecatalog/controller/UserCourseCatalogController.java

@@ -173,4 +173,17 @@ public class UserCourseCatalogController extends JeecgController<UserCourseCatal
         return Result.OK();
     }
 
+
+    /**
+     * 获取课程任务学习进度
+     *
+     * @return
+     */
+    @AutoLog(value = "获取课程任务学习进度")
+    @ApiOperation(value = "获取课程任务学习进度", notes = "获取课程任务学习进度")
+    @GetMapping(value = "/getCourseStudyProcess")
+    public Result<?> getCourseStudyProcess(@RequestParam String courseId) {
+        return Result.OK(userCourseCatalogService.getCourseStudyProcess(courseId));
+    }
+
 }

+ 10 - 0
web/src/main/java/com/ynfy/buss/course/usercoursecatalog/service/IUserCourseCatalogService.java

@@ -4,6 +4,8 @@ import com.baomidou.mybatisplus.extension.service.IService;
 import com.ynfy.buss.course.usercoursecatalog.entity.UserCourseCatalog;
 import com.ynfy.buss.course.usercoursecatalog.entity.vo.CatalogTimeVO;
 
+import java.util.List;
+
 /**
  * @Description: 用户课程任务学习情况
  * @Author: jeecg-boot
@@ -20,4 +22,12 @@ public interface IUserCourseCatalogService extends IService<UserCourseCatalog> {
     void calcStudyTime(CatalogTimeVO catalogTimeVO);
 
     UserCourseCatalog findUserCatalog(String userId, String courseCatalogId);
+
+
+    /**
+     * 获取课程任务学习进度
+     *
+     * @return
+     */
+    List<UserCourseCatalog> getCourseStudyProcess(String courseId);
 }

+ 24 - 0
web/src/main/java/com/ynfy/buss/course/usercoursecatalog/service/impl/UserCourseCatalogServiceImpl.java

@@ -6,6 +6,7 @@ import cn.hutool.core.util.NumberUtil;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ynfy.buss.course.coursecatalog.entity.CourseCatalog;
+import com.ynfy.buss.course.coursecatalog.service.ICourseCatalogService;
 import com.ynfy.buss.course.usercoursecatalog.entity.UserCourseCatalog;
 import com.ynfy.buss.course.usercoursecatalog.entity.vo.CatalogTimeVO;
 import com.ynfy.buss.course.usercoursecatalog.mapper.UserCourseCatalogMapper;
@@ -13,10 +14,14 @@ import com.ynfy.buss.course.usercoursecatalog.service.IUserCourseCatalogService;
 import org.apache.commons.lang3.StringUtils;
 import org.apache.shiro.SecurityUtils;
 import org.jeecg.common.system.vo.LoginUser;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Lazy;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
+import java.util.List;
 import java.util.Objects;
+import java.util.stream.Collectors;
 
 /**
  * @Description: 用户课程任务学习情况
@@ -27,6 +32,10 @@ import java.util.Objects;
 @Service
 public class UserCourseCatalogServiceImpl extends ServiceImpl<UserCourseCatalogMapper, UserCourseCatalog> implements IUserCourseCatalogService {
 
+    @Lazy
+    @Autowired
+    private ICourseCatalogService courseCatalogService;
+
     /**
      * 计算任务学习时长
      *
@@ -73,4 +82,19 @@ public class UserCourseCatalogServiceImpl extends ServiceImpl<UserCourseCatalogM
                 .eq(UserCourseCatalog::getUserId, userId).eq(UserCourseCatalog::getCourseCatalogId, courseCatalogId);
         return getOne(query);
     }
+
+
+    /**
+     * 获取课程任务学习进度
+     *
+     * @return
+     */
+    @Override
+    public List<UserCourseCatalog> getCourseStudyProcess(String courseId) {
+        List<CourseCatalog> catalogList = courseCatalogService.listCourseCatalog(courseId);
+        List<String> courseCatalogIdList = catalogList.stream().map(CourseCatalog::getId).collect(Collectors.toList());
+        LambdaQueryWrapper<UserCourseCatalog> query = new LambdaQueryWrapper<UserCourseCatalog>()
+                .in(UserCourseCatalog::getCourseCatalogId, courseCatalogIdList);
+        return list(query);
+    }
 }