flame/translator

Nette多语言应用程序的翻译器

dev-master 2017-03-08 03:27 UTC

This package is not auto-updated.

Last update: 2024-09-14 12:47:55 UTC


README

Nette Translator (c) Patrik Votoček (Vrtak-CZ), 2010 (http://patrik.votocek.cz)

注意

这是一份简短的指南,说明如何在最新版的Nette 2.0中以最简单的方式使用Nette Translator。无需编辑或操作.po/.mo文件。撰写于2012年2月10日。

实际信息/指南:http://wiki.nette.org/cs/cookbook/zprovozneni-prekladace-nettetranslator

1. 启用翻译器

config.neon

common:
	services:
		translator:
			factory: \Flame\Translator\Gettext::getTranslator
			setup:
				- addFile(%appDir%/lang, front) # at leas one file required
				- \Flame\Translator\Panel::register # panel to debug bar

注意:**请不要忘记使文件夹%appDir%/lang可写**

2. 在模板中使用

default.latte

{_"Dog"}
{_"Cat", $number} // for plural, default are Czech plurals: 1, 2-4, 5+

3. 在表单中使用

/**
 * Base presenter for all application presenters.
 */
abstract class BasePresenter extends Flame\Application\UI\Presenter
{

	/**
	 * @persistent
	 */
	public $lang;

	/**
	 * @autowire
	 * @var \Flame\Translator\Gettext
	 */
	protected $translator;

	/**
	 * @autowire
	 * @var \Nette\Http\Request
	 */
	protected $request;

	protected function startup()
	{
		parent::startup();

		if (!$this->lang) {
			$lang = $this->request->detectLanguage(array('en', 'cs')) ?: 'cs';
			$this->redirectUrl($lang);
		}

	}

	public function createTemplate($class = NULL)
	{
		$template = parent::createTemplate($class);
		$this->translator->setLang($this->lang); // set lang
		$template->setTranslator($this->translator);
		return $template;
	}

}