Browse Source

修改同步订单脚本计算成本方式

shensong 5 years ago
parent
commit
719947e390

+ 88 - 0
app/Console/Commands/CleaningData.php

@@ -0,0 +1,88 @@
1
+<?php namespace App\Console\Commands;
2
+
3
+use Illuminate\Console\Command;
4
+use DB;
5
+use App\Order;
6
+use App\GoodsSkus;
7
+use App\OrderGoodsSkus;
8
+
9
+class CleaningData extends Command {
10
+    protected $signature = 'CleaningData';
11
+
12
+    /**
13
+     * The console command description.
14
+     *
15
+     * @var string
16
+     */
17
+    protected $description = '清洗订单成本数据';
18
+
19
+
20
+    public function handle()
21
+    {
22
+        $this->SyncMjOrderStatus();
23
+    }
24
+    public function SyncMjOrderStatus(){
25
+
26
+        $orders = Order::select('id', 'outerCode')->where('orderCode','>',0)->where('status', 3)->where('warehouse', 3)->where('is_del', 0)->orderBy('id', 'desc')->get();
27
+        $orders = json_decode(json_encode($orders), true);
28
+        foreach($orders as $k=>$order){
29
+            $result = $this->getMjOrder($order['id'], $order['outerCode']);
30
+//           print_r($result);die;
31
+            if( !empty($result) ){
32
+                $data = array();
33
+                if( isset($result['expressCode']) && !empty($result['expressCode']) ){
34
+                    $data['is_cannot_del'] = 1;
35
+                }
36
+                $status = $result['status'];
37
+                if($status == '已发货' || $status == '已完成'){
38
+                    $data['status'] = 3;
39
+                    $data['logistics_id'] = $result['expressCode'];
40
+                    $data['send_time'] = !empty($result['deliveryTime']) ? date('Y-m-d', substr($result['deliveryTime'], 0, 10) ) : date('Y-m-d');
41
+                    $data['cost'] = 0;
42
+                    #计算成本
43
+                    //if($sku_info->referenceCost) $cost += $sku_info->referenceCost * $gnum[$k];
44
+                    foreach($result['skuList'] as $key=>$sku){
45
+                        $skuCode = $sku['skuCode'];
46
+                        $code_arr = explode('|', $skuCode);
47
+                        $sku_id = $code_arr[1];
48
+                        $cost = GoodsSkus::select('referenceCost', 'is_weigh')->where('id', $sku_id)->first(); //获取规格成本/是否称重
49
+                        $quantity = $cost->is_weigh == 1 ? $sku['quantity']/2 : $sku['quantity']; //对应规格数量
50
+                        if(isset($sku['cost'])) {
51
+                            $data['cost'] += $sku['cost']; //对应规格总成本
52
+                        } else {
53
+                            echo $order['id'].' ';
54
+                            $data['cost'] += $cost->referenceCost * $quantity; //对应规格总成本
55
+                        }
56
+//                        $data['cost'] += $cost->referenceCost * $quantity; //对应规格总成本
57
+                        #更新order_sku
58
+                        OrderGoodsSkus::where('order_id', $order['id'])->where('sku_id', $sku_id)->update(['send_num'=>$quantity]);
59
+                    }
60
+                }
61
+
62
+                if(!empty($data)){
63
+                    Order::where('id', $order['id'])->update($data);
64
+                }
65
+            }
66
+
67
+        }
68
+
69
+    }
70
+
71
+    /**
72
+     * 获取订单信息,可用来判断订单是否存在,同步订单状态
73
+     */
74
+    public function getMjOrder($id, $outerCode=''){
75
+        $order = array();
76
+        $order['eshopCode'] = config('constants.ESHOP_CODE');
77
+        if(!$outerCode){
78
+            $outerCode = Order::where('id', $id)->pluck('outerCode');
79
+        }
80
+        $order['outerCode'] = $outerCode;
81
+        $mjOrder = Order::mjOrderGet($order);
82
+        if(!isset($mjOrder['order']['code'])){
83
+            return false;
84
+        }
85
+        return $mjOrder['order'];
86
+    }
87
+
88
+}

+ 2 - 3
app/Console/Commands/SyncMjOrderStatus.php

@@ -28,8 +28,7 @@ class SyncMjOrderStatus extends Command {
28 28
         $orders = json_decode(json_encode($orders), true);
29 29
         foreach($orders as $k=>$order){
30 30
             $result = $this->getMjOrder($order['id'], $order['outerCode']);
31
-//           print_r($result);die;
32
-            if( !empty($result) ){             
31
+            if( !empty($result) ){
33 32
                 $data = array();
34 33
                 if( isset($result['expressCode']) && !empty($result['expressCode']) ){
35 34
                     $data['is_cannot_del'] = 1;
@@ -48,7 +47,7 @@ class SyncMjOrderStatus extends Command {
48 47
                         $sku_id = $code_arr[1];
49 48
                         $cost = GoodsSkus::select('referenceCost', 'is_weigh')->where('id', $sku_id)->first(); //获取规格成本/是否称重
50 49
                         $quantity = $cost->is_weigh == 1 ? $sku['quantity']/2 : $sku['quantity']; //对应规格数量
51
-                        $data['cost'] += $sku['cost']; //对应规格总成本
50
+                        $data['cost'] += $sku['cost']*$sku['quantity']; //对应规格总成本
52 51
 //                        $data['cost'] += $cost->referenceCost * $quantity; //对应规格总成本
53 52
                         #更新order_sku
54 53
                         OrderGoodsSkus::where('order_id', $order['id'])->where('sku_id', $sku_id)->update(['send_num'=>$quantity]);

+ 1 - 0
app/Console/Kernel.php

@@ -48,6 +48,7 @@ class Kernel extends ConsoleKernel {
48 48
         'App\Console\Commands\DayGrandSalerTotal',
49 49
         'App\Console\Commands\freightCost',
50 50
         'App\Console\Commands\CustomerOrder',
51
+        'App\Console\Commands\CleaningData',
51 52
     ];
52 53
 
53 54
 	/**