Solidus Internationalization
This is the Internationalization project for Solidus
Changes in Version 2.0
solidus_i18n Version 2.0+ only contains translation files.
Previous versions of solidus_i18n included extra functionality like locale
selectors and which is now built in to Solidus 2.6+. Configuration for
routing-filter
has also been removed and must be configured manually
(See Locale in URL).
Installation
Add the following to your Gemfile
:
gem 'solidus_i18n', '~> 2.0'
gem 'rails-i18n', '~> 5.1'
gem 'kaminari-i18n', '~> 0.5.0'
Locale in URL
Older versions of solidus_i18n included the routing-filter gem and configured routes to include the locale in the URL. This is still supported (maybe even recommended) but requires some additional configuration.
- Add this gem to your
Gemfile
, then runbundle install
gem 'routing-filter', '~> 0.6.0'
- Add
filter :locale
to yourconfig/routes.rb
Rails.application.routes.draw do
filter :locale
mount Spree::Core::Engine, at: '/'
end
- Configure routing-fitler in
config/initializers/locale_filter.rb
(optional)
# Do not include the default locale in the URL
RoutingFilter::Locale.include_default_locale = false
Supported languages
We currently support the following locales by default. If you need a locale that is not in the list you can add a custom translation file into your application by following the Rails translations guide.
Updating Translations
If you want to improve the translations on your language, run the tasks:
bundle exec rake solidus_i18n:update_default
bundle exec i18n-tasks add-missing --nil-value --locale <LOCALE>
Substitute it
).
This will do a cleanup and prepare <LOCALE>.yml
with all the missing keys.
You can then write the translations and open a pull request.
Model Translations
We removed support for translating models into a separate Gem.
Please update your Gemfile
if you still need the model translations.
# Gemfile
gem 'solidus_globalize', github: 'solidusio-contrib/solidus_globalize', branch: 'master'
Localizing country names
You can translate country names by defining spree.country_names
in your own locale files. For example, to have countries in Spanish do:
es:
spree:
country_names:
US: Estados Unidos de América
UK: Reino Unido
CA: Canadá
# ...
Some supported languages already define localized country names. Take a look at this repo's .yml
files for your locale to confirm if we already provide translations.
Contributing
Solidus is an open source project and we encourage contributions. Please read CONTRIBUTING.md before contributing.