Sha256: e1db3fe3171fd2754923582bcb5c352fc2a3bd4453571a4433e92291594724de
Contents?: true
Size: 1.39 KB
Versions: 2
Compression:
Stored size: 1.39 KB
Contents
class String # Usage: # "+31 (0)30 1234 123".phony_normalized # => '31301234123' # "(0)30 1234 123".phony_normalized # => '301234123' # "(0)30 1234 123".phony_normalized(country_code: 'NL') # => '301234123' def phony_normalized(options = {}) normalize_country_code = options.delete(:country_code) PhonyRails.normalize_number(self, :default_country_code => normalize_country_code.to_s) end # Add a method to the String class so we can easily format phone numbers. # This enables: # "31612341234".phony_formatted # => '06 12341234' # "31612341234".phony_formatted(:spaces => '-') # => '06-12341234' # To first normalize a String use: # "010-12341234".phony_formatted(:normalize => :NL) # To return nil when a number is not correct (checked using Phony.plausible?) use # "010-12341234".phony_formatted(strict: true) def phony_formatted(options = {}) normalize_country_code = options.delete(:normalize) s = (normalize_country_code ? PhonyRails.normalize_number(self, :default_country_code => normalize_country_code.to_s) : self.gsub(/\D/, '')) return if s.blank? return if options[:strict] && !Phony.plausible?(s) Phony.format(s, options.reverse_merge(:format => :national)) end # The bang method def phony_formatted!(options = {}) replace(self.phony_formatted(options)) end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
phony_rails-0.9.0 | lib/phony_rails/string_extensions.rb |
phony_rails-0.8.2 | lib/phony_rails/string_extensions.rb |