mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
BUG Fixes serious issue with FieldList::addFieldsToTab failing to accept multiple field groups.
Additional groups beyond the first are ignored. Test cases included.
This commit is contained in:
parent
688d853a95
commit
24950692cd
@ -130,7 +130,7 @@ class FieldList extends ArrayList {
|
|||||||
// Check if a field by the same name exists in this tab
|
// Check if a field by the same name exists in this tab
|
||||||
if($insertBefore) {
|
if($insertBefore) {
|
||||||
$tab->insertBefore($field, $insertBefore);
|
$tab->insertBefore($field, $insertBefore);
|
||||||
} elseif($tab->fieldByName($field->getName())) {
|
} elseif(($name = $field->getName()) && $tab->fieldByName($name)) {
|
||||||
// It exists, so we need to replace the old one
|
// It exists, so we need to replace the old one
|
||||||
$this->replaceField($field->getName(), $field);
|
$this->replaceField($field->getName(), $field);
|
||||||
} else {
|
} else {
|
||||||
|
@ -48,6 +48,43 @@ class FieldListTest extends SapphireTest {
|
|||||||
/* We'll have 3 fields inside the tab */
|
/* We'll have 3 fields inside the tab */
|
||||||
$this->assertEquals(3, $tab->Fields()->Count());
|
$this->assertEquals(3, $tab->Fields()->Count());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that groups can be added to a fieldlist
|
||||||
|
*/
|
||||||
|
public function testFieldgroup() {
|
||||||
|
$fields = new FieldList();
|
||||||
|
$tab = new Tab('Root');
|
||||||
|
$fields->push($tab);
|
||||||
|
|
||||||
|
$fields->addFieldsToTab('Root', array(
|
||||||
|
$group1 = new FieldGroup(
|
||||||
|
new TextField('Name'),
|
||||||
|
new EmailField('Email')
|
||||||
|
),
|
||||||
|
$group2 = new FieldGroup(
|
||||||
|
new TextField('Company'),
|
||||||
|
new TextareaField('Address')
|
||||||
|
)
|
||||||
|
));
|
||||||
|
|
||||||
|
/* Check that the field objects were created */
|
||||||
|
$this->assertNotNull($fields->dataFieldByName('Name'));
|
||||||
|
$this->assertNotNull($fields->dataFieldByName('Email'));
|
||||||
|
$this->assertNotNull($fields->dataFieldByName('Company'));
|
||||||
|
$this->assertNotNull($fields->dataFieldByName('Address'));
|
||||||
|
|
||||||
|
/* The field objects in the set should be the same as the ones we created */
|
||||||
|
$this->assertSame($fields->dataFieldByName('Name'), $group1->fieldByName('Name'));
|
||||||
|
$this->assertSame($fields->dataFieldByName('Email'), $group1->fieldByName('Email'));
|
||||||
|
$this->assertSame($fields->dataFieldByName('Company'), $group2->fieldByName('Company'));
|
||||||
|
$this->assertSame($fields->dataFieldByName('Address'), $group2->fieldByName('Address'));
|
||||||
|
|
||||||
|
/* We'll have 2 fields directly inside the tab */
|
||||||
|
$this->assertEquals(2, $tab->Fields()->Count());
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test removing a single field from a tab in a set.
|
* Test removing a single field from a tab in a set.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user