Fixed: gantt displays issues by date of creation.

git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@4421 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
Jean-Philippe Lang 2010-11-21 13:54:26 +00:00
parent 1158716f46
commit 77c6188ec2
2 changed files with 14 additions and 2 deletions

View File

@ -68,8 +68,7 @@ class Issue < ActiveRecord::Base
:conditions => ["#{Project.table_name}.status=#{Project::STATUS_ACTIVE}"]
named_scope :for_gantt, lambda {
{
:include => [:tracker, :status, :assigned_to, :priority, :project, :fixed_version],
:order => "#{Issue.table_name}.due_date ASC, #{Issue.table_name}.start_date ASC, #{Issue.table_name}.id ASC"
:include => [:tracker, :status, :assigned_to, :priority, :project, :fixed_version]
}
}

View File

@ -178,6 +178,7 @@ module Redmine
# Second, Issues without a version
issues = project.issues.for_gantt.without_version.with_query(@query)
sort_issues!(issues)
if issues
issue_rendering = render_issues(issues, options)
output << issue_rendering if options[:format] == :html
@ -237,6 +238,7 @@ module Redmine
issues = version.fixed_issues.for_gantt.with_query(@query)
if issues
sort_issues!(issues)
# Indent issues
options[:indent] += options[:indent_increment]
output << render_issues(issues, options)
@ -952,6 +954,17 @@ module Redmine
private
# Sorts a collection of issues by start_date, due_date, id for gantt rendering
def sort_issues!(issues)
issues.sort! do |a, b|
cmp = 0
cmp = (a.start_date <=> b.start_date) if a.start_date? && b.start_date?
cmp = (a.due_date <=> b.due_date) if cmp == 0 && a.due_date? && b.due_date?
cmp = (a.id <=> b.id) if cmp == 0
cmp
end
end
# Renders both the subjects and lines of the Gantt chart for the
# PDF format
def pdf_subjects_and_lines(pdf, options = {})