Setting up a Multilingual site in Joomla 5 -January 2025
Introduction
Before attempting to setup jDownloads as multilingual it is of course necessary to set up Joomla as a mulilingual.
This article just describes setting up Joomla as multilingual.
As from Joomla 4.3.4 setting up a multi-language version of Joomla has been made even simpler. A click on a link sets up all the required multilingual items. Further it also generates examples of multilingual menus and content.
The ablity to add extra languages to Joomla has been available for a long time. Obviously when viewing content such as articles in a particular language one does not wish to see the articles from other languages mixed up in the list. And of course there needs to be a simple way for users to dynamically select the relevant language. Again most sites are public so language selection cannot require being logged in.
To meet these needs a multilingual site needs a menu for each language. Also for content each language needs a matching article category, and each language needs matching articles. Also the relevant categories and articles need to be associating accross languages. For example if we have an article Category called 'Articles en français' whose language setting is French and another one called 'Articles in English' then the two article Categories need to be associated. The same applies to the relevant articles themselves.
Doing this is not difficult but it is very tedious setting up this infrastructure and sometimes challenging getting it right if you are doing this for the first time.
Aditiononally one needs to set up the 'language plugins'. Again not difficult but easily missed.
But now adding the multilanguage menus, example multilingual categories and multilingual articles, and activating the relevant plugins is available from a button! This article takes you through the steps of the automation process.
This article just describes setting up Joomla as multilingual.
As from Joomla 4.3.4 setting up a multi-language version of Joomla has been made even simpler. A click on a link sets up all the required multilingual items. Further it also generates examples of multilingual menus and content.
The ablity to add extra languages to Joomla has been available for a long time. Obviously when viewing content such as articles in a particular language one does not wish to see the articles from other languages mixed up in the list. And of course there needs to be a simple way for users to dynamically select the relevant language. Again most sites are public so language selection cannot require being logged in.
To meet these needs a multilingual site needs a menu for each language. Also for content each language needs a matching article category, and each language needs matching articles. Also the relevant categories and articles need to be associating accross languages. For example if we have an article Category called 'Articles en français' whose language setting is French and another one called 'Articles in English' then the two article Categories need to be associated. The same applies to the relevant articles themselves.
Doing this is not difficult but it is very tedious setting up this infrastructure and sometimes challenging getting it right if you are doing this for the first time.
Aditiononally one needs to set up the 'language plugins'. Again not difficult but easily missed.
But now adding the multilanguage menus, example multilingual categories and multilingual articles, and activating the relevant plugins is available from a button! This article takes you through the steps of the automation process.
Install Joomla
Joomla is installed in just three simple steps:
1. Select the installation language and the name of the site as shown opposite. Then click ondata:image/s3,"s3://crabby-images/252a2/252a20e94e1bfd042ecec4a9178682d2c46f6fe0" alt="V4 button setup login data"
data:image/s3,"s3://crabby-images/7b861/7b8614c1b9ed73c09a60c4e466bb673a16ce84a4" alt="V4 install01"
1. Select the installation language and the name of the site as shown opposite. Then click on
data:image/s3,"s3://crabby-images/252a2/252a20e94e1bfd042ecec4a9178682d2c46f6fe0" alt="V4 button setup login data"
data:image/s3,"s3://crabby-images/7b861/7b8614c1b9ed73c09a60c4e466bb673a16ce84a4" alt="V4 install01"
2. Set up login data as shown opposite then click on
data:image/s3,"s3://crabby-images/13289/13289e3b9e713afc3d73f90fac32d0d0c76dfc6d" alt="V4 setup login data"
data:image/s3,"s3://crabby-images/ad573/ad5732bc073cf04cca03b08b02e0488a0358e795" alt="V4 button setup database connection"
data:image/s3,"s3://crabby-images/13289/13289e3b9e713afc3d73f90fac32d0d0c76dfc6d" alt="V4 setup login data"
3. Finally set the Database configuration as shown opposite. Then click on data:image/s3,"s3://crabby-images/841e3/841e3156bcb67e88253255f981f988b2c5c879c5" alt="v4 button install joomla"
data:image/s3,"s3://crabby-images/4b6e2/4b6e29e77a412b3f682a6c4581565f7d32ccd246" alt="install02"
data:image/s3,"s3://crabby-images/841e3/841e3156bcb67e88253255f981f988b2c5c879c5" alt="v4 button install joomla"
data:image/s3,"s3://crabby-images/4b6e2/4b6e29e77a412b3f682a6c4581565f7d32ccd246" alt="install02"
Whislt Joomla is being installed there are several 'progress' messages.
When done you get a 'Joomla site is ready' message together with the opportunity to install additional languages.
So click on the
button to start the process.
Note if you are installing on XAMPP or similar then you may get a warning as below about the installation folder:
Just remove the installation folder manually.
data:image/s3,"s3://crabby-images/0fbf7/0fbf76aa7277c7f54b284994fc1444dd3c76e488" alt="install04"
When done you get a 'Joomla site is ready' message together with the opportunity to install additional languages.
So click on the
data:image/s3,"s3://crabby-images/6421c/6421cafd1d6d16fe9c3456afc6f648b0199bd880" alt="button additional languages"
Note if you are installing on XAMPP or similar then you may get a warning as below about the installation folder:
data:image/s3,"s3://crabby-images/cb49c/cb49cd521a1bb94fcfa1106e34a6318c6ab5d305" alt="error deleting install folder"
data:image/s3,"s3://crabby-images/0fbf7/0fbf76aa7277c7f54b284994fc1444dd3c76e488" alt="install04"
Add Additional Languages
After clicking on the
button a list of all the available languages is shown as illustrated opposite.
Tick the the box,
, alongside the required languages. Then scroll to the bottom of the list and click in the
button.
Again on XAMPP you may get a message such as
.
If you miss the initial 'Add Languages' or decide to add an extra language later then go to
and in the
section click on
This allows you to add the relevant Joomla! content languages.data:image/s3,"s3://crabby-images/d9b49/d9b496482b2cd947a0abeaf73b60d191170f9ed5" alt="addlang 01"
data:image/s3,"s3://crabby-images/197bc/197bc9cfec862533ca04aa23ecb15399195dc612" alt="three dotsA"
data:image/s3,"s3://crabby-images/da821/da821083a633eedf276cd85de4eb372059e38869" alt="addlang 02"
data:image/s3,"s3://crabby-images/6421c/6421cafd1d6d16fe9c3456afc6f648b0199bd880" alt="button additional languages"
Tick the the box,
data:image/s3,"s3://crabby-images/5504c/5504c2dde6c46124af74476490632c3003c36ea6" alt="tick box"
data:image/s3,"s3://crabby-images/2c803/2c803a596c4011bcfdd53d05f215100c4d0a262d" alt="button install selected langs"
Again on XAMPP you may get a message such as
data:image/s3,"s3://crabby-images/f96cf/f96cf6c74d8c98c2f03cff7efc3998c714be06d1" alt="install later msg"
If you miss the initial 'Add Languages' or decide to add an extra language later then go to
data:image/s3,"s3://crabby-images/322d8/322d8d78750e706852ac264b57cc6d50352e37a6" alt="V4 button system"
data:image/s3,"s3://crabby-images/4cda9/4cda981b43c00108c178fe7c7fc77167979cd7ab" alt="V4 button manage tab"
data:image/s3,"s3://crabby-images/722c2/722c28e26720bc1689516ca8c8acfc597b2b67b9" alt="V4 button content lang"
data:image/s3,"s3://crabby-images/d9b49/d9b496482b2cd947a0abeaf73b60d191170f9ed5" alt="addlang 01"
data:image/s3,"s3://crabby-images/197bc/197bc9cfec862533ca04aa23ecb15399195dc612" alt="three dotsA"
data:image/s3,"s3://crabby-images/da821/da821083a633eedf276cd85de4eb372059e38869" alt="addlang 02"
In this example three extra languages were added, giving four in total. This makes the illustration of setting up a multilingual site more realistic.
Arabic wasa choosen as one of the languages because it is a 'right to left' language.
To proceed click on the
data:image/s3,"s3://crabby-images/a92b6/a92b69a76ac521c8ef33bee29f00bcd35ab3b4f3" alt="button open admin"
If you are installing on XAMPP or similar then you may get a warning as below:
data:image/s3,"s3://crabby-images/cb49c/cb49cd521a1bb94fcfa1106e34a6318c6ab5d305" alt="error deleting install folder"
Just remove the installation folder manually. And click on the
data:image/s3,"s3://crabby-images/a92b6/a92b69a76ac521c8ef33bee29f00bcd35ab3b4f3" alt="button open admin"
You will be asked to login
data:image/s3,"s3://crabby-images/8a34e/8a34e734a75ef773d679c08df73b9c03cee1b285" alt="install06"
Setup Multilingual site
1. Publish Languages
Go to
and in the
section select '
'.
Publish the required languages by clicking on the relevant
.data:image/s3,"s3://crabby-images/1a749/1a7492dd5f44b601f718279adca39260700e107f" alt="languages publish"
data:image/s3,"s3://crabby-images/322d8/322d8d78750e706852ac264b57cc6d50352e37a6" alt="V4 button system"
data:image/s3,"s3://crabby-images/4cda9/4cda981b43c00108c178fe7c7fc77167979cd7ab" alt="V4 button manage tab"
data:image/s3,"s3://crabby-images/722c2/722c28e26720bc1689516ca8c8acfc597b2b67b9" alt="V4 button content lang"
Publish the required languages by clicking on the relevant
data:image/s3,"s3://crabby-images/ee04f/ee04f30c48e9fa7f6010cae05f58443c569140f6" alt="cross unpublished"
data:image/s3,"s3://crabby-images/1a749/1a7492dd5f44b601f718279adca39260700e107f" alt="languages publish"
2.Install Multilingual Sample Data
Select the
and find the Multilingual Sampe Data panel as shown opposite. Click on Install. data:image/s3,"s3://crabby-images/84726/84726d6b49c7d9621634cc86d99eada2855ccf08" alt="Multiling sample data"
data:image/s3,"s3://crabby-images/54e60/54e60590998b048354b89983c0010246a313a3cd" alt="V4 button Home Dashboard"
data:image/s3,"s3://crabby-images/84726/84726d6b49c7d9621634cc86d99eada2855ccf08" alt="Multiling sample data"
This then shows a panel such as opposite. So click on the
button.
This will go through several steps and when done it will return to the Home menu. At the top of the view there will be a message
data:image/s3,"s3://crabby-images/c1377/c1377035c3ba30fc1de902277d7e842ce9266ec9" alt="msg sample data installed"
data:image/s3,"s3://crabby-images/0569c/0569c450c17bd1ff875ff1e6f8db625b8855d55e" alt="install sample data"
data:image/s3,"s3://crabby-images/43638/43638b6727122a0c2178d96974a0d748dea6e4a0" alt="V4 button ok"
This will go through several steps and when done it will return to the Home menu. At the top of the view there will be a message
data:image/s3,"s3://crabby-images/c1377/c1377035c3ba30fc1de902277d7e842ce9266ec9" alt="msg sample data installed"
data:image/s3,"s3://crabby-images/0569c/0569c450c17bd1ff875ff1e6f8db625b8855d55e" alt="install sample data"
3.Content Language Plugins Enabled
To see these go to the
menu and in the
section select
. In the Search Bar select 'Language'. This will show three plugins as illustrated opposite.
Enable the 'System - Language Code' plugin as it is shows which languages are installed
The 'System - Language Filter' filters the displayed content so that only the current language items are included.
The 'Web Services - Langages' plugin adds language routes to the API for your website.data:image/s3,"s3://crabby-images/db8a6/db8a6c25c91d8bde3c66b031559329ca9e0b662e" alt="system lang plugins"
data:image/s3,"s3://crabby-images/322d8/322d8d78750e706852ac264b57cc6d50352e37a6" alt="V4 button system"
data:image/s3,"s3://crabby-images/4cda9/4cda981b43c00108c178fe7c7fc77167979cd7ab" alt="V4 button manage tab"
data:image/s3,"s3://crabby-images/ff657/ff6576ae196e35ef38afc4ce2a5e0aba7dbb053e" alt="V4 button plugins"
Enable the 'System - Language Code' plugin as it is shows which languages are installed
The 'System - Language Filter' filters the displayed content so that only the current language items are included.
The 'Web Services - Langages' plugin adds language routes to the API for your website.
data:image/s3,"s3://crabby-images/db8a6/db8a6c25c91d8bde3c66b031559329ca9e0b662e" alt="system lang plugins"
4.Menus
A main menu is created for each language as ilustrated opposite.
The relevant menu and its associated module is shown in the front end in the 'side bar right' position.
There is also a 'regular' Main Menu. This needs to have a menu item 'List All Categories'
as it is used by jDownloads just as a 'single language' site.
data:image/s3,"s3://crabby-images/520f4/520f478df15358127c44ad5971d8340aa7fd2154" alt="created menus site"
5.Example Categories
The system creates a sample Article Category for each language.
The language is of course set appropriately.
More significantly each category has been Associated with the relevant other language categories.
data:image/s3,"s3://crabby-images/7da75/7da75eaf39673744a476577dda73fd6de735ca8e" alt="created article categs"
The language is of course set appropriately.
More significantly each category has been Associated with the relevant other language categories.
data:image/s3,"s3://crabby-images/7da75/7da75eaf39673744a476577dda73fd6de735ca8e" alt="created article categs"
6.Example Articles
Similarly example multilingual aricles, one for each language, are created.
Again the language has been set and the articles are associated as shown opposite.
data:image/s3,"s3://crabby-images/96e3d/96e3d71e9849bc7b88b4ddb30fb9f6e22492881e" alt="created article examples"
Again the language has been set and the articles are associated as shown opposite.
data:image/s3,"s3://crabby-images/96e3d/96e3d71e9849bc7b88b4ddb30fb9f6e22492881e" alt="created article examples"
7.Language Switcher - Frontend
As part of the multilingual facilites, a language switcher module is created with the default front end location as position sidebar-right. This shows the 'flags' of the available languages
. The current language is English as indicated by the faintly highlighted back ground. There are several parameters that you can adjust to suit your needs. The main use is to allow the User to select their own language and to rapidly switch between languages.
data:image/s3,"s3://crabby-images/602f7/602f7fde394ccc74479028d767d7fd4acda61fdb" alt="front end language switcher module"
The front end will now look something like the image shown opposite.
data:image/s3,"s3://crabby-images/c3892/c3892e8ca997990690deb8182a8646fb8c229e39" alt="front end view"
ColinM 21 September 2023, modified Feb 2024, November 2024, January 2025