Download the PHP package esi/pagination without Composer
On this page you can find all versions of the php package esi/pagination. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Informations about the package pagination
Pagination
Esi\Pagination
- A library that implements a paging interface on collections of things.
Installation
Esi\Pagination
can be installed via Composer:
How Pagination Works
I have tried to make Pagination as simple, flexible, and easy to use as possible. There are four main elements that describe the operation of Pagination. These are:
- Paginator service
- Item total callback
- Slice callback
- Pagination model
The Paginator service performs the pagination algorithm, generating the page range and item collection slices. When it is done, it will return a Pagination object filled with the item collection slice and metadata.
The two main operations the Paginator service will perform on your collection (or data set) are denoted by two callback methods passed to the Paginator service. The first one is the Item total callback. This callback is used to determine the total amount of items in your collection (returned as an integer). The second one is the Slice callback. This callback actually slices your collection given an offset and length argument.
The idea behind using these callbacks is so that Pagination is kept, well, simple! The real power comes with the flexibility. You can use Pagination with just about any collection you want. From simple arrays to database lists to Doctrine collections to Solr result sets — we have you covered! It really doesn't matter what we paginate — as long as it is a collection of things, and you can count and slice it.
Basic Usage
First, the most basic example — paginating over an array.
There are lots of other pieces of metadata held within the pagination object. These can be used for building first, last, previous and next buttons.
MySQL Example
Now take the example above and use a MySQL result set instead of an array.
Note: The example above uses mysqli
as I tried to make it as simple as possible. In the real world please use PDO,
Doctrine DBAL, etc.
It really does not matter what sort of collection you return from the Paginator::setSliceCallback()
callback. It will always end up in Pagination::getItems()
.
Constructor Configuration
You can also configure the paginator with a configuration array passed to the constructor. For example:
Pagination as an Iterator
The Pagination
object returned from the Paginator
service implements \IteratorAggregate
and \Countable
so you can do things like this in your view:
Arbitrary Pagination Metadata
In itemTotalCallback
and sliceCallback
, you have the option of passing arbitrary metadata to the pagination object. This is an optional feature
and is useful if you have a use-case where additional data is returned by these operations, and you want to access it from the pagination object
whilst listing the items. A good example of this is when using search engines such as ElasticSearch, you
can pass back secondary information — like aggregations, etc. A generic example can be seen below:
Pre-Query and Post-Query Callbacks
Before and after the count and slice queries, you can set callbacks to fire. To set them, do the following:
This is handy if you want to perform some function or process, such as adding/removing meta data, before and after each query is made.
Pagination Object
Paginator::paginate()
will return a Pagination
model object, which carries the item collection for the current page plus the meta
information for the collection. For e.g., the pages array, next page number, previous page number, etc.
Please see below for a list of properties that the Pagination
object has.
- items : array (Collection of items for the current page)
- pages : array (Array of page numbers in the current range)
- totalNumberOfPages : int (Total number of pages)
- currentPageNumber : int (Current page number)
- firstPageNumber : int (First page number)
- lastPageNumber : int (Last page number)
- previousPageNumber : int | null (Previous page number)
- nextPageNumber : int | null (Next page number)
- itemsPerPage : int (Number of items per page)
- totalNumberOfItems : int (Total number of items)
- firstPageNumberInRange : int (First page number in current range)
- lastPageNumberInRange : int (Last page number in current range)
A good example of using the Pagination
object is to build a simple pagination navigation structure:
About
Requirements
- Pagination works with PHP 8.2.0 or above.
Credits
This library is a fork
of the AshleyDawson\SimplePagination library by Ashley Dawson.
To view changes in this library in comparison to the original library, please see the CHANGELOG.md file.
- Author: Eric Sizemore
- Thanks to Ashley Dawson for the original AshleyDawson\SimplePagination library that this library is forked from.
- Thanks to all Contributors.
- Special thanks to JetBrains for their Licenses for Open Source Development.
Contributing
See CONTRIBUTING.
Bugs and feature requests are tracked on GitHub.
Contributor Covenant Code of Conduct
See CODE_OF_CONDUCT.md
Backward Compatibility Promise
See backward-compatibility.md for more information on Backwards Compatibility.
Changelog
See the CHANGELOG for more information on what has changed recently.
License
See the LICENSE for more information on the license that applies to this project.
Security
See SECURITY for more information on the security disclosure process.