X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/d1d4f8192da5a266cddb17bb8970b2b04387888c..f3519e97819cc5a5e2c2f9931c7d565b8e5227c8:/app/models/issue.rb?ds=sidebyside diff --git a/app/models/issue.rb b/app/models/issue.rb index a9e2d2405..690a02477 100644 --- a/app/models/issue.rb +++ b/app/models/issue.rb @@ -1,24 +1,26 @@ class Issue < ActiveRecord::Base belongs_to :reportable, :polymorphic => true belongs_to :user, :class_name => "User", :foreign_key => :reported_user_id + belongs_to :user_updated, :class_name => "User", :foreign_key => :updated_by - has_many :reports - has_many :comments, :class_name => "IssueComment" + has_many :reports, dependent: :destroy + has_many :comments, :class_name => "IssueComment", dependent: :destroy validates :reportable_id, :uniqueness => { :scope => [ :reportable_type ] } validates :reported_user_id, :presence => true # Check if more statuses are needed enum status: %w( open ignored resolved ) + enum type: %w( administrator moderator ) scope :with_status, -> (issue_status) { where(:status => statuses[issue_status])} def read_reports - resolved_at.present? ? reports.where("created_at < ?", resolved_at) : nil + resolved_at.present? ? reports.where("updated_at < ?", resolved_at) : nil end def unread_reports - resolved_at.present? ? reports.where("created_at >= ?", resolved_at) : reports + resolved_at.present? ? reports.where("updated_at >= ?", resolved_at) : reports end include AASM @@ -40,8 +42,8 @@ class Issue < ActiveRecord::Base event :reopen do transitions :from => :resolved, :to => :open + transitions :from => :ignored, :to => :open end end - end