From 72ef4f043ba34a535d00bff6a0e264d1a7e12548 Mon Sep 17 00:00:00 2001 From: rentaiming <806181062@qq.com> Date: 星期一, 27 五月 2024 17:54:57 +0800 Subject: [PATCH] 写用户端接口 --- ruoyi-modules/ruoyi-article/src/main/java/com/ruoyi/article/service/impl/ArticleServiceImpl.java | 152 ++++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 138 insertions(+), 14 deletions(-) diff --git a/ruoyi-modules/ruoyi-article/src/main/java/com/ruoyi/article/service/impl/ArticleServiceImpl.java b/ruoyi-modules/ruoyi-article/src/main/java/com/ruoyi/article/service/impl/ArticleServiceImpl.java index e0db56b..68bba48 100644 --- a/ruoyi-modules/ruoyi-article/src/main/java/com/ruoyi/article/service/impl/ArticleServiceImpl.java +++ b/ruoyi-modules/ruoyi-article/src/main/java/com/ruoyi/article/service/impl/ArticleServiceImpl.java @@ -6,14 +6,20 @@ import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ruoyi.article.domain.Article; import com.ruoyi.article.domain.ArticleComments; +import com.ruoyi.article.domain.MemberArticleCollection; +import com.ruoyi.article.domain.MemberLike; import com.ruoyi.article.dto.ArticleDTO; import com.ruoyi.article.mapper.ArticleMapper; import com.ruoyi.article.service.IArticleCommentsService; import com.ruoyi.article.service.IArticleService; +import com.ruoyi.article.service.IMemberArticleCollectionService; +import com.ruoyi.article.service.IMemberLikeService; import com.ruoyi.article.vo.ArticleCommentsVO; +import com.ruoyi.article.vo.ArticleVO; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.enums.ArticleTypeEnum; import com.ruoyi.common.core.enums.AuditStatusEnum; +import com.ruoyi.common.core.utils.bean.BeanUtils; import com.ruoyi.common.core.utils.page.PageDTO; import com.ruoyi.system.api.domain.Member; import com.ruoyi.system.api.domain.MemberAddress; @@ -47,10 +53,16 @@ private IArticleCommentsService articleCommentsService; @Resource - private MemberClient emberClient; + private MemberClient memberClient; + + @Resource + private IMemberLikeService memberLikeService; + + @Resource + private IMemberArticleCollectionService memberArticleCollectionService; @Override - public PageDTO<Article> getArticleList(ArticleDTO articleDTO) { + public PageDTO<ArticleVO> getArticleList(ArticleDTO articleDTO) { Page<Article> page = new Page<>(articleDTO.getPageCurr(), articleDTO.getPageSize()); LambdaQueryWrapper< Article> wrapper= Wrappers.lambdaQuery(); if (articleDTO.getArticleType()!=0){ @@ -61,7 +73,39 @@ wrapper.eq( Article::getDelFlag,0); wrapper.orderByDesc(Article::getCreateTime); Page< Article> page1 = articleService.page(page, wrapper); - return PageDTO.of(page1); + + PageDTO<ArticleVO> articleCommentsVOPageDTO = PageDTO.of(page1, ArticleVO.class); + List<ArticleVO> list2 = articleCommentsVOPageDTO.getList(); + for (ArticleVO articleVO:list2) { + if (articleVO.getMemberId()!=null){ + R<Member> membeOne = memberClient.getMembeOne(articleVO.getMemberId()); + Member data = membeOne.getData(); + articleVO.setMemberNickname(data.getNickname()); + } + LambdaQueryWrapper<MemberLike> wrapper1 = Wrappers.lambdaQuery(); + wrapper1.eq(MemberLike::getMemberId, articleDTO.getMemberId()); + wrapper1.eq(MemberLike::getArticleId, articleVO.getId()); + wrapper1.eq(MemberLike::getType, 1); + wrapper1.eq(MemberLike::getDelFlag, 0); + List<MemberLike> list = memberLikeService.list(wrapper1); + if (list.size() > 0) { + articleVO.setIsLike(1); + } else { + articleVO.setIsLike(2); + } + + LambdaQueryWrapper<MemberArticleCollection> wrapper2 = Wrappers.lambdaQuery(); + wrapper2.eq(MemberArticleCollection::getMemberId, articleDTO.getMemberId()); + wrapper2.eq(MemberArticleCollection::getTargetId, articleVO.getId()); + wrapper2.eq(MemberArticleCollection::getDelFlag, 0); + List<MemberArticleCollection> list1 = memberArticleCollectionService.list(wrapper2); + if (list1.size() > 0) { + articleVO.setIsCollect(1); + } else { + articleVO.setIsCollect(2); + } + } + return articleCommentsVOPageDTO; } @Override @@ -108,9 +152,34 @@ } @Override - public Article getMemberArticleInfo(ArticleDTO articleDTO) { + public ArticleVO getMemberArticleInfo(ArticleDTO articleDTO) { Article article=articleService.getById(articleDTO.getId()); - return article; + ArticleVO articleVO=new ArticleVO(); + BeanUtils.copyProperties(article, articleVO); + + LambdaQueryWrapper<MemberLike> wrapper1= Wrappers.lambdaQuery(); + wrapper1.eq(MemberLike::getMemberId,articleDTO.getMemberId()); + wrapper1.eq(MemberLike::getArticleId,article.getId()); + wrapper1.eq(MemberLike::getType,1); + wrapper1.eq( MemberLike::getDelFlag,0); + List<MemberLike> list = memberLikeService.list(wrapper1); + if (list.size()>0){ + articleVO.setIsLike(1); + }else { + articleVO.setIsLike(2); + } + + LambdaQueryWrapper<MemberArticleCollection> wrapper2= Wrappers.lambdaQuery(); + wrapper2.eq(MemberArticleCollection::getMemberId,articleDTO.getMemberId()); + wrapper2.eq(MemberArticleCollection::getTargetId,article.getId()); + wrapper2.eq( MemberArticleCollection::getDelFlag,0); + List<MemberArticleCollection> list1 = memberArticleCollectionService.list(wrapper2); + if (list1.size()>0){ + articleVO.setIsCollect(1); + }else { + articleVO.setIsCollect(2); + } + return articleVO; } @Override @@ -122,24 +191,79 @@ wrapper.eq( ArticleComments::getType,1); wrapper.orderByDesc(ArticleComments::getCreateTime); Page<ArticleComments> page1 = articleCommentsService.page(page, wrapper); + PageDTO<ArticleCommentsVO> articleCommentsVOPageDTO = PageDTO.of(page1, ArticleCommentsVO.class); + List<ArticleCommentsVO> list2 = articleCommentsVOPageDTO.getList(); + for(ArticleCommentsVO articleCommentsVO:list2){ + R<Member> membeOne = memberClient.getMembeOne(articleCommentsVO.getMemberId()); + Member data = membeOne.getData(); + articleCommentsVO.setMemberNickname(data.getNickname()); + articleCommentsVO.setBmemberNickavatar(data.getAvatar()); + LambdaQueryWrapper<MemberLike> wrapper1= Wrappers.lambdaQuery(); + wrapper1.eq(MemberLike::getMemberId,articleCommentsVO.getMemberId()); + wrapper1.eq(MemberLike::getArticleId,articleCommentsVO.getArticleId()); + wrapper1.eq(MemberLike::getType,2); + wrapper1.eq( MemberLike::getDelFlag,0); + List<MemberLike> list = memberLikeService.list(wrapper1); + if (list.size()>0){ + articleCommentsVO.setIslike(1); + }else { + articleCommentsVO.setIslike(2); + } - List<ArticleComments> articleCommentsList=page1.getRecords(); - List<ArticleCommentsVO> articleCommentsVOList=new ArrayList<>(); - for(ArticleComments articleComments:articleCommentsList){ - ArticleCommentsVO articleCommentsVO=new ArticleCommentsVO(); + List<ArticleCommentsVO> articleCommentsVOList1=new ArrayList<>(); + + LambdaQueryWrapper< ArticleComments> wrapper2= Wrappers.lambdaQuery(); + wrapper2.eq(ArticleComments::getReplyId,articleCommentsVO.getArticleId()); + wrapper2.eq( ArticleComments::getDelFlag,0); + wrapper2.eq( ArticleComments::getType,2); + List<ArticleComments> list1 = articleCommentsService.list(wrapper2); + for (ArticleComments articleComments1:list1){ + ArticleCommentsVO articleCommentsVO1=new ArticleCommentsVO(); + + R<Member> membeOne1 = memberClient.getMembeOne(articleCommentsVO.getMemberId()); + Member data1 = membeOne1.getData(); + + R<Member> membeOne2 = memberClient.getMembeOne(articleCommentsVO.getBmemberId()); + Member data2 = membeOne2.getData(); + + articleCommentsVO1.setArticleId(articleComments1.getArticleId()); + articleCommentsVO1.setContent(articleComments1.getContent()); + articleCommentsVO1.setMemberId(articleComments1.getMemberId()); + articleCommentsVO1.setId(articleComments1.getId()); + articleCommentsVO1.setMemberNickname(data1.getNickname()); + articleCommentsVO1.setBmemberNickavatar(data1.getAvatar()); + articleCommentsVO1.setLikeCount(articleComments1.getLikeCount()); + articleCommentsVO1.setCreateTime(articleComments1.getCreateTime()); + articleCommentsVO1.setBmemberNickavatar(data2.getAvatar()); + articleCommentsVO1.setBmemberNickname(data2.getNickname()); + + LambdaQueryWrapper<MemberLike> wrapper3= Wrappers.lambdaQuery(); + wrapper3.eq(MemberLike::getMemberId,articleCommentsVO.getMemberId()); + wrapper3.eq(MemberLike::getArticleId,articleCommentsVO.getArticleId()); + wrapper3.eq(MemberLike::getType,2); + wrapper3.eq( MemberLike::getDelFlag,0); + List<MemberLike> list3 = memberLikeService.list(wrapper3); + if (list3.size()>0){ + articleCommentsVO1.setIslike(1); + }else { + articleCommentsVO1.setIslike(2); + } + articleCommentsVOList1.add(articleCommentsVO1); + } + + articleCommentsVO.setArticleCommentsVOList(articleCommentsVOList1); + + list2.add(articleCommentsVO); } - - - - return null; + return articleCommentsVOPageDTO; } @Override public void getReport(ArticleDTO articleDTO) { Article article= articleService.getById(articleDTO.getId()); - R<Member> membeOne = emberClient.getMembeOne(articleDTO.getMemberId()); + R<Member> membeOne = memberClient.getMembeOne(articleDTO.getMemberId()); Member data = membeOne.getData(); article.setReportBy(data.getNickname()); article.setReportedTime(LocalDateTime.now()); -- Gitblit v1.7.1