Pager.php

Same filename in this branch
  1. 9 core/lib/Drupal/Core/Pager/Pager.php
Same filename and directory in other branches
  1. 8.9.x core/lib/Drupal/Core/Render/Element/Pager.php
  2. 8.9.x core/lib/Drupal/Core/Pager/Pager.php
  3. 10 core/lib/Drupal/Core/Render/Element/Pager.php
  4. 10 core/lib/Drupal/Core/Pager/Pager.php
  5. 11.x core/lib/Drupal/Core/Render/Element/Pager.php
  6. 11.x core/lib/Drupal/Core/Pager/Pager.php

Namespace

Drupal\Core\Render\Element

File

core/lib/Drupal/Core/Render/Element/Pager.php

View source
<?php

namespace Drupal\Core\Render\Element;


/**
 * Provides a render element for a pager.
 *
 * The pager must be initialized with a call to
 * \Drupal\Core\Pager\PagerManagerInterface::createPager() in order to render
 * properly. When used with database queries, this is performed for you when you
 * extend a select query with \Drupal\Core\Database\Query\PagerSelectExtender.
 *
 * Properties:
 * - #element: (optional, int) The pager ID, to distinguish between multiple
 *   pagers on the same page (defaults to 0).
 * - #parameters: (optional) An associative array of query string parameters to
 *   append to the pager.
 * - #quantity: The maximum number of numbered page links to create (defaults
 *   to 9).
 * - #tags: (optional) An array of labels for the controls in the pages.
 * - #route_name: (optional) The name of the route to be used to build pager
 *   links. Defaults to '<none>', which will make links relative to the current
 *   URL. This makes the page more effectively cacheable.
 *
 * @code
 * $build['pager'] = [
 *   '#type' => 'pager',
 * ];
 * @endcode
 *
 * @RenderElement("pager")
 */
class Pager extends RenderElement {
    
    /**
     * {@inheritdoc}
     */
    public function getInfo() {
        return [
            '#pre_render' => [
                static::class . '::preRenderPager',
            ],
            '#theme' => 'pager',
            // The pager ID, to distinguish between multiple pagers on the same page.
'#element' => 0,
            // An associative array of query string parameters to append to the pager
            // links.
'#parameters' => [],
            // The number of pages in the list.
'#quantity' => 9,
            // An array of labels for the controls in the pager.
'#tags' => [],
            // The name of the route to be used to build pager links. By default no
            // path is provided, which will make links relative to the current URL.
            // This makes the page more effectively cacheable.
'#route_name' => '<none>',
        ];
    }
    
    /**
     * #pre_render callback to associate the appropriate cache context.
     *
     *
     * @param array $pager
     *   A renderable array of #type => pager.
     *
     * @return array
     */
    public static function preRenderPager(array $pager) {
        // Note: the default pager theme process function
        // template_preprocess_pager() also calls
        // \Drupal\Core\Pager\PagerManagerInterface::getUpdatedParameters(), which
        // maintains the existing query string. Therefore
        // template_preprocess_pager() adds the 'url.query_args' cache context,
        // which causes the more specific cache context below to be optimized away.
        // In other themes, however, that may not be the case.
        $pager['#cache']['contexts'][] = 'url.query_args.pagers:' . $pager['#element'];
        return $pager;
    }

}

Classes

Title Deprecated Summary
Pager Provides a render element for a pager.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.