|
@@ -0,0 +1,929 @@
|
|
|
+package com.shop.service;
|
|
|
+ * Created by 17173 on 2018/3/13.
|
|
|
+ */
|
|
|
+
|
|
|
+import com.alibaba.fastjson.JSON;
|
|
|
+import com.github.miemiedev.mybatis.paginator.domain.PageBounds;
|
|
|
+import com.github.miemiedev.mybatis.paginator.domain.PageList;
|
|
|
+import com.github.miemiedev.mybatis.paginator.domain.Paginator;
|
|
|
+import com.shop.constant.DmConstant;
|
|
|
+import com.shop.constant.MessageModel;
|
|
|
+import com.shop.dao.OrderDao;
|
|
|
+import com.shop.dao.ProductDao;
|
|
|
+import com.shop.exception.ParamException;
|
|
|
+import com.shop.gto.IndexDto;
|
|
|
+import com.shop.gto.OrderDto;
|
|
|
+import com.shop.model.*;
|
|
|
+import com.shop.util.AssertUtil;
|
|
|
+import com.shop.util.MessageModelUtil;
|
|
|
+import com.shop.vo.LoginIdentity;
|
|
|
+import org.apache.commons.lang3.StringUtils;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.stereotype.Service;
|
|
|
+import org.springframework.transaction.annotation.Transactional;
|
|
|
+
|
|
|
+import java.math.BigDecimal;
|
|
|
+import java.util.*;
|
|
|
+
|
|
|
+
|
|
|
+ * @author DY
|
|
|
+ * @create 2018-03-13 18:20
|
|
|
+ **/
|
|
|
+@Service
|
|
|
+@Transactional
|
|
|
+public class OrderService {
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private OrderDao orderDao;
|
|
|
+ @Autowired
|
|
|
+ private ProductDao productDao;
|
|
|
+
|
|
|
+
|
|
|
+ * @author DY
|
|
|
+ * @create 2018/3/13 19:43
|
|
|
+ * 订单总数,销售总额,昨日销售总额,近七天销售总额接口接口
|
|
|
+ */
|
|
|
+ public MessageModel order_total_amount(LoginIdentity loginIdentity) {
|
|
|
+ MessageModel messageModel = new MessageModel();
|
|
|
+ Map map = new HashMap();
|
|
|
+ OrderDto orderDto = getOrderDto(loginIdentity, DmConstant.VERSION_ONE);
|
|
|
+
|
|
|
+ orderDto.setTime(0);
|
|
|
+ IndexDto indexDto = orderDao.queryOrderCountAmountTotalByUserId(orderDto);
|
|
|
+ map.put("orderTotalCount", indexDto.getOrderTotalCount());
|
|
|
+ map.put("orderTotalPriceToday", indexDto.getOrderTotalPrice());
|
|
|
+
|
|
|
+ orderDto.setTime(1);
|
|
|
+ indexDto = orderDao.queryOrderCountAmountTotalByUserId(orderDto);
|
|
|
+ map.put("orderTotalPriceYesterday", indexDto.getOrderTotalPrice());
|
|
|
+
|
|
|
+ orderDto.setTime(7);
|
|
|
+ indexDto = orderDao.queryOrderAmountTotalByUserId(orderDto);
|
|
|
+ BigDecimal totalPriceAweek = indexDto.getOrderTotalPrice();
|
|
|
+ map.put("orderTotalPriceAweek", totalPriceAweek);
|
|
|
+ messageModel.setCode(DmConstant.OPS_SUCCESS_CODE);
|
|
|
+ messageModel.setMsg(DmConstant.OPS_SUCCESS_MSG);
|
|
|
+ messageModel.setData(map);
|
|
|
+ return messageModel;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ private OrderDto getOrderDto(LoginIdentity loginIdentity, Integer version) {
|
|
|
+ Integer store = loginIdentity.getStore();
|
|
|
+ Integer type = loginIdentity.getType();
|
|
|
+ OrderDto orderDto = new OrderDto();
|
|
|
+ orderDto.setStore(store);
|
|
|
+ orderDto.setVersion(version);
|
|
|
+ orderDto.setType(type);
|
|
|
+ return orderDto;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ private OrderDto getOrderDto(OrderDto orderDto, LoginIdentity loginIdentity) {
|
|
|
+ Integer store = loginIdentity.getStore();
|
|
|
+ Integer type = loginIdentity.getType();
|
|
|
+ orderDto.setStore(store);
|
|
|
+ orderDto.setType(type);
|
|
|
+ return orderDto;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * @author DY
|
|
|
+ * @create 2018/3/14 17:08
|
|
|
+ * 统计各个订单状态数量
|
|
|
+ */
|
|
|
+ public MessageModel query_order_status(LoginIdentity loginIdentity) {
|
|
|
+ MessageModel messageModel = new MessageModel();
|
|
|
+ Map map = new HashMap();
|
|
|
+ OrderDto orderDto = getOrderDto(loginIdentity, null);
|
|
|
+
|
|
|
+ List<OrderStatus> orders = orderDao.query_order_status(orderDto);
|
|
|
+ AssertUtil.listIsNotEmpty(orders, "你还没订单哦...");
|
|
|
+ Integer total_order = 0;
|
|
|
+ Integer un_pay_order = 0;
|
|
|
+ Integer have_pay_order = 0;
|
|
|
+ Integer wait_receive_order = 0;
|
|
|
+ Integer wait_show_order = 0;
|
|
|
+ Integer have_show_order = 0;
|
|
|
+ Integer close_order = 0;
|
|
|
+ Integer refund_order = 0;
|
|
|
+ Integer refund_order_over = 0;
|
|
|
+
|
|
|
+ for (int i = 0; i < orders.size(); i++) {
|
|
|
+ OrderStatus orderStatus = orders.get(i);
|
|
|
+ total_order += orderStatus.getOrderTotalCount();
|
|
|
+
|
|
|
+ if (orderStatus.getStatus().equals(DmConstant.UN_PAID_CODE)
|
|
|
+ && orderStatus.getVersion().equals(1)
|
|
|
+ && orderStatus.getExpire().after(new Date(System.currentTimeMillis()))
|
|
|
+ && orderStatus.getRefundCode().equals(0)
|
|
|
+
|
|
|
+ ) {
|
|
|
+ un_pay_order += 1;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (orderStatus.getStatus().equals(DmConstant.UN_DELIVERY_CODE)
|
|
|
+ && orderStatus.getVersion().equals(1)
|
|
|
+ && (orderStatus.getRefundCode().equals(0)
|
|
|
+ || orderStatus.getRefundCode().equals(4)
|
|
|
+ || orderStatus.getRefundCode().equals(10))
|
|
|
+ ) {
|
|
|
+ have_pay_order += 1;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if (orderStatus.getStatus().equals(DmConstant.UN_RECEIVE_CODE)
|
|
|
+ && orderStatus.getVersion().equals(1)
|
|
|
+ && (orderStatus.getRefundCode().equals(0)
|
|
|
+ || orderStatus.getRefundCode().equals(4)
|
|
|
+ || orderStatus.getRefundCode().equals(10))
|
|
|
+ ) {
|
|
|
+ wait_receive_order += 1;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if (orderStatus.getStatus().equals(DmConstant.UN_SHOW_CODE)
|
|
|
+ && orderStatus.getVersion().equals(1)
|
|
|
+ && (orderStatus.getRefundCode().equals(0)
|
|
|
+ || orderStatus.getRefundCode().equals(4)
|
|
|
+ || orderStatus.getRefundCode().equals(10))
|
|
|
+ ) {
|
|
|
+ wait_show_order += 1;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if (orderStatus.getStatus().equals(DmConstant.HAVE_SHOW_CODE)
|
|
|
+ && orderStatus.getVersion().equals(1)
|
|
|
+ && (orderStatus.getRefundCode().equals(0)
|
|
|
+ || orderStatus.getRefundCode().equals(4)
|
|
|
+ || orderStatus.getRefundCode().equals(10))
|
|
|
+ ) {
|
|
|
+ have_show_order += 1;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if (orderStatus.getVersion().equals(DmConstant.VERSION_CANCEL_ORDER)
|
|
|
+ ) {
|
|
|
+ close_order += 1;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if (orderStatus.getVersion().equals(1)
|
|
|
+ && (
|
|
|
+ orderStatus.getRefundCode().equals(1)
|
|
|
+ || orderStatus.getRefundCode().equals(2)
|
|
|
+ || orderStatus.getRefundCode().equals(3)
|
|
|
+ || orderStatus.getRefundCode().equals(5)
|
|
|
+ || orderStatus.getRefundCode().equals(8)
|
|
|
+ || orderStatus.getRefundCode().equals(9)
|
|
|
+ )
|
|
|
+ ) {
|
|
|
+ refund_order += 1;
|
|
|
+ }
|
|
|
+
|
|
|
+ if (orderStatus.getVersion().equals(1)
|
|
|
+ && (orderStatus.getRefundCode().equals(6)
|
|
|
+ || orderStatus.getRefundCode().equals(7)
|
|
|
+ )
|
|
|
+ ) {
|
|
|
+ refund_order_over += 1;
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ map.put("refund_order", refund_order);
|
|
|
+ map.put("refund_order_over", refund_order_over);
|
|
|
+ map.put("close_order", close_order);
|
|
|
+ map.put("have_show_order", have_show_order);
|
|
|
+ map.put("wait_show_order", wait_show_order);
|
|
|
+ map.put("wait_receive_order", wait_receive_order);
|
|
|
+ map.put("have_pay_order", have_pay_order);
|
|
|
+ map.put("un_pay_order", un_pay_order);
|
|
|
+
|
|
|
+ map.put("total_order", total_order);
|
|
|
+ messageModel.setCode(DmConstant.OPS_SUCCESS_CODE);
|
|
|
+ messageModel.setMsg(DmConstant.OPS_SUCCESS_MSG);
|
|
|
+ messageModel.setData(map);
|
|
|
+ return messageModel;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * @author DY
|
|
|
+ * @create 2018/3/19 14:22
|
|
|
+ * 查看订单
|
|
|
+ */
|
|
|
+ public MessageModel showObligationOrder(OrderDto orderDto, LoginIdentity loginIdentity) {
|
|
|
+ MessageModel messageModel = new MessageModel();
|
|
|
+ orderDto = getOrderDto(orderDto, loginIdentity);
|
|
|
+ Integer status = orderDto.getStatus();
|
|
|
+
|
|
|
+ orderDto.setRefundCode(-1);
|
|
|
+
|
|
|
+ if (status == null) {
|
|
|
+
|
|
|
+ } else {
|
|
|
+
|
|
|
+ if (status == 0) {
|
|
|
+ orderDto.setRefundCode(0);
|
|
|
+ orderDto.setExpire(1);
|
|
|
+ orderDto.setVersion(1);
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ if (status == 1) {
|
|
|
+ orderDto.setRefundCode(0);
|
|
|
+ orderDto.setVersion(1);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (status == 2) {
|
|
|
+ orderDto.setRefundCode(0);
|
|
|
+ orderDto.setVersion(1);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (status == 3) {
|
|
|
+ orderDto.setRefundCode(0);
|
|
|
+ orderDto.setVersion(1);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (status == 4) {
|
|
|
+ orderDto.setRefundCode(0);
|
|
|
+ orderDto.setVersion(1);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (status == 5) {
|
|
|
+ orderDto.setStatus(-1);
|
|
|
+ orderDto.setVersion(-1);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if (status == 6) {
|
|
|
+ orderDto.setStatus(null);
|
|
|
+ orderDto.setRefundCode(1);
|
|
|
+ orderDto.setVersion(1);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if (status == 7) {
|
|
|
+ orderDto.setStatus(null);
|
|
|
+ orderDto.setRefundCode(2);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ Map map = new HashMap();
|
|
|
+
|
|
|
+ PageBounds pageBounds = orderDto.buildPageBounds();
|
|
|
+
|
|
|
+ List<OrderDetail> order = orderDao.findOrderItemByUserId(orderDto, pageBounds);
|
|
|
+
|
|
|
+ PageList<OrderDetail> orderListStr = (PageList<OrderDetail>) order;
|
|
|
+ List<List<OrderDetail>> newOrderItem = getList(orderListStr);
|
|
|
+
|
|
|
+ Paginator paginator = orderListStr.getPaginator();
|
|
|
+ map.put("paginator", paginator);
|
|
|
+
|
|
|
+
|
|
|
+ messageModel.setCode(DmConstant.OPS_SUCCESS_CODE);
|
|
|
+ messageModel.setMsg(DmConstant.OPS_SUCCESS_MSG);
|
|
|
+
|
|
|
+ map.put("listOrder", newOrderItem);
|
|
|
+ messageModel.setData(map);
|
|
|
+ return messageModel;
|
|
|
+ }
|
|
|
+
|
|
|
+ private List<List<OrderDetail>> getList(List<OrderDetail> orders) {
|
|
|
+
|
|
|
+ Map<Integer, List> map = new LinkedHashMap();
|
|
|
+
|
|
|
+ for (int i = 0; i < orders.size(); i++) {
|
|
|
+ OrderDetail item = orders.get(i);
|
|
|
+
|
|
|
+ Integer refundCode = item.getOrderItemRefundCode();
|
|
|
+ Date refundTime = item.getRefundTime();
|
|
|
+ if (refundCode == DmConstant.REFUND_CODE_APPLY) {
|
|
|
+ Date refundLateTime = new Date(refundTime.getTime() + DmConstant.APPLY_REFUND_IN_REFUND_APPLY);
|
|
|
+ item.setAgreeTimeRefundTime(refundLateTime);
|
|
|
+ }
|
|
|
+ if (refundCode == DmConstant.REFUND_CODE_EXPRESS_NUMBER) {
|
|
|
+ Date refundLateTime = new Date(refundTime.getTime() + DmConstant.APPLY_REFUND_IN_REFUND_HAVE_SEND_REFUND_GOODS);
|
|
|
+ item.setAgreeConfirmTimeRefundTime(refundLateTime);
|
|
|
+ }
|
|
|
+
|
|
|
+ Boolean isExtend = item.getIsExtend();
|
|
|
+ if (item.getDeliveryTime() != null && (refundCode == DmConstant.REFUND_CODE_DEFAULT || refundCode == DmConstant.REFUND_CODE_CANCEL)) {
|
|
|
+ Date time = new Date(item.getDeliveryTime().getTime() + DmConstant.AUTOMATICRECEIVING);
|
|
|
+ if (isExtend) {
|
|
|
+ time = new Date(time.getTime() + DmConstant.EXTENDTHERECEIVING * 24 * 60 * 60 * 1000);
|
|
|
+ }
|
|
|
+ item.setAutomaticReceivingDate(time);
|
|
|
+ }
|
|
|
+ Integer status = item.getOrderItemStatus();
|
|
|
+ if (refundCode == DmConstant.REFUND_CODE_AGREE && status != 1) {
|
|
|
+ item.setRefundSendDate(new Date(item.getModifyDate().getTime() + DmConstant.APPLY_REFUND_IN_REFUND_AGREE));
|
|
|
+ }
|
|
|
+ Integer key = item.getId();
|
|
|
+
|
|
|
+ if (map.containsKey(key)) {
|
|
|
+ map.get(key).add(item);
|
|
|
+ } else {
|
|
|
+ List list = new ArrayList();
|
|
|
+ list.add(item);
|
|
|
+ map.put(key, list);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ List<List<OrderDetail>> data = new PageList<>();
|
|
|
+ for (Map.Entry<Integer, List> entry : map.entrySet()) {
|
|
|
+ data.add(entry.getValue());
|
|
|
+ }
|
|
|
+
|
|
|
+ return data;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public void update_receive_address (ReceiveAddress receiveAddress) {
|
|
|
+ AssertUtil.intIsNotEmpty(receiveAddress.getId(), "请选择要修改的订单...");
|
|
|
+ Integer code = orderDao.updateOrderReceiveAddressById(receiveAddress);
|
|
|
+ AssertUtil.intIsNotEmpty(code, "修改失败,请联系客服....");
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ * @author DY
|
|
|
+ * @create 2018/3/27 18:31
|
|
|
+ * 修改订单商品信息
|
|
|
+ *
|
|
|
+ public MessageModel update_order_property(ProductUpdate productNew) {
|
|
|
+
|
|
|
+ checkParams(productNew);
|
|
|
+
|
|
|
+ ProductUpdate productOld = orderDao.queryProductByOrderItemId(productNew.getOrderItemId());
|
|
|
+ AssertUtil.notNull(productOld, "所查询的商品不存在");
|
|
|
+ Boolean quantity = productNew.getQuantity().equals(productOld.getQuantity());
|
|
|
+
|
|
|
+ if (StringUtils.isNotBlank(productOld.getCustomNames())) {
|
|
|
+ AssertUtil.isNotEmpty(productNew.getCustomIds(), "请传入定制ids");
|
|
|
+
|
|
|
+
|
|
|
+ List<ProductCustom> productCustoms = orderDao.queryCustomsByCustomId(productNew.getCustomIds());
|
|
|
+ BigDecimal customTotalPrice = BigDecimal.ZERO;
|
|
|
+ StringBuffer sb = new StringBuffer();
|
|
|
+ for (int i = 0; i < productCustoms.size(); i++) {
|
|
|
+ ProductCustom productCustom = productCustoms.get(i);
|
|
|
+ customTotalPrice = customTotalPrice.add(productCustom.getPrice());
|
|
|
+ sb.append(" " + productCustom.getName());
|
|
|
+ }
|
|
|
+ String customNames = sb.toString();
|
|
|
+
|
|
|
+ BigDecimal defaultProductPrice = orderDao.queryDefaultProductPriceByProductId(productOld.getProduct());
|
|
|
+ AssertUtil.notNull(defaultProductPrice, "默认商品不存在,请联系客服...");
|
|
|
+ BigDecimal newPriceOrderItem = defaultProductPrice.add(customTotalPrice);
|
|
|
+
|
|
|
+ Integer code = orderDao.updateOrderItemCustom(newPriceOrderItem, productNew.getQuantity(), customNames, productNew.getOrderItemId());
|
|
|
+ AssertUtil.intIsNotEmpty(code, "更新子订单属性失败,请联系客服....");
|
|
|
+
|
|
|
+ BigDecimal newPriceTotal = newPriceOrderItem.multiply(new BigDecimal(productNew.getQuantity()));
|
|
|
+ BigDecimal oldPriceTotal = productOld.getPrice().multiply(new BigDecimal(productOld.getQuantity()));
|
|
|
+ BigDecimal differentPrice = newPriceTotal.subtract(oldPriceTotal);
|
|
|
+ Integer differentQuantity = productNew.getQuantity() - productOld.getQuantity();
|
|
|
+
|
|
|
+ UpdateOrderParams updateOrderParams = new UpdateOrderParams();
|
|
|
+ updateOrderParams.setOrderId(productOld.getOrders());
|
|
|
+ updateOrderParams.setAmountUpdate(differentPrice);
|
|
|
+ updateOrderParams.setQuantityUpdate(differentQuantity);
|
|
|
+ updateOrderPriceQuantity(updateOrderParams);
|
|
|
+ Map map = new HashMap();
|
|
|
+ map.put("price", newPriceOrderItem);
|
|
|
+ map.put("quantity", productNew.getQuantity());
|
|
|
+ return MessageModelUtil.getSuccessMessageModel(newPriceOrderItem);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ Boolean scm = productNew.getSize().equals(productOld.getSize()) && productNew.getColor().equals(productOld.getColor())
|
|
|
+ && productNew.getMaterial().equals(productOld.getMaterial());
|
|
|
+
|
|
|
+ if (scm && quantity) {
|
|
|
+ return MessageModelUtil.getSuccessMessageModel();
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ UpdateOrderParams updateOrderParams = new UpdateOrderParams();
|
|
|
+ updateOrderParams.setOrderId(productOld.getOrders());
|
|
|
+
|
|
|
+ ProductUpdate productUpdate = new ProductUpdate();
|
|
|
+ Integer orderItemId = productNew.getOrderItemId();
|
|
|
+ productUpdate.setOrderItemId(orderItemId);
|
|
|
+
|
|
|
+ if (!scm && quantity) {
|
|
|
+
|
|
|
+ Product productGetByAttribute = updateProductAttribute(productOld, productNew);
|
|
|
+
|
|
|
+ productUpdate = updateOrderItemAttribute(productGetByAttribute, orderItemId);
|
|
|
+ updateOrderItem(productUpdate);
|
|
|
+
|
|
|
+ if (productOld.getPrice().compareTo(productGetByAttribute.getPrice()) != 0) {
|
|
|
+
|
|
|
+ BigDecimal differentPriceAmount = productGetByAttribute.getPrice().subtract(productOld.getPrice()).multiply(new BigDecimal(productOld.getQuantity()));
|
|
|
+
|
|
|
+ updateOrderParams.setAmountUpdate(differentPriceAmount);
|
|
|
+ updateOrderPriceQuantity(updateOrderParams);
|
|
|
+ }
|
|
|
+ Map map = new HashMap();
|
|
|
+ map.put("price", productGetByAttribute.getPrice());
|
|
|
+ map.put("quantity", productNew.getQuantity());
|
|
|
+ return MessageModelUtil.getSuccessMessageModel(map);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (scm && !quantity) {
|
|
|
+ productUpdate.setQuantity(productNew.getQuantity());
|
|
|
+ updateOrderItem(productUpdate);
|
|
|
+ Integer differentQuantity = productNew.getQuantity() - productOld.getQuantity();
|
|
|
+
|
|
|
+ updateQuantityProduct(productOld.getProduct(), differentQuantity);
|
|
|
+ BigDecimal differentPriceAmount = productOld.getPrice().multiply(new BigDecimal(differentQuantity));
|
|
|
+ updateOrderParams.setAmountUpdate(differentPriceAmount);
|
|
|
+ updateOrderParams.setQuantityUpdate(differentQuantity);
|
|
|
+ updateOrderPriceQuantity(updateOrderParams);
|
|
|
+ Map map = new HashMap();
|
|
|
+ map.put("price", productOld.getPrice());
|
|
|
+ map.put("quantity", productNew.getQuantity());
|
|
|
+ return MessageModelUtil.getSuccessMessageModel(map);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!scm && !quantity) {
|
|
|
+
|
|
|
+ Product productGetByAttribute = updateProductAttribute(productOld, productNew);
|
|
|
+
|
|
|
+ productUpdate = updateOrderItemAttribute(productGetByAttribute, orderItemId);
|
|
|
+ productUpdate.setQuantity(productNew.getQuantity());
|
|
|
+ updateOrderItem(productUpdate);
|
|
|
+ Integer differentQuantity = productNew.getQuantity() - productOld.getQuantity();
|
|
|
+
|
|
|
+ BigDecimal priceNew = productGetByAttribute.getPrice().multiply(new BigDecimal(productNew.getQuantity()));
|
|
|
+
|
|
|
+ BigDecimal priceOld = productOld.getPrice().multiply(new BigDecimal(productOld.getQuantity()));
|
|
|
+ BigDecimal differentPriceAmount = priceNew.subtract(priceOld);
|
|
|
+ updateOrderParams.setAmountUpdate(differentPriceAmount);
|
|
|
+ updateOrderParams.setQuantityUpdate(differentQuantity);
|
|
|
+ updateOrderPriceQuantity(updateOrderParams);
|
|
|
+ Map map = new HashMap();
|
|
|
+ map.put("price", productGetByAttribute.getPrice());
|
|
|
+ map.put("quantity", productNew.getQuantity());
|
|
|
+ return MessageModelUtil.getSuccessMessageModel(map);
|
|
|
+
|
|
|
+ }
|
|
|
+ return MessageModelUtil.getSuccessMessageModel();
|
|
|
+ }*/
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ * @author DY
|
|
|
+ * @create 2018/3/27 18:31
|
|
|
+ * 修改订单商品信息--更改
|
|
|
+ */
|
|
|
+ public MessageModel update_order_property(ProductUpdate productNew) {
|
|
|
+
|
|
|
+ checkParams(productNew);
|
|
|
+ Map map = new HashMap();
|
|
|
+
|
|
|
+ ProductUpdate productOld = orderDao.queryProductByOrderItemId(productNew.getOrderItemId());
|
|
|
+ AssertUtil.notNull(productOld, "所查询的商品不存在");
|
|
|
+ if (productOld.getIsCustom()) {
|
|
|
+ Integer a = 0;
|
|
|
+ if (null != productNew.getMeasureId()) {
|
|
|
+ a = a + 1;
|
|
|
+ }
|
|
|
+ if (StringUtils.isNotBlank(productNew.getSize())) {
|
|
|
+ a = a + 1;
|
|
|
+ }
|
|
|
+ AssertUtil.isTrue(a == 2, "定制尺码和套码只能而二选一");
|
|
|
+ }
|
|
|
+ Boolean quantity = productNew.getQuantity() == productOld.getQuantity();
|
|
|
+
|
|
|
+
|
|
|
+ Boolean scmDetail = false;
|
|
|
+ if (StringUtils.isNotBlank(productNew.getCustomNamesIds())) {
|
|
|
+ scmDetail = productNew.getCustomNamesIds().equals(productOld.getCustomNamesIds());
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if (scmDetail == false) {
|
|
|
+
|
|
|
+
|
|
|
+ String customNames = null;
|
|
|
+ BigDecimal customTotalPriceOld = BigDecimal.ZERO;
|
|
|
+ BigDecimal customTotalPriceNew = BigDecimal.ZERO;
|
|
|
+ if (productOld.getCustomNamesIds() != null) {
|
|
|
+ List<ProductCustom> productCustomsOld = orderDao.queryCustomsByCustomId(productOld.getCustomNamesIds());
|
|
|
+
|
|
|
+ List<ProductCustom> productCustomsNew = orderDao.queryCustomsByCustomId(productNew.getCustomNamesIds());
|
|
|
+ StringBuffer sb = new StringBuffer();
|
|
|
+ for (int i = 0; i < productCustomsOld.size(); i++) {
|
|
|
+ ProductCustom productCustom = productCustomsOld.get(i);
|
|
|
+ customTotalPriceOld = customTotalPriceOld.add(productCustom.getPrice());
|
|
|
+ }
|
|
|
+
|
|
|
+ for (int i = 0; i < productCustomsNew.size(); i++) {
|
|
|
+ ProductCustom productCustom = productCustomsNew.get(i);
|
|
|
+ customTotalPriceNew = customTotalPriceNew.add(productCustom.getPrice());
|
|
|
+ sb.append(" " + productCustom.getName());
|
|
|
+ }
|
|
|
+ customNames = sb.toString();
|
|
|
+ }
|
|
|
+
|
|
|
+ UpdateOrderParams updateOrderParams = new UpdateOrderParams();
|
|
|
+ updateOrderParams.setOrderId(productOld.getOrders());
|
|
|
+
|
|
|
+ ProductUpdate productUpdate = new ProductUpdate();
|
|
|
+ Integer orderItemId = productNew.getOrderItemId();
|
|
|
+ productUpdate.setOrderItemId(orderItemId);
|
|
|
+
|
|
|
+
|
|
|
+ Product newProductUpdate = updateProductAttribute(productOld, productNew);
|
|
|
+
|
|
|
+ productUpdate = updateOrderItemAttribute(newProductUpdate, orderItemId);
|
|
|
+ productUpdate.setQuantity(productNew.getQuantity());
|
|
|
+ productUpdate.setCustomNames(customNames);
|
|
|
+ productUpdate.setCustomNamesIds(productNew.getCustomNamesIds());
|
|
|
+ productUpdate.setCustomDetailPrice(customTotalPriceNew);
|
|
|
+
|
|
|
+ if (StringUtils.isNotBlank(productNew.getSize())) {
|
|
|
+ productUpdate.setMeasureId(null);
|
|
|
+ }
|
|
|
+ if (productNew.getMeasureId() != null) {
|
|
|
+ productUpdate.setSize(null);
|
|
|
+ }
|
|
|
+ updateOrderItem(productUpdate);
|
|
|
+
|
|
|
+ Integer differentQuantity = productNew.getQuantity() - productOld.getQuantity();
|
|
|
+
|
|
|
+ BigDecimal priceNew = (newProductUpdate.getPrice().add(customTotalPriceNew)).multiply(new BigDecimal(productNew.getQuantity()));
|
|
|
+
|
|
|
+ BigDecimal priceOld = (productOld.getPrice().add(customTotalPriceOld)).multiply(new BigDecimal(productOld.getQuantity()));
|
|
|
+ BigDecimal differentPriceAmount = priceNew.subtract(priceOld);
|
|
|
+ updateOrderParams.setAmountUpdate(differentPriceAmount);
|
|
|
+ updateOrderParams.setQuantityUpdate(differentQuantity);
|
|
|
+ updateOrderPriceQuantity(updateOrderParams);
|
|
|
+ map.put("price", newProductUpdate.getPrice().add(customTotalPriceNew));
|
|
|
+ map.put("quantity", productNew.getQuantity());
|
|
|
+ return MessageModelUtil.getSuccessMessageModel(map);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ Boolean scm = productNew.getSize().equals(productOld.getSize()) && productNew.getColor().equals(productOld.getColor());
|
|
|
+
|
|
|
+ if (scm && quantity) {
|
|
|
+ map.put("price", productOld.getPrice());
|
|
|
+ map.put("quantity", productOld.getQuantity());
|
|
|
+ return MessageModelUtil.getSuccessMessageModel(map);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if (!scm && quantity) {
|
|
|
+ map = updateAttributeProductOnly(productNew, productOld);
|
|
|
+ return MessageModelUtil.getSuccessMessageModel(map);
|
|
|
+ }
|
|
|
+
|
|
|
+ if (scm && !quantity) {
|
|
|
+ map = updateQuantityProductOnly(productNew, productOld);
|
|
|
+ return MessageModelUtil.getSuccessMessageModel(map);
|
|
|
+ }
|
|
|
+ if (!scm && !quantity) {
|
|
|
+ map = updateAttributeAndQuantityProductOnly(productNew, productOld);
|
|
|
+ return MessageModelUtil.getSuccessMessageModel(map);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ return MessageModelUtil.getSuccessMessageModel();
|
|
|
+ }
|
|
|
+
|
|
|
+ private Map updateAttributeProductOnly(ProductUpdate productNew, ProductUpdate productOld) {
|
|
|
+
|
|
|
+ UpdateOrderParams updateOrderParams = new UpdateOrderParams();
|
|
|
+ updateOrderParams.setOrderId(productOld.getOrders());
|
|
|
+
|
|
|
+ ProductUpdate productUpdate = new ProductUpdate();
|
|
|
+ Integer orderItemId = productNew.getOrderItemId();
|
|
|
+ productUpdate.setOrderItemId(orderItemId);
|
|
|
+
|
|
|
+ Product newProductUpdate = updateProductAttribute(productOld, productNew);
|
|
|
+
|
|
|
+ productUpdate = updateOrderItemAttribute(newProductUpdate, orderItemId);
|
|
|
+ productUpdate.setMeasureId(productNew.getMeasureId());
|
|
|
+
|
|
|
+ if (StringUtils.isNotBlank(productNew.getSize())) {
|
|
|
+ productUpdate.setMeasureId(null);
|
|
|
+ }
|
|
|
+ if (productNew.getMeasureId() != null) {
|
|
|
+ productUpdate.setSize(null);
|
|
|
+ }
|
|
|
+ updateOrderItem(productUpdate);
|
|
|
+
|
|
|
+ if (productOld.getPrice().compareTo(newProductUpdate.getPrice()) != 0) {
|
|
|
+
|
|
|
+ BigDecimal differentPriceAmount = newProductUpdate.getPrice().subtract(productOld.getPrice()).multiply(new BigDecimal(productOld.getQuantity()));
|
|
|
+
|
|
|
+ updateOrderParams.setAmountUpdate(differentPriceAmount);
|
|
|
+ updateOrderPriceQuantity(updateOrderParams);
|
|
|
+ }
|
|
|
+ Map map = new HashMap();
|
|
|
+ map.put("price", newProductUpdate.getPrice());
|
|
|
+ map.put("quantity", productNew.getQuantity());
|
|
|
+ return map;
|
|
|
+ }
|
|
|
+
|
|
|
+ private Map updateQuantityProductOnly(ProductUpdate productNew, ProductUpdate productOld) {
|
|
|
+
|
|
|
+ UpdateOrderParams updateOrderParams = new UpdateOrderParams();
|
|
|
+ updateOrderParams.setOrderId(productOld.getOrders());
|
|
|
+
|
|
|
+ ProductUpdate productUpdate = new ProductUpdate();
|
|
|
+ Integer orderItemId = productNew.getOrderItemId();
|
|
|
+ productUpdate.setOrderItemId(orderItemId);
|
|
|
+
|
|
|
+ productUpdate.setQuantity(productNew.getQuantity());
|
|
|
+ productUpdate.setMeasureId(productNew.getMeasureId());
|
|
|
+ updateOrderItem(productUpdate);
|
|
|
+ Integer differentQuantity = productNew.getQuantity() - productOld.getQuantity();
|
|
|
+
|
|
|
+ if (productOld.getIsCustom() == false) {
|
|
|
+ updateQuantityProduct(productOld.getProduct(), differentQuantity);
|
|
|
+ }
|
|
|
+ BigDecimal differentPriceAmount = productOld.getPrice().multiply(new BigDecimal(differentQuantity));
|
|
|
+ updateOrderParams.setAmountUpdate(differentPriceAmount);
|
|
|
+ updateOrderParams.setQuantityUpdate(differentQuantity);
|
|
|
+ updateOrderPriceQuantity(updateOrderParams);
|
|
|
+ Map map = new HashMap();
|
|
|
+ map.put("price", productOld.getPrice());
|
|
|
+ map.put("quantity", productNew.getQuantity());
|
|
|
+
|
|
|
+ return map;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ private Map updateAttributeAndQuantityProductOnly(ProductUpdate productNew, ProductUpdate productOld) {
|
|
|
+
|
|
|
+
|
|
|
+ UpdateOrderParams updateOrderParams = new UpdateOrderParams();
|
|
|
+ updateOrderParams.setOrderId(productOld.getOrders());
|
|
|
+
|
|
|
+ ProductUpdate productUpdate = new ProductUpdate();
|
|
|
+ Integer orderItemId = productNew.getOrderItemId();
|
|
|
+ productUpdate.setOrderItemId(orderItemId);
|
|
|
+
|
|
|
+ Product newProductUpdate = updateProductAttribute(productOld, productNew);
|
|
|
+
|
|
|
+ productUpdate = updateOrderItemAttribute(newProductUpdate, orderItemId);
|
|
|
+ productUpdate.setQuantity(productNew.getQuantity());
|
|
|
+ productUpdate.setMeasureId(productNew.getMeasureId());
|
|
|
+
|
|
|
+ if (StringUtils.isNotBlank(productNew.getSize())) {
|
|
|
+ productUpdate.setMeasureId(null);
|
|
|
+ }
|
|
|
+ if (productNew.getMeasureId() != null) {
|
|
|
+ productUpdate.setSize(null);
|
|
|
+ }
|
|
|
+ updateOrderItem(productUpdate);
|
|
|
+ Integer differentQuantity = productNew.getQuantity() - productOld.getQuantity();
|
|
|
+
|
|
|
+ BigDecimal priceNew = newProductUpdate.getPrice().multiply(new BigDecimal(productNew.getQuantity()));
|
|
|
+
|
|
|
+ BigDecimal priceOld = productOld.getPrice().multiply(new BigDecimal(productOld.getQuantity()));
|
|
|
+ BigDecimal differentPriceAmount = priceNew.subtract(priceOld);
|
|
|
+ updateOrderParams.setAmountUpdate(differentPriceAmount);
|
|
|
+ updateOrderParams.setQuantityUpdate(differentQuantity);
|
|
|
+ updateOrderPriceQuantity(updateOrderParams);
|
|
|
+ Map map = new HashMap();
|
|
|
+ map.put("price", newProductUpdate.getPrice());
|
|
|
+ map.put("quantity", productNew.getQuantity());
|
|
|
+ return map;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ private void updateQuantityProduct(Integer productId, Integer quantity) {
|
|
|
+ Integer code = productDao.updateStockOldProduct(productId, quantity);
|
|
|
+ AssertUtil.intIsNotEmpty(code, "修改数量失败....");
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ private void updateOrderItem(ProductUpdate productUpdate) {
|
|
|
+
|
|
|
+ Integer updateOrderItemCode = orderDao.updateOrderItemByProduct(productUpdate);
|
|
|
+ AssertUtil.intIsNotEmpty(updateOrderItemCode, "更改子订单属性smc失败...");
|
|
|
+ }
|
|
|
+
|
|
|
+ private void updateOrderPriceQuantity(UpdateOrderParams updateOrderParams) {
|
|
|
+ Integer updateOrderCode = orderDao.updateOrderByProduct(updateOrderParams);
|
|
|
+ AssertUtil.intIsNotEmpty(updateOrderCode, "修改失败,请联系客服....");
|
|
|
+ }
|
|
|
+
|
|
|
+ private ProductUpdate updateOrderItemAttribute(Product productGetByAttribute, Integer orderItemId) {
|
|
|
+ ProductUpdate productUpdate = new ProductUpdate();
|
|
|
+ productUpdate.setProduct(productGetByAttribute.getId());
|
|
|
+ productUpdate.setOrderItemId(orderItemId);
|
|
|
+ productUpdate.setPrice(productGetByAttribute.getPrice());
|
|
|
+ productUpdate.setColor(productGetByAttribute.getColor());
|
|
|
+ productUpdate.setSize(productGetByAttribute.getSize());
|
|
|
+ return productUpdate;
|
|
|
+ }
|
|
|
+
|
|
|
+ private Product updateProductAttribute(ProductUpdate productOld, ProductUpdate productNew) {
|
|
|
+ Integer quantityOld = productOld.getQuantity();
|
|
|
+ Integer quantityNew = productNew.getQuantity();
|
|
|
+
|
|
|
+ List<Product> updateProduct = null;
|
|
|
+ Product product = null;
|
|
|
+
|
|
|
+ Boolean isCustom = productNew.getIsCustom();
|
|
|
+
|
|
|
+ if (isCustom) {
|
|
|
+ String size = productNew.getSize();
|
|
|
+ productNew.setSize(null);
|
|
|
+ updateProduct = productDao.queryProductBySMC(productNew);
|
|
|
+ AssertUtil.isTrue(updateProduct.isEmpty(), "更改的商品不存在,请稍后重试...");
|
|
|
+ product = updateProduct.get(0);
|
|
|
+ product.setSize(size);
|
|
|
+ } else {
|
|
|
+ updateProduct = productDao.queryProductBySMC(productNew);
|
|
|
+ AssertUtil.isTrue(updateProduct.isEmpty(), "更改的商品不存在,请稍后重试...");
|
|
|
+ product = updateProduct.get(0);
|
|
|
+
|
|
|
+ Integer codeOld = productDao.updateStockOldProduct(productOld.getProduct(), -quantityOld);
|
|
|
+ AssertUtil.intIsNotEmpty(codeOld, "回滚库存失败,请联系客服...");
|
|
|
+ Integer codeNew = productDao.updateStockOldProduct(product.getId(), quantityNew);
|
|
|
+ AssertUtil.intIsNotEmpty(codeNew, "扣除库存失败,请联系客服...");
|
|
|
+ }
|
|
|
+ return product;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ private void checkParams(ProductUpdate product) {
|
|
|
+ AssertUtil.intIsNotEmpty(product.getOrderItemId(), "请传入订单明细id...");
|
|
|
+ AssertUtil.intIsNotEmpty(product.getQuantity(), "请传入修改之后的数量...");
|
|
|
+ }
|
|
|
+
|
|
|
+ public void update_order_totalPrice(BigDecimal totalPrice, Integer id) {
|
|
|
+ AssertUtil.intIsNotEmpty(id, "请选择订单...");
|
|
|
+ AssertUtil.notNull(totalPrice, "请传入要修改的价格...");
|
|
|
+ Integer code = orderDao.updateOrderPriceByPrice(totalPrice, id);
|
|
|
+ AssertUtil.intIsNotEmpty(code, "价格修改失败,请联系客服.....");
|
|
|
+ }
|
|
|
+
|
|
|
+ public void updateOrderStatusToSend(String deliverySend) {
|
|
|
+ AssertUtil.isNotEmpty(deliverySend, "请传入发货信息...");
|
|
|
+
|
|
|
+ List<DeliverySend> deliverySends = null;
|
|
|
+ if (StringUtils.isNotBlank(deliverySend)) {
|
|
|
+ deliverySends = JSON.parseArray(deliverySend, DeliverySend.class);
|
|
|
+ }
|
|
|
+
|
|
|
+ Integer codeOrderItem = orderDao.updateOrderItemStatusCode(deliverySends);
|
|
|
+ AssertUtil.intIsNotEmpty(codeOrderItem, "更改订单状态失败,请联系客服...");
|
|
|
+
|
|
|
+ for (int i = 0; i < deliverySends.size(); i++) {
|
|
|
+ Integer orderId=deliverySends.get(i).getOrderId();
|
|
|
+ AssertUtil.intIsNotEmpty(orderId, "请传入父订单Id...");
|
|
|
+ Integer isHaveNoSend=orderDao.findOrdersNoSend(orderId,DmConstant.UN_DELIVERY_CODE);
|
|
|
+ if(isHaveNoSend==null||isHaveNoSend<0){
|
|
|
+ Integer code = orderDao.updateOrderStatusAndDelivery(orderId,DmConstant.UN_RECEIVE_CODE);
|
|
|
+ AssertUtil.intIsNotEmpty(code, "更新父订单失败,请稍后重试..."+orderId);
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ Integer codeOrder=orderDao.updateOrderStatus(unReceiveCode,orderId);
|
|
|
+ AssertUtil.intIsNotEmpty(codeOrder,"更改订单状态失败,请联系客服...");
|
|
|
+
|
|
|
+ Integer codeOrderItem=orderDao.updateOrderItemStatusCode(unReceiveCode,orderId);
|
|
|
+ AssertUtil.intIsNotEmpty(codeOrderItem,"更改订单状态失败,请联系客服...");
|
|
|
+ }*/
|
|
|
+
|
|
|
+ public List<DeliveryCode> query_delivery_code() {
|
|
|
+ List<DeliveryCode> deliveryCodeList = orderDao.queryDeliveryCode();
|
|
|
+ return deliveryCodeList;
|
|
|
+ }
|
|
|
+
|
|
|
+ public void deal_with_return_order(Integer orderItemId, Boolean isAgree,Integer refundCodeF) {
|
|
|
+ AssertUtil.intIsNotEmpty(orderItemId, "请选择带操作的订单");
|
|
|
+ AssertUtil.intIsNotEmpty(refundCodeF, "请传入待退款订单的状态refundCode");
|
|
|
+ AssertUtil.notNull(isAgree, "请选择同意或者拒绝...");
|
|
|
+ Integer refundCode = null;
|
|
|
+ if (isAgree) {
|
|
|
+ refundCode = DmConstant.REFUND_CODE_AGREE;
|
|
|
+
|
|
|
+
|
|
|
+ OrderItemDetail orderDetail1 = orderDao.findOrderItemById(orderItemId);
|
|
|
+
|
|
|
+ Boolean isCustom = orderDetail1.getIsCustom();
|
|
|
+
|
|
|
+ if (isCustom == false) {
|
|
|
+ Integer quantity = orderDetail1.getQuantity();
|
|
|
+ Integer product = orderDetail1.getProduct();
|
|
|
+ Integer updateProductStock = orderDao.updateProductStock(-quantity, product);
|
|
|
+ AssertUtil.intIsNotEmpty(updateProductStock, "取消订单失败003,请联系客服...");
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ if(refundCodeF==DmConstant.REFUND_CODE_APPLY||refundCodeF==DmConstant.REFUND_CODE_APPLY_CANCEL_AGAIN){
|
|
|
+ refundCode = DmConstant.REFUND_CODE_REFUSE;
|
|
|
+ }
|
|
|
+ if(refundCodeF==DmConstant.REFUND_CODE_APPLY_REFUSE_AGAIN){
|
|
|
+ refundCode = DmConstant.REFUND_CODE_REFUSE_AGAIN;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ Integer code = orderDao.updateOrderItemRefundStatus(orderItemId, refundCode);
|
|
|
+ AssertUtil.intIsNotEmpty(code, "操作失败,请联系客服...");
|
|
|
+ }
|
|
|
+
|
|
|
+ public void updateOrderStatusToAgree() {
|
|
|
+
|
|
|
+ OrderDto orderDto = new OrderDto();
|
|
|
+ orderDto.setRefundCode(DmConstant.REFUND_CODE_AGREE);
|
|
|
+ orderDto.setRefundTime(DmConstant.REFUND_AGREE_TIME);
|
|
|
+
|
|
|
+ orderDao.updateOrderItemStatusToAgree(orderDto);
|
|
|
+
|
|
|
+ orderDto.setRefundCode(DmConstant.REFUND_CODE_AGREE);
|
|
|
+ List<OrderItemQuery> orderDetails = orderDao.findOrderItemByOrderDto(orderDto);
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ OrderItemQuery orderItemQuery = orderDetails.get(i);
|
|
|
+
|
|
|
+ Boolean isCustom = orderItemQuery.getIsCustom();
|
|
|
+
|
|
|
+ if (isCustom == false) {
|
|
|
+ Integer quantity = orderItemQuery.getOrderItemQuantity();
|
|
|
+ Integer product = orderItemQuery.getProduct();
|
|
|
+ Integer updateProductStock = orderDao.updateProductStock(-quantity, product);
|
|
|
+ AssertUtil.intIsNotEmpty(updateProductStock, "取消订单失败003,请联系客服...");
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ }*/
|
|
|
+ StringBuffer orders = new StringBuffer();
|
|
|
+ if (orderDetails.size() != 0) {
|
|
|
+ for (int i = 0; i < orderDetails.size(); i++) {
|
|
|
+ OrderItemQuery orderItemQuery = orderDetails.get(i);
|
|
|
+ Integer orderId = orderItemQuery.getOrderId();
|
|
|
+
|
|
|
+ if (orderItemQuery.getOrderQuantity().equals(orderItemQuery.getOrderItemQuantity())) {
|
|
|
+ orders.append(orderId + ",");
|
|
|
+ } else {
|
|
|
+
|
|
|
+ String refundCodes = DmConstant.REFUND_CODE_APPLY + "," + DmConstant.REFUND_CODE_REFUSE;
|
|
|
+ List<Integer> integers = orderDao.findOrderItemByOrderId(orderId, refundCodes);
|
|
|
+ if (integers.size() == 0) {
|
|
|
+ orders.append(orderId + ",");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ orders.deleteCharAt(orders.length() - 1);
|
|
|
+ String ordersStr = orders.toString();
|
|
|
+
|
|
|
+ orderDao.updateOrderStatusToAgree(ordersStr, DmConstant.REFUND_CODE_AGREE);
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ public Integer query_order_refund_status(LoginIdentity loginIdentity) {
|
|
|
+ OrderDto orderDto = getOrderDto(loginIdentity, null);
|
|
|
+
|
|
|
+ List<Integer> return_order = orderDao.queryReturnOrder(orderDto);
|
|
|
+ return return_order.size();
|
|
|
+ }
|
|
|
+
|
|
|
+ public void return_order_to_last(Integer orderId,Integer orderItemId,Integer isAgree) {
|
|
|
+ AssertUtil.intIsNotEmpty(orderId, "请确认打款的父订单...");
|
|
|
+ AssertUtil.intIsNotEmpty(orderItemId, "请确认打款的子订单...");
|
|
|
+ AssertUtil.intIsNotEmpty(isAgree, "请确认是否同意...");
|
|
|
+ Integer refundCode=null;
|
|
|
+ if(isAgree==1){
|
|
|
+ refundCode=DmConstant.REFUND_CODE_CONFIRM_RECEIVING;
|
|
|
+ }
|
|
|
+ else if(isAgree==2){
|
|
|
+ refundCode=DmConstant.REFUND_CODE_REFUSE_AGAIN;
|
|
|
+ }
|
|
|
+ else{
|
|
|
+ throw new ParamException("请传入正确的状态值");
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ Integer code=orderDao.updateOrderItemRefundStatus(orderItemId,refundCode);
|
|
|
+ AssertUtil.intIsNotEmpty(code,"子订单更新失败");
|
|
|
+ if(isAgree==1){
|
|
|
+
|
|
|
+ String refundCodes="1,2,3,5,6,8,9,11";
|
|
|
+ Integer code2=orderDao.findIsHaveRefundOrder(orderId,refundCodes);
|
|
|
+
|
|
|
+ if(code2==null||code2<0){
|
|
|
+ Integer code3=orderDao.updateOrderRefundStatus(orderId,refundCode);
|
|
|
+ AssertUtil.intIsNotEmpty(code3,"父订单更新失败");
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+}
|