From 1116d7d15dcd3b3c96ad6df2b72694f919b90a3b Mon Sep 17 00:00:00 2001 From: Dimitris Savvopoulos Date: Thu, 7 May 2015 18:07:37 +0200 Subject: [PATCH] Update readme.md --- readme.md | 36 +++++++++++++++++++++++++++++++----- 1 file changed, 31 insertions(+), 5 deletions(-) diff --git a/readme.md b/readme.md index e61b26c..2429f89 100644 --- a/readme.md +++ b/readme.md @@ -59,11 +59,11 @@ If you want to store translations of your models into the database, this package **Filling multiple translations** ```php - $data = array( + $data = [ 'code' => 'gr', - 'en' => array('name' => 'Greece'), - 'fr' => array('name' => 'Grèce'), - ); + 'en' => ['name' => 'Greece'], + 'fr' => ['name' => 'Grèce'], + ]; $greece = Country::create($data); @@ -122,7 +122,7 @@ class Country extends Eloquent { use \Dimsav\Translatable\Translatable; - public $translatedAttributes = array('name'); + public $translatedAttributes = ['name']; protected $fillable = ['code', 'name']; } @@ -238,6 +238,32 @@ $translation = $germany->getNewTranslation('it'); $germany->translations(); ``` +### Magic properties + +To use the magic properties, you have to define the property `$translatedAttributes` in your + main model: + + ```php + class Country extends Eloquent { + + use \Dimsav\Translatable\Translatable; + + public $translatedAttributes = ['name']; + } + ``` + +```php +// Again we start by having a country instance +$germany = Country::where('code', 'de')->first(); + +// We can reference properties of the translation object directly from our main model. +// This uses the default locale and is the equivalent of $germany->translate()->name +$germany->name; // 'Germany' + +// We can also quick access a translation with a custom locale +$germany->{'name:de'} // 'Deutschland' +``` + ### Fallback locales If you want to fallback to a default translation when a translation has not been found, enable this in the configuration