mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
Merge pull request #7408 from ajoneil/fix-paginated-list-get-vars
Prior to this change, if there were already GET vars on a page with a PaginatedList, the links would include a mix of '&' and '&'.
This commit is contained in:
commit
060c2d62d3
@ -436,7 +436,12 @@ class PaginatedList extends ListDecorator
|
|||||||
*/
|
*/
|
||||||
public function FirstLink()
|
public function FirstLink()
|
||||||
{
|
{
|
||||||
return HTTP::setGetVar($this->getPaginationGetVar(), 0);
|
return HTTP::setGetVar(
|
||||||
|
$this->getPaginationGetVar(),
|
||||||
|
0,
|
||||||
|
$this->request ? $this->request->getURL(true) : null,
|
||||||
|
'&'
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -446,7 +451,12 @@ class PaginatedList extends ListDecorator
|
|||||||
*/
|
*/
|
||||||
public function LastLink()
|
public function LastLink()
|
||||||
{
|
{
|
||||||
return HTTP::setGetVar($this->getPaginationGetVar(), ($this->TotalPages() - 1) * $this->getPageLength());
|
return HTTP::setGetVar(
|
||||||
|
$this->getPaginationGetVar(),
|
||||||
|
($this->TotalPages() - 1) * $this->getPageLength(),
|
||||||
|
$this->request ? $this->request->getURL(true) : null,
|
||||||
|
'&'
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -458,7 +468,12 @@ class PaginatedList extends ListDecorator
|
|||||||
public function NextLink()
|
public function NextLink()
|
||||||
{
|
{
|
||||||
if ($this->NotLastPage()) {
|
if ($this->NotLastPage()) {
|
||||||
return HTTP::setGetVar($this->getPaginationGetVar(), $this->getPageStart() + $this->getPageLength());
|
return HTTP::setGetVar(
|
||||||
|
$this->getPaginationGetVar(),
|
||||||
|
$this->getPageStart() + $this->getPageLength(),
|
||||||
|
$this->request ? $this->request->getURL(true) : null,
|
||||||
|
'&'
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -471,7 +486,12 @@ class PaginatedList extends ListDecorator
|
|||||||
public function PrevLink()
|
public function PrevLink()
|
||||||
{
|
{
|
||||||
if ($this->NotFirstPage()) {
|
if ($this->NotFirstPage()) {
|
||||||
return HTTP::setGetVar($this->getPaginationGetVar(), $this->getPageStart() - $this->getPageLength());
|
return HTTP::setGetVar(
|
||||||
|
$this->getPaginationGetVar(),
|
||||||
|
$this->getPageStart() - $this->getPageLength(),
|
||||||
|
$this->request ? $this->request->getURL(true) : null,
|
||||||
|
'&'
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,6 +9,7 @@ use SilverStripe\Dev\SapphireTest;
|
|||||||
use SilverStripe\ORM\Queries\SQLSelect;
|
use SilverStripe\ORM\Queries\SQLSelect;
|
||||||
use SilverStripe\ORM\Tests\DataObjectTest\Player;
|
use SilverStripe\ORM\Tests\DataObjectTest\Player;
|
||||||
use SilverStripe\View\ArrayData;
|
use SilverStripe\View\ArrayData;
|
||||||
|
use SilverStripe\Control\HTTPRequest;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests for the {@link SilverStripe\ORM\PaginatedList} class.
|
* Tests for the {@link SilverStripe\ORM\PaginatedList} class.
|
||||||
@ -92,15 +93,13 @@ class PaginatedListTest extends SapphireTest
|
|||||||
public function testGetIterator()
|
public function testGetIterator()
|
||||||
{
|
{
|
||||||
$list = new PaginatedList(
|
$list = new PaginatedList(
|
||||||
new ArrayList(
|
new ArrayList([
|
||||||
array(
|
|
||||||
new DataObject(array('Num' => 1)),
|
new DataObject(array('Num' => 1)),
|
||||||
new DataObject(array('Num' => 2)),
|
new DataObject(array('Num' => 2)),
|
||||||
new DataObject(array('Num' => 3)),
|
new DataObject(array('Num' => 3)),
|
||||||
new DataObject(array('Num' => 4)),
|
new DataObject(array('Num' => 4)),
|
||||||
new DataObject(array('Num' => 5)),
|
new DataObject(array('Num' => 5)),
|
||||||
)
|
])
|
||||||
)
|
|
||||||
);
|
);
|
||||||
$list->setPageLength(2);
|
$list->setPageLength(2);
|
||||||
|
|
||||||
@ -128,13 +127,13 @@ class PaginatedListTest extends SapphireTest
|
|||||||
$list->setPageLength(0);
|
$list->setPageLength(0);
|
||||||
$list->setCurrentPage(1);
|
$list->setCurrentPage(1);
|
||||||
$this->assertDOSEquals(
|
$this->assertDOSEquals(
|
||||||
array(
|
[
|
||||||
array('Num' => 1),
|
array('Num' => 1),
|
||||||
array('Num' => 2),
|
array('Num' => 2),
|
||||||
array('Num' => 3),
|
array('Num' => 3),
|
||||||
array('Num' => 4),
|
array('Num' => 4),
|
||||||
array('Num' => 5)
|
array('Num' => 5),
|
||||||
),
|
],
|
||||||
$list->getIterator()
|
$list->getIterator()
|
||||||
);
|
);
|
||||||
|
|
||||||
@ -156,9 +155,9 @@ class PaginatedListTest extends SapphireTest
|
|||||||
$list->setPageLength(10);
|
$list->setPageLength(10);
|
||||||
$list->setTotalItems(50);
|
$list->setTotalItems(50);
|
||||||
|
|
||||||
$this->assertEquals(5, count($list->Pages()));
|
$this->assertCount(5, $list->Pages());
|
||||||
$this->assertEquals(3, count($list->Pages(3)));
|
$this->assertCount(3, $list->Pages(3));
|
||||||
$this->assertEquals(5, count($list->Pages(15)));
|
$this->assertCount(5, $list->Pages(15));
|
||||||
|
|
||||||
$list->setCurrentPage(3);
|
$list->setCurrentPage(3);
|
||||||
|
|
||||||
@ -221,10 +220,10 @@ class PaginatedListTest extends SapphireTest
|
|||||||
$list = new PaginatedList($list);
|
$list = new PaginatedList($list);
|
||||||
|
|
||||||
$list->setCurrentPage(3);
|
$list->setCurrentPage(3);
|
||||||
$this->assertEquals(10, count($list->getIterator()->getInnerIterator()));
|
$this->assertCount(10, $list->getIterator()->getInnerIterator());
|
||||||
|
|
||||||
$list->setLimitItems(false);
|
$list->setLimitItems(false);
|
||||||
$this->assertEquals(50, count($list->getIterator()->getInnerIterator()));
|
$this->assertCount(50, $list->getIterator()->getInnerIterator());
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testCurrentPage()
|
public function testCurrentPage()
|
||||||
@ -330,6 +329,27 @@ class PaginatedListTest extends SapphireTest
|
|||||||
$this->assertContains('start=0', $list->FirstLink());
|
$this->assertContains('start=0', $list->FirstLink());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testFirstLinkContainsCurrentGetParameters()
|
||||||
|
{
|
||||||
|
$request = new HTTPRequest(
|
||||||
|
'GET',
|
||||||
|
'http://example.com/my-cool-page',
|
||||||
|
['awesomeness' => 'nextLevel', 'start' => 20]
|
||||||
|
);
|
||||||
|
$list = new PaginatedList(new ArrayList(), $request);
|
||||||
|
$list->setTotalItems(50);
|
||||||
|
$list->setPageLength(10);
|
||||||
|
|
||||||
|
// check the query string has correct parameters
|
||||||
|
$queryString = parse_url($list->FirstLink(), PHP_URL_QUERY);
|
||||||
|
parse_str($queryString, $queryParams);
|
||||||
|
|
||||||
|
$this->assertArrayHasKey('awesomeness', $queryParams);
|
||||||
|
$this->assertequals('nextLevel', $queryParams['awesomeness']);
|
||||||
|
$this->assertArrayHasKey('start', $queryParams);
|
||||||
|
$this->assertequals(0, $queryParams['start']);
|
||||||
|
}
|
||||||
|
|
||||||
public function testLastLink()
|
public function testLastLink()
|
||||||
{
|
{
|
||||||
$list = new PaginatedList(new ArrayList());
|
$list = new PaginatedList(new ArrayList());
|
||||||
@ -342,6 +362,27 @@ class PaginatedListTest extends SapphireTest
|
|||||||
$this->assertContains('start=0', $list->LastLink());
|
$this->assertContains('start=0', $list->LastLink());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testLastLinkContainsCurrentGetParameters()
|
||||||
|
{
|
||||||
|
$request = new HTTPRequest(
|
||||||
|
'GET',
|
||||||
|
'http://example.com/my-cool-page',
|
||||||
|
['awesomeness' => 'nextLevel']
|
||||||
|
);
|
||||||
|
$list = new PaginatedList(new ArrayList(), $request);
|
||||||
|
$list->setTotalItems(50);
|
||||||
|
$list->setPageLength(10);
|
||||||
|
|
||||||
|
// check the query string has correct parameters
|
||||||
|
$queryString = parse_url($list->LastLink(), PHP_URL_QUERY);
|
||||||
|
parse_str($queryString, $queryParams);
|
||||||
|
|
||||||
|
$this->assertArrayHasKey('awesomeness', $queryParams);
|
||||||
|
$this->assertequals('nextLevel', $queryParams['awesomeness']);
|
||||||
|
$this->assertArrayHasKey('start', $queryParams);
|
||||||
|
$this->assertequals(40, $queryParams['start']);
|
||||||
|
}
|
||||||
|
|
||||||
public function testNextLink()
|
public function testNextLink()
|
||||||
{
|
{
|
||||||
$list = new PaginatedList(new ArrayList());
|
$list = new PaginatedList(new ArrayList());
|
||||||
@ -363,6 +404,27 @@ class PaginatedListTest extends SapphireTest
|
|||||||
$this->assertNull($list->NextLink());
|
$this->assertNull($list->NextLink());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testNextLinkContainsCurrentGetParameters()
|
||||||
|
{
|
||||||
|
$request = new HTTPRequest(
|
||||||
|
'GET',
|
||||||
|
'http://example.com/my-cool-page',
|
||||||
|
['awesomeness' => 'nextLevel']
|
||||||
|
);
|
||||||
|
$list = new PaginatedList(new ArrayList(), $request);
|
||||||
|
$list->setTotalItems(50);
|
||||||
|
$list->setPageLength(10);
|
||||||
|
|
||||||
|
// check the query string has correct parameters
|
||||||
|
$queryString = parse_url($list->NextLink(), PHP_URL_QUERY);
|
||||||
|
parse_str($queryString, $queryParams);
|
||||||
|
|
||||||
|
$this->assertArrayHasKey('awesomeness', $queryParams);
|
||||||
|
$this->assertequals('nextLevel', $queryParams['awesomeness']);
|
||||||
|
$this->assertArrayHasKey('start', $queryParams);
|
||||||
|
$this->assertequals(10, $queryParams['start']);
|
||||||
|
}
|
||||||
|
|
||||||
public function testPrevLink()
|
public function testPrevLink()
|
||||||
{
|
{
|
||||||
$list = new PaginatedList(new ArrayList());
|
$list = new PaginatedList(new ArrayList());
|
||||||
@ -380,4 +442,25 @@ class PaginatedListTest extends SapphireTest
|
|||||||
$list->setPageLength(0);
|
$list->setPageLength(0);
|
||||||
$this->assertNull($list->PrevLink());
|
$this->assertNull($list->PrevLink());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testPrevLinkContainsCurrentGetParameters()
|
||||||
|
{
|
||||||
|
$request = new HTTPRequest(
|
||||||
|
'GET',
|
||||||
|
'http://example.com/my-cool-page',
|
||||||
|
['awesomeness' => 'nextLevel', 'start' => '30']
|
||||||
|
);
|
||||||
|
$list = new PaginatedList(new ArrayList(), $request);
|
||||||
|
$list->setTotalItems(50);
|
||||||
|
$list->setPageLength(10);
|
||||||
|
|
||||||
|
// check the query string has correct parameters
|
||||||
|
$queryString = parse_url($list->PrevLink(), PHP_URL_QUERY);
|
||||||
|
parse_str($queryString, $queryParams);
|
||||||
|
|
||||||
|
$this->assertArrayHasKey('awesomeness', $queryParams);
|
||||||
|
$this->assertequals('nextLevel', $queryParams['awesomeness']);
|
||||||
|
$this->assertArrayHasKey('start', $queryParams);
|
||||||
|
$this->assertequals(20, $queryParams['start']);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user