setForm($form); $compontent = $gridField->getConfig()->getComponentByType('GridFieldSortableHeader'); $htmlFragment = $compontent->getHTMLFragments($gridField); // Check that the output shows name and hat as sortable fields, but not city $this->assertContains('City', $htmlFragment['header']); $this->assertContains('value="Name" class="action grid-field__sort" id="action_SetOrderName"', $htmlFragment['header']); $this->assertContains( 'value="Cheerleader Hat" class="action grid-field__sort" id="action_SetOrderCheerleader-Hat-Colour"', $htmlFragment['header']); // Check inverse of above $this->assertNotContains('value="City" class="action grid-field__sort" id="action_SetOrderCity"', $htmlFragment['header']); $this->assertNotContains('Name', $htmlFragment['header']); $this->assertNotContains('Cheerleader Hat', $htmlFragment['header']); } public function testGetManipulatedData() { $list = new DataList('GridFieldSortableHeaderTest_Team'); $config = new GridFieldConfig_RecordEditor(); $gridField = new GridField('testfield', 'testfield', $list, $config); // Test normal sorting $state = $gridField->State->GridFieldSortableHeader; $state->SortColumn = 'City'; $state->SortDirection = 'asc'; $compontent = $gridField->getConfig()->getComponentByType('GridFieldSortableHeader'); $listA = $compontent->getManipulatedData($gridField, $list); $state->SortDirection = 'desc'; $listB = $compontent->getManipulatedData($gridField, $list); $this->assertEquals( array('Auckland', 'Cologne', 'Melbourne', 'Wellington'), $listA->column('City') ); $this->assertEquals( array('Wellington', 'Melbourne', 'Cologne', 'Auckland'), $listB->column('City') ); // Test one relation 'deep' $state->SortColumn = 'Cheerleader.Name'; $state->SortDirection = 'asc'; $relationListA = $compontent->getManipulatedData($gridField, $list); $state->SortDirection = 'desc'; $relationListB = $compontent->getManipulatedData($gridField, $list); $this->assertEquals( array('Wellington', 'Melbourne', 'Cologne', 'Auckland'), $relationListA->column('City') ); $this->assertEquals( array('Auckland', 'Cologne', 'Melbourne', 'Wellington'), $relationListB->column('City') ); // Test two relations 'deep' $state->SortColumn = 'Cheerleader.Hat.Colour'; $state->SortDirection = 'asc'; $relationListC = $compontent->getManipulatedData($gridField, $list); $state->SortDirection = 'desc'; $relationListD = $compontent->getManipulatedData($gridField, $list); $this->assertEquals( array('Cologne', 'Auckland', 'Wellington', 'Melbourne'), $relationListC->column('City') ); $this->assertEquals( array('Melbourne', 'Wellington', 'Auckland', 'Cologne'), $relationListD->column('City') ); } /** * Test getManipulatedData on subclassed dataobjects */ public function testInheritedGetManiplatedData() { $list = GridFieldSortableHeaderTest_TeamGroup::get(); $config = new GridFieldConfig_RecordEditor(); $gridField = new GridField('testfield', 'testfield', $list, $config); $state = $gridField->State->GridFieldSortableHeader; $compontent = $gridField->getConfig()->getComponentByType('GridFieldSortableHeader'); // Test that inherited dataobjects will work correctly $state->SortColumn = 'Cheerleader.Hat.Colour'; $state->SortDirection = 'asc'; $relationListA = $compontent->getManipulatedData($gridField, $list); $relationListAsql = Convert::nl2os($relationListA->sql(), ' '); // Assert that all tables are joined properly $this->assertContains('FROM "GridFieldSortableHeaderTest_Team"', $relationListAsql); $this->assertContains( 'LEFT JOIN "GridFieldSortableHeaderTest_TeamGroup" ' . 'ON "GridFieldSortableHeaderTest_TeamGroup"."ID" = "GridFieldSortableHeaderTest_Team"."ID"', $relationListAsql ); $this->assertContains( 'LEFT JOIN "GridFieldSortableHeaderTest_Cheerleader" ' . 'ON "GridFieldSortableHeaderTest_Cheerleader"."ID" = "GridFieldSortableHeaderTest_Team"."CheerleaderID"', $relationListAsql ); $this->assertContains( 'LEFT JOIN "GridFieldSortableHeaderTest_CheerleaderHat" ' . 'ON "GridFieldSortableHeaderTest_CheerleaderHat"."ID" = "GridFieldSortableHeaderTest_Cheerleader"."HatID"', $relationListAsql); // Test sorting is correct $this->assertEquals( array('Cologne', 'Auckland', 'Wellington', 'Melbourne'), $relationListA->column('City') ); $state->SortDirection = 'desc'; $relationListAdesc = $compontent->getManipulatedData($gridField, $list); $this->assertEquals( array('Melbourne', 'Wellington', 'Auckland', 'Cologne'), $relationListAdesc->column('City') ); // Test subclasses of tables $state->SortColumn = 'CheerleadersMom.Hat.Colour'; $state->SortDirection = 'asc'; $relationListB = $compontent->getManipulatedData($gridField, $list); $relationListBsql = $relationListB->sql(); // Assert that subclasses are included in the query $this->assertContains('FROM "GridFieldSortableHeaderTest_Team"', $relationListBsql); $this->assertContains( 'LEFT JOIN "GridFieldSortableHeaderTest_TeamGroup" ' . 'ON "GridFieldSortableHeaderTest_TeamGroup"."ID" = "GridFieldSortableHeaderTest_Team"."ID"', $relationListBsql ); // Joined tables are joined basetable first $this->assertContains( 'LEFT JOIN "GridFieldSortableHeaderTest_Cheerleader" ' . 'ON "GridFieldSortableHeaderTest_Cheerleader"."ID" = "GridFieldSortableHeaderTest_Team"."CheerleadersMomID"', $relationListBsql ); // Then the basetable of the joined record is joined to the specific subtable $this->assertContains( 'LEFT JOIN "GridFieldSortableHeaderTest_Mom" ' . 'ON "GridFieldSortableHeaderTest_Cheerleader"."ID" = "GridFieldSortableHeaderTest_Mom"."ID"', $relationListBsql ); $this->assertContains( 'LEFT JOIN "GridFieldSortableHeaderTest_CheerleaderHat" ' . 'ON "GridFieldSortableHeaderTest_CheerleaderHat"."ID" = "GridFieldSortableHeaderTest_Cheerleader"."HatID"', $relationListBsql ); // Test sorting is correct $this->assertEquals( array('Cologne', 'Auckland', 'Wellington', 'Melbourne'), $relationListB->column('City') ); $state->SortDirection = 'desc'; $relationListBdesc = $compontent->getManipulatedData($gridField, $list); $this->assertEquals( array('Melbourne', 'Wellington', 'Auckland', 'Cologne'), $relationListBdesc->column('City') ); } } class GridFieldSortableHeaderTest_Team extends DataObject implements TestOnly { private static $summary_fields = array( 'Name' => 'Name', 'City.Initial' => 'City', 'Cheerleader.Hat.Colour' => 'Cheerleader Hat' ); private static $db = array( 'Name' => 'Varchar', 'City' => 'Varchar' ); private static $has_one = array( 'Cheerleader' => 'GridFieldSortableHeaderTest_Cheerleader', 'CheerleadersMom' => 'GridFieldSortableHeaderTest_Mom' ); } class GridFieldSortableHeaderTest_TeamGroup extends GridFieldSortableHeaderTest_Team implements TestOnly { private static $db = array( 'GroupName' => 'Varchar' ); } class GridFieldSortableHeaderTest_Cheerleader extends DataObject implements TestOnly { private static $db = array( 'Name' => 'Varchar' ); private static $has_one = array( 'Team' => 'GridFieldSortableHeaderTest_Team', 'Hat' => 'GridFieldSortableHeaderTest_CheerleaderHat' ); } /** * Should have access to same properties as cheerleader */ class GridFieldSortableHeaderTest_Mom extends GridFieldSortableHeaderTest_Cheerleader implements TestOnly { private static $db = array( 'NumberOfCookiesBaked' => 'Int' ); } class GridFieldSortableHeaderTest_CheerleaderHat extends DataObject implements TestOnly { private static $db = array( 'Colour' => 'Varchar' ); private static $has_one = array( 'Cheerleader' => 'GridFieldSortableHeaderTest_Cheerleader' ); }