Multilingual wiki: Difference between revisions

No edit summary
No edit summary
 
(18 intermediate revisions by the same user not shown)
Line 1: Line 1:
{{DISPLAYTITLE:Multilingual wiki (single wiki)}}
{{DISPLAYTITLE:Multilingual wiki (single wiki)}}
[[File:hallo-cloud.png|alt=word cloud with translations of the greeting "hello"|right|200x200px]]
A wiki can be set up to include different language versions for wiki pages. Wiki administrators have to make some decisions regarding how they want to support each wiki user's language setting in addition to simply providing translated page content.


A wiki can be set up to include different language versions of a wiki content. Wiki administrators have to make some decisions regarding how they want to support each wiki user's language setting in addition to simply providing translated content.
The following considerations refer to a single-wiki scenario in ''BlueSpice free or pro'' and don't apply if the language versions are maintained in separate wikis.
 
The following considerations refer to a single-wiki scenario and don't apply if the language versions are maintained in multiple wikis.


== Concepts ==
== Concepts ==
To make a wiki multilingual, the some basic steps are necessary:
To make a single wiki multilingual, you can:


* Import a '''language switcher'''
* Create  wiki pages with '''automatically''' '''linked''' '''translation subpages'''
* Create wiki pages with '''linked''' '''translation subpages'''
   
In addition, depending on your wiki setup, it is possible to create:
* multilingual '''navigation links'''
* '''flexible''' '''page lists''' for each language
* '''portal pages''' based on user language
* '''template and form labels''' based on user language
* a multilingual '''category system'''


== Techniques ==
[[File:langswitcher.png|alt=globe icon with submenu links to English and French translations|thumb|language switcher|150x150px]]
[[File:usrelanguage-switchlabels.png|alt=Content based on user language settings|thumb|250x250px|Content based on user language ]]
[[File:multilingual-categories.png|alt=Multilingual category tree|thumb|250x250px|Multilingual category tree]]The explanations on this page use the following techniques, which we will look at in more detail:


In addition, depending on your wiki setup, further aspects can and should be considered:
#'''Automatic language switcher:'''  
* Create '''page lists''' for each language with different filter settings
#*The wiki automatically adds a language switcher to a page that has at least one language subpage.<br />
* Create '''portal pages''' based on user language
#'''User language:''' A simple mechanism to determine which language  a user has defined in their personal settings.  It provides options to:
* Create '''template and form labels''' based on user language
#*show or hide content based on the user language
* Create a multilingual '''category system'''
#*swap the entire page content shown to the user
* Create multilingual '''navigation links'''
#*customize the main navigation
#*display template and form labels to users based on their user preference. <br />
#'''Categories:''' A multilingual category system.  It is useful for:
#*users that don't speak the "main" language (the content language) of the wiki and, therefore, want to tag pages in another supported language.


==A note about MediaWiki translation extensions==
The following information gives you some suggestions for organising a wiki around its multilingual content based on the previously mentioned aspects. It does not consider using  MediaWiki extensions like [[mediawikiwiki:Extension:Translate|Translate]]  or the [[mediawikiwiki:MediaWiki_Language_Extension_Bundle|MW Language Extension Bundle]] which can be installed in multlingual wikis to enable a section-by-section translation of wiki pages.


The following information gives you some suggestions for how to  organise a wiki around its multilingual content based on these aspects. It does not consider using the MediaWiki extension [[mediawikiwiki:Extension:Translate|Translate]] which is often installed in multlingual wikis to faciliate a section-by-section translation of wiki pages. If most of your wiki content needs consistently accurate translations, this extension can be useful.
If most of your wiki content needs consistently accurate translations, these extensions can be valuable. Such a focus on translation, however, requires an understanding of how this mechanism technically works and might hinder the spontaneous contribution  to the wiki by a broad user base. In addition, these extensions are not bundled with BlueSpice and require additional administrative effort during wiki updates or upgrades.


== Importing the language switcher ==
Here, we look at techniques that support multilingual content in an easy way.  
To show that a page has different versions, it is useful to indicate this with a language switcher on each page. If you have no language switcher in your wiki, you can [[Templates download/Language switcher|download a language switcher template]]. The techniques shown in the following sections assume that this language switcher is installed.  


Be sure to read the configuration instructions on the downloads page. You need to define the languages that you want to support in the template.
== Considerations before using the subpages approach ==
Many wikis use the approach of creating language subpages of a page that is written in the wiki's main language (=content language defined during wiki installation). This is a great mechanism if we assume that the majority of content is available in the wiki's main language first. This is often the case in English wikis.  But what if there is no "main" language in a wiki - when the language(s) of many contributors do not match this content language of the wiki?


[[File:language-switcher-template.png|alt=language switcher on a wiki page|center|thumb|450x450px|language switcher on a wiki page]]
The solution in this case is often to maintain separate wikis for each language "community" and then connect the wikis via so called [[Manual:Extension/BlueSpiceInterWikiLinks|Interwiki links]]


== Creating wiki pages with translated subpages ==
=== Interwiki links used within a single wiki ===
Let's take a page called ''Vacation policy'' and create a German language version as a subpage. After saving the page ''Vacation policy/d''e and providing the content translation, we have the German translation that we wanted. As you can see in the screenshots below, the page content is always shown in the context of the user language preferences of each user. This means that the user interface elements do not necessarily correspond to the translated language. But since the user decided on this language preference, it does not negatively effect the user, but actually supports the user when navigating the wiki.
It is possible to think of each language as independent and to allow users to create pages in their preferred language. A German speaking user could create a page "Urlaubsregelung" in an English wiki. If another user creates a "matching" page "Vacation policy" in the wiki, these two pages can be connected  manually by adding interlanguage links to the page. For this purpose, wiki administrators can create the needed interwiki links. The language switcher configuration can then be switched from suppporting language subpages to consider Interwiki links instead. A combination of both subpages and Interwiki links is not supported.


<gallery widths="500" heights="350">
==Creating wiki pages with translated subpages==
File:language-subpage-de.png|alt=German content version with user language preference English.|German content version (1) with user language preference English (2).
Let's take a page called ''Vacation policy'' in a wiki with English as its content language and create a German language version.
File:language-subpage-de-uselang-de.png|alt=German content version with user language preference German.|German content version with user language preference German.
</gallery>


=== Adding the language switcher to a page ===
{{Messagebox|boxtype=note|icon=|Note text=When  working with translation subpages, it is important to know the [https://www.mediawiki.org/wiki/Manual:Language content language] of the wiki. It is the language in which the wiki has been installed. To find it out, you can add the magic word <nowiki>{{CONTENTLANGUAGE}}</nowiki> to the source view of any wiki page and save it. The page will then display the language code.|bgcolor=}}
Now that we have two language versions, we want to connect them. with the language switcher. To add the language switcher to a page:
# '''Open''' the page in edit mode.
# '''Insert''' the template ''Languages'' form the editor toolbar.
# '''Enter''' a display title for the page (recommended for subpages).[[File:language-displaytitle.png|link=https://en.wiki.bluespice.com/wiki/File:language-displaytitle.png|alt=Setting the display title|center|thumb|450x450px|Setting the display title]]The search engine will index this display title  so that the title search returns the expected result.
# '''Save''' the page.
# '''Repeat''' steps 1-4 with other language subpages (e.g, fr, nl).




The language switcher now indicates directly on a page if and what other languages are already available for that page.
[[File:languageswitcher-DE.png|alt=Language switcher shows all available translations|center|thumb|650x650px|The language switcher shows all available translations]]
#
#


== Creating page lists for different languages ==
To create a language version for the main language (=content language), a subpage with the [[wikipedia:List_of_ISO_639-1_codes|ISO-639-1]] language code as subpage name is created. This means that for the page ''Vacation policy'' in an English wiki, you need to create the subpage ''Vacation policy/de'' for the German translation.  
Over time, a wiki can have lots of these translated pages. We want to make sure that users know what pages are available in what languages. For this purpose, the language switcher template includes a custom property L''anguages/tracklang'' that allows to easily create filtered page lists for this purpose.


Working with properties requires the Semantic MediaWiki extensions, which are bundled in ''BlueSpice pro'', but not in ''BlueSpice free''. There are, however, [[Multilingual wiki#Alternative solutions in BlueSpice free|alternative approaches for creating page lists in ''BlueSpice free'']].  
As you can see in the screenshots below, the page content is always shown in the context of the user language preferences of each user. This means that the user interface elements do not necessarily correspond to the translated language. But since the user decided to use this language setting, it does not negatively affect this user, but actually supports them when navigating the wiki.


In ''BlueSpice pro,'' you can include different inline queries on any wiki page. This example lists German language pages in the main namespace  and displays them in a category-type output (A-Z listing):<syntaxhighlight lang="text">
<gallery widths="500" heights="350">
{{#ask:
File:language-subpage-de.png|alt=German content version with user language preference English.|German content version (1) with user language preference English (2).
[[:+]][[Languages/tracklang::de]]
File:language-subpage-de-uselang-de.png|alt=German content version with user language preference German.|German content version with user language preference German.
|format=category
</gallery>
}}
</syntaxhighlight>
[[File:languageswitcher-ask-result-category-de.png|alt=Results format "category"|center|thumb|450x450px|Results format "category"]]
Explanation of the arguments for this query:


* '''<nowiki>[[:+]]</nowiki>''': Returns pages only in the main namespace. To show the pages form the entire wiki, simply delete this argument.
== Connecting unrelated wiki pages instead of subpages ==
**<nowiki>[[QM::+]]</nowiki>: Returns pages from the namespace QM
If you want to relate pages in the wiki as language equivalents, the language switcher [[Reference:BlueSpiceDiscovery#Configuration|needs to be configured on the server]] to consider interwiki links instead of subpages.
**<nowiki>[[QM:+||Help:+]]</nowiki>: Returns pages from the namespaces QM and Help.
* '''<nowiki>[[Languages/tracklang::de]]</nowiki>''': Returns only pages that are marked by the language switcher template as German language pages. Other options:
**<nowiki>[[Languages/tracklang::+]]</nowiki>: Returns all language pages that are tracked in the wiki by the language switcher template.
**<nowiki>[[Languages/tracklang::!de]]</nowiki>: Returns all language pages except German pages.
**<nowiki>[[Languages/tracklang::de||fr]]</nowiki>: Returns all language pages in German and French (in the example above restricted to the main namespace.
* '''format=category''': returns a category style output.
** format=ul: returns a list style output
[[File:languageswitcher-ask-result-de.png|alt=Results format "ul"|center|thumb|250x250px|Results format "ul"]]


If you need a way to connect German and English pages on the same wiki, you need to set up the same interwiki link with a different prefix on the page ''Special:InterWikiLinks''.
[[File:interwikilinks-edit.png|alt=edit dialog for a interwiki link with the prefix "de"|center|thumb|450x450px|Setting up an interwiki link]]
The URL is always the same, the path of your wiki and the placeholder <code>$1</code> for the pagename. The prefix reflects the language: ''de''=German, ''en''=English, ''fr''=French, and so on.


To see more examples for how to define and further modify a query for creating page lists, go to our [[SMW queries|SMW-query examples]] page.
You can then connect the page "Urlaubsregelung" to the English page "Vacation policy" by adding the following interwiki link to the wikisource of the page "Urlaubsregelung":<syntaxhighlight lang="text">
[[en:Vacation policy]]
</syntaxhighlight>


== Creating portal pages based on user language settings ==
== Creating portal pages based on user language settings ==
Portal pages are pages  that serve as entry points to different topics or areas in the portal, often considering the needs of specific user groups. A typical example is the main page of the wiki, which is often used to give users a high-level orientation in the wiki. A portal page is a good place to also consider the language needs of different users.  
Portal pages are pages  that serve as entry points to different topics or areas in the portal, often considering the needs of specific user groups. A typical example is the main page of the wiki, which should give users a high-level orientation in the wiki. A portal page is a good place to take the language needs of different users into account.  


Here, we can take two different approaches:
Here, we can take two different approaches:


# Show the '''same page to all users''', but include '''some content''' that targets specific user languages.
#Show the '''same page to all users''', but include '''some content''' that targets specific user languages.
# Show completely '''separate content''' to users based on their user language.
#Show completely '''separate content''' to users based on their user language.


=== What is the user language? ===
===What is the user language?===
Wiki users  can change their own language setting in the user preferences:
Wiki users  can change their own language setting in the user preferences:
[[File:userlanguage.png|alt=User language preference|center|thumb|550x550px|User language preference]]
[[File:userlanguage.png|alt=User language preference|center|thumb|550x550px|User language preference]]
Line 94: Line 89:
To provide additional support for this setting, we can include checks on wiki pages that determine the user language and serve up additional or alternative information as needed.  
To provide additional support for this setting, we can include checks on wiki pages that determine the user language and serve up additional or alternative information as needed.  


=== Preparing the user language check ===
===Preparing the user language check===
Checking for the user language requires that we create a system message for this purpose. This needs to be done by users in the role ''admin'' or ''structuremanager'':
Checking for the user language requires that we create a system message for this purpose. This is easy to do, but needs to be done by users in the role ''admin'' or ''structuremanager.''  


# '''Create''' the page ''MediaWiki:lang w''ith the content being the language code of the content language of your wiki. If you are not sure in what language your wiki was installed, you can add the magic word <nowiki>{{CONTENTLANGUAGE}}</nowiki> to the source of any wiki page and look at its output.  If you have an English wiki, you need to add "en" as the content to this page. If your wiki is German, add "de" instead.[[File:message key-lang.png|alt=Page MediaWiki:Lang|center|thumb|650x650px|Page MediaWiki:Lang]]
To create a system message for the user language:
# '''Create''' subpages to this page for the user languages you want to support. For example in an English wiki:
#* MediaWiki:Lang/de
#* MediaWiki:Lang/fr


Now that we have the mechanism to detect the user language, we can use it in many different scenarios.
#'''Create''' the page ''MediaWiki:lang w''ith the content being the language code of the content language of your wiki. If you are not sure in what language your wiki was installed, you can add the magic word <nowiki>{{CONTENTLANGUAGE}}</nowiki> to the source of any wiki page and look at its output.  If you have an English wiki, you need to add "en" as the content to this page. If your wiki is German, add "de" instead.[[File:message key-lang.png|alt=Page MediaWiki:Lang|center|thumb|650x650px|Page MediaWiki:Lang]]
#'''Create''' subpages to this page for the user languages you want to support. For example in an English wiki:
#*MediaWiki:Lang/de
#*MediaWiki:Lang/fr


=== Displaying additional content ===
Now  we have a mechanism to detect the user language. By checking for the value of the "[[mediawikiwiki:Help:Magic_words#Localization|magic word]]" <nowiki>{{int:lang}}</nowiki> , we  can use it in many different scenarios.
To show content on a page only to users with a specific language setting, for example, German, we add the following check:<syntaxhighlight lang="text">
 
===Displaying additional content===
To show content on a page only to users with a specific language setting for example, German we can add the following check:<syntaxhighlight lang="text">
{{#ifeq: {{int:lang}}|de|show this content|}}
{{#ifeq: {{int:lang}}|de|show this content|}}
</syntaxhighlight>
</syntaxhighlight>


=== Displaying different page content ===
===Switching to different page content===
To show entirely different content to users with different language settings, you can prepare different pages and then serve them up as needed. As an example we take the homepage of the wiki.
To show entirely different content to users with different language settings, you can prepare different pages and then serve them up as needed. As an example we take the homepage of the wiki.


To display different homepage content based on user language in an English wiki, where the homepage is called ''Main Page'':
To display different homepage content based on user language in an English wiki, where the homepage is called ''Main Page'':


# Create a subpage for each language you want to support, e.g.
#Create a subpage for each language you want to support, e.g.
## Main Page/en
## Main Page/en
## Main Page/de
##Main Page/de
## Main Page/fr
## Main Page/fr
# On the page Main Page, add the following switch:<syntaxhighlight lang="text">
#On the page Main Page, add the following switch:<syntaxhighlight lang="text">
{{#switch: {{int:lang}}|de={{:Main Page/de}}|fr={{:Main Page/fr}}|{{:Main Page/en}} }}
{{#switch: {{int:lang}}|de={{:Main Page/de}}|fr={{:Main Page/fr}}|{{:Main Page/en}} }}
</syntaxhighlight>Users with language setting "de" will see the content of page ''Main Page/de'', users with "fr" language setting the page ''Main Page/fr'', all other users get the page Main ''Page/en''.
</syntaxhighlight>Users with language setting "de" will see the content of page ''Main Page/de'', users with "fr" language setting the page ''Main Page/fr'', all other users get the page Main ''Page/en''.
===Switching labels===
To show different labels or short text snippets directly on a page, we can also use the switch function:<syntaxhighlight lang="text">
{{#switch:{{int:lang}}|de=Überschrift 2|en=Heading 2}}
</syntaxhighlight>To summarize, the following main page can be accomplished in two different ways:


#By creating separate subpages for each user language and then transcluding them with a user language check on the actual Main Page.
#By loading the actual Main Page and then building the language checks into the page itself. The following picture shows examples of:
#*(1), (2) Switching headings
#*(3) Displaying query results based on the tracked language from the language switcher template (e.g., <nowiki>[[Languages/tracklang::en]]</nowiki>)
#*(4) Switching display labels in templates (this can also be applied to page forms)
#*(5) Switching image captions
[[File:usrelanguage-switchlabels.png|alt=Content based on user language settings|center|thumb|750x750px|Content based on user language settings]]
===Switching template and form labels===
As the previous screenshot shows, labels in templates (and forms) can also be shown based on user language. You can simply add the switch function directly in the template. The  template ''Template:Contactinfo'' collects street, zip and city info:<syntaxhighlight lang="text">
{| class="wikitable"
! {{#switch:{{int:lang}}|en=Street|de=Straße}}
| {{{street|}}}
|-
! {{#switch:{{int:lang}}|en=Zip|de=PLZ}}
| {{{zip|}}}
|-
! {{#switch:{{int:lang}}|en=City|de=Stadt}}
| {{{city|}}}
|}
</syntaxhighlight>It displays the different labels as needed:<gallery widths="180" heights="100">
File:uselang-template-en.png|alt=English labels|English labels
File:uselang-template-de.png|alt=German labels|German labels
</gallery>
==Multilingual navigation==
Currently, there is no easy mechanism to create multilingual navigation menus, such as the main navigation or the custom menu. More support should be coming in one of the next minor releases of BlueSpice (4.2 or 4.3). In the meantime, you can create [[Manual:Extension/BlueSpiceDiscovery/Main navigation/Language support|individual links based on a user's language settings]].
==Multilingual categories==
An important aspect of organizing content is a well-designed category system for your wiki. By tagging your content, you support both the search functionality and the possibility of creating context-based page lists in all kinds of variations.
One way to accomplish this is to work with a prefix system that associates the different language categories.
For example, for the category Application, you would use (in an English wiki) the English category ''APP Application'' and the German category ''APPde Anwendung''. They would have a subcategory APP SAP (English subcategory) and APPde SAP (German subcategory).
[[File:multilingual-categories.png|alt=Multilingual category tree|center|thumb|550x550px|Multilingual category tree]]
===Creating a root category first===
It is also a good idea to start your category system with a single root category:
[[File:rootcategory.png|alt=Starting with a root category|center|thumb|250x250px|Starting with a root category]]
This allows you to later manage your category system without entangling it with other unrelated categories that might be created by users. Besides your category system, other types of categories might coexist:
*[[mediawikiwiki:Help:Categories#Hidden_categories|Hidden categories]]
*[[mediawikiwiki:Help:Tracking_categories|Tracking categories]]
*Informal tagging-categories created by users "on-the-go"
===Querying pages by language categories===
To find the pages in a particular language and in a particular category, we can now use our multilingual category system. For example, we can show all pages in the English category ''DOC Process description:''<syntaxhighlight lang="text">
{{#ask: [[Category:DOC Process description]] [[Modification date::+]]
|format=Category
}}


=== Switching labels ===
To show different labels or short text snippets, you can also use the switch function:<syntaxhighlight lang="text">
{{#switch:{{int:lang}}|de=Überschrift 2|en=Heading 2}}
</syntaxhighlight>
</syntaxhighlight>
{{Messagebox|boxtype=note|icon=|Note text=To avoid deleted pages showing up in your results list, you can add the property <nowiki>[[Modification date::+]]</nowiki> to any of your queries.|bgcolor=}}




== Multilingual navigation ==
[[de:Mehrsprachiges Wiki]]
Currently, there is no easy mechanism to create multilingual navigation menus, such as the main navigation or the custom menu. More support should be coming in one of the next minor releases of BlueSpice (4.1.3 or 4.1.4). In the meantime, you can create [[Manual:Extension/BlueSpiceDiscovery/Main navigation/Language support|individual links based on a user's language settings]].
[[Category:Translation]]
 
== Alternative solutions in BlueSpice free ==
[[Category:Multilingual wiki]]

Latest revision as of 17:15, 19 December 2023

word cloud with translations of the greeting "hello"

A wiki can be set up to include different language versions for wiki pages. Wiki administrators have to make some decisions regarding how they want to support each wiki user's language setting in addition to simply providing translated page content.

The following considerations refer to a single-wiki scenario in BlueSpice free or pro and don't apply if the language versions are maintained in separate wikis.

Concepts

To make a single wiki multilingual, you can:

  • Create wiki pages with automatically linked translation subpages

In addition, depending on your wiki setup, it is possible to create:

  • multilingual navigation links
  • flexible page lists for each language
  • portal pages based on user language
  • template and form labels based on user language
  • a multilingual category system

Techniques

globe icon with submenu links to English and French translations
language switcher
Content based on user language settings
Content based on user language
Multilingual category tree
Multilingual category tree

The explanations on this page use the following techniques, which we will look at in more detail:

  1. Automatic language switcher:
    • The wiki automatically adds a language switcher to a page that has at least one language subpage.
  2. User language: A simple mechanism to determine which language a user has defined in their personal settings. It provides options to:
    • show or hide content based on the user language
    • swap the entire page content shown to the user
    • customize the main navigation
    • display template and form labels to users based on their user preference.
  3. Categories: A multilingual category system. It is useful for:
    • users that don't speak the "main" language (the content language) of the wiki and, therefore, want to tag pages in another supported language.

A note about MediaWiki translation extensions

The following information gives you some suggestions for organising a wiki around its multilingual content based on the previously mentioned aspects. It does not consider using MediaWiki extensions like Translate or the MW Language Extension Bundle which can be installed in multlingual wikis to enable a section-by-section translation of wiki pages.

If most of your wiki content needs consistently accurate translations, these extensions can be valuable. Such a focus on translation, however, requires an understanding of how this mechanism technically works and might hinder the spontaneous contribution to the wiki by a broad user base. In addition, these extensions are not bundled with BlueSpice and require additional administrative effort during wiki updates or upgrades.

Here, we look at techniques that support multilingual content in an easy way.

Considerations before using the subpages approach

Many wikis use the approach of creating language subpages of a page that is written in the wiki's main language (=content language defined during wiki installation). This is a great mechanism if we assume that the majority of content is available in the wiki's main language first. This is often the case in English wikis. But what if there is no "main" language in a wiki - when the language(s) of many contributors do not match this content language of the wiki?

The solution in this case is often to maintain separate wikis for each language "community" and then connect the wikis via so called Interwiki links.

Interwiki links used within a single wiki

It is possible to think of each language as independent and to allow users to create pages in their preferred language. A German speaking user could create a page "Urlaubsregelung" in an English wiki. If another user creates a "matching" page "Vacation policy" in the wiki, these two pages can be connected manually by adding interlanguage links to the page. For this purpose, wiki administrators can create the needed interwiki links. The language switcher configuration can then be switched from suppporting language subpages to consider Interwiki links instead. A combination of both subpages and Interwiki links is not supported.

Creating wiki pages with translated subpages

Let's take a page called Vacation policy in a wiki with English as its content language and create a German language version.

Note:When working with translation subpages, it is important to know the content language of the wiki. It is the language in which the wiki has been installed. To find it out, you can add the magic word {{CONTENTLANGUAGE}} to the source view of any wiki page and save it. The page will then display the language code.



To create a language version for the main language (=content language), a subpage with the ISO-639-1 language code as subpage name is created. This means that for the page Vacation policy in an English wiki, you need to create the subpage Vacation policy/de for the German translation.

As you can see in the screenshots below, the page content is always shown in the context of the user language preferences of each user. This means that the user interface elements do not necessarily correspond to the translated language. But since the user decided to use this language setting, it does not negatively affect this user, but actually supports them when navigating the wiki.

Connecting unrelated wiki pages instead of subpages

If you want to relate pages in the wiki as language equivalents, the language switcher needs to be configured on the server to consider interwiki links instead of subpages.

If you need a way to connect German and English pages on the same wiki, you need to set up the same interwiki link with a different prefix on the page Special:InterWikiLinks.

edit dialog for a interwiki link with the prefix "de"
Setting up an interwiki link

The URL is always the same, the path of your wiki and the placeholder $1 for the pagename. The prefix reflects the language: de=German, en=English, fr=French, and so on.

You can then connect the page "Urlaubsregelung" to the English page "Vacation policy" by adding the following interwiki link to the wikisource of the page "Urlaubsregelung":

[[en:Vacation policy]]

Creating portal pages based on user language settings

Portal pages are pages that serve as entry points to different topics or areas in the portal, often considering the needs of specific user groups. A typical example is the main page of the wiki, which should give users a high-level orientation in the wiki. A portal page is a good place to take the language needs of different users into account.

Here, we can take two different approaches:

  1. Show the same page to all users, but include some content that targets specific user languages.
  2. Show completely separate content to users based on their user language.

What is the user language?

Wiki users can change their own language setting in the user preferences:

User language preference
User language preference

Depending on this setting, users then see the user interface elements in that language as we have seen in previous screenshots. This applies to interface elements that already have translated system messages.

To provide additional support for this setting, we can include checks on wiki pages that determine the user language and serve up additional or alternative information as needed.

Preparing the user language check

Checking for the user language requires that we create a system message for this purpose. This is easy to do, but needs to be done by users in the role admin or structuremanager.

To create a system message for the user language:

  1. Create the page MediaWiki:lang with the content being the language code of the content language of your wiki. If you are not sure in what language your wiki was installed, you can add the magic word {{CONTENTLANGUAGE}} to the source of any wiki page and look at its output. If you have an English wiki, you need to add "en" as the content to this page. If your wiki is German, add "de" instead.
    Page MediaWiki:Lang
    Page MediaWiki:Lang
  2. Create subpages to this page for the user languages you want to support. For example in an English wiki:
    • MediaWiki:Lang/de
    • MediaWiki:Lang/fr

Now we have a mechanism to detect the user language. By checking for the value of the "magic word" {{int:lang}} , we can use it in many different scenarios.

Displaying additional content

To show content on a page only to users with a specific language setting — for example, German — we can add the following check:

{{#ifeq: {{int:lang}}|de|show this content|}}

Switching to different page content

To show entirely different content to users with different language settings, you can prepare different pages and then serve them up as needed. As an example we take the homepage of the wiki.

To display different homepage content based on user language in an English wiki, where the homepage is called Main Page:

  1. Create a subpage for each language you want to support, e.g.
    1. Main Page/en
    2. Main Page/de
    3. Main Page/fr
  2. On the page Main Page, add the following switch:
    {{#switch: {{int:lang}}|de={{:Main Page/de}}|fr={{:Main Page/fr}}|{{:Main Page/en}} }}
    
    Users with language setting "de" will see the content of page Main Page/de, users with "fr" language setting the page Main Page/fr, all other users get the page Main Page/en.

Switching labels

To show different labels or short text snippets directly on a page, we can also use the switch function:

{{#switch:{{int:lang}}|de=Überschrift 2|en=Heading 2}}

To summarize, the following main page can be accomplished in two different ways:

  1. By creating separate subpages for each user language and then transcluding them with a user language check on the actual Main Page.
  2. By loading the actual Main Page and then building the language checks into the page itself. The following picture shows examples of:
    • (1), (2) Switching headings
    • (3) Displaying query results based on the tracked language from the language switcher template (e.g., [[Languages/tracklang::en]])
    • (4) Switching display labels in templates (this can also be applied to page forms)
    • (5) Switching image captions
Content based on user language settings
Content based on user language settings

Switching template and form labels

As the previous screenshot shows, labels in templates (and forms) can also be shown based on user language. You can simply add the switch function directly in the template. The template Template:Contactinfo collects street, zip and city info:

{| class="wikitable"
! {{#switch:{{int:lang}}|en=Street|de=Straße}}
| {{{street|}}}
|-
! {{#switch:{{int:lang}}|en=Zip|de=PLZ}}
| {{{zip|}}}
|-
! {{#switch:{{int:lang}}|en=City|de=Stadt}}
| {{{city|}}}
|}

It displays the different labels as needed:

Multilingual navigation

Currently, there is no easy mechanism to create multilingual navigation menus, such as the main navigation or the custom menu. More support should be coming in one of the next minor releases of BlueSpice (4.2 or 4.3). In the meantime, you can create individual links based on a user's language settings.

Multilingual categories

An important aspect of organizing content is a well-designed category system for your wiki. By tagging your content, you support both the search functionality and the possibility of creating context-based page lists in all kinds of variations.

One way to accomplish this is to work with a prefix system that associates the different language categories.

For example, for the category Application, you would use (in an English wiki) the English category APP Application and the German category APPde Anwendung. They would have a subcategory APP SAP (English subcategory) and APPde SAP (German subcategory).

Multilingual category tree
Multilingual category tree

Creating a root category first

It is also a good idea to start your category system with a single root category:

Starting with a root category
Starting with a root category

This allows you to later manage your category system without entangling it with other unrelated categories that might be created by users. Besides your category system, other types of categories might coexist:

Querying pages by language categories

To find the pages in a particular language and in a particular category, we can now use our multilingual category system. For example, we can show all pages in the English category DOC Process description:

{{#ask: [[Category:DOC Process description]] [[Modification date::+]]
|format=Category
}}
Note:To avoid deleted pages showing up in your results list, you can add the property [[Modification date::+]] to any of your queries.



To submit feedback about this documentation, visit our community forum.

Discussions