/app/views/queries/_filters.rhtml

https://github.com/orospakr/chiliproject-ircan · Ruby HTML · 121 lines · 114 code · 7 blank · 0 comment · 14 complexity · 0b1b0df26fff43dc3f4fcd33ce928f66 MD5 · raw file

  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. Form.Element.enable("operators_" + field);
  22. Form.Element.enable("values_" + field);
  23. toggle_operator(field);
  24. } else {
  25. Element.hide("operators_" + field);
  26. Element.hide("div_values_" + field);
  27. Form.Element.disable("operators_" + field);
  28. Form.Element.disable("values_" + field);
  29. }
  30. }
  31. function toggle_operator(field) {
  32. operator = $("operators_" + field);
  33. switch (operator.value) {
  34. case "!*":
  35. case "*":
  36. case "t":
  37. case "w":
  38. case "o":
  39. case "c":
  40. Element.hide("div_values_" + field);
  41. break;
  42. default:
  43. Element.show("div_values_" + field);
  44. break;
  45. }
  46. }
  47. function toggle_multi_select(field) {
  48. select = $('values_' + field);
  49. if (select.multiple == true) {
  50. select.multiple = false;
  51. } else {
  52. select.multiple = true;
  53. }
  54. }
  55. function apply_filters_observer() {
  56. $$("#query_form input[type=text]").invoke("observe", "keypress", function(e){
  57. if(e.keyCode == Event.KEY_RETURN) {
  58. <%= remote_function(:url => { :set_filter => 1},
  59. :update => "content",
  60. :with => "Form.serialize('query_form')",
  61. :complete => "e.stop(); apply_filters_observer()") %>
  62. }
  63. });
  64. }
  65. Event.observe(document,"dom:loaded", apply_filters_observer);
  66. //]]>
  67. </script>
  68. <table width="100%">
  69. <tr>
  70. <td>
  71. <table>
  72. <% query.available_filters.sort{|a,b| a[1][:order]<=>b[1][:order]}.each do |filter| %>
  73. <% field = filter[0]
  74. options = filter[1] %>
  75. <tr <%= 'style="display:none;"' unless query.has_filter?(field) %> id="tr_<%= field %>" class="filter">
  76. <td style="width:200px;">
  77. <%= check_box_tag 'f[]', field, query.has_filter?(field), :onclick => "toggle_filter('#{field}');", :id => "cb_#{field}" %>
  78. <label for="cb_<%= field %>"><%= filter[1][:name] || l(("field_"+field.to_s.gsub(/\_id$/, "")).to_sym) %></label>
  79. </td>
  80. <td style="width:150px;">
  81. <%= select_tag "op[#{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;" %>
  82. </td>
  83. <td>
  84. <div id="div_values_<%= field %>" style="display:none;">
  85. <% case options[:type]
  86. when :list, :list_optional, :list_status, :list_subprojects %>
  87. <select <%= "multiple=true" if query.values_for(field) and query.values_for(field).length > 1 %> name="v[<%= field %>][]" id="values_<%= field %>" class="select-small" style="vertical-align: top;">
  88. <%= options_for_select options[:values], query.values_for(field) %>
  89. </select>
  90. <%= link_to_function image_tag('bullet_toggle_plus.png'), "toggle_multi_select('#{field}');", :style => "vertical-align: bottom;" %>
  91. <% when :date, :date_past %>
  92. <%= text_field_tag "v[#{field}][]", query.values_for(field), :id => "values_#{field}", :size => 3, :class => "select-small" %> <%= l(:label_day_plural) %>
  93. <% when :string, :text %>
  94. <%= text_field_tag "v[#{field}][]", query.values_for(field), :id => "values_#{field}", :size => 30, :class => "select-small" %>
  95. <% when :integer %>
  96. <%= text_field_tag "v[#{field}][]", query.values_for(field), :id => "values_#{field}", :size => 3, :class => "select-small" %>
  97. <% end %>
  98. </div>
  99. <script type="text/javascript">toggle_filter('<%= field %>');</script>
  100. </td>
  101. </tr>
  102. <% end %>
  103. </table>
  104. </td>
  105. <td class="add-filter">
  106. <%= label_tag('add_filter_select', l(:label_filter_add)) %>:
  107. <%= 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),
  108. :onchange => "add_filter();",
  109. :class => "select-small",
  110. :name => nil %>
  111. </td>
  112. </tr>
  113. </table>
  114. <%= hidden_field_tag 'f[]', '' %>