phpnomad/symfony-translation-integration 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

phpnomad/symfony-translation-integration

最新稳定版本:1.0.0

Composer 安装命令:

composer require phpnomad/symfony-translation-integration

包简介

PHPNomad Symfony translation strategy implementation

README 文档

README

Latest Version Total Downloads PHP Version License

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 of PHPNomad\Translations\Interfaces\TranslationStrategy that delegates translate() and translatePlural() calls to Symfony's TranslatorInterface::trans().
  • Disambiguation context is encoded using gettext's msgctxt convention (the \x04 EOT separator), so catalogues loaded from gettext .po/.mo files 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 the TranslationStrategy interface along with the HasTextDomain and HasLanguage providers
  • symfony/translation-contracts ^2.5 or ^3.0, which defines TranslatorInterface
  • A configured Symfony translator with your catalogues loaded (the full symfony/translation package or any implementation of TranslatorInterface)

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

License

MIT. See LICENSE.

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-03-31

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固