ilyasapunkov/laravel-translatable

A Laravel package for translatable models using JSON fields

0.0.6 2025-02-24 12:38 UTC

This package is auto-updated.

Last update: 2025-05-24 13:20:33 UTC


README

A Laravel package for managing translatable models using JSON fields.

Installation

  1. Install the package via Composer:

    composer require ilyasapunkov/laravel-translatable
    
  2. Publish the migration:

    php artisan vendor:publish --tag=translatable-migrations
    
  3. Run the migration:

    php artisan migrate
    

Usage

  1. Use the Translatable trait in your model:

    namespace App\Models;
    
    use Illuminate\Database\Eloquent\Model;
    use IlyaSapunkov\Translatable\Traits\Translatable;
    
    class Post extends Model
    {
        use Translatable;
    
        protected $translatableFields = ['title', 'description'];
    }
  2. Set translations:

    $post = Post::create();
    
    $post->syncTranslation([
      'ru' => [
           'title' => 'Заголовок на русском',
           'description' => 'Описание на русском',
       ]
    ]);
  3. Get translations:

    echo $post->title; // Заголовок на русском (если текущая локаль 'ru')
    echo $post->description; // Описание на русском
  4. Filter by translations:

    $posts = Post::hasTranslation('title')->get();
    $posts = Post::hasTranslation('title', 'en')->get();