Nenhuma Descrição

SyncMjOrderStatus.php 6.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. <?php
  2. namespace App\Console\Commands;
  3. use Illuminate\Console\Command;
  4. use DB;
  5. use App\Order;
  6. use App\FxOrder;
  7. use App\GoodsSkus;
  8. use App\OrderGoodsSkus;
  9. use App\FxOrderGoodsSkus;
  10. class SyncMjOrderStatus extends Command {
  11. protected $signature = 'SyncMjOrderStatus';
  12. /**
  13. * The console command description.
  14. *
  15. * @var string
  16. */
  17. protected $description = '同步订单状态';
  18. public function handle()
  19. {
  20. $this->SyncMjOrderStatus();
  21. $this->SyncFxOrderStatus();
  22. }
  23. public function SyncMjOrderStatus(){
  24. $orders = Order::select('id', 'outerCode', 'admin_id')->where('orderCode','>',0)->where('status', '<', 3)->where('warehouse', 3)->where('is_del', 0)->orderBy('id', 'desc')->get();
  25. $orders = json_decode(json_encode($orders), true);
  26. foreach($orders as $k=>$order){
  27. $result = $this->getMjOrder($order['id'], $order['outerCode']);
  28. if( !empty($result) ){
  29. $data = array();
  30. if( isset($result['expressCode']) && !empty($result['expressCode']) ){
  31. $data['is_cannot_del'] = 1;
  32. }
  33. $status = $result['status'];
  34. if($status == '已发货' || $status == '已完成'){
  35. $data['status'] = 3;
  36. $data['logistics_id'] = $result['expressCode'];
  37. $data['send_time'] = !empty($result['deliveryTime']) ? date('Y-m-d', substr($result['deliveryTime'], 0, 10) ) : date('Y-m-d');
  38. $data['cost'] = 0;
  39. #计算成本
  40. //if($sku_info->referenceCost) $cost += $sku_info->referenceCost * $gnum[$k];
  41. foreach($result['skuList'] as $key=>$sku){
  42. $skuCode = $sku['skuCode'];
  43. $code_arr = explode('|', $skuCode);
  44. $sku_id = $code_arr[1];
  45. $cost = GoodsSkus::select('referenceCost', 'is_weigh')->where('id', $sku_id)->first(); //获取规格成本/是否称重
  46. $quantity = $cost->is_weigh == 1 ? $sku['quantity']/2 : $sku['quantity']; //对应规格数量
  47. if(isset($sku['cost'])) {
  48. $data['cost'] += $sku['cost']*$sku['quantity']; //对应规格总成本
  49. } else {
  50. $data['cost'] += 0;
  51. // $data['cost'] += $cost->referenceCost * $quantity; //对应规格总成本
  52. }
  53. // $data['cost'] += $cost->referenceCost * $quantity; //对应规格总成本
  54. #更新order_sku
  55. OrderGoodsSkus::where('order_id', $order['id'])->where('sku_id', $sku_id)->update(['send_num'=>$quantity]);
  56. }
  57. }
  58. if(!empty($data)){
  59. Order::where('id', $order['id'])->update($data);
  60. }
  61. }
  62. }
  63. }
  64. public function SyncFxOrderStatus(){
  65. $orders = FxOrder::select('id', 'outerCode')->where('orderCode','>',0)->where('status', '<', 3)->where('warehouse', 3)->where('is_del', 0)->orderBy('id', 'desc')->get();
  66. $orders = json_decode(json_encode($orders), true);
  67. foreach($orders as $k=>$order){
  68. $result = $this->getFxMjOrder($order['id'], $order['outerCode']);
  69. if( !empty($result) ){
  70. $data = array();
  71. if( isset($result['expressCode']) && !empty($result['expressCode']) ){
  72. $data['is_cannot_del'] = 1;
  73. }
  74. $status = $result['status'];
  75. if($status == '已发货' || $status == '已完成'){
  76. $data['status'] = 3;
  77. $data['logistics_id'] = $result['expressCode'];
  78. $data['send_time'] = !empty($result['deliveryTime']) ? date('Y-m-d', substr($result['deliveryTime'], 0, 10) ) : date('Y-m-d');
  79. $data['cost'] = 0;
  80. #计算成本
  81. foreach($result['skuList'] as $key=>$sku){
  82. $skuCode = $sku['skuCode'];
  83. $code_arr = explode('|', $skuCode);
  84. $sku_id = $code_arr[1];
  85. $cost = GoodsSkus::select('referenceCost', 'is_weigh')->where('id', $sku_id)->first(); //获取规格成本/是否称重
  86. $quantity = $cost->is_weigh == 1 ? $sku['quantity']/2 : $sku['quantity']; //对应规格数量
  87. if(isset($sku['cost'])) {
  88. $data['cost'] += ceil($sku['cost'] * $sku['quantity'] * 115)/100; //对应规格总成本
  89. } else {
  90. $data['cost'] += 0;
  91. // $data['cost'] += $cost->referenceCost * $quantity; //对应规格总成本
  92. }
  93. // $data['cost'] += $cost->referenceCost * $quantity; //对应规格总成本
  94. #更新order_sku
  95. FxOrderGoodsSkus::where('order_id', $order['id'])->where('sku_id', $sku_id)->update(['send_num'=>$quantity]);
  96. }
  97. }
  98. if(!empty($data)){
  99. FxOrder::where('id', $order['id'])->update($data);
  100. }
  101. }
  102. }
  103. }
  104. /**
  105. * 获取订单信息,可用来判断订单是否存在,同步订单状态
  106. */
  107. public function getMjOrder($id, $outerCode=''){
  108. $order = array();
  109. $order['eshopCode'] = config('constants.ESHOP_CODE');
  110. if(!$outerCode){
  111. $outerCode = Order::where('id', $id)->pluck('outerCode');
  112. }
  113. $order['outerCode'] = $outerCode;
  114. $mjOrder = Order::mjOrderGet($order);
  115. if(!isset($mjOrder['order']['code'])){
  116. return false;
  117. }
  118. return $mjOrder['order'];
  119. }
  120. /**
  121. * 获取订单信息,可用来判断订单是否存在,同步订单状态
  122. */
  123. public function getFxMjOrder($id, $outerCode=''){
  124. $order = array();
  125. $order['eshopCode'] = config('constants.ESHOP_CODE');
  126. if(!$outerCode){
  127. $outerCode = FxOrder::where('id', $id)->pluck('outerCode');
  128. }
  129. $order['outerCode'] = $outerCode;
  130. $mjOrder = Order::mjOrderGet($order);
  131. if(!isset($mjOrder['order']['code'])){
  132. return false;
  133. }
  134. return $mjOrder['order'];
  135. }
  136. }