Developers can define new or remove a defined language through the locale configuration file. The resource is managed by org.exoplatform.services.resources.LocaleConfigService as follows:
<component>
<key>org.exoplatform.services.resources.LocaleConfigService</key>
<type>org.exoplatform.services.resources.impl.LocaleConfigServiceImpl</type>
<init-params>
<value-param>
<name>locale.config.file</name>
<value>war:/conf/common/locales-config.xml</value>
</value-param>
</init-params>
</component>
All languages defined in the locale-config.xml
file are listed in the
Interface Language Settings
window. The resource bundle is managed by org.exoplatform.services.resources.ResourceBundleService
as follows:
<external-component-plugins>
<!-- The full qualified name of the ResourceBundleService -->
<target-component>org.exoplatform.services.resources.ResourceBundleService</target-component>
<component-plugin>
<!-- The name of the plugin -->
<name>Sample ResourceBundle Plugin</name>
<!-- The name of the method to call on the ResourceBundleService in order to register the ResourceBundles -->
<set-method>addResourceBundle</set-method>
<!-- The full qualified name of the BaseResourceBundlePlugin -->
<type>org.exoplatform.services.resources.impl.BaseResourceBundlePlugin</type>
<init-params>
<!--values-param>
<name>classpath.resources</name>
<description>The resources that start with the following package name should be load from file system</description>
<value>locale.portlet</value>
</values-param-->
<values-param>
<name>init.resources</name>
<description>Store the following resources into the db for the first launch</description>
<value>locale.portal.sample</value>
</values-param>
<values-param>
<name>portal.resource.names</name>
<description>The properties files of the portal , those files will be merged
into one ResourceBundle properties
</description>
<value>locale.portal.sample</value>
</values-param>
</init-params>
</component-plugin>
</external-component-plugins>
To add a new language, you need to copy the default locale-config.xml
file
from platform-extension/WEB-INF/conf/common/locales-config.xml
to your custom-extension.war
(with the same path) and add the corresponding language entry.
For example, to add Italian, do as follows:
Add the following code to the locale-config.xml
file under your extension project.
<locale-config>
<locale>it</locale>
<output-encoding>UTF-8</output-encoding>
<input-encoding>UTF-8</input-encoding>
<description>Default configuration for Italian locale</description>
</locale-config>
Create a new resource bundle as sample_it.properties
in
the custom-extension.war!/WEB-INF/classes/locale/portal
folder or in the src/main/resources/locale/portal
folder of the source code if you are using Maven.
This step is necessary because the Resource Bundle Service of the portal will find keys and values in the resource bundle of each corresponding language.
Restart the server.
To check if the added language takes effect, click your username on the top navigation bar and click Change Language. In the Interface Language Settings window that appears, you will see the Italian is listed as below:
To remove an existing language, you need to delete the relevant language code in the
locale-config.xml
file and all files containing the suffix name as the key of language.
For example, to remove French, do as follows:
Find and remove the following code from the locale-config.xml
file under your extension project.
<locale-config>
<locale>fr</locale>
<output-encoding>UTF-8</output-encoding>
<input-encoding>UTF-8</input-encoding>
<description>Default configuration for france locale</description>
</locale-config>
Continue removing all resource bundle files containing the suffix name as fr in all folders.
It is recommended this step be done to delete unnecessary data in the application.
Restart the server.
To check if French is removed, hover your cursor over your username on the top navigation bar, then click Change Language.
In the Interface Language Settings window that appears, French is no longer listed.