文章优选功能

This commit is contained in:
ronger 2020-12-18 14:20:47 +08:00
parent 59992dcd53
commit 1ef5f5c898
7 changed files with 50 additions and 7 deletions

View File

@ -53,4 +53,6 @@ public class ArticleDTO {
private List<PortfolioArticleDTO> portfolios;
private Integer sortNo;
/** 0:非优选1优选;0 */
private String articlePerfect;
}

View File

@ -36,7 +36,7 @@ public class Article implements Serializable,Cloneable {
private String articlePreviewContent;
/** 评论总数 */
private Integer articleCommentCount;
/** 0:非优选1优选;0 */
/** 0:非优选1优选; */
private String articlePerfect;
/** 文章永久链接 */
private String articlePermalink;

View File

@ -176,4 +176,12 @@ public interface ArticleMapper extends Mapper<Article> {
* @return
*/
List<ArticleDTO> selectPortfolioArticlesByIdPortfolioAndSortNo(@Param("idPortfolio") Integer idPortfolio, @Param("sortNo") Integer sortNo);
/**
* 更新文章优选状态
* @param idArticle
* @param articlePerfect
* @return
*/
int updatePerfect(@Param("idArticle") Integer idArticle, @Param("articlePerfect") String articlePerfect);
}

View File

@ -111,6 +111,16 @@ public interface ArticleService extends Service<Article> {
* @param idArticle
* @param tags
* @return
* @throws UnsupportedEncodingException
* @throws BaseApiException
*/
Map updateTags(Integer idArticle, String tags) throws UnsupportedEncodingException, BaseApiException;
/**
* 更新文章优选状态
* @param idArticle
* @param articlePerfect
* @return
*/
Map updatePerfect(Integer idArticle, String articlePerfect);
}

View File

@ -334,24 +334,37 @@ public class ArticleServiceImpl extends AbstractService<Article> implements Arti
return map;
}
@Override
public Map updatePerfect(Integer idArticle, String articlePerfect) {
Map map = new HashMap(2);
int result = articleMapper.updatePerfect(idArticle, articlePerfect);
if (result == 0) {
map.put("success", false);
map.put("message", "设置优选文章失败!");
} else {
map.put("success", true);
}
return map;
}
private ArticleDTO genArticle(ArticleDTO article, Integer type) {
Integer ARTICLE_LIST = 0;
Integer ARTICLE_VIEW = 1;
Integer ARTICLE_EDIT = 2;
Integer articleList = 0;
Integer articleView = 1;
Integer articleEdit = 2;
Author author = genAuthor(article);
article.setArticleAuthor(author);
article.setTimeAgo(Utils.getTimeAgo(article.getUpdatedTime()));
List<ArticleTagDTO> tags = articleMapper.selectTags(article.getIdArticle());
article.setTags(tags);
if (!type.equals(ARTICLE_LIST)) {
if (!type.equals(articleList)) {
ArticleContent articleContent = articleMapper.selectArticleContent(article.getIdArticle());
if (type.equals(ARTICLE_VIEW)) {
if (type.equals(articleView)) {
article.setArticleContent(articleContent.getArticleContentHtml());
// 获取所属作品集列表数据
List<PortfolioArticleDTO> portfolioArticleDTOList = articleMapper.selectPortfolioArticles(article.getIdArticle());
portfolioArticleDTOList.forEach(portfolioArticleDTO -> genPortfolioArticles(portfolioArticleDTO));
article.setPortfolios(portfolioArticleDTOList);
} else if (type.equals(ARTICLE_EDIT)) {
} else if (type.equals(articleEdit)) {
article.setArticleContent(articleContent.getArticleContent());
} else {
article.setArticleContent(articleContent.getArticleContentHtml());

View File

@ -87,4 +87,10 @@ public class ArticleController {
return GlobalResultGenerator.genSuccessResult(map);
}
@PatchMapping("/update-perfect")
public GlobalResult updatePerfect(@RequestBody Article article) {
Map map = articleService.updatePerfect(article.getIdArticle(), article.getArticlePerfect());
return GlobalResultGenerator.genSuccessResult(map);
}
}

View File

@ -38,6 +38,7 @@
<result column="article_status" property="articleStatus"></result>
<result column="updated_time" property="updatedTime"></result>
<result column="sort_no" property="sortNo"></result>
<result column="article_perfect" property="articlePerfect"></result>
</resultMap>
<resultMap id="ArticleContentResultMap" type="com.rymcu.forest.entity.ArticleContent">
<result column="id_article" property="idArticle"/>
@ -78,6 +79,9 @@
<update id="updateArticleLinkAndPreviewContent">
update vertical_article set article_link = #{articleLink}, article_permalink = #{articlePermalink}, article_preview_content = #{articlePreviewContent} where id = #{idArticle}
</update>
<update id="updatePerfect">
update vertical_article set article_perfect = #{articlePerfect} where id = #{idArticle}
</update>
<delete id="deleteTagArticle">
delete from vertical_tag_article where id_article = #{id}
</delete>