@@ -170,6 +170,10 class Query < ActiveRecord::Base | |||
|
170 | 170 | |
|
171 | 171 | def validate |
|
172 | 172 | filters.each_key do |field| |
|
173 | if type_for(field) == :integer && values_for(field) | |
|
174 | errors.add label_for(field), :invalid if values_for(field).detect {|v| v.present? && !v.match(/^\d+(\.\d+)?$/) } | |
|
175 | end | |
|
176 | ||
|
173 | 177 | errors.add label_for(field), :blank unless |
|
174 | 178 | # filter requires one or more values |
|
175 | 179 | (values_for(field) and !values_for(field).first.blank?) or |
@@ -278,11 +282,7 class Query < ActiveRecord::Base | |||
|
278 | 282 | # allowed_values = values & ([""] + (filter_options[:values] || []).collect {|val| val[1]}) |
|
279 | 283 | # filters[field] = {:operator => operator, :values => allowed_values } if (allowed_values.first and !allowed_values.first.empty?) or ["o", "c", "!*", "*", "t"].include? operator |
|
280 | 284 | #end |
|
281 | values ||= [''] | |
|
282 | if filter_options[:type] == :integer | |
|
283 | values = values.select {|v| v.blank? || v.match(/^\d+(\.\d+)?$/) } | |
|
284 | end | |
|
285 | filters[field] = {:operator => operator, :values => values } | |
|
285 | filters[field] = {:operator => operator, :values => (values || [''])} | |
|
286 | 286 | end |
|
287 | 287 | end |
|
288 | 288 |
General Comments 0
You need to be logged in to leave comments.
Login now