58 lines
3 KiB
Ruby
58 lines
3 KiB
Ruby
|
require 'twitter/place'
|
||
|
require 'twitter/request'
|
||
|
require 'twitter/rest/utils'
|
||
|
require 'twitter/trend_results'
|
||
|
|
||
|
module Twitter
|
||
|
module REST
|
||
|
module Trends
|
||
|
include Twitter::REST::Utils
|
||
|
|
||
|
# Returns the top 10 trending topics for a specific WOEID
|
||
|
#
|
||
|
# @see https://dev.twitter.com/docs/api/1.1/get/trends/place
|
||
|
# @rate_limited Yes
|
||
|
# @authentication Requires user context
|
||
|
# @raise [Twitter::Error::Unauthorized] Error raised when supplied user credentials are not valid.
|
||
|
# @param id [Integer] The {https://developer.yahoo.com/geo/geoplanet Yahoo! Where On Earth ID} of the location to return trending information for. WOEIDs can be retrieved by calling {Twitter::REST::Trends#trends_available}. Global information is available by using 1 as the WOEID.
|
||
|
# @param options [Hash] A customizable set of options.
|
||
|
# @option options [String] :exclude Setting this equal to 'hashtags' will remove all hashtags from the trends list.
|
||
|
# @return [Array<Twitter::Trend>]
|
||
|
def trends(id = 1, options = {})
|
||
|
options[:id] = id
|
||
|
response = get('/1.1/trends/place.json', options).body.first
|
||
|
Twitter::TrendResults.new(response)
|
||
|
end
|
||
|
alias_method :local_trends, :trends
|
||
|
alias_method :trends_place, :trends
|
||
|
|
||
|
# Returns the locations that Twitter has trending topic information for
|
||
|
#
|
||
|
# @see https://dev.twitter.com/docs/api/1.1/get/trends/available
|
||
|
# @rate_limited Yes
|
||
|
# @authentication Requires user context
|
||
|
# @raise [Twitter::Error::Unauthorized] Error raised when supplied user credentials are not valid.
|
||
|
# @param options [Hash] A customizable set of options.
|
||
|
# @return [Array<Twitter::Place>]
|
||
|
def trends_available(options = {})
|
||
|
perform_with_objects(:get, '/1.1/trends/available.json', options, Twitter::Place)
|
||
|
end
|
||
|
alias_method :trend_locations, :trends_available
|
||
|
|
||
|
# Returns the locations that Twitter has trending topic information for, closest to a specified location.
|
||
|
#
|
||
|
# @see https://dev.twitter.com/docs/api/1.1/get/trends/closest
|
||
|
# @rate_limited Yes
|
||
|
# @authentication Requires user context
|
||
|
# @raise [Twitter::Error::Unauthorized] Error raised when supplied user credentials are not valid.
|
||
|
# @param options [Hash] A customizable set of options.
|
||
|
# @option options [Float] :lat If provided with a :long option the available trend locations will be sorted by distance, nearest to furthest, to the co-ordinate pair. The valid ranges for latitude are -90.0 to +90.0 (North is positive) inclusive.
|
||
|
# @option options [Float] :long If provided with a :lat option the available trend locations will be sorted by distance, nearest to furthest, to the co-ordinate pair. The valid ranges for longitude are -180.0 to +180.0 (East is positive) inclusive.
|
||
|
# @return [Array<Twitter::Place>]
|
||
|
def trends_closest(options = {})
|
||
|
perform_with_objects(:get, '/1.1/trends/closest.json', options, Twitter::Place)
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
end
|