From 34e270fe6f3eb6571d2371414f13fd4d726430b5 Mon Sep 17 00:00:00 2001 From: Steve Boyd Date: Wed, 12 Jun 2024 10:57:42 +1200 Subject: [PATCH] FIX Do not load source in SearchableDropdownTrait when lazy-loading --- src/Forms/SearchableDropdownTrait.php | 4 ++++ .../php/Forms/SearchableDropdownTraitTest.php | 24 +++++++++++++++++++ 2 files changed, 28 insertions(+) diff --git a/src/Forms/SearchableDropdownTrait.php b/src/Forms/SearchableDropdownTrait.php index 5931912f9d2..c692eaffe28 100644 --- a/src/Forms/SearchableDropdownTrait.php +++ b/src/Forms/SearchableDropdownTrait.php @@ -262,6 +262,10 @@ public function setIsSearchable(bool $isSearchable): static */ public function getSource(): array { + // Source will be unused when lazy-loading so just return an empty array + if ($this->getIsLazyLoaded()) { + return []; + } return $this->getListMap($this->sourceList); } diff --git a/tests/php/Forms/SearchableDropdownTraitTest.php b/tests/php/Forms/SearchableDropdownTraitTest.php index d6f3aae4cd4..4a2ad9ca815 100644 --- a/tests/php/Forms/SearchableDropdownTraitTest.php +++ b/tests/php/Forms/SearchableDropdownTraitTest.php @@ -217,4 +217,28 @@ public function testGetSchemaDataDefaults(): void $this->assertSame('My placeholder', $schema['placeholder']); $this->assertFalse($schema['searchable']); } + + public function provideGetSource(): array + { + return [ + 'lazyLoad' => [ + 'isLazyLoaded' => true, + 'expected' => 0, + ], + 'not lazyLoad' => [ + 'isLazyLoaded' => false, + 'expected' => 3, + ], + ]; + } + + /** + * @dataProvider provideGetSource + */ + public function testGetSource(bool $isLazyLoaded, int $expected): void + { + $field = new SearchableDropdownField('MyField', 'MyField', Team::get()); + $field->setIsLazyLoaded($isLazyLoaded); + $this->assertCount($expected, $field->getSource()); + } }