From 8d84cb35b0d16ca68793e35b383c5cd742e8e30f Mon Sep 17 00:00:00 2001 From: Andrew Aitken-Fincham Date: Tue, 23 Jan 2018 14:18:48 +0000 Subject: [PATCH] make dropdownFieldThreshold configurable on DBForeignKey --- src/ORM/FieldType/DBForeignKey.php | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) diff --git a/src/ORM/FieldType/DBForeignKey.php b/src/ORM/FieldType/DBForeignKey.php index c01a945beb1..c7eba498502 100644 --- a/src/ORM/FieldType/DBForeignKey.php +++ b/src/ORM/FieldType/DBForeignKey.php @@ -29,6 +29,15 @@ class DBForeignKey extends DBInt */ protected $object; + /** + * This represents the number of related objects to show in a dropdown before it reverts + * to a NumericField + * + * @config + * @var int + */ + private static $dropdownFieldThreshold = 100; + private static $index = true; private static $default_search_filter_class = 'ExactMatchFilter'; @@ -63,11 +72,17 @@ public function scaffoldFormField($title = null, $params = null) $list = DataList::create($hasOneClass); // Don't scaffold a dropdown for large tables, as making the list concrete // might exceed the available PHP memory in creating too many DataObject instances - if ($list->count() < 100) { + $threshold = self::config()->get('dropdownFieldThreshold'); + if ($list->count() < $threshold) { $field = new DropdownField($this->name, $title, $list->map('ID', $titleField)); $field->setEmptyString(' '); } else { $field = new NumericField($this->name, $title); + $field->setRightTitle( + 'This field has been converted to a NumericField as there are at least ' . $threshold + . ' related object(s). This can be set with the config variable' + . ' SilverStripe\ORM\FieldTypeDBForeignKey::dropdownFieldThreshold' + ); } return $field; }