You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

_filters.rhtml 3.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <script type="text/javascript">
  2. //<![CDATA[
  3. function add_filter() {
  4. select = $('add_filter_select');
  5. field = select.value
  6. Element.show('tr_' + field);
  7. check_box = $('cb_' + field);
  8. check_box.checked = true;
  9. toggle_filter(field);
  10. select.selectedIndex = 0;
  11. for (i=0; i<select.options.length; i++) {
  12. if (select.options[i].value == field) {
  13. select.options[i].disabled = true;
  14. }
  15. }
  16. }
  17. function toggle_filter(field) {
  18. check_box = $('cb_' + field);
  19. if (check_box.checked) {
  20. Element.show("operators_" + field);
  21. toggle_operator(field);
  22. } else {
  23. Element.hide("operators_" + field);
  24. Element.hide("div_values_" + field);
  25. }
  26. }
  27. function toggle_operator(field) {
  28. operator = $("operators_" + field);
  29. switch (operator.value) {
  30. case "!*":
  31. case "*":
  32. case "t":
  33. case "w":
  34. case "o":
  35. case "c":
  36. Element.hide("div_values_" + field);
  37. break;
  38. default:
  39. Element.show("div_values_" + field);
  40. break;
  41. }
  42. }
  43. function toggle_multi_select(field) {
  44. select = $('values_' + field);
  45. if (select.multiple == true) {
  46. select.multiple = false;
  47. } else {
  48. select.multiple = true;
  49. }
  50. }
  51. //]]>
  52. </script>
  53. <table width="100%">
  54. <tr>
  55. <td>
  56. <table>
  57. <% query.available_filters.sort{|a,b| a[1][:order]<=>b[1][:order]}.each do |filter| %>
  58. <% field = filter[0]
  59. options = filter[1] %>
  60. <tr <%= 'style="display:none;"' unless query.has_filter?(field) %> id="tr_<%= field %>" class="filter">
  61. <td style="width:200px;">
  62. <%= check_box_tag 'fields[]', field, query.has_filter?(field), :onclick => "toggle_filter('#{field}');", :id => "cb_#{field}" %>
  63. <label for="cb_<%= field %>"><%= filter[1][:name] || l(("field_"+field.to_s.gsub(/\_id$/, "")).to_sym) %></label>
  64. </td>
  65. <td style="width:150px;">
  66. <%= select_tag "operators[#{field}]", options_for_select(operators_for_select(options[:type]), query.operator_for(field)), :id => "operators_#{field}", :onchange => "toggle_operator('#{field}');", :class => "select-small", :style => "vertical-align: top;" %>
  67. </td>
  68. <td>
  69. <div id="div_values_<%= field %>" style="display:none;">
  70. <% case options[:type]
  71. when :list, :list_optional, :list_status, :list_subprojects %>
  72. <select <%= "multiple=true" if query.values_for(field) and query.values_for(field).length > 1 %> name="values[<%= field %>][]" id="values_<%= field %>" class="select-small" style="vertical-align: top;">
  73. <%= options_for_select options[:values], query.values_for(field) %>
  74. </select>
  75. <%= link_to_function image_tag('bullet_toggle_plus.png'), "toggle_multi_select('#{field}');", :style => "vertical-align: bottom;" %>
  76. <% when :date, :date_past %>
  77. <%= text_field_tag "values[#{field}][]", query.values_for(field), :id => "values_#{field}", :size => 3, :class => "select-small" %> <%= l(:label_day_plural) %>
  78. <% when :string, :text %>
  79. <%= text_field_tag "values[#{field}][]", query.values_for(field), :id => "values_#{field}", :size => 30, :class => "select-small" %>
  80. <% when :integer %>
  81. <%= text_field_tag "values[#{field}][]", query.values_for(field), :id => "values_#{field}", :size => 3, :class => "select-small" %>
  82. <% end %>
  83. </div>
  84. <script type="text/javascript">toggle_filter('<%= field %>');</script>
  85. </td>
  86. </tr>
  87. <% end %>
  88. </table>
  89. </td>
  90. <td class="add-filter">
  91. <%= l(:label_filter_add) %>:
  92. <%= 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),
  93. :onchange => "add_filter();",
  94. :class => "select-small",
  95. :name => nil %>
  96. </td>
  97. </tr>
  98. </table>