Added new sorting for "Hot" in GroupCollection, GroupTimeline
• Added: - new sorting for "Hot" in GroupCollection, GroupTimeline
This commit is contained in:
@@ -33,6 +33,7 @@ class Api::V1::Timelines::GroupCollectionController < Api::BaseController
|
||||
def set_sort_type
|
||||
@sort_type = 'newest'
|
||||
@sort_type = params[:sort_by] if [
|
||||
'hot',
|
||||
'newest',
|
||||
'recent',
|
||||
'top_today',
|
||||
@@ -43,7 +44,7 @@ class Api::V1::Timelines::GroupCollectionController < Api::BaseController
|
||||
].include? params[:sort_by]
|
||||
|
||||
if @collection_type === 'featured' && (@sort_type == 'newest' || @sort_type == 'recent')
|
||||
@sort_type = 'top_today'
|
||||
@sort_type = 'hot'
|
||||
end
|
||||
|
||||
return @sort_type
|
||||
@@ -72,7 +73,12 @@ class Api::V1::Timelines::GroupCollectionController < Api::BaseController
|
||||
date_limit = 30.days.ago
|
||||
top_order = 'status_stats.favourites_count DESC, status_stats.reblogs_count DESC, status_stats.replies_count DESC'
|
||||
|
||||
if @sort_type == 'top_today'
|
||||
if @sort_type == 'hot'
|
||||
# : todo :
|
||||
# unique groups
|
||||
# unique users
|
||||
date_limit = 8.hours.ago
|
||||
elsif @sort_type == 'top_today'
|
||||
date_limit = 24.hours.ago
|
||||
elsif @sort_type == 'top_weekly'
|
||||
date_limit = 7.days.ago
|
||||
@@ -99,7 +105,7 @@ class Api::V1::Timelines::GroupCollectionController < Api::BaseController
|
||||
limit_param(DEFAULT_STATUSES_LIMIT),
|
||||
params_slice(:max_id, :since_id, :min_id)
|
||||
).reject { |status| FeedManager.instance.filter?(:home, status, current_account.id) }
|
||||
elsif ['top_today', 'top_weekly', 'top_monthly', 'top_yearly', 'top_all_time'].include? @sort_type
|
||||
elsif ['top_today', 'top_weekly', 'top_monthly', 'top_yearly', 'top_all_time', 'hot'].include? @sort_type
|
||||
if @sort_type == 'top_all_time'
|
||||
statuses = Status.unscoped.where(
|
||||
group: @groupIds, reply: false
|
||||
@@ -133,7 +139,7 @@ class Api::V1::Timelines::GroupCollectionController < Api::BaseController
|
||||
limit_param(DEFAULT_STATUSES_LIMIT),
|
||||
params_slice(:max_id, :since_id, :min_id)
|
||||
)
|
||||
elsif ['top_today', 'top_weekly', 'top_monthly', 'top_yearly', 'top_all_time'].include? @sort_type
|
||||
elsif ['top_today', 'top_weekly', 'top_monthly', 'top_yearly', 'top_all_time', 'hot'].include? @sort_type
|
||||
if @sort_type == 'top_all_time'
|
||||
statuses = Status.unscoped.where(
|
||||
group: @groupIds, reply: false
|
||||
|
||||
@@ -22,6 +22,7 @@ class Api::V1::Timelines::GroupController < Api::BaseController
|
||||
def set_sort_type
|
||||
@sort_type = 'newest'
|
||||
@sort_type = params[:sort_by] if [
|
||||
'hot',
|
||||
'newest',
|
||||
'recent',
|
||||
'top_today',
|
||||
@@ -52,7 +53,12 @@ class Api::V1::Timelines::GroupController < Api::BaseController
|
||||
date_limit = 30.days.ago
|
||||
top_order = 'status_stats.favourites_count DESC, status_stats.reblogs_count DESC, status_stats.replies_count DESC'
|
||||
|
||||
if @sort_type == 'top_today'
|
||||
if @sort_type == 'hot'
|
||||
# : todo :
|
||||
# unique groups
|
||||
# unique users
|
||||
date_limit = 8.hours.ago
|
||||
elsif @sort_type == 'top_today'
|
||||
date_limit = 24.hours.ago
|
||||
elsif @sort_type == 'top_weekly'
|
||||
date_limit = 7.days.ago
|
||||
@@ -79,7 +85,7 @@ class Api::V1::Timelines::GroupController < Api::BaseController
|
||||
limit_param(DEFAULT_STATUSES_LIMIT),
|
||||
params_slice(:max_id, :since_id, :min_id)
|
||||
).reject { |status| FeedManager.instance.filter?(:home, status, current_account.id) }
|
||||
elsif ['top_today', 'top_weekly', 'top_monthly', 'top_yearly', 'top_all_time'].include? @sort_type
|
||||
elsif ['top_today', 'top_weekly', 'top_monthly', 'top_yearly', 'top_all_time', 'hot'].include? @sort_type
|
||||
if @sort_type == 'top_all_time'
|
||||
statuses = Status.unscoped.where(
|
||||
group: @group, reply: false
|
||||
@@ -116,7 +122,7 @@ class Api::V1::Timelines::GroupController < Api::BaseController
|
||||
limit_param(DEFAULT_STATUSES_LIMIT),
|
||||
params_slice(:max_id, :since_id, :min_id)
|
||||
)
|
||||
elsif ['top_today', 'top_weekly', 'top_monthly', 'top_yearly', 'top_all_time'].include? @sort_type
|
||||
elsif ['top_today', 'top_weekly', 'top_monthly', 'top_yearly', 'top_all_time', 'hot'].include? @sort_type
|
||||
if @sort_type == 'top_all_time'
|
||||
statuses = Status.unscoped.where(
|
||||
group: @group, reply: false
|
||||
|
||||
Reference in New Issue
Block a user