Actions

カスタム翻訳

From LimeSurvey Manual

Revision as of 11:25, 25 May 2024 by Bravehorse (talk | contribs) (Created page with "# ソースメッセージ<code>INSERT INTO lime_source_message (id, category, message) VALUES (NULL, NULL, 'Submit');</code>を作成する。 # 以下の手順で使用するため、IDを確認する(もし1番の場合:IDは1) # 関連する翻訳を作成する:<code>INSERT INTO lime_message (id, language, translation) VALUES ('1', 'en', 'Validate'), ('1', 'fr', 'Valider'); </code>")
Other languages:

はじめに

LimeSurvey 5.4.0以降では、データベースへの直接アクセスによって全言語のあらゆる文字列を独自に翻訳することができます。

既存の翻訳がビジネスニーズに適合しない場合にこのしくみを使用することができます。

LimeSurveyの中核部分のテキストを変更すると、データベースを変更する必要があるため、特定の場合にのみ使用してください。

さらに、このしくみを使用すれば、アンケートテーマ固有の文字列を翻訳することもできます。

データベース翻訳のしくみ

データベースの翻訳は、LimeSurveyはYiiフレームワークのCDbMessageSourceから着想を得た方法を使用しています。

  1. SourceMessageテーブルのlime_source_message->messageで文字列を検索し、lime_source_message->idからidを取得します。
  2. 存在する場合、対象のid lime_message->idを持つ言語lime_message->languageのMessageテーブルの関連する翻訳 lime_message->translationを検索します。

LimeSurveyは、poファイルから翻訳の配列を作成し(このファイルの更新方法についてはLimeSurveyの翻訳を参照してください)、その後、データベースのすべての翻訳とマージします。

データベースに翻訳がある場合、常にその翻訳が返されます。

「送信」ボタンの例(英語とフランス語)

(特定のテーマと共に)すべてのアンケートの送信ボタンについて、_Submit_ではなく_Validate_を表示したいとします。テーマを更新し、gT('Submit')をgT('Validate')に置き換えると、すべての言語で常に_Validate_が表示されます。

すべてのテーマのすべてのアンケート

  1. ソースメッセージINSERT INTO lime_source_message (id, category, message) VALUES (NULL, NULL, 'Submit');を作成する。
  2. 以下の手順で使用するため、IDを確認する(もし1番の場合:IDは1)
  3. 関連する翻訳を作成する:INSERT INTO lime_message (id, language, translation) VALUES ('1', 'en', 'Validate'), ('1', 'fr', 'Valider');

Using your own theme (recommended solution)

This method uses a solution with your own template, it updates the default string for all other languages as well.

  1. In Theme editor select the Navigation part
  2. Search for Template:GT("Submit") (in navigator.twig)
  3. Replace by Template:GT("Validate")
  4. Create the source message INSERT INTO lime_source_message (id, category, message) VALUES (NULL, NULL, 'Validate');
  5. Check the ID (if it's the 1st : ID is 1) and use it for next instruction
  6. Create the related translation : INSERT INTO lime_message (id, language, translation) VALUES ('1', 'fr', 'Valider');