From 69830f1a3b084ad6800c8013268624a11d7fa5f3 Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Thu, 11 Jan 2024 09:56:48 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/cms' into anentang

---
 src/main/java/com/xcong/farmer/cms/core/handler/ArticleDataParserHandler.java |   52 +++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 39 insertions(+), 13 deletions(-)

diff --git a/src/main/java/com/xcong/farmer/cms/core/handler/ArticleDataParserHandler.java b/src/main/java/com/xcong/farmer/cms/core/handler/ArticleDataParserHandler.java
index a8c1e0d..951659e 100644
--- a/src/main/java/com/xcong/farmer/cms/core/handler/ArticleDataParserHandler.java
+++ b/src/main/java/com/xcong/farmer/cms/core/handler/ArticleDataParserHandler.java
@@ -1,10 +1,12 @@
 package com.xcong.farmer.cms.core.handler;
 
 
+import cn.hutool.core.util.StrUtil;
 import com.alibaba.fastjson.JSONObject;
 import com.xcong.farmer.cms.configurations.properties.CmsProperties;
 import com.xcong.farmer.cms.conversion.ArticleConversion;
 import com.xcong.farmer.cms.core.node.AttrNode;
+import com.xcong.farmer.cms.core.tag.data.ArticleChildData;
 import com.xcong.farmer.cms.core.tag.data.ArticleData;
 import com.xcong.farmer.cms.core.tag.model.Article;
 import com.xcong.farmer.cms.modules.system.entity.ArticleEntity;
@@ -14,7 +16,9 @@
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Component;
 
+import java.util.ArrayList;
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 
 /**
@@ -25,32 +29,54 @@
 public class ArticleDataParserHandler implements DataParserHandler {
 
     private final ArticleMapper articleMapper = SpringContextHolder.getBean(ArticleMapper.class);
-    private final CmsProperties cmsProperties = SpringContextHolder.getBean(CmsProperties.class);
     @Override
     public void dataParser(AttrNode node) {
-        log.info("文章解析");
+//        log.info("######文章解析########");
+        String baseUrl = (String) node.getSystemDataValue("baseUrl");
+
         Article tag = (Article) node.getParam();
         ArticleEntity data = articleMapper.selectById(tag.getId());
 
+        ArticleData articleData = ArticleConversion.INSTANCE.entityToData(data);
+
         ArticleEntity prevEntity = articleMapper.selectPrevOrNextArticle(data.getId(), data.getColumnId(), 1);
-        ArticleData prev = ArticleConversion.INSTANCE.entityToData(prevEntity);
-        if (prevEntity.getType() == 2) {
-            prev.setUrl(prevEntity.getArticleUrl());
+        if (prevEntity != null) {
+            ArticleData prev = ArticleConversion.INSTANCE.entityToData(prevEntity);
+            if (prevEntity.getType() == 2) {
+                prev.setUrl(prevEntity.getArticleUrl());
+            } else {
+                prev.setUrl(baseUrl + prevEntity.getPath() + "/" + prevEntity.getId() + ".html");
+            }
+
+            articleData.setPrev(prev);
         } else {
-            prev.setUrl(cmsProperties.getBaseUrl() + prevEntity.getPath() + "/" + prevEntity.getId() + ".html");
+            articleData.setPrev(new ArticleData());
         }
 
         ArticleEntity nextEntity = articleMapper.selectPrevOrNextArticle(data.getId(), data.getColumnId(), 2);
-        ArticleData next = ArticleConversion.INSTANCE.entityToData(nextEntity);
-        if (nextEntity.getType() == 2) {
-            next.setUrl(prevEntity.getArticleUrl());
+        if (nextEntity != null) {
+            ArticleData next = ArticleConversion.INSTANCE.entityToData(nextEntity);
+            if (nextEntity.getType() == 2) {
+                next.setUrl(nextEntity.getArticleUrl());
+            } else {
+                next.setUrl(baseUrl + nextEntity.getPath() + "/" + nextEntity.getId() + ".html");
+            }
+
+            articleData.setNext(next);
         } else {
-            next.setUrl(cmsProperties.getBaseUrl() + nextEntity.getPath() + "/" + nextEntity.getId() + ".html");
+            articleData.setNext(new ArticleData());
         }
 
-        ArticleData articleData = ArticleConversion.INSTANCE.entityToData(data);
-        articleData.setNext(next);
-        articleData.setPrev(prev);
+        if (StrUtil.isNotBlank(data.getAtlas())) {
+            List<ArticleChildData> children = new ArrayList<>();
+            StrUtil.split(data.getAtlas(), ',').forEach(item -> {
+                ArticleChildData child = new ArticleChildData();
+                child.setUrl(item);
+                children.add(child);
+            });
+            articleData.setChildren(children);
+        }
+
         node.setData(articleData);
     }
 }

--
Gitblit v1.9.1