From 7dc4502634b3b5a982a9899dbf8e36d0b016231c Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期五, 06 十二月 2024 19:31:05 +0800
Subject: [PATCH] 新增售后接口

---
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/ShoppingCartServiceImpl.java |    2 
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/RefundPassService.java            |   10 ++
 ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/model/RefundPass.java                     |    2 
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/ApplyRefundPass.java                   |   25 ++++++
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/RefundPassController.java      |  105 +++++++++++++++++++++++++
 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/RefundPassServiceImpl.java   |   50 ++++++++++++
 6 files changed, 190 insertions(+), 4 deletions(-)

diff --git a/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/model/RefundPass.java b/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/model/RefundPass.java
index 9f9db3d..5aeea6e 100644
--- a/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/model/RefundPass.java
+++ b/ruoyi-api/ruoyi-api-order/src/main/java/com/ruoyi/order/model/RefundPass.java
@@ -30,6 +30,8 @@
 
     @TableId("id")
     private Long id;
+    @TableField(exist = false)
+    private String idStr;
 
     @ApiModelProperty(value = "订单id")
     @TableField("order_id")
diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/RefundPassController.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/RefundPassController.java
index 7ac38db..2085ad3 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/RefundPassController.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/RefundPassController.java
@@ -1,8 +1,21 @@
 package com.ruoyi.order.controller;
 
 
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RestController;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.security.service.TokenService;
+import com.ruoyi.order.model.Order;
+import com.ruoyi.order.model.RefundPass;
+import com.ruoyi.order.service.OrderService;
+import com.ruoyi.order.service.RefundPassService;
+import com.ruoyi.order.vo.ApplyRefundPass;
+import io.swagger.annotations.ApiImplicitParam;
+import io.swagger.annotations.ApiImplicitParams;
+import io.swagger.annotations.ApiOperation;
+import org.springframework.web.bind.annotation.*;
+
+import javax.annotation.Resource;
+import java.util.Arrays;
 
 /**
  * <p>
@@ -16,5 +29,93 @@
 @RequestMapping("/refund-pass")
 public class RefundPassController {
 
+
+	@Resource
+	private RefundPassService refundPassService;
+	
+	@Resource
+	private TokenService tokenService;
+	
+	@Resource
+	private OrderService orderService;
+	
+	
+	@ResponseBody
+	@PostMapping("/applyRefundPass")
+	@ApiOperation(value = "售后申请", tags = {"我的订单-个人中心-小程序"})
+	public R applyRefundPass(@RequestBody ApplyRefundPass applyRefundPass){
+		return refundPassService.applyRefundPass(applyRefundPass);
+	}
+	
+	@ResponseBody
+	@GetMapping("/getRefundPass/{orderId}")
+	@ApiOperation(value = "获取售后详情", tags = {"我的订单-个人中心-小程序"})
+	@ApiImplicitParams({
+			@ApiImplicitParam(name = "orderId", value = "订单id", required = true, dataType = "long"),
+	})
+	public R<RefundPass> getRefundPass(@PathVariable("orderId") Long orderId){
+		Long userid = tokenService.getLoginUserApplet().getUserid();
+		Order order = orderService.getById(orderId);
+		if(!order.getAppUserId().equals(userid)){
+			return R.fail("权限不足");
+		}
+		RefundPass one = refundPassService.getOne(new LambdaQueryWrapper<RefundPass>().eq(RefundPass::getOrderId, orderId)
+				.eq(RefundPass::getDelFlag, 0).last(" order by createTime desc limit 0,1"));
+		one.setIdStr(one.getId().toString());
+		return R.ok(one);
+	}
+	
+	
+	@ResponseBody
+	@PutMapping("/cancelRefundPass/{id}")
+	@ApiOperation(value = "取消售后", tags = {"我的订单-个人中心-小程序"})
+	@ApiImplicitParams({
+			@ApiImplicitParam(name = "id", value = "售后数据id", required = true, dataType = "long"),
+	})
+	public R cancelRefundPass(@PathVariable("id") Long id){
+		RefundPass refundPass = refundPassService.getById(id);
+		if(null == refundPass){
+			return R.fail();
+		}
+		Long userid = tokenService.getLoginUserApplet().getUserid();
+		Order order = orderService.getById(refundPass.getOrderId());
+		if(!order.getAppUserId().equals(userid)){
+			return R.fail("权限不足");
+		}
+		if(Arrays.asList(2, 3).contains(refundPass.getStatus())){
+			return R.fail("售后取消失败");
+		}
+		refundPass.setDelFlag(1);
+		refundPassService.updateById(refundPass);
+		order.setOrderStatus(4);
+		orderService.updateById(order);
+		return R.ok();
+	}
+	
+	
+	@ResponseBody
+	@PutMapping("/deliverGoodsRefundPass/{id}")
+	@ApiOperation(value = "售后已发货操作", tags = {"我的订单-个人中心-小程序"})
+	@ApiImplicitParams({
+			@ApiImplicitParam(name = "id", value = "售后数据id", required = true, dataType = "long"),
+	})
+	public R deliverGoodsRefundPass(@PathVariable("id") Long id){
+		RefundPass refundPass = refundPassService.getById(id);
+		if(null == refundPass){
+			return R.fail();
+		}
+		Long userid = tokenService.getLoginUserApplet().getUserid();
+		Order order = orderService.getById(refundPass.getOrderId());
+		if(!order.getAppUserId().equals(userid)){
+			return R.fail("权限不足");
+		}
+		if(4 != refundPass.getStatus()){
+			return R.fail("操作失败");
+		}
+		refundPass.setStatus(5);
+		refundPassService.updateById(refundPass);
+		return R.ok();
+	}
+	
 }
 
diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/RefundPassService.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/RefundPassService.java
index 57f8f22..d771ad7 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/RefundPassService.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/RefundPassService.java
@@ -1,7 +1,10 @@
 package com.ruoyi.order.service;
 
 import com.baomidou.mybatisplus.extension.service.IService;
+import com.ruoyi.common.core.domain.R;
 import com.ruoyi.order.model.RefundPass;
+import com.ruoyi.order.vo.ApplyRefundPass;
+import org.springframework.web.bind.annotation.RequestBody;
 
 /**
  * <p>
@@ -12,5 +15,12 @@
  * @since 2024-11-21
  */
 public interface RefundPassService extends IService<RefundPass> {
+	
+	/**
+	 * 申请售后
+	 * @param applyRefundPass
+	 * @return
+	 */
+	R applyRefundPass(ApplyRefundPass applyRefundPass);
 
 }
diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/RefundPassServiceImpl.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/RefundPassServiceImpl.java
index e729de4..a06c6bb 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/RefundPassServiceImpl.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/RefundPassServiceImpl.java
@@ -1,10 +1,19 @@
 package com.ruoyi.order.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.core.domain.R;
 import com.ruoyi.order.mapper.RefundPassMapper;
+import com.ruoyi.order.model.Order;
 import com.ruoyi.order.model.RefundPass;
+import com.ruoyi.order.service.OrderService;
 import com.ruoyi.order.service.RefundPassService;
+import com.ruoyi.order.vo.ApplyRefundPass;
 import org.springframework.stereotype.Service;
+
+import javax.annotation.Resource;
+import java.time.LocalDateTime;
+import java.time.ZoneOffset;
 
 /**
  * <p>
@@ -16,5 +25,44 @@
  */
 @Service
 public class RefundPassServiceImpl extends ServiceImpl<RefundPassMapper, RefundPass> implements RefundPassService {
-
+	
+	@Resource
+	private OrderService orderService;
+	
+	
+	/**
+	 * 申请售后
+	 * @param applyRefundPass
+	 * @return
+	 */
+	@Override
+	public R applyRefundPass(ApplyRefundPass applyRefundPass) {
+		RefundPass one = this.getOne(new LambdaQueryWrapper<RefundPass>().eq(RefundPass::getOrderId, applyRefundPass.getId()).eq(RefundPass::getDelFlag, 0)
+				.ne(RefundPass::getStatus, 3));
+		if(null != one){
+			return R.fail("不能重复提交售后");
+		}
+		Order order = orderService.getById(applyRefundPass.getId());
+		//判断是都已经超过售后时间
+		LocalDateTime afterSaleTime = order.getAfterSaleTime();
+		if(null != afterSaleTime && afterSaleTime.toEpochSecond(ZoneOffset.UTC) < LocalDateTime.now().toEpochSecond(ZoneOffset.UTC)){
+			return R.fail("已超过售后期间");
+		}
+		
+		//构建售后申请数据
+		RefundPass refundPass = new RefundPass();
+		refundPass.setOrderId(applyRefundPass.getId());
+		refundPass.setStatus(1);
+		refundPass.setRefundMethod(applyRefundPass.getRefundMethod());
+		refundPass.setRefundReason(applyRefundPass.getRefundReason());
+		refundPass.setUserRemark(applyRefundPass.getUserRemark());
+		refundPass.setPics(applyRefundPass.getPics());
+		refundPass.setPassStatus(1);
+		refundPass.setDelFlag(0);
+		refundPass.setCreateTime(LocalDateTime.now());
+		this.save(refundPass);
+		order.setOrderStatus(7);
+		orderService.updateById(order);
+		return R.ok();
+	}
 }
diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/ShoppingCartServiceImpl.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/ShoppingCartServiceImpl.java
index 23e1522..ac40b11 100644
--- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/ShoppingCartServiceImpl.java
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/ShoppingCartServiceImpl.java
@@ -530,7 +530,7 @@
 			goodsShop.setGoodsId(shoppingCart.getGoodsId());
 			goodsShop.setShopId(shopId);
 			GoodsShop goodsShop1 = goodsShopClient.getGoodsShop(goodsShop).getData();
-			vo.setVerifiable(null == goodsShop1 ? false : true);
+			vo.setVerifiable(goods.getAppointStore() == 1 && null == goodsShop1 ? false : true);
 			//判断当前数量是否已经超出限购数量(需要计算已经购买的数量)
 			if(null == goods.getPurchaseLimit() || -1 == goods.getPurchaseLimit()){
 				vo.setPurchaseLimit(false);
diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/ApplyRefundPass.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/ApplyRefundPass.java
new file mode 100644
index 0000000..651cd12
--- /dev/null
+++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/ApplyRefundPass.java
@@ -0,0 +1,25 @@
+package com.ruoyi.order.vo;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+/**
+ * @author zhibing.pu
+ * @Date 2024/12/6 18:30
+ */
+@Data
+@ApiModel
+public class ApplyRefundPass {
+	@ApiModelProperty(value = "订单id", required = true)
+	private Long id;
+	@ApiModelProperty(value = "售后类型(1=退货退款,2=仅退款)", required = true)
+	private Integer refundMethod;
+	@ApiModelProperty(value = "申请原因", required = true)
+	private String refundReason;
+	@ApiModelProperty(value = "备注", required = true)
+	private String userRemark;
+	@ApiModelProperty(value = "图片地址,多个逗号分隔", required = true)
+	private String pics;
+	
+}

--
Gitblit v1.7.1