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