diaspora/lib/stream/soup.rb
2011-10-14 14:23:18 -07:00

56 lines
1.4 KiB
Ruby

class Stream::Soup < Stream::Base
def link(opts)
Rails.application.routes.url_helpers.soup_path
end
def title
I18n.t('streams.soup.title')
end
def contacts_title
I18n.t('streams.soup.contacts_title')
end
def posts
@posts ||= lambda do
post_ids = aspect_posts_ids + followed_tag_ids + mentioned_post_ids
post_ids += featured_user_post_ids
Post.where(:id => post_ids).for_a_stream(max_time, order)
end.call
end
def ajax_stream?
false
end
private
def aspect_posts_ids
@aspect_posts_ids ||= user.visible_post_ids(:limit => 15, :order => "#{order} DESC", :max_time => max_time, :all_aspects? => true, :by_members_of => aspect_ids)
end
def followed_tag_ids
@followed_tag_ids ||= ids(StatusMessage.tag_stream(user, tag_array, max_time, order))
end
def mentioned_post_ids
@mentioned_post_ids ||= ids(StatusMessage.where_person_is_mentioned(user.person).for_a_stream(max_time, order))
end
def featured_user_post_ids
@featured_user_post_ids ||= ids(Post.all_public.where(:author_id => featured_user_ids).for_a_stream(max_time, order))
end
#worthless helpers
def featured_user_ids
Person.featured_users.select('id').map{|x| x.id}
end
def tag_array
user.followed_tags.select('name').map{|x| x.name}
end
def ids(enumerable)
Post.connection.select_values(enumerable.select('posts.id').to_sql)
end
end