debian-mirror-gitlab/app/models/concerns/sortable.rb

68 lines
2.4 KiB
Ruby
Raw Normal View History

2018-11-20 20:47:30 +05:30
# frozen_string_literal: true
2015-04-26 12:48:37 +05:30
# == Sortable concern
#
# Set default scope for ordering objects
#
module Sortable
extend ActiveSupport::Concern
included do
2020-03-09 13:42:32 +05:30
scope :with_order_id_desc, -> { order(self.arel_table['id'].desc) }
scope :order_id_desc, -> { reorder(self.arel_table['id'].desc) }
scope :order_id_asc, -> { reorder(self.arel_table['id'].asc) }
scope :order_created_desc, -> { reorder(self.arel_table['created_at'].desc) }
scope :order_created_asc, -> { reorder(self.arel_table['created_at'].asc) }
scope :order_updated_desc, -> { reorder(self.arel_table['updated_at'].desc) }
scope :order_updated_asc, -> { reorder(self.arel_table['updated_at'].asc) }
2018-11-08 19:23:39 +05:30
scope :order_name_asc, -> { reorder(Arel::Nodes::Ascending.new(arel_table[:name].lower)) }
scope :order_name_desc, -> { reorder(Arel::Nodes::Descending.new(arel_table[:name].lower)) }
2015-04-26 12:48:37 +05:30
end
2018-11-20 20:47:30 +05:30
class_methods do
2015-04-26 12:48:37 +05:30
def order_by(method)
2019-07-07 11:18:12 +05:30
simple_sorts.fetch(method.to_s, -> { all }).call
end
def simple_sorts
{
'created_asc' => -> { order_created_asc },
2019-12-04 20:38:33 +05:30
'created_at_asc' => -> { order_created_asc },
2019-07-07 11:18:12 +05:30
'created_date' => -> { order_created_desc },
'created_desc' => -> { order_created_desc },
2019-12-04 20:38:33 +05:30
'created_at_desc' => -> { order_created_desc },
2019-07-07 11:18:12 +05:30
'id_asc' => -> { order_id_asc },
'id_desc' => -> { order_id_desc },
'name_asc' => -> { order_name_asc },
'name_desc' => -> { order_name_desc },
'updated_asc' => -> { order_updated_asc },
2019-12-04 20:38:33 +05:30
'updated_at_asc' => -> { order_updated_asc },
'updated_desc' => -> { order_updated_desc },
'updated_at_desc' => -> { order_updated_desc }
2019-07-07 11:18:12 +05:30
}
2015-04-26 12:48:37 +05:30
end
2016-09-13 17:45:13 +05:30
private
2016-11-03 12:29:30 +05:30
def highest_label_priority(target_type_column: nil, target_type: nil, target_column:, project_column:, excluded_labels: [])
2017-09-10 17:25:29 +05:30
query = Label.select(LabelPriority.arel_table[:priority].minimum)
.left_join_priorities
.joins(:label_links)
.where("label_priorities.project_id = #{project_column}")
.where("label_links.target_id = #{target_column}")
.reorder(nil)
2016-09-13 17:45:13 +05:30
2017-08-17 22:00:37 +05:30
query =
if target_type_column
query.where("label_links.target_type = #{target_type_column}")
else
query.where(label_links: { target_type: target_type })
end
2016-11-03 12:29:30 +05:30
query = query.where.not(title: excluded_labels) if excluded_labels.present?
2016-09-13 17:45:13 +05:30
query
end
2015-04-26 12:48:37 +05:30
end
end