From e68c33e84e7f85fe8504de9c105d8597b996a906 Mon Sep 17 00:00:00 2001 From: Pu Zhibing <393733352@qq.com> Date: 星期一, 02 十二月 2024 18:05:08 +0800 Subject: [PATCH] 完成购物车支付业务逻辑 --- ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserCouponClient.java | 10 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/ShoppingCartPayment.java | 4 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/UserPoint.java | 6 ruoyi-api/ruoyi-api-order/src/main/java/model/Order.java | 4 ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/domain/Goods.java | 2 ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/feignClient/GoodsShopClient.java | 11 ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserPointController.java | 18 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserCouponClientFallbackFactory.java | 5 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/AppUser.java | 14 ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserAddressController.java | 14 ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/UserCouponService.java | 2 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/BalanceChangeRecordClientFallbackFactory.java | 23 + ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsShopController.java | 13 ruoyi-api/ruoyi-api-order/src/main/java/model/OrderGood.java | 48 ++ ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/factory/GoodsShopClientFallbackFactory.java | 8 ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/AppUserServiceImpl.java | 18 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserPointClient.java | 26 + ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserAddressClientFallbackFactory.java | 5 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserPointFallbackFactory.java | 22 + ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/service/impl/ShoppingCartServiceImpl.java | 550 +++++++++++++++++++++++++++++++ ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/BalanceChangeRecordController.java | 37 ++ ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/UserCouponServiceImpl.java | 27 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserAddressClient.java | 9 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/BalanceChangeRecord.java | 2 ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/MyShoppingCartVo.java | 42 ++ ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/vo/PaymentUserCouponVo.java | 3 ruoyi-api/ruoyi-api-account/src/main/resources/META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports | 4 ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/BalanceChangeRecordClient.java | 26 + ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserCouponController.java | 19 + ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/vo/GetGoodsShopByGoodsIds.java | 21 + 30 files changed, 933 insertions(+), 60 deletions(-) diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/BalanceChangeRecordClientFallbackFactory.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/BalanceChangeRecordClientFallbackFactory.java new file mode 100644 index 0000000..7471ade --- /dev/null +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/BalanceChangeRecordClientFallbackFactory.java @@ -0,0 +1,23 @@ +package com.ruoyi.account.api.factory; + +import com.ruoyi.account.api.feignClient.BalanceChangeRecordClient; +import com.ruoyi.account.api.model.BalanceChangeRecord; +import com.ruoyi.common.core.domain.R; +import org.springframework.cloud.openfeign.FallbackFactory; + +/** + * @author zhibing.pu + * @Date 2024/12/2 15:35 + */ +public class BalanceChangeRecordClientFallbackFactory implements FallbackFactory<BalanceChangeRecordClient> { + @Override + public BalanceChangeRecordClient create(Throwable cause) { + return new BalanceChangeRecordClient(){ + + @Override + public R saveBalanceChangeRecord(BalanceChangeRecord balanceChangeRecord) { + return R.fail("保存账户流水记录失败:" + cause.getMessage()); + } + }; + } +} diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserAddressClientFallbackFactory.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserAddressClientFallbackFactory.java index 64c54a1..f6b2f98 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserAddressClientFallbackFactory.java +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserAddressClientFallbackFactory.java @@ -18,6 +18,11 @@ public R<UserAddress> getDefaultUserAddress(Long userId) { return R.fail("获取用户默认地址失败:" + cause.getMessage()); } + + @Override + public R<UserAddress> getUserAddressById(Integer id) { + return R.fail("根据id获取用户地址信息失败:" + cause.getMessage()); + } }; } } diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserCouponClientFallbackFactory.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserCouponClientFallbackFactory.java index 18a31cc..1ab202f 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserCouponClientFallbackFactory.java +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserCouponClientFallbackFactory.java @@ -22,6 +22,11 @@ public R<List<PaymentUserCouponVo>> getPaymentUserCoupon(PaymentUserCoupon paymentUserCoupon) { return R.fail("根据id获取优惠券数据失败:" + cause.getMessage()); } + + @Override + public R<CouponInfoVo> getCouponInfo(Long userCouponId) { + return R.fail("根据用户优惠券id获取优惠券详情失败:" + cause.getMessage()); + } }; } } diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserPointFallbackFactory.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserPointFallbackFactory.java new file mode 100644 index 0000000..96ac46e --- /dev/null +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/factory/UserPointFallbackFactory.java @@ -0,0 +1,22 @@ +package com.ruoyi.account.api.factory; + +import com.ruoyi.account.api.feignClient.UserPointClient; +import com.ruoyi.account.api.model.UserPoint; +import com.ruoyi.common.core.domain.R; +import org.springframework.cloud.openfeign.FallbackFactory; + +/** + * @author zhibing.pu + * @Date 2024/12/2 15:04 + */ +public class UserPointFallbackFactory implements FallbackFactory<UserPointClient> { + @Override + public UserPointClient create(Throwable cause) { + return new UserPointClient() { + @Override + public R saveUserPoint(UserPoint userPoint) { + return R.fail("保存积分流水记录失败:" + cause.getMessage()); + } + }; + } +} diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/BalanceChangeRecordClient.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/BalanceChangeRecordClient.java new file mode 100644 index 0000000..3722e49 --- /dev/null +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/BalanceChangeRecordClient.java @@ -0,0 +1,26 @@ +package com.ruoyi.account.api.feignClient; + +import com.ruoyi.account.api.factory.BalanceChangeRecordClientFallbackFactory; +import com.ruoyi.account.api.model.BalanceChangeRecord; +import com.ruoyi.common.core.constant.ServiceNameConstants; +import com.ruoyi.common.core.domain.R; +import org.springframework.cloud.openfeign.FeignClient; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; + +/** + * @author zhibing.pu + * @Date 2024/12/2 15:34 + */ +@FeignClient(contextId = "BalanceChangeRecordClient", value = ServiceNameConstants.ACCOUNT_SERVICE, fallbackFactory = BalanceChangeRecordClientFallbackFactory.class) +public interface BalanceChangeRecordClient { + + + /** + * 保存账户流水记录 + * @param balanceChangeRecord + * @return + */ + @PostMapping("/balanceChangeRecord/saveBalanceChangeRecord") + R saveBalanceChangeRecord(@RequestBody BalanceChangeRecord balanceChangeRecord); +} diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserAddressClient.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserAddressClient.java index 261c662..90ce1db 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserAddressClient.java +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserAddressClient.java @@ -22,4 +22,13 @@ */ @PostMapping("/user-address/getDefaultUserAddress") R<UserAddress> getDefaultUserAddress(@RequestParam("userId") Long userId); + + + /** + * 根据id获取用户地址信息 + * @param id + * @return + */ + @PostMapping("/user-address/getUserAddressById") + R<UserAddress> getUserAddressById(@RequestParam("id") Integer id); } diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserCouponClient.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserCouponClient.java index a5ffd14..84b2d1c 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserCouponClient.java +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserCouponClient.java @@ -9,6 +9,7 @@ import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RequestParam; import java.util.List; @@ -26,4 +27,13 @@ */ @PostMapping("/user-coupon/getPaymentUserCoupon") R<List<PaymentUserCouponVo>> getPaymentUserCoupon(@RequestBody PaymentUserCoupon paymentUserCoupon); + + + /** + * 根据用户优惠券id获取优惠券详情 + * @param userCouponId + * @return + */ + @PostMapping("/user-coupon/getCouponInfo") + R<CouponInfoVo> getCouponInfo(@RequestParam("userCouponId") Long userCouponId); } diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserPointClient.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserPointClient.java new file mode 100644 index 0000000..c7af699 --- /dev/null +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/feignClient/UserPointClient.java @@ -0,0 +1,26 @@ +package com.ruoyi.account.api.feignClient; + +import com.ruoyi.account.api.factory.UserPointFallbackFactory; +import com.ruoyi.account.api.model.UserPoint; +import com.ruoyi.common.core.constant.ServiceNameConstants; +import com.ruoyi.common.core.domain.R; +import org.springframework.cloud.openfeign.FeignClient; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; + +/** + * @author zhibing.pu + * @Date 2024/12/2 15:04 + */ +@FeignClient(contextId = "UserPointClient", value = ServiceNameConstants.ACCOUNT_SERVICE, fallbackFactory = UserPointFallbackFactory.class) +public interface UserPointClient { + + /** + * 保存积分流水记录 + * @param userPoint + * @return + */ + @PostMapping("/user-point/saveUserPoint") + R saveUserPoint(@RequestBody UserPoint userPoint); + +} diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/AppUser.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/AppUser.java index 026c52b..078ec05 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/AppUser.java +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/AppUser.java @@ -100,19 +100,19 @@ @ApiModelProperty(value = "合伙人积分数") @TableField("part_point") - private BigDecimal partPoint; + private Integer partPoint; @ApiModelProperty(value = "合伙人培育积分数") @TableField("part_grow_point") - private BigDecimal partGrowPoint; + private Integer partGrowPoint; @ApiModelProperty(value = "消费积分数") @TableField("shop_point") - private BigDecimal shopPoint; + private Integer shopPoint; @ApiModelProperty(value = "返佣积分数") @TableField("share_point") - private BigDecimal sharePoint; + private Integer sharePoint; @ApiModelProperty(value = "消费总金额") @TableField("shop_amount") @@ -142,9 +142,13 @@ @TableField("total_distribution_amount") private BigDecimal totalDistributionAmount; + @ApiModelProperty(value = "账户余额") + @TableField("balance") + private BigDecimal balance; + @ApiModelProperty(value = "剩余积分") @TableField("lave_point") - private BigDecimal lavePoint; + private Integer lavePoint; @ApiModelProperty(value = "是否可更换推广人(0=否,1=是)") @TableField("change_promoter") diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/BalanceChangeRecord.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/BalanceChangeRecord.java index 8de1bfd..9792ae1 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/BalanceChangeRecord.java +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/BalanceChangeRecord.java @@ -31,7 +31,7 @@ private Long orderId; @ApiModelProperty("类型:1充值2提现3红包4分佣5商城购物") - private Integer type; + private Integer changeType; @ApiModelProperty("变更前金额") private BigDecimal beforeAmount; diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/UserPoint.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/UserPoint.java index 1878f6b..89d0ba8 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/UserPoint.java +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/model/UserPoint.java @@ -38,15 +38,15 @@ @ApiModelProperty(value = "历史余额") @TableField("historical_point") - private BigDecimal historicalPoint; + private Integer historicalPoint; @ApiModelProperty(value = "变动金额") @TableField("variable_point") - private BigDecimal variablePoint; + private Integer variablePoint; @ApiModelProperty(value = "变动后余额") @TableField("balance") - private BigDecimal balance; + private Integer balance; @ApiModelProperty(value = "变动时间") @TableField("create_time") diff --git a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/vo/PaymentUserCouponVo.java b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/vo/PaymentUserCouponVo.java index f91a159..64713fd 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/vo/PaymentUserCouponVo.java +++ b/ruoyi-api/ruoyi-api-account/src/main/java/com/ruoyi/account/api/vo/PaymentUserCouponVo.java @@ -5,6 +5,7 @@ import lombok.Data; import java.math.BigDecimal; +import java.util.List; /** * @author zhibing.pu @@ -31,6 +32,8 @@ private String periodStartTime; @ApiModelProperty("有效期结束时间") private String periodEndTime; + @ApiModelProperty("适用商品id集合,为null表示全部适用") + private List<Integer> forGoodIds; @ApiModelProperty("是否可用") private Boolean available; } diff --git a/ruoyi-api/ruoyi-api-account/src/main/resources/META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports b/ruoyi-api/ruoyi-api-account/src/main/resources/META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports index 975746c..3261002 100644 --- a/ruoyi-api/ruoyi-api-account/src/main/resources/META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports +++ b/ruoyi-api/ruoyi-api-account/src/main/resources/META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports @@ -1,3 +1,5 @@ com.ruoyi.account.api.factory.AppUserClientFallbackFactory com.ruoyi.account.api.factory.UserAddressClientFallbackFactory -com.ruoyi.account.api.factory.UserCouponClientFallbackFactory \ No newline at end of file +com.ruoyi.account.api.factory.UserCouponClientFallbackFactory +com.ruoyi.account.api.factory.UserPointFallbackFactory +com.ruoyi.account.api.factory.BalanceChangeRecordClientFallbackFactory \ No newline at end of file diff --git a/ruoyi-api/ruoyi-api-order/src/main/java/model/Order.java b/ruoyi-api/ruoyi-api-order/src/main/java/model/Order.java index c0bf9a7..3497fd6 100644 --- a/ruoyi-api/ruoyi-api-order/src/main/java/model/Order.java +++ b/ruoyi-api/ruoyi-api-order/src/main/java/model/Order.java @@ -103,7 +103,7 @@ @ApiModelProperty(value = "使用积分") @TableField("point") - private BigDecimal point; + private Integer point; @ApiModelProperty(value = "1wx2积分") @TableField("pay_method") @@ -135,7 +135,7 @@ @ApiModelProperty(value = "本单获取的积分") @TableField("get_point") - private BigDecimal getPoint; + private Integer getPoint; @ApiModelProperty(value = "微信支付号") @TableField("serial_number") diff --git a/ruoyi-api/ruoyi-api-order/src/main/java/model/OrderGood.java b/ruoyi-api/ruoyi-api-order/src/main/java/model/OrderGood.java index 01c601d..cc8495c 100644 --- a/ruoyi-api/ruoyi-api-order/src/main/java/model/OrderGood.java +++ b/ruoyi-api/ruoyi-api-order/src/main/java/model/OrderGood.java @@ -31,11 +31,11 @@ @ApiModelProperty(value = "商品id") @TableField("goods_id") - private Long goodsId; + private Integer goodsId; @ApiModelProperty(value = "订单id") @TableField("order_id") - private Integer orderId; + private Long orderId; @ApiModelProperty(value = "商品券优惠金额") @TableField("good_amount") @@ -61,6 +61,50 @@ @ApiModelProperty(value = "添加时间") @TableField("create_time") private LocalDateTime createTime; + + @ApiModelProperty(value = "可获得消费积分") + @TableField("earn_spending_points") + private Integer earnSpendingPoints; + + @ApiModelProperty(value = "上级获得分佣金额") + @TableField("superior_subcommission") + private BigDecimal superiorSubcommission; + + @ApiModelProperty(value = "上级获得返佣积分") + @TableField("superior_rebate_points") + private Integer superiorRebatePoints; + + @ApiModelProperty(value = "获取返佣积分上级类型(1=直推上级,2=直帮上级)") + @TableField("superior_type") + private Integer superiorType; + + @ApiModelProperty(value = "核销门店可获得服务费") + @TableField("servuce_shop_charges") + private BigDecimal servuceShopCharges; + + @ApiModelProperty(value = "核销门店可获得服务积分") + @TableField("servuce_shop_points") + private Integer servuceShopPoints; + + @ApiModelProperty(value = "技师可获得服务积分") + @TableField("technician_points") + private Integer technicianPoints; + + @ApiModelProperty(value = "绑定门店可获得分佣金额") + @TableField("bound_shop_charges") + private BigDecimal boundShopCharges; + + @ApiModelProperty(value = "绑定门店可获得返佣积分") + @TableField("bound_shop_points") + private Integer boundShopPoints; + + @ApiModelProperty(value = "绑定门店上级门店可获得分佣金额") + @TableField("bound_shop_superiors_charges") + private BigDecimal boundShopSuperiorsCharges; + + @ApiModelProperty(value = "绑定门店上级门店可获得返佣积分") + @TableField("bound_shop_superiors_points") + private Integer boundShopSuperiorsPoints; } diff --git a/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/domain/Goods.java b/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/domain/Goods.java index cd1e819..4e6f8d7 100644 --- a/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/domain/Goods.java +++ b/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/domain/Goods.java @@ -28,7 +28,7 @@ @ApiModelProperty(value = "主键") @TableId(value = "id", type = IdType.AUTO) - private Long id; + private Integer id; @ApiModelProperty(value = "名称") @TableField("name") diff --git a/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/factory/GoodsShopClientFallbackFactory.java b/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/factory/GoodsShopClientFallbackFactory.java index c320e21..671bc36 100644 --- a/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/factory/GoodsShopClientFallbackFactory.java +++ b/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/factory/GoodsShopClientFallbackFactory.java @@ -3,7 +3,10 @@ import com.ruoyi.common.core.domain.R; import com.ruoyi.other.api.domain.GoodsShop; import com.ruoyi.other.api.feignClient.GoodsShopClient; +import com.ruoyi.other.api.vo.GetGoodsShopByGoodsIds; import org.springframework.cloud.openfeign.FallbackFactory; + +import java.util.List; /** * @author zhibing.pu @@ -19,6 +22,11 @@ public R<GoodsShop> getGoodsShop(GoodsShop goodsShop) { return R.fail("获取商品门店关系数据失败:" + cause.getMessage()); } + + @Override + public R<List<GoodsShop>> getGoodsShopByGoodsIds(GetGoodsShopByGoodsIds goodsIds) { + return R.fail("根据商品id集合和门店id查询数据失败:" + cause.getMessage()); + } }; } } diff --git a/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/feignClient/GoodsShopClient.java b/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/feignClient/GoodsShopClient.java index cc033c8..300d0f3 100644 --- a/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/feignClient/GoodsShopClient.java +++ b/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/feignClient/GoodsShopClient.java @@ -4,9 +4,12 @@ import com.ruoyi.common.core.domain.R; import com.ruoyi.other.api.domain.GoodsShop; import com.ruoyi.other.api.factory.GoodsShopClientFallbackFactory; +import com.ruoyi.other.api.vo.GetGoodsShopByGoodsIds; import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; + +import java.util.List; /** * @author zhibing.pu @@ -22,4 +25,12 @@ */ @PostMapping("/goods-shop/getGoodsShop") R<GoodsShop> getGoodsShop(@RequestBody GoodsShop goodsShop); + + /** + * 根据商品id集合和门店id查询数据 + * @param goodsIds + * @return + */ + @PostMapping("/goods-shop/getGoodsShopByGoodsIds") + R<List<GoodsShop>> getGoodsShopByGoodsIds(@RequestBody GetGoodsShopByGoodsIds goodsIds); } diff --git a/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/vo/GetGoodsShopByGoodsIds.java b/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/vo/GetGoodsShopByGoodsIds.java new file mode 100644 index 0000000..81a2f96 --- /dev/null +++ b/ruoyi-api/ruoyi-api-other/src/main/java/com/ruoyi/other/api/vo/GetGoodsShopByGoodsIds.java @@ -0,0 +1,21 @@ +package com.ruoyi.other.api.vo; + +import lombok.Data; + +import java.util.List; + +/** + * @author zhibing.pu + * @Date 2024/12/2 10:18 + */ +@Data +public class GetGoodsShopByGoodsIds { + /** + * 门店id + */ + private Integer shopId; + /** + * 商品id集合 + */ + private List<Integer> goodsIds; +} diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/BalanceChangeRecordController.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/BalanceChangeRecordController.java new file mode 100644 index 0000000..eb01dad --- /dev/null +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/BalanceChangeRecordController.java @@ -0,0 +1,37 @@ +package com.ruoyi.account.controller; + +import com.ruoyi.account.api.model.BalanceChangeRecord; +import com.ruoyi.account.service.BalanceChangeRecordService; +import com.ruoyi.common.core.domain.R; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestBody; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.bind.annotation.RestController; + +import javax.annotation.Resource; + +/** + * @author zhibing.pu + * @Date 2024/12/2 15:36 + */ +@RestController +@RequestMapping("/balanceChangeRecord") +public class BalanceChangeRecordController { + + @Resource + private BalanceChangeRecordService balanceChangeRecordService; + + + /** + * 保存账户流水记录 + * @param balanceChangeRecord + * @return + */ + @PostMapping("/saveBalanceChangeRecord") + public R saveBalanceChangeRecord(@RequestBody BalanceChangeRecord balanceChangeRecord){ + balanceChangeRecordService.save(balanceChangeRecord); + return R.ok(); + } + + +} diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserAddressController.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserAddressController.java index bb6226e..73091a9 100644 --- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserAddressController.java +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserAddressController.java @@ -99,6 +99,18 @@ userAddressService.updateById(byId); return R.ok(); } - + + /** + * 根据id获取用户地址信息 + * @param id + * @return + */ + @ResponseBody + @PostMapping("/getUserAddressById") + public R<UserAddress> getUserAddressById(@RequestParam("id") Integer id){ + UserAddress userAddress = userAddressService.getById(id); + return R.ok(userAddress); + } + } diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserCouponController.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserCouponController.java index dd9e7ff..1846885 100644 --- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserCouponController.java +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserCouponController.java @@ -147,9 +147,24 @@ @ResponseBody @PostMapping("/getPaymentUserCoupon") public R<List<PaymentUserCouponVo>> getPaymentUserCoupon(@RequestBody PaymentUserCoupon paymentUserCoupon){ - List<PaymentUserCouponVo> userCoupon = userCouponService.getUserCoupon(paymentUserCoupon.getUserId(), paymentUserCoupon.getOrderMoney(), paymentUserCoupon.getType()); + List<PaymentUserCouponVo> userCoupon = userCouponService.getUserCoupon(paymentUserCoupon.getUserId(), paymentUserCoupon.getType()); return R.ok(userCoupon); } - + + + /** + * 根据用户优惠券id获取优惠券详情 + * @param userCouponId + * @return + */ + @ResponseBody + @PostMapping("/getCouponInfo") + public R<CouponInfoVo> getCouponInfo(@RequestParam("userCouponId") Long userCouponId){ + UserCoupon userCoupon = userCouponService.getById(userCouponId); + CouponInfo data = couponClient.detail(userCoupon.getCouponId()).getData(); + CouponInfoVo couponInfoVo = new CouponInfoVo(); + BeanUtils.copyProperties(data, couponInfoVo); + return R.ok(couponInfoVo); + } } diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserPointController.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserPointController.java index 6015842..cb8e4e0 100644 --- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserPointController.java +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/controller/UserPointController.java @@ -1,6 +1,7 @@ package com.ruoyi.account.controller; +import com.ruoyi.account.api.model.UserPoint; import com.ruoyi.account.service.UserPointService; import com.ruoyi.account.vo.UserPointDetailVO; import com.ruoyi.account.vo.UserPointVO; @@ -11,10 +12,7 @@ import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import io.swagger.annotations.ApiParam; -import org.springframework.web.bind.annotation.GetMapping; -import org.springframework.web.bind.annotation.PostMapping; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.bind.annotation.RestController; +import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; import java.math.BigDecimal; @@ -68,5 +66,17 @@ public R<Void> transferPoint(@ApiParam("积分") BigDecimal point, @ApiParam("手机号") Long phone){ return R.ok(); } + + + /** + * 保存积分流水记录 + * @param userPoint + * @return + */ + @PostMapping("/saveUserPoint") + public R saveUserPoint(@RequestBody UserPoint userPoint){ + userPointService.save(userPoint); + return R.ok(); + } } diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/UserCouponService.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/UserCouponService.java index 0c98266..9edcda4 100644 --- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/UserCouponService.java +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/UserCouponService.java @@ -24,5 +24,5 @@ * @param userId * @return */ - List<PaymentUserCouponVo> getUserCoupon(Long userId, BigDecimal orderMoney, Integer type); + List<PaymentUserCouponVo> getUserCoupon(Long userId, Integer type); } diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/AppUserServiceImpl.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/AppUserServiceImpl.java index 0cf053a..bfb01d7 100644 --- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/AppUserServiceImpl.java +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/AppUserServiceImpl.java @@ -109,7 +109,7 @@ */ @Override public R<LoginVo> mobileLogin(MobileLogin mobileLogin) { - //校验验证码 + //校验验证码 TODO 待完善 // String code = redisService.getCacheObject(mobileLogin.getPhone()); // if(null == code || !code.equals(mobileLogin.getCode())){ // return R.fail("验证码错误"); @@ -188,6 +188,7 @@ */ @Override public R<LoginVo> registerAccount(RegisterAccount registerAccount) { + // TODO 待完善 //校验验证码 // String code = redisService.getCacheObject(registerAccount.getPhone()); // if(null == code || !code.equals(registerAccount.getCode())){ @@ -229,22 +230,23 @@ AppUser appUser2 = this.getById(registerAccount.getPromoter()); appUser.setInviteUserId(registerAccount.getPromoter()); appUser.setShopId(appUser2.getShopId()); - appUser.setPartPoint(BigDecimal.ZERO); - appUser.setPartGrowPoint(BigDecimal.ZERO); - appUser.setShopPoint(BigDecimal.ZERO); - appUser.setSharePoint(BigDecimal.ZERO); + appUser.setPartPoint(0); + appUser.setPartGrowPoint(0); + appUser.setShopPoint(0); + appUser.setSharePoint(0); appUser.setShopAmount(BigDecimal.ZERO); appUser.setWithdrawableAmount(BigDecimal.ZERO); appUser.setWithdrawnAmount(BigDecimal.ZERO); appUser.setTotalRechargeAmount(BigDecimal.ZERO); appUser.setTotalRedPacketAmount(BigDecimal.ZERO); appUser.setTotalDistributionAmount(BigDecimal.ZERO); - appUser.setLavePoint(BigDecimal.ZERO); + appUser.setBalance(BigDecimal.ZERO); + appUser.setLavePoint(0); //根据平台的配置未达标,则标注为可修改推广人 appUser.setChangePromoter(0); appUser.setLongitude(registerAccount.getLongitude()); appUser.setLatitude(registerAccount.getLatitude()); - //调用地图获取省市区数据 + //调用地图获取省市区数据 TODO 待完善 // appUser.setProvince(); // appUser.setProvinceCode(); // appUser.setCity(); @@ -324,7 +326,7 @@ //使用地图获取省市区数据 String longitude = nearbyReferrer.getLongitude(); String latitude = nearbyReferrer.getLatitude(); - String cityCode = ""; + String cityCode = ""; // TODO 待完善 List<NearbyReferrerVo> list = this.baseMapper.getNearbyReferrer(cityCode, nearbyReferrer); return list; } diff --git a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/UserCouponServiceImpl.java b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/UserCouponServiceImpl.java index eac7acd..b1c2894 100644 --- a/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/UserCouponServiceImpl.java +++ b/ruoyi-service/ruoyi-account/src/main/java/com/ruoyi/account/service/impl/UserCouponServiceImpl.java @@ -1,5 +1,6 @@ package com.ruoyi.account.service.impl; +import com.alibaba.fastjson2.JSON; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ruoyi.account.api.vo.CouponInfoVo; @@ -13,6 +14,7 @@ import javax.annotation.Resource; import java.math.BigDecimal; +import java.time.Instant; import java.time.format.DateTimeFormatter; import java.util.ArrayList; import java.util.List; @@ -41,7 +43,7 @@ * @return */ @Override - public List<PaymentUserCouponVo> getUserCoupon(Long userId, BigDecimal orderMoney, Integer type) { + public List<PaymentUserCouponVo> getUserCoupon(Long userId, Integer type) { List<UserCoupon> list = this.list(new LambdaQueryWrapper<UserCoupon>().eq(UserCoupon::getAppUserId, userId).eq(UserCoupon::getDelFlag, 0) .last(" and now() between start_time and end_time")); List<Integer> couponIds = list.stream().map(UserCoupon::getCouponId).collect(Collectors.toList()); @@ -54,6 +56,10 @@ List<PaymentUserCouponVo> infoVoList = new ArrayList<>(); for (UserCoupon userCoupon : list) { CouponInfo couponInfo = couponInfoList.stream().filter(s -> s.getId().equals(userCoupon.getCouponId())).findFirst().get(); + //排除商品券(商品券线下领取) + if(4 == couponInfo.getCouponType()){ + continue; + } PaymentUserCouponVo couponInfoVo = new PaymentUserCouponVo(); couponInfoVo.setId(userCoupon.getId()); couponInfoVo.setName(couponInfo.getCouponName()); @@ -64,19 +70,14 @@ couponInfoVo.setDiscount(couponInfo.getDiscount()); couponInfoVo.setPeriodEndTime(couponInfo.getPeriodStartTime().format(formatter)); couponInfoVo.setPeriodEndTime(couponInfo.getPeriodEndTime().format(formatter)); + String forGoodIds = couponInfo.getForGoodIds(); + Integer instant = JSON.parseArray(forGoodIds).getInteger(0); + if(-1 == instant){ + couponInfoVo.setForGoodIds(null); + }else{ + couponInfoVo.setForGoodIds(JSON.parseArray(forGoodIds, Integer.class)); + } couponInfoVo.setAvailable(false); - //满减券 - if(1 == couponInfo.getCouponType() && orderMoney.compareTo(couponInfo.getConditionAmount()) >= 0){ - couponInfoVo.setAvailable(true); - } - //代金券和折扣券 - if(2 == couponInfo.getCouponType() || 3 == couponInfo.getCouponType()){ - couponInfoVo.setAvailable(true); - } - //商品券 - if(4 == couponInfo.getCouponType() && 2 == type){ - couponInfoVo.setAvailable(true); - } infoVoList.add(couponInfoVo); } return infoVoList; 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 c9fc889..cac0a44 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 @@ -3,13 +3,14 @@ import com.alibaba.fastjson2.JSON; import com.alibaba.fastjson2.JSONArray; import com.alibaba.fastjson2.JSONObject; +import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; -import com.ruoyi.account.api.feignClient.AppUserClient; -import com.ruoyi.account.api.feignClient.UserAddressClient; -import com.ruoyi.account.api.feignClient.UserCouponClient; +import com.ruoyi.account.api.feignClient.*; import com.ruoyi.account.api.model.AppUser; +import com.ruoyi.account.api.model.BalanceChangeRecord; import com.ruoyi.account.api.model.UserAddress; +import com.ruoyi.account.api.model.UserPoint; import com.ruoyi.account.api.vo.CouponInfoVo; import com.ruoyi.account.api.vo.PaymentUserCoupon; import com.ruoyi.account.api.vo.PaymentUserCouponVo; @@ -24,6 +25,7 @@ import com.ruoyi.other.api.domain.*; import com.ruoyi.other.api.feignClient.*; import com.ruoyi.other.api.vo.GetGoodsBargainPrice; +import com.ruoyi.other.api.vo.GetGoodsShopByGoodsIds; import com.ruoyi.other.api.vo.GetSeckillActivityInfo; import io.swagger.annotations.ApiModelProperty; import lombok.Data; @@ -35,10 +37,9 @@ import javax.annotation.Resource; import java.math.BigDecimal; import java.math.RoundingMode; -import java.util.ArrayList; -import java.util.Arrays; -import java.util.List; -import java.util.Map; +import java.text.SimpleDateFormat; +import java.time.LocalDateTime; +import java.util.*; import java.util.stream.Collectors; @Service @@ -92,6 +93,12 @@ @Resource private SystemConfigClient systemConfigClient; + @Resource + private UserPointClient userPointClient; + + @Resource + private BalanceChangeRecordClient balanceChangeRecordClient; + @@ -112,7 +119,7 @@ if(null == data){ throw new RuntimeException("根据类型(1=服务商品,2=单品商品)获取商品数据失败"); } - List<Long> goodsIds = data.stream().map(Goods::getId).collect(Collectors.toList()); + List<Integer> goodsIds = data.stream().map(Goods::getId).collect(Collectors.toList()); //查询符合商品类型的商品数据 List<ShoppingCart> list = this.list(new LambdaQueryWrapper<ShoppingCart>().eq(ShoppingCart::getAppUserId, userid).in(ShoppingCart::getGoodsId, goodsIds)); //构建返回数据 @@ -164,6 +171,16 @@ price.setCashPayment(goodsVip.getCashPayment() == 1 ? true : false); price.setPointPayment(goodsVip.getPointPayment() == 1 ? true : false); price.setEarnSpendingPoints(goodsVip.getEarnSpendingPoints()); + price.setSuperiorSubcommission(goodsVip.getSuperiorSubcommission()); + price.setSuperiorRebatePoints(goodsVip.getSuperiorRebatePoints()); + price.setSuperiorType(goodsVip.getSuperiorType()); + price.setServuceShopCharges(goodsVip.getServuceShopCharges()); + price.setServuceShopPoints(goodsVip.getServuceShopPoints()); + price.setTechnicianPoints(goodsVip.getTechnicianPoints()); + price.setBoundShopCharges(goodsVip.getBoundShopCharges()); + price.setBoundShopPoints(goodsVip.getBoundShopPoints()); + price.setBoundShopSuperiorsCharges(goodsVip.getBoundShopSuperiorsCharges()); + price.setBoundShopSuperiorsPoints(goodsVip.getBoundShopSuperiorsPoints()); } }else{ price.setCash(goodsArea.getSellingPrice()); @@ -171,6 +188,16 @@ price.setCashPayment(goodsArea.getCashPayment() == 1 ? true : false); price.setPointPayment(goodsArea.getPointPayment() == 1 ? true : false); price.setEarnSpendingPoints(goodsArea.getEarnSpendingPoints()); + price.setSuperiorSubcommission(goodsArea.getSuperiorSubcommission()); + price.setSuperiorRebatePoints(goodsArea.getSuperiorRebatePoints()); + price.setSuperiorType(goodsArea.getSuperiorType()); + price.setServuceShopCharges(goodsArea.getServuceShopCharges()); + price.setServuceShopPoints(goodsArea.getServuceShopPoints()); + price.setTechnicianPoints(goodsArea.getTechnicianPoints()); + price.setBoundShopCharges(goodsArea.getBoundShopCharges()); + price.setBoundShopPoints(goodsArea.getBoundShopPoints()); + price.setBoundShopSuperiorsCharges(goodsArea.getBoundShopSuperiorsCharges()); + price.setBoundShopSuperiorsPoints(goodsArea.getBoundShopSuperiorsPoints()); } }else{ price.setCash(bargainPriceDetail.getSellingPrice()); @@ -185,6 +212,16 @@ area.setVip(appUser.getVipId()); GoodsArea goodsArea = goodsAreaClient.getGoodsArea(area).getData(); price.setEarnSpendingPoints(goodsArea.getEarnSpendingPoints()); + price.setSuperiorSubcommission(goodsArea.getSuperiorSubcommission()); + price.setSuperiorRebatePoints(goodsArea.getSuperiorRebatePoints()); + price.setSuperiorType(goodsArea.getSuperiorType()); + price.setServuceShopCharges(goodsArea.getServuceShopCharges()); + price.setServuceShopPoints(goodsArea.getServuceShopPoints()); + price.setTechnicianPoints(goodsArea.getTechnicianPoints()); + price.setBoundShopCharges(goodsArea.getBoundShopCharges()); + price.setBoundShopPoints(goodsArea.getBoundShopPoints()); + price.setBoundShopSuperiorsCharges(goodsArea.getBoundShopSuperiorsCharges()); + price.setBoundShopSuperiorsPoints(goodsArea.getBoundShopSuperiorsPoints()); } }else{ //构建价格数据 @@ -202,6 +239,16 @@ price.setPointPayment(goodsSeckill.getPointPayment() == 1 ? true : false); price.setEndTime(goodsSeckill.getEndTime()); price.setEarnSpendingPoints(goodsSeckill.getEarnSpendingPoints()); + price.setSuperiorSubcommission(goodsSeckill.getSuperiorSubcommission()); + price.setSuperiorRebatePoints(goodsSeckill.getSuperiorRebatePoints()); + price.setSuperiorType(goodsSeckill.getSuperiorType()); + price.setServuceShopCharges(goodsSeckill.getServuceShopCharges()); + price.setServuceShopPoints(goodsSeckill.getServuceShopPoints()); + price.setTechnicianPoints(goodsSeckill.getTechnicianPoints()); + price.setBoundShopCharges(goodsSeckill.getBoundShopCharges()); + price.setBoundShopPoints(goodsSeckill.getBoundShopPoints()); + price.setBoundShopSuperiorsCharges(goodsSeckill.getBoundShopSuperiorsCharges()); + price.setBoundShopSuperiorsPoints(goodsSeckill.getBoundShopSuperiorsPoints()); } return price; } @@ -233,6 +280,46 @@ * 可获得消费积分 */ private Integer earnSpendingPoints; + /** + * 上级获得分佣金额 + */ + private BigDecimal superiorSubcommission; + /** + * 上级获得返佣积分 + */ + private Integer superiorRebatePoints; + /** + * 获取返佣积分上级类型(1=直推上级,2=直帮上级) + */ + private Integer superiorType; + /** + * 核销门店可获得服务费 + */ + private BigDecimal servuceShopCharges; + /** + * 核销门店可获得服务积分 + */ + private Integer servuceShopPoints; + /** + * 技师可获得服务积分 + */ + private Integer technicianPoints; + /** + * 绑定门店可获得分佣金额 + */ + private BigDecimal boundShopCharges; + /** + * 绑定门店可获得返佣积分 + */ + private Integer boundShopPoints; + /** + * 绑定门店上级门店可获得分佣金额 + */ + private BigDecimal boundShopSuperiorsCharges; + /** + * 绑定门店上级门店可获得返佣积分 + */ + private Integer boundShopSuperiorsPoints; } @@ -326,8 +413,42 @@ paymentUserCoupon.setUserId(userid); paymentUserCoupon.setOrderMoney(orderMoney); paymentUserCoupon.setType(confirmOrder.getType()); - List<PaymentUserCouponVo> data = userCouponClient.getPaymentUserCoupon(paymentUserCoupon).getData(); - confirmOrderVo.setCoupon(data); + if(confirmOrder.getPaymentType() == 1){ + List<PaymentUserCouponVo> data = userCouponClient.getPaymentUserCoupon(paymentUserCoupon).getData(); + for (PaymentUserCouponVo couponInfo : data) { + List<Integer> forGoodIds = couponInfo.getForGoodIds(); + //全部商品适用 + if(null == forGoodIds){ + //满减券 + if(1 == couponInfo.getCouponType() && orderMoney.compareTo(couponInfo.getConditionAmount()) >= 0){ + couponInfo.setAvailable(true); + } + //代金券和折扣券 + if(2 == couponInfo.getCouponType() || 3 == couponInfo.getCouponType()){ + couponInfo.setAvailable(true); + } + }else{ + //部分商品适用 + BigDecimal goodsMoney = BigDecimal.ZERO; + for (MyShoppingCartVo myShoppingCartVo : goodsList) { + Integer goodsId = myShoppingCartVo.getGoodsId(); + BigDecimal cash = myShoppingCartVo.getCash(); + if(forGoodIds.contains(goodsId)){ + goodsMoney = goodsMoney.add(cash); + } + } + //满减 + if(1 == couponInfo.getCouponType() && couponInfo.getConditionAmount().compareTo(goodsMoney) <= 0){ + couponInfo.setAvailable(true); + } + //代金券 + if(2 == couponInfo.getCouponType() || 3 == couponInfo.getCouponType()){ + couponInfo.setAvailable(true); + } + } + } + confirmOrderVo.setCoupon(data); + } //获取快递策略 SystemConfig systemConfig = systemConfigClient.getSystemConfig(3).getData(); JSONObject jsonObject = JSON.parseObject(systemConfig.getContent()); @@ -367,6 +488,7 @@ Goods goods = goodsClient.getGoodsById(shoppingCart.getGoodsId()).getData(); MyShoppingCartVo vo = new MyShoppingCartVo(); vo.setId(shoppingCart.getId()); + vo.setGoodsId(goods.getId()); vo.setHomePicture(goods.getHomePagePicture()); vo.setName(goods.getName()); int num = shoppingCart.getNumber(); @@ -414,8 +536,18 @@ } vo.setPurchaseLimit((num + sum) > goods.getPurchaseLimit() ? true : false); } - vo.setEarnSpendingPoints(price.getEarnSpendingPoints()); vo.setDistributionMode(goods.getDistributionMode()); + vo.setEarnSpendingPoints(price.getEarnSpendingPoints()); + vo.setSuperiorSubcommission(price.getSuperiorSubcommission()); + vo.setSuperiorRebatePoints(price.getSuperiorRebatePoints()); + vo.setSuperiorType(price.getSuperiorType()); + vo.setServuceShopCharges(price.getServuceShopCharges()); + vo.setServuceShopPoints(price.getServuceShopPoints()); + vo.setTechnicianPoints(price.getTechnicianPoints()); + vo.setBoundShopCharges(price.getBoundShopCharges()); + vo.setBoundShopPoints(price.getBoundShopPoints()); + vo.setBoundShopSuperiorsCharges(price.getBoundShopSuperiorsCharges()); + vo.setBoundShopSuperiorsPoints(price.getBoundShopSuperiorsPoints()); page.add(vo); } return page; @@ -432,22 +564,412 @@ Long userid = tokenService.getLoginUserApplet().getUserid(); AppUser appUser = appUserClient.getAppUserById(userid); Integer shopId = shoppingCartPayment.getShopId(); - Shop shop = shopClient.getShopById(shopId).getData(); String goodsJson = shoppingCartPayment.getGoodsJson(); List<Long> ids = new ArrayList<>(); + Integer num = 0; JSONArray objects = JSON.parseArray(goodsJson); for (int i = 0; i < objects.size(); i++) { Long id = objects.getJSONObject(i).getLong("id"); + Integer num1 = objects.getJSONObject(i).getInteger("num"); + num += num1; + ShoppingCart shoppingCart = this.getById(id); + //判断当前数量是否已经超出限购数量(需要计算已经购买的数量) + Goods goods = goodsClient.getGoodsById(shoppingCart.getGoodsId()).getData(); + if(null != goods.getPurchaseLimit() && -1 != goods.getPurchaseLimit()){ + List<Order> orders = orderService.list(new LambdaQueryWrapper<Order>().eq(Order::getAppUserId, appUser.getId()).eq(Order::getDelFlag, 0).in(Order::getOrderStatus, Arrays.asList(4, 8))); + List<Long> orderIds = orders.stream().map(Order::getId).collect(Collectors.toList()); + int sum = 0; + if(orderIds.size() > 0){ + List<OrderGood> orderGoodList = orderGoodService.list(new LambdaQueryWrapper<OrderGood>().in(OrderGood::getOrderId, orderIds) + .eq(OrderGood::getGoodsId, shoppingCart.getGoodsId()).eq(OrderGood::getDelFlag, 0)); + sum = orderGoodList.stream().mapToInt(OrderGood::getNum).sum(); + } + if((num1 + sum) > goods.getPurchaseLimit()){ + return R.fail(goods.getName() + "已超出购买上限"); + } + } ids.add(id); } + List<ShoppingCart> list = this.listByIds(ids); - ConfirmOrderVo confirmOrderVo = new ConfirmOrderVo(); //构建商品明细列表 List<MyShoppingCartVo> goodsList = buildDetail(appUser, shopId, list, objects); + //判断支付当时是否正确 + if(1 == shoppingCartPayment.getPaymentType() || 2 == shoppingCartPayment.getPaymentType()){ + //现金支付 + long count = goodsList.stream().filter(s -> s.getCashPayment()).count(); + if(count != goodsList.size()){ + return R.fail("支付方式不正确"); + } + } else if(3 == shoppingCartPayment.getPaymentType()){ + //积分支付 + long count = goodsList.stream().filter(s -> s.getPointPayment()).count(); + if(count != goodsList.size()){ + return R.fail("支付方式不正确"); + } + }else{ + return R.fail("支付方式不正确"); + } + //判断门店是都可以核销所有的商品 + List<Integer> goodsIds = goodsList.stream().map(MyShoppingCartVo::getGoodsId).collect(Collectors.toList()); + GetGoodsShopByGoodsIds goodsShopByGoodsIds = new GetGoodsShopByGoodsIds(); + goodsShopByGoodsIds.setGoodsIds(goodsIds); + goodsShopByGoodsIds.setShopId(shopId); + List<GoodsShop> data = goodsShopClient.getGoodsShopByGoodsIds(goodsShopByGoodsIds).getData(); + List<Integer> collect = data.stream().map(GoodsShop::getGoodsId).collect(Collectors.toList()); + if(data.size() != goodsList.size()){ + String goodsName = ""; + for (Integer goodsId : goodsIds) { + if(!collect.contains(goodsId)){ + goodsName = goodsClient.getGoodsById(goodsId).getData().getName(); + break; + } + } + return R.fail(goodsName + "不能在该门店核销"); + } + //开始构建支付信息 + //现金支付的订单金额 + BigDecimal orderMoney = BigDecimal.ZERO; + //折扣(9折) + BigDecimal discount = null; + //积分支付的订单积分 + Integer orderPoint = 0; + if(3 != shoppingCartPayment.getPaymentType()){ + orderMoney = goodsList.stream().map(MyShoppingCartVo::getCash).reduce(BigDecimal::add).get(); + }else{ + orderPoint = goodsList.stream().mapToInt(MyShoppingCartVo::getPoint).sum(); + if(appUser.getLavePoint().intValue() < orderPoint){ + return R.fail("账户剩余积分不足"); + } + } + //现金的支付金额 + BigDecimal paymentMoney = orderMoney; + //满减金额 + BigDecimal fullReductionAmount = BigDecimal.ZERO; + //代金券抵扣金额 + BigDecimal moneyAmount = BigDecimal.ZERO; + //折扣券抵扣金额 + BigDecimal discountAmount = BigDecimal.ZERO; + //活动优惠金额 + BigDecimal activityAmount = BigDecimal.ZERO; + //减去优惠券优惠金额 + CouponInfoVo couponInfoVo = null; + if(null != shoppingCartPayment.getUserCouponId() && 3 != shoppingCartPayment.getPaymentType()){ + couponInfoVo = userCouponClient.getCouponInfo(shoppingCartPayment.getUserCouponId()).getData(); + String forGoodIds = couponInfoVo.getForGoodIds(); + List<Integer> parseArray = JSON.parseArray(forGoodIds, Integer.class); + //全部商品 + if(parseArray.contains(-1)){ + //满减 + if(1 == couponInfoVo.getCouponType() && couponInfoVo.getConditionAmount().compareTo(paymentMoney) <= 0){ + paymentMoney = paymentMoney.subtract(couponInfoVo.getDiscountAmount()); + fullReductionAmount = fullReductionAmount.add(couponInfoVo.getDiscountAmount()); + } + //代金券 + if(2 == couponInfoVo.getCouponType()){ + paymentMoney = paymentMoney.subtract(couponInfoVo.getMoneyAmount()); + moneyAmount = moneyAmount.add(couponInfoVo.getMoneyAmount()); + if(paymentMoney.compareTo(BigDecimal.ZERO) < 0){ + paymentMoney = BigDecimal.ZERO; + } + } + //折扣券 + if(3 == couponInfoVo.getCouponType()){ + BigDecimal paymentMoney1 = couponInfoVo.getDiscount().divide(new BigDecimal(10)).multiply(paymentMoney); + BigDecimal bigDecimal = paymentMoney.subtract(paymentMoney1).setScale(2, RoundingMode.HALF_EVEN); + discount = couponInfoVo.getDiscount(); + paymentMoney = paymentMoney1; + discountAmount = discountAmount.add(bigDecimal); + } + }else{ + //部分商品,需要计算参与优惠商品的支付金额,然后再对商品进行优惠券处理 + paymentMoney = BigDecimal.ZERO; + BigDecimal goodsMoney = BigDecimal.ZERO; + for (MyShoppingCartVo myShoppingCartVo : goodsList) { + Integer goodsId = myShoppingCartVo.getGoodsId(); + BigDecimal cash = myShoppingCartVo.getCash(); + if(parseArray.contains(goodsId)){ + goodsMoney = goodsMoney.add(cash); + }else{ + paymentMoney = paymentMoney.add(cash); + } + } + + //满减 + if(1 == couponInfoVo.getCouponType() && couponInfoVo.getConditionAmount().compareTo(goodsMoney) <= 0){ + goodsMoney = goodsMoney.subtract(couponInfoVo.getDiscountAmount()); + fullReductionAmount = fullReductionAmount.add(couponInfoVo.getDiscountAmount()); + } + //代金券 + if(2 == couponInfoVo.getCouponType()){ + goodsMoney = goodsMoney.subtract(couponInfoVo.getMoneyAmount()); + moneyAmount = moneyAmount.add(couponInfoVo.getMoneyAmount()); + if(goodsMoney.compareTo(BigDecimal.ZERO) < 0){ + goodsMoney = BigDecimal.ZERO; + } + } + //折扣券 + if(3 == couponInfoVo.getCouponType()){ + BigDecimal paymentMoney1 = couponInfoVo.getDiscount().divide(new BigDecimal(10)).multiply(goodsMoney); + BigDecimal bigDecimal = goodsMoney.subtract(paymentMoney1).setScale(2, RoundingMode.HALF_EVEN); + discount = couponInfoVo.getDiscount(); + goodsMoney = paymentMoney1; + discountAmount = discountAmount.add(bigDecimal); + } + paymentMoney = paymentMoney.add(goodsMoney); + } + } + //查询当前是否有订单活动 + OrderActivityInfo orderActivityInfo = orderActivityInfoClient.getNowOrderActivityInfo(appUser.getVipId()).getData(); + BaseSetting baseSetting = baseSettingClient.getBaseSetting(4).getData(); + //系统活动设置(优惠券和活动能否同时使用) + boolean useSimultaneously = baseSetting.getContent().equals("1") ? true : false; + //满XX才打折,只有现金才能优惠 + //如果使用优惠券,则需要判断是否可以和同时使用,且活动满足使用条件。 + //没有使用优惠券,只需要判断是都满足使用条件 + if(((useSimultaneously && null != shoppingCartPayment.getUserCouponId()) || null == shoppingCartPayment.getUserCouponId()) && + null != orderActivityInfo && shoppingCartPayment.getPaymentType() != 3 && orderActivityInfo.getConditionAmount().compareTo(paymentMoney) <= 0){ + BigDecimal paymentMoney1 = orderActivityInfo.getDiscount().divide(new BigDecimal(10)).multiply(paymentMoney); + BigDecimal bigDecimal = paymentMoney.subtract(paymentMoney1).setScale(2, RoundingMode.HALF_EVEN); + discount = orderActivityInfo.getDiscount(); + paymentMoney = paymentMoney1; + activityAmount = activityAmount.add(bigDecimal); + } + //可获得的消费积分 + int earnPoint = goodsList.stream().mapToInt(MyShoppingCartVo::getEarnSpendingPoints).sum(); + if(null != shoppingCartPayment.getUserAddressId()){ + userAddressClient.getUserAddressById(shoppingCartPayment.getUserAddressId()).getData(); + } - return null; + //获取快递策略,计算快递费 + BigDecimal expressFee = BigDecimal.ZERO; + if(null != shoppingCartPayment.getUserAddressId()){ + SystemConfig systemConfig = systemConfigClient.getSystemConfig(3).getData(); + JSONObject jsonObject = JSON.parseObject(systemConfig.getContent()); + //快递费 + expressFee = jsonObject.getBigDecimal("expressFee"); + List<Integer> vip = jsonObject.getJSONArray("vip").toList(Integer.class); + //包邮条件(所有会员或者满足条件的会员) + if(vip.get(0) == -1 || vip.contains(appUser.getVipId())){ + if(shoppingCartPayment.getPaymentType() != 3){ + //现金支付,支付金额满足包邮条件 + BigDecimal cash = jsonObject.getBigDecimal("cash"); + if(paymentMoney.compareTo(cash) >= 0){ + expressFee = BigDecimal.ZERO; + } + }else{ + //积分支付,支付积分是否满足包邮条件 + Integer point = jsonObject.getInteger("point"); + if(orderPoint.compareTo(point) >= 0){ + expressFee = BigDecimal.ZERO; + } + } + } + } + //构建订单明细 + Order order = new Order(); + order.setAppUserId(userid); + order.setNum(num); + String goodPics = ""; + String goodName = ""; + for (MyShoppingCartVo myShoppingCartVo : goodsList) { + goodPics += myShoppingCartVo.getHomePicture() + ","; + goodName += myShoppingCartVo.getName() + ","; + } + order.setGoodPics(goodPics.substring(0, goodPics.length() - 1)); + order.setGoodName(goodName.substring(0, goodName.length() - 1)); + Goods goods = goodsClient.getGoodsById(goodsList.get(0).getGoodsId()).getData(); + order.setOrderType(goods.getType()); + order.setOrderStatus(1); + SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS"); + order.setOrderNumber("QJS" + getNumber(3) + sdf.format(new Date())); + order.setTotalAmount(orderMoney.setScale(2, RoundingMode.HALF_EVEN)); + order.setFullReductionAmount(fullReductionAmount); + order.setMoneyAmount(moneyAmount); + order.setDiscountAmount(discountAmount); + order.setActivityAmount(activityAmount); + order.setDiscountTotalAmount(fullReductionAmount.add(moneyAmount).add(discountAmount).add(activityAmount)); + order.setPaymentAmount(paymentMoney); + order.setPoint(orderPoint); + order.setPayMethod(shoppingCartPayment.getPaymentType()); + if(3 != shoppingCartPayment.getPaymentType() && (fullReductionAmount.compareTo(BigDecimal.ZERO) > 0 ||moneyAmount.compareTo(BigDecimal.ZERO) > 0 || discountAmount.compareTo(BigDecimal.ZERO) > 0)){ + order.setCouponJson(JSON.toJSONString(couponInfoVo)); + } + if(activityAmount.compareTo(BigDecimal.ZERO) > 0){ + order.setActivityJson(JSON.toJSONString(orderActivityInfo)); + } + if(null != shoppingCartPayment.getUserAddressId()){ + UserAddress address = userAddressClient.getUserAddressById(shoppingCartPayment.getUserAddressId()).getData(); + order.setExpressAmount(expressFee); + order.setAddressJson(JSON.toJSONString(address)); + } + order.setGetPoint(earnPoint); + order.setPayStatus(1); + order.setShopId(shoppingCartPayment.getShopId()); + order.setDelFlag(0); + order.setCreateTime(LocalDateTime.now()); + + if(2 == shoppingCartPayment.getPaymentType()){ + BigDecimal balance = appUser.getBalance(); + if(balance.compareTo(paymentMoney.add(expressFee)) < 0){ + return R.fail("账户余额不足"); + } + } + orderService.save(order); + //构建订单明细数据 + for (MyShoppingCartVo myShoppingCartVo : goodsList) { + OrderGood orderGood = new OrderGood(); + orderGood.setGoodsId(myShoppingCartVo.getGoodsId()); + orderGood.setOrderId(order.getId()); + GetSeckillActivityInfo info = new GetSeckillActivityInfo(); + info.setGoodsId(myShoppingCartVo.getGoodsId()); + info.setVip(appUser.getVipId()); + GoodsSeckill goodsSeckill = seckillActivityInfoClient.getSeckillActivityInfo(info).getData(); + if(null != goodsSeckill){ + orderGood.setSeckillJson(JSON.toJSONString(goodsSeckill)); + } + for (int i = 0; i < objects.size(); i++) { + Long id = objects.getJSONObject(i).getLong("id"); + if(myShoppingCartVo.getId().equals(id)){ + Integer num1 = objects.getJSONObject(i).getInteger("num"); + orderGood.setNum(num1); + Goods goods1 = goodsClient.getGoodsById(myShoppingCartVo.getGoodsId()).getData(); + orderGood.setGoodJson(JSON.toJSONString(goods1)); + break; + } + } + orderGood.setDelFlag(0); + orderGood.setCreateTime(LocalDateTime.now()); + orderGood.setEarnSpendingPoints(myShoppingCartVo.getEarnSpendingPoints()); + orderGood.setSuperiorSubcommission(myShoppingCartVo.getSuperiorSubcommission()); + orderGood.setSuperiorRebatePoints(myShoppingCartVo.getSuperiorRebatePoints()); + orderGood.setSuperiorType(myShoppingCartVo.getSuperiorType()); + orderGood.setServuceShopCharges(myShoppingCartVo.getServuceShopCharges()); + orderGood.setServuceShopPoints(myShoppingCartVo.getServuceShopPoints()); + orderGood.setTechnicianPoints(myShoppingCartVo.getTechnicianPoints()); + orderGood.setBoundShopCharges(myShoppingCartVo.getBoundShopCharges()); + orderGood.setBoundShopPoints(myShoppingCartVo.getBoundShopPoints()); + orderGood.setBoundShopSuperiorsCharges(myShoppingCartVo.getBoundShopSuperiorsCharges()); + orderGood.setBoundShopSuperiorsPoints(myShoppingCartVo.getBoundShopSuperiorsPoints()); + orderGoodService.save(orderGood); + } + + //开始构建支付数据 + //现金支付 + paymentMoney = paymentMoney.add(expressFee).setScale(2, RoundingMode.HALF_EVEN); + if(1 == shoppingCartPayment.getPaymentType()){ + //调起微信支付 TODO 待完善 + + + + } + //账户余额 + if(2 == shoppingCartPayment.getPaymentType()){ + BigDecimal totalRedPacketAmount = appUser.getTotalRedPacketAmount(); + BigDecimal totalDistributionAmount = appUser.getTotalDistributionAmount(); + BigDecimal balance = appUser.getBalance(); + if(paymentMoney.compareTo(totalRedPacketAmount) <= 0){ + totalRedPacketAmount = totalRedPacketAmount.subtract(paymentMoney); + balance = balance.subtract(paymentMoney); + appUser.setTotalRedPacketAmount(totalRedPacketAmount); + appUser.setBalance(balance); + }else{ + paymentMoney = paymentMoney.subtract(totalRedPacketAmount); + totalRedPacketAmount = BigDecimal.ZERO; + if(paymentMoney.compareTo(totalDistributionAmount) <= 0){ + totalDistributionAmount = totalDistributionAmount.subtract(paymentMoney); + balance = balance.subtract(paymentMoney); + appUser.setTotalRedPacketAmount(totalRedPacketAmount); + appUser.setTotalDistributionAmount(totalDistributionAmount); + appUser.setBalance(balance); + }else{ + paymentMoney = paymentMoney.subtract(totalDistributionAmount); + totalDistributionAmount = BigDecimal.ZERO; + balance = balance.subtract(paymentMoney); + appUser.setTotalRedPacketAmount(totalRedPacketAmount); + appUser.setTotalDistributionAmount(totalDistributionAmount); + appUser.setBalance(balance); + } + } + //构建积分流水记录 + if(earnPoint > 0){ + appUser.setShopPoint(appUser.getShopPoint() + earnPoint); + appUser.setLavePoint(appUser.getLavePoint() + earnPoint); + + UserPoint userPoint = new UserPoint(); + userPoint.setType(1); + userPoint.setHistoricalPoint(appUser.getLavePoint() - earnPoint); + userPoint.setVariablePoint(earnPoint); + userPoint.setBalance(appUser.getLavePoint()); + userPoint.setCreateTime(LocalDateTime.now()); + userPoint.setAppUserId(appUser.getId()); + userPoint.setObjectId(order.getId()); + userPointClient.saveUserPoint(userPoint); + } + appUserClient.editAppUserById(appUser); + //构建余额明细变动记录 + BalanceChangeRecord balanceChangeRecord = new BalanceChangeRecord(); + balanceChangeRecord.setAppUserId(appUser.getId()); + balanceChangeRecord.setOrderId(order.getId()); + balanceChangeRecord.setChangeType(5); + balanceChangeRecord.setBeforeAmount(balance.add(paymentMoney)); + balanceChangeRecord.setChangeAmount(paymentMoney); + balanceChangeRecord.setAfterAmount(balance); + balanceChangeRecord.setDelFlag(0); + balanceChangeRecord.setCreateTime(LocalDateTime.now()); + balanceChangeRecordClient.saveBalanceChangeRecord(balanceChangeRecord); + //修改订支付状态 + order.setPayStatus(2); + orderService.updateById(order); + //删除购物车数据 + this.removeBatchByIds(ids); + } + //积分支付 + if(3 == shoppingCartPayment.getPaymentType()){ + Integer lavePoint = appUser.getLavePoint(); + appUser.setLavePoint(lavePoint - orderPoint); + appUser.setShopPoint(appUser.getShopPoint() + earnPoint); + appUser.setLavePoint(appUser.getLavePoint() + earnPoint); + appUserClient.editAppUserById(appUser); + //构建积分流水记录 + UserPoint userPoint = new UserPoint(); + userPoint.setType(4); + userPoint.setHistoricalPoint(lavePoint); + userPoint.setVariablePoint(orderPoint); + userPoint.setBalance(appUser.getLavePoint()); + userPoint.setCreateTime(LocalDateTime.now()); + userPoint.setAppUserId(appUser.getId()); + userPoint.setObjectId(order.getId()); + userPointClient.saveUserPoint(userPoint); + if(earnPoint > 0){ + userPoint = new UserPoint(); + userPoint.setType(1); + userPoint.setHistoricalPoint(appUser.getLavePoint() - earnPoint); + userPoint.setVariablePoint(earnPoint); + userPoint.setBalance(appUser.getLavePoint()); + userPoint.setCreateTime(LocalDateTime.now()); + userPoint.setAppUserId(appUser.getId()); + userPoint.setObjectId(order.getId()); + userPointClient.saveUserPoint(userPoint); + } + //修改订支付状态 + order.setPayStatus(2); + orderService.updateById(order); + //删除购物车数据 + this.removeBatchByIds(ids); + } + return R.ok(); + } + + + public String getNumber(Integer size){ + String str = ""; + for (Integer i = 0; i < size; i++) { + str += Double.valueOf(Math.random() * 10).intValue(); + } + return str; } } diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/MyShoppingCartVo.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/MyShoppingCartVo.java index defd541..77ba777 100644 --- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/MyShoppingCartVo.java +++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/MyShoppingCartVo.java @@ -15,6 +15,8 @@ public class MyShoppingCartVo { @ApiModelProperty("数据id") private Long id; + @ApiModelProperty("商品id") + private Integer goodsId; @ApiModelProperty("封面图") private String homePicture; @ApiModelProperty("商品名称") @@ -43,4 +45,44 @@ * 可获得消费积分 */ private Integer earnSpendingPoints; + /** + * 上级获得分佣金额 + */ + private BigDecimal superiorSubcommission; + /** + * 上级获得返佣积分 + */ + private Integer superiorRebatePoints; + /** + * 获取返佣积分上级类型(1=直推上级,2=直帮上级) + */ + private Integer superiorType; + /** + * 核销门店可获得服务费 + */ + private BigDecimal servuceShopCharges; + /** + * 核销门店可获得服务积分 + */ + private Integer servuceShopPoints; + /** + * 技师可获得服务积分 + */ + private Integer technicianPoints; + /** + * 绑定门店可获得分佣金额 + */ + private BigDecimal boundShopCharges; + /** + * 绑定门店可获得返佣积分 + */ + private Integer boundShopPoints; + /** + * 绑定门店上级门店可获得分佣金额 + */ + private BigDecimal boundShopSuperiorsCharges; + /** + * 绑定门店上级门店可获得返佣积分 + */ + private Integer boundShopSuperiorsPoints; } diff --git a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/ShoppingCartPayment.java b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/ShoppingCartPayment.java index 268ac4c..e4e3a0a 100644 --- a/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/ShoppingCartPayment.java +++ b/ruoyi-service/ruoyi-order/src/main/java/com/ruoyi/order/vo/ShoppingCartPayment.java @@ -13,12 +13,12 @@ public class ShoppingCartPayment { @ApiModelProperty(value = "购物车数据id,数量 JSON[{id:1212,num:2}]", required = true) private String goodsJson; - @ApiModelProperty(value = "支付方式(1=现金,2=积分)", required = true) + @ApiModelProperty(value = "支付方式(1=微信,2=账户余额,3=积分)", required = true) private Integer paymentType; @ApiModelProperty(value = "核销门店id", required = true) private Integer shopId; @ApiModelProperty(value = "优惠券id", required = false) - private String userCouponId; + private Long userCouponId; @ApiModelProperty(value = "配送方式(1=自提,2=快递)", required = false) private Integer distributionMode; @ApiModelProperty(value = "配送地址id", required = false) diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsShopController.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsShopController.java index 4511634..0578e20 100644 --- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsShopController.java +++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsShopController.java @@ -4,10 +4,12 @@ import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.ruoyi.common.core.domain.R; import com.ruoyi.other.api.domain.GoodsShop; +import com.ruoyi.other.api.vo.GetGoodsShopByGoodsIds; import com.ruoyi.other.service.GoodsShopService; import org.springframework.web.bind.annotation.*; import javax.annotation.Resource; +import java.util.List; /** * <p> @@ -39,5 +41,16 @@ } + /** + * 根据商品id集合和门店id查询数据 + * @param goodsIds + * @return + */ + @ResponseBody + @PostMapping("/getGoodsShopByGoodsIds") + public R<List<GoodsShop>> getGoodsShopByGoodsIds(@RequestBody GetGoodsShopByGoodsIds goodsIds) { + List<GoodsShop> list = goodsShopService.list(new LambdaQueryWrapper<GoodsShop>().eq(GoodsShop::getShopId, goodsIds.getShopId()).in(GoodsShop::getGoodsId, goodsIds.getGoodsIds())); + return R.ok(list); + } } -- Gitblit v1.7.1