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-order/src/main/java/com/ruoyi/order/controller/ShoppingCartController.java | 97 ++++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 88 insertions(+), 9 deletions(-) diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/ShoppingCartController.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/ShoppingCartController.java index aeaa5dc..b9be064 100644 --- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/ShoppingCartController.java +++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/ShoppingCartController.java @@ -1,19 +1,32 @@ package com.ruoyi.order.controller; +import cn.hutool.core.collection.CollectionUtil; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.ruoyi.account.api.feignClient.AppUserClient; +import com.ruoyi.account.api.model.AppUser; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.web.controller.BaseController; -import com.ruoyi.common.core.web.domain.AjaxResult; import com.ruoyi.common.core.web.page.TableDataInfo; +import com.ruoyi.common.security.service.TokenService; import com.ruoyi.order.service.ShoppingCartService; import com.ruoyi.order.vo.*; +import com.ruoyi.other.api.domain.GoodsShop; +import com.ruoyi.other.api.domain.Shop; +import com.ruoyi.other.api.feignClient.GoodsShopClient; +import com.ruoyi.other.api.feignClient.ShopClient; +import com.ruoyi.other.api.vo.GetGoodsShopByGoodsIds; +import com.ruoyi.system.api.model.LoginUser; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; -import model.ShoppingCart; +import com.ruoyi.order.model.ShoppingCart; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; +import java.util.ArrayList; +import java.util.List; +import java.util.stream.Collectors; @RestController @RequestMapping("/shopping-cart") @@ -22,6 +35,19 @@ @Resource private ShoppingCartService shoppingCartService; + + @Resource + private TokenService tokenService; + + @Resource + private GoodsShopClient goodsShopClient; + @Resource + private ShopClient shopClient; + @Resource + private AppUserClient appUserClient; + + + @ResponseBody @@ -47,27 +73,80 @@ @ResponseBody @PostMapping("/setGoodsNumber") @ApiOperation(value = "修改购物车数量", tags = {"商城-购物车-小程序"}) - public AjaxResult setGoodsNumber(@RequestBody SetGoodsNumber setGoodsNumber){ + public R setGoodsNumber(@RequestBody SetGoodsNumber setGoodsNumber){ return shoppingCartService.setGoodsNumber(setGoodsNumber); } @ResponseBody + @DeleteMapping("/delShoppingCart") + @ApiOperation(value = "删除购物车", tags = {"商城-购物车-小程序"}) + public R delShoppingCart(Long id){ + Long userid = tokenService.getLoginUserApplet().getUserid(); + ShoppingCart shoppingCart = shoppingCartService.getById(id); + if(!userid.equals(shoppingCart.getAppUserId())){ + return R.fail("权限不足,不允许此操作"); + } + shoppingCartService.removeById(id); + return R.ok(); + } + + + + + + @ResponseBody @PostMapping("/confirmOrder") @ApiOperation(value = "确定购物车订单", tags = {"商城-购物车-小程序"}) - public AjaxResult<ConfirmOrderVo> confirmOrder(@RequestBody ConfirmOrder confirmOrder){ - // todo 待完善 pu - return AjaxResult.success(); + public R<ConfirmOrderVo> confirmOrder(@RequestBody ConfirmOrder confirmOrder){ + ConfirmOrderVo confirmOrderVo = shoppingCartService.confirmOrder(confirmOrder); + return R.ok(confirmOrderVo); } @ResponseBody @PostMapping("/shoppingCartPayment") @ApiOperation(value = "购物车订单支付", tags = {"商城-购物车-小程序"}) - public AjaxResult<Void> shoppingCartPayment(@RequestBody ShoppingCartPayment shoppingCartPayment){ - // todo 待完善 pu - return AjaxResult.success(); + public R<String> shoppingCartPayment(@RequestBody ShoppingCartPayment shoppingCartPayment){ + return shoppingCartService.shoppingCartPayment(shoppingCartPayment); + } + + + @ResponseBody + @GetMapping("/getVerifiableShop") + @ApiOperation(value = "获取可核销门店列表", tags = {"购物车-小程序"}) + public R<List<VerifiableShopVo>> getVerifiableShop(){ + LoginUser loginUser = tokenService.getLoginUserApplet(); + List<ShoppingCart> shoppingCarts = shoppingCartService.list(new LambdaQueryWrapper<ShoppingCart>() + .eq(ShoppingCart::getAppUserId, loginUser.getUserid())); + + List<Integer> goodsIds = shoppingCarts.stream().map(ShoppingCart::getGoodsId).collect(Collectors.toList()); + GetGoodsShopByGoodsIds goodsShopByGoodsIds = new GetGoodsShopByGoodsIds(); + goodsShopByGoodsIds.setGoodsIds(goodsIds); + R<List<GoodsShop>> r = goodsShopClient.getGoodsShopByGoodsIds(goodsShopByGoodsIds); + List<GoodsShop> goodsShops = r.getData(); + List<VerifiableShopVo> verifiableShopVoList = new ArrayList<>(); + if (CollectionUtil.isNotEmpty(goodsShops)){ + for (GoodsShop goodsShop : goodsShops) { + R<Shop> shopR = shopClient.getShopById(goodsShop.getShopId()); + if (R.isSuccess(shopR)){ + VerifiableShopVo verifiableShopVo = new VerifiableShopVo(); + verifiableShopVo.setId(shopR.getData().getId()); + verifiableShopVo.setName(shopR.getData().getName()); + verifiableShopVoList.add(verifiableShopVo); + } + } + } + return R.ok(verifiableShopVoList); + } + + + @GetMapping("/getGoodsPrice") + public R<Price> getGoodsPrice(Long appUserId, Integer goodsId, Integer shopId){ + AppUser appUser = appUserClient.getAppUserById(appUserId); + Price price = shoppingCartService.getPrice(appUser, goodsId, shopId); + return R.ok(price); } -- Gitblit v1.7.1