如何解决如何使用ransack gem根据模型的实例方法对表进行排序?
我正在使用Rails和ransacker gem(2.3.2)构建一个可按列名过滤的表。我想根据该帐户的电子邮件地址的第一个成员过滤帐户。模型和实例方法如下所示:
class Account
has_many :members
def first_member_email
members.order(created_at: :desc).first.email
end
end
class Member
belongs_to :account
end
我计划使用Ransack的“ sort_link”根据帐户的first_member_email实例方法进行排序。基于documentation,使用抢劫犯似乎是必经之路。像这样:
ransacker :first_member_email do |parent|
Arel.sql(something)
end
并在视图中:
th=sort_link @q,:first_member_email,'Created By'
但是我无法让Arel工作。要使此功能起作用的查询是什么?或者没有使用Arel的另一种方法?
解决方法
您可以这样做:
# app/models/account.rb
class Account < ApplicationRecord
scope :sort_by_first_member_email_asc,-> { sort_by(&:first_member_email) }
scope :sort_by_first_member_email_desc,-> { sort_by(&:first_member_email).reverse }
end
如果需要,可以在合并范围内编写自定义查询。谢谢:)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。