I18n (english): Porovnání verzí
Z Freenetis Wiki
Řádek 1: | Řádek 1: | ||
[[cs:I18n]] | [[cs:I18n]] | ||
− | + | [[ru:I18n (русский)]] | |
+ | |||
+ | Internationalization in FreenetISu covers two areas: | ||
+ | * Strings that are contained in the source code - this is done using the language files in i18n | ||
+ | * Strings in the database - string in the database is usually not necessary to translate. The exceptions are enumerated types - eg types of members, facilities, contacts that you can edit through a web interface. Since the installation Freenetis contains basic values for these types, it is necessary for them to think about internationalization. | ||
+ | |||
+ | Enumerated types are implemented using two tables: | ||
+ | |||
+ | {| Border = "1" class = "wikitable" | ||
+ | | + Enum_types: | ||
+ | ! id! type_id! value | ||
+ | | - | ||
+ | | 1 | | 1 (eg type = member) | | Applicant | ||
+ | | - | ||
+ | | 2 | | 1 | | Regular member | ||
+ | | - | ||
+ | | 3 | | 1 | | Honorary member | ||
+ | | - | ||
+ | | 4 | | 2 (eg = contact type) | | Phone | ||
+ | | - | ||
+ | | 5 | | 2 | | ICQ | ||
+ | | - | ||
+ | | 6 | | 2 | | Skype | ||
+ | |} | ||
+ | Table enum_types contains a listing of all types in the default language (here English is selected) | ||
+ | |||
+ | Translations for each row of enum_types we obtain from the table translations: | ||
+ | |||
+ | {| Border = "1" class = "wikitable" | ||
+ | | + Translations: | ||
+ | ! id! original_term! translated_term! lang | ||
+ | | - | ||
+ | | 1 | | Regular member | | Řádný člen | | cs | ||
+ | | - | ||
+ | | 2 | | Regular member | | Regular member | | en | ||
+ | | - | ||
+ | | 3 | | Regular member | | ordentlich Mitglied | | de | ||
+ | | - | ||
+ | | 4 | | Phone | | Phone | | cs | ||
+ | | - | ||
+ | | 5 | | Phone | | Phone | | de | ||
+ | | - | ||
+ | |} | ||
+ | |||
+ | Due to the fact that both tables are interrelated by key, you can use the table translations and translation of terms from other tables than enum_types. | ||
+ | |||
+ | Common query to get id and the corresponding strings for a particular language types of members (type_id = 1): | ||
+ | |||
+ | SELECT enum_types.id, IFNULL(translations.translated_term,enum_types.value) as value FROM enum_types | ||
+ | LEFT JOIN translations on enum_types.value = translations.original_term | ||
+ | WHERE enum_types.type_id=1 AND translations.lang="cs" |
Aktuální verze z 10. 12. 2013, 12:14
Internationalization in FreenetISu covers two areas:
- Strings that are contained in the source code - this is done using the language files in i18n
- Strings in the database - string in the database is usually not necessary to translate. The exceptions are enumerated types - eg types of members, facilities, contacts that you can edit through a web interface. Since the installation Freenetis contains basic values for these types, it is necessary for them to think about internationalization.
Enumerated types are implemented using two tables:
+ Enum_types: | id! type_id! value | - | | 1 (eg type = member) | | Applicant | - | | 1 | | Regular member | - | | 1 | | Honorary member | - | | 2 (eg = contact type) | | Phone | - | | 2 | | ICQ | - | | 2 | | Skype |
---|
Table enum_types contains a listing of all types in the default language (here English is selected)
Translations for each row of enum_types we obtain from the table translations:
+ Translations: | id! original_term! translated_term! lang | - | | Regular member | | Řádný člen | | cs | - | | Regular member | | Regular member | | en | - | | Regular member | | ordentlich Mitglied | | de | - | | Phone | | Phone | | cs | - | | Phone | | Phone | | de | - |
---|
Due to the fact that both tables are interrelated by key, you can use the table translations and translation of terms from other tables than enum_types.
Common query to get id and the corresponding strings for a particular language types of members (type_id = 1):
SELECT enum_types.id, IFNULL(translations.translated_term,enum_types.value) as value FROM enum_types LEFT JOIN translations on enum_types.value = translations.original_term WHERE enum_types.type_id=1 AND translations.lang="cs"