model = new ModelWphOrder(); } /** * 订单入库和更新 * * @return void */ public function fanliOrder($order) { $order_list = isset($order['detailList']) ? $order['detailList'] : []; if(empty($order_list))return ['status'=>false,'info'=>'商品数据为空']; foreach($order_list as $item){ Db::startTrans(); $find_order = $this->model->where(['order_sn'=>$order['orderSn'],'goods_id'=>$item['goodsId'],'size_id'=>$item['sizeId']])->find(); $save_order = [ 'order_sn' => $order['orderSn'], 'status' => isset($order['status']) ? $order['status'] : '', 'new_customer' => isset($order['newCustomer']) ? $order['newCustomer'] : '', 'channel_tag' => isset($order['channelTag']) ? $order['channelTag'] : '', 'order_time' => isset($order['orderTime']) ? $order['orderTime'] : '', 'sign_time' => isset($order['signTime']) ? $order['signTime'] : '', 'settled_time' => isset($order['settledTime']) ? $order['settledTime'] : '', 'commission_total_cost' => isset($item['commissionTotalCost']) ? $item['commissionTotalCost'] : '', 'commission_rate' => isset($item['commissionRate']) ? $item['commissionRate'] : '', 'order_source' => isset($item['orderSource']) ? $item['orderSource'] : '', 'goods_id' => isset($item['goodsId']) ? $item['goodsId'] : '', 'goods_final_price' => isset($item['goodsFinalPrice']) ? $item['goodsFinalPrice'] : '', 'goods_count' => isset($item['goodsCount']) ? $item['goodsCount'] : '', 'goods_thumb' => isset($item['goodsThumb']) ? $item['goodsThumb'] : '', 'commission' => isset($item['commission']) ? $item['commission'] : '', 'comm_name' => isset($item['commName']) ? $item['commName'] : '', 'goods_name' => isset($item['goodsName']) ? $item['goodsName'] : '', 'order_sub_status_name' => isset($order['orderSubStatusName']) ? $order['orderSubStatusName'] : '', 'size_id' => isset($item['sizeId']) ? $item['sizeId'] : '', 'spu_id' => isset($item['spuId']) ? $item['spuId'] : '', ]; if(empty($find_order)){ $save_order['tk_z_status'] = 1; $save_order['is_distribution'] = (empty($save_order['channel_tag']) || $save_order['channel_tag'] == 0) ? 2 : 0; //如果没有渠道关系ID则该订单无须反佣 $save_order['reate_time'] = time(); $res = $this->model->insert($save_order); if(!$res){ Db::rollback(); return ['status'=>false,'info'=>'订单添加失败,订单order_sn:'.$order['orderSn'].',sizeId:'.$save_order['size_id'].',spuId:'.$save_order['spu_id']]; } }else{ if($find_order['order_sub_status_name'] != $save_order['order_sub_status_name']){ //订单发生改变,更新订单 $save_order['update_time'] = time(); $save_order['tk_z_status'] = 2; $res_update = $this->model->where(['id'=> $find_order['id']])->update($save_order); if(!$res_update){ Db::rollback(); return ['status'=>false,'info'=>'订单更新失败,订单order_sn:'.$order['orderSn'].',sizeId:'.$save_order['size_id'].',spuId:'.$save_order['spu_id']]; } } } Db::commit(); } return ['status'=>true,'info'=>'订单逻辑处理完成']; } /** * 拆分订单 * * @return void */ public function chaifenOrder() { $list = $this->model->where(['is_distribution'=>0,'channel_tag'=>['neq',''],'channel_tag'=>['neq',0]])->whereOr("is_distribution = 1 And tk_z_status = 2 And channel_tag !=''")->limit(20)->order('id desc')->select(); if(!empty($list)){ $LogicWphCommission = new LogicWphCommission(); foreach($list as $order){ $result = $LogicWphCommission->fanliCommission($order); if(!$result){ mylog('订单拆分错误',$result['info'],"errorInfo"); } } } return ['status'=>true,'info'=>'拆分逻辑执行完成']; } }