From f04b8922283120e2bc4a476ddc302ebd3b0894e4 Mon Sep 17 00:00:00 2001
From: Helius <wangdoubleone@gmail.com>
Date: Thu, 07 Jul 2022 20:42:05 +0800
Subject: [PATCH] Merge branch 'master' of http://120.27.238.55:7000/r/farmer-cms

---
 src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java |   74 +++++++++++++++++++++++++++++++++---
 1 files changed, 67 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java b/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java
index 1110bfb..9ef6e93 100644
--- a/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java
+++ b/src/main/java/com/xcong/farmer/cms/modules/system/service/Impl/CmsTemplateServiceImpl.java
@@ -1,17 +1,22 @@
 package com.xcong.farmer.cms.modules.system.service.Impl;
 
 import cn.hutool.core.io.FileUtil;
+import cn.hutool.core.util.IdUtil;
+import cn.hutool.core.util.StrUtil;
 import cn.hutool.core.util.ZipUtil;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.xcong.farmer.cms.common.exception.GlobalException;
+import com.xcong.farmer.cms.common.response.Result;
 import com.xcong.farmer.cms.common.utils.FileUtils;
 import com.xcong.farmer.cms.configurations.GlobalExceptionHandler;
+import com.xcong.farmer.cms.configurations.properties.CmsProperties;
 import com.xcong.farmer.cms.core.template.TemplateConfiguration;
 import com.xcong.farmer.cms.modules.system.dto.TemplateListDto;
 import com.xcong.farmer.cms.modules.system.entity.CmsTemplateEntity;
+import com.xcong.farmer.cms.modules.system.entity.UserEntity;
 import com.xcong.farmer.cms.modules.system.mapper.CmsTemplateMapper;
 import com.xcong.farmer.cms.modules.system.service.ICmsTemplateService;
 import com.xcong.farmer.cms.modules.system.util.LoginUserUtil;
@@ -22,7 +27,12 @@
 import org.springframework.web.multipart.MultipartFile;
 
 import java.io.File;
+import java.io.FileInputStream;
 import java.io.IOException;
+import java.io.InputStream;
+import java.nio.charset.StandardCharsets;
+import java.nio.file.Files;
+import java.nio.file.Paths;
 import java.util.ArrayList;
 import java.util.Arrays;
 import java.util.List;
@@ -35,14 +45,15 @@
 public class CmsTemplateServiceImpl extends ServiceImpl<CmsTemplateMapper, CmsTemplateEntity> implements ICmsTemplateService {
 
     @Autowired
-    private TemplateConfiguration cfg;
+    private CmsProperties properties;
 
     private List<String> fileSuffix = Arrays.asList(".zip", ".html");
 
     @Override
     public void updateTemplate(MultipartFile upload) {
-        String templatePath = cfg.templatePath;
-        String staticPath = cfg.staticPath;
+        String templatePath = properties.getTemplatePath();
+        String staticPath = properties.getStaticPath();
+        Long companyId = LoginUserUtil.getCompanyId();
 
         String filename = upload.getOriginalFilename();
         String suffix = filename.substring(filename.lastIndexOf("."));
@@ -68,6 +79,7 @@
 
                 for (File templateFile : files) {
                     if (!templateFile.isFile()) {
+                        FileUtil.move(templateFile, new File(staticPath), true);
                         continue;
                     }
 
@@ -76,15 +88,14 @@
                     }
 
                     String name = templateFile.getName();
-                    if (!name.endsWith(".list.html") && !name.endsWith(".article.html") && !name.endsWith(".index.html")) {
+                    if (!name.endsWith(".list.html") && !name.endsWith(".article.html") && !name.endsWith("index.html")) {
                         continue;
                     }
 
                     Document parse = Jsoup.parse(templateFile, null);
                     String attr = parse.head().attr("name");
-                    System.out.println(attr);
                     CmsTemplateEntity cmsTemplate = new CmsTemplateEntity();
-                    cmsTemplate.setCompanyId(10L);
+                    cmsTemplate.setCompanyId(companyId);
                     if (name.endsWith(".list.html")) {
                         cmsTemplate.setType(2);
                     } else if (name.endsWith(".article.html")) {
@@ -92,14 +103,32 @@
                     } else {
                         cmsTemplate.setType(1);
                     }
-                    cmsTemplate.setName(templateFile.getName());
+                    cmsTemplate.setName(StrUtil.isNotBlank(attr) ? attr : templateFile.getName());
                     cmsTemplate.setPath(templateFile.getName());
+
+                    this.baseMapper.insert(cmsTemplate);
                 }
 
             }
 
             if (".html".equals(suffix)) {
                 FileUtil.touch(file);
+
+                Document parse = Jsoup.parse(file, null);
+                String attr = parse.head().attr("name");
+                CmsTemplateEntity cmsTemplate = new CmsTemplateEntity();
+                cmsTemplate.setCompanyId(companyId);
+                if (file.getName().endsWith(".list.html")) {
+                    cmsTemplate.setType(2);
+                } else if (file.getName().endsWith(".article.html")) {
+                    cmsTemplate.setType(3);
+                } else {
+                    cmsTemplate.setType(1);
+                }
+                cmsTemplate.setName(StrUtil.isNotBlank(attr) ? attr : file.getName());
+                cmsTemplate.setPath(file.getName());
+
+                this.baseMapper.insert(cmsTemplate);
             }
         } catch (IOException e) {
             e.printStackTrace();
@@ -121,4 +150,35 @@
         Long companyId = LoginUserUtil.getCompanyId();
         this.baseMapper.delete(id, companyId);
     }
+
+    @Override
+    public Result dropdownList() {
+        Long companyId = LoginUserUtil.getCompanyId();
+        QueryWrapper<CmsTemplateEntity> objectQueryWrapper = new QueryWrapper<>();
+        objectQueryWrapper.eq("company_id",companyId);
+        List<CmsTemplateEntity> cmsTemplateEntities = this.baseMapper.selectList(objectQueryWrapper);
+        return Result.ok(cmsTemplateEntities);
+    }
+
+    @Autowired
+    private CmsProperties cmsProperties;
+
+    @Override
+    public Result viewTemplateInfo(Long id) {
+        CmsTemplateEntity cmsTemplateEntity = this.baseMapper.selectById(id);
+        String templatePath = cmsProperties.getTemplatePath();
+        String pathName = FileUtils.path(templatePath, cmsTemplateEntity.getPath());
+
+        byte[] bytes = new byte[0];
+        try {
+            bytes = Files.readAllBytes(Paths.get(pathName));
+        } catch (IOException e) {
+            e.printStackTrace();
+            return Result.ok("未找到模板");
+        }
+
+        String content = new String(bytes, StandardCharsets.UTF_8);
+        return Result.ok(content );
+    }
+
 }

--
Gitblit v1.9.1