phpnomad/symfony-translation-integration
最新稳定版本:1.0.0
Composer 安装命令:
composer require phpnomad/symfony-translation-integration
包简介
PHPNomad Symfony translation strategy implementation
README 文档
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.
统计信息
- 总下载量: 0
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 3
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-03-31