hostnet/entity-translation-bundle 问题修复 & 功能扩展

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

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

hostnet/entity-translation-bundle

最新稳定版本:1.0.10

Composer 安装命令:

composer require hostnet/entity-translation-bundle

包简介

Translation bundle to help with rendering pretty names for enum-like classes.

README 文档

README

This bundle allows the automation of translating an enum value to a human readable string, for example, displaying a status text instead of the enum-value of a status code.

In it's essence, it allows to map a value to a translation within the domain that is the class name. What this means in practice is that you can use it as follows:

$status_text = $translator->trans(SetupStatus::DONE, [], SetupStatus::class);

Or in a twig template:

{{ constant('AppBundle\\Entity\\SetupStatus::DONE') | trans([], 'AppBundle\\Entity\\SetupStatus') }}

Requirements

The entity translation bundle requires at least php 7.3 and the symfony translation component. For specific requirements, please check composer.json

Installation

Installing is pretty straightforward, this package is available on packagist.

Example

$ composer require hostnet/entity-translation-bundle

Register The Bundle in your AppKernel

This bundle makes use of the translator which is registered by the framework bundle. So make sure you register this bundle after the FrameworkBundle.

class AppKernel extends Kernel
{
    public function registerBundles()
    {
        $bundles = [
            // ...
            new AppBundle\AppBundle(),
            new Hostnet\Bundle\EntityTranslationBundle\HostnetEntityTranslationBundle(),
            // ...
        ];

        return $bundles;
    }
}

Usage

Simply add an enum.en.yml to the translations folder in the Resources folder of one of your bundles. This will contain the translations for a given enum. The translation keys are the fully qualified namespaces in lowercase and an _ between CamelCase words. So for instance the enum AppBundle\Entity\SetupStatus would become app_bundle.entity.setup_status.

Consider the following class:

<?php
namespace AppBundle\Entity;

final class SetupStatus
{
    const PENDING           = 1;
    const DONE              = 2;
    const ERROR             = 3;
    const REVERTING_CHANGES = 4;
}

Your AppBundle/Resources/translations/enum.en.yml could look as followed:

app_bundle:
    entity:
        setup_status:
            pending           : Installation Pending.
            done              : Installation Complete.
            error             : An error occured.
            reverting_changes : Reverting changes.

The translator will then pick up all enum classes defined in your translation file.

统计信息

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

GitHub 信息

  • Stars: 5
  • Watchers: 4
  • Forks: 7
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2014-09-25