Remove duplication of action defintion, add missing spec for topics_by, extract out URL construction logic
This commit is contained in:
parent
243a6ae291
commit
7dfa99998f
|
@ -10,7 +10,7 @@ class ListController < ApplicationController
|
||||||
list_opts = build_topic_list_options
|
list_opts = build_topic_list_options
|
||||||
user = list_target_user
|
user = list_target_user
|
||||||
list = TopicQuery.new(user, list_opts).public_send("list_#{filter}")
|
list = TopicQuery.new(user, list_opts).public_send("list_#{filter}")
|
||||||
list.more_topics_url = url_for(self.public_send "#{filter}_path".to_sym, list_opts.merge(format: 'json', page: next_page))
|
list.more_topics_url = construct_url_with(filter, list_opts)
|
||||||
if [:latest, :hot].include?(filter)
|
if [:latest, :hot].include?(filter)
|
||||||
@description = SiteSetting.site_description
|
@description = SiteSetting.site_description
|
||||||
@rss = filter
|
@rss = filter
|
||||||
|
@ -33,45 +33,17 @@ class ListController < ApplicationController
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def topics_by
|
[:topics_by, :private_messages, :private_messages_sent, :private_messages_unread].each do |action|
|
||||||
list_opts = build_topic_list_options
|
define_method("#{action}") do
|
||||||
list = TopicQuery.new(current_user, list_opts).list_topics_by(fetch_user_from_params)
|
list_opts = build_topic_list_options
|
||||||
list.more_topics_url = url_for(topics_by_path(list_opts.merge(format: 'json', page: next_page)))
|
target_user = fetch_user_from_params
|
||||||
|
guardian.ensure_can_see_private_messages!(target_user.id) unless action == :topics_by
|
||||||
respond(list)
|
list = generate_list_for(action.to_s, target_user, list_opts)
|
||||||
end
|
url_prefix = "topics" unless action == :topics_by
|
||||||
|
url = construct_url_with(action, list_opts, url_prefix)
|
||||||
def private_messages
|
list.more_topics_url = url_for(url)
|
||||||
list_opts = build_topic_list_options
|
respond(list)
|
||||||
target_user = fetch_user_from_params
|
end
|
||||||
guardian.ensure_can_see_private_messages!(target_user.id)
|
|
||||||
|
|
||||||
list = TopicQuery.new(current_user, list_opts).list_private_messages(target_user)
|
|
||||||
list.more_topics_url = url_for(topics_private_messages_path(list_opts.merge(format: 'json', page: next_page)))
|
|
||||||
|
|
||||||
respond(list)
|
|
||||||
end
|
|
||||||
|
|
||||||
def private_messages_sent
|
|
||||||
list_opts = build_topic_list_options
|
|
||||||
target_user = fetch_user_from_params
|
|
||||||
guardian.ensure_can_see_private_messages!(target_user.id)
|
|
||||||
|
|
||||||
list = TopicQuery.new(current_user, list_opts).list_private_messages_sent(target_user)
|
|
||||||
list.more_topics_url = url_for(topics_private_messages_sent_path(list_opts.merge(format: 'json', page: next_page)))
|
|
||||||
|
|
||||||
respond(list)
|
|
||||||
end
|
|
||||||
|
|
||||||
def private_messages_unread
|
|
||||||
list_opts = build_topic_list_options
|
|
||||||
target_user = fetch_user_from_params
|
|
||||||
guardian.ensure_can_see_private_messages!(target_user.id)
|
|
||||||
|
|
||||||
list = TopicQuery.new(current_user, list_opts).list_private_messages_unread(target_user)
|
|
||||||
list.more_topics_url = url_for(topics_private_messages_unread_path(list_opts.merge(format: 'json', page: next_page)))
|
|
||||||
|
|
||||||
respond(list)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def category
|
def category
|
||||||
|
@ -98,7 +70,6 @@ class ListController < ApplicationController
|
||||||
raise Discourse::InvalidParameters.new('Category RSS of "uncategorized"') if request_is_for_uncategorized?
|
raise Discourse::InvalidParameters.new('Category RSS of "uncategorized"') if request_is_for_uncategorized?
|
||||||
|
|
||||||
guardian.ensure_can_see!(@category)
|
guardian.ensure_can_see!(@category)
|
||||||
|
|
||||||
discourse_expires_in 1.minute
|
discourse_expires_in 1.minute
|
||||||
|
|
||||||
@title = @category.name
|
@title = @category.name
|
||||||
|
@ -176,4 +147,14 @@ class ListController < ApplicationController
|
||||||
current_user
|
current_user
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def generate_list_for(action, target_user, opts)
|
||||||
|
list = TopicQuery.new(current_user, opts)
|
||||||
|
list = list.send("list_#{action}", target_user)
|
||||||
|
end
|
||||||
|
|
||||||
|
def construct_url_with(action, opts, url_prefix=nil)
|
||||||
|
method = url_prefix.blank? ? "#{action}_path" : "#{url_prefix}_#{action}_path"
|
||||||
|
public_send(method, opts.merge(format: 'json', page: next_page))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -133,6 +133,15 @@ describe ListController do
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "topics_by" do
|
||||||
|
let!(:user) { log_in }
|
||||||
|
|
||||||
|
it "should respond with a list" do
|
||||||
|
xhr :get, :topics_by, username: @user.username
|
||||||
|
response.should be_success
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
context "private_messages" do
|
context "private_messages" do
|
||||||
let!(:user) { log_in }
|
let!(:user) { log_in }
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue