From cd55aff7eea06f77a8f712cef1ad2744c44d0f8a Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期四, 20 六月 2024 18:56:16 +0800
Subject: [PATCH] 1.修改bug
---
ruoyi-modules/ruoyi-article/src/main/java/com/ruoyi/article/service/impl/ArticleServiceImpl.java | 175 ++++++++++++++++++++++++++++++++++++----------------------
1 files changed, 109 insertions(+), 66 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 4e43392..1b176ea 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
@@ -8,8 +8,10 @@
import com.ruoyi.article.controller.forepart.dto.ArticleDTO;
import com.ruoyi.article.controller.forepart.vo.ArticleCommentsVO;
import com.ruoyi.article.controller.forepart.vo.ArticleVO;
+import com.ruoyi.article.controller.management.dto.MgtArticleAuditDTO;
import com.ruoyi.article.controller.management.dto.MgtArticleDTO;
import com.ruoyi.article.controller.management.dto.MgtArticleQuery;
+import com.ruoyi.article.controller.management.dto.MgtArticleUpdDTO;
import com.ruoyi.article.controller.management.vo.MgtArticleVO;
import com.ruoyi.article.domain.Article;
import com.ruoyi.article.domain.ArticleComments;
@@ -80,6 +82,7 @@
if (articleDTO.getTitle()!=null){
wrapper.like(Article::getTitle,articleDTO.getTitle());
}
+ wrapper.eq(Article::getListingStatus,0);
wrapper.eq(Article::getStatus,2);
wrapper.eq( Article::getDelFlag,0);
wrapper.orderByDesc(Article::getCreateTime);
@@ -202,72 +205,79 @@
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<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(),
+ if (list2!=null){
+ for(int i=0;i<list2.size();i++){
+ ArticleCommentsVO articleCommentsVO=list2.get(i);
+ R<Member> membeOne = 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);
+ Member data = membeOne.getData();
+ articleCommentsVO.setMemberNickname(data.getNickname());
+ articleCommentsVO.setMemberNickavatar(data.getAvatar());
+ LambdaQueryWrapper<MemberLike> wrapper1= Wrappers.lambdaQuery();
+ wrapper1.eq(MemberLike::getMemberId,articleCommentsVO.getMemberId());
+ wrapper1.eq(MemberLike::getArticleId,articleCommentsVO.getId());
+ wrapper1.eq(MemberLike::getType,2);
+ wrapper1.eq( MemberLike::getDelFlag,0);
+ List<MemberLike> list = memberLikeService.list(wrapper1);
+ if (list.size()>0){
+ articleCommentsVO.setIslike(1);
}else {
- articleCommentsVO1.setIslike(2);
+ articleCommentsVO.setIslike(2);
}
- articleCommentsVOList1.add(articleCommentsVO1);
+
+
+ List<ArticleCommentsVO> articleCommentsVOList1=new ArrayList<>();
+
+ LambdaQueryWrapper< ArticleComments> wrapper2= Wrappers.lambdaQuery();
+ wrapper2.eq(ArticleComments::getReplyId,articleCommentsVO.getId());
+ 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(articleComments1.getMemberId(),
+ SecurityConstants.INNER);
+ Member data1 = membeOne1.getData();
+
+
+
+ R<Member> membeOne2 = memberClient.getMembeOne(articleComments1.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.setMemberNickavatar(data1.getAvatar());
+ articleCommentsVO1.setBmemberNickavatar(data1.getAvatar());
+ articleCommentsVO1.setLikeCount(articleComments1.getLikeCount());
+ articleCommentsVO1.setCreateTime(articleComments1.getCreateTime());
+ articleCommentsVO1.setBmemberNickname(data2.getNickname());
+ articleCommentsVO1.setState(articleComments1.getState());
+ articleCommentsVO1.setBmemberId(data2.getId());
+
+ LambdaQueryWrapper<MemberLike> wrapper3= Wrappers.lambdaQuery();
+ wrapper3.eq(MemberLike::getMemberId,articleCommentsVO.getMemberId());
+ wrapper3.eq(MemberLike::getArticleId,articleComments1.getId());
+ 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);
+
}
-
- articleCommentsVO.setArticleCommentsVOList(articleCommentsVOList1);
-
- list2.add(articleCommentsVO);
}
+
return articleCommentsVOPageDTO;
}
@@ -295,6 +305,7 @@
// 构建查询条件
Set<Long> sysUserIdSet = null;
Set<Long> memberIdSet = null;
+ Page<Article> page = new Page<>(query.getPageCurr(), query.getPageSize());
if (StringUtils.isNotBlank(query.getCreateBy()) || StringUtils.isNotBlank(
query.getPhone())) {
SysUser user = new SysUser();
@@ -311,20 +322,23 @@
SecurityConstants.INNER).getData();
memberIdSet = memberlist.stream().map(Member::getId)
.collect(Collectors.toSet());
+ if (StringUtils.isEmpty(sysUserIdSet) && StringUtils.isEmpty(memberIdSet)) {
+ return PageDTO.empty(page);
+ }
}
// 分页查询
- Page<Article> page = this.lambdaQuery()
+ page = this.lambdaQuery()
.in(StringUtils.isNotEmpty(sysUserIdSet), Article::getCreateBy,
sysUserIdSet)
.in(StringUtils.isNotEmpty(memberIdSet), Article::getMemberId, memberIdSet)
.eq(StringUtils.isNotNull(query.getListingStatus()), Article::getListingStatus,
query.getListingStatus())
.like(StringUtils.isNotBlank(query.getTitle()), Article::getTitle, query.getTitle())
- .orderByDesc(Article::getStatus)
+ .orderByDesc(Article::getReported)
.page(new Page<>(query.getPageCurr(), query.getPageSize()));
// 若为空直接返回
- if (StringUtils.isNotEmpty(page.getRecords())) {
+ if (StringUtils.isEmpty(page.getRecords())) {
return PageDTO.empty(page);
}
/*根据资讯的发布类型分别从系统用户表和会员表中查询发布人信息并封装VO*/
@@ -350,8 +364,7 @@
Collectors.toSet());
if (StringUtils.isNotEmpty(memIds)) {
List<Member> memberList = memberClient.getMemberListByIds(memIds,
- SecurityConstants.INNER)
- .getData();
+ SecurityConstants.INNER).getData();
memberMap = memberList.stream().collect(
Collectors.toMap(Member::getId, Function.identity()));
} else {
@@ -390,6 +403,7 @@
Article article = BeanUtils.copyBean(dto, Article.class);
if (StringUtils.isNull(article.getId())) {
article.setStatus(AuditStatusEnum.PASSED);
+ article.setArticleType(ArticleTypeEnum.PLATFORM_RELEASE);
this.save(article);
} else {
Article articleById = this.getById(article.getId());
@@ -432,4 +446,33 @@
}
return BeanUtils.copyBean(article, MgtArticleVO.class);
}
+
+ /**
+ * 资讯审核
+ *
+ * @param dto 管理后台-资讯审核传输对象
+ */
+ @Override
+ public void audit(MgtArticleAuditDTO dto) {
+ Article article = this.getById(dto.getId());
+ if (StringUtils.isNull(article)) {
+ throw new ServiceException("资讯不存在");
+ }
+ article.setStatus(dto.getStatus());
+ if (AuditStatusEnum.REJECTED.equals(dto.getStatus())) {
+ article.setRefuseComment(dto.getRefuseComment());
+ }
+ this.updateById(article);
+ }
+
+ /**
+ * 上架/下架
+ *
+ * @param dto 资讯上下架数据传输对象
+ */
+ @Override
+ public void updStatus(MgtArticleUpdDTO dto) {
+ this.lambdaUpdate().set(Article::getListingStatus, dto.getListingStatus())
+ .eq(Article::getId, dto.getId()).update();
+ }
}
--
Gitblit v1.7.1