Template:LangSwitch: Difference between revisions

From FlightGear wiki
Jump to navigation Jump to search
(+Copyable sample; -List of two-letter language codes. They are now all included in the copyable sample)
(→‎Copyable sample: + Serbian)
Line 92: Line 92:
<!-- | pt =  Portugese -->
<!-- | pt =  Portugese -->
<!-- | ru =  Russian -->
<!-- | ru =  Russian -->
<!-- | sr =  Serbian -->
<!-- | sv =  Swedish -->
<!-- | sv =  Swedish -->
<!-- | zh =  Chinese -->
<!-- | zh =  Chinese -->

Revision as of 20:52, 20 August 2014


The following template description is not displayed when the template is inserted in an article.

Goal

This template will show texts in different languages depending on the language of the page it is placed on.

It is mainly meant for translation of contents within templates so that a single template can be used in pages of different languages, rather than having to be translated with one template for each language.

The language the text will be shown in depends on the two letter language code between the page namespace and the page title, for example Talk:De/HB Radio-NAV. If a parameter with a text is not available in the language of the page or is empty, the English text will be shown instead provided it is available.

Usage

The parameters of this template corresponds to the ISO 639-1 two letter language code for the language to be used in that parameter.

For testing and demonstration purposes the named parameter lang can be used to select a different language than the language of the page the template is used on.

{{LangSwitch |de= |en= |es= |fr= |nl= |ru= ... |lang=}}
{{LangSwitch
| de = 
| en = 
| es = 
| fr = 
| nl = 
| ru = 
... 
| lang = 
}}

Examples

Translating templates

The template is mainly used for translating templates.

Do note that many templates are based on tables and have to start from the beginning of the line, which is accomplished like in the below example, and that inserting blank lines will alter the way the template is rendered.

{{LangSwitch
| en =  <!-- English -->
{{ Template with English contents }}
| de =  <!-- German -->
{{ Template with German contents }}
| fr =  <!-- French -->
{{ Template with French contents }}
}}

Using the lang parameter

For testing and demonstration purposes the the lang parameter can be used to override the automatic language selection.

<!-- Caveat: Google translated -->
{{LangSwitch
|de = Hallo Welt!
|en = Hello World!
|es = ¡Hola Mundo!
|fr = Bonjour tout le monde!
|nl = Hello World!
|ru = Привет мир!
|lang = fr
}}

Bonjour tout le monde!

Copyable sample

Please uncomment used entries, in essence by dragging and dropping <!-- to the left of the name of the language.

{{LangSwitch
<!-- | ca =  Catalan -->
<!-- | de =  German-->
| en =  <!-- English-->

<!-- | es =  Spanish -->
<!-- | fa =  Farsi -->
<!-- | fi =  Finnish -->
<!-- | fr =  French -->
<!-- | it =  Italian -->
<!-- | nl =  Dutch -->
<!-- | pl =  Polish -->
<!-- | pt =  Portugese -->
<!-- | ru =  Russian -->
<!-- | sr =  Serbian -->
<!-- | sv =  Swedish -->
<!-- | zh =  Chinese -->
| lang = {{{lang}}}
}}

Known issues

Using some characters like equal signs (=) and pipes/vertical strokes (|) inside template parameters will break the template. Do note that pipes will break tables and that this workaround have to be used for tables. Ways around this is to either use {{=}}, {{!}}, {{!!}} {{!-}} or or <nowiki>=</nowiki>, <nowiki>|</nowiki>, <nowiki>||</nowiki> or <nowiki>|-</nowiki>.

Related content