mirror of
https://github.com/lingble/chatwoot.git
synced 2025-10-29 18:22:53 +00:00
* feat: order canned response Order canned responses by short_code match first and then with content * Added specs --------- Co-authored-by: Pranav Raj S <pranav@chatwoot.com>
31 lines
981 B
Ruby
31 lines
981 B
Ruby
# == Schema Information
|
|
#
|
|
# Table name: canned_responses
|
|
#
|
|
# id :integer not null, primary key
|
|
# content :text
|
|
# short_code :string
|
|
# created_at :datetime not null
|
|
# updated_at :datetime not null
|
|
# account_id :integer not null
|
|
#
|
|
|
|
class CannedResponse < ApplicationRecord
|
|
validates_presence_of :content
|
|
validates_presence_of :short_code
|
|
validates_presence_of :account
|
|
validates_uniqueness_of :short_code, scope: :account_id
|
|
|
|
belongs_to :account
|
|
|
|
scope :order_by_search, lambda { |search|
|
|
short_code_starts_with = sanitize_sql_array(['WHEN short_code ILIKE ? THEN 1', "#{search}%"])
|
|
short_code_like = sanitize_sql_array(['WHEN short_code ILIKE ? THEN 0.5', "%#{search}%"])
|
|
content_like = sanitize_sql_array(['WHEN content ILIKE ? THEN 0.2', "%#{search}%"])
|
|
|
|
order_clause = "CASE #{short_code_starts_with} #{short_code_like} #{content_like} ELSE 0 END"
|
|
|
|
order(Arel.sql(order_clause) => :desc)
|
|
}
|
|
end
|