From feea6a61a270993e5ec7899192d8719e631f70f4 Mon Sep 17 00:00:00 2001 From: xuhy <3313886187@qq.com> Date: 星期六, 13 九月 2025 14:58:02 +0800 Subject: [PATCH] 业务员导出 --- ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TSysLiveServiceImpl.java | 38 ++++++++++++++++++++++++++++++++++++-- 1 files changed, 36 insertions(+), 2 deletions(-) diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TSysLiveServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TSysLiveServiceImpl.java index 496e7eb..62b5b0e 100644 --- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TSysLiveServiceImpl.java +++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TSysLiveServiceImpl.java @@ -1,18 +1,29 @@ package com.ruoyi.system.service.impl; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.google.common.collect.ImmutableMap; import com.ruoyi.common.basic.PageInfo; +import com.ruoyi.common.constant.Constants; import com.ruoyi.common.core.domain.R; +import com.ruoyi.common.core.redis.RedisCache; +import com.ruoyi.common.utils.DateUtils; import com.ruoyi.system.mapper.TSysLiveMapper; import com.ruoyi.system.model.TSysEducationalInfo; import com.ruoyi.system.model.TSysLive; import com.ruoyi.system.query.TSysLiveQuery; import com.ruoyi.system.service.TSysLiveService; +import com.ruoyi.system.task.base.QuartzManager; +import com.ruoyi.system.task.base.TimeJobType; +import com.ruoyi.system.task.jobs.LivePushJob; import com.ruoyi.system.vo.TSysLiveVO; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import org.springframework.util.CollectionUtils; import java.time.LocalDateTime; +import java.util.Date; import java.util.List; +import java.util.Map; import java.util.Objects; /** @@ -26,14 +37,31 @@ @Service public class TSysLiveServiceImpl extends ServiceImpl<TSysLiveMapper, TSysLive> implements TSysLiveService { + @Autowired + private RedisCache redisCache; + @Override public R pushUser(String id, String pushType) { TSysLive sysLive = this.getById(id); if (Objects.nonNull(sysLive)){ + // 判断直播开始时间是否在当前时间之后 + if (sysLive.getStartTime().isBefore(LocalDateTime.now())){ + return R.fail("直播已开始,无法配置推送"); + } sysLive.setPushType(pushType); this.updateById(sysLive); - // TODO 添加定时推送 - + // 添加定时任务 直播开始推送 + Map<String, ? extends Object> maps = + new ImmutableMap.Builder<String, String>(). + put("id", sysLive.getId()) + .build(); + QuartzManager.addJob( + LivePushJob.class, + (LivePushJob.name+sysLive.getId()).toUpperCase(), + TimeJobType.LIVE_PUSH, + DateUtils.localDateTimeToDate(sysLive.getStartTime()), + maps + ); } return R.ok(); } @@ -42,6 +70,9 @@ public PageInfo<TSysLiveVO> pageList(TSysLiveQuery query) { PageInfo<TSysLiveVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize()); List<TSysLiveVO> list = this.baseMapper.pageList(query,pageInfo); + if (CollectionUtils.isEmpty(list)){ + return pageInfo; + } // 判断状态 for (TSysLiveVO sysLive : list) { if(sysLive.getStartTime().isAfter(LocalDateTime.now())){ @@ -53,6 +84,9 @@ if(sysLive.getEndTime().isBefore(LocalDateTime.now())){ sysLive.setLiveStatus(3); } + // 查看是否包含该值 + boolean memberInSet = redisCache.isMemberInSet(Constants.LIVE_APPOINTMENT_PUSH + sysLive.getId(), query.getAppUserId()); + sysLive.setAppointmentStatus(memberInSet ? 2 : 1); } pageInfo.setRecords(list); return pageInfo; -- Gitblit v1.7.1