From 2eea3290641657d2ee13edd90d27f8b2ec01c209 Mon Sep 17 00:00:00 2001
From: 罗yu 元桥 <2376770955@qq.com>
Date: 星期六, 08 五月 2021 18:23:48 +0800
Subject: [PATCH] Merge branch 'test' into 'master'

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopOrderServiceImpl.java |  109 +++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 91 insertions(+), 18 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopOrderServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopOrderServiceImpl.java
index 5bfbc88..2569896 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopOrderServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopOrderServiceImpl.java
@@ -29,6 +29,7 @@
 import java.math.BigDecimal;
 import java.text.SimpleDateFormat;
 import java.util.ArrayList;
+import java.util.Calendar;
 import java.util.Date;
 import java.util.List;
 
@@ -161,6 +162,7 @@
         if(shopOrders.isEmpty()){//未查询到用户上一笔订单
             //查询用户收货地址中的默认地址
             ComShopUserAddressDO userAddressDO = comShopUserAddressDAO.selectOne(new QueryWrapper<ComShopUserAddressDO>()
+                    .eq("delete_status", 2)
                     .eq("user_id",orderPreviewDTO.getUserId()).eq("is_default",ComShopUserAddressDO.isDefault.yes));
             if(userAddressDO != null){
                 ComShopUserAddressVO userAddressVO = new ComShopUserAddressVO();
@@ -178,9 +180,11 @@
         }else{//查询到用户上一笔订单
             ComShopUserAddressDO userAddressDO = comShopUserAddressDAO.selectById(shopOrders.get(0).getReceiverId());
             if(userAddressDO != null){
-                ComShopUserAddressVO userAddressVO = new ComShopUserAddressVO();
-                BeanUtils.copyProperties(userAddressDO,userAddressVO);
-                orderPreviewVO.setUserAddressVO(userAddressVO);
+                if(userAddressDO.getDeleteStatus() == 2) {
+                    ComShopUserAddressVO userAddressVO = new ComShopUserAddressVO();
+                    BeanUtils.copyProperties(userAddressDO, userAddressVO);
+                    orderPreviewVO.setUserAddressVO(userAddressVO);
+                }
             }
         }
         return R.ok(orderPreviewVO);
@@ -198,7 +202,7 @@
         ComShopOrderVO shopOrderVO = new ComShopOrderVO();
         //查询用户收货地址
         ComShopUserAddressDO userAddressDO = comShopUserAddressDAO.selectById(orderCreateDTO.getReceiverId());
-        if(userAddressDO == null){
+        if(userAddressDO == null||userAddressDO.getDeleteStatus()!=2){
             return R.fail("收货地址不存在");
         }
         //用户id
@@ -287,6 +291,7 @@
         comShopOrderOperateDAO.insert(orderOperateDO);
         shopOrderVO.setOrderNo(orderNo);
         shopOrderVO.setOrderTotal(orderTotal);
+        shopOrderVO.setOrderId(shopOrderDO.getId());
 
         try {
             BigDecimal money = orderTotal;
@@ -384,6 +389,16 @@
                 orderGoodsVO.setNum(orderGoods.getAmount());
                 orderGoodsVO.setGoodsPic(orderGoods.getGoodsAttrPic());
                 orderGoodsVO.setPrice(orderGoods.getGoodsAttrPrice());
+                //查询商品信息判断商品状态
+                ComShopGoodsDO goodsDO = comShopGoodsDAO.selectById(orderGoods.getGoodsId());
+                if(goodsDO == null || goodsDO.getDeleteStatus().equals(ComShopGoodsDO.deleteStatus.yes) || goodsDO.getDeleteStatus().equals(ComShopGoodsDO.status.recovery)){
+                    orderGoodsVO.setGoodsStatus(ComShopOrderGoodsVO.goodsStatus.ysc);
+                }else if(goodsDO.getStatus().equals(ComShopGoodsDO.status.lower)){
+                    orderGoodsVO.setGoodsStatus(ComShopOrderGoodsVO.goodsStatus.yxj);
+                }else if(goodsDO.getStatus().equals(ComShopGoodsDO.status.sell)){
+                    orderGoodsVO.setGoodsStatus(ComShopOrderGoodsVO.goodsStatus.csz);
+                }
+
                 //根据商品规格id查询商品规格
                 ComShopGoodsAttrDO goodsAttrDO = comShopGoodsAttrDAO.selectById(orderGoods.getGoodsAttrId());
                 if(goodsAttrDO != null){
@@ -418,15 +433,14 @@
 
     /**
      * 根据订单id取消订单
-     * @param orderId   订单id
-     * @param phone 操作用户手机号
+     * @param comShopOrderQueryDTO   订单信息
      * @return  取消结果
      */
     @Transactional(rollbackFor = Exception.class)
     @Override
-    public R orderCancel(Long orderId,String phone){
+    public R orderCancel(ComShopOrderQueryDTO comShopOrderQueryDTO){
         //查询订单
-        ComShopOrderDO shopOrderDO = this.baseMapper.selectById(orderId);
+        ComShopOrderDO shopOrderDO = this.baseMapper.selectById(comShopOrderQueryDTO.getOrderId());
         if(shopOrderDO == null){
             return R.fail("未查询到订单");
         }
@@ -441,9 +455,9 @@
             orderOperateDO.setOrderNo(shopOrderDO.getOrderNo());
             orderOperateDO.setOperationType(ComShopOrderOperateDO.operationType.cancel);
             orderOperateDO.setOperationTime(new Date());
-            if(StringUtils.isNotEmpty(phone)){
-                orderOperateDO.setOperationContent("用户" + phone + "取消订单");
-                orderOperateDO.setOperationBy("用户" + phone);
+            if(comShopOrderQueryDTO.getIsAdmin()){
+                orderOperateDO.setOperationContent("管理员" + comShopOrderQueryDTO.getOperUserAccount() + "取消订单");
+                orderOperateDO.setOperationBy("用户" + comShopOrderQueryDTO.getOperUserAccount());
             }else {
                 orderOperateDO.setOperationContent("用户取消订单");
                 orderOperateDO.setOperationBy("用户");
@@ -499,6 +513,7 @@
         }
         //订单确认收货
         shopOrderDO.setStatus(ComShopOrderDO.status.ywc);
+        shopOrderDO.setReceivingTime(new Date());
         if(this.baseMapper.updateById(shopOrderDO) > 0){
             //添加订单操作记录
             ComShopOrderOperateDO orderOperateDO = new ComShopOrderOperateDO();
@@ -570,18 +585,35 @@
         comShopOrderDO.setDeliveryStatus(2);
         comShopOrderDO.setDeliveryType(2);
         comShopOrderDO.setStatus(3);
+        comShopOrderDO.setDeliveryTime(Calendar.getInstance().getTime());
         comShopOrderDO.setLogisticsCompany(orderShipDTO.getLogisticsCompany());
         comShopOrderDO.setLogisticsNo(orderShipDTO.getLogisticsNo());
         int updated = comShopOrderDAO.updateById(comShopOrderDO);
         if(updated==1){
+            //创建订单操作记录
+            ComShopOrderOperateDO orderOperateDO = new ComShopOrderOperateDO();
+            orderOperateDO.setOrderNo(comShopOrderDO.getOrderNo());
+            orderOperateDO.setOperationType(ComShopOrderOperateDO.operationType.deliver);
+            orderOperateDO.setOperationTime(new Date());
+            if(orderShipDTO.getIsAdmin()){
+                orderOperateDO.setOperationContent(orderShipDTO.getOperUserAccount()+"已发货");
+                orderOperateDO.setOperationBy(orderShipDTO.getOperUserAccount());
+            }else {
+                orderOperateDO.setOperationContent(orderShipDTO.getOperUserAccount() + "已发货");
+                orderOperateDO.setOperationBy(orderShipDTO.getOperUserAccount());
+            }
+            int inserted = comShopOrderOperateDAO.insert(orderOperateDO);
+            if(inserted!=1){
+                log.error("订单发货日志保存错误");
+            }
             return R.ok("发货成功");
         }
         return R.fail("发货失败!");
     }
 
     @Override
-    public R deliverOrder(Long orderId) {
-        ComShopOrderDO comShopOrderDO = comShopOrderDAO.selectById(orderId);
+    public R deliverOrder(ComShopOrderDeliverDTO orderDeliverDTO) {
+        ComShopOrderDO comShopOrderDO = comShopOrderDAO.selectById(orderDeliverDTO.getOrderId());
         if(comShopOrderDO==null){
             return R.fail("订单不存在");
         }
@@ -596,25 +628,63 @@
         comShopOrderDO.setDeliveryStatus(4);
         comShopOrderDO.setDeliveryType(1);
         comShopOrderDO.setStatus(3);
+        comShopOrderDO.setDeliveryTime(Calendar.getInstance().getTime());
         int updated = comShopOrderDAO.updateById(comShopOrderDO);
         if(updated==1){
+
+            //创建订单操作记录
+            ComShopOrderOperateDO orderOperateDO = new ComShopOrderOperateDO();
+            orderOperateDO.setOrderNo(comShopOrderDO.getOrderNo());
+            orderOperateDO.setOperationType(ComShopOrderOperateDO.operationType.deliver);
+            orderOperateDO.setOperationTime(new Date());
+            if(orderDeliverDTO.getIsAdmin()){
+                orderOperateDO.setOperationContent(orderDeliverDTO.getOperUserAccount() + "已发货");
+                orderOperateDO.setOperationBy(orderDeliverDTO.getOperUserAccount());
+            }else {
+                orderOperateDO.setOperationContent(orderDeliverDTO.getOperUserAccount() + "已发货");
+                orderOperateDO.setOperationBy(orderDeliverDTO.getOperUserAccount());
+            }
+            int inserted = comShopOrderOperateDAO.insert(orderOperateDO);
+            if(inserted!=1){
+                log.error("订单发货日志保存错误");
+            }
             return R.ok("开始配送");
         }
         return R.fail("操作失败!");
     }
 
     @Override
-    public R finishDeliverOrder(Long orderId) {
-        ComShopOrderDO comShopOrderDO = comShopOrderDAO.selectById(orderId);
+    public R finishDeliverOrder(ComShopOrderDeliverDTO orderDeliverDTO) {
+        ComShopOrderDO comShopOrderDO = comShopOrderDAO.selectById(orderDeliverDTO.getOrderId());
         if(comShopOrderDO==null){
             return R.fail("订单不存在");
         }
-        if(!(comShopOrderDO.getDeliveryStatus() == 4)){
+        if(comShopOrderDO.getDeliveryStatus() != 4 && comShopOrderDO.getDeliveryStatus() != 3){
             return R.fail("订单还未开始配送");
         }
+        if(!(comShopOrderDO.getStatus() == 3)){
+            return R.fail("订单还未发货");
+        }
+        //comShopOrderDO.setStatus(4);
         comShopOrderDO.setDeliveryStatus(5);
         int updated = comShopOrderDAO.updateById(comShopOrderDO);
         if(updated==1){
+            //创建订单操作记录
+            ComShopOrderOperateDO orderOperateDO = new ComShopOrderOperateDO();
+            orderOperateDO.setOrderNo(comShopOrderDO.getOrderNo());
+            orderOperateDO.setOperationType(ComShopOrderOperateDO.operationType.complete);
+            orderOperateDO.setOperationTime(new Date());
+            if(orderDeliverDTO.getIsAdmin()){
+                orderOperateDO.setOperationContent("订单已完成");
+                orderOperateDO.setOperationBy(orderDeliverDTO.getOperUserAccount());
+            }else {
+                orderOperateDO.setOperationContent("订单已完成");
+                orderOperateDO.setOperationBy(orderDeliverDTO.getOperUserAccount());
+            }
+            int inserted = comShopOrderOperateDAO.insert(orderOperateDO);
+            if(inserted!=1){
+                log.error("订单发货日志保存错误");
+            }
             return R.ok("配送完成");
         }
         return R.fail("操作失败!");
@@ -623,7 +693,7 @@
     @Override
     public R shopOrderExportData(ComShopOrderExportDTO comShopOrderExportDTO) {
         Page page = new Page();
-        page.setSize(1000);
+        page.setSize(10000);
         page.setCurrent(1);
         IPage<ExcelShopOrderDTO>  excelShopOrderDTO = comShopOrderDAO.selectOrderExport(page, comShopOrderExportDTO);
         return R.ok(excelShopOrderDTO.getRecords());
@@ -632,7 +702,7 @@
     @Override
     public R shopOrderFundsExportData(ComShopFundsExportDTO comShopFundsExportDTO) {
         Page page = new Page();
-        page.setSize(1000);
+        page.setSize(10000);
         page.setCurrent(1);
         IPage<ExcelShopFundsDTO>  excelShopFundsDTO = comShopOrderDAO.selectFundsExport(page, comShopFundsExportDTO);
         return R.ok(excelShopFundsDTO.getRecords());
@@ -798,6 +868,9 @@
         }catch (Exception e){
             log.error("调用微信支付异常,异常原因:" + e.getMessage());
         }
+        shopOrderVO.setOrderId(orderDO.getId());
+        shopOrderVO.setOrderNo(orderDO.getOrderNo());
+        shopOrderVO.setOrderTotal(orderDO.getTotalAmount());
         return R.ok(shopOrderVO);
     }
 

--
Gitblit v1.7.1