diff --git a/app/controllers/issues_controller.rb b/app/controllers/issues_controller.rb
index 790718e5d..80be8c5d5 100644
--- a/app/controllers/issues_controller.rb
+++ b/app/controllers/issues_controller.rb
@@ -95,6 +95,7 @@ class IssuesController < ApplicationController
format.api {
Issue.load_visible_relations(@issues) if include_in_api_response?('relations')
}
+ # format.json { render :json => @issues.map { |issue| issue.to_json}} #:json => @issues.map { |issue| issue.to_json}
format.atom { render_feed(@issues, :title => "#{@project || Setting.app_title}: #{l(:label_issue_plural)}") }
format.csv { send_data(query_to_csv(@issues, @query, params), :type => 'text/csv; header=present', :filename => 'issues.csv') }
format.pdf { send_data(issues_to_pdf(@issues, @project, @query), :type => 'application/pdf', :filename => 'issues.pdf') }
diff --git a/app/helpers/queries_helper.rb b/app/helpers/queries_helper.rb
index f36d2ea94..e1d8c3e12 100644
--- a/app/helpers/queries_helper.rb
+++ b/app/helpers/queries_helper.rb
@@ -255,8 +255,19 @@ module QueriesHelper
# Give it a name, required to be valid
@query = IssueQuery.new(:name => "_")
@query.project = @project
+ params[:f] = %w(subject status_id priority_id author_id assigned_to_id) unless params[:status_id].nil?
+ params[:op] = {'subject' => "~" ,
+ 'status_id' => ( params[:status_id] == '0' ? "!":"=" ),
+ 'priority_id' => ( params[:priority_id] == '0' ? "!":"=" ),
+ 'author_id' => ( params[:author_id] == '0' ? "!":"=" ),
+ 'assigned_to_id' => ( params[:assigned_to_id] == '0' ? "!":"=" )} unless params[:status_id].nil?
+ params[:v] = {'subject' => [params[:subject]],
+ 'status_id' => [params[:status_id]],
+ 'priority_id' => [params[:priority_id]],
+ 'author_id' => [params[:author_id]],
+ 'assigned_to_id' => [params[:assigned_to_id]]} unless params[:status_id].nil?
@query.build_from_params(params)
- session[:query] = {:project_id => @query.project_id, :filters => @query.filters, :group_by => @query.group_by, :column_names => @query.column_names}
+ #session[:query] = {:project_id => @query.project_id, :filters => @query.filters, :group_by => @query.group_by, :column_names => @query.column_names}
else
# retrieve from session
@query = IssueQuery.find_by_id(session[:query][:id]) if session[:query][:id]
diff --git a/app/views/issues/_list.html.erb b/app/views/issues/_list.html.erb
index 9a918bb5f..1a77c03d3 100644
--- a/app/views/issues/_list.html.erb
+++ b/app/views/issues/_list.html.erb
@@ -27,4 +27,7 @@
<% end %>
- <% end -%>
\ No newline at end of file
+ <% end -%>
+
+ <%= pagination_links_full issue_pages, issue_count, :per_page_links => false, :remote => false, :flag => true %>
+
\ No newline at end of file
diff --git a/app/views/issues/index.html.erb b/app/views/issues/index.html.erb
index 376cbb906..f20ce9b12 100644
--- a/app/views/issues/index.html.erb
+++ b/app/views/issues/index.html.erb
@@ -1,15 +1,71 @@
+
<%= l(:label_issue_tracking) %>
-
<% unless @project.enabled_modules.where("name = 'issue_tracking'").empty? %>
-
- <%= link_to l(:label_query), '#',
- :onclick => '$("#custom_query").slideToggle(400); ' if true || User.current.logged? %>
-
+ <%= form_tag({:controller => 'issues', :action => 'index', :project_id => @project}, :method => :get,:id=>"issue_query_form", :class => 'query_form') do %>
+ <%= hidden_field_tag 'set_filter', '1' %>
+
+
+
+ <%= select( :issue,:user_id, @project.members.order("lower(users.login)").map{|c| [c.name, c.user_id]}.unshift(["指派给",0]),
+ { :include_blank => false,:selected=>0
+ },
+ {:onchange=>"remote_function();",:id=>"assigned_to_id",:name=>"v[assigned_to_id]",:class=>"w90"}
+ )
+ %>
+ <%= select( :issue,:prior, [["低",1],["正常",2],["高",3],["紧急",4],["立刻",5]].unshift(["优先级",0]),
+ { :include_blank => false,:selected=>0
+ },
+ {:onchange=>"remote_function();",:id=>"priority_id",:name=>"v[priority_id]",:class=>"w90"}
+ )
+ %>
+ <%= select( :issue,:status, [["新增",1],["正在解决",2],["已解决",3],["反馈",4],["关闭",5],["拒绝",6]].unshift(["状态",0]),
+ { :include_blank => false,:selected=>0
+ },
+ {:onchange=>"remote_function();",:id=>"status_id",:name=>"v[status_id]",:class=>"w90"}
+ )
+ %>
+ <%= select( :issue,:user_id, @project.members.order("lower(users.login)").map{|c| [c.name, c.user_id]}.unshift(["作者",0]),
+ { :include_blank => false,:selected=>0
+ },
+ {:onchange=>"remote_function();",:id=>"author_id",:name=>"v[author_id]",:class=>"w90"}
+ )
+ %>
+
+
+ <% end %>
+
<%= l(:label_issues_sum) %>:
+ <%= @project.issues.count %> <%= l(:lable_issues_undo) %>
+ <%= @project.issues.where('status_id in (1,2,4,6)').count %>
+
+
+
<% end %>
-
<%= l(:label_issues_sum) %>:<%= @project.issues.count %> <%= l(:lable_issues_undo) %>:<%= @project.issues.where('status_id in (1,2,4,6)').count %>
<% if !@query.new_record? && @query.editable_by?(User.current) %>
@@ -20,49 +76,6 @@
<% html_title(@query.new_record? ? l(:label_issue_plural) : @query.name) %>
- <%= form_tag({:controller => 'issues', :action => 'index', :project_id => @project}, :method => :get, :id => 'query_form', :class => 'query_form') do %>
- <%= hidden_field_tag 'set_filter', '1' %>
-
-
---<%= l :label_query_new %>---
-
-
">
-
- <%= l(:label_issue_query_condition) %>
-
- ">
- <%= render :partial => 'queries/filters', :locals => {:query => @query} %>
-
-
-
-
- <%= link_to_function l(:label_issue_query), 'submit_query_form("query_form")', :class => 'icon icon-checked' %>
- <%= link_to l(:label_issue_cancel_query), {:set_filter => 1, :project_id => @project}, :class => 'icon icon-reload' %>
-
-
-
- <% end %>
<%= error_messages_for 'query' %>
@@ -73,10 +86,10 @@
<%= l(:label_no_data) %>
<% else %>
- <%= render :partial => 'issues/list', :locals => {:issues => @issues, :query => @query} %>
-
- <%= pagination_links_full @issue_pages, @issue_count, :per_page_links => false, :remote => false, :flag => true %>
-
+
+ <%= render :partial => 'issues/list', :locals => {:issues => @issues, :query => @query,:issue_pages=>@issue_pages,:issue_count=>@issue_count} %>
+
+
<% end %>
diff --git a/app/views/issues/index.js.erb b/app/views/issues/index.js.erb
new file mode 100644
index 000000000..34d2eb760
--- /dev/null
+++ b/app/views/issues/index.js.erb
@@ -0,0 +1 @@
+$("#issue_list").html("<%= escape_javascript(render :partial => 'issues/list',:locals => {:issues => @issues, :query => @query,:issue_pages=>@issue_pages,:issue_count=>@issue_count})%>");
\ No newline at end of file