ceedcv-maya / shared-translations-laravel
Polymorphic translations for Laravel: a single translations table + HasTranslations trait to store per-locale field values for any model (panel alerts, messages, …).
Package info
github.com/Maya-AQSS/shared-translations-laravel
pkg:composer/ceedcv-maya/shared-translations-laravel
Requires
- php: ^8.4
- illuminate/contracts: ^11.0 || ^12.0 || ^13.0
- illuminate/database: ^11.0 || ^12.0 || ^13.0
- illuminate/support: ^11.0 || ^12.0 || ^13.0
README
Traducciones polimórficas para Laravel: una única tabla translations + el
trait HasTranslations para almacenar el valor de cualquier campo de cualquier
modelo en N idiomas, sin tocar el esquema del modelo origen.
Instalación (dev local)
Override en composer.local.json de la app (patrón del ecosistema Maya):
{
"repositories": [
{ "type": "path", "url": "../maya_platform/packages/php/shared-translations-laravel", "options": { "symlink": true } }
],
"require": { "ceedcv-maya/shared-translations-laravel": "*" }
}
Uso
- Cargar la migración en el
AppServiceProvider::boot():
use Maya\Translations\Migrations as TranslationMigrations; $this->loadMigrationsFrom(TranslationMigrations::translations());
- Registrar el morph alias del modelo (en
AppServiceProvider::boot()):
use Illuminate\Database\Eloquent\Relations\Relation; Relation::enforceMorphMap(['panel_alert' => \App\Models\PanelAlert::class]);
- Usar el trait:
use Maya\Translations\Concerns\HasTranslations; class PanelAlert extends Model { use HasTranslations; protected array $translatable = ['text', 'action_label']; }
// Escritura (reemplaza todas las traducciones del campo) $alert->syncTranslations('text', ['es' => 'Hola', 'va' => 'Hola']); // Lectura con fallback $alert->translate('text', 'va', 'es'); // Serialización para API / payload de notificación $alert->translationsMap(); // { "text": { "es": "…", "va": "…" }, ... }
Esquema
translations(id, translatable_type, translatable_id, field, locale, value, timestamps)
con único (translatable_type, translatable_id, field, locale). translatable_id
es VARCHAR para soportar claves bigint y UUID/slug indistintamente.