Include uncategorized pinned topics on 'Hot'

This commit is contained in:
Robin Ward 2013-04-01 13:49:35 -04:00
parent 79c986dd92
commit 1e6f8dc93a
2 changed files with 23 additions and 2 deletions

View File

@ -3,7 +3,6 @@ class HotTopic < ActiveRecord::Base
belongs_to :topic belongs_to :topic
belongs_to :category belongs_to :category
# Here's the current idea behind the implementaiton of hot: random can produce good results! # Here's the current idea behind the implementaiton of hot: random can produce good results!
# Hot is currently made up of a random selection of high percentile topics. It includes mostly # Hot is currently made up of a random selection of high percentile topics. It includes mostly
# new topics, but also some old ones for variety. # new topics, but also some old ones for variety.
@ -18,6 +17,16 @@ class HotTopic < ActiveRecord::Base
new_days = 21 # how many days old we consider old new_days = 21 # how many days old we consider old
# Include all sticky uncategorized on Hot
exec_sql("INSERT INTO hot_topics (topic_id, score)
SELECT t.id, RANDOM()
FROM topics AS t
WHERE t.deleted_at IS NULL
AND t.visible
AND (NOT t.archived)
AND t.pinned_at IS NOT NULL
AND t.category_id IS NULL")
# Include high percentile recent topics # Include high percentile recent topics
exec_sql("INSERT INTO hot_topics (topic_id, category_id, score) exec_sql("INSERT INTO hot_topics (topic_id, category_id, score)
SELECT t.id, SELECT t.id,
@ -28,9 +37,11 @@ class HotTopic < ActiveRecord::Base
AND t.visible AND t.visible
AND (NOT t.closed) AND (NOT t.closed)
AND (NOT t.archived) AND (NOT t.archived)
AND t.pinned_at IS NULL
AND t.archetype <> :private_message AND t.archetype <> :private_message
AND created_at >= (CURRENT_TIMESTAMP - INTERVAL ':days_ago' DAY) AND created_at >= (CURRENT_TIMESTAMP - INTERVAL ':days_ago' DAY)
AND t.percent_rank < :hot_percentile AND t.percent_rank < :hot_percentile
AND NOT EXISTS(SELECT * FROM hot_topics AS ht2 WHERE ht2.topic_id = t.id)
LIMIT :limit", LIMIT :limit",
hot_percentile: hot_percentile, hot_percentile: hot_percentile,
limit: ((1.0 - older_percentage) * max_hot_topics).round, limit: ((1.0 - older_percentage) * max_hot_topics).round,
@ -47,9 +58,11 @@ class HotTopic < ActiveRecord::Base
AND t.visible AND t.visible
AND (NOT t.closed) AND (NOT t.closed)
AND (NOT t.archived) AND (NOT t.archived)
AND t.pinned_at IS NULL
AND t.archetype <> :private_message AND t.archetype <> :private_message
AND created_at < (CURRENT_TIMESTAMP - INTERVAL ':days_ago' DAY) AND created_at < (CURRENT_TIMESTAMP - INTERVAL ':days_ago' DAY)
AND t.percent_rank < :hot_percentile AND t.percent_rank < :hot_percentile
AND NOT EXISTS(SELECT * FROM hot_topics AS ht2 WHERE ht2.topic_id = t.id)
LIMIT :limit", LIMIT :limit",
hot_percentile: hot_percentile, hot_percentile: hot_percentile,
limit: (older_percentage * max_hot_topics).round, limit: (older_percentage * max_hot_topics).round,

View File

@ -27,6 +27,14 @@ class TopicQuery
END DESC" END DESC"
end end
def order_hotness
"CASE
WHEN (COALESCE(topics.pinned_at, '#{lowest_date}') > COALESCE(tu.cleared_pinned_at, '#{lowest_date}'))
THEN 100
ELSE hot_topics.score + (COALESCE(categories.hotness, 5.0) / 11.0)
END DESC"
end
# If you've clearned the pin, use bumped_at, otherwise put it at the top # If you've clearned the pin, use bumped_at, otherwise put it at the top
def order_nocategory_with_pinned_sql def order_nocategory_with_pinned_sql
"CASE "CASE
@ -125,7 +133,7 @@ class TopicQuery
return_list(unordered: true) do |list| return_list(unordered: true) do |list|
# Find hot topics # Find hot topics
list = list.joins(:hot_topic) list = list.joins(:hot_topic)
.order('hot_topics.score + (COALESCE(categories.hotness, 5.0) / 11.0) desc') .order(TopicQuery.order_hotness)
end end
end end