From 037507bbe28ab8093c8cb20b4af85888f67be65a Mon Sep 17 00:00:00 2001
From: CeDo <cedoogle@gmail.com>
Date: 星期四, 22 四月 2021 14:02:03 +0800
Subject: [PATCH] Default Changelist

---
 springcloud_k8s_panzhihuazhihuishequ/service_community/src/main/java/com/panzhihua/service_community/service/impl/ComShopOrderServiceImpl.java |   83 +++++++++++++++++++++++++++++++++++++----
 1 files changed, 74 insertions(+), 9 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 a1f380d..37ce854 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
@@ -559,8 +559,13 @@
             return R.fail("订单不存在");
         }
         if(!(comShopOrderDO.getStatus()==2)
-                || !(comShopOrderDO.getDeleteStatus()==1)){
+                || !(comShopOrderDO.getDeliveryStatus()==1)){
             return R.fail("订单发货失败,订单状态不允许发货");
+        }
+
+        ComShopStoreDO storeDO  = comShopStoreDAO.selectById(comShopOrderDO.getStoreId());
+        if(storeDO.getDeliveryType()!=2){
+            return R.fail("该商家不支持通过快递物流发货");
         }
         comShopOrderDO.setDeliveryStatus(2);
         comShopOrderDO.setDeliveryType(2);
@@ -569,41 +574,101 @@
         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("订单不存在");
         }
-        if(!(comShopOrderDO.getStatus()==2)){
+        if(!(comShopOrderDO.getStatus()==2)
+                || !(comShopOrderDO.getDeliveryStatus()==1)){
             return R.fail("当前订单不能配送");
+        }
+        ComShopStoreDO storeDO  = comShopStoreDAO.selectById(comShopOrderDO.getStoreId());
+        if(storeDO.getDeliveryType()!=1){
+            return R.fail("该商家不支持通过商家配送");
         }
         comShopOrderDO.setDeliveryStatus(4);
         comShopOrderDO.setDeliveryType(1);
+        comShopOrderDO.setStatus(3);
         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("操作失败!");
@@ -612,7 +677,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());
@@ -621,7 +686,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());

--
Gitblit v1.7.1