with(['orderGoods', 'market']) ->where([ ['user_id','=',$userId], ['type','=',1] ]); switch ($tab) { case 'all': break; case 'completed': $builder->whereIn('state', OrderState::FINISH); break; case 'unpaid': $builder->where(['state' => OrderState::UNPAID]); break; case 'receiving': $builder->whereIn('state', OrderState::RECEIVING); break; case 'refund': $builder->whereIn('state', OrderState::REFUND); break; } $paginate = $builder->paginate($pagesize); $orders = $paginate->toArray(); return ['has_more_pages' => $paginate->hasMorePages(), 'orders' => $orders['data']]; } public function onlineByStore($storeId, $tab, $page=1, $pagesize=10) { $builder = OrderMain::query() ->select('id','global_order_id', 'money', 'state', 'market_id', 'created_at') ->with(['orders' => function($query) use ($storeId) { $query->where('store_id',$storeId)->with('orderGoods'); }]) ->where([ 'type' => 1 ]); switch ($tab) { case 'all': break; case 'completed': $builder->whereIn('state', OrderState::FINISH); break; case 'unpaid': $builder->where(['state' => OrderState::UNPAID]); break; case 'receiving': $builder->whereIn('state', OrderState::RECEIVING); break; case 'refund': $builder->whereIn('state', OrderState::REFUND); break; } $paginate = $builder->paginate($pagesize); $orders = $paginate->toArray(); return ['has_more_pages' => $paginate->hasMorePages(), 'orders' => $orders['data']]; } public function offlineByStore($storeId, $tab, $page=1, $pagesize=10) { $builder = Order::Join('lanzu_order_main','lanzu_order.order_main_id','lanzu_order_main.id') ->where('store_id', $storeId) ->where('lanzu_order_main.type',4) ->with('user'); $sw = [ 'all'=>'', 'completed'=> OrderState::FINISH, 'unpaid'=> OrderState::UNPAID, 'receiving' => OrderState::RECEIVING, 'refund' => OrderState::REFUND ]; switch ($tab) { case 'all': break; case 'completed': $builder->whereIn('state', OrderState::FINISH); break; case 'unpaid': $builder->where(['state' => OrderState::UNPAID]); break; case 'receiving': $builder->whereIn('state', OrderState::RECEIVING); break; case 'refund': $builder->whereIn('state', OrderState::REFUND); break; } $paginate = $builder->paginate($pagesize); $orders = $paginate->toArray(); return ['has_more_pages' => $paginate->hasMorePages(), 'orders' => $orders['data']]; } }