X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/453f758f91d57688663e354a54061a65945410e7..e74163d036a0520de62667b2e77ffbe66bc7c72d:/app/models/issue.rb diff --git a/app/models/issue.rb b/app/models/issue.rb index 1726e690f..6de535e81 100644 --- a/app/models/issue.rb +++ b/app/models/issue.rb @@ -1,20 +1,25 @@ class Issue < ActiveRecord::Base belongs_to :reportable, :polymorphic => true + belongs_to :user, :class_name => "User", :foreign_key => :reported_user_id + has_many :reports + has_many :comments, :class_name => "IssueComment" + validates :reportable_id, :uniqueness => { :scope => [ :reportable_type ] } - belongs_to :user_id + 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 @@ -36,8 +41,8 @@ class Issue < ActiveRecord::Base event :reopen do transitions :from => :resolved, :to => :open + transitions :from => :ignored, :to => :open end end - end