laravelarab / tarjama
This package is abandoned and no longer maintained.
The author suggests using the fevrok/laravel-translatable package instead.
It's a laravel model columns translation manager
v1.8.0
2020-12-24 22:00 UTC
Requires
- php: ^5.6.4|^7.0|^8.0
- illuminate/support: ^5.4|^6.0|^7.0|^8.0
Requires (Dev)
- orchestra/testbench: ~3.6.7|~3.7.8|~3.8.6|^4.8|^5.2|^6.0
- phpunit/phpunit: ^5.7.14|^6.0|^7.0|^8.0|^9.0
README
It's a Laravel model columns translation manager
Current working model
Installation
You can install the package via composer:
composer require laravelarab/tarjama
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
LaravelArab\Tarjama\TarjamaServiceProvider::class,
If you want to change the default locale, you must publish the config file:
php artisan vendor:publish --provider="LaravelArab\Tarjama\TarjamaServiceProvider"
This is the contents of the published file:
return [ /** * Default Locale || Root columns locale * We will use this locale if config('app.locale') translation not exist */ 'locale' => 'en', /** * Supported Locales e.g: ['en', 'fr', 'ar'] */ 'locales' => ['ar', 'en', 'fr'] ];
next migrate translations table
php artisan migrate
Making a model translatable
The required steps to make a model translatable are:
- Just use the
LaravelArab\Tarjama\Translatable
trait.
Here's an example of a prepared model:
use Illuminate\Database\Eloquent\Model; use LaravelArab\Tarjama\Translatable; class Item extends Model { use Translatable; /** * The attributes that are Translatable. * * @var array */ protected $translatable = [ 'name', 'color' ]; }
Available methods
Saving translations
$item = new Item; $data = array('en' => 'car', 'ar' => 'سيارة'); $item->setTranslations('name', $data); // setTranslations($attribute, array $translations, $save = false) // or save one translation $item->setTranslation('name', 'en', 'car', true); // setTranslation($attribute, $locale, $value, $save = false) // or just do $item->name = 'car'; // note: this will save automaticaly unless it's the default locale // This will save if (current locale == default locale OR $save = false) $item->save();
Get translations
$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)
Delete translations
$item = new Item::first(); $item->deleteTranslations(['name', 'color'], ['ar', 'en']); // deleteTranslations(array $attributes, $locales = null)
Maintainers
Abdellah Chadidi |