mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
ENHANCEMENT: Add method to disable automatic limiting on PaginagedLists.
In some circumstances a custom generated list will already only contain the items for the current page. The automatic limiting will then limit the already limited list, breaking pagination. This allows you to disable automatic limiting so all items are shown regardless of the current page.
This commit is contained in:
parent
5eab25cdbc
commit
77d712202c
@ -13,6 +13,7 @@ class PaginatedList extends SS_ListDecorator {
|
|||||||
protected $pageLength = 10;
|
protected $pageLength = 10;
|
||||||
protected $pageStart;
|
protected $pageStart;
|
||||||
protected $totalItems;
|
protected $totalItems;
|
||||||
|
protected $limitItems = true;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs a new paginated list instance around a list.
|
* Constructs a new paginated list instance around a list.
|
||||||
@ -144,13 +145,39 @@ class PaginatedList extends SS_ListDecorator {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns whether or not the underlying list is limited to the current
|
||||||
|
* pagination range when iterating.
|
||||||
|
*
|
||||||
|
* By default the limit method will be called on the underlying list to
|
||||||
|
* extract the subset for the current page. In some situations, if the list
|
||||||
|
* is custom generated and already paginated you don't want to additionally
|
||||||
|
* limit the list. You can use {@link setLimitItems} to control this.
|
||||||
|
*
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function getLimitItems() {
|
||||||
|
return $this->limitItems;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param bool $limit
|
||||||
|
*/
|
||||||
|
public function setLimitItems($limit) {
|
||||||
|
$this->limitItems = (bool) $limit;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return IteratorIterator
|
* @return IteratorIterator
|
||||||
*/
|
*/
|
||||||
public function getIterator() {
|
public function getIterator() {
|
||||||
return new IteratorIterator(
|
if($this->limitItems) {
|
||||||
$this->list->limit($this->pageLength, $this->getPageStart())
|
return new IteratorIterator(
|
||||||
);
|
$this->list->limit($this->pageLength, $this->getPageStart())
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
return new IteratorIterator($this->list);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -6,7 +6,7 @@ care of fetching a sub-set of the total list and presenting it to the template.
|
|||||||
|
|
||||||
In order to create a paginated list, you can create a method on your controller
|
In order to create a paginated list, you can create a method on your controller
|
||||||
that first creates a `DataList` that will return all pages, and then wraps it
|
that first creates a `DataList` that will return all pages, and then wraps it
|
||||||
in a `[api:PaginatedSet]` object. The `PaginatedList` object is also passed the
|
in a `[api:PaginatedList]` object. The `PaginatedList` object is also passed the
|
||||||
HTTP request object so it can read the current page information from the
|
HTTP request object so it can read the current page information from the
|
||||||
"?start=" GET var.
|
"?start=" GET var.
|
||||||
|
|
||||||
@ -26,7 +26,7 @@ information.
|
|||||||
|
|
||||||
Now all that remains is to render this list into a template, along with pagination
|
Now all that remains is to render this list into a template, along with pagination
|
||||||
controls. There are two ways to generate pagination controls:
|
controls. There are two ways to generate pagination controls:
|
||||||
`[api:PaginatedSet->Pages()]` and `[api:PaginatedSet->PaginationSummary()]`. In
|
`[api:PaginatedList->Pages()]` and `[api:PaginatedList->PaginationSummary()]`. In
|
||||||
this example we will use `PaginationSummary()`.
|
this example we will use `PaginationSummary()`.
|
||||||
|
|
||||||
The first step is to simply list the objects in the template:
|
The first step is to simply list the objects in the template:
|
||||||
@ -64,3 +64,11 @@ controls below this so the user can switch between pages:
|
|||||||
|
|
||||||
If there is more than one page, this block will render a set of pagination
|
If there is more than one page, this block will render a set of pagination
|
||||||
controls in the form `[1] ... [3] [4] [[5]] [6] [7] ... [10]`.
|
controls in the form `[1] ... [3] [4] [[5]] [6] [7] ... [10]`.
|
||||||
|
|
||||||
|
## Paginating Custom Lists
|
||||||
|
|
||||||
|
In some situations where you are generating the list yourself, the underlying
|
||||||
|
list will already contain only the items that you wish to display on the current
|
||||||
|
page. In this situation the automatic limiting done by `[api:PaginatedList]`
|
||||||
|
will break the pagination. You can disable automatic limiting using the
|
||||||
|
`[api:PaginatedList->setLimitItems()]` method when using custom lists.
|
||||||
|
@ -135,6 +135,17 @@ class PaginatedListTest extends SapphireTest {
|
|||||||
$this->assertDOSEquals($expect, $list->PaginationSummary(4));
|
$this->assertDOSEquals($expect, $list->PaginationSummary(4));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testLimitItems() {
|
||||||
|
$list = new ArrayList(range(1, 50));
|
||||||
|
$list = new PaginatedList($list);
|
||||||
|
|
||||||
|
$list->setCurrentPage(3);
|
||||||
|
$this->assertEquals(10, count($list->getIterator()->getInnerIterator()));
|
||||||
|
|
||||||
|
$list->setLimitItems(false);
|
||||||
|
$this->assertEquals(50, count($list->getIterator()->getInnerIterator()));
|
||||||
|
}
|
||||||
|
|
||||||
public function testCurrentPage() {
|
public function testCurrentPage() {
|
||||||
$list = new PaginatedList(new ArrayList());
|
$list = new PaginatedList(new ArrayList());
|
||||||
$list->setTotalItems(50);
|
$list->setTotalItems(50);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user