From b305b6ce82fbb975acf42af3ad450aa4c7699d5e Mon Sep 17 00:00:00 2001 From: zxl <763096477@qq.com> Date: 星期四, 26 六月 2025 14:35:46 +0800 Subject: [PATCH] 客户分析,和浏览视频记录 --- framework/src/main/java/cn/lili/modules/member/serviceimpl/FootprintServiceImpl.java | 83 +++++++++++++++++++++++++++++++++++++++-- 1 files changed, 78 insertions(+), 5 deletions(-) diff --git a/framework/src/main/java/cn/lili/modules/member/serviceimpl/FootprintServiceImpl.java b/framework/src/main/java/cn/lili/modules/member/serviceimpl/FootprintServiceImpl.java index 723725f..e995846 100644 --- a/framework/src/main/java/cn/lili/modules/member/serviceimpl/FootprintServiceImpl.java +++ b/framework/src/main/java/cn/lili/modules/member/serviceimpl/FootprintServiceImpl.java @@ -1,26 +1,34 @@ package cn.lili.modules.member.serviceimpl; +import cn.lili.base.Result; import cn.lili.common.security.context.UserContext; import cn.lili.modules.goods.entity.dos.GoodsSku; import cn.lili.modules.goods.service.GoodsSkuService; +import cn.lili.modules.lmk.domain.query.FootPrintQuery; +import cn.lili.modules.lmk.domain.vo.SimpleVideoTagVO; +import cn.lili.modules.lmk.domain.vo.VideoFootInfoVo; +import cn.lili.modules.lmk.domain.vo.VideoFootVO; +import cn.lili.modules.lmk.domain.vo.VideoVO; +import cn.lili.modules.lmk.mapper.VideoMapper; import cn.lili.modules.member.entity.dos.FootPrint; import cn.lili.modules.member.entity.dto.FootPrintQueryParams; import cn.lili.modules.member.mapper.FootprintMapper; import cn.lili.modules.member.service.FootprintService; import cn.lili.modules.search.entity.dos.EsGoodsIndex; import cn.lili.mybatis.util.PageUtil; +import cn.lili.utils.COSUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; + import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; -import java.util.Date; -import java.util.List; -import java.util.Objects; -import java.util.Optional; +import java.math.BigDecimal; +import java.math.RoundingMode; +import java.util.*; import java.util.stream.Collectors; import java.util.stream.IntStream; @@ -36,6 +44,12 @@ @Autowired private GoodsSkuService goodsSkuService; + + @Autowired + private VideoMapper videoMapper; + + @Autowired + private COSUtil cOSUtil; @Override public FootPrint saveFootprint(FootPrint footPrint) { @@ -64,7 +78,6 @@ Page<FootPrint> footPrintPages = this.page(PageUtil.initPage(params), params.queryWrapper()); //瀹氫箟缁撴灉 Page<EsGoodsIndex> esGoodsIndexIPage = new Page<>(); - if (footPrintPages.getRecords() != null && !footPrintPages.getRecords().isEmpty()) { List<String> skuIds = footPrintPages.getRecords().stream().map(FootPrint::getSkuId).collect(Collectors.toList()); List<GoodsSku> goodsSkuByIdFromCache = goodsSkuService.getGoodsSkuByIdFromCache(skuIds); @@ -92,10 +105,70 @@ } @Override + public Result videoFootPrintPage(FootPrintQuery query) { + IPage<VideoFootVO> page = cn.lili.utils.PageUtil.getPage(query,VideoFootVO.class); + videoMapper.videoFootPage(page,query); + + VideoFootInfoVo videoFootInfoVo = videoMapper.getVideoFootInfo(query.getMemberId()); + + for (VideoFootVO videoFootVO : page.getRecords()) { + videoFootVO.setCoverCOSUrl(cOSUtil.getPreviewUrl(videoFootVO.getCoverUrl())); + //璁$畻鎾斁杩涘害 + if(videoFootVO.getPlayAt() == null || videoFootVO.getPlayAt().isEmpty()){ + videoFootVO.setPlayProgress(0.0); + continue; + } + + BigDecimal value = BigDecimal.valueOf(Double.parseDouble(videoFootVO.getPlayAt()) / videoFootVO.getVideoDuration()) + .setScale(2, RoundingMode.HALF_UP); + + if (value.compareTo(BigDecimal.ONE) > 0) { + // 杩欓噷鍙互娣诲姞澶勭悊閫昏緫锛屾瘮濡傦細鑷姩淇涓�1.0 + value = BigDecimal.ONE; + } + + videoFootVO.setPlayProgress(value.doubleValue()); + } + + HashMap<String,Object> map = new HashMap<>(); + map.put("data", page.getRecords()); + map.put("total", page.getTotal()); + if (videoFootInfoVo == null) { + map.put("avgProgress",0); + map.put("totalDuration",0); + }else { + map.put("avgProgress",videoFootInfoVo.getAvgCompletionRate()); + map.put("totalDuration",videoFootInfoVo.getTotalDuration()); + } + return Result.ok().data(map); + } + + @Override + public Result memberActionAnalyse(String id){ + //瑙嗛鍒嗙被 + List<VideoFootVO> list = videoMapper.videoFoot(id); + Map<String, Long> tagCountMap = list.stream() + .flatMap(video -> video.getTagList().stream()) // 灞曞紑鎵�鏈� tag + .filter(Objects::nonNull) // 杩囨护 null + .collect(Collectors.groupingBy( + SimpleVideoTagVO::getTagName, // 鎸� tagName 鍒嗙粍 + Collectors.counting() // 璁$畻姣忎釜 tagName 鍑虹幇鐨勬鏁� + )); + + return Result.ok().data(tagCountMap); + } + + + @Override public long getFootprintNum() { LambdaQueryWrapper<FootPrint> lambdaQueryWrapper = Wrappers.lambdaQuery(); lambdaQueryWrapper.eq(FootPrint::getMemberId, Objects.requireNonNull(UserContext.getCurrentUser()).getId()); lambdaQueryWrapper.eq(FootPrint::getDeleteFlag, false); return this.count(lambdaQueryWrapper); } + + + } + + -- Gitblit v1.8.0