ruvents/paginator

该软件包已被废弃,不再维护。没有建议的替代软件包。

Ruwork Paginator

0.1.2 2017-11-12 21:22 UTC

This package is not auto-updated.

Last update: 2020-08-22 05:58:36 UTC


README

描述

此库提供了一种方便的方法来分页任何数据结构。

一些定义

  • section 是一组页面,一起渲染。
  • Proximity 是当前页前后显示的页数。

例如,对于10页,接近度为2,当前页为5,分页器将包含3个部分,页码如下:[1], [3, 4, 5, 6, 7], [10]

当当前页靠近边缘时,部分会合并。

控制器代码示例

<?php

use Ruwork\Paginator\PaginatorBuilder;
use Ruwork\Paginator\Provider\IterableProvider;

$data = range(1, 100);

$paginator = PaginatorBuilder::create()
    // required
    ->setProvider(new IterableProvider($data))
    // defaults to 1
    // when out of range of estimated pages, PageOutOfRangeException is thrown
    ->setCurrent(2)
    // defaults to 2
    ->setProximity(1)
    // defaults to 10
    ->setPerPage(3)
    ->getPaginator();

// template logic

foreach ($paginator->getItems() as $item) {
    // render the item row
}

if (null !== $previous = $paginator->getPrevious()) {
    echo sprintf('<a href="?page=%d">Previous</a>', $previous->getNumber());
}

foreach ($paginator as $section) {
    foreach ($section as $page) {
        echo sprintf('<a href="?page=%1$d" class="%2$s">%1$d</a>', $page->getNumber(), $page->isCurrent() ? 'active' : '');
    }
}

if (null !== $next = $paginator->getNext()) {
    echo sprintf('<a href="?page=%d">Next</a>', $next->getNumber());
}

数据提供者

IterableProvider

可以与 array 或实现 \Traversable 的对象一起使用。

DoctrineOrmProvider

可用于分页 Doctrine 实体。内部使用原生的 Doctrine\ORM\Tools\Pagination\Paginator 辅助工具。

<?php

use Ruwork\Paginator\PaginatorBuilder;
use Ruwork\Paginator\Provider\DoctrineOrmProvider;
use Doctrine\ORM\EntityRepository;

/** @var EntityRepository $repository */

$qb = $repository->createQueryBuilder('entity')
    ->andWhere('entity.id = :id')
    ->setParameters([
        'id' => 1
    ]);

$paginator = PaginatorBuilder::create()
    ->setProvider(new DoctrineOrmProvider($qb))
    ->getPaginator();

自定义

通过实现 Ruwork\Paginator\Provider\ProviderInterface 创建自己的提供者。

模板

bootstrap_4.html.twig

{% set route = app.request.attributes.get('_route') %}
{% set route_params = app.request.attributes.get('_route_params', []) %}

{% embed 'twig/bootstrap_4.html.twig' with {paginator: paginator, show_previous_next: false} %}
    {% block href path(route, route_params|merge({page: page.first ? null : page.number})) %}

    {% block previous_label 'Предыдущая' %}

    {% block next_label 'Следующая' %}
{% endembed %}