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
@@or_delimiter =
','

Instance Attribute Summary collapse

Attributes inherited from Base

#action_group, #user

Instance Method Summary collapse

Methods inherited from Base

#crud_type, #formats, #formats=, inherited

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
13
14
# File 'lib/active_scaffold/config/field_search.rb', line 5

def initialize(core_config)
  @core = core_config

  @text_search = self.class.text_search
  @or_delimiter = self.class.or_delimiter

  # start with the ActionLink defined globally
  @link = self.class.link.clone
  @action_group = self.class.action_group.clone if self.class.action_group
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”=>“%?%”}



89
90
91
# File 'lib/active_scaffold/config/field_search.rb', line 89

def default_params
  @default_params
end

#human_conditionsObject

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



93
94
95
# File 'lib/active_scaffold/config/field_search.rb', line 93

def human_conditions
  @human_conditions
end

the ActionLink for this action



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

def link
  @link
end

#or_delimiterObject

Returns the value of attribute or_delimiter.



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

def or_delimiter
  @or_delimiter
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



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

def text_search
  @text_search
end

Instance Method Details

#columnsObject

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



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

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



70
71
72
# File 'lib/active_scaffold/config/field_search.rb', line 70

def optional_columns
  @optional_columns ||= []
end

#optional_columns=(optionals) ⇒ Object

rarely searched columns may be placed in a hidden subgroup



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

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

#or_columnsObject



80
81
82
83
84
85
# File 'lib/active_scaffold/config/field_search.rb', line 80

def or_columns
  unless @or_columns
    self.or_columns = @core.columns.collect{|c| c.name if @core.columns._inheritable.include?(c.name) and c.searchable? and c.column and c.column.text?}.compact
  end
  @or_columns
end

#or_columns=(or_columns) ⇒ Object

columns which should support or searches eg like ‘x’ or … like ‘y’



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

def or_columns=(or_columns)
  @or_columns = Array(or_columns)
end