delboy1978uk/bone-i18n 问题修复 & 功能扩展

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

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

delboy1978uk/bone-i18n

最新稳定版本:v1.4.5

Composer 安装命令:

composer require delboy1978uk/bone-i18n

包简介

I18n package for Bone Framework

README 文档

README

Latest Stable Version Total Downloads Latest Unstable Version License
build status Code Coverage Scrutinizer Code Quality

I18n package for Bone Framework

installation

bone-i18n is a core dependency of delboy1978uk/bone, and so it is installed by default.

setup

The skeleton app has a directory for translations (usually data/translations but you can set this to anything), which will contain locale folders such as en_US etc.

Drop in your .mo and .po files. Open config/bone-i18n.php and tweak to suit:

<?php

return [
    'i18n' => [
        'enabled' => true,
        'translations_dir' => 'data/translations',
        'default_locale' => 'en_PI',
        'supported_locales' => ['en_PI', 'en_GB', 'nl_BE', 'fr_BE'],
        'date_format' => 'd/m/Y',
    ]
];

For any package you have that will contain translation files, edit your package class and make it implement Bone\I18n\I18nRegistrationInterface. Create the method public function getTranslationsDirectory(): string that will return the translations directory path.

usage

locale view helper

You can have routes prepended with the current locale by calling

<?= $this->locale() ?>

Or more conveniently

<?= $this->l() ?>

in your view files. A link such as /user would then become /en_US/user. Bone Framework uses i18n middleware to fetch the locale and it strips the locale from the URL and sets it as a Request Attribute, so you do not need to define routes with a locale parameter.

controllers

In a controller action if you need the locale you can say:

$locale = $request->getAttribute('locale');

To get a translator into your controller, make it implement Bone\I18n\I18nAwareInterface and use the Bone\I18n\Traits\HasTranslatorTrait. If you package's Package class returns the controller without going through the Bone\Mvc\Controller\Init class, change it now to this:

return  Init::controller(new YourController(), $c);

You can now call $this->getTranslator() which will return an instance of the translator.

translation view helper

To translate text in your view, call the following:

<?= $this->translate('whatever.key.to.translate') ;?>

Or again, more conveniently

<?= $this->t('whatever.key.to.translate') ;?>

i18n aware forms

Bone Framework uses delboy1978uk/form for its form functionality. However, instead of extending Del\Form, you can create a form extending Bone\I18n\Form, which takes the translator as a second argument.

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2020-02-26