From d51a8cfa10c34d9c1e7d6b4726d31e75ecee5dc6 Mon Sep 17 00:00:00 2001
From: phpcjl <phpcjl@gmail.com>
Date: 星期五, 20 十二月 2024 18:32:03 +0800
Subject: [PATCH] 1

---
 ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/GoodsEvaluateServiceImpl.java |   42 ++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 42 insertions(+), 0 deletions(-)

diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/GoodsEvaluateServiceImpl.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/GoodsEvaluateServiceImpl.java
index 04203e5..1d047e0 100644
--- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/GoodsEvaluateServiceImpl.java
+++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/service/impl/GoodsEvaluateServiceImpl.java
@@ -1,10 +1,22 @@
 package com.ruoyi.other.service.impl;
 
+import cn.hutool.core.collection.CollectionUtil;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.utils.StringUtils;
+import com.ruoyi.common.security.service.TokenService;
+import com.ruoyi.order.feignClient.RemoteOrderGoodsClient;
+import com.ruoyi.order.model.Order;
 import com.ruoyi.other.mapper.GoodsEvaluateMapper;
 import com.ruoyi.other.api.domain.GoodsEvaluate;
 import com.ruoyi.other.service.GoodsEvaluateService;
+import com.ruoyi.other.vo.GoodsEvaluateVO;
+import com.ruoyi.system.api.model.LoginUser;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import javax.annotation.Resource;
+import java.util.List;
 
 /**
  * <p>
@@ -16,5 +28,35 @@
  */
 @Service
 public class GoodsEvaluateServiceImpl extends ServiceImpl<GoodsEvaluateMapper, GoodsEvaluate> implements GoodsEvaluateService {
+    @Resource
+    private RemoteOrderGoodsClient remoteOrderGoodsClient;
+    @Resource
+    private TokenService tokenService;
 
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public void addGoodsEvaluate(GoodsEvaluateVO goodsEvaluateVO) {
+        List<GoodsEvaluate> evaluates = goodsEvaluateVO.getEvaluates();
+        for (GoodsEvaluate goodsEvaluate : evaluates) {
+            goodsEvaluate.setStatus(2);
+            if (StringUtils.isNotEmpty(goodsEvaluate.getIdStr())){
+                goodsEvaluate.setId(Long.valueOf(goodsEvaluate.getIdStr()));
+                updateById(goodsEvaluate);
+            }else {
+                LoginUser loginUserApplet = tokenService.getLoginUserApplet();
+                goodsEvaluate.setAppUserId(loginUserApplet.getUserid());
+                save(goodsEvaluate);
+            }
+        }
+        if (CollectionUtil.isNotEmpty(evaluates)){
+            Order order = new Order();
+            order.setId(goodsEvaluateVO.getEvaluates().get(0).getOrderId());
+            order.setOrderStatus(8);
+            R<Void> r = remoteOrderGoodsClient.updateOrderStatus(order);
+            if (R.isError(r)){
+                throw new RuntimeException("修改订单状态失败");
+            }
+        }
+
+    }
 }

--
Gitblit v1.7.1