dnj / laravel-localization
Installs: 218
Dependents: 1
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/dnj/laravel-localization
Requires
- php: ^8.1
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.11
- orchestra/testbench: ^8.0
- phpstan/phpstan: ^1.4.1
- phpunit/phpunit: ^9.5
This package is auto-updated.
Last update: 2025-10-21 22:49:53 UTC
README
This package helps you to manage and present your multi-language Eloquent models easier.
There is core concept: You have a record (like Product) and each record has some localized attribute (like title or descriptions). So you create a Eloquent model for your main entity:
<?php namespace App\Models; use dnj\Localization\Contracts\ITranslatableModel; use dnj\Localization\Eloquent\HasTranslate; class Product extends Model implements ITranslatableModel { use HasTranslate; protected $table = "product"; }
And then create another model for its translates:
<?php namespace App\Models; use dnj\Localization\Contracts\ITranslateModel; use dnj\Localization\Eloquent\IsTranslate; class ProductTranslate extends Model implements ITranslateModel { use IsTranslate; protected $table = "product_translate"; }
ITranslatableModel
This interface prodvide two methods for you which you can retrive translates for a model:
| Method | Description | 
|---|---|
| getTranslate(string $locale): ?ITranslateModel | Get translation for this model for $locale, if it's present. | 
| getTranslates(): iterable | Get all translates for this model. | 
To facilitate things there is a HasTranslate trait that taking care of implementing those methods.
On top of that, this trait has some extra methods:
| Method | Description | 
|---|---|
| getTranslateForUpdate(string $locale): ITranslateModel | Get & lock the translation for update. If it's not exist an exception will throw | 
| addTranslate(string $locale, array $fields): ITranslateModel | Insert new translation for this object in $localelanguage. | 
| deleteTranslate(string $locale): void | Permanently destroy a translate for this object in $localelanguage. | 
| updateTranslate(string $locale, array $fields): ITranslateModel | Update the translation in $localelanguage for this object. | 
| updateTranslate(array<string,array<string,string>> $changes): static | Insert&Update&Delete translations based on input. | 
ITranslateModel
This model is much simpler. Just contains some getters.
| Method | Description | 
|---|---|
| getLocale(): string | Getter for the translation localevalue. | 
| getField(string $key): string | Getter for the field with $keykey. If$keydoes not exists an exception will throw | 
| getFields(): array<string,string> | All fields as an associative array. | 
And also there is IsTranslate trait which implements these methods for you.
Security
If you've found a bug regarding security please mail security@dnj.co.ir instead of using the issue tracker.
License
The MIT License (MIT). Please see License File for more information.