-
Notifications
You must be signed in to change notification settings - Fork 161
Language Apps
The purpose of Language Apps is to translate all customizable interface text strings into a different language. Such text strings include buttons, menu items, alerts, forms, page block titles, email templates and so forth. Every installed language in UNA is under control of the Polyglot system app where you can add new language keys or edit the existing ones. By default, the English and Russian language apps are available in UNA.
You can use the Polyglot app to make small edits, but when it comes to editing hundreds of language strings, working in Polyglot will become tedious and time consuming. In this case, creating a copy of an existing language app will be a more straightforward process. Follow these steps to create a copy of the English app:
-
Use your favorite FTP manager to navigate to the English app location, which is modules/boonex/english. Download the whole folder to your local computer. Alternatively, you can download the zipped version of the app from the UNA Market (if you know the exact app version), and then unzip it.
-
Edit the file install/config.php. Here you will have to change some member values of the
$aConfig
array. All the suggested values here are optional. The goal here is to use something different and unique.-
vendor
-> change the value to your own name, for exampleJohn Doe
-
name
-> change the value tojohndoe_en
-
title
-> change the value toEnglish (Custom)
-
help_url
-> change the value to your own URL, for examplehttp://mysite.com
-
home_dir
-> change the value tojohndoe/english/
-
home_uri
-> change the value toen1
-
db_prefix
-> change the value tojohndoe_eng_
-
class_prefix
-> change the value toJohnDoeEng
-
language_category
-> change the value toJohn Doe English
Save the file.
-
-
Edit the file install/langs/en.xml:
- inside the resources tag change the following attribute value:
-
title
-> change the value toJohn Doe English
-
-
_bx_eng_wgt_cpt
-> change to_johndoe_eng_wgt_cpt
-
_bx_eng_stg_cpt_type
-> change to_johndoe_eng_stg_cpt_type
-
_bx_eng_stg_cpt_category_system
-> change to_johndoe_eng_stg_cpt_category_system
In other words, you will need to replace the default db_prefix
bx_eng_
with your custom onejohndoe_eng_
.You may also want to change the string values inside the
![CDATA[]]
tags in this file but it is not necessary.Save the file.
- inside the resources tag change the following attribute value:
-
Now you need to edit the module's utility SQL files which will be used to install, uninstall, enable and disable your module in the Studio. Edit the following files and their contents:
-
install/sql/install.sql
- search for
bx_en
and replace all the occurences withjohndoe_en
- search for
'en'
and replace all the occurences with'en1'
- search for
modules/boonex/english
and replace all the occurences withmodules/johndoe/english
- search for
-
install/sql/uninstall.sql, install/sql/enable.sql, install/sql/disable.sql
- search for
bx_en
and replace all the occurences withjohndoe_en
- search for
'en'
and replace all the occurences with'en1'
- search for
Also change the module's installation file install/installer.php
- replace
BxEngInstaller
withJohnDoeEngInstaller
Save the files.
-
install/sql/install.sql
-
Now it's time to edit the language strings themselves. Rename the file data/langs/system/en.xml to en1.xml and edit it:
-
inside the resources tag change the following attribute values:
-
name
-> change the value toen1
-
title
-> change the value toJohn Doe English
-
-
change the values for the language strings you wish to edit. Change only the values of
<![CDATA[]]>
tags. For example:old string:
<![CDATA[Message was successfully sent.]]>
new string:
<![CDATA[Hooray! Message was successfully sent.]]>
Save the file.
-
-
If you want to provide translations for modules other than system, create folders in the folder data/langs with the names corresponding to the modules names, for example data/langs/bx_accounts. Copy the English language file for the module and put it inside the newly created folder with the new name en1. Module's language files are located in the folder install/langs inside a module's folder, for example modules/boonex/accounts/install/langs/en.xml. Return to the step 5) to change the contents of the new file.
-
Now you can upload the results on the server.
- Create the folder johndoe inside the modules folder
- Upload the whole english folder from your local computer to the johndoe folder on the server.
-
Go to Studio -> Apps Market -> Downloaded and install your new language app from there.
When creating a new language app, you can slightly modify the steps used for the custom English language with some additions. Follow the steps below using the French language file as an example.
-
Use your favorite FTP manager to navigate to the English app location, which is modules/boonex/english. Download the whole folder to your local computer. Alternatively, you can download the zipped version of the app from the UNA Market (if you know the exact app version), and then unzip it. Rename the folder english to french.
-
Edit the file install/config.php. Here you will have to change some member values of the
$aConfig
array. All the suggested values here are optional. The goal here is to use something different and unique-
vendor
-> change the value to your own name, for exampleVendor
-
name
-> change the value tovendor_fr
-
title
-> change the value toFrench
-
help_url
-> change the value to your own URL, for examplehttp://mysite.com
-
home_dir
-> change the value tovendor/french/
-
home_uri
-> change the value tofr
-
db_prefix
-> change the value tovendor_fr_
-
class_prefix
-> change the value toVendorFr
-
language_category
-> change the value toFrench
Save the file.
-
-
Edit the file install/langs/en.xml (use some editor which supports UTF-8 without BOM, such as Notepad++):
- inside the resources tag change the following attribute value:
-
title
-> change the value toFrench
-
-
_bx_eng_wgt_cpt
-> change to_vendor_fr_wgt_cpt
-
_bx_eng_stg_cpt_type
-> change to_vendor_fr_stg_cpt_type
-
_bx_eng_stg_cpt_category_system
-> change to_vendor_fr_stg_cpt_category_system
In other words, you will need to replace the default db_prefix
bx_eng_
with your custom onevendor_fr_
.Also change the string values inside the
![CDATA[]]
tags in this file, for example:old string:
<![CDATA[French]]>
new string:
<![CDATA[Français]]>
Save the file.
- inside the resources tag change the following attribute value:
-
Now you need to edit the module's utility SQL files which will be used to install, uninstall, enable and disable your module in the Studio. Edit the following files and their contents:
-
install/sql/install.sql
- search for
bx_en
and replace all the occurences withvendor_fr
- for 2 letters code use ISO 639-1 standard and some abbreviation for your or your organization name - search for
'en'
and replace all the occurencies with'fr'
- search for
modules/boonex/english
and replace all the occurences withmodules/vendor/french
- search for
-
install/sql/uninstall.sql, install/sql/enable.sql, install/sql/disable.sql
- search for
bx_en
and replace all the occurences withvendor_fr
- search for
'en'
and replace all the occurences with'fr'
- search for
Also change the module's installation file install/installer.php
- replace
BxEngInstaller
withVendorFrInstaller
Save the files.
-
install/sql/install.sql
-
Now it's time to edit the language strings themselves. Rename the file data/langs/system/en.xml to fr.xml and edit it (use some editor which supports UTF-8 without BOM, such as Notepad++):
-
inside the resources tag change the following attribute values:
-
name
-> change the value tofr
-
title
-> change the value toFrench
-
flag
-> change the value tofr
-
-
change the values for the language strings you wish to edit. Change only the values of
<![CDATA[]]>
tags. For example:old string:
<![CDATA[Message was successfully sent.]]>
new string:
<![CDATA[Le message a été envoyé avec succès.]]>
Save the file.
-
-
If you want to provide translations for modules other than system, create folders in the folder data/langs with the names corresponding to the modules names, for example data/langs/bx_accounts. Copy the English language file for the module and put it inside the newly created folder with the new name fr. A module's language files are usually located in the folder install/langs. Return to step 5) to change the contents of the new file.
NOTE: Most of these steps can be automated with a special script which copies all english xml files to one place. In your server's console, navigate to the UNA installation folder and type phing package_all_langs (phing binary must be installed). This way you will have all of the language files in the packages/en folder. Then copy files from the packages/en folder to the french/data/langs/ folder. Then you will need to repeat step 6) to translate all of the files.
NOTE: to get translations for all modules refer to the UNA GitHub repository.
NOTE: it's possible to rename all of the files in data/langs folder using the following MAC OSX command:
find . -name en.xml | while read f; do mv -v "$f" "$(echo "$f" | sed -e 's/en.xml/fr.xml/')"; done
NOTE: it's possible to search and replace strings in the data/langs folder files using the following MAC OSX commands:
find . -name fr.xml -exec sed -i '' 's/name="en"/name="fr"/g' {} \;
find . -name fr.xml -exec sed -i '' 's/flag="gb"/flag="fr"/g' {} \;
find . -name fr.xml -exec sed -i '' 's/title="English"/title="French"/g' {} \;
-
Change images in the template/images/icons folder by using the following guide and PSD template to create a new one. Please use flag picture - instructions on how to create module icon.
-
Now you can upload the results on the server.
- Create the folder vendor inside the modules folder
- Upload the whole french folder from your local computer to the vendor folder on the server.
-
Go to Studio -> Apps Market -> Downloaded and install your new language app from there.
-
When a new version of UNA is released, you need to update the module and add/remove/change some language keys. The list of changed language keys can be found in the English module update files. You can also use it as a template to create own language module update. For example, here is the list of changes from 9.0.0 to 9.0.1 for English language. For how to write an upgrade script for the module, refer to the following doc: Creating app auto update script.
-
To package the module, run the following from your UNA root folder (it requires build.xml file which is in the UNA repository):
/path/to/phing package_module -Dvendor=your_vendor_folder_name -Dmodule=your_module_folder_name
A ZIP file for the module will appear in the /packages/ folder in your UNA root directory.
IMPORTANT NOTE: documentation was moved here - https://una.io/wiki/Introduction