Have you ever been in situation where you want to run sortBy method, to sort content by specific relation on object, but content is paginated also?
In that scenario you can only sort per page, and not overall result.
So we have:
and that would work perfectly, but the problem is simple, you can’t call ->paginate(x) on collection which get() returns.
At that scenario, it’s time to go to very top of your controller and to append following uses:
Next thing to do, is to implement following function which enables you to paginate collection, and it needs to look like:
private function paginate($items, $perPage = 5, $page = null, $options = )
$page = $page ?: (Paginator::resolveCurrentPage() ?: 1);
$items = $items instanceof Collection ? $items : Collection::make($items);
return new LengthAwarePaginator($items->forPage($page, $perPage), $items->count(), $perPage, $page, $options);
And than, in that controller, you can use $this->paginate($exampleContent->get(), 10), which will paginate your collection same way as ->paginate(10) would do on a query, and contain all same functions.
I’m totally sure that you can find better place for this function, but I’ve used controller just as quick example for educational purposes.