|  | @@ -6,8 +6,10 @@ import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 | 
	
		
			
				|  |  |  import com.yonge.cooleshow.biz.dal.dao.CourseScheduleDao;
 | 
	
		
			
				|  |  |  import com.yonge.cooleshow.biz.dal.dao.StudentStarDao;
 | 
	
		
			
				|  |  |  import com.yonge.cooleshow.biz.dal.dao.TeacherDao;
 | 
	
		
			
				|  |  | +import com.yonge.cooleshow.biz.dal.entity.LiveRoom;
 | 
	
		
			
				|  |  |  import com.yonge.cooleshow.biz.dal.entity.Teacher;
 | 
	
		
			
				|  |  |  import com.yonge.cooleshow.biz.dal.enums.CacheNameEnum;
 | 
	
		
			
				|  |  | +import com.yonge.cooleshow.biz.dal.service.LiveRoomService;
 | 
	
		
			
				|  |  |  import org.redisson.api.RedissonClient;
 | 
	
		
			
				|  |  |  import org.springframework.beans.factory.annotation.Autowired;
 | 
	
		
			
				|  |  |  import org.springframework.stereotype.Service;
 | 
	
	
		
			
				|  | @@ -38,14 +40,16 @@ public class TeacherTotalServiceImpl extends ServiceImpl<TeacherTotalDao, Teache
 | 
	
		
			
				|  |  |      private CourseScheduleDao courseScheduleDao;
 | 
	
		
			
				|  |  |      @Autowired
 | 
	
		
			
				|  |  |      private RedissonClient redissonClient;
 | 
	
		
			
				|  |  | +    @Autowired
 | 
	
		
			
				|  |  | +    private LiveRoomService liveRoomService;
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -	@Override
 | 
	
		
			
				|  |  | +    @Override
 | 
	
		
			
				|  |  |      public TeacherTotalVo detail(Long id) {
 | 
	
		
			
				|  |  |          return baseMapper.detail(id);
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  | -    
 | 
	
		
			
				|  |  | -     @Override
 | 
	
		
			
				|  |  | -    public IPage<TeacherTotalVo> selectPage(IPage<TeacherTotalVo> page, TeacherTotalSearch query){
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +    @Override
 | 
	
		
			
				|  |  | +    public IPage<TeacherTotalVo> selectPage(IPage<TeacherTotalVo> page, TeacherTotalSearch query) {
 | 
	
		
			
				|  |  |          return page.setRecords(baseMapper.selectPage(page, query));
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -65,21 +69,36 @@ public class TeacherTotalServiceImpl extends ServiceImpl<TeacherTotalDao, Teache
 | 
	
		
			
				|  |  |          if (!CollectionUtils.isEmpty(teacherCourseTotal)) {
 | 
	
		
			
				|  |  |              teacherCourseMap = teacherCourseTotal.stream().collect(Collectors.toMap(TeacherTotalVo::getUserId, o -> o));
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  | +        //查询老师正在直播的直播间
 | 
	
		
			
				|  |  | +        List<LiveRoom> templist = liveRoomService.list(Wrappers.<LiveRoom>lambdaQuery()
 | 
	
		
			
				|  |  | +                .eq(LiveRoom::getLiveState, 1)
 | 
	
		
			
				|  |  | +                .eq(LiveRoom::getRoomState, 0)
 | 
	
		
			
				|  |  | +                .eq(LiveRoom::getType, "TEMP"));
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +        Map<Long, Boolean> liveMap = new HashMap<>();
 | 
	
		
			
				|  |  | +        for (LiveRoom liveRoom : templist) {
 | 
	
		
			
				|  |  | +            liveMap.put(liveRoom.getSpeakerId(), true);
 | 
	
		
			
				|  |  | +        }
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |          List<TeacherTotal> resultList = new ArrayList<>();
 | 
	
		
			
				|  |  |          for (Teacher teacher : teachers) {
 | 
	
		
			
				|  |  |              TeacherTotal teacherTotal = new TeacherTotal();
 | 
	
		
			
				|  |  |              teacherTotal.setUserId(teacher.getUserId());
 | 
	
		
			
				|  |  |              //粉丝数
 | 
	
		
			
				|  |  |              TeacherTotalVo fansTotal = teacherStarMap.get(teacher.getUserId());
 | 
	
		
			
				|  |  | -            if (null != fansTotal) {
 | 
	
		
			
				|  |  | +            if (null != fansTotal && null != fansTotal.getFansNum()) {
 | 
	
		
			
				|  |  |                  teacherTotal.setFansNum(fansTotal.getFansNum());
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |              TeacherTotalVo courseTotal = teacherCourseMap.get(teacher.getUserId());
 | 
	
		
			
				|  |  |              if (null != courseTotal) {
 | 
	
		
			
				|  |  |                  //课时数
 | 
	
		
			
				|  |  | -                teacherTotal.setExpTime(courseTotal.getExpTime());
 | 
	
		
			
				|  |  | -                teacherTotal.setUnExpTime(courseTotal.getUnExpTime());
 | 
	
		
			
				|  |  | +                if (null != courseTotal.getExpTime()) {
 | 
	
		
			
				|  |  | +                    teacherTotal.setExpTime(courseTotal.getExpTime());
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  | +                if (null != courseTotal.getUnExpTime()) {
 | 
	
		
			
				|  |  | +                    teacherTotal.setUnExpTime(courseTotal.getUnExpTime());
 | 
	
		
			
				|  |  | +                }
 | 
	
		
			
				|  |  |                  //星级
 | 
	
		
			
				|  |  |                  Double starGrade = courseTotal.getStarGrade();
 | 
	
		
			
				|  |  |                  if (null != starGrade) {
 | 
	
	
		
			
				|  | @@ -87,6 +106,9 @@ public class TeacherTotalServiceImpl extends ServiceImpl<TeacherTotalDao, Teache
 | 
	
		
			
				|  |  |                      teacherTotal.setStarGrade(round.doubleValue());
 | 
	
		
			
				|  |  |                  }
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  | +            //是否正在直播
 | 
	
		
			
				|  |  | +            teacherTotal.setLiveFlag(null == liveMap.get(teacher.getUserId()) ? false : true);
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |              resultList.add(teacherTotal);
 | 
	
		
			
				|  |  |              redissonClient.getBucket(CacheNameEnum.TEACHER_TOTAL.getRedisKey(teacherTotal.getUserId()))
 | 
	
		
			
				|  |  |                      .set(teacherTotal);
 |