Sha256: cbce777e920df98ac53d98064c5286b4adbcb889ac604cca61fe18d9b79e1e80

Contents?: true

Size: 1.66 KB

Versions: 1

Compression:

Stored size: 1.66 KB

Contents

module Barometer
  #
  # Format: Coordinates
  #
  # eg. 123.1234,-123.123
  #
  # This class is used to determine if a query is a
  # :coordinates and how to convert to :coordinates.
  #
  class Query::Format::Coordinates < Query::Format

    def self.format; :coordinates; end
    def self.regex; /^[-]?[0-9\.]+[,]{1}\s?[-]?[0-9\.]+$/; end
    def self.convertable_formats
      [:short_zipcode, :zipcode, :postalcode, :weather_id, :coordinates, :icao, :geocode, :woe_id]
    end

    # convert to this format, X -> :coordinates
    #
    def self.to(original_query)
      raise ArgumentError unless is_a_query?(original_query)
      return nil unless converts?(original_query)
      converted_query = Barometer::Query.new

      # pre-convert
      #
      pre_query = nil
      if original_query.format == :weather_id
        unless pre_query = original_query.get_conversion(Query::Format::Geocode.format)
          pre_query = Query::Format::WeatherID.reverse(original_query)
          original_query.post_conversion(pre_query)
        end
      elsif original_query.format == :woe_id
        pre_query = Query::Format::WoeID.reverse(original_query)
      end

      # convert & adjust
      #
      converted_query = Query::Format::Geocode.geocode(pre_query || original_query)
      converted_query.q = converted_query.geo.coordinates if converted_query.geo
      converted_query.format = format

      converted_query
    end

    def self.parse_latitude(query)
      coordinates = query.to_s.split(',')
      coordinates ? coordinates[0] : nil
    end

    def self.parse_longitude(query)
      coordinates = query.to_s.split(',')
      coordinates ? coordinates[1] : nil
    end

  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
barometer-0.8.0 lib/barometer/formats/coordinates.rb