Alphapager advanced
Total 16 items.
# | Last Name | First Name | Born | Died |
---|---|---|---|---|
1 | Nabokov | Vladimir | 1899/04/23 | 1977/07/02 |
2 | Naipaul | V.S. | 1932/08/17 | 2018/08/11 |
3 | Nash | John | 1928/06/13 | 2015/05/23 |
4 | Newman | Barnett | 1905/01/29 | 1970/07/04 |
5 | Newman | Paul | 1925/01/26 | 2008/09/26 |
6 | Newman | Randy | 1943/11/28 | — |
7 | Newman | Thomas | 1955/10/20 | — |
8 | Newton | Isaac | 1643/01/04 | 1727/03/31 |
9 | Nicholson | Jack | 1937/04/22 | — |
10 | Nico | — | 1939/10/16 | 1988/07/18 |
11 | Nimoy | Leonard | 1931/03/26 | 2015/02/27 |
12 | Niro | Robert de | 1943/08/17 | — |
13 | Noiret | Philippe | 1930/10/01 | 2006/11/23 |
14 | Nolan | Christopher | 1970/07/30 | — |
15 | Norton | Edward | 1969/08/18 | — |
16 | Nyman | Michael | 1943/03/23 | — |
Yii2 Alphapager lets you do alphabetic paging in the Yii framework 2.0. On this page it is shown with some special settings.
The relevant code involved is something like this:
<?php use sjaakp\alphapager\ActiveDataProvider; use sjaakp\alphapager\AlphaPager; $query = Person::find()->orderBy('last_name, first_name'); $dataProvider = new ActiveDataProvider([ 'query' => $query, 'alphaAttribute' => 'last_name', 'alphaDigits' => 'compact', // one button for digits '0' - '9' 'alphaPages' => [ 'P' => [ 'label' => 'pq', // label button 'P' with 'pq' 'pattern' => [ '[PpQq]' ], // regular expression: include words starting with 'Q' under 'P' ], 'Q' => false, // suppress page 'Q' 'Z' => [ 'label' => 'x-z', // label button 'Z' with 'x-z' 'pattern' => [ '[X-Zx-z]' ], // regular expression: include words starting with 'X' or 'Y' under 'Z' ], 'X' => false, // suppress page 'X' 'Y' => false, // suppress page 'Y' ], 'pagination' => false // switch off normal pagination ]); ?> <?= AlphaPager::widget([ 'dataProvider' => $dataProvider, 'preButtons' => [], // no 'all' button 'lowerCase' => true // buttons in lower case ]) ?> <?= GridView::widget([ 'dataProvider' => $dataProvider, 'columns' => [ ['class' => 'yii\grid\SerialColumn'], 'last_name:ntext', 'first_name:ntext', 'born:date', 'died:date', ], ]); ?>
A basic example is here.