Feat: custom sort (#4864)

This commit is contained in:
Tejaswini Chile
2022-06-22 11:04:42 +05:30
committed by GitHub
parent a2204cf269
commit ffd102cdfe
7 changed files with 199 additions and 6 deletions

View File

@@ -50,6 +50,7 @@ class Conversation < ApplicationRecord
include RoundRobinHandler
include ActivityMessageHandler
include UrlHelper
include SortHandler
validates :account_id, presence: true
validates :inbox_id, presence: true
@@ -60,7 +61,6 @@ class Conversation < ApplicationRecord
enum status: { open: 0, resolved: 1, pending: 2, snoozed: 3 }
scope :latest, -> { order(last_activity_at: :desc) }
scope :unassigned, -> { where(assignee_id: nil) }
scope :assigned, -> { where.not(assignee_id: nil) }
scope :assigned_to, ->(agent) { where(assignee_id: agent.id) }
@@ -70,6 +70,13 @@ class Conversation < ApplicationRecord
open.where('last_activity_at < ? ', Time.now.utc - auto_resolve_duration.days)
}
scope :last_user_message_at, lambda {
joins(
"INNER JOIN (#{last_messaged_conversations.to_sql}) grouped_conversations
ON grouped_conversations.conversation_id = conversations.id"
).sort_on_last_user_message_at
}
belongs_to :account
belongs_to :inbox
belongs_to :assignee, class_name: 'User', optional: true