mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
NEW Allow setting of unlimited row counts on GridFieldPaginator
This commit is contained in:
parent
3859a1d7e7
commit
776d2fbc66
@ -179,15 +179,23 @@ class GridFieldPaginator implements GridField_HTMLProvider, GridField_DataManipu
|
|||||||
$totalRows = $this->totalItems;
|
$totalRows = $this->totalItems;
|
||||||
if(!$totalRows) return null;
|
if(!$totalRows) return null;
|
||||||
|
|
||||||
$totalPages = (int)ceil($totalRows/$this->itemsPerPage);
|
$totalPages = 1;
|
||||||
if($totalPages == 0)
|
$firstShownRecord = 1;
|
||||||
$totalPages = 1;
|
$lastShownRecord = $totalRows;
|
||||||
$firstShownRecord = ($state->currentPage - 1) * $this->itemsPerPage + 1;
|
if ($itemsPerPage = $this->getItemsPerPage()) {
|
||||||
if($firstShownRecord > $totalRows)
|
$totalPages = (int)ceil($totalRows / $itemsPerPage);
|
||||||
$firstShownRecord = $totalRows;
|
if ($totalPages == 0) {
|
||||||
$lastShownRecord = $state->currentPage * $this->itemsPerPage;
|
$totalPages = 1;
|
||||||
if($lastShownRecord > $totalRows)
|
}
|
||||||
$lastShownRecord = $totalRows;
|
$firstShownRecord = ($state->currentPage - 1) * $itemsPerPage + 1;
|
||||||
|
if ($firstShownRecord > $totalRows) {
|
||||||
|
$firstShownRecord = $totalRows;
|
||||||
|
}
|
||||||
|
$lastShownRecord = $state->currentPage * $itemsPerPage;
|
||||||
|
if ($lastShownRecord > $totalRows) {
|
||||||
|
$lastShownRecord = $totalRows;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// If there is only 1 page for all the records in list, we don't need to go further
|
// If there is only 1 page for all the records in list, we don't need to go further
|
||||||
// to sort out those first page, last page, pre and next pages, etc
|
// to sort out those first page, last page, pre and next pages, etc
|
||||||
|
@ -52,6 +52,26 @@ class GridFieldPaginatorTest extends FunctionalTest {
|
|||||||
$this->assertEquals(2, count($content->getBySelector('.pagination-records-number')));
|
$this->assertEquals(2, count($content->getBySelector('.pagination-records-number')));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testUnlimitedRowCount() {
|
||||||
|
$total = $this->list->count();
|
||||||
|
// set up the paginator
|
||||||
|
/** @var GridFieldPaginator $paginator */
|
||||||
|
$paginator = $this->gridField->getConfig()->getComponentByType("GridFieldPaginator");
|
||||||
|
$paginator->setThrowExceptionOnBadDataType(true);
|
||||||
|
$paginator->setItemsPerPage(1);
|
||||||
|
$paginator->getManipulatedData($this->gridField, $this->list);
|
||||||
|
|
||||||
|
|
||||||
|
$params = $paginator->getTemplateParameters($this->gridField)->toMap();
|
||||||
|
$this->assertFalse($params['OnlyOnePage']);
|
||||||
|
$this->assertEquals($total, $params['NumRecords']);
|
||||||
|
|
||||||
|
$paginator->setItemsPerPage(0);
|
||||||
|
$params = $paginator->getTemplateParameters($this->gridField)->toMap();
|
||||||
|
$this->assertTrue($params['OnlyOnePage']);
|
||||||
|
$this->assertEquals($total, $params['NumRecords']);
|
||||||
|
}
|
||||||
|
|
||||||
public function testPaginationAvoidsIllegalOffsets() {
|
public function testPaginationAvoidsIllegalOffsets() {
|
||||||
$grid = $this->gridField;
|
$grid = $this->gridField;
|
||||||
$total = $this->list->count();
|
$total = $this->list->count();
|
||||||
|
Loading…
Reference in New Issue
Block a user