From 971f29d43dcfdda5ce1a15d06d652cdadf67b4d9 Mon Sep 17 00:00:00 2001
From: rentaiming <806181062@qq.com>
Date: 星期五, 07 六月 2024 11:24:01 +0800
Subject: [PATCH] 用户端商品
---
ruoyi-modules/ruoyi-article/src/main/java/com/ruoyi/article/service/impl/ArticleServiceImpl.java | 218 +++++++++++++++++++++++++++++++++++++++++++-----------
1 files changed, 172 insertions(+), 46 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..6f75caa 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,28 +6,32 @@
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.ruoyi.article.domain.Article;
import com.ruoyi.article.domain.ArticleComments;
-import com.ruoyi.article.dto.ArticleDTO;
+import com.ruoyi.article.domain.MemberArticleCollection;
+import com.ruoyi.article.domain.MemberLike;
+import com.ruoyi.article.controller.forepart.dto.ArticleDTO;
import com.ruoyi.article.mapper.ArticleMapper;
import com.ruoyi.article.service.IArticleCommentsService;
import com.ruoyi.article.service.IArticleService;
-import com.ruoyi.article.vo.ArticleCommentsVO;
+import com.ruoyi.article.service.IMemberArticleCollectionService;
+import com.ruoyi.article.service.IMemberLikeService;
+import com.ruoyi.article.controller.forepart.vo.ArticleCommentsVO;
+import com.ruoyi.article.controller.forepart.vo.ArticleVO;
+import com.ruoyi.common.core.constant.SecurityConstants;
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;
import com.ruoyi.system.api.feignClient.MemberClient;
-import org.springframework.stereotype.Service;
-import org.springframework.web.multipart.MultipartFile;
-import util.HuaWeiOBSUtil;
-
-import javax.annotation.Resource;
-import org.springframework.stereotype.Service;
+import com.ruoyi.system.api.util.HuaWeiOBSUtil;
import java.io.IOException;
import java.time.LocalDateTime;
import java.util.ArrayList;
import java.util.List;
+import javax.annotation.Resource;
+import org.springframework.stereotype.Service;
+import org.springframework.web.multipart.MultipartFile;
/**
* <p>
@@ -40,28 +44,68 @@
@Service
public class ArticleServiceImpl extends ServiceImpl<ArticleMapper, Article> implements IArticleService {
- @Resource
- private IArticleService articleService;
@Resource
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){
wrapper.eq(Article::getArticleType,articleDTO.getArticleType());
}
- wrapper.like(Article::getTitle,articleDTO.getTitle());
+ if (articleDTO.getTitle()!=null){
+ wrapper.like(Article::getTitle,articleDTO.getTitle());
+ }
wrapper.eq(Article::getStatus,2);
wrapper.eq( Article::getDelFlag,0);
wrapper.orderByDesc(Article::getCreateTime);
- Page< Article> page1 = articleService.page(page, wrapper);
- return PageDTO.of(page1);
+ Page< Article> page1 = this.page(page, wrapper);
+
+ 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(),
+ SecurityConstants.INNER);
+ Member data = membeOne.getData();
+ articleVO.setMemberNickname(data.getNickname());
+ articleVO.setMemberAvatar(data.getAvatar());
+ }
+ 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
@@ -69,9 +113,10 @@
Page<Article> page = new Page<>(articleDTO.getPageCurr(), articleDTO.getPageSize());
LambdaQueryWrapper< Article> wrapper= Wrappers.lambdaQuery();
wrapper.eq(Article::getMemberId,articleDTO.getMemberId());
+ wrapper.eq(Article::getArticleType,2);
wrapper.eq( Article::getDelFlag,0);
wrapper.orderByDesc(Article::getCreateTime);
- Page<Article> page1 = articleService.page(page, wrapper);
+ Page<Article> page1 = this.page(page, wrapper);
return PageDTO.of(page1);
}
@@ -79,38 +124,60 @@
public void saveMemberArticle(ArticleDTO articleDTO) {
Article article=new Article();
if (articleDTO.getId()!=null){
- article=articleService.getById(articleDTO.getId());
+ article=this.getById(articleDTO.getId());
}
article.setMemberId(articleDTO.getMemberId());
+
article.setArticleType(ArticleTypeEnum.USER_POSTING);
article.setStatus(AuditStatusEnum.TO_BE_REVIEWED);
article.setContent(articleDTO.getContent());
article.setTitle(articleDTO.getTitle());
- List<String> urlList=new ArrayList<>();
- if (articleDTO.getRticleImageUrl().length>0){
- for (MultipartFile file:articleDTO.getRticleImageUrl()){
- try {
- String url= HuaWeiOBSUtil.obsUpload(file);
- urlList.add(url);
- } catch (IOException e) {
- throw new RuntimeException(e);
- }
- }
- article.setImages(urlList.toString());
- }
- articleService.saveOrUpdate(article);
+ article.setImages(articleDTO.getRticleImageUrl());
+ this.saveOrUpdate(article);
}
@Override
public void delMemberArticle(ArticleDTO articleDTO) {
- articleService.removeById(articleDTO.getId());
+ this.removeById(articleDTO.getId());
}
@Override
- public Article getMemberArticleInfo(ArticleDTO articleDTO) {
- Article article=articleService.getById(articleDTO.getId());
- return article;
+ public ArticleVO getMemberArticleInfo(ArticleDTO articleDTO) {
+ Article article=this.getById(articleDTO.getId());
+ ArticleVO articleVO=new ArticleVO();
+
+ BeanUtils.copyProperties(article, articleVO);
+
+ R<Member> membeOne = memberClient.getMembeOne(articleVO.getMemberId(),
+ SecurityConstants.INNER);
+ Member data = membeOne.getData();
+ articleVO.setMemberNickname(data.getNickname());
+ articleVO.setMemberAvatar(data.getAvatar());
+
+ 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,27 +189,86 @@
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(),
+ SecurityConstants.INNER);
+ 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(),
+ SecurityConstants.INNER);
+ Member data1 = membeOne1.getData();
+
+ R<Member> membeOne2 = memberClient.getMembeOne(articleCommentsVO.getBmemberId(),
+ SecurityConstants.INNER);
+ 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());
+ Article article= this.getById(articleDTO.getId());
+ R<Member> membeOne = memberClient.getMembeOne(articleDTO.getMemberId(),
+ SecurityConstants.INNER);
Member data = membeOne.getData();
article.setReportBy(data.getNickname());
article.setReportedTime(LocalDateTime.now());
- articleService.saveOrUpdate(article);
+ this.saveOrUpdate(article);
}
}
--
Gitblit v1.7.1