Module: PhonyRails
- Defined in:
- lib/phony_rails.rb,
lib/phony_rails/version.rb
Defined Under Namespace
Modules: ActiveRecordExtension
Constant Summary collapse
- VERSION =
"0.1.12"
Class Method Summary collapse
- .country_number_for(country_code) ⇒ Object
-
.normalize_number(number, options = {}) ⇒ Object
This method requires a country_code attribute (eg. NL) and phone_number to be set.
Class Method Details
.country_number_for(country_code) ⇒ Object
9 10 11 |
# File 'lib/phony_rails.rb', line 9 def self.country_number_for(country_code) ISO3166::Country::Data[country_code].try(:[], 'country_code') end |
.normalize_number(number, options = {}) ⇒ Object
This method requires a country_code attribute (eg. NL) and phone_number to be set. Options:
:country_code => The country code we should use.
:default_country_code => Some fallback code (eg. 'NL') that can be used as default (comes from phony_normalize_numbers method).
This idea came from:
http://www.redguava.com.au/2011/06/rails-convert-phone-numbers-to-international-format-for-sms/
19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
# File 'lib/phony_rails.rb', line 19 def self.normalize_number(number, = {}) return if number.nil? number = number.clone # Just to be sure, we don't want to change the original. number.gsub!(/[^\d\+]/, '') # Strips weird stuff from the number return if number.blank? if country_number = country_number_for([:country_code] || [:default_country_code]) # Add country_number if missing number = "#{country_number}#{number}" if not number =~ /^(00|\+)?#{country_number}/ end number = Phony.normalize(number) return number.to_s rescue number # If all goes wrong .. we still return the original input. end |