astrotomic/laravel-translatable

A Laravel package for multilingual models

Maintainers

πŸ‘ Gummibeer

Package info

github.com/Astrotomic/laravel-translatable

Homepage

Documentation

pkg:composer/astrotomic/laravel-translatable

Fund package maintenance!

Gummibeer

forest.astrotomic.info

Statistics

Installs: 8 166 338

Dependents: 129

Suggesters: 8

Stars: 1 411

Open Issues: 34

v11.17.0 2026-03-27 14:41 UTC

Requires

Requires (Dev)

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT e29bb7d66017033337e0271a103a940d2d745681

databasetranslationlanguagelaravel


README

πŸ‘ Latest Version
πŸ‘ MIT License
πŸ‘ Offset Earth
πŸ‘ Larabelles

πŸ‘ GitHub Workflow Status
πŸ‘ GitHub Workflow Status
πŸ‘ Codecov Coverage
πŸ‘ Total Downloads
πŸ‘ GitBook

πŸ‘ laravel-translatable socialcard

If you want to store translations of your models into the database, this package is for you.

This is a Laravel package for translatable models. Its goal is to remove the complexity in retrieving and storing multilingual model instances. With this package you write less code, as the translations are being fetched/saved when you fetch/save your instance.

The full documentation can be found at GitBook.

Installation

composer require astrotomic/laravel-translatable

Quick Example

Getting translated attributes

$post = Post::first();
echo $post->translate('en')->title; // My first post

App::setLocale('en');
echo $post->title; // My first post

App::setLocale('de');
echo $post->title; // Mein erster Post

Saving translated attributes

$post = Post::first();
echo $post->translate('en')->title; // My first post

$post->translate('en')->title = 'My cool post';
$post->save();

$post = Post::first();
echo $post->translate('en')->title; // My cool post

Filling multiple translations

$data = [
 'author' => 'Gummibeer',
 'en' => ['title' => 'My first post'],
 'fr' => ['title' => 'Mon premier post'],
];
$post = Post::create($data);

echo $post->translate('fr')->title; // Mon premier post

Filling multiple translations wrapped

You may define a wrapper property when creating new translations. Set the translations_wrapper property in translatable config file:

'translations_wrapper' => 'translations',

Then just wrap multiple locales using that property:

$data = [
 'author' => 'Gummibeer',
 'translations' => [
 'en' => ['title' => 'My first post'],
 'fr' => ['title' => 'Mon premier post'],
 ],
];
$post = Post::create($data);

echo $post->translate('fr')->title; // Mon premier post

Tutorials

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details. You could also be interested in CODE OF CONDUCT.

Security

If you discover any security related issues, please check SECURITY for steps to report it.

Credits

Versions

Package Laravel PHP
v11.17 9.* / 10.* / 11.* / 12.* / 13.* ^8.0
v11.16 9.* / 10.* / 11.* / 12.* ^8.0
v11.13 - v11.15 9.* / 10.* / 11.* ^8.0
v11.12 - v11.12 8.* / 9.* / 10.* ^8.0
v11.10 - v11.11 8.* / 9.* ^8.0
v11.6 - v11.9 5.8.* / 6.* / 7.* / 8.* >=7.2
v11.4 - v11.5 5.6.* / 5.7.* / 5.8.* / 6.* >=7.1.3
v11.0 - v11.3 5.6.* / 5.7.* / 5.8.* >=7.1.3

Treeware

You're free to use this package, but if it makes it to your production environment I would highly appreciate you buying the world a tree.

It’s now common knowledge that one of the best tools to tackle the climate crisis and keep our temperatures from rising above 1.5C is to plant trees. If you contribute to my forest you’ll be creating employment for local families and restoring wildlife habitats.

You can buy trees at offset.earth/treeware

Read more about Treeware at treeware.earth