mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
FIX: Hierarchy was incorrectly unexpanding nodes that had been previously expanded
This commit is contained in:
parent
6ee3e458b6
commit
43dcde5197
@ -274,7 +274,8 @@ class Hierarchy extends DataExtension {
|
|||||||
foreach($children as $child) {
|
foreach($children as $child) {
|
||||||
$markingMatches = $this->markingFilterMatches($child);
|
$markingMatches = $this->markingFilterMatches($child);
|
||||||
if($markingMatches) {
|
if($markingMatches) {
|
||||||
if($child->$numChildrenMethod()) {
|
// Mark a child node as unexpanded if it has children and has not already been expanded
|
||||||
|
if($child->$numChildrenMethod() && !$child->isExpanded()) {
|
||||||
$child->markUnexpanded();
|
$child->markUnexpanded();
|
||||||
} else {
|
} else {
|
||||||
$child->markExpanded();
|
$child->markExpanded();
|
||||||
|
@ -59,12 +59,12 @@ class HierarchyTest extends SapphireTest {
|
|||||||
// Obj 3 has been deleted; let's bring it back from the grave
|
// Obj 3 has been deleted; let's bring it back from the grave
|
||||||
$obj3 = Versioned::get_including_deleted("HierarchyTest_Object", "\"Title\" = 'Obj 3'")->First();
|
$obj3 = Versioned::get_including_deleted("HierarchyTest_Object", "\"Title\" = 'Obj 3'")->First();
|
||||||
|
|
||||||
// Check that both obj 3 children are returned
|
// Check that all obj 3 children are returned
|
||||||
$this->assertEquals(array("Obj 3a", "Obj 3b", "Obj 3c"),
|
$this->assertEquals(array("Obj 3a", "Obj 3b", "Obj 3c", "Obj 3d"),
|
||||||
$obj3->AllHistoricalChildren()->column('Title'));
|
$obj3->AllHistoricalChildren()->column('Title'));
|
||||||
|
|
||||||
// Check numHistoricalChildren
|
// Check numHistoricalChildren
|
||||||
$this->assertEquals(3, $obj3->numHistoricalChildren());
|
$this->assertEquals(4, $obj3->numHistoricalChildren());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -94,11 +94,11 @@ class HierarchyTest extends SapphireTest {
|
|||||||
public function testNumChildren() {
|
public function testNumChildren() {
|
||||||
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj1')->numChildren(), 0);
|
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj1')->numChildren(), 0);
|
||||||
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj2')->numChildren(), 2);
|
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj2')->numChildren(), 2);
|
||||||
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj3')->numChildren(), 3);
|
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj3')->numChildren(), 4);
|
||||||
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj2a')->numChildren(), 2);
|
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj2a')->numChildren(), 2);
|
||||||
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj2b')->numChildren(), 0);
|
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj2b')->numChildren(), 0);
|
||||||
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj3a')->numChildren(), 2);
|
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj3a')->numChildren(), 2);
|
||||||
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj3b')->numChildren(), 0);
|
$this->assertEquals($this->objFromFixture('HierarchyTest_Object', 'obj3d')->numChildren(), 0);
|
||||||
|
|
||||||
$obj1 = $this->objFromFixture('HierarchyTest_Object', 'obj1');
|
$obj1 = $this->objFromFixture('HierarchyTest_Object', 'obj1');
|
||||||
$this->assertEquals($obj1->numChildren(), 0);
|
$this->assertEquals($obj1->numChildren(), 0);
|
||||||
@ -180,6 +180,53 @@ class HierarchyTest extends SapphireTest {
|
|||||||
$this->assertEquals('Obj 2 » Obj 2a » Obj 2aa', $obj2aa->getBreadcrumbs());
|
$this->assertEquals('Obj 2 » Obj 2a » Obj 2aa', $obj2aa->getBreadcrumbs());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @covers Hierarchy::markChildren()
|
||||||
|
*/
|
||||||
|
public function testMarkChildrenDoesntUnmarkPreviouslyMarked() {
|
||||||
|
$obj3 = $this->objFromFixture('HierarchyTest_Object', 'obj3');
|
||||||
|
$obj3aa = $this->objFromFixture('HierarchyTest_Object', 'obj3aa');
|
||||||
|
$obj3ba = $this->objFromFixture('HierarchyTest_Object', 'obj3ba');
|
||||||
|
$obj3ca = $this->objFromFixture('HierarchyTest_Object', 'obj3ca');
|
||||||
|
|
||||||
|
$obj3->markPartialTree();
|
||||||
|
$obj3->markToExpose($obj3aa);
|
||||||
|
$obj3->markToExpose($obj3ba);
|
||||||
|
$obj3->markToExpose($obj3ca);
|
||||||
|
|
||||||
|
$expected = <<<EOT
|
||||||
|
<ul>
|
||||||
|
<li>Obj 3a
|
||||||
|
<ul>
|
||||||
|
<li>Obj 3aa
|
||||||
|
</li>
|
||||||
|
<li>Obj 3ab
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</li>
|
||||||
|
<li>Obj 3b
|
||||||
|
<ul>
|
||||||
|
<li>Obj 3ba
|
||||||
|
</li>
|
||||||
|
<li>Obj 3bb
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</li>
|
||||||
|
<li>Obj 3c
|
||||||
|
<ul>
|
||||||
|
<li>Obj 3c
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
</li>
|
||||||
|
<li>Obj 3d
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
|
||||||
|
EOT;
|
||||||
|
|
||||||
|
$this->assertSame($expected, $obj3->getChildrenAsUL());
|
||||||
|
}
|
||||||
|
|
||||||
public function testGetChildrenAsUL() {
|
public function testGetChildrenAsUL() {
|
||||||
$obj1 = $this->objFromFixture('HierarchyTest_Object', 'obj1');
|
$obj1 = $this->objFromFixture('HierarchyTest_Object', 'obj1');
|
||||||
$obj2 = $this->objFromFixture('HierarchyTest_Object', 'obj2');
|
$obj2 = $this->objFromFixture('HierarchyTest_Object', 'obj2');
|
||||||
@ -539,6 +586,8 @@ class HierarchyTest_Object extends DataObject implements TestOnly {
|
|||||||
"Versioned('Stage', 'Live')",
|
"Versioned('Stage', 'Live')",
|
||||||
);
|
);
|
||||||
|
|
||||||
|
private static $default_sort = 'Title ASC';
|
||||||
|
|
||||||
public function cmstreeclasses() {
|
public function cmstreeclasses() {
|
||||||
return $this->markingClasses();
|
return $this->markingClasses();
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,9 @@ HierarchyTest_Object:
|
|||||||
obj3c:
|
obj3c:
|
||||||
Parent: =>HierarchyTest_Object.obj3
|
Parent: =>HierarchyTest_Object.obj3
|
||||||
Title: Obj 3c
|
Title: Obj 3c
|
||||||
|
obj3d:
|
||||||
|
Parent: =>HierarchyTest_Object.obj3
|
||||||
|
Title: Obj 3d
|
||||||
obj2aa:
|
obj2aa:
|
||||||
Parent: =>HierarchyTest_Object.obj2a
|
Parent: =>HierarchyTest_Object.obj2a
|
||||||
Title: Obj 2aa
|
Title: Obj 2aa
|
||||||
@ -31,4 +34,13 @@ HierarchyTest_Object:
|
|||||||
Title: Obj 3aa
|
Title: Obj 3aa
|
||||||
obj3ab:
|
obj3ab:
|
||||||
Parent: =>HierarchyTest_Object.obj3a
|
Parent: =>HierarchyTest_Object.obj3a
|
||||||
Title: Obj 3ab
|
Title: Obj 3ab
|
||||||
|
obj3ba:
|
||||||
|
Parent: =>HierarchyTest_Object.obj3b
|
||||||
|
Title: Obj 3ba
|
||||||
|
obj3bb:
|
||||||
|
Parent: =>HierarchyTest_Object.obj3b
|
||||||
|
Title: Obj 3bb
|
||||||
|
obj3ca:
|
||||||
|
Parent: =>HierarchyTest_Object.obj3c
|
||||||
|
Title: Obj 3c
|
||||||
|
Loading…
Reference in New Issue
Block a user