UPDATED: Refactored Translation module specific code out of the SiteConfig

This commit is contained in:
Damian Mooyman 2012-08-16 14:11:25 +12:00
parent cb3515a4d5
commit 4379034abf
2 changed files with 70 additions and 1 deletions

View File

@ -1132,6 +1132,72 @@ class Translatable extends DataExtension implements PermissionProvider {
return ($translations) ? $translations->First() : null; return ($translations) ? $translations->First() : null;
} }
/**
* Enables automatic population of SiteConfig fields using createTranslation if
* created outside of the Translatable module
* @var boolean
*/
public static $enable_siteconfig_generation = true;
/**
* When the SiteConfig object is automatically instantiated, we should ensure that
* 1. All SiteConfig objects belong to the same group
* 2. Defaults are correctly initiated from the base object
* 3. The creation mechanism uses the createTranslation function in order to be consistent
* This function ensures that any already created "vanilla" SiteConfig object is populated
* correctly with translated values.
* This function DOES populate the ID field with the newly created object ID
* @see SiteConfig
*/
protected function populateSiteConfig()
{
// This is required to prevent infinite loop during createTranslation
// If createTranslation is called directly on SiteConfig then this function could
// be called twice, but it will not cause harm for this to happen.
if(!self::$enable_siteconfig_generation)
return;
self::$enable_siteconfig_generation = false;
// Find the best base translation for site config
Translatable::disable_locale_filter();
$existingConfig = SiteConfig::get()->filter(array('Locale' => Translatable::default_locale()))->first();
if(!$existingConfig)
$existingConfig = SiteConfig::get()->first();
Translatable::enable_locale_filter();
// Base case; creation of the first site config
if(!$existingConfig)
{
$this->owner->Locale = Translatable::get_current_locale();
return;
}
// Edge case: creating new translation in same locale as an existing object probably
// should not have the same translation group (@todo find examples)
if(Translatable::get_current_locale() == $existingConfig->Locale)
return;
// Create a third "staging" translated object using the correct createTranslation mechanism
$stagingConfig = $existingConfig->createTranslation(Translatable::get_current_locale());
// Copy fields from translated object (including ID) to the generated object
// This is similar to the creation of objects via createTranslation, but we need to
// preserve the ID in order to prevent
$this->owner->update($stagingConfig->toMap());
// Re-enable config generation
self::$enable_siteconfig_generation = true;
}
/**
* Hooks into the DataObject::populateDefaults() method
*/
public function populateDefaults()
{
if (empty($this->owner->ID) && $this->owner instanceof SiteConfig)
$this->populateSiteConfig();
}
/** /**
* Creates a new translation for the owner object of this decorator. * Creates a new translation for the owner object of this decorator.
* Checks {@link getTranslation()} to return an existing translation * Checks {@link getTranslation()} to return an existing translation

View File

@ -32,8 +32,11 @@ class TranslatableSiteConfigTest extends SapphireTest {
} }
function testCurrentCreatesDefaultForLocale() { function testCurrentCreatesDefaultForLocale() {
Translatable::set_current_locale(Translatable::default_locale());
$configEn = SiteConfig::current_site_config(); $configEn = SiteConfig::current_site_config();
$configFr = SiteConfig::current_site_config('fr_FR'); Translatable::set_current_locale('fr_FR');
$configFr = SiteConfig::current_site_config();
Translatable::set_current_locale(Translatable::default_locale());
$this->assertInstanceOf('SiteConfig', $configFr); $this->assertInstanceOf('SiteConfig', $configFr);
$this->assertEquals($configFr->Locale, 'fr_FR'); $this->assertEquals($configFr->Locale, 'fr_FR');