Developer Support
Localize Your App
4 min read
·
Last updated on Jan 20, 2023
Localizing your app is a great way to get more users. We have over 220 million users worldwide – and many of them aren’t native English speakers.
To appeal to and benefit more users around the world, we strongly recommend offering your app in at least one language other than English. This can help you get more users, earn higher ratings, and convert more users to paid plans.
The five most common languages of Wix users are:
- English
- Spanish
- Portuguese
- Russian
- French
Getting started
- Localize your app’s UI: This involves a variety of tasks – translating the UI strings in your app, modifying dates and times, adjusting layouts, and more. Refer to the design tips below.
- Match your app’s language to the user’s language: When the user first installs your app, display your UI in the language the user defined in their language/regional preferences.
- Let users customize your app for their target audience (website components only): Add these options to your App Settings panel:
- Allow users to choose the language that’s suitable for their target audience – add a dropdown with a list of languages (the user’s language preference might be different from the language used in the live site).
- Allow users to change text elements and other regional settings (like measurements).
4. Translate your market listing: Increase your app’s reach by speaking to users in their own language.
5. Translate your app component name: Help users to understand your app components with a description in their language.
Design tips
- Make sure any text-based UI elements are designed with plenty of space to accommodate other languages. You should allow for up to 30% more space than the text your default language requires.
- If your UI can't accommodate text in one of your target languages, you can create an alternative layout for that language only.
- Keep in mind that in different locations, different symbols and formats are used for dates, times, numbers, currencies, etc. For example, February 1, 2023 will be 1/2/23 in Europe but 2/1/23 in the U.S.
- It's important to have a default set of resources available so that if you get a request to load your app in a location that you don't support, you'll have a fallback and your app won't crash. We suggest that you use English as the fallback language.
Provide localized support
If your app is supported in a certain language, users may ask for your help in that language. We recommend engaging with users in their native language, or if that’s not possible, in a common language. If your app becomes popular in a specific language, consider hiring a native-language speaker for that language to ensure textual accuracy and to provide user support.
Implementation
- Match your app’s language to the user’s language: When the user first installs your app, detect the user’s language (it’s defined in their language/regional preferences).
- Server-side rendering: use the locale parameter, which is one of the query parameters we pass over to you when we call your app’s endpoint.
- Using the SDK: use the Utils.getLocale method to decide which set of strings to use in your App Settings.
- When building your app, we suggest managing all of the UI strings in one place and not adding any hardcoded strings to your code. For example:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
<!DOCTYPE html> <html> <head> <script type="text/javascript"> // Managing the UI strings in one place var langs = { "en" : { "title": "My Title", "text": "My Text" }, "es" : { "title": "Mi Título", "text": "Mi Texto" }, "pt" : { "title": "Meu Título", "text": "Meu Texto" }, "fr" : { "title": "Mon Titre", "text": "Mon Texte" }, }; // Changing the locale in the App Settings var locale = Wix.Utils.getLocale() || 'en'; // English is the default language var localeStrings = langs[locale] || langs['en']; // Replacing the the UI elements with the correct text for (var id in localeStrings) { $('#' + id).text(localeStrings[id]); } </script> </head> <body> <div> <h4 id="title">Default Title</h4> <p id="text">Default Text</p> </div> </body> </html>
Was this article helpful?