'wid'], ['data' => 'type'], ['data' => 'timestamp'], ]; $query = db_select('watchdog', 'd')->extend('Drupal\Core\Database\Query\PagerSelectExtender')->element($element); $result = $query ->fields('d', ['wid', 'type', 'timestamp']) ->limit($limit) ->orderBy('d.wid') ->execute(); $rows = []; foreach ($result as $row) { $rows[] = ['data' => (array) $row]; } return [ '#theme' => 'table', '#header' => $header, '#rows' => $rows, '#empty' => $this->t("There are no watchdog records found in the db"), ]; } /** * Returns a pager with 'parameters' variable. * * The 'pager_calls' parameter counts the calls to the pager, subsequent * to the initial call. */ public function queryParameters() { // Example query. $build['pager_table_0'] = $this->buildTestTable(0, 5); // Counter of calls to the current pager. $query_params = pager_get_query_parameters(); $pager_calls = isset($query_params['pager_calls']) ? ($query_params['pager_calls'] ? $query_params['pager_calls'] : 0) : 0; $build['l_pager_pager_0'] = ['#markup' => $this->t('Pager calls: @pager_calls', ['@pager_calls' => $pager_calls])]; // Pager. $build['pager_pager_0'] = [ '#type' => 'pager', '#element' => 0, '#parameters' => [ 'pager_calls' => ++$pager_calls, ], '#pre_render' => [ 'Drupal\pager_test\Controller\PagerTestController::showPagerCacheContext', ] ]; return $build; } /** * Returns a page with multiple pagers. */ public function multiplePagers() { // Build three tables with same query and different pagers. $build['pager_table_0'] = $this->buildTestTable(0, 20); $build['pager_pager_0'] = [ '#type' => 'container', '#attributes' => ['class' => ['test-pager-0']], 'pager' => [ '#type' => 'pager', '#element' => 0, ], ]; $build['pager_table_1'] = $this->buildTestTable(1, 20); $build['pager_pager_1'] = [ '#type' => 'container', '#attributes' => ['class' => ['test-pager-1']], 'pager' => [ '#type' => 'pager', '#element' => 1, ], ]; $build['pager_table_4'] = $this->buildTestTable(4, 20); $build['pager_pager_4'] = [ '#type' => 'container', '#attributes' => ['class' => ['test-pager-4']], 'pager' => [ '#type' => 'pager', '#element' => 4, ], ]; return $build; } /** * #pre_render callback for #type => pager that shows the pager cache context. */ public static function showPagerCacheContext(array $pager) { drupal_set_message(\Drupal::service('cache_contexts_manager')->convertTokensToKeys(['url.query_args.pagers:' . $pager['#element']])->getKeys()[0]); return $pager; } }