Merge pull request #776 from simonwelsh/maniplist

FIX Use the manipulated datalist for counting total items
This commit is contained in:
Ingo Schommer 2012-09-06 12:55:05 -07:00
commit 99ae715f8a
3 changed files with 41 additions and 7 deletions

View File

@ -193,6 +193,21 @@ class GridField extends FormField {
return $this->list; return $this->list;
} }
/**
* Get the datasource after applying the {@link GridField_DataManipulator}s to it.
*
* @return SS_List
*/
public function getManipulatedList() {
$list = $this->getList();
foreach($this->getComponents() as $item) {
if($item instanceof GridField_DataManipulator) {
$list = $item->getManipulatedData($this, $list);
}
}
return $list;
}
/** /**
* Get the current GridState_Data or the GridState * Get the current GridState_Data or the GridState
* *
@ -227,12 +242,7 @@ class GridField extends FormField {
$columns = $this->getColumns(); $columns = $this->getColumns();
// Get data // Get data
$list = $this->getList(); $list = $this->getManipulatedList();
foreach($this->getComponents() as $item) {
if($item instanceof GridField_DataManipulator) {
$list = $item->getManipulatedData($this, $list);
}
}
// Render headers, footers, etc // Render headers, footers, etc
$content = array( $content = array(

View File

@ -108,7 +108,7 @@ class GridFieldPaginator implements GridField_HTMLProvider, GridField_DataManipu
public function getManipulatedData(GridField $gridField, SS_List $dataList) { public function getManipulatedData(GridField $gridField, SS_List $dataList) {
if(!$this->checkDataType($dataList)) return $dataList; if(!$this->checkDataType($dataList)) return $dataList;
$this->totalItems = $gridField->getList()->count(); $this->totalItems = $dataList->count();
$state = $gridField->State->GridFieldPaginator; $state = $gridField->State->GridFieldPaginator;
if(!is_int($state->currentPage)) { if(!is_int($state->currentPage)) {

View File

@ -392,6 +392,22 @@ class GridFieldTest extends SapphireTest {
$this->assertEquals((string)$members[1]->td[0], 'Otto Fischer', 'Second object Name should be Otto Fischer'); $this->assertEquals((string)$members[1]->td[0], 'Otto Fischer', 'Second object Name should be Otto Fischer');
$this->assertEquals((string)$members[1]->td[1], 'otto.fischer@example.org', 'Second object Email should be otto.fischer@example.org'); $this->assertEquals((string)$members[1]->td[1], 'otto.fischer@example.org', 'Second object Email should be otto.fischer@example.org');
} }
public function testChainedDataManipulators() {
$config = new GridFieldConfig();
$data = new ArrayList(array(1, 2, 3, 4, 5, 6));
$gridField = new GridField('testfield', 'testfield', $data, $config);
$endList = $gridField->getManipulatedList();
$this->assertEquals($endList->Count(), 6);
$config->addComponent(new GridFieldTest_Component2);
$endList = $gridField->getManipulatedList();
$this->assertEquals($endList->Count(), 12);
$config->addComponent(new GridFieldPaginator(10));
$endList = $gridField->getManipulatedList();
$this->assertEquals($endList->Count(), 10);
}
} }
class GridFieldTest_Component implements GridField_ColumnProvider, GridField_ActionProvider, TestOnly{ class GridFieldTest_Component implements GridField_ColumnProvider, GridField_ActionProvider, TestOnly{
@ -430,6 +446,14 @@ class GridFieldTest_Component implements GridField_ColumnProvider, GridField_Act
} }
class GridFieldTest_Component2 implements GridField_DataManipulator, TestOnly {
function getManipulatedData(GridField $gridField, SS_List $dataList) {
$dataList = clone $dataList;
$dataList->merge(new ArrayList(array(7, 8, 9, 10, 11, 12)));
return $dataList;
}
}
class GridFieldTest_Team extends DataObject implements TestOnly { class GridFieldTest_Team extends DataObject implements TestOnly {
static $db = array( static $db = array(
'Name' => 'Varchar', 'Name' => 'Varchar',