diff options
author | Eugen Rochko <eugen@zeonfederated.com> | 2022-04-08 17:10:53 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-04-08 17:10:53 +0200 |
commit | fd9a9b07c2cd19ef08d15e138fd3fc59fc5318b6 (patch) | |
tree | 2de019901aef5a8839223ea4b04c0fe0dc6a9557 /app/models/trends/query.rb | |
parent | 6b72641641a25ae664413d0d587080ffe70af6c2 (diff) |
Fix trends returning less results per page when filtered in REST API (#17996)
- Change filtering and pagination to occur in SQL instead of Redis - Change rank/score displayed on trends in admin UI to be locale-specific
Diffstat (limited to 'app/models/trends/query.rb')
-rw-r--r-- | app/models/trends/query.rb | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/app/models/trends/query.rb b/app/models/trends/query.rb index f19df162f..cd5571bc6 100644 --- a/app/models/trends/query.rb +++ b/app/models/trends/query.rb @@ -14,8 +14,8 @@ class Trends::Query @records = [] @loaded = false @allowed = false - @limit = -1 - @offset = 0 + @limit = nil + @offset = nil end def allowed! @@ -73,7 +73,10 @@ class Trends::Query if tmp_ids.empty? klass.none else - klass.joins("join unnest(array[#{tmp_ids.join(',')}]) with ordinality as x (id, ordering) on #{klass.table_name}.id = x.id").reorder('x.ordering') + scope = klass.joins("join unnest(array[#{tmp_ids.join(',')}]) with ordinality as x (id, ordering) on #{klass.table_name}.id = x.id").reorder('x.ordering') + scope = scope.offset(@offset) if @offset.present? + scope = scope.limit(@limit) if @limit.present? + scope end end @@ -93,7 +96,7 @@ class Trends::Query end def ids - redis.zrevrange(key, @offset, @limit.positive? ? @limit - 1 : @limit).map(&:to_i) + redis.zrevrange(key, 0, -1).map(&:to_i) end def perform_queries |