Completed
Pull Request — master (#162)
by
unknown
01:22
created

SimplePaginate   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 18
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 1

Importance

Changes 0
Metric Value
wmc 2
lcom 0
cbo 1
dl 0
loc 18
rs 10
c 0
b 0
f 0

1 Method

Rating   Name   Duplication   Size   Complexity  
A __invoke() 0 15 2
1
<?php
2
3
namespace Spatie\CollectionMacros\Macros;
4
5
use Illuminate\Pagination\Paginator;
6
7
/*
8
 * Paginate the collection into a simple paginator
9
 *
10
 * @param int $perPage
11
 * @param int $page
12
 * @param string $pageName
13
 *
14
 * @return \Illuminate\Contracts\Pagination\Paginator
15
 */
16
class SimplePaginate
17
{
18
    public function __invoke()
19
    {
20
        return function (int $perPage = 15, string $pageName = 'page', int $page = null, array $options = []): Paginator {
21
            $page = $page ?: Paginator::resolveCurrentPage($pageName);
22
23
            $results = $this->slice(($page - 1) * $perPage)->take($perPage + 1);
0 ignored issues
show
Bug introduced by
The method slice() does not seem to exist on object<Spatie\Collection...\Macros\SimplePaginate>.

This check looks for calls to methods that do not seem to exist on a given type. It looks for the method on the type itself as well as in inherited classes or implemented interfaces.

This is most likely a typographical error or the method has been renamed.

Loading history...
24
25
            $options += [
26
                'path' => Paginator::resolveCurrentPath(),
27
                'pageName' => $pageName,
28
            ];
29
30
            return new Paginator($results, $perPage, $page, $options);
31
        };
32
    }
33
}
34