mirror of
https://github.com/silverstripe/silverstripe-subsites
synced 2024-10-22 11:05:55 +02:00
Merge pull request #359 from creative-commoners/pulls/1.4/default-page-on-creation
FIX Automatically create default SiteTree records for new subsites
This commit is contained in:
commit
6a8da1caaa
@ -743,16 +743,35 @@ class Subsite extends DataObject
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whenever a Subsite is written, rewrite the hostmap
|
* Whenever a Subsite is written, rewrite the hostmap and create some default pages
|
||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public function onAfterWrite()
|
public function onAfterWrite()
|
||||||
{
|
{
|
||||||
Subsite::writeHostMap();
|
Subsite::writeHostMap();
|
||||||
|
if ($this->isChanged('ID')) {
|
||||||
|
$this->createDefaultPages();
|
||||||
|
}
|
||||||
parent::onAfterWrite();
|
parent::onAfterWrite();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Automatically create default pages for new subsites
|
||||||
|
*/
|
||||||
|
protected function createDefaultPages()
|
||||||
|
{
|
||||||
|
$currentSubsite = Subsite::currentSubsiteID();
|
||||||
|
Subsite::changeSubsite($this->ID);
|
||||||
|
|
||||||
|
// Silence DB schema output
|
||||||
|
DB::quiet();
|
||||||
|
$siteTree = new SiteTree();
|
||||||
|
$siteTree->requireDefaultRecords();
|
||||||
|
|
||||||
|
Subsite::changeSubsite($currentSubsite);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the primary domain of this site. Tries to "normalize" the domain name,
|
* Return the primary domain of this site. Tries to "normalize" the domain name,
|
||||||
* by replacing potential wildcards.
|
* by replacing potential wildcards.
|
||||||
|
@ -13,6 +13,14 @@ class SiteTreeSubsitesTest extends BaseSubsiteTest
|
|||||||
'SiteTree' => array('Translatable')
|
'SiteTree' => array('Translatable')
|
||||||
);
|
);
|
||||||
|
|
||||||
|
public function setUp()
|
||||||
|
{
|
||||||
|
// We have our own home page fixtures, prevent the default one being created in this test suite.
|
||||||
|
Config::inst()->update('SiteTree', 'create_default_pages', false);
|
||||||
|
|
||||||
|
parent::setUp();
|
||||||
|
}
|
||||||
|
|
||||||
public function testPagesInDifferentSubsitesCanShareURLSegment()
|
public function testPagesInDifferentSubsitesCanShareURLSegment()
|
||||||
{
|
{
|
||||||
$subsiteMain = $this->objFromFixture('Subsite', 'main');
|
$subsiteMain = $this->objFromFixture('Subsite', 'main');
|
||||||
|
@ -442,4 +442,15 @@ class SubsiteTest extends BaseSubsiteTest
|
|||||||
$subsite2->activate();
|
$subsite2->activate();
|
||||||
$this->assertEquals('MyNewAwesomePage', DataObject::get_by_id('Page', $page2->ID)->Title);
|
$this->assertEquals('MyNewAwesomePage', DataObject::get_by_id('Page', $page2->ID)->Title);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testDefaultPageCreatedWhenCreatingSubsite()
|
||||||
|
{
|
||||||
|
$subsite = new Subsite();
|
||||||
|
$subsite->Title = 'New Subsite';
|
||||||
|
$subsite->write();
|
||||||
|
$subsite->activate();
|
||||||
|
|
||||||
|
$pages = SiteTree::get();
|
||||||
|
$this->assertGreaterThanOrEqual(1, $pages->count());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user