All Projects → stefangabos → Zebra_pagination

stefangabos / Zebra_pagination

Licence: other
A generic, Twitter Bootstrap compatible, pagination library for automatically generating navigation links

Projects that are alternatives of or similar to Zebra pagination

Sesame
Android architecture components made right
Stars: ✭ 48 (-47.83%)
Mutual labels:  pagination
Utils
🛠 Lightweight utilities for string & array manipulation, image handling, safe JSON encoding/decoding, validation, slug or strong password generating etc.
Stars: ✭ 1,158 (+1158.7%)
Mutual labels:  pagination
Pagination view
Flutter package to simplify pagination of list of items from the internet.
Stars: ✭ 82 (-10.87%)
Mutual labels:  pagination
Templateplugin
A template for creating minecraft plugin from 1.7.10 to 1.16.2
Stars: ✭ 51 (-44.57%)
Mutual labels:  pagination
Squid
Declarative and Reactive Networking for Swift.
Stars: ✭ 61 (-33.7%)
Mutual labels:  pagination
Dotnetpaging
Data paging with ASP.NET and ASP.NET Core
Stars: ✭ 70 (-23.91%)
Mutual labels:  pagination
Datagrid
Datagrid for Laravel v5
Stars: ✭ 44 (-52.17%)
Mutual labels:  pagination
Pager Api
Easy API pagination for Rails
Stars: ✭ 86 (-6.52%)
Mutual labels:  pagination
Mmm Pages
Add pages to your MagicMirror²!
Stars: ✭ 61 (-33.7%)
Mutual labels:  pagination
Queryql
Easily add filtering, sorting, and pagination to your Node.js REST API through your old friend: the query string!
Stars: ✭ 76 (-17.39%)
Mutual labels:  pagination
Ngx Pagination
Pagination for Angular
Stars: ✭ 1,080 (+1073.91%)
Mutual labels:  pagination
Aws Pagination Rules
The rules for pagination in AWS SDKs
Stars: ✭ 57 (-38.04%)
Mutual labels:  pagination
Elements
⚒ Modular components for RecyclerView development enforcing clean, reusable and testable code, with built-in support for paging and complex hierarchies of data.
Stars: ✭ 75 (-18.48%)
Mutual labels:  pagination
Kaminari
⚡ A Scope & Engine based, clean, powerful, customizable and sophisticated paginator for Ruby webapps
Stars: ✭ 8,085 (+8688.04%)
Mutual labels:  pagination
Filterable
Filtering from incoming params in Elixir/Ecto/Phoenix with easy to use DSL.
Stars: ✭ 83 (-9.78%)
Mutual labels:  pagination
Cursor Pagination
Cursor pagination for your Laravel API
Stars: ✭ 47 (-48.91%)
Mutual labels:  pagination
Sequelize Paginate
Sequelize model plugin for add paginate method
Stars: ✭ 70 (-23.91%)
Mutual labels:  pagination
React Paginating
Simple, lightweight, flexible pagination ReactJS component ⏮⏪1️⃣2️⃣3️⃣⏩⏭
Stars: ✭ 89 (-3.26%)
Mutual labels:  pagination
Pagination
Pagination for javascript and nodejs
Stars: ✭ 84 (-8.7%)
Mutual labels:  pagination
Lightquery
Lightweight solution for sorting and paging Asp.Net Core API results
Stars: ✭ 75 (-18.48%)
Mutual labels:  pagination
zebrajs

Zebra_Pagination

A generic, Twitter Bootstrap compatible, pagination library that automatically generates navigation links

Latest Stable Version Total Downloads Monthly Downloads Daily Downloads License

A generic, Twitter Bootstrap compatible (both versions 3 and 4), pagination script that automatically generates navigation links as well as next/previous page links, given the total number of records and the number of records to be shown per page. Useful for breaking large sets of data into smaller chunks, reducing network traffic and, at the same time, improving readability, aesthetics and usability.

Adheres to pagination best practices (provides large clickable areas, doesn't use underlines, the selected page is clearly highlighted, page links are spaced out, provides "previous page" and "next page" links, provides "first page" and "last page" links - as outlined in an article by Faruk Ates from 2007, which can now be found here, can generate links both in natural as well as in reverse order, can be easily, localized, supports different positions for next/previous page buttons, supports page propagation via GET or via URL rewriting, is SEO-friendly, and the appearance is easily customizable through CSS.

Please note that this is a generic pagination script, meaning that it does not display any records and it does not have any dependencies on database connections or SQL queries, making it very flexible! It is up to the developer to fetch the actual data and display it based on the information returned by this pagination script. The advantage is that it can be used to paginate over records coming from any source like arrays or databases.

The code is heavily commented and generates no warnings/errors/notices when PHP's error reporting level is set to E_ALL.

📚 Check out the awesome documentation!

Support the development of this library

Donate

Features

  • it is a generic library: can be used to paginate records both from an array or from a database
  • it automatically generates navigation links, given the total number of items and the number of items per page (examples of best practices are also included)
  • navigation links can be generated in natural or in reverse order
  • it is SEO-friendly – it uses rel="next" and rel="prev" and solves the problem of duplicate content on the first page without navigation and the first page having the page number in the URL
  • appearance is easily customizable through CSS
  • compatible with Twitter Bootstrap 3 and 4
  • code is heavily commented and generates no warnings/errors/notices when PHP’s error reporting level is set to E_ALL
  • has awesome documentation

Requirements

PHP 5+

Installation

You can install Zebra_Pagination via Composer

# get the latest stable release
composer require stefangabos/zebra_pagination

# get the latest commit
composer require stefangabos/zebra_pagination:dev-master

Or you can install it manually by downloading the latest version, unpacking it, and then including it in your project

require_once 'path/to/Zebra_Pagination.php';

How to use

Make sure that in the

of your page you have
<!-- you don't need this if you're using Twitter Bootstrap -->
<link rel="stylesheet" href="path/to/zebra_pagination.css" type="text/css">

If you want to preserve hashes in the URL, also include the JavaScript file – simply including it will suffice; (jQuery needs to also be loaded before loading this file)

<script src="path/to/zebra_pagination.js"></script>

Paginate data from an array:

The PHP

<?php

// let's paginate data from an array...
$countries = array(
    // array of countries
);

// how many records should be displayed on a page?
$records_per_page = 10;

// include the pagination class
require 'path/to/Zebra_Pagination.php';

// instantiate the pagination object
$pagination = new Zebra_Pagination();

// the number of total records is the number of records in the array
$pagination->records(count($countries));

// records per page
$pagination->records_per_page($records_per_page);

// here's the magic: we need to display *only* the records for the current page
$countries = array_slice(
    $countries,
    (($pagination->get_page() - 1) * $records_per_page),
    $records_per_page
);

?>

<table>
    <thead>
    <tr>
        <th>Country</th>
    </tr>
    </thead>
    <tbody>
    <?php foreach ($countries as $index => $country): ?>
    <tr<?php echo $index % 2 ? ' class="even"' : ''; ?>>
        <td><?php echo $country; ?></td>
    </tr>
    <?php endforeach; ?>
    </tbody>
</table>

<?php

// render the pagination links
$pagination->render();

Would result is something like

Zebra_Pagination

You can set the navigation links' position to the left or to the right of the pagination links using the navigation_position() method:

$pagination->navigation_position('left');

Zebra_Pagination

$pagination->navigation_position('right');

Zebra_Pagination

Labels for "Previous" and "Next" links can be changed with the labels() method:

$pagination->labels('Previous', 'Next');

Zebra_Pagination

You can also have HTML markup as labels making it easy to include font icons like the ones from Font Awesome

$pagination->labels('<i class="fa fa-arrow-left"></i>', '<i class="fa fa-arrow-right"></i>');

Zebra_Pagination

Paginate data from MySQL:

<?php

// connect to a database
$connection = mysqli_connect($host, $username, $password, $database);

// how many records should be displayed on a page?
$records_per_page = 10;

// include the pagination class
require 'path/to/Zebra_Pagination.php';

// instantiate the pagination object
$pagination = new Zebra_Pagination();

// the MySQL statement to fetch the rows
$sql = '
    SELECT
        country
    FROM
        countries
    LIMIT
        ' . (($pagination->get_page() - 1) * $records_per_page) . ', ' . $records_per_page . '
';

// execute the MySQL query
// (you will use mysqli or PDO here, but you get the idea)
$result = mysqli_query($connection, $sql) or die(mysqli_error($connection));

// fetch the total number of records in the table
$rows = mysqli_fetch_assoc(mysqli_query($connection, 'SELECT COUNT(*) AS rows FROM countries'));

// pass the total number of records to the pagination class
$pagination->records($rows['rows']);

// records per page
$pagination->records_per_page($records_per_page);

?>

<table>
    <thead>
    <tr>
        <th>Country</th>
    </tr>
    </thead>
    <tbody>
    <?php $index = 0; while ($row = mysqli_fetch_assoc($result)): ?>
    <tr<?php echo $index++ % 2 ? ' class="even"' : ''; ?>>
        <td><?php echo $row['country']; ?></td>
    </tr>
    <?php endwhile; ?>
    </tbody>
</table>

<?php

// render the pagination links
$pagination->render();

Paginate data from MySQL in reverse order:

<?php

// connect to a database
$connection = mysqli_connect($host, $username, $password, $database);

// how many records should be displayed on a page?
$records_per_page = 10;

// include the pagination class
require 'path/to/Zebra_Pagination.php';

// instantiate the pagination object
$pagination = new Zebra_Pagination();

// show records in reverse order
$pagination->reverse(true);

// when showing records in reverse order, we need to know the total number
// of records from the beginning
$result = mysqli_query($connection, 'SELECT COUNT(*) AS rows FROM countries'))) or die (mysqli_error());

// pass the total number of records to the pagination class
$pagination->records(array_pop(mysqli_fetch_assoc($result)));

// records per page
$pagination->records_per_page($records_per_page);

// the MySQL statement to fetch the rows
// note the LIMIT - use it exactly like that!
// also note that we're ordering data descendingly - most important when we're
// showing records in reverse order!
$sql = '
    SELECT
        country
    FROM
        countries
    ORDER BY
        country DESC
    LIMIT
        ' . (($pagination->get_pages() - $pagination->get_page()) * $records_per_page) . ', ' . $records_per_page . '
';

// run the query
mysqli_query($connection. $sql) or die(mysqli_error($connection));

?>

<table>
    <thead>
    <tr>
        <th>Country</th>
    </tr>
    </thead>
    <tbody>
    <?php $index = 0; while ($row = mysqli_fetch_assoc($result)): ?>
    <tr<?php echo $index++ % 2 ? ' class="even"' : ''; ?>>
        <td><?php echo $row['country']; ?></td>
    </tr>
    <?php endwhile; ?>
    </tbody>
</table>

<?php

// render the pagination links
$pagination->render();

Would result in something like

Zebra_Pagination

📚 Check out the awesome documentation!

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].