2007-03-12 20:59:02 +03:00
|
|
|
<script type="text/javascript">
|
|
|
|
//<![CDATA[
|
|
|
|
function add_filter() {
|
2011-07-10 21:29:29 +04:00
|
|
|
select = $('add_filter_select');
|
|
|
|
field = select.value
|
|
|
|
Element.show('tr_' + field);
|
|
|
|
check_box = $('cb_' + field);
|
|
|
|
check_box.checked = true;
|
|
|
|
toggle_filter(field);
|
|
|
|
select.selectedIndex = 0;
|
|
|
|
|
|
|
|
for (i=0; i<select.options.length; i++) {
|
|
|
|
if (select.options[i].value == field) {
|
|
|
|
select.options[i].disabled = true;
|
2011-09-17 10:00:38 +04:00
|
|
|
}
|
2011-07-10 21:29:29 +04:00
|
|
|
}
|
2007-03-12 20:59:02 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
function toggle_filter(field) {
|
2011-07-10 21:29:29 +04:00
|
|
|
check_box = $('cb_' + field);
|
|
|
|
if (check_box.checked) {
|
|
|
|
Element.show("operators_" + field);
|
|
|
|
Form.Element.enable("operators_" + field);
|
|
|
|
toggle_operator(field);
|
|
|
|
} else {
|
|
|
|
Element.hide("operators_" + field);
|
|
|
|
Form.Element.disable("operators_" + field);
|
|
|
|
enableValues(field, []);
|
2007-03-12 20:59:02 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-07-10 21:29:29 +04:00
|
|
|
function enableValues(field, indexes) {
|
2011-09-18 06:02:57 +04:00
|
|
|
var f = $$(".values_" + field);
|
|
|
|
for(var i=0;i<f.length;i++) {
|
|
|
|
if (indexes.include(i)) {
|
|
|
|
Form.Element.enable(f[i]);
|
|
|
|
f[i].up('span').show();
|
|
|
|
} else {
|
|
|
|
f[i].value = '';
|
2011-07-10 21:29:29 +04:00
|
|
|
Form.Element.disable(f[i]);
|
|
|
|
f[i].up('span').hide();
|
2011-09-18 06:02:57 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (indexes.length > 0) {
|
|
|
|
Element.show("div_values_" + field);
|
|
|
|
} else {
|
|
|
|
Element.hide("div_values_" + field);
|
|
|
|
}
|
2011-07-10 21:29:29 +04:00
|
|
|
}
|
|
|
|
|
2007-03-12 20:59:02 +03:00
|
|
|
function toggle_operator(field) {
|
|
|
|
operator = $("operators_" + field);
|
|
|
|
switch (operator.value) {
|
|
|
|
case "!*":
|
|
|
|
case "*":
|
|
|
|
case "t":
|
2007-09-05 21:47:17 +04:00
|
|
|
case "w":
|
2007-03-12 20:59:02 +03:00
|
|
|
case "o":
|
|
|
|
case "c":
|
2011-07-10 21:29:29 +04:00
|
|
|
enableValues(field, []);
|
2011-07-10 12:00:25 +04:00
|
|
|
break;
|
|
|
|
case "><":
|
2011-07-10 21:29:29 +04:00
|
|
|
enableValues(field, [0,1]);
|
|
|
|
break;
|
|
|
|
case "<t+":
|
|
|
|
case ">t+":
|
|
|
|
case "t+":
|
|
|
|
case ">t-":
|
|
|
|
case "<t-":
|
|
|
|
case "t-":
|
|
|
|
enableValues(field, [2]);
|
2007-03-12 20:59:02 +03:00
|
|
|
break;
|
|
|
|
default:
|
2011-07-10 21:29:29 +04:00
|
|
|
enableValues(field, [0]);
|
2007-03-12 20:59:02 +03:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-07-10 21:29:29 +04:00
|
|
|
function toggle_multi_select(el) {
|
|
|
|
var select = $(el);
|
|
|
|
if (select.multiple == true) {
|
|
|
|
select.multiple = false;
|
|
|
|
} else {
|
|
|
|
select.multiple = true;
|
|
|
|
}
|
2007-03-12 20:59:02 +03:00
|
|
|
}
|
2010-09-17 01:33:49 +04:00
|
|
|
|
2011-04-01 18:34:44 +04:00
|
|
|
function submit_query_form(id) {
|
|
|
|
selectAllOptions("selected_columns");
|
|
|
|
$(id).submit();
|
|
|
|
}
|
|
|
|
|
2010-09-17 01:33:49 +04:00
|
|
|
function apply_filters_observer() {
|
|
|
|
$$("#query_form input[type=text]").invoke("observe", "keypress", function(e){
|
|
|
|
if(e.keyCode == Event.KEY_RETURN) {
|
2011-04-01 18:34:44 +04:00
|
|
|
submit_query_form("query_form");
|
2010-09-17 01:33:49 +04:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
Event.observe(document,"dom:loaded", apply_filters_observer);
|
2007-03-12 20:59:02 +03:00
|
|
|
//]]>
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<table width="100%">
|
|
|
|
<tr>
|
|
|
|
<td>
|
2008-04-13 15:18:09 +04:00
|
|
|
<table>
|
2007-03-12 20:59:02 +03:00
|
|
|
<% query.available_filters.sort{|a,b| a[1][:order]<=>b[1][:order]}.each do |filter| %>
|
|
|
|
<% field = filter[0]
|
|
|
|
options = filter[1] %>
|
2008-04-13 15:18:09 +04:00
|
|
|
<tr <%= 'style="display:none;"' unless query.has_filter?(field) %> id="tr_<%= field %>" class="filter">
|
2011-07-31 14:39:59 +04:00
|
|
|
<td class="field">
|
2011-04-01 19:00:23 +04:00
|
|
|
<%= check_box_tag 'f[]', field, query.has_filter?(field), :onclick => "toggle_filter('#{field}');", :id => "cb_#{field}" %>
|
2007-04-17 14:53:20 +04:00
|
|
|
<label for="cb_<%= field %>"><%= filter[1][:name] || l(("field_"+field.to_s.gsub(/\_id$/, "")).to_sym) %></label>
|
2007-03-12 20:59:02 +03:00
|
|
|
</td>
|
2011-07-31 14:39:59 +04:00
|
|
|
<td class="operator">
|
2011-10-29 05:14:10 +04:00
|
|
|
<%= label_tag "op_#{field}", l(:description_filter), :class => "hidden-for-sighted" %>
|
|
|
|
<%= select_tag "op[#{field}]", options_for_select(operators_for_select(options[:type]),
|
|
|
|
query.operator_for(field)), :id => "operators_#{field}",
|
|
|
|
:onchange => "toggle_operator('#{field}');" %>
|
2007-03-12 20:59:02 +03:00
|
|
|
</td>
|
2011-09-17 10:00:38 +04:00
|
|
|
<td class="values">
|
2007-05-05 20:10:45 +04:00
|
|
|
<div id="div_values_<%= field %>" style="display:none;">
|
2007-03-12 20:59:02 +03:00
|
|
|
<% case options[:type]
|
2008-02-29 00:57:03 +03:00
|
|
|
when :list, :list_optional, :list_status, :list_subprojects %>
|
2011-07-10 21:29:29 +04:00
|
|
|
<span class="span_values_<%= field %>">
|
2011-09-18 06:02:57 +04:00
|
|
|
<%= select_tag "v[#{field}][]", options_for_select(options[:values], query.values_for(field)), :class => "values_#{field}", :id => "values_#{field}_1", :multiple => (query.values_for(field) && query.values_for(field).length > 1) %>
|
2011-07-31 14:39:59 +04:00
|
|
|
<%= link_to_function image_tag('bullet_toggle_plus.png'), "toggle_multi_select('values_#{field}_1');" %>
|
2011-07-10 21:29:29 +04:00
|
|
|
</span>
|
2007-03-12 20:59:02 +03:00
|
|
|
<% when :date, :date_past %>
|
2011-07-10 21:29:29 +04:00
|
|
|
<span class="span_values_<%= field %>"><%= text_field_tag "v[#{field}][]", query.value_for(field), :size => 10, :class => "values_#{field}", :id => "values_#{field}_1" %> <%= calendar_for "values_#{field}_1" %></span>
|
|
|
|
<span class="span_values_<%= field %>"><%= text_field_tag "v[#{field}][]", query.value_for(field, 1), :size => 10, :class => "values_#{field}", :id => "values_#{field}_2" %> <%= calendar_for "values_#{field}_2" %></span>
|
|
|
|
<span class="span_values_<%= field %>"><%= text_field_tag "v[#{field}][]", query.value_for(field), :size => 3, :class => "values_#{field}" %> <%= l(:label_day_plural) %></span>
|
2007-04-17 14:53:20 +04:00
|
|
|
<% when :string, :text %>
|
2011-07-10 21:29:29 +04:00
|
|
|
<span class="span_values_<%= field %>"><%= text_field_tag "v[#{field}][]", query.value_for(field), :class => "values_#{field}", :id => "values_#{field}", :size => 30 %></span>
|
2011-07-11 15:36:55 +04:00
|
|
|
<% when :integer, :float %>
|
2011-07-11 15:40:38 +04:00
|
|
|
<span class="span_values_<%= field %>"><%= text_field_tag "v[#{field}][]", query.value_for(field), :class => "values_#{field}", :id => "values_#{field}_1", :size => 6 %></span>
|
|
|
|
<span class="span_values_<%= field %>"><%= text_field_tag "v[#{field}][]", query.value_for(field, 1), :class => "values_#{field}", :id => "values_#{field}_2", :size => 6 %></span>
|
2007-03-12 20:59:02 +03:00
|
|
|
<% end %>
|
|
|
|
</div>
|
|
|
|
<script type="text/javascript">toggle_filter('<%= field %>');</script>
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
<% end %>
|
|
|
|
</table>
|
|
|
|
</td>
|
2008-04-13 15:18:09 +04:00
|
|
|
<td class="add-filter">
|
2011-07-02 15:49:13 +04:00
|
|
|
<%= label_tag('add_filter_select', l(:label_filter_add)) %>
|
2009-02-13 01:01:20 +03:00
|
|
|
<%= select_tag 'add_filter_select', options_for_select([["",""]] + query.available_filters.sort{|a,b| a[1][:order]<=>b[1][:order]}.collect{|field| [ field[1][:name] || l(("field_"+field[0].to_s.gsub(/_id$/, "")).to_sym), field[0]] unless query.has_filter?(field[0])}.compact),
|
2011-09-18 06:02:57 +04:00
|
|
|
:onchange => "add_filter();",
|
|
|
|
:name => nil %>
|
2007-03-12 20:59:02 +03:00
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
</table>
|
2011-04-01 19:00:23 +04:00
|
|
|
<%= hidden_field_tag 'f[]', '' %>
|