From 3292a8b773c5b29a69b72718f996a36f3daead1d Mon Sep 17 00:00:00 2001 From: Al Twohill Date: Thu, 12 Jul 2018 13:44:32 +1200 Subject: [PATCH] NEW Add `columnUnique` API SS_List classes. --- src/ORM/ArrayList.php | 11 ++++++++++ src/ORM/DataList.php | 13 +++++++++++- src/ORM/DataQuery.php | 1 - src/ORM/ListDecorator.php | 5 +++++ src/ORM/UnsavedRelationList.php | 12 +++++++++++ .../GridField/GridFieldSortableHeaderTest.php | 2 +- tests/php/ORM/DataQueryTest.php | 20 +++++++++++++++++++ 7 files changed, 61 insertions(+), 3 deletions(-) diff --git a/src/ORM/ArrayList.php b/src/ORM/ArrayList.php index a012d4009..952bbcc03 100644 --- a/src/ORM/ArrayList.php +++ b/src/ORM/ArrayList.php @@ -370,6 +370,17 @@ class ArrayList extends ViewableData implements SS_List, Filterable, Sortable, L return $result; } + /** + * Returns a unique array of a single field value for all the items in the list + * + * @param string $colName + * @return array + */ + public function columnUnique($colName = 'ID') + { + return array_unique($this->column($colName)); + } + /** * You can always sort a ArrayList * diff --git a/src/ORM/DataList.php b/src/ORM/DataList.php index f9d1e87cf..996f78edf 100644 --- a/src/ORM/DataList.php +++ b/src/ORM/DataList.php @@ -990,7 +990,18 @@ class DataList extends ViewableData implements SS_List, Filterable, Sortable, Li */ public function column($colName = "ID") { - return $this->dataQuery->column($colName); + return $this->dataQuery->distinct(false)->column($colName); + } + + /** + * Returns a unque array of a single field value for all items in the list. + * + * @param string $colName + * @return array + */ + public function columnUnique($colName = "ID") + { + return $this->dataQuery->distinct(true)->column($colName); } // Member altering methods diff --git a/src/ORM/DataQuery.php b/src/ORM/DataQuery.php index f953aca35..e403f90b3 100644 --- a/src/ORM/DataQuery.php +++ b/src/ORM/DataQuery.php @@ -1147,7 +1147,6 @@ class DataQuery { $fieldExpression = $this->expressionForField($field); $query = $this->getFinalisedQuery(array($field)); - $query->setDistinct(false); $originalSelect = $query->getSelect(); $query->setSelect(array()); $query->selectField($fieldExpression, $field); diff --git a/src/ORM/ListDecorator.php b/src/ORM/ListDecorator.php index 8d1397fcd..b141d548e 100644 --- a/src/ORM/ListDecorator.php +++ b/src/ORM/ListDecorator.php @@ -142,6 +142,11 @@ abstract class ListDecorator extends ViewableData implements SS_List, Sortable, return $this->list->column($value); } + public function columnUnique($value = "ID") + { + return $this->list->columnUnique($value); + } + public function each($callback) { return $this->list->each($callback); diff --git a/src/ORM/UnsavedRelationList.php b/src/ORM/UnsavedRelationList.php index 2885c89fc..5b1479b40 100644 --- a/src/ORM/UnsavedRelationList.php +++ b/src/ORM/UnsavedRelationList.php @@ -275,6 +275,18 @@ class UnsavedRelationList extends ArrayList implements Relation return $list->column($colName); } + /** + * Returns a unique array of a single field value for all items in the list. + * + * @param string $colName + * @return array + */ + public function columnUnique($colName = "ID") + { + $list = new ArrayList($this->toArray()); + return $list->columnUnique($colName); + } + /** * Returns a copy of this list with the relationship linked to the given foreign ID. * @param int|array $id An ID or an array of IDs. diff --git a/tests/php/Forms/GridField/GridFieldSortableHeaderTest.php b/tests/php/Forms/GridField/GridFieldSortableHeaderTest.php index c39ee1788..937731607 100644 --- a/tests/php/Forms/GridField/GridFieldSortableHeaderTest.php +++ b/tests/php/Forms/GridField/GridFieldSortableHeaderTest.php @@ -68,7 +68,7 @@ class GridFieldSortableHeaderTest extends SapphireTest public function testGetManipulatedData() { - $list = new DataList(Team::class); + $list = Team::get()->filter([ 'ClassName' => Team::class ]); $config = new GridFieldConfig_RecordEditor(); $gridField = new GridField('testfield', 'testfield', $list, $config); diff --git a/tests/php/ORM/DataQueryTest.php b/tests/php/ORM/DataQueryTest.php index 8f2b2a3fd..ef3a72c96 100644 --- a/tests/php/ORM/DataQueryTest.php +++ b/tests/php/ORM/DataQueryTest.php @@ -397,4 +397,24 @@ class DataQueryTest extends SapphireTest $result = DataQueryTest\ObjectA::get()->column('Name'); $this->assertEquals(['Bar', 'Foo', 'Bar'], $result); } + + public function testColumnUniqueReturnsAllValues() + { + $first = new DataQueryTest\ObjectA(); + $first->Name = 'Bar'; + $first->write(); + + $second = new DataQueryTest\ObjectA(); + $second->Name = 'Foo'; + $second->write(); + + $third = new DataQueryTest\ObjectA(); + $third->Name = 'Bar'; + $third->write(); + + $result = DataQueryTest\ObjectA::get()->columnUnique('Name'); + $this->assertCount(2, $result); + $this->assertContains('Bar', $result); + $this->assertContains('Foo', $result); + } }