Module: ActiveAdmin::Filters::FormtasticAddons
- Included in:
- FormBuilder, Inputs::Filters::Base
- Defined in:
- lib/active_admin/filters/formtastic_addons.rb
Instance Method Summary collapse
- #column ⇒ Object
- #column_for(method) ⇒ Object
- 
  
    
      #has_predicate?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    If the given method has a predicate (like _eq or _lteq), it’s pretty likely we’re dealing with a valid search method. 
- 
  
    
      #humanized_method_name  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    The below are Formtastic method overrides that jump inside of the Ransack search object to get at the object being searched upon. 
- 
  
    
      #klass  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    The resource class, unwrapped from Ransack. 
- #polymorphic_foreign_type?(method) ⇒ Boolean
- #reflection_for(method) ⇒ Object
- 
  
    
      #scope?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Ransack supports exposing selected scopes on your model for advanced searches. 
- 
  
    
      #searchable_has_many_through?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    These help figure out whether the given method or association will be recognized by Ransack. 
- #seems_searchable? ⇒ Boolean
Instance Method Details
#column ⇒ Object
| 27 28 29 | # File 'lib/active_admin/filters/formtastic_addons.rb', line 27 def column column_for method end | 
#column_for(method) ⇒ Object
| 23 24 25 | # File 'lib/active_admin/filters/formtastic_addons.rb', line 23 def column_for(method) klass.columns_hash[method.to_s] if klass.respond_to? :columns_hash end | 
#has_predicate? ⇒ Boolean
If the given method has a predicate (like _eq or _lteq), it’s pretty likely we’re dealing with a valid search method.
| 63 64 65 | # File 'lib/active_admin/filters/formtastic_addons.rb', line 63 def has_predicate? !!Ransack::Predicate.detect_from_string(method.to_s) end | 
#humanized_method_name ⇒ Object
The below are Formtastic method overrides that jump inside of the Ransack search object to get at the object being searched upon.
| 11 12 13 14 15 16 17 | # File 'lib/active_admin/filters/formtastic_addons.rb', line 11 def humanized_method_name if klass.respond_to?(:human_attribute_name) klass.human_attribute_name(method) else method.to_s.public_send(builder.label_str_method) end end | 
#klass ⇒ Object
The resource class, unwrapped from Ransack
| 36 37 38 | # File 'lib/active_admin/filters/formtastic_addons.rb', line 36 def klass @object.object.klass end | 
#polymorphic_foreign_type?(method) ⇒ Boolean
| 40 41 42 43 | # File 'lib/active_admin/filters/formtastic_addons.rb', line 40 def polymorphic_foreign_type?(method) klass.reflect_on_all_associations.select { |r| r.macro == :belongs_to && r.[:polymorphic] } .map(&:foreign_type).include? method.to_s end | 
#reflection_for(method) ⇒ Object
| 19 20 21 | # File 'lib/active_admin/filters/formtastic_addons.rb', line 19 def reflection_for(method) klass.reflect_on_association(method) if klass.respond_to? :reflect_on_association end | 
#scope? ⇒ Boolean
Ransack supports exposing selected scopes on your model for advanced searches.
| 68 69 70 71 | # File 'lib/active_admin/filters/formtastic_addons.rb', line 68 def scope? context = Ransack::Context.for klass context.respond_to?(:ransackable_scope?) && context.ransackable_scope?(method.to_s, klass) end | 
#searchable_has_many_through? ⇒ Boolean
These help figure out whether the given method or association will be recognized by Ransack.
| 49 50 51 52 53 54 55 | # File 'lib/active_admin/filters/formtastic_addons.rb', line 49 def searchable_has_many_through? if klass.ransackable_associations.include?(method.to_s) && reflection && reflection.[:through] reflection.through_reflection.klass.ransackable_attributes.include? reflection.foreign_key else false end end | 
#seems_searchable? ⇒ Boolean
| 57 58 59 | # File 'lib/active_admin/filters/formtastic_addons.rb', line 57 def seems_searchable? column_for(method).nil? && (has_predicate? || scope?) end |