8

在我的 ActiveAdmin 模型中,我有一个自定义范围来显示已删除的记录和几个用于按特定列搜索记录的过滤器。

单独使用过滤器或组合使用过滤器可以按预期工作。

使用范围按预期工作。

问题是使用范围似乎会覆盖所有过滤器,并且在选择范围后,添加的任何过滤器都不会执行任何操作。

有人在这里有什么想法吗?我想要的是能够显示特定范围,然后仍然能够过滤该范围内的结果。

    ActiveAdmin.register Example do
      scope :deleted do |example|
        Example.only_deleted
      end

      scope :all do |example|
        Example.with_deleted
      end

      filter :title
      filter :description

      index do
        column :title
        column :description
      end

    end

[更新]

这是我采用的解决方案。我在模型上设置了 with_deleted 范围,并在侧面包含过滤器以显示/隐藏已删除的结果。不理想,因为还显示了最初删除的结果,但至少所有过滤器可以一起使用。

    ActiveAdmin.register Example.with_deleted do

      filter :title
      filter :description
      filter :deleted, :as => :select, :collection => {:true => nil, :false => false }

      index do
        column :title
        column :description
      end

    end
4

2 回答 2

3

默认情况下,ActiveAdmin 希望范围只提供符号化的方法名称。当您以这种方式定义范围时,它们可以链接到过滤器已经提供的范围,并且它们可以无缝地协同工作。

因此,您的错误是显式调用Model#class_method而不是提供:symbolized_class_method_name(带有当前模型的隐含所有者)。

如果您替换此代码,过滤器和范围将协同工作:

scope :all do |example|
  Example.with_deleted
end

scope :deleted do |example|
  Example.only_deleted
end

有了这个:

scope "Deleted", :only_deleted
scope "All", :with_deleted
于 2018-03-06T18:23:28.390 回答
-3

而不是范围创建另一个过滤器,它将根据是否删除示例或全部来选择标准上的记录。并根据需要应用尽可能多的过滤器。

或者在计算将运行过滤器的选择器时在过滤器中相应地运行范围,然后将过滤器条件放在该选择器上。

于 2012-05-09T20:30:35.987 回答