sortable.rb 1.84 KB
Newer Older
1 2 3 4 5 6 7 8
# == Sortable concern
#
# Set default scope for ordering objects
#
module Sortable
  extend ActiveSupport::Concern

  included do
9
    scope :order_id_desc, -> { reorder(id: :desc) }
10
    scope :order_id_asc, -> { reorder(id: :asc) }
11 12 13 14
    scope :order_created_desc, -> { reorder(created_at: :desc) }
    scope :order_created_asc, -> { reorder(created_at: :asc) }
    scope :order_updated_desc, -> { reorder(updated_at: :desc) }
    scope :order_updated_asc, -> { reorder(updated_at: :asc) }
15 16
    scope :order_name_asc, -> { reorder(name: :asc) }
    scope :order_name_desc, -> { reorder(name: :desc) }
17 18 19
  end

  module ClassMethods
20
    def order_by(method)
21
      case method.to_s
22 23
      when 'created_asc'  then order_created_asc
      when 'created_date' then order_created_desc
24
      when 'created_desc' then order_created_desc
25 26 27 28 29 30
      when 'id_asc'       then order_id_asc
      when 'id_desc'      then order_id_desc
      when 'name_asc'     then order_name_asc
      when 'name_desc'    then order_name_desc
      when 'updated_asc'  then order_updated_asc
      when 'updated_desc' then order_updated_desc
31
      else
32
        all
33 34
      end
    end
Felipe Artur's avatar
Felipe Artur committed
35 36 37

    private

38
    def highest_label_priority(target_type_column: nil, target_type: nil, target_column:, project_column:, excluded_labels: [])
39 40 41 42 43 44
      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)
Felipe Artur's avatar
Felipe Artur committed
45

Douwe Maan's avatar
Douwe Maan committed
46 47 48 49 50 51
      query =
        if target_type_column
          query.where("label_links.target_type = #{target_type_column}")
        else
          query.where(label_links: { target_type: target_type })
        end
52 53

      query = query.where.not(title: excluded_labels) if excluded_labels.present?
Felipe Artur's avatar
Felipe Artur committed
54 55 56

      query
    end
57 58
  end
end