config/environment.rbで
# The internationalization framework can be changed to have another default locale (standard is :en) or more load paths.
# All files from config/locales/*.rb,yml are added automatically.
# config.i18n.load_path < < Dir[File.join(RAILS_ROOT, 'my', 'locales', '*.{rb,yml}')]
# config.i18n.default_locale = :de
[/sourcecode]
がある。コード部分をコメントアウトして、load_pathに追加する「<<」を「+=」に修正(2.2.2のバグ)する。今回はロケールをjaにするので、:deを:jaとする。
翻訳ファイルの置き場所として、config/localesディレクトリを作成する。
validationなどはすでにrails-i18nに用意されているので、ダウンロードしてlocales以下に置く。日本語の場合はja.ymlをダウンロードする。ja.yml中activerecordが2つあって1つめが無効になってしまったので、ひとつにまとめておく。具体的には
[sourcecode lang="ruby"]
activerecord:
errors:
template:
header:
one: "{{model}}にエラーが発生しました。"
other: "{{model}}に{{count}}つのエラーが発生しました。"
body: "次の項目を確認してください。"
activerecord:
errors:
messages:
[/sourcecode]
を
[sourcecode lang="ruby"]
activerecord:
errors:
template:
header:
one: "{{model}}にエラーが発生しました。"
other: "{{model}}に{{count}}つのエラーが発生しました。"
body: "次の項目を確認してください。"
messages:
[/sourcecode]
と修正する。
view、controllerで利用するには
[sourcecode lang="ruby"]
<td>< %= l(survey.started_at) %>
<td>< %= l(survey.ended_at) %></td>
<td>< %= link_to t('Show'), survey_questions_path(survey) %></td>
ここでl,tメソッドがi18nしている。lはlocalizeのaliasで、localeに応じた日付フォーマットでstrftimeする。tはtranslateのaliasで、翻訳ファイルにあるものを返す。上記ではShowがキーになるので、ファイルに追加する必要がある。
validationで表示されるテーブル、カラム名を翻訳することもできる。
テーブル名「Todos」、カラム名「title」の場合、
ja:
activerecord:
models:
todo: "Todo"
attributes:
todo:
title: "タイトル"
とする。テーブル名は複数形だが、ファイル中では(クラス名なので)シングルにする必要がある。
翻訳ファイル中で言語をキーにしているので、ファイルはひとつでもよいし、たくさんでもよい。フレームワークで利用するファイルとアプリケーション固有のファイルを言語ごとにわければメンテナンス性に優れているだろう。