ZendFrameworkPaginatorAdapter::getUrl()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 4
ccs 2
cts 2
cp 1
rs 10
c 0
b 0
f 0
cc 1
nc 1
nop 1
crap 1
1
<?php
2
3
/*
4
 * This file is part of the League\Fractal package.
5
 *
6
 * (c) Phil Sturgeon <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace League\Fractal\Pagination;
13
14
use Zend\Paginator\Paginator;
15
16
/**
17
 * A paginator adapter for zendframework/zend-paginator.
18
 *
19
 * @author Abdul Malik Ikhsan <[email protected]>
20
 */
21
class ZendFrameworkPaginatorAdapter implements PaginatorInterface
22
{
23
    /**
24
     * The paginator instance.
25
     *
26
     * @var \Zend\Paginator\Paginator
27
     */
28
    protected $paginator;
29
30
    /**
31
     * The route generator.
32
     *
33
     * @var callable
34
     */
35
    protected $routeGenerator;
36
37
    /**
38
     * Create a new zendframework pagination adapter.
39
     *
40
     * @param \Zend\Paginator\Paginator $paginator
41
     * @param callable                  $routeGenerator
42
     *
43
     * @return void
0 ignored issues
show
Comprehensibility Best Practice introduced by
Adding a @return annotation to constructors is generally not recommended as a constructor does not have a meaningful return value.

Adding a @return annotation to a constructor is not recommended, since a constructor does not have a meaningful return value.

Please refer to the PHP core documentation on constructors.

Loading history...
44
     */
45 1
    public function __construct(Paginator $paginator, $routeGenerator)
46
    {
47 1
        $this->paginator = $paginator;
48 1
        $this->routeGenerator = $routeGenerator;
49 1
    }
50
51
    /**
52
     * Get the current page.
53
     *
54
     * @return int
55
     */
56 1
    public function getCurrentPage()
57
    {
58 1
        return $this->paginator->getCurrentPageNumber();
59
    }
60
61
    /**
62
     * Get the last page.
63
     *
64
     * @return int
65
     */
66 1
    public function getLastPage()
67
    {
68 1
        return $this->paginator->count();
69
    }
70
71
    /**
72
     * Get the total.
73
     *
74
     * @return int
75
     */
76 1
    public function getTotal()
77
    {
78 1
        return $this->paginator->getTotalItemCount();
79
    }
80
81
    /**
82
     * Get the count.
83
     *
84
     * @return int
85
     */
86 1
    public function getCount()
87
    {
88 1
        return $this->paginator->getCurrentItemCount();
89
    }
90
91
    /**
92
     * Get the number per page.
93
     *
94
     * @return int
95
     */
96 1
    public function getPerPage()
97
    {
98 1
        return $this->paginator->getItemCountPerPage();
99
    }
100
101
    /**
102
     * Get the url for the given page.
103
     *
104
     * @param int $page
105
     *
106
     * @return string
107
     */
108 1
    public function getUrl($page)
109
    {
110 1
        return call_user_func($this->routeGenerator, $page);
111
    }
112
113
    /**
114
     * Get the paginator instance.
115
     *
116
     * @return \Zend\Paginator\Paginator
117
     */
118
    public function getPaginator()
119
    {
120
        return $this->paginator;
121
    }
122
123
    /**
124
     * Get the the route generator.
125
     *
126
     * @return callable
127
     */
128
    public function getRouteGenerator()
129
    {
130
        return $this->routeGenerator;
131
    }
132
}
133