Как обсуждалось здесь ( Вопрос: Какие еще слои данных мы можем показать на карте? ) Я реализовал (# 3719) новый метод поиска ближайших людей по заданной широте, долготе и тегу (необязательно).
Код находится здесь: https://github.com/publiclab/plots2/blob/master/app/services/search_service.rb#L118 -L146
def tagNearbyPeople(query, tag, limit = 10)
raise("Must separate coordinates with ,") unless query.include? ","
lat, lon = query.split(',')
user_locations = User.where('rusers.status <> 0')\
.joins(:user_tags)\
.where('value LIKE ?', 'lat:' + lat[0..lat.length - 2] + '%')\
.distinct
if tag.present?
user_locations = User.joins(:user_tags)\
.where('user_tags.value LIKE ?', tag)\
.where(id: user_locations.select("rusers.id"))
end
ids = user_locations.collect(&:id).uniq || []
items = User.where('rusers.status <> 0').joins(:user_tags)
.where('rusers.id IN (?) AND value LIKE ?', ids, 'lon:' + lon[0..lon.length - 2] + '%')
# selects the items whose node_tags don't have the location:blurred tag
items.select do |item|
item.user_tags.none? do |user_tag|
user_tag.name == "location:blurred"
end
end
items = items.limit(limit)
end
Теперь, в качестве следующего шага, нам нужно изменить метод, чтобы отсортировать результаты по крайней мере по самой последней регистрации.
Метод search_profiles()
сортирует результаты по последним пользователям, я думаю, здесь можно использовать ту же стратегию.
Потрясающие !!!
@milaaraujo, я могу поработать над этим?
Конечно, просто назначьте проблему себе!