Skip to content

Rails plugin for localized "country_select" helper with Rake task for downloading locales from Unicode.org's CLDR

License

Notifications You must be signed in to change notification settings

intellum/localized_country_select

 
 

Repository files navigation

Why forking?

The original gem (github.com/railmlitwiniuk/localized_country_select) was not maintained anymore.

It was using some deprecated urls to download country names from Unicode.org’s CLDR repository, and was not compatible with Ruby 3. So I made a few changes and now works as expected.

LocalizedCountrySelect

Rails plugin to provide support for localized <select> menu with country names and for storing country information as country code (eg. ‘es’), not name (eg. ‘Spain’), in the database.

Uses the Rails internationalization framework (I18n, rails-i18n.org) for translating the names of countries. Requires Rails 2.2 (released November 21st, 2008) or later versions. Country names are loaded from hashes in plugin directory, according to I18n.locale value.

You can easily translate country codes in your application like this:

<%= I18n.t @user.country, :scope => 'countries' %>

Comes with a Rake task rails import:country_select LOCALE=de for importing country names from Unicode.org’s CLDR repository (www.unicode.org/cldr/data/charts/summary/root.html) Don’t forget to restart the application when you add new locale.

ActionView helper code is adapted from Rails’ default country_select plugin (previously in core). See github.com/rails/country_select/tree/master/lib/country_select.rb

Rails 5 / Rails 6

In your Gemfile add:

gem 'localized_country_select', '>= 0.10.2'

Rails 3 / Rails 4

In your Gemfile add:

gem 'localized_country_select', '= 0.9.11'

Rails 2.3

No longer supported, but you can still use old version of gem. In environment.rb add

config.gem 'localized_country_select', :version => '0.0.1'

Example

Show full country names:

<%= localized_country_select(:user, :country, [], {include_blank: 'Please choose...'}) %>

will become:

<select name="user[country]" id="user_country">
<option value="">Please choose...</option>
<option disabled="disabled" value="">-------------</option>
<option value="AF">Afghanistan</option>
...
<option value="ZW">Zimbabwe</option>
</select>

Show only country codes:

<%= localized_country_select(:user, :country, [], {include_blank: 'Please choose...', description: :abbreviated}) %>

will become:

<select name="user[country]" id="user_country">
<option value="">Please choose...</option>
<option disabled="disabled" value="">-------------</option>
<option value="AF">AF</option>
...
<option value="ZW">ZW</option>
</select>

for the en locale.

You can exclude countries by code using the exclude option (a single code or an array of country codes):

localized_country_select(:user, :country, [], {exclude: [:ZZ, :US]})

Formtastic and SimpleForm

Gem supports (via alias_method) both formtastic and simple_form :country input

Other resources

Copyright © 2008 Karel Minarik (www.karmi.cz), released under the MIT license

About

Rails plugin for localized "country_select" helper with Rake task for downloading locales from Unicode.org's CLDR

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Ruby 100.0%