Sha256: 9e89cf3d17bdae6a7ace39cc39c270f6a735ac9fb05aba02f3b14c9d694a3662

Contents?: true

Size: 1.51 KB

Versions: 1

Compression:

Stored size: 1.51 KB

Contents

require 'vrbo/class_methods'

module VRBO
  class Calendar
    extend ClassMethods

    attr_accessor :id, :available_dates, :days

    def initialize(calendar_id = nil)
      @id = calendar_id || VRBO.config.calendar_id
      @days = {}
      @available_dates = []
    end

    def available?(arrival, depart, my_dates = nil)
      dates = my_dates || available_dates
      available = dates.any?
      arrival.upto(depart - 1).each do |date|
        available = false unless dates.include?(date.to_s)
      end
      available
    end

    def find_all_available_dates
      today = Date.today
      @available_dates = today.upto(today + 365).map { |date| date_if_available(date) }.compact
    end

    def date_if_available(date)
      m = date.month.to_s
      days[m] ||= collect_days_for_month(date)
      date.to_s if days[m].include?(date.day.to_s)
    end

    def collect_days_for_month(date)
      scrape_table_for(date).map { |cell| cell.children.to_s.strip }
    end

    def scrape_table_for(date)
      calendar.search('.cal-month').at(table_xpath(date)).search('td:not(.strike)')
    end

    def calendar
      @calendar ||= agent.get(calendar_url)
    end

    def agent
      @agent ||= Mechanize.new
    end

    def calendar_url
      if id
        "http://www.vrbo.com/#{id}/calendar"
      else
        raise ArgumentError, 'You must provide a calendar id'
      end
    end

    # March 2014
    def table_xpath(date)
      "//b[contains(text(), '#{date.strftime('%B %Y')}')]/following-sibling::table"
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
vrbo-0.2.0 lib/vrbo/calendar.rb