Code cleanup.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@8526 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
ca1958972e
commit
f3a2c8d7f7
|
@ -151,9 +151,10 @@ class Issue < ActiveRecord::Base
|
||||||
issue = self.class.new.copy_from(self)
|
issue = self.class.new.copy_from(self)
|
||||||
else
|
else
|
||||||
issue = self
|
issue = self
|
||||||
issue.init_journal(User.current, options[:notes])
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
issue.init_journal(User.current, options[:notes])
|
||||||
|
|
||||||
issue.project = new_project
|
issue.project = new_project
|
||||||
if new_tracker
|
if new_tracker
|
||||||
issue.tracker = new_tracker
|
issue.tracker = new_tracker
|
||||||
|
@ -162,10 +163,7 @@ class Issue < ActiveRecord::Base
|
||||||
if options[:attributes]
|
if options[:attributes]
|
||||||
issue.attributes = options[:attributes]
|
issue.attributes = options[:attributes]
|
||||||
end
|
end
|
||||||
if options[:copy] && options[:notes].present?
|
|
||||||
issue.init_journal(User.current, options[:notes])
|
|
||||||
issue.current_journal.notify = false
|
|
||||||
end
|
|
||||||
unless issue.save
|
unless issue.save
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
@ -385,9 +383,13 @@ class Issue < ActiveRecord::Base
|
||||||
|
|
||||||
def init_journal(user, notes = "")
|
def init_journal(user, notes = "")
|
||||||
@current_journal ||= Journal.new(:journalized => self, :user => user, :notes => notes)
|
@current_journal ||= Journal.new(:journalized => self, :user => user, :notes => notes)
|
||||||
|
if new_record?
|
||||||
|
@current_journal.notify = false
|
||||||
|
else
|
||||||
@attributes_before_change = attributes.dup
|
@attributes_before_change = attributes.dup
|
||||||
@custom_values_before_change = {}
|
@custom_values_before_change = {}
|
||||||
self.custom_values.each {|c| @custom_values_before_change.store c.custom_field_id, c.value }
|
self.custom_values.each {|c| @custom_values_before_change.store c.custom_field_id, c.value }
|
||||||
|
end
|
||||||
# Make sure updated_on is updated when adding a note.
|
# Make sure updated_on is updated when adding a note.
|
||||||
updated_on_will_change!
|
updated_on_will_change!
|
||||||
@current_journal
|
@current_journal
|
||||||
|
@ -932,6 +934,7 @@ class Issue < ActiveRecord::Base
|
||||||
def create_journal
|
def create_journal
|
||||||
if @current_journal
|
if @current_journal
|
||||||
# attributes changes
|
# attributes changes
|
||||||
|
if @attributes_before_change
|
||||||
(Issue.column_names - %w(id root_id lft rgt lock_version created_on updated_on)).each {|c|
|
(Issue.column_names - %w(id root_id lft rgt lock_version created_on updated_on)).each {|c|
|
||||||
before = @attributes_before_change[c]
|
before = @attributes_before_change[c]
|
||||||
after = send(c)
|
after = send(c)
|
||||||
|
@ -941,6 +944,8 @@ class Issue < ActiveRecord::Base
|
||||||
:old_value => before,
|
:old_value => before,
|
||||||
:value => after)
|
:value => after)
|
||||||
}
|
}
|
||||||
|
end
|
||||||
|
if @custom_values_before_change
|
||||||
# custom fields changes
|
# custom fields changes
|
||||||
custom_values.each {|c|
|
custom_values.each {|c|
|
||||||
before = @custom_values_before_change[c.custom_field_id]
|
before = @custom_values_before_change[c.custom_field_id]
|
||||||
|
@ -951,6 +956,7 @@ class Issue < ActiveRecord::Base
|
||||||
:old_value => before,
|
:old_value => before,
|
||||||
:value => after)
|
:value => after)
|
||||||
}
|
}
|
||||||
|
end
|
||||||
@current_journal.save
|
@current_journal.save
|
||||||
# reset current journal
|
# reset current journal
|
||||||
init_journal @current_journal.user, @current_journal.notes
|
init_journal @current_journal.user, @current_journal.notes
|
||||||
|
|
Loading…
Reference in New Issue