mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Merge pull request #1094 from silverstripe-big-o/pulls/3.1-versioned-relfield
BUGFIX Versioned_Version->relField()
This commit is contained in:
commit
f0d92f7bcc
@ -1222,4 +1222,32 @@ class Versioned_Version extends ViewableData {
|
|||||||
public function Published() {
|
public function Published() {
|
||||||
return !empty( $this->record['WasPublished'] );
|
return !empty( $this->record['WasPublished'] );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copied from DataObject to allow access via dot notation.
|
||||||
|
*/
|
||||||
|
public function relField($fieldName) {
|
||||||
|
$component = $this;
|
||||||
|
|
||||||
|
if(strpos($fieldName, '.') !== false) {
|
||||||
|
$parts = explode('.', $fieldName);
|
||||||
|
$fieldName = array_pop($parts);
|
||||||
|
|
||||||
|
// Traverse dot syntax
|
||||||
|
foreach($parts as $relation) {
|
||||||
|
if($component instanceof SS_List) {
|
||||||
|
if(method_exists($component,$relation)) $component = $component->$relation();
|
||||||
|
else $component = $component->relation($relation);
|
||||||
|
} else {
|
||||||
|
$component = $component->$relation();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unlike has-one's, these "relations" can return false
|
||||||
|
if($component) {
|
||||||
|
if ($component->hasMethod($fieldName)) return $component->$fieldName();
|
||||||
|
return $component->$fieldName;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user