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/controller/RefundPassController.java |  105 +++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 103 insertions(+), 2 deletions(-)

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();
+	}
+	
 }
 

--
Gitblit v1.7.1