前端+后端:完整接入订单确认的优惠劵计算

pull/1/head
YunaiV 2019-04-20 01:22:39 +08:00
parent cb07eb3f71
commit bc2bf52039
8 changed files with 42 additions and 16 deletions

View File

@ -35,13 +35,14 @@ export function confirmReceiving(orderId) {
}); });
} }
export function getOrderConfirmCreateOrder(skuId, quantity) { export function getOrderConfirmCreateOrder(skuId, quantity, couponCardId) {
return request({ return request({
url: '/order-api/users/order/confirm_create_order', url: '/order-api/users/order/confirm_create_order',
method: 'get', method: 'get',
params: { params: {
skuId, skuId,
quantity, quantity,
couponCardId,
} }
}); });
} }
@ -109,13 +110,12 @@ export function updateCartSelected(skuIds, selected) {
}); });
} }
export function getCartConfirmCreateOrder(skuId, quantity) { export function getCartConfirmCreateOrder(couponCardId) {
return request({ return request({
url: '/order-api/users/cart/confirm_create_order', url: '/order-api/users/cart/confirm_create_order',
method: 'get', method: 'get',
params: { params: {
skuId, couponCardId
quantity,
} }
}); });
} }

View File

@ -125,6 +125,21 @@
}, },
methods: { methods: {
onCouponChange(index) { onCouponChange(index) {
// debugger;
let couponCardId = this.coupons[index].id;
if (this.from === 'direct_order') {
getOrderConfirmCreateOrder(this.skuId, this.quantity, couponCardId).then(data => {
// this.itemGroups = data.itemGroups;
this.fee = data.fee;
this.coupons[index].value = data.couponCardDiscountTotal; //
})
} else if (this.from === 'cart') {
getCartConfirmCreateOrder(couponCardId).then(data => {
// this.itemGroups = data.itemGroups;
this.fee = data.fee;
this.coupons[index].value = data.couponCardDiscountTotal; //
})
}
this.chosenCoupon = index; this.chosenCoupon = index;
this.showCouponPopup = false; this.showCouponPopup = false;
}, },
@ -205,7 +220,7 @@
endAt: card.validEndTime / 1000, endAt: card.validEndTime / 1000,
// description: '', // description: '',
reason: card.unavailableReason, reason: card.unavailableReason,
value: 0, // TODO value: 0,
valueDesc: card.preferentialType === 1 ? card.priceOff / 100 : card.percentOff / 10.0, valueDesc: card.preferentialType === 1 ? card.priceOff / 100 : card.percentOff / 10.0,
unitDesc: card.preferentialType === 1 ? '元' : '折' unitDesc: card.preferentialType === 1 ? '元' : '折'
}) })
@ -228,6 +243,12 @@
this.itemGroups = data.itemGroups; this.itemGroups = data.itemGroups;
this.fee = data.fee; this.fee = data.fee;
// //
this.coupons = this.convertCouponList(data.couponCards.filter(function (element) {
return element.available;
}));
this.disabledCoupons = this.convertCouponList(data.couponCards.filter(function (element) {
return !element.available;
}));
}) })
} else if (this.from === 'cart') { } else if (this.from === 'cart') {
getCartConfirmCreateOrder().then(data => { getCartConfirmCreateOrder().then(data => {

View File

@ -105,7 +105,7 @@ public class UsersCartController {
} }
@GetMapping("/confirm_create_order") @GetMapping("/confirm_create_order")
public CommonResult<UsersOrderConfirmCreateVO> getConfirmCreateOrder(@RequestParam("couponCardId") Integer couponCardId) { public CommonResult<UsersOrderConfirmCreateVO> getConfirmCreateOrder(@RequestParam(value = "couponCardId", required = false) Integer couponCardId) {
Integer userId = UserSecurityContextHolder.getContext().getUserId(); Integer userId = UserSecurityContextHolder.getContext().getUserId();
// 获得购物车中选中的 // 获得购物车中选中的
List<CartItemBO> cartItems = cartService.list(userId, true).getData(); List<CartItemBO> cartItems = cartService.list(userId, true).getData();

View File

@ -94,7 +94,7 @@ public class UsersOrderController {
@ApiOperation("确认创建订单") @ApiOperation("确认创建订单")
public CommonResult<UsersOrderConfirmCreateVO> getConfirmCreateOrder(@RequestParam("skuId") Integer skuId, public CommonResult<UsersOrderConfirmCreateVO> getConfirmCreateOrder(@RequestParam("skuId") Integer skuId,
@RequestParam("quantity") Integer quantity, @RequestParam("quantity") Integer quantity,
@RequestParam("couponCardId") Integer couponCardId) { @RequestParam(value = "couponCardId", required = false) Integer couponCardId) {
// 创建 CalcOrderPriceDTO 对象,并执行价格计算 // 创建 CalcOrderPriceDTO 对象,并执行价格计算
CalcOrderPriceDTO calcOrderPriceDTO = new CalcOrderPriceDTO() CalcOrderPriceDTO calcOrderPriceDTO = new CalcOrderPriceDTO()
.setUserId(UserSecurityContextHolder.getContext().getUserId()) .setUserId(UserSecurityContextHolder.getContext().getUserId())

View File

@ -24,6 +24,10 @@ public class UsersOrderConfirmCreateVO {
* TODO * TODO
*/ */
private List<CouponCardAvailableBO> couponCards; private List<CouponCardAvailableBO> couponCards;
/**
*
*/
private Integer couponCardDiscountTotal;
/** /**
* *
* *

View File

@ -379,7 +379,8 @@ public class CartServiceImpl implements CartService {
Assert.isTrue(presentTotal > 0, "计算后,价格为负数:" + presentTotal); Assert.isTrue(presentTotal > 0, "计算后,价格为负数:" + presentTotal);
} else if (PreferentialTypeEnum.DISCOUNT.getValue().equals(couponCard.getPreferentialType())) { // 打折 } else if (PreferentialTypeEnum.DISCOUNT.getValue().equals(couponCard.getPreferentialType())) { // 打折
presentTotal = originalTotal * couponCard.getPercentOff() / 100; presentTotal = originalTotal * couponCard.getPercentOff() / 100;
if (originalTotal - presentTotal > couponCard.getDiscountPriceLimit()) { if (couponCard.getDiscountPriceLimit() != null // 空,代表不限制优惠上限
&& originalTotal - presentTotal > couponCard.getDiscountPriceLimit()) {
presentTotal = originalTotal - couponCard.getDiscountPriceLimit(); presentTotal = originalTotal - couponCard.getDiscountPriceLimit();
} }
} else { } else {
@ -432,7 +433,7 @@ public class CartServiceImpl implements CartService {
Assert.isTrue(PromotionActivityTypeEnum.FULL_PRIVILEGE.getValue().equals(activity.getActivityType()), Assert.isTrue(PromotionActivityTypeEnum.FULL_PRIVILEGE.getValue().equals(activity.getActivityType()),
"传入的必须的满减送活动必须是满减送"); "传入的必须的满减送活动必须是满减送");
// 获得优惠信息 // 获得优惠信息
List<CalcOrderPriceBO.Item> items = itemGroup.getItems().stream().filter(item -> !item.getSelected()) List<CalcOrderPriceBO.Item> items = itemGroup.getItems().stream().filter(CalcOrderPriceBO.Item::getSelected)
.collect(Collectors.toList()); .collect(Collectors.toList());
Integer itemCnt = items.stream().mapToInt(CalcOrderPriceBO.Item::getBuyQuantity).sum(); Integer itemCnt = items.stream().mapToInt(CalcOrderPriceBO.Item::getBuyQuantity).sum();
Integer originalTotal = items.stream().mapToInt(CalcOrderPriceBO.Item::getPresentTotal).sum(); Integer originalTotal = items.stream().mapToInt(CalcOrderPriceBO.Item::getPresentTotal).sum();

View File

@ -3,6 +3,7 @@ package cn.iocoder.mall.promotion.api.bo;
import lombok.Data; import lombok.Data;
import lombok.experimental.Accessors; import lombok.experimental.Accessors;
import java.io.Serializable;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
@ -13,7 +14,7 @@ import java.util.List;
*/ */
@Data @Data
@Accessors(chain = true) @Accessors(chain = true)
public class CouponCardDetailBO { public class CouponCardDetailBO implements Serializable {
// ========== 基本信息 BEGIN ========== // ========== 基本信息 BEGIN ==========
/** /**

View File

@ -20,10 +20,7 @@ import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.annotation.Transactional;
import java.util.Calendar; import java.util.*;
import java.util.Date;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@Service // 实际上不用添加。添加的原因是,必须 Spring 报错提示 @Service // 实际上不用添加。添加的原因是,必须 Spring 报错提示
@ -279,8 +276,10 @@ public class CouponServiceImpl implements CouponService {
public CommonResult<List<CouponCardAvailableBO>> getCouponCardList(Integer userId, List<CouponCardSpuDTO> spus) { public CommonResult<List<CouponCardAvailableBO>> getCouponCardList(Integer userId, List<CouponCardSpuDTO> spus) {
// 查询用户未使用的优惠劵列表 // 查询用户未使用的优惠劵列表
List<CouponCardDO> cards = couponCardMapper.selectListByUserIdAndStatus(userId, CouponCardStatusEnum.UNUSED.getValue()); List<CouponCardDO> cards = couponCardMapper.selectListByUserIdAndStatus(userId, CouponCardStatusEnum.UNUSED.getValue());
if (cards.isEmpty()) {
// TODO: 2019-04-19 芋艿 如果没有优惠券,处理 return CommonResult.success(Collections.emptyList());
}
// 查询优惠劵模板集合
Map<Integer, CouponTemplateDO> templates = couponTemplateMapper.selectListByIds(cards.stream().map(CouponCardDO::getTemplateId).collect(Collectors.toSet())) Map<Integer, CouponTemplateDO> templates = couponTemplateMapper.selectListByIds(cards.stream().map(CouponCardDO::getTemplateId).collect(Collectors.toSet()))
.stream().collect(Collectors.toMap(CouponTemplateDO::getId, template -> template)); .stream().collect(Collectors.toMap(CouponTemplateDO::getId, template -> template));
// 逐个判断是否可用 // 逐个判断是否可用