Class: ActiveScaffold::Config::FieldSearch

Inherits:
Base show all
Defined in:
lib/active_scaffold/config/field_search.rb

Constant Summary collapse

ActiveScaffold::DataStructures::ActionLink.new('show_search', :label => :search, :type => :collection, :security_method => :search_authorized?, :ignore_method => :search_ignore?)
@@text_search =
:full
@@human_conditions =
false

Instance Attribute Summary collapse

Attributes inherited from Base

#action_group, #user

Instance Method Summary collapse

Methods inherited from Base

#crud_type, #formats, #formats=, inherited, #label

Methods included from ActiveScaffold::Configurable

#configure, #method_missing

Constructor Details

#initialize(core_config) ⇒ FieldSearch

Returns a new instance of FieldSearch.



5
6
7
8
9
10
11
12
# File 'lib/active_scaffold/config/field_search.rb', line 5

def initialize(core_config)
  super
  @text_search = self.class.text_search
  @human_conditions = self.class.human_conditions

  # start with the ActionLink defined globally
  @link = self.class.link.clone
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method in the class ActiveScaffold::Configurable

Instance Attribute Details

#default_paramsObject

default search params default_params = => {“from”=>“test”, “to”=>“”, “opt”=>“%?%”}



72
73
74
# File 'lib/active_scaffold/config/field_search.rb', line 72

def default_params
  @default_params
end

#human_conditionsObject

human conditions instead of just filtered you may show the user a humanized search condition statment



76
77
78
# File 'lib/active_scaffold/config/field_search.rb', line 76

def human_conditions
  @human_conditions
end

the ActionLink for this action



59
60
61
# File 'lib/active_scaffold/config/field_search.rb', line 59

def link
  @link
end

#text_searchObject

A flag for how the search should do full-text searching in the database:

  • :full: LIKE %?%

  • :start: LIKE ?%

  • :end: LIKE %?

  • false: LIKE ?

Default is :full



56
57
58
# File 'lib/active_scaffold/config/field_search.rb', line 56

def text_search
  @text_search
end

Instance Method Details

#columnsObject

provides access to the list of columns specifically meant for the Search to use



39
40
41
42
43
44
45
46
# File 'lib/active_scaffold/config/field_search.rb', line 39

def columns
  # we want to delay initializing to the @core.columns set for as long as possible. Too soon and .search_sql will not be available to .searchable?
  unless @columns
    self.columns = @core.columns._inheritable
    self.columns.exclude @core.columns.active_record_class.locking_column.to_sym
  end
  @columns
end

#optional_columnsObject



66
67
68
# File 'lib/active_scaffold/config/field_search.rb', line 66

def optional_columns
  @optional_columns ||= []
end

#optional_columns=(optionals) ⇒ Object

rarely searched columns may be placed in a hidden subgroup



62
63
64
# File 'lib/active_scaffold/config/field_search.rb', line 62

def optional_columns=(optionals)
  @optional_columns = Array(optionals)
end