Custom data pagination with Laravel 5

2015/04/22

Let’s say that you have an array of data, e.g results from a search query, and you want to paginate them.

Laravel provides pagination for Eloquent results out of the box, but for custom data we need to do the pagination manually.

Let see how in the next example:

<?php namespace App\Http\Controllers;

use Illuminate\Pagination\LengthAwarePaginator;
use Illuminate\Support\Collection;

class SearchController extends Controller {

	public function search()
	{
	    .
	    .
	    .

        $searchResults = [
            'item1',
            'item2',
            'item3',
            'item4',
            'item5',
            'item6',
            'item7',
            'item8',
            'item9',
            'item10'
            ];

        //Get current page form url e.g. &page=6
        $currentPage = LengthAwarePaginator::resolveCurrentPage();

        //Create a new Laravel collection from the array data
        $collection = new Collection($searchResults);

        //Define how many items we want to be visible in each page
        $perPage = 5;

        //Slice the collection to get the items to display in current page
        $currentPageSearchResults = $collection->slice($currentPage * $perPage, $perPage)->all();

        //Create our paginator and pass it to the view
        $paginatedSearchResults= new LengthAwarePaginator($currentPageSearchResults, count($collection), $perPage);

        return view('search', ['results' => $paginatedSearchResults]);
    }
?>

Now in the view add the following:

{% raw %}

    @foreach ($results as $result)
        <p>{{ $result }}</p>
    @endforeach

    <?php echo $results->render(); ?>

{% endraw %}

Categories: posts Tags: php laravel