From 7239db8c1b41191fb0472c93abce78828a32ce03 Mon Sep 17 00:00:00 2001 From: Ingo Schommer Date: Sat, 1 Nov 2008 13:23:38 +0000 Subject: [PATCH] ENHANCEMENT Allowing translation of some static properties on DataObject and subclasses through DataObject->fieldLabels(). Part of the provideI18nEntities() work which was started in r64881 (see #1625) git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@65020 467b73ca-7a2a-4603-9d3b-597d59a354a9 --- core/model/DataObject.php | 29 +++++++++++++++++++++-------- 1 file changed, 21 insertions(+), 8 deletions(-) diff --git a/core/model/DataObject.php b/core/model/DataObject.php index 8abb3d4ff..7d1595ea8 100644 --- a/core/model/DataObject.php +++ b/core/model/DataObject.php @@ -2535,11 +2535,24 @@ class DataObject extends ViewableData implements DataObjectInterface { public function fieldLabels() { $customLabels = $this->stat('field_labels'); $autoLabels = array(); - if($this->inheritedDatabaseFields()){ - foreach($this->inheritedDatabaseFields() as $name => $type) { - $autoLabels[$name] = FormField::name_to_label($name); - } - } + + // get all translated static properties as defined in i18nCollectStatics() + $ancestry = ClassInfo::ancestry($this->class); + $ancestry = array_reverse($ancestry); + if($ancestry) foreach($ancestry as $ancestorClass) { + if($ancestorClass == 'ViewableData') break; + $types = array( + 'db' => (array)singleton($ancestorClass)->uninherited('db', true), + 'has_one' => (array)singleton($ancestorClass)->uninherited('has_one', true), + 'has_many' => (array)singleton($ancestorClass)->uninherited('has_many', true), + 'many_many' => (array)singleton($ancestorClass)->uninherited('many_many', true) + ); + foreach($types as $type => $attrs) { + foreach($attrs as $name => $spec) + $autoLabels[$name] = _t("{$ancestorClass}.{$type}_{$name}",FormField::name_to_label($name)); + } + } + $labels = array_merge((array)$autoLabels, (array)$customLabels); $this->extend('updateFieldLabels', $labels); @@ -2858,13 +2871,13 @@ class DataObject extends ViewableData implements DataObjectInterface { } $entities["{$this->class}.SINGULARNAME"] = array( - $this->uninherited('singular_name', true), + $this->singular_name(), PR_MEDIUM, 'Singular name of the object, used in dropdowns and to generally identify a single object in the interface' ); - + $entities["{$this->class}.PLURALNAME"] = array( - $this->uninherited('plural_name', true), + $this->plural_name(), PR_MEDIUM, 'Pural name of the object, used in dropdowns and to generally identify a collection of this object in the interface' );