From 07882a44365a0621640fdc646ffb8df55c46d80c Mon Sep 17 00:00:00 2001 From: phpcjl <phpcjl@gmail.com> Date: 星期三, 18 十二月 2024 16:33:25 +0800 Subject: [PATCH] 1 --- ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/controller/ShoppingCartController.java | 61 +++++++++++++++++++++++++++++- 1 files changed, 59 insertions(+), 2 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 9f04e77..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.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 com.ruoyi.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") @@ -25,6 +38,13 @@ @Resource private TokenService tokenService; + + @Resource + private GoodsShopClient goodsShopClient; + @Resource + private ShopClient shopClient; + @Resource + private AppUserClient appUserClient; @@ -88,9 +108,46 @@ @ResponseBody @PostMapping("/shoppingCartPayment") @ApiOperation(value = "购物车订单支付", tags = {"商城-购物车-小程序"}) - public R<Void> shoppingCartPayment(@RequestBody ShoppingCartPayment shoppingCartPayment){ + 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