debian-mirror-gitlab/app/helpers/issues_helper.rb

164 lines
4.4 KiB
Ruby
Raw Normal View History

2014-09-02 18:07:02 +05:30
module IssuesHelper
2015-04-26 12:48:37 +05:30
def issue_css_classes(issue)
2014-09-02 18:07:02 +05:30
classes = "issue"
classes << " closed" if issue.closed?
classes << " today" if issue.today?
classes
end
# Returns an OpenStruct object suitable for use by <tt>options_from_collection_for_select</tt>
# to allow filtering issues by an unassigned User or Milestone
def unassigned_filter
# Milestone uses :title, Issue uses :name
OpenStruct.new(id: 0, title: 'None (backlog)', name: 'Unassigned')
end
2015-04-26 12:48:37 +05:30
def url_for_issue(issue_iid, project = @project, options = {})
2014-09-02 18:07:02 +05:30
return '' if project.nil?
2016-06-02 11:05:42 +05:30
url =
if options[:only_path]
project.issues_tracker.issue_path(issue_iid)
else
project.issues_tracker.issue_url(issue_iid)
end
# Ensure we return a valid URL to prevent possible XSS.
URI.parse(url).to_s
rescue URI::InvalidURIError
''
2014-09-02 18:07:02 +05:30
end
def bulk_update_milestone_options
2016-04-02 18:10:28 +05:30
milestones = @project.milestones.active.reorder(due_date: :asc, title: :asc).to_a
2015-12-23 02:04:40 +05:30
milestones.unshift(Milestone::None)
options_from_collection_for_select(milestones, 'id', 'title', params[:milestone_id])
2014-09-02 18:07:02 +05:30
end
2015-04-26 12:48:37 +05:30
def milestone_options(object)
2016-04-02 18:10:28 +05:30
milestones = object.project.milestones.active.reorder(due_date: :asc, title: :asc).to_a
2016-06-02 11:05:42 +05:30
milestones.unshift(object.milestone) if object.milestone.present? && object.milestone.closed?
2015-12-23 02:04:40 +05:30
milestones.unshift(Milestone::None)
options_from_collection_for_select(milestones, 'id', 'title', object.milestone_id)
2014-09-02 18:07:02 +05:30
end
2016-06-02 11:05:42 +05:30
def project_options(issuable, current_user, ability: :read_project)
projects = current_user.authorized_projects
projects = projects.select do |project|
current_user.can?(ability, project)
end
no_project = OpenStruct.new(id: 0, name_with_namespace: 'No project')
projects.unshift(no_project)
projects.delete(issuable.project)
options_from_collection_for_select(projects, :id, :name_with_namespace)
end
2015-12-23 02:04:40 +05:30
def status_box_class(item)
2014-09-02 18:07:02 +05:30
if item.respond_to?(:expired?) && item.expired?
2015-12-23 02:04:40 +05:30
'status-box-expired'
2014-09-02 18:07:02 +05:30
elsif item.respond_to?(:merged?) && item.merged?
2015-12-23 02:04:40 +05:30
'status-box-merged'
2014-09-02 18:07:02 +05:30
elsif item.closed?
2015-12-23 02:04:40 +05:30
'status-box-closed'
2014-09-02 18:07:02 +05:30
else
2015-12-23 02:04:40 +05:30
'status-box-open'
2014-09-02 18:07:02 +05:30
end
end
2015-04-26 12:48:37 +05:30
2016-04-02 18:10:28 +05:30
def issue_button_visibility(issue, closed)
return 'hidden' if issue.closed? == closed
end
2015-10-24 18:46:33 +05:30
def merge_requests_sentence(merge_requests)
2015-12-23 02:04:40 +05:30
# Sorting based on the `!123` or `group/project!123` reference will sort
# local merge requests first.
merge_requests.map do |merge_request|
merge_request.to_reference(@project)
end.sort.to_sentence(last_word_connector: ', or ')
2015-10-24 18:46:33 +05:30
end
2016-06-02 11:05:42 +05:30
def confidential_icon(issue)
icon('eye-slash') if issue.confidential?
end
def emoji_icon(name, unicode = nil, aliases = [], sprite: true)
2016-08-24 12:49:21 +05:30
unicode ||= Gitlab::Emoji.emoji_filename(name) rescue ""
2016-06-02 11:05:42 +05:30
data = {
aliases: aliases.join(" "),
emoji: name,
unicode_name: unicode
}
if sprite
# Emoji icons for the emoji menu, these use a spritesheet.
content_tag :div, "",
class: "icon emoji-icon emoji-#{unicode}",
title: name,
data: data
else
# Emoji icons displayed separately, used for the awards already given
# to an issue or merge request.
content_tag :img, "",
class: "icon emoji",
title: name,
height: "20px",
width: "20px",
src: url_to_image("#{unicode}.png"),
data: data
end
2015-11-26 14:37:03 +05:30
end
2016-11-03 12:29:30 +05:30
def award_user_list(awards, current_user, limit: 10)
2016-09-29 09:46:39 +05:30
names = awards.map do |award|
award.user == current_user ? 'You' : award.user.name
end
current_user_name = names.delete('You')
2016-11-03 12:29:30 +05:30
names = names.insert(0, current_user_name).compact.first(limit)
2016-09-29 09:46:39 +05:30
names << "#{awards.size - names.size} more." if awards.size > names.size
names.to_sentence
2015-11-26 14:37:03 +05:30
end
def award_active_class(awards, current_user)
if current_user && awards.find { |a| a.user_id == current_user.id }
2015-11-26 14:37:03 +05:30
"active"
else
""
end
end
def awards_sort(awards)
awards.sort_by do |award, notes|
if award == "thumbsup"
0
elsif award == "thumbsdown"
1
else
2
end
end.to_h
end
2016-06-02 11:05:42 +05:30
def due_date_options
options = [
Issue::AnyDueDate,
Issue::NoDueDate,
Issue::DueThisWeek,
Issue::DueThisMonth,
Issue::Overdue
]
options_from_collection_for_select(options, 'name', 'title', params[:due_date])
end
2015-12-23 02:04:40 +05:30
# Required for Banzai::Filter::IssueReferenceFilter
2015-09-11 14:41:01 +05:30
module_function :url_for_issue
2014-09-02 18:07:02 +05:30
end