phpnomad / symfony-translation-integration
PHPNomad Symfony translation strategy implementation
Package info
github.com/phpnomad/symfony-translation-integration
pkg:composer/phpnomad/symfony-translation-integration
Requires
- phpnomad/translate: ^2.0
- symfony/translation-contracts: ^2.5 || ^3.0
Requires (Dev)
- mockery/mockery: ^1.5
- phpnomad/tests: ^0.1.0 || ^0.3.0
- phpunit/phpunit: ^9.6
README
Integrates the Symfony Translation component with PHPNomad's phpnomad/translate abstraction. It supplies a single TranslationStrategy implementation backed by Symfony's TranslatorInterface, so applications that call the PHPNomad translation API can resolve strings through a configured Symfony translator without changing any call sites.
Installation
composer require phpnomad/symfony-translation-integration
What This Provides
PHPNomad\Symfony\Translation\Strategies\TranslationStrategy, a concrete implementation ofPHPNomad\Translations\Interfaces\TranslationStrategythat delegatestranslate()andtranslatePlural()calls to Symfony'sTranslatorInterface::trans().- Disambiguation context is encoded using gettext's
msgctxtconvention (the\x04EOT separator), so catalogues loaded from gettext.po/.mofiles resolve contextual strings correctly. - Pluralization uses Symfony's
%count%parameter convention, which lines up with Symfony's ICU and legacy plural format loaders.
Requirements
phpnomad/translate^2.0, which defines theTranslationStrategyinterface along with theHasTextDomainandHasLanguageproviderssymfony/translation-contracts^2.5 or ^3.0, which definesTranslatorInterface- A configured Symfony translator with your catalogues loaded (the full
symfony/translationpackage or any implementation ofTranslatorInterface)
Usage
Bind the concrete strategy to the interface inside your PHPNomad bootstrapper. The strategy takes three constructor dependencies: the Symfony translator, a HasTextDomain provider that returns the active text domain, and a HasLanguage provider that returns the target locale (or null to fall back to the translator's default).
<?php use PHPNomad\Symfony\Translation\Strategies\TranslationStrategy; use PHPNomad\Translations\Interfaces\HasLanguage; use PHPNomad\Translations\Interfaces\HasTextDomain; use PHPNomad\Translations\Interfaces\TranslationStrategy as TranslationStrategyInterface; use Symfony\Component\Translation\Loader\ArrayLoader; use Symfony\Component\Translation\Translator; use Symfony\Contracts\Translation\TranslatorInterface; $container->bind(TranslatorInterface::class, function () { $translator = new Translator('en_US'); $translator->addLoader('array', new ArrayLoader()); $translator->addResource('array', ['hello' => 'Hello'], 'en_US', 'messages'); return $translator; }); $container->bind(HasTextDomain::class, MyTextDomainProvider::class); $container->bind(HasLanguage::class, MyLanguageProvider::class); $container->bind(TranslationStrategyInterface::class, TranslationStrategy::class);
Once bound, any code that resolves TranslationStrategy from the container will route through Symfony.
Documentation
- PHPNomad docs: phpnomad.com
- Symfony Translation component: symfony.com/doc/current/translation.html
License
MIT. See LICENSE.