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