Help:Localisation
MediaWiki Handbook: Contents, Readers, Editors, Moderators, System admins +/- |
A collection of texts in various languages basically is a 2D array. They can be stored in the following ways:
- for each text in each language there is a separate page, e.g.:
- MediaWiki:1movedto2/nl (for the set of pages see [1])
- commons:Template:Potd/2007-05-01 (de) (for the set of pages see [2])
- Template:Lang name - de (fr) (for the set of pages see [3])
- Fundraising FAQ/nl (for the set of pages see [4])
- ditto, but all translations are on the respective sites only, so the page name need not contain the language; this applies for example more or less for Wikipedia articles about a subject; however, they are usually not simply translations, and subjects which are combined in one article on one Wikipedia may be split up in another Wikipedia; an example for templates (deleted on en: and nl:) is:
- for each text (meaning) there is a template containing all translations, e.g.:
- for each language there is a template with multiple texts in that language (comparable to the php messsage files); a parameter selects the text; the templates may be subtemplates of a template with two parameters, one for the language and one for the selection of the text; see Category:Set of templates, each containing multiple texts in one language. Examples:
- Template:Language/fr; such templates (list) are subtemplates of Template:Language, which is a member of Category:Set of templates, each containing multiple texts in one language.
- Template:N fr (for the set see [5])
- Template:Snippets/lang fr (not just language names, but also some other texts, for the set see [6])
- there is one template containing the whole 2D array, e.g.:
- Template:Ln (small example)
One system for a multilingual template is that the template has an additional parameter "lan", and a text is produced depending on language; each line in Template:Pim shows an example of a style for making template content dependent on the language parameter: [[:Help:Localisation/examples]]
{{Help:Localisation/examples|lan=en}} gives: Help:Localisation/examples
{{Help:Localisation/examples|lan=nl}} gives: Help:Localisation/examples
For Template:HelpuMetaFarigxiMultlingva, Template:Tradukistoj, etc. it does not seem possible to select a language through a parameter; instead CSS or JS is used.
Contents
Template name
When copying a template to another site a translated name can be used. In the case of multilingualism on one site, in the simple case where only the template names are multilingual, the content can be put under one name, while under the translated names there are only redirects.
If the content is also localised, each template can call a common template, but each time with a different value of parameter lan. E.g. Template:Demo of English version of multilingual template calls Template:Multilingual template demo with lan=en, and Template:Demo van Nederlandstalige versie van meertalig sjabloon calls the same template with lan=nl.
If the template has e.g. a complicated logical structure, it is convenient if that logic is contained in a common template, to avoid duplication of effort.
Template content
As seen above there are various ways to make texts dependent on the value of parameter lan. If the template calls another template, and for that template the name, parameter names, or parameter values have to be localised, then the outer template has to take care of these localisations too. If the localisation of the inner template has been carried out such it can be called with international names too (see also below) then localisation of various templates can be carried out more independently of each other.
Examples of language-dependent "texts" are also Template:Multilingual template demo/thousands separator and Template:Multilingual template demo/decimal point. See also formatnum:, dependent on the format specified for the site, not on a template parameter "lan".
Note however that ParserFunctions #expr and #ifexpr only recognize a decimal point, and do not recognize any thousands separator.
Template parameter names
The localised templates can each use the localised name of a parameter. It calls the common template and gives an international parameter, e.g. "text", the value of the local parameter, e.g. "tekst". Two methods are:
- Parameter "text" is always defined; the value is the text "undefined" if parameter "tekst" is undefined:
- text={{{tekst|undefined}}}
- the state of being undefined is preserved, if parameter "tekst" is undefined then parameter "text" is left undefined too:
- {{#ifeq:{{{tekst|+}}}|{{{tekst|-}}}|text={{{tekst}}}}}
Correspondingly, if both parameter "tekst" and parameter "text" is allowed, and where if both are defined "tekst" prevails:
- text={{{tekst|{{{text|undefined}}}}}}
- Two methods ensuring that if neither parameter is defined parameter "text" is left undefined:
- {{#ifeq:{{{tekst|{{{text|+}}}}}}|{{{tekst|{{{text|-}}}}}}|text={{{tekst|{{{text}}}}}}}}
- {{#ifeq:{{{text|+}}}|{{{text|-}}}|text={{{text}}}}}|{{#ifeq:{{{tekst|+}}}|{{{tekst|-}}}|text={{{tekst}}}}}
Note that in the last method the dominating parameter is processed last, to override a possible value of "text".
Template parameter values
If a parameter value is not just passed through as text to be displayed, etc., but used in a condition, the possible parameter values can also be localised. We can either just allow the local versions of the values (the test value which a parameter value is compared is localised like ordinary text), or also allow the international version. In the latter case we can use something like {{#ifexpr:{{#ifeq:{{{font}}}|bold|1|0}}or{{#ifeq:{{{font}}}|vet|1|0}}|'''{{{text}}}'''|{{{text}}}}} ("vet" is Dutch for "bold").
See also
- Help:System message
- MediaWiki localisation
- Template:Mlmw
- Template:Multilingual template demo
- Meta:Language select
- w:af:Template:Voormalige Land Inligtingsraampie
- Help:Namespace#Generic namespace names
- bugzilla:8063 - JavaScript table sort does not observe local language with respect to digit groups, decimals and date formats
Links to other help pages
- Help contents
- Meta · Wikinews · Wikipedia · Wikiquote · Wiktionary · Commons: · mw: · b: · s: · mw:Manual · Google
- Versions of this help page (for other languages see further)
- Meta · Wikinews · Wikipedia · Wikiquote · Wiktionary
- What links here on Meta or from Meta · Wikipedia · MediaWiki
- Reading
- Go · Search · Stop words · Namespace · Page name · Section · Backlinks · Redirect · Category · Image page · Special pages · Printable version
- Tracking changes
- Recent changes (enhanced) | Related changes · Watching pages · Diff · Page history · Edit summary · User contributions · Minor edit · Patrolled edit
- Logging in and preferences
- Logging in · Preferences · User style
- Editing
- Starting a new page · Advanced editing · Editing FAQ · Edit toolbar · Export · Import · Shortcuts · Edit conflict · Page size
- Referencing
- Links · URLs · Piped links · Interwiki linking · Footnotes
- Style and formatting
- Wikitext examples · CSS · Reference card · HTML in wikitext · Formula · List · Table · Sorting · Colors · Images and file uploads
- Fixing mistakes
- Show preview · Testing · Reverting edits
- Advanced functioning
- Expansion · Template · Advanced templates · Parser function · Parameter default · Variable · System message · Substitution · Array · Calculation · Embed page
- Others
- Special characters · Renaming (moving) a page · Talk page · Signatures · Sandbox · Legal issues for editors