From b50926fa7052b4e85c9aff36816f842284c2498c Mon Sep 17 00:00:00 2001
From: xin <1099200748@qq.com>
Date: Fri, 05 Sep 2025 21:25:00 +0800
Subject: [PATCH] 订单总金额
---
oying-system/src/main/java/com/oying/modules/sh/service/impl/OrderServiceImpl.java | 174 +++++++++++++++++++++++++++++++++++++++++++++------------
1 files changed, 136 insertions(+), 38 deletions(-)
diff --git a/oying-system/src/main/java/com/oying/modules/sh/service/impl/OrderServiceImpl.java b/oying-system/src/main/java/com/oying/modules/sh/service/impl/OrderServiceImpl.java
index 7f31fb6..5137765 100644
--- a/oying-system/src/main/java/com/oying/modules/sh/service/impl/OrderServiceImpl.java
+++ b/oying-system/src/main/java/com/oying/modules/sh/service/impl/OrderServiceImpl.java
@@ -8,25 +8,22 @@
import com.oying.modules.pc.product.domain.enums.ProductStatusEnum;
import com.oying.modules.pc.product.service.ProductService;
import com.oying.modules.pc.store.domain.Store;
+import com.oying.modules.pc.store.domain.enums.StoreStatusEnum;
import com.oying.modules.pc.store.service.StoreService;
-import com.oying.modules.sh.domain.Order;
-import com.oying.modules.sh.domain.OrderProductSnapshot;
+import com.oying.modules.sh.domain.*;
import com.oying.modules.sh.domain.request.GeneratorOrder;
import com.oying.modules.sh.domain.request.ProductOrder;
+import com.oying.modules.sh.domain.request.StatusOrder;
import com.oying.modules.sh.domain.request.SubmitOrder;
import com.oying.modules.sh.domain.vo.OrderInfo;
+import com.oying.modules.sh.domain.vo.OrderResponse;
import com.oying.modules.sh.domain.vo.ProductInfo;
-import com.oying.modules.sh.service.OrderProductSnapshotService;
-import com.oying.modules.sh.service.UserAddressService;
+import com.oying.modules.sh.service.*;
import com.oying.utils.*;
-import com.oying.utils.enums.GenerateEnum;
-import com.oying.utils.enums.OrderStatusEnum;
-import com.oying.utils.enums.PayStateEnum;
-import com.oying.utils.enums.PayTypeEnum;
+import com.oying.utils.enums.*;
import lombok.RequiredArgsConstructor;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
-import com.oying.modules.sh.service.OrderService;
import com.oying.modules.sh.domain.dto.OrderQueryCriteria;
import com.oying.modules.sh.mapper.OrderMapper;
import org.springframework.stereotype.Service;
@@ -53,36 +50,54 @@
private final ProductService productService;
private final SwiftPassService swiftPassService;
private final OrderProductSnapshotService productSnapshotService;
+ private final OrderAddressSnapshotService addressSnapshotService;
private final RedisUtils redisUtils;
private final StoreService storeService;
- private final static String DESCRIBE = "哦应:";
+ private final OrderOperationLogService operationLogService;
+ private static final String DESCRIBE = "哦应:";
+ private static final String ORDER_KEY = "oying:order";
+ private static final String ORDER_STORE_KEY = "oying:order:store";
+ private static final String ORDER_CODE = "ORDER";
@Override
public PageResult<Order> queryAll(OrderQueryCriteria criteria, Page<Object> page) {
- return PageUtil.toPage(orderMapper.findAll(criteria, page));
+ criteria.setOffset(page.offset());
+ List<Order> list = orderMapper.findAll(criteria, criteria.getBlurry());
+ Long total = orderMapper.countAll(criteria, criteria.getBlurry());
+ return PageUtil.toPage(list, total);
}
@Override
public List<Order> queryAll(OrderQueryCriteria criteria) {
- return orderMapper.findAll(criteria);
+ return orderMapper.findAll(criteria, criteria.getBlurry());
}
@Override
@Transactional(rollbackFor = Exception.class)
public synchronized Order submitOrder(SubmitOrder submit, HttpServletRequest request) {
- if (!submit.getPayType().equals(PayTypeEnum.HWC)) {
- throw new BadRequestException("支付类型暂未开放");
+ switch (submit.getPayType()) {
+ case HWC:
+ case HWC2:
+ break;
+ default:
+ throw new BadRequestException("支付类型暂未开放");
}
- String orderNum = redisUtils.generateOrderSn(GenerateEnum.ORDER.getKey());
- // 总金额
- BigDecimal amount = BigDecimal.ZERO;
GeneratorOrder generator = new GeneratorOrder();
generator.setProducts(submit.getProducts());
generator.setStoreId(submit.getStoreId());
OrderInfo info = generatorOrder(generator);
+ Store store = info.getStore();
+ UserAddress address = userAddressService.getById(submit.getAddressId(), store.getLongitude(), store.getLatitude());
+ if (address == null) {
+ throw new BadRequestException("没找到用户地址");
+ }
+ if (!(address.getDistance().compareTo(BigDecimal.valueOf(store.getRadius())) <= 0)) {
+ throw new BadRequestException("超出配送范围");
+ }
+ // 订单号
+ String orderNum = redisUtils.generateSn(ORDER_KEY, GenerateEnum.ORDER.getKey());
// 商品快照
List<OrderProductSnapshot> snapshots = new ArrayList<>();
-
for (ProductInfo productInfo : info.getProducts()) {
Product product = productInfo.getProduct();
OrderProductSnapshot snapshot = new OrderProductSnapshot();
@@ -99,7 +114,6 @@
snapshot.setOriginalPrice(product.getPrice());
snapshot.setPaidPrice(product.getPrice());
BigDecimal decimal = BigDecimalUtils.multiply(product.getPrice(), productInfo.getCount());
- amount = BigDecimalUtils.add(amount, decimal);
snapshot.setActuallyPayPrice(decimal);
snapshot.setPayState(PayStateEnum.NOTPAY.getKey());
snapshots.add(snapshot);
@@ -115,23 +129,30 @@
// 订单信息
Order order = new Order();
order.setOrderNum(orderNum);
+ order.setOrderStoreNum(redisUtils.generateSn(ORDER_STORE_KEY, Math.toIntExact(submit.getStoreId())).substring(orderNum.length() - 4));
order.setOrderStatus(OrderStatusEnum.ZERO.getKey());
order.setOrderStatusDescribe(OrderStatusEnum.ZERO.getValue());
+ order.setOrderRemark(submit.getRemark() != null ? submit.getRemark() : "");
+ order.setOrderTime(submit.getDateTime());
+ order.setSendPrice(store.getDeliveryFee());
+ order.setSendType(SendTypeEnum.LY.getKey());
order.setUserId(SecurityUtils.getCurrentUserId());
order.setUsername(SecurityUtils.getCurrentUsername());
- Store store = storeService.getMerchantStore(submit.getStoreId());
order.setStoreId(submit.getStoreId());
order.setStoreName(store.getStoreName());
order.setStoreLogo(store.getLogoImageUrl());
+ order.setStoreAddress(store.getAddress());
+ order.setStoreLongitude(BigDecimal.valueOf(store.getLongitude()));
+ order.setStoreLatitude(BigDecimal.valueOf(store.getLatitude()));
order.setOrderDescribe(DESCRIBE + submit.getStoreId());
- order.setOriginalPrice(amount);
- order.setPaidPrice(amount);
- order.setActuallyPayPrice(amount);
+ order.setOriginalPrice(info.getAmount());
+ order.setPaidPrice(BigDecimalUtils.subtract(info.getAmount(), info.getPromotionAmount()));
+ order.setActuallyPayPrice(info.getPayAmount());
order.setOpenid(openid);
order.setPayType(submit.getPayType().getKey());
order.setExpireTime(expire);
order.setOpenid(openid);
- Long total = BigDecimalUtils.yuanToCents(amount);
+ Long total = BigDecimalUtils.yuanToCents(info.getAmount());
if (total > 0) {
HwcResponse response = swiftPassService.pay(StringUtils.getIp(request), total.toString(), expire,
DESCRIBE + submit.getStoreId(), openid, orderNum, submit.getPayType());
@@ -150,16 +171,48 @@
order.setPayMessage(PayStateEnum.SUCCESS.getValue());
order.setPayTime(DateUtil.localDateTimeFormat(now.toLocalDateTime(), DateUtil.SDF_YMDHMS));
}
+
+ OrderAddressSnapshot addressSnapshot = getOrderAddressSnapshot(orderNum, address);
+
+ addressSnapshotService.save(addressSnapshot);
orderMapper.insert(order);
productSnapshotService.saveBatch(snapshots);
+
+ order.setProductSnapshots(new HashSet<>(snapshots));
+ OrderResponse response = new OrderResponse(order, addressSnapshot, null);
+
+ operationLogService.create(response, OrderStatusEnum.ZERO, null);
return order;
+ }
+
+ private static OrderAddressSnapshot getOrderAddressSnapshot(String orderNum, UserAddress address) {
+ OrderAddressSnapshot snapshot = new OrderAddressSnapshot();
+ snapshot.setOrderNum(orderNum);
+ snapshot.setReceiverName(address.getReceiverName());
+ snapshot.setReceiverPhone(address.getReceiverPhone());
+ snapshot.setProvince(address.getProvince() != null ? address.getProvince() : "");
+ snapshot.setCity(address.getCity() != null ? address.getCity() : "");
+ snapshot.setDistrict(address.getDistrict() != null ? address.getDistrict() : "");
+ snapshot.setStreet(address.getStreet() != null ? address.getStreet() : "");
+ snapshot.setShortAddress(address.getShortAddress());
+ snapshot.setDetail(address.getDetail());
+ snapshot.setLongitude(address.getLongitude());
+ snapshot.setLatitude(address.getLatitude());
+ snapshot.setTag(address.getTag());
+ return snapshot;
}
@Override
@Transactional(rollbackFor = Exception.class)
public synchronized OrderInfo generatorOrder(GeneratorOrder criteria) {
+ // 门店信息
+ Store store = storeService.getById(criteria.getStoreId());
+ if (!store.getBusinessStatus().equals(StoreStatusEnum.OPEN.getValue())) {
+ throw new BadRequestException("停止营业");
+ }
List<ProductInfo> products = new ArrayList<>();
BigDecimal amount = BigDecimal.ZERO;
+ int count = 0;
for (ProductOrder productOrder : criteria.getProducts()) {
Product product = productService.getById(productOrder.getProductId());
if (product == null) {
@@ -184,25 +237,51 @@
info.setCount(productOrder.getCount());
products.add(info);
amount = BigDecimalUtils.add(amount, BigDecimalUtils.multiply(product.getPrice(), productOrder.getCount()));
+ count += productOrder.getCount();
+ }
+ if (!(amount.compareTo(store.getDeliveryMinimum()) >= 0)) {
+ throw new BadRequestException("起送金额:" + store.getDeliveryMinimum());
}
OrderInfo info = new OrderInfo();
+ info.setStore(store);
info.setProducts(products);
+ info.setPromotionAmount(BigDecimal.ZERO);
+ info.setDeliveryPrice(store.getDeliveryFee());
+ BigDecimal packagingPrice = BigDecimalUtils.multiply(store.getPackagingFee(), count);
+ info.setPackagingPrice(packagingPrice);
+ amount = BigDecimalUtils.add(amount, packagingPrice);
+ amount = BigDecimalUtils.add(amount, store.getDeliveryFee());
info.setAmount(amount);
info.setPayAmount(amount);
- info.setPromotionAmount(BigDecimal.ZERO);
- info.setUserAddresses(userAddressService.queryUserAddress());
+
+ info.setUserAddresses(userAddressService.queryUserAddress(store.getLongitude(), store.getLatitude()));
return info;
}
@Override
@Transactional(rollbackFor = Exception.class)
- public Order getByOrderNum(String orderNum) {
+ public void statusOrder(StatusOrder statusOrder) {
+ operationLog(getByOrderNum(statusOrder.getOrderNum()), statusOrder.getStatus(), null);
+ }
+
+ @Override
+ @Transactional(rollbackFor = Exception.class)
+ public OrderResponse getByOrderNum(String orderNum) {
+ return new OrderResponse(orderMapper.getByOrderNum(orderNum),
+ addressSnapshotService.queryByOrderNum(orderNum),
+ operationLogService.getByOrderNum(orderNum, ORDER_CODE));
+ }
+
+ @Override
+ @Transactional(rollbackFor = Exception.class)
+ public Order queryByOrderNum(String orderNum) {
return orderMapper.getByOrderNum(orderNum);
}
@Override
@Transactional(rollbackFor = Exception.class)
- public void paySuccess(Order order) {
+ public void operationLog(OrderResponse order, OrderStatusEnum stateEnum, String cardName) {
+ operationLogService.create(order, stateEnum, cardName);
}
@Override
@@ -213,32 +292,38 @@
@Override
@Transactional(rollbackFor = Exception.class)
- public void closeOrder(String orderNum) {
- Order order = getByOrderNum(orderNum);
+ public synchronized void cancel(String orderNum) {
+ OrderResponse response = getByOrderNum(orderNum);
+ Order order = response.getOrder();
if (order == null) {
- throw new BadRequestException("订单不存在");
+ throw new BadRequestException("订单不存在!");
+ }
+ if (!SecurityUtils.getCurrentUserId().equals(order.getUserId())) {
+ throw new BadRequestException("不能修改他人订单");
+ }
+ if (!order.getPayState().equals(PayStateEnum.NOTPAY.getKey())) {
+ throw new BadRequestException(PayStateEnum.getValue(order.getPayState()));
}
PayTypeEnum anEnum = PayTypeEnum.find(order.getPayType());
switch (anEnum) {
case HWC:
case HWC2:
JSONObject object = swiftPassService.query(orderNum, anEnum);
- if (object.getString("trade_state").equals(PayStateEnum.SUCCESS.getKey())) {
- throw new BadRequestException("订单已支付");
- }
- if (object.getString("trade_state").equals(PayStateEnum.CLOSED.getKey())) {
- throw new BadRequestException("订单已关闭");
+ if (!object.getString("trade_state").equals(PayStateEnum.NOTPAY.getKey())) {
+ throw new BadRequestException(PayStateEnum.getValue(order.getPayState()));
}
swiftPassService.closeOrder(orderNum, anEnum);
break;
}
- orderMapper.updateCloseStatus(orderNum, PayStateEnum.CLOSED.getKey());
+ operationLogService.create(response, OrderStatusEnum.NINE, null);
+ orderMapper.updateCloseStatus(orderNum, PayStateEnum.CLOSED.getKey(), PayStateEnum.CLOSED.getValue());
}
@Override
@Transactional(rollbackFor = Exception.class)
public void create(Order resources) {
orderMapper.insert(resources);
+ throw new BadRequestException("未开放");
}
@Override
@@ -252,6 +337,19 @@
@Override
@Transactional(rollbackFor = Exception.class)
public void deleteAll(List<Long> ids) {
+ Long userid = SecurityUtils.getCurrentUserId();
+ for (Long id : ids) {
+ Order order = getById(id);
+ if (order == null) {
+ throw new BadRequestException("订单不存在!");
+ }
+ if (!order.getUserId().equals(userid)) {
+ throw new BadRequestException("不能删除他人订单");
+ }
+ if (!order.getPayState().equals(PayStateEnum.NOTPAY.getKey())) {
+ throw new BadRequestException("只能删除未支付订单");
+ }
+ }
orderMapper.deleteBatchIds(ids);
}
@@ -272,7 +370,7 @@
map.put("消息", order.getPayMessage());
map.put("支付类型", order.getPayType());
map.put("支付时间", order.getPayTime());
- map.put("订单失效时间RFC3339", order.getExpireTime());
+ map.put("订单失效时间", order.getExpireTime());
map.put("openid", order.getOpenid());
map.put("APPID", order.getAppId());
map.put("创建人", order.getCreateBy());
--
Gitblit v1.9.3