Nessuna descrizione

SyncMjOrderStatus.php 2.8KB

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