commit
af667a2872
@ -0,0 +1,11 @@ |
|||||||
|
class Report::Filter |
||||||
|
class MultiChoice < Base |
||||||
|
|
||||||
|
dont_inherit :available_operators |
||||||
|
use '=' |
||||||
|
|
||||||
|
def self.is_multiple_choice? |
||||||
|
true |
||||||
|
end |
||||||
|
end |
||||||
|
end |
@ -0,0 +1,37 @@ |
|||||||
|
class Widget::Filters::MultiChoice < Widget::Filters::Base |
||||||
|
|
||||||
|
def render |
||||||
|
filterName = filter_class.underscore_name |
||||||
|
content_tag :td do |
||||||
|
content_tag :div, :id => "#{filterName}_arg_1", :class => "filter_values" do |
||||||
|
choices = filter_class.available_values.each_with_index.map do |(label, value), i| |
||||||
|
opts = { |
||||||
|
:type => "radio", |
||||||
|
:name => "values[#{filterName}][]", |
||||||
|
:id => "#{filterName}_radio_option_#{i}", |
||||||
|
:value => value |
||||||
|
} |
||||||
|
opts[:checked] = "checked" if filter.values == value |
||||||
|
radio_button = tag :input, opts |
||||||
|
content_tag :label, radio_button + translate(label), |
||||||
|
:for => "#{filterName}_radio_option_#{i}", |
||||||
|
:'data-filter-name' => filter_class.underscore_name, |
||||||
|
:class => "#{filterName}_radio_option filter_radio_option" |
||||||
|
end |
||||||
|
content_tag :div, choices.join.html_safe, |
||||||
|
:id => "#{filter_class.underscore_name}_arg_1_val" |
||||||
|
end |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
private |
||||||
|
|
||||||
|
def translate(label) |
||||||
|
if label.is_a?(Symbol) |
||||||
|
::I18n.t(label) |
||||||
|
else |
||||||
|
label |
||||||
|
end |
||||||
|
end |
||||||
|
|
||||||
|
end |
Loading…
Reference in new issue