FEATURE: query param for topic state

This commit is contained in:
Sam 2014-07-17 09:29:09 +10:00
parent cc5152e962
commit 189b1c729a
4 changed files with 27 additions and 10 deletions

View File

@ -1,6 +1,6 @@
Discourse.DiscoverySortableController = Discourse.Controller.extend({ Discourse.DiscoverySortableController = Discourse.Controller.extend({
needs: ['discovery/topics'], needs: ['discovery/topics'],
queryParams: ['order', 'ascending', 'status'], queryParams: ['order', 'ascending', 'status', 'state', 'search'],
order: Em.computed.alias('controllers.discovery/topics.order'), order: Em.computed.alias('controllers.discovery/topics.order'),
ascending: Em.computed.alias('controllers.discovery/topics.ascending'), ascending: Em.computed.alias('controllers.discovery/topics.ascending'),
status: Em.computed.alias('controllers.discovery/topics.status') status: Em.computed.alias('controllers.discovery/topics.status')

View File

@ -4,7 +4,9 @@ export default function(filter) {
queryParams: { queryParams: {
sort: { replace: true }, sort: { replace: true },
ascending: { replace: true }, ascending: { replace: true },
status: { replace: true } status: { replace: true },
state: { replace: true },
search: { replace: true }
}, },
beforeModel: function() { beforeModel: function() {
@ -19,10 +21,11 @@ export default function(filter) {
Discourse.ScreenTrack.current().stop(); Discourse.ScreenTrack.current().stop();
var findOpts = {}; var findOpts = {};
if (params && params.order) { findOpts.order = params.order; } if(params){
if (params && params.ascending) { findOpts.ascending = params.ascending; } _.keys(this.queryParams).forEach(function(opt) {
if (params && params.status) { findOpts.status = params.status; } if (params[opt]) { findOpts[opt] = params[opt]; }
});
}
return Discourse.TopicList.list(filter, findOpts).then(function(list) { return Discourse.TopicList.list(filter, findOpts).then(function(list) {
var tracking = Discourse.TopicTrackingState.current(); var tracking = Discourse.TopicTrackingState.current();
@ -36,10 +39,9 @@ export default function(filter) {
setupController: function(controller, model, trans) { setupController: function(controller, model, trans) {
controller.setProperties({ controller.setProperties(Em.getProperties(trans, _.keys(this.queryParams).map(function(v){
order: Em.get(trans, 'queryParams.order'), return 'queryParams.' + v;
ascending: Em.get(trans, 'queryParams.ascending') })));
});
var period = filter.indexOf('/') > 0 ? filter.split('/')[1] : '', var period = filter.indexOf('/') > 0 ? filter.split('/')[1] : '',
filterText = I18n.t('filters.' + filter.replace('/', '.') + '.title', {count: 0}); filterText = I18n.t('filters.' + filter.replace('/', '.') + '.title', {count: 0});

View File

@ -270,6 +270,7 @@ class ListController < ApplicationController
min_posts: params[:min_posts], min_posts: params[:min_posts],
max_posts: params[:max_posts], max_posts: params[:max_posts],
status: params[:status], status: params[:status],
state: params[:state],
search: params[:search] search: params[:search]
} }
options[:no_subcategories] = true if params[:no_subcategories] == 'true' options[:no_subcategories] = true if params[:no_subcategories] == 'true'

View File

@ -23,6 +23,7 @@ class TopicQuery
no_subcategories no_subcategories
no_definitions no_definitions
status status
state
search search
).map(&:to_sym) ).map(&:to_sym)
@ -265,6 +266,19 @@ class TopicQuery
result = result.where("topics.id in (select pp.topic_id from post_search_data pd join posts pp on pp.id = pd.post_id where pd.search_data @@ #{Search.ts_query(search.to_s)})") result = result.where("topics.id in (select pp.topic_id from post_search_data pd join posts pp on pp.id = pd.post_id where pd.search_data @@ #{Search.ts_query(search.to_s)})")
end end
# NOTE protect against SYM attack can be removed with Ruby 2.2
#
state = options[:state]
if @user && state &&
TopicUser.notification_levels.keys.map(&:to_s).include?(state)
level = TopicUser.notification_levels[state.to_sym]
result = result.where('topics.id IN (
SELECT topic_id
FROM topic_users
WHERE user_id = ? AND
notification_level = ?)', @user.id, level)
end
if status = options[:status] if status = options[:status]
case status case status
when 'open' when 'open'