From 51ea662e22121f9a0ddb5b40c4a8e93e098b34ec Mon Sep 17 00:00:00 2001
From: Hentua <wangdoubleone@gmail.com>
Date: Wed, 10 Jan 2024 22:22:44 +0800
Subject: [PATCH] fxi

---
 src/main/java/com/xcong/farmer/cms/core/handler/ArticleDataParserHandler.java |   23 +++++++++++++++++++----
 1 files changed, 19 insertions(+), 4 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 c73ba7b..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,10 +29,11 @@
 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());
 
@@ -40,7 +45,7 @@
             if (prevEntity.getType() == 2) {
                 prev.setUrl(prevEntity.getArticleUrl());
             } else {
-                prev.setUrl(cmsProperties.getBaseUrl() + prevEntity.getPath() + "/" + prevEntity.getId() + ".html");
+                prev.setUrl(baseUrl + prevEntity.getPath() + "/" + prevEntity.getId() + ".html");
             }
 
             articleData.setPrev(prev);
@@ -54,7 +59,7 @@
             if (nextEntity.getType() == 2) {
                 next.setUrl(nextEntity.getArticleUrl());
             } else {
-                next.setUrl(cmsProperties.getBaseUrl() + nextEntity.getPath() + "/" + nextEntity.getId() + ".html");
+                next.setUrl(baseUrl + nextEntity.getPath() + "/" + nextEntity.getId() + ".html");
             }
 
             articleData.setNext(next);
@@ -62,6 +67,16 @@
             articleData.setNext(new ArticleData());
         }
 
+        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