Skip to content

Commit

Permalink
Document package usage
Browse files Browse the repository at this point in the history
  • Loading branch information
chadidi committed Dec 26, 2021
1 parent 60189a9 commit 9f52c5f
Showing 1 changed file with 84 additions and 35 deletions.
119 changes: 84 additions & 35 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ composer require fevrok/laravel-translatable

If you have Laravel 5.5 and up The package will automatically register itself.

else you have to add the service provider to app/config/app.php
else you have to add the service provider to `config/app.php`

```php
Fevrok\Translatable\TranslatableServiceProvider::class,
Expand All @@ -40,16 +40,19 @@ After finishing the installation you can open `config/translatable.php`:

```php
return [
/**
* Set whether or not the translations is enbaled.
*/
'enabled' => true,

/**
* Default Locale || Root columns locale
* We will use this locale if config('app.locale') translation not exist
* Select default language
*/
'locale' => 'en',

];
```
Update your config accordingly.
And update your config accordingly.

### Making a model translatable

Expand All @@ -76,7 +79,7 @@ class Item extends Model
*/
protected $translatable = [
'name',
'description'
'description',
];
}
```
Expand All @@ -94,7 +97,7 @@ class CustomTranslation extends \Fevrok\Translatable\Models\Translation
}
```

Add `$translations_model` property and give it your custom translations class.
Add `$translations_model` property and give it to the model you wanna customize,

```php
use Illuminate\Database\Eloquent\Model;
Expand Down Expand Up @@ -126,57 +129,103 @@ class Item extends Model

### Eager-load translations

### Get default language value
```php
// Loads all translations
$posts = Post::with('translations')->get();

### Get translated value
// Loads all translations
$posts = Post::all();
$posts->load('translations');

### Translate the whole model
// Loads all translations
$posts = Post::withTranslations()->get();

### Check if model is translatable
// Loads specific locales translations
$posts = Post::withTranslations(['en', 'da'])->get();

### Set attribute translations
// Loads specific locale translations
$posts = Post::withTranslation('da')->get();

### Query translatable Models
// Loads current locale translations
$posts = Post::withTranslation('da')->get();
```

Saving translations
### Get default language value

```php
$item = new Item;
$data = array('en' => 'car', 'ar' => 'سيارة');
echo $post->title;
```

### Get translated value

$item->setTranslations('name', $data); // setTranslations($attribute, array $translations, $save = false)
```php
echo $post->getTranslatedAttribute('title', 'locale', 'fallbackLocale');
```

// or save one translation
$item->setTranslation('name', 'en', 'car', true); // setTranslation($attribute, $locale, $value, $save = false)
If you do not define locale, the current application locale will be used. You can pass in your own locale as a string. If you do not define fallbackLocale, the current application fallback locale will be used. You can pass your own locale as a string. If you want to turn the fallback locale off, pass false. If no values are found for the model for a specific attribute, either for the locale or the fallback, it will set that attribute to null.

// or just do
$item->name = 'car'; // note: this will save automaticaly unless it's the default locale
### Translate the whole model

// This will save if (current locale == default locale OR $save = false)
$item->save();
```php
$post = $post->translate('locale', 'fallbackLocale');
echo $post->title;
echo $post->body;

// You can also run the `translate` method on the Eloquent collection
// to translate all models in the collection.
$posts = $posts->translate('locale', 'fallbackLocale');
echo $posts[0]->title;
```

If you do not define locale, the current application locale will be used. You can pass in your own locale as a string. If you do not define fallbackLocale, the current application fallback locale will be used. You can pass in your own locale as a string. If you want to turn the fallback locale off, pass false. If no values are found for the model for a specific attribute, either for the locale or the fallback, it will set that attribute to null.

### Check if model is translatable

```php
// with string
if (Translatable::translatable(Post::class)) {
// it's translatable
}

// with object of Model or Collection
if (Translatable::translatable($post)) {
// it's translatable
}
```

Get translations
### Set attribute translations

```php
$item = new Item::first();
// get current locale translation
$item->city
OR
$item->getTranslation('city');

// pass translation locales
$item->getTranslation('city', 'ar'); // getTranslation($attribute, $language = null, $fallback = true)
$item->getTranslationsOf('name', ['ar', 'en']); // getTranslationsOf($attribute, array $languages = null, $fallback = true)
$post = $post->translate('da');
$post->title = 'foobar';
$post->save();
```

Delete translations
This will update or create the translation for title of the post with the locale da. Please note that if a modified attribute is not translatable, then it will make the changes directly to the model itself. Meaning that it will overwrite the attribute in the language set as default.

### Query translatable Models

To search for a translated value, you can use the `whereTranslation` method.
For example, to search for the slug of a post, you'd use

```php
$item = new Item::first();
$item->deleteTranslations(['name', 'color'], ['ar', 'en']); // deleteTranslations(array $attributes, $locales = null)
$page = Page::whereTranslation('slug', 'my-translated-slug');
// Is the same as
$page = Page::whereTranslation('slug', '=', 'my-translated-slug');
// Search only locale en, de and the default locale
$page = Page::whereTranslation('slug', '=', 'my-translated-slug', ['en', 'de']);
// Search only locale en and de
$page = Page::whereTranslation('slug', '=', 'my-translated-slug', ['en', 'de'], false);
```

`whereTranslation` accepts the following parameter:

* `field` the field you want to search in
* `operator` the operator. Defaults to `=`. Also can be the value \(Same as [where](https://laravel.com/docs/queries#where-clauses)\)
* `value` the value you want to search for
* `locales` the locales you want to search in as an array. Leave as `null` if you want to search all locales
* `default` also search in the default value/locale. Defaults to true.

## Maintainers

<table>
Expand Down

0 comments on commit 9f52c5f

Please sign in to comment.