X-Git-Url: https://git.openstreetmap.org./rails.git/blobdiff_plain/faf4c5aa7a3c75b89d32b7d2205d004f9aa99cb7..ed84930283982062753e8fbd7323239d70dd1611:/app/models/issue.rb?ds=sidebyside diff --git a/app/models/issue.rb b/app/models/issue.rb index cd3f5150d..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 @@ -44,5 +46,4 @@ class Issue < ActiveRecord::Base end end - end