To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.

Statistics Download as Zip
| Branch: | Tag: | Revision:

root / app / models / journal.rb @ 403:b15397a5341c

History | View | Annotate | Download (3.14 KB)

1
# redMine - project management software
2
# Copyright (C) 2006  Jean-Philippe Lang
3
#
4
# This program is free software; you can redistribute it and/or
5
# modify it under the terms of the GNU General Public License
6
# as published by the Free Software Foundation; either version 2
7
# of the License, or (at your option) any later version.
8
# 
9
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
# GNU General Public License for more details.
13
# 
14
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17

    
18
class Journal < ActiveRecord::Base
19
  belongs_to :journalized, :polymorphic => true
20
  # added as a quick fix to allow eager loading of the polymorphic association
21
  # since always associated to an issue, for now
22
  belongs_to :issue, :foreign_key => :journalized_id
23
  
24
  belongs_to :user
25
  has_many :details, :class_name => "JournalDetail", :dependent => :delete_all
26
  attr_accessor :indice
27
  
28
  acts_as_event :title => Proc.new {|o| status = ((s = o.new_status) ? " (#{s})" : nil); "#{o.issue.tracker} ##{o.issue.id}#{status}: #{o.issue.subject}" },
29
                :description => :notes,
30
                :author => :user,
31
                :type => Proc.new {|o| (s = o.new_status) ? (s.is_closed? ? 'issue-closed' : 'issue-edit') : 'issue-note' },
32
                :url => Proc.new {|o| {:controller => 'issues', :action => 'show', :id => o.issue.id, :anchor => "change-#{o.id}"}}
33

    
34
  acts_as_activity_provider :type => 'issues',
35
                            :permission => :view_issues,
36
                            :author_key => :user_id,
37
                            :find_options => {:include => [{:issue => :project}, :details, :user],
38
                                              :conditions => "#{Journal.table_name}.journalized_type = 'Issue' AND" +
39
                                                             " (#{JournalDetail.table_name}.prop_key = 'status_id' OR #{Journal.table_name}.notes <> '')"}
40
  
41
  def save(*args)
42
    # Do not save an empty journal
43
    (details.empty? && notes.blank?) ? false : super
44
  end
45
  
46
  # Returns the new status if the journal contains a status change, otherwise nil
47
  def new_status
48
    c = details.detect {|detail| detail.prop_key == 'status_id'}
49
    (c && c.value) ? IssueStatus.find_by_id(c.value.to_i) : nil
50
  end
51
  
52
  def new_value_for(prop)
53
    c = details.detect {|detail| detail.prop_key == prop}
54
    c ? c.value : nil
55
  end
56
  
57
  def editable_by?(usr)
58
    usr && usr.logged? && (usr.allowed_to?(:edit_issue_notes, project) || (self.user == usr && usr.allowed_to?(:edit_own_issue_notes, project)))
59
  end
60
  
61
  def project
62
    journalized.respond_to?(:project) ? journalized.project : nil
63
  end
64
  
65
  def attachments
66
    journalized.respond_to?(:attachments) ? journalized.attachments : nil
67
  end
68

    
69
  # Returns a string of css classes
70
  def css_classes
71
    s = 'journal'
72
    s << ' has-notes' unless notes.blank?
73
    s << ' has-details' unless details.blank?
74
    s
75
  end
76
end