前端 + 后端:创建订单,接入价格计算
parent
ff69f324d5
commit
5785827748
|
@ -59,13 +59,14 @@ export function getOrderInfo(orderId) {
|
||||||
|
|
||||||
// Cart
|
// Cart
|
||||||
|
|
||||||
export function createOrderFromCart(userAddressId, remark) {
|
export function createOrderFromCart(userAddressId, couponCardId, remark) {
|
||||||
return request({
|
return request({
|
||||||
url: '/order-api/users/order/create_order_from_cart',
|
url: '/order-api/users/order/create_order_from_cart',
|
||||||
method: 'post',
|
method: 'post',
|
||||||
params: {
|
params: {
|
||||||
userAddressId,
|
userAddressId,
|
||||||
remark,
|
remark,
|
||||||
|
couponCardId,
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -161,12 +161,14 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
const remark = '';
|
const remark = '';
|
||||||
|
const couponCardId = this.chosenCoupon >= 0 ? this.coupons[this.chosenCoupon].id : undefined;
|
||||||
|
|
||||||
if (this.from === 'direct_order') {
|
if (this.from === 'direct_order') {
|
||||||
const { skuId, quantity } = this.$route.query;
|
const { skuId, quantity } = this.$route.query;
|
||||||
const orderItems = [{
|
const orderItems = [{
|
||||||
skuId,
|
skuId,
|
||||||
quantity,
|
quantity,
|
||||||
|
couponCardId,
|
||||||
}];
|
}];
|
||||||
createOrder({
|
createOrder({
|
||||||
orderItems,
|
orderItems,
|
||||||
|
@ -184,7 +186,7 @@
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else if (this.from === 'cart') {
|
} else if (this.from === 'cart') {
|
||||||
createOrderFromCart(userAddressId, remark).then(result => {
|
createOrderFromCart(userAddressId, couponCardId, remark).then(result => {
|
||||||
if (result) {
|
if (result) {
|
||||||
// const { orderNo } = result;
|
// const { orderNo } = result;
|
||||||
this.$router.push({ //核心语句
|
this.$router.push({ //核心语句
|
||||||
|
|
|
@ -67,6 +67,7 @@ public class UsersOrderController {
|
||||||
@PostMapping("create_order_from_cart")
|
@PostMapping("create_order_from_cart")
|
||||||
@ApiOperation("创建订单购物车")
|
@ApiOperation("创建订单购物车")
|
||||||
public CommonResult<OrderCreateBO> createOrderFromCart(@RequestParam("userAddressId") Integer userAddressId,
|
public CommonResult<OrderCreateBO> createOrderFromCart(@RequestParam("userAddressId") Integer userAddressId,
|
||||||
|
@RequestParam(value = "couponCardId", required = false) Integer couponCardId,
|
||||||
@RequestParam(value = "remark", required = false) String remark,
|
@RequestParam(value = "remark", required = false) String remark,
|
||||||
HttpServletRequest request) {
|
HttpServletRequest request) {
|
||||||
Integer userId = UserSecurityContextHolder.getContext().getUserId();
|
Integer userId = UserSecurityContextHolder.getContext().getUserId();
|
||||||
|
@ -78,7 +79,7 @@ public class UsersOrderController {
|
||||||
// 创建 OrderCreateDTO 对象
|
// 创建 OrderCreateDTO 对象
|
||||||
OrderCreateDTO orderCreateDTO = OrderConvertAPP.INSTANCE.createOrderCreateDTO(userId, userAddressId,
|
OrderCreateDTO orderCreateDTO = OrderConvertAPP.INSTANCE.createOrderCreateDTO(userId, userAddressId,
|
||||||
remark, HttpUtil.getIp(request),
|
remark, HttpUtil.getIp(request),
|
||||||
cartItems);
|
cartItems, couponCardId);
|
||||||
// 创建订单
|
// 创建订单
|
||||||
CommonResult<OrderCreateBO> createResult= orderService.createOrder(orderCreateDTO);
|
CommonResult<OrderCreateBO> createResult= orderService.createOrder(orderCreateDTO);
|
||||||
if (createResult.isError()) {
|
if (createResult.isError()) {
|
||||||
|
|
|
@ -40,15 +40,15 @@ public interface OrderConvertAPP {
|
||||||
@Mappings({})
|
@Mappings({})
|
||||||
List<OrderCreateItemDTO> convert(List<CartItemBO> cartItems);
|
List<OrderCreateItemDTO> convert(List<CartItemBO> cartItems);
|
||||||
|
|
||||||
default OrderCreateDTO createOrderCreateDTO(Integer userId, Integer userAddressId,
|
default OrderCreateDTO createOrderCreateDTO(Integer userId, Integer userAddressId, String remark, String ip,
|
||||||
String remark, String ip,
|
List<CartItemBO> cartItems, Integer couponCardId) {
|
||||||
List<CartItemBO> cartItems) {
|
|
||||||
return new OrderCreateDTO()
|
return new OrderCreateDTO()
|
||||||
.setUserId(userId)
|
.setUserId(userId)
|
||||||
.setUserAddressId(userAddressId)
|
.setUserAddressId(userAddressId)
|
||||||
.setRemark(remark)
|
.setRemark(remark)
|
||||||
.setIp(ip)
|
.setIp(ip)
|
||||||
.setOrderItems(this.convert(cartItems));
|
.setOrderItems(this.convert(cartItems))
|
||||||
|
.setCouponCardId(couponCardId);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,6 +24,10 @@ public class OrderCreatePO implements Serializable {
|
||||||
*/
|
*/
|
||||||
@NotNull(message = "用户地址id不能为空!")
|
@NotNull(message = "用户地址id不能为空!")
|
||||||
private Integer userAddressId;
|
private Integer userAddressId;
|
||||||
|
/**
|
||||||
|
* 优惠劵编号
|
||||||
|
*/
|
||||||
|
private Integer couponCardId;
|
||||||
/**
|
/**
|
||||||
* 备注
|
* 备注
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -142,7 +142,7 @@ public class CalcOrderPriceBO {
|
||||||
*/
|
*/
|
||||||
private Integer discountTotal;
|
private Integer discountTotal;
|
||||||
/**
|
/**
|
||||||
* 邮费
|
* 邮费 TODO 芋艿,将 postage 改成 logistics
|
||||||
*/
|
*/
|
||||||
private Integer postageTotal;
|
private Integer postageTotal;
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -24,6 +24,10 @@ public class OrderCreateDTO implements Serializable {
|
||||||
* 用户地址
|
* 用户地址
|
||||||
*/
|
*/
|
||||||
private Integer userAddressId;
|
private Integer userAddressId;
|
||||||
|
/**
|
||||||
|
* 优惠劵编号
|
||||||
|
*/
|
||||||
|
private Integer couponCardId;
|
||||||
/**
|
/**
|
||||||
* 备注
|
* 备注
|
||||||
*/
|
*/
|
||||||
|
@ -37,4 +41,5 @@ public class OrderCreateDTO implements Serializable {
|
||||||
/// order item
|
/// order item
|
||||||
|
|
||||||
private List<OrderCreateItemDTO> orderItems;
|
private List<OrderCreateItemDTO> orderItems;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,39 +0,0 @@
|
||||||
package cn.iocoder.mall.order.biz;
|
|
||||||
|
|
||||||
import cn.iocoder.mall.order.biz.dataobject.OrderItemDO;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 订单常用
|
|
||||||
*
|
|
||||||
* @author Sin
|
|
||||||
* @time 2019-03-23 11:51
|
|
||||||
*/
|
|
||||||
public interface OrderCommon {
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 计算总价格
|
|
||||||
*
|
|
||||||
* @param items
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
Integer calculatedPrice(List<OrderItemDO> items);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 计算订单实付金额
|
|
||||||
*
|
|
||||||
* @param items
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
Integer calculatedAmount(List<OrderItemDO> items);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 计算物流金额
|
|
||||||
*
|
|
||||||
* @param items
|
|
||||||
* @return
|
|
||||||
*/
|
|
||||||
Integer calculatedLogisticsPrice(List<OrderItemDO> items);
|
|
||||||
}
|
|
|
@ -1,54 +0,0 @@
|
||||||
package cn.iocoder.mall.order.biz;
|
|
||||||
|
|
||||||
import cn.iocoder.mall.order.biz.dataobject.OrderItemDO;
|
|
||||||
import org.springframework.stereotype.Component;
|
|
||||||
import org.springframework.util.CollectionUtils;
|
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* 订单常用
|
|
||||||
*
|
|
||||||
* @author Sin
|
|
||||||
* @time 2019-03-23 11:53
|
|
||||||
*/
|
|
||||||
@Component
|
|
||||||
public class OrderCommonImpl implements OrderCommon {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Integer calculatedPrice(List<OrderItemDO> items) {
|
|
||||||
if (CollectionUtils.isEmpty(items)) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
AtomicInteger totalPrice = new AtomicInteger(0);
|
|
||||||
items.forEach(orderItemDO -> {
|
|
||||||
totalPrice.addAndGet(orderItemDO.getPrice() * orderItemDO.getQuantity());
|
|
||||||
});
|
|
||||||
return totalPrice.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Integer calculatedAmount(List<OrderItemDO> items) {
|
|
||||||
if (CollectionUtils.isEmpty(items)) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
AtomicInteger totalAmount = new AtomicInteger(0);
|
|
||||||
items.forEach(orderItemDO -> {
|
|
||||||
totalAmount.addAndGet(orderItemDO.getPayAmount() * orderItemDO.getQuantity());
|
|
||||||
});
|
|
||||||
return totalAmount.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Integer calculatedLogisticsPrice(List<OrderItemDO> items) {
|
|
||||||
if (CollectionUtils.isEmpty(items)) {
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
AtomicInteger totalAmount = new AtomicInteger(0);
|
|
||||||
items.forEach(orderItemDO -> {
|
|
||||||
totalAmount.addAndGet(orderItemDO.getLogisticsPrice());
|
|
||||||
});
|
|
||||||
return totalAmount.get();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -29,15 +29,27 @@ public class OrderDO extends DeletableDO {
|
||||||
*/
|
*/
|
||||||
private String orderNo;
|
private String orderNo;
|
||||||
/**
|
/**
|
||||||
* 价格(分)
|
* 购买(商品)总金额,单位:分
|
||||||
*/
|
*/
|
||||||
private Integer price;
|
private Integer buyPrice;
|
||||||
|
/**
|
||||||
|
* 优惠总金额,单位:分。
|
||||||
|
*/
|
||||||
|
private Integer discountPrice;
|
||||||
/**
|
/**
|
||||||
* 物流金额 (分)
|
* 物流金额 (分)
|
||||||
*/
|
*/
|
||||||
private Integer logisticsPrice;
|
private Integer logisticsPrice;
|
||||||
/**
|
/**
|
||||||
* 交易金额
|
* 最终金额,单位:分
|
||||||
|
*
|
||||||
|
* buyPrice + logisticsPrice - discountPrice = presentPrice
|
||||||
|
*/
|
||||||
|
private Integer presentPrice;
|
||||||
|
/**
|
||||||
|
* 实际已支付金额,单位:分
|
||||||
|
*
|
||||||
|
* 初始时,金额为 0 。等到支付成功后,会进行更新。
|
||||||
*/
|
*/
|
||||||
private Integer payAmount;
|
private Integer payAmount;
|
||||||
|
|
||||||
|
|
|
@ -48,22 +48,6 @@ public class OrderItemDO extends DeletableDO {
|
||||||
* 数量
|
* 数量
|
||||||
*/
|
*/
|
||||||
private Integer quantity;
|
private Integer quantity;
|
||||||
/**
|
|
||||||
* 商品成交单价(分)
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
private Integer price;
|
|
||||||
/**
|
|
||||||
* 支付金额(实付金额)
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
private Integer payAmount;
|
|
||||||
/**
|
|
||||||
* 物流金额 (分)
|
|
||||||
*/
|
|
||||||
@Deprecated
|
|
||||||
private Integer logisticsPrice;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 原始单价,单位:分。
|
* 原始单价,单位:分。
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -9,7 +9,6 @@ import cn.iocoder.mall.order.api.constant.OrderErrorCodeEnum;
|
||||||
import cn.iocoder.mall.order.api.constant.OrderHasReturnExchangeEnum;
|
import cn.iocoder.mall.order.api.constant.OrderHasReturnExchangeEnum;
|
||||||
import cn.iocoder.mall.order.api.constant.OrderStatusEnum;
|
import cn.iocoder.mall.order.api.constant.OrderStatusEnum;
|
||||||
import cn.iocoder.mall.order.api.dto.*;
|
import cn.iocoder.mall.order.api.dto.*;
|
||||||
import cn.iocoder.mall.order.biz.OrderCommon;
|
|
||||||
import cn.iocoder.mall.order.biz.constants.OrderDeliveryTypeEnum;
|
import cn.iocoder.mall.order.biz.constants.OrderDeliveryTypeEnum;
|
||||||
import cn.iocoder.mall.order.biz.constants.OrderRecipientTypeEnum;
|
import cn.iocoder.mall.order.biz.constants.OrderRecipientTypeEnum;
|
||||||
import cn.iocoder.mall.order.biz.convert.*;
|
import cn.iocoder.mall.order.biz.convert.*;
|
||||||
|
@ -25,6 +24,7 @@ import com.google.common.collect.Lists;
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
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 org.springframework.util.Assert;
|
||||||
import org.springframework.util.CollectionUtils;
|
import org.springframework.util.CollectionUtils;
|
||||||
|
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
|
@ -57,11 +57,11 @@ public class OrderServiceImpl implements OrderService {
|
||||||
private OrderRecipientMapper orderRecipientMapper;
|
private OrderRecipientMapper orderRecipientMapper;
|
||||||
@Autowired
|
@Autowired
|
||||||
private OrderCancelMapper orderCancelMapper;
|
private OrderCancelMapper orderCancelMapper;
|
||||||
@Autowired
|
|
||||||
private OrderCommon orderCommon;
|
|
||||||
|
|
||||||
@Reference
|
@Reference
|
||||||
private ProductSpuService productSpuService;
|
private ProductSpuService productSpuService;
|
||||||
|
@Autowired
|
||||||
|
private CartServiceImpl cartService;
|
||||||
@Reference
|
@Reference
|
||||||
private UserAddressService userAddressService;
|
private UserAddressService userAddressService;
|
||||||
@Reference
|
@Reference
|
||||||
|
@ -196,61 +196,70 @@ public class OrderServiceImpl implements OrderService {
|
||||||
// 获取商品信息
|
// 获取商品信息
|
||||||
Set<Integer> skuIds = orderItemDOList.stream()
|
Set<Integer> skuIds = orderItemDOList.stream()
|
||||||
.map(orderItemDO -> orderItemDO.getSkuId()).collect(Collectors.toSet());
|
.map(orderItemDO -> orderItemDO.getSkuId()).collect(Collectors.toSet());
|
||||||
|
|
||||||
CommonResult<List<ProductSkuDetailBO>> productResult = productSpuService.getProductSkuDetailList(skuIds);
|
CommonResult<List<ProductSkuDetailBO>> productResult = productSpuService.getProductSkuDetailList(skuIds);
|
||||||
|
|
||||||
// 校验商品信息
|
// 校验商品信息
|
||||||
if (productResult.isError()) {
|
if (productResult.isError()) {
|
||||||
return ServiceExceptionUtil.error(OrderErrorCodeEnum.ORDER_GET_SKU_FAIL.getCode());
|
return ServiceExceptionUtil.error(OrderErrorCodeEnum.ORDER_GET_SKU_FAIL.getCode());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (productResult.getData() == null) {
|
if (productResult.getData() == null) {
|
||||||
return ServiceExceptionUtil.error(OrderErrorCodeEnum.ORDER_GET_SKU_NOT_EXISTENT.getCode());
|
return ServiceExceptionUtil.error(OrderErrorCodeEnum.ORDER_GET_SKU_NOT_EXISTENT.getCode());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (orderItemDTOList.size() != productResult.getData().size()) {
|
if (orderItemDTOList.size() != productResult.getData().size()) {
|
||||||
return ServiceExceptionUtil.error(OrderErrorCodeEnum.ORDER_GET_GOODS_INFO_INCORRECT.getCode());
|
return ServiceExceptionUtil.error(OrderErrorCodeEnum.ORDER_GET_GOODS_INFO_INCORRECT.getCode());
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
// 价格计算
|
||||||
|
CommonResult<CalcOrderPriceBO> calcOrderPriceResult = calcOrderPrice(productResult.getData(), orderCreateDTO);
|
||||||
|
if (calcOrderPriceResult.isError()) {
|
||||||
|
return CommonResult.error(calcOrderPriceResult);
|
||||||
|
}
|
||||||
|
CalcOrderPriceBO calcOrderPrice = calcOrderPriceResult.getData();
|
||||||
|
|
||||||
// 设置 orderItem
|
// 设置 orderItem
|
||||||
|
|
||||||
Map<Integer, ProductSkuDetailBO> productSpuBOMap = productResult.getData()
|
Map<Integer, ProductSkuDetailBO> productSpuBOMap = productResult.getData()
|
||||||
.stream().collect(Collectors.toMap(o -> o.getId(), o -> o));
|
.stream().collect(Collectors.toMap(ProductSkuDetailBO::getId, o -> o)); // 商品 SKU 信息的集合
|
||||||
|
Map<Integer, CalcOrderPriceBO.Item> priceItemMap = new HashMap<>();
|
||||||
|
calcOrderPrice.getItemGroups().forEach(itemGroup ->
|
||||||
|
itemGroup.getItems().forEach(item -> priceItemMap.put(item.getId(), item)));
|
||||||
|
|
||||||
for (OrderItemDO orderItemDO : orderItemDOList) {
|
for (OrderItemDO orderItemDO : orderItemDOList) {
|
||||||
ProductSkuDetailBO productSkuDetailBO = productSpuBOMap.get(orderItemDO.getSkuId());
|
ProductSkuDetailBO productSkuDetailBO = productSpuBOMap.get(orderItemDO.getSkuId());
|
||||||
if (productSkuDetailBO.getQuantity() <= 0) {
|
if (productSkuDetailBO.getQuantity() <= 0) {
|
||||||
return ServiceExceptionUtil.error(OrderErrorCodeEnum.ORDER_INSUFFICIENT_INVENTORY.getCode());
|
return ServiceExceptionUtil.error(OrderErrorCodeEnum.ORDER_INSUFFICIENT_INVENTORY.getCode());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (productSkuDetailBO.getPrice() <= 0) {
|
if (productSkuDetailBO.getPrice() <= 0) {
|
||||||
return ServiceExceptionUtil.error(OrderErrorCodeEnum.ORDER_GOODS_AMOUNT_INCORRECT.getCode());
|
return ServiceExceptionUtil.error(OrderErrorCodeEnum.ORDER_GOODS_AMOUNT_INCORRECT.getCode());
|
||||||
}
|
}
|
||||||
|
// 设置 SKU 信息
|
||||||
orderItemDO.setSkuImage(Optional.ofNullable(productSkuDetailBO.getSpu().getPicUrls().get(0)).get());
|
orderItemDO.setSkuImage(Optional.ofNullable(productSkuDetailBO.getSpu().getPicUrls().get(0)).get());
|
||||||
orderItemDO.setSkuName(productSkuDetailBO.getSpu().getName());
|
orderItemDO.setSkuName(productSkuDetailBO.getSpu().getName());
|
||||||
orderItemDO.setPrice(productSkuDetailBO.getPrice());
|
// 设置价格信息
|
||||||
orderItemDO.setLogisticsPrice(0);
|
CalcOrderPriceBO.Item priceItem = priceItemMap.get(orderItemDO.getSkuId());
|
||||||
|
Assert.notNull(priceItem, "商品计算价格为空");
|
||||||
int payAmount = orderItemDO.getQuantity() * orderItemDO.getPrice();
|
orderItemDO.setOriginPrice(priceItem.getOriginPrice())
|
||||||
orderItemDO.setPayAmount(payAmount);
|
.setBuyPrice(priceItem.getBuyPrice())
|
||||||
|
.setPresentPrice(priceItem.getPresentPrice())
|
||||||
|
.setBuyTotal(priceItem.getBuyTotal())
|
||||||
|
.setDiscountTotal(priceItem.getDiscountTotal())
|
||||||
|
.setPresentTotal(priceItem.getPresentTotal());
|
||||||
}
|
}
|
||||||
|
|
||||||
// order
|
// order
|
||||||
|
|
||||||
// TODO: 2019-04-11 Sin 订单号需要生成规则
|
// TODO: 2019-04-11 Sin 订单号需要生成规则
|
||||||
String orderNo = UUID.randomUUID().toString().replace("-", "").substring(0, 16);
|
String orderNo = UUID.randomUUID().toString().replace("-", "").substring(0, 16);
|
||||||
Integer totalAmount = orderCommon.calculatedAmount(orderItemDOList);
|
// Integer totalAmount = orderCommon.calculatedAmount(orderItemDOList);
|
||||||
Integer totalPrice = orderCommon.calculatedPrice(orderItemDOList);
|
// Integer totalPrice = orderCommon.calculatedPrice(orderItemDOList);
|
||||||
Integer totalLogisticsPrice = orderCommon.calculatedLogisticsPrice(orderItemDOList);
|
// Integer totalLogisticsPrice = orderCommon.calculatedLogisticsPrice(orderItemDOList);
|
||||||
OrderDO orderDO = new OrderDO()
|
OrderDO orderDO = new OrderDO()
|
||||||
.setUserId(userId)
|
.setUserId(userId)
|
||||||
.setOrderNo(orderNo)
|
.setOrderNo(orderNo)
|
||||||
.setPrice(totalPrice)
|
.setBuyPrice(calcOrderPrice.getFee().getBuyTotal())
|
||||||
.setPayAmount(totalAmount)
|
.setDiscountPrice(calcOrderPrice.getFee().getDiscountTotal())
|
||||||
.setLogisticsPrice(totalLogisticsPrice)
|
.setLogisticsPrice(calcOrderPrice.getFee().getPostageTotal())
|
||||||
|
.setPresentPrice(calcOrderPrice.getFee().getPresentTotal())
|
||||||
|
.setPayAmount(0)
|
||||||
.setClosingTime(null)
|
.setClosingTime(null)
|
||||||
.setDeliveryTime(null)
|
.setDeliveryTime(null)
|
||||||
.setPaymentTime(null)
|
.setPaymentTime(null)
|
||||||
|
@ -330,6 +339,19 @@ public class OrderServiceImpl implements OrderService {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private CommonResult<CalcOrderPriceBO> calcOrderPrice(List<ProductSkuDetailBO> skus, OrderCreateDTO orderCreateDTO) {
|
||||||
|
// 创建计算的 DTO
|
||||||
|
CalcOrderPriceDTO calcOrderPriceDTO = new CalcOrderPriceDTO()
|
||||||
|
.setUserId(orderCreateDTO.getUserId())
|
||||||
|
.setItems(new ArrayList<>(skus.size()))
|
||||||
|
.setCouponCardId(orderCreateDTO.getCouponCardId());
|
||||||
|
for (ProductSkuDetailBO item : skus) {
|
||||||
|
calcOrderPriceDTO.getItems().add(new CalcOrderPriceDTO.Item(item.getId(), item.getQuantity(), true));
|
||||||
|
}
|
||||||
|
// 执行计算
|
||||||
|
return cartService.calcOrderPrice(calcOrderPriceDTO);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CommonResult updateOrderItem(OrderItemUpdateDTO orderUpdateDTO) {
|
public CommonResult updateOrderItem(OrderItemUpdateDTO orderUpdateDTO) {
|
||||||
OrderItemDO orderItemDO = OrderItemConvert.INSTANCE.convert(orderUpdateDTO);
|
OrderItemDO orderItemDO = OrderItemConvert.INSTANCE.convert(orderUpdateDTO);
|
||||||
|
@ -352,17 +374,21 @@ public class OrderServiceImpl implements OrderService {
|
||||||
}
|
}
|
||||||
|
|
||||||
// 先更新金额
|
// 先更新金额
|
||||||
orderItemMapper.updateById(new OrderItemDO().setId(orderItemId).setPayAmount(payAmount));
|
orderItemMapper.updateById(new OrderItemDO().setId(orderItemId)
|
||||||
|
// .setPayAmount(payAmount) TODO 芋艿,这里要修改
|
||||||
|
);
|
||||||
|
|
||||||
// 再重新计算订单金额
|
// 再重新计算订单金额
|
||||||
List<OrderItemDO> orderItemDOList = orderItemMapper
|
List<OrderItemDO> orderItemDOList = orderItemMapper
|
||||||
.selectByDeletedAndOrderId(orderId, DeletedStatusEnum.DELETED_NO.getValue());
|
.selectByDeletedAndOrderId(orderId, DeletedStatusEnum.DELETED_NO.getValue());
|
||||||
Integer price = orderCommon.calculatedPrice(orderItemDOList);
|
// Integer price = orderCommon.calculatedPrice(orderItemDOList);
|
||||||
Integer amount = orderCommon.calculatedAmount(orderItemDOList);
|
// Integer amount = orderCommon.calculatedAmount(orderItemDOList);
|
||||||
|
Integer price = -1; // TODO 芋艿,这里要修改,价格
|
||||||
|
Integer amount = -1;
|
||||||
orderMapper.updateById(
|
orderMapper.updateById(
|
||||||
new OrderDO()
|
new OrderDO()
|
||||||
.setId(orderId)
|
.setId(orderId)
|
||||||
.setPrice(price)
|
// .setPrice(price) TODO 芋艿,这里要修改
|
||||||
.setPayAmount(amount)
|
.setPayAmount(amount)
|
||||||
);
|
);
|
||||||
return CommonResult.success(null);
|
return CommonResult.success(null);
|
||||||
|
@ -495,7 +521,8 @@ public class OrderServiceImpl implements OrderService {
|
||||||
);
|
);
|
||||||
|
|
||||||
// 更新订单 amount
|
// 更新订单 amount
|
||||||
Integer totalAmount = orderCommon.calculatedAmount(effectiveOrderItems);
|
// Integer totalAmount = orderCommon.calculatedAmount(effectiveOrderItems);
|
||||||
|
Integer totalAmount = -1; // TODO 芋艿,需要修改下,价格相关
|
||||||
orderMapper.updateById(
|
orderMapper.updateById(
|
||||||
new OrderDO()
|
new OrderDO()
|
||||||
.setId(orderId)
|
.setId(orderId)
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
|
|
||||||
<sql id="FIELDS">
|
<sql id="FIELDS">
|
||||||
id, order_id, order_no, sku_id, sku_name, sku_image, order_logistics_id,
|
id, order_id, order_no, sku_id, sku_name, sku_image, order_logistics_id,
|
||||||
quantity, price, pay_amount,
|
quantity, origin_price, buy_price, present_price, buy_total, discount_total, present_total,
|
||||||
payment_time, delivery_time, receiver_time, closing_time,
|
payment_time, delivery_time, receiver_time, closing_time,
|
||||||
has_return_exchange, delivery_type, status,
|
has_return_exchange, delivery_type, status,
|
||||||
create_time, update_time, deleted
|
create_time, update_time, deleted
|
||||||
|
@ -13,20 +13,20 @@
|
||||||
<!--
|
<!--
|
||||||
插入数据
|
插入数据
|
||||||
-->
|
-->
|
||||||
<insert id="insert" parameterType="OrderItemDO" useGeneratedKeys="true" keyColumn="id" keyProperty="id">
|
<insert id="insert" useGeneratedKeys="true" keyColumn="id" keyProperty="id">
|
||||||
INSERT INTO `order_item` (
|
INSERT INTO `order_item` (
|
||||||
order_id, order_no, sku_id, sku_name, sku_image, order_logistics_id,
|
order_id, order_no, sku_id, sku_name, sku_image, order_logistics_id,
|
||||||
quantity, price, pay_amount,
|
quantity, origin_price, buy_price, present_price, buy_total, discount_total, present_total,
|
||||||
payment_time, delivery_time, receiver_time, closing_time,
|
payment_time, delivery_time, receiver_time, closing_time,
|
||||||
has_return_exchange, delivery_type, status,
|
has_return_exchange, delivery_type, status,
|
||||||
create_time, update_time, deleted
|
create_time, update_time, deleted
|
||||||
) VALUES
|
) VALUES
|
||||||
<foreach collection="list" item="item" separator="," open="(" close=")">
|
<foreach collection="list" item="item" separator=",">
|
||||||
#{item.orderId}, #{item.orderNo}, #{item.skuId}, #{item.skuName}, #{item.skuImage}, #{item.orderLogisticsId},
|
(#{item.orderId}, #{item.orderNo}, #{item.skuId}, #{item.skuName}, #{item.skuImage}, #{item.orderLogisticsId},
|
||||||
#{item.quantity}, #{item.price}, #{item.payAmount},
|
#{item.quantity}, #{item.originPrice}, #{item.buyPrice}, #{item.presentPrice}, #{item.buyTotal}, #{item.discountTotal}, #{item.presentTotal},
|
||||||
#{item.paymentTime}, #{item.deliveryTime}, #{item.receiverTime}, #{item.closingTime},
|
#{item.paymentTime}, #{item.deliveryTime}, #{item.receiverTime}, #{item.closingTime},
|
||||||
#{item.hasReturnExchange}, #{item.deliveryType}, #{item.status},
|
#{item.hasReturnExchange}, #{item.deliveryType}, #{item.status},
|
||||||
#{item.createTime}, #{item.updateTime}, #{item.deleted}
|
#{item.createTime}, #{item.updateTime}, #{item.deleted})
|
||||||
</foreach>
|
</foreach>
|
||||||
</insert>
|
</insert>
|
||||||
|
|
||||||
|
@ -56,12 +56,13 @@
|
||||||
<if test="orderItemDO.quantity != null">
|
<if test="orderItemDO.quantity != null">
|
||||||
, quantity = #{orderItemDO.quantity}
|
, quantity = #{orderItemDO.quantity}
|
||||||
</if>
|
</if>
|
||||||
<if test="orderItemDO.price != null">
|
<!-- TODO 芋艿 需要改 -->
|
||||||
, price = #{orderItemDO.price}
|
<!-- <if test="orderItemDO.price != null">-->
|
||||||
</if>
|
<!-- , price = #{orderItemDO.price}-->
|
||||||
<if test="orderItemDO.payAmount != null">
|
<!-- </if>-->
|
||||||
, pay_amount = #{orderItemDO.payAmount}
|
<!-- <if test="orderItemDO.payAmount != null">-->
|
||||||
</if>
|
<!-- , pay_amount = #{orderItemDO.payAmount}-->
|
||||||
|
<!-- </if>-->
|
||||||
|
|
||||||
<if test="orderItemDO.paymentTime != null">
|
<if test="orderItemDO.paymentTime != null">
|
||||||
, payment_time = #{orderItemDO.paymentTime}
|
, payment_time = #{orderItemDO.paymentTime}
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
<mapper namespace="cn.iocoder.mall.order.biz.dao.OrderMapper">
|
<mapper namespace="cn.iocoder.mall.order.biz.dao.OrderMapper">
|
||||||
|
|
||||||
<sql id="FIELDS">
|
<sql id="FIELDS">
|
||||||
id, user_id, order_no, price, pay_amount, logistics_price,
|
id, user_id, order_no, buy_price, discount_price, logistics_price, present_price, pay_amount,
|
||||||
payment_time, delivery_time, receiver_time, closing_time,
|
payment_time, delivery_time, receiver_time, closing_time,
|
||||||
has_return_exchange,
|
has_return_exchange,
|
||||||
status, remark, create_time, update_time, `deleted`
|
status, remark, create_time, update_time, `deleted`
|
||||||
|
@ -14,12 +14,12 @@
|
||||||
-->
|
-->
|
||||||
<insert id="insert" parameterType="OrderDO" useGeneratedKeys="true" keyColumn="id" keyProperty="id">
|
<insert id="insert" parameterType="OrderDO" useGeneratedKeys="true" keyColumn="id" keyProperty="id">
|
||||||
INSERT INTO `order` (
|
INSERT INTO `order` (
|
||||||
user_id, order_no, price, pay_amount, logistics_price,
|
user_id, order_no, buy_price, discount_price, logistics_price, present_price, pay_amount,
|
||||||
payment_time, delivery_time, receiver_time, closing_time,
|
payment_time, delivery_time, receiver_time, closing_time,
|
||||||
has_return_exchange,
|
has_return_exchange,
|
||||||
status, remark, create_time, update_time, `deleted`
|
status, remark, create_time, update_time, `deleted`
|
||||||
) VALUES (
|
) VALUES (
|
||||||
#{userId}, #{orderNo}, #{price}, #{payAmount}, #{logisticsPrice},
|
#{userId}, #{orderNo}, #{buyPrice}, #{discountPrice}, #{logisticsPrice}, #{presentPrice}, #{payAmount},
|
||||||
#{paymentTime}, #{deliveryTime}, #{receiverTime}, #{closingTime},
|
#{paymentTime}, #{deliveryTime}, #{receiverTime}, #{closingTime},
|
||||||
#{hasReturnExchange},
|
#{hasReturnExchange},
|
||||||
#{status}, #{remark}, #{createTime}, #{updateTime}, #{deleted}
|
#{status}, #{remark}, #{createTime}, #{updateTime}, #{deleted}
|
||||||
|
@ -34,15 +34,15 @@
|
||||||
<if test="orderNo != null">
|
<if test="orderNo != null">
|
||||||
, order_no = #{orderNo}
|
, order_no = #{orderNo}
|
||||||
</if>
|
</if>
|
||||||
<if test="price != null">
|
<!-- <if test="price != null">--> <!-- TODO 后面要改下 -->
|
||||||
, price = #{price}
|
<!-- , price = #{price}-->
|
||||||
</if>
|
<!-- </if>-->
|
||||||
<if test="payAmount != null">
|
<!-- <if test="payAmount != null">-->
|
||||||
, pay_amount = #{payAmount}
|
<!-- , pay_amount = #{payAmount}-->
|
||||||
</if>
|
<!-- </if>-->
|
||||||
<if test="logisticsPrice != null">
|
<!-- <if test="logisticsPrice != null">-->
|
||||||
, logistics_price = #{logisticsPrice}
|
<!-- , logistics_price = #{logisticsPrice}-->
|
||||||
</if>
|
<!-- </if>-->
|
||||||
|
|
||||||
<if test="paymentTime != null">
|
<if test="paymentTime != null">
|
||||||
, payment_time = #{paymentTime}
|
, payment_time = #{paymentTime}
|
||||||
|
@ -129,7 +129,7 @@
|
||||||
SELECT
|
SELECT
|
||||||
COUNT(*)
|
COUNT(*)
|
||||||
FROM `order`
|
FROM `order`
|
||||||
WHERE 1 = 1
|
WHERE 1 = 1 <!-- TODO 芋艿 不要 1=1 ,会有问题,使用 where 标签 -->
|
||||||
<include refid="selectWhere" />
|
<include refid="selectWhere" />
|
||||||
</select>
|
</select>
|
||||||
|
|
||||||
|
@ -140,7 +140,7 @@
|
||||||
SELECT
|
SELECT
|
||||||
<include refid="FIELDS" />
|
<include refid="FIELDS" />
|
||||||
FROM `order`
|
FROM `order`
|
||||||
WHERE 1 = 1
|
WHERE 1 = 1 <!-- TODO 芋艿 不要 1=1 ,会有问题,使用 where 标签 -->
|
||||||
<include refid="selectWhere" />
|
<include refid="selectWhere" />
|
||||||
LIMIT ${pageNo * pageSize}, ${pageSize}
|
LIMIT ${pageNo * pageSize}, ${pageSize}
|
||||||
</select>
|
</select>
|
||||||
|
|
Loading…
Reference in New Issue