From e49e4c4284a7c390f605fb0e8c4d2c590ba20020 Mon Sep 17 00:00:00 2001
From: peng <peng.com>
Date: 星期四, 16 十月 2025 13:48:26 +0800
Subject: [PATCH] 模板修改

---
 seller-api/src/main/java/cn/lili/controller/order/OrderStoreController.java                     |   16 ++++++++
 framework/src/main/java/cn/lili/modules/lmk/service/impl/GoodsCustomizeTemplateServiceImpl.java |   59 ++++++++++++++++++++++++++++-
 framework/src/main/java/cn/lili/modules/lmk/service/GoodsCustomizeTemplateService.java          |    7 +++
 3 files changed, 79 insertions(+), 3 deletions(-)

diff --git a/framework/src/main/java/cn/lili/modules/lmk/service/GoodsCustomizeTemplateService.java b/framework/src/main/java/cn/lili/modules/lmk/service/GoodsCustomizeTemplateService.java
index acd40ca..d8c2c4d 100644
--- a/framework/src/main/java/cn/lili/modules/lmk/service/GoodsCustomizeTemplateService.java
+++ b/framework/src/main/java/cn/lili/modules/lmk/service/GoodsCustomizeTemplateService.java
@@ -2,10 +2,13 @@
 
 import cn.lili.modules.lmk.domain.entity.GoodsCustomizeTemplate;
 import cn.lili.modules.lmk.domain.vo.GoodsCustomizeTemplateVO;
+import cn.lili.modules.order.cart.entity.vo.BindingTemplateParam;
 import com.baomidou.mybatisplus.extension.service.IService;
 import cn.lili.base.Result;
 import cn.lili.modules.lmk.domain.form.GoodsCustomizeTemplateForm;
 import cn.lili.modules.lmk.domain.query.GoodsCustomizeTemplateQuery;
+import org.springframework.web.bind.annotation.RequestBody;
+
 import java.util.List;
 
 /**
@@ -68,5 +71,9 @@
 
     Result getCustomizeTemplate(String id);
 
+    Result getCustomizeTemplateById(String id);
+
+    Result editTemplate(BindingTemplateParam bindingTemplateParam);
+
     Result changeStatus(String id);
 }
diff --git a/framework/src/main/java/cn/lili/modules/lmk/service/impl/GoodsCustomizeTemplateServiceImpl.java b/framework/src/main/java/cn/lili/modules/lmk/service/impl/GoodsCustomizeTemplateServiceImpl.java
index 9e38933..bd1a200 100644
--- a/framework/src/main/java/cn/lili/modules/lmk/service/impl/GoodsCustomizeTemplateServiceImpl.java
+++ b/framework/src/main/java/cn/lili/modules/lmk/service/impl/GoodsCustomizeTemplateServiceImpl.java
@@ -1,7 +1,8 @@
 package cn.lili.modules.lmk.service.impl;
 
-import cn.lili.modules.lmk.domain.entity.TemplateConstomizeTitle;
-import cn.lili.modules.lmk.domain.entity.TemplateImgs;
+import cn.lili.common.enums.ResultUtil;
+import cn.lili.modules.lmk.domain.entity.*;
+import cn.lili.modules.lmk.domain.form.CustomizeTemplateForm;
 import cn.lili.modules.lmk.enums.general.EnableStatusEnums;
 import cn.lili.modules.lmk.service.TemplateConstomizeTitleService;
 import cn.lili.modules.lmk.service.TemplateImgsService;
@@ -10,12 +11,15 @@
 import cn.lili.modules.goods.service.GoodsSkuService;
 import cn.lili.modules.lmk.domain.entity.TemplateImgs;
 import cn.lili.modules.lmk.domain.vo.CustomizeTemplateVO;
+import cn.lili.modules.lmk.service.UserCheckTemplateService;
+import cn.lili.modules.order.cart.entity.vo.BindingTemplateParam;
 import cn.lili.utils.COSUtil;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
-import cn.lili.modules.lmk.domain.entity.GoodsCustomizeTemplate;
 import cn.lili.modules.lmk.mapper.GoodsCustomizeTemplateMapper;
 import cn.lili.modules.lmk.service.GoodsCustomizeTemplateService;
 import cn.lili.base.Result;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import cn.lili.modules.lmk.domain.form.GoodsCustomizeTemplateForm;
@@ -29,6 +33,7 @@
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.Assert;
 
+import java.util.ArrayList;
 import java.util.List;
 import java.util.stream.Collectors;
 
@@ -47,6 +52,7 @@
     private final TemplateImgsService templateImgsService;
     private final TemplateConstomizeTitleService templateConstomizeTitleService;
     private final GoodsSkuService goodsSkuService;
+    private final UserCheckTemplateService userCheckTemplateService;
 
     private final COSUtil cosUtil;
     /**
@@ -240,6 +246,23 @@
     }
 
     @Override
+    public Result getCustomizeTemplateById(String id) {
+        CustomizeTemplateVO customizeTemplate = baseMapper.getCustomizeTemplate(id);
+        if (customizeTemplate != null) {
+            List<TemplateImgs> templateImgs = customizeTemplate.getTemplateImgs();
+            if (!templateImgs.isEmpty()) {
+                for (TemplateImgs templateImg : templateImgs) {
+                    String imgUrl = templateImg.getImgUrl();
+                    if (StringUtils.isNotBlank(imgUrl)&&!imgUrl.contains("http")) {
+                        templateImg.setImgUrl(cosUtil.getPreviewUrl(imgUrl));
+                    }
+                }
+            }
+        }
+        return Result.ok().data(customizeTemplate);
+    }
+
+    @Override
     public Result getCustomizeTemplate(String id) {
         GoodsSku goodsSku = goodsSkuService.getById(id);
         String templateId = goodsSku.getCustomizeTemplateId();
@@ -257,4 +280,34 @@
         }
         return Result.ok().data(customizeTemplate);
     }
+
+    @Override
+    @Transactional
+    public Result editTemplate(BindingTemplateParam bindingTemplateParam) {
+        LambdaQueryWrapper<UserCheckTemplate> del = Wrappers.<UserCheckTemplate>lambdaQuery();
+        del.eq(UserCheckTemplate::getOrderSn,bindingTemplateParam.getSn())
+                .eq(UserCheckTemplate::getTemplateId,bindingTemplateParam.getTemplateId());
+        userCheckTemplateService.remove(del);
+        //瀹氬埗鍟嗗搧鐗规畩澶勭悊
+        if (StringUtils.isNotBlank(bindingTemplateParam.getTemplateId())){
+            List<CustomizeTemplateForm> templateForm = bindingTemplateParam.getTemplateForm();
+            List<UserCheckTemplate> customizeTemplateForms = new ArrayList<>();
+            for (CustomizeTemplateForm customizeTemplateForm : templateForm) {
+                UserCheckTemplate userCheckTemplate = new UserCheckTemplate();
+                userCheckTemplate.setContentType(customizeTemplateForm.getContentType());
+                userCheckTemplate.setChooseImg(bindingTemplateParam.getChooseImage());
+                userCheckTemplate.setChooseImgId(bindingTemplateParam.getChooseImageId());
+                userCheckTemplate.setTemplateName(bindingTemplateParam.getTemplateName());
+                userCheckTemplate.setTemplateId(bindingTemplateParam.getTemplateId());
+                userCheckTemplate.setOrderSn(bindingTemplateParam.getSn());
+                userCheckTemplate.setSubId(customizeTemplateForm.getId());
+                userCheckTemplate.setSubName(customizeTemplateForm.getTemplateTitle());
+                userCheckTemplate.setContent(customizeTemplateForm.getValue());
+                customizeTemplateForms.add(userCheckTemplate);
+            }
+            userCheckTemplateService.saveBatch(customizeTemplateForms);
+
+        }
+        return Result.ok();
+    }
 }
diff --git a/seller-api/src/main/java/cn/lili/controller/order/OrderStoreController.java b/seller-api/src/main/java/cn/lili/controller/order/OrderStoreController.java
index f7922d8..ce4e681 100644
--- a/seller-api/src/main/java/cn/lili/controller/order/OrderStoreController.java
+++ b/seller-api/src/main/java/cn/lili/controller/order/OrderStoreController.java
@@ -2,6 +2,7 @@
 
 import cn.hutool.core.convert.Convert;
 import cn.hutool.core.util.NumberUtil;
+import cn.lili.base.Result;
 import cn.lili.common.aop.annotation.PreventDuplicateSubmissions;
 import cn.lili.common.context.ThreadContextHolder;
 import cn.lili.common.enums.ResultCode;
@@ -11,9 +12,11 @@
 import cn.lili.common.utils.StringUtils;
 import cn.lili.common.vo.ResultMessage;
 import cn.lili.modules.lmk.domain.entity.UserCheckTemplate;
+import cn.lili.modules.lmk.service.GoodsCustomizeTemplateService;
 import cn.lili.modules.lmk.service.UserCheckTemplateService;
 import cn.lili.modules.member.entity.dto.MemberAddressDTO;
 import cn.lili.modules.member.service.StoreLogisticsService;
+import cn.lili.modules.order.cart.entity.vo.BindingTemplateParam;
 import cn.lili.modules.order.order.entity.dto.OrderSearchParams;
 import cn.lili.modules.order.order.entity.dto.PartDeliveryParamsDTO;
 import cn.lili.modules.order.order.entity.vo.OrderDetailVO;
@@ -80,6 +83,8 @@
 
     @Autowired
     private UserCheckTemplateService userCheckTemplateService;
+    @Autowired
+    private GoodsCustomizeTemplateService goodsCustomizeTemplateService;
 
     @Autowired
     private COSUtil cosUtil;
@@ -286,4 +291,15 @@
         orderService.updateSellerRemark(orderSn, sellerRemark);
         return ResultUtil.success();
     }
+
+    @ApiOperation(value = "瀹氬埗鍟嗗搧鑾峰彇妯℃澘淇℃伅")
+    @GetMapping(value = "/getTemplate/{templateId}")
+    public Result getTemplate(@PathVariable String templateId) {
+        return goodsCustomizeTemplateService.getCustomizeTemplateById(templateId);
+    }
+    @ApiOperation(value = "淇敼瀹氬埗鍟嗗搧鑾峰彇妯℃澘淇℃伅")
+    @PostMapping(value = "/edit/template")
+    public Result editTemplate(@RequestBody BindingTemplateParam bindingTemplateParam) {
+        return goodsCustomizeTemplateService.editTemplate(bindingTemplateParam);
+    }
 }
\ No newline at end of file

--
Gitblit v1.8.0