gitlabhq/app/models/concerns/issuable.rb

108 lines
2.2 KiB
Ruby
Raw Normal View History

2013-01-03 09:06:07 +02:00
# == Issuable concern
2012-12-30 16:19:31 +02:00
#
# Contains common functionality shared between Issues and MergeRequests
2012-12-30 16:19:31 +02:00
#
# Used by Issue, MergeRequest
#
2013-01-03 09:06:07 +02:00
module Issuable
extend ActiveSupport::Concern
included do
belongs_to :project
belongs_to :author, class_name: "User"
belongs_to :assignee, class_name: "User"
belongs_to :milestone
has_many :notes, as: :noteable, dependent: :destroy
2012-10-09 04:10:04 +04:00
validates :project, presence: true
validates :author, presence: true
validates :title, presence: true, length: { within: 0..255 }
2012-09-05 03:14:24 -07:00
validates :closed, inclusion: { in: [true, false] }
2013-02-12 11:16:45 +04:00
scope :opened, -> { where(closed: false) }
scope :closed, -> { where(closed: true) }
scope :of_group, ->(group) { where(project_id: group.project_ids) }
scope :of_user_team, ->(team) { where(project_id: team.project_ids, assignee_id: team.member_ids) }
2012-10-04 13:40:40 +03:00
scope :assigned, ->(u) { where(assignee_id: u.id)}
2013-02-12 11:16:45 +04:00
scope :recent, -> { order("created_at DESC") }
delegate :name,
:email,
to: :author,
prefix: true
delegate :name,
:email,
to: :assignee,
allow_nil: true,
prefix: true
attr_accessor :author_id_of_changes
end
module ClassMethods
def search(query)
where("title like :query", query: "%#{query}%")
end
end
def today?
Date.today == created_at.to_date
end
def new?
today? && created_at == updated_at
end
def is_assigned?
!!assignee_id
end
def is_being_reassigned?
assignee_id_changed?
end
def is_being_closed?
closed_changed? && closed
end
def is_being_reopened?
closed_changed? && !closed
end
#
# Votes
#
# Return the number of -1 comments (downvotes)
def downvotes
notes.select(&:downvote?).size
2013-01-03 09:06:07 +02:00
end
def downvotes_in_percent
2013-01-03 09:06:07 +02:00
if votes_count.zero?
0
else
100.0 - upvotes_in_percent
2013-01-03 09:06:07 +02:00
end
end
# Return the number of +1 comments (upvotes)
def upvotes
notes.select(&:upvote?).size
2013-01-03 09:06:07 +02:00
end
def upvotes_in_percent
2013-01-03 09:06:07 +02:00
if votes_count.zero?
0
else
100.0 / votes_count * upvotes
2013-01-03 09:06:07 +02:00
end
end
# Return the total number of votes
def votes_count
upvotes + downvotes
end
end