From c8a21748f87bc0a23744d9fee5dec3eaaa403fdc Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期二, 11 六月 2024 18:59:51 +0800
Subject: [PATCH] 1.提交【管理后台】-资讯管理相关接口

---
 ruoyi-modules/ruoyi-article/src/main/java/com/ruoyi/article/service/impl/ArticleServiceImpl.java |  113 +++++++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 107 insertions(+), 6 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 6f75caa..1552bc7 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
@@ -4,34 +4,42 @@
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.google.common.collect.Lists;
+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.MgtArticleQuery;
+import com.ruoyi.article.controller.management.vo.MgtArticleVO;
 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.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.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.StringUtils;
 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.SysUser;
+import com.ruoyi.system.api.domain.dto.MemberDTO;
 import com.ruoyi.system.api.feignClient.MemberClient;
-import com.ruoyi.system.api.util.HuaWeiOBSUtil;
-import java.io.IOException;
+import com.ruoyi.system.api.feignClient.SysUserClient;
 import java.time.LocalDateTime;
 import java.util.ArrayList;
 import java.util.List;
+import java.util.Map;
+import java.util.Set;
+import java.util.function.Function;
+import java.util.stream.Collectors;
 import javax.annotation.Resource;
 import org.springframework.stereotype.Service;
-import org.springframework.web.multipart.MultipartFile;
 
 /**
  * <p>
@@ -56,6 +64,9 @@
 
     @Resource
     private IMemberArticleCollectionService memberArticleCollectionService;
+
+    @Resource
+    private SysUserClient sysUserClient;
 
     @Override
     public PageDTO<ArticleVO> getArticleList(ArticleDTO articleDTO) {
@@ -271,4 +282,94 @@
         article.setReportedTime(LocalDateTime.now());
         this.saveOrUpdate(article);
     }
+
+    @Override
+    public PageDTO<MgtArticleVO> getArticlePage(MgtArticleQuery query) {
+        // 构建查询条件
+        Set<Long> sysUserIdSet = null;
+        Set<Long> memberIdSet = null;
+        if (StringUtils.isNotBlank(query.getCreateBy()) || StringUtils.isNotBlank(
+                query.getPhone())) {
+            SysUser user = new SysUser();
+            user.setNickName(query.getCreateBy());
+            user.setPhonenumber(query.getPhone());
+            List<SysUser> sysUserList = sysUserClient.getUserListByName(user,
+                    SecurityConstants.INNER).getData();
+            sysUserIdSet = sysUserList.stream().map(SysUser::getUserId)
+                    .collect(Collectors.toSet());
+            MemberDTO memberDTO = new MemberDTO();
+            memberDTO.setNickname(query.getCreateBy());
+            memberDTO.setPhone(query.getPhone());
+            List<Member> memberlist = memberClient.getMemberListByCondition(memberDTO,
+                    SecurityConstants.INNER).getData();
+            memberIdSet = memberlist.stream().map(Member::getId)
+                    .collect(Collectors.toSet());
+        }
+        // 分页查询
+        Page<Article> 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)
+                .page(new Page<>(query.getPageCurr(), query.getPageSize()));
+
+        // 若为空直接返回
+        if (StringUtils.isNotEmpty(page.getRecords())) {
+            return PageDTO.empty(page);
+        }
+        /*根据资讯的发布类型分别从系统用户表和会员表中查询发布人信息并封装VO*/
+        PageDTO<MgtArticleVO> pageVO = PageDTO.of(page, MgtArticleVO.class);
+        List<MgtArticleVO> voList = pageVO.getList();
+        Set<Integer> sysUserIds = voList.stream().filter(articleVO -> articleVO.getArticleType()
+                        .equals(ArticleTypeEnum.PLATFORM_RELEASE)).map(MgtArticleVO::getCreateBy)
+                .map(Integer::valueOf).collect(
+                        Collectors.toSet());
+
+        Map<Long, SysUser> userMap;
+        Map<Long, Member> memberMap;
+        if (StringUtils.isNotEmpty(sysUserIds)) {
+            List<SysUser> userList = sysUserClient.getUserList(Lists.newArrayList(sysUserIds))
+                    .getData();
+            userMap = userList.stream().collect(
+                    Collectors.toMap(SysUser::getUserId, Function.identity()));
+        } else {
+            userMap = null;
+        }
+        Set<Long> memIds = voList.stream().filter(articleVO -> articleVO.getArticleType()
+                .equals(ArticleTypeEnum.USER_POSTING)).map(MgtArticleVO::getMemberId).collect(
+                Collectors.toSet());
+        if (StringUtils.isNotEmpty(memIds)) {
+            List<Member> memberList = memberClient.getMemberListByIds(memIds,
+                            SecurityConstants.INNER)
+                    .getData();
+            memberMap = memberList.stream().collect(
+                    Collectors.toMap(Member::getId, Function.identity()));
+        } else {
+            memberMap = null;
+        }
+        if (StringUtils.isNotNull(userMap)) {
+            voList.stream().filter(articleVO -> articleVO.getArticleType()
+                    .equals(ArticleTypeEnum.PLATFORM_RELEASE)).forEach(articleVO -> {
+                SysUser sysUser = userMap.get(Long.valueOf(articleVO.getCreateBy()));
+                if (StringUtils.isNotNull(sysUser)) {
+                    articleVO.setCreateBy(sysUser.getNickName());
+                    articleVO.setPhone(sysUser.getPhonenumber());
+                }
+            });
+        }
+        if (StringUtils.isNotNull(memberMap)) {
+            voList.stream().filter(articleVO -> articleVO.getArticleType()
+                    .equals(ArticleTypeEnum.USER_POSTING)).forEach(articleVO -> {
+                Member member = memberMap.get(articleVO.getMemberId());
+                if (StringUtils.isNotNull(member)) {
+                    articleVO.setCreateBy(member.getNickname());
+                    articleVO.setPhone(member.getPhone());
+                }
+            });
+        }
+        return pageVO;
+    }
 }

--
Gitblit v1.7.1