Welcome to mirror list, hosted at ThFree Co, Russian Federation.

sortable.rb « concerns « models « app - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 6532a18d1b8abd2c3422d51d3aac7e3c89ae6fca (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
# frozen_string_literal: true

# == Sortable concern
#
# Set default scope for ordering objects
#
module Sortable
  extend ActiveSupport::Concern

  included do
    scope :with_order_id_desc, -> { order(self.arel_table['id'].desc) }
    scope :with_order_id_asc, -> { order(self.arel_table['id'].asc) }
    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) }
    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)) }
  end

  class_methods do
    def order_by(method)
      simple_sorts.fetch(method.to_s, -> { all }).call
    end

    def simple_sorts
      {
        'created_asc' => -> { order_created_asc },
        'created_at_asc' => -> { order_created_asc },
        'created_date' => -> { order_created_desc },
        'created_desc' => -> { order_created_desc },
        'created_at_desc' => -> { order_created_desc },
        '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 },
        'updated_at_asc' => -> { order_updated_asc },
        'updated_desc' => -> { order_updated_desc },
        'updated_at_desc' => -> { order_updated_desc }
      }
    end

    def build_keyset_order_on_joined_column(scope:, attribute_name:, column:, direction:, nullable:)
      reversed_direction = direction == :asc ? :desc : :asc

      # rubocop: disable GitlabSecurity/PublicSend
      order = ::Gitlab::Pagination::Keyset::Order.build(
        [
          ::Gitlab::Pagination::Keyset::ColumnOrderDefinition.new(
            attribute_name: attribute_name,
            column_expression: column,
            order_expression: column.send(direction).send(nullable),
            reversed_order_expression: column.send(reversed_direction).send(nullable),
            order_direction: direction,
            distinct: false,
            add_to_projections: true,
            nullable: nullable
          ),
          ::Gitlab::Pagination::Keyset::ColumnOrderDefinition.new(
            attribute_name: 'id',
            order_expression: arel_table['id'].desc
          )
        ]
      )
      # rubocop: enable GitlabSecurity/PublicSend

      order.apply_cursor_conditions(scope).reorder(order)
    end

    private

    def highest_label_priority(target_column:, project_column:, target_type_column: nil, target_type: nil, excluded_labels: [])
      query = Label.select(LabelPriority.arel_table[:priority].minimum.as('label_priority'))
        .left_join_priorities
        .joins(:label_links)
        .where("label_priorities.project_id = #{project_column}")
        .where("label_links.target_id = #{target_column}")
        .reorder(nil)

      query =
        if target_type_column
          query.where("label_links.target_type = #{target_type_column}")
        else
          query.where(label_links: { target_type: target_type })
        end

      query = query.where.not(title: excluded_labels) if excluded_labels.present?

      query
    end
  end
end