Нет описания

CleaningData.php 3.5KB

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