gitlab-org--gitlab-foss/app/helpers/issues_helper.rb

142 lines
3.9 KiB
Ruby
Raw Normal View History

2011-10-08 17:36:38 -04:00
module IssuesHelper
def issue_css_classes(issue)
2012-06-21 01:29:53 -04:00
classes = "issue"
2013-02-18 04:10:58 -05:00
classes << " closed" if issue.closed?
2012-06-21 01:29:53 -04:00
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
def url_for_project_issues(project = @project, options = {})
2014-05-26 08:40:10 -04:00
return '' if project.nil?
if options[:only_path]
project.issues_tracker.project_path
else
project.issues_tracker.project_url
end
end
def url_for_new_issue(project = @project, options = {})
2014-05-26 08:40:10 -04:00
return '' if project.nil?
if options[:only_path]
project.issues_tracker.new_issue_path
else
project.issues_tracker.new_issue_url
end
end
def url_for_issue(issue_iid, project = @project, options = {})
2014-05-26 08:40:10 -04:00
return '' if project.nil?
2013-02-11 08:32:29 -05:00
if options[:only_path]
project.issues_tracker.issue_path(issue_iid)
else
project.issues_tracker.issue_url(issue_iid)
end
2013-01-23 09:13:28 -05:00
end
def bulk_update_milestone_options
milestones = project_active_milestones.to_a
milestones.unshift(Milestone::None)
options_from_collection_for_select(milestones, 'id', 'title', params[:milestone_id])
end
def milestone_options(object)
milestones = object.project.milestones.active.to_a
milestones.unshift(Milestone::None)
options_from_collection_for_select(milestones, 'id', 'title', object.milestone_id)
end
def status_box_class(item)
if item.respond_to?(:expired?) && item.expired?
'status-box-expired'
elsif item.respond_to?(:merged?) && item.merged?
'status-box-merged'
elsif item.closed?
'status-box-closed'
else
'status-box-open'
end
end
def issue_button_visibility(issue, closed)
return 'hidden' if issue.closed? == closed
end
def issue_to_atom(xml, issue)
xml.entry do
xml.id namespace_project_issue_url(issue.project.namespace,
issue.project, issue)
xml.link href: namespace_project_issue_url(issue.project.namespace,
issue.project, issue)
xml.title truncate(issue.title, length: 80)
xml.updated issue.created_at.strftime("%Y-%m-%dT%H:%M:%SZ")
xml.media :thumbnail, width: "40", height: "40", url: image_url(avatar_icon(issue.author_email))
xml.author do |author|
xml.name issue.author_name
xml.email issue.author_email
end
xml.summary issue.title
end
end
def merge_requests_sentence(merge_requests)
# 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 ')
end
2015-12-24 04:28:51 -05:00
def emoji_icon(name, unicode = nil, aliases = [])
2016-01-04 07:06:48 -05:00
unicode ||= Emoji.emoji_filename(name) rescue ""
2015-12-22 12:39:15 -05:00
content_tag :div, "",
class: "icon emoji-icon emoji-#{unicode}",
"data-emoji" => name,
2015-12-24 04:28:51 -05:00
"data-aliases" => aliases.join(" "),
2015-12-22 12:39:15 -05:00
"data-unicode-name" => unicode
2015-11-11 08:12:51 -05:00
end
2015-11-18 08:43:53 -05:00
def emoji_author_list(notes, current_user)
list = notes.map do |note|
2015-12-02 07:59:21 -05:00
note.author == current_user ? "me" : note.author.name
2015-11-18 08:43:53 -05:00
end
list.join(", ")
end
2015-11-18 17:59:07 -05:00
def note_active_class(notes, current_user)
2015-11-19 06:20:09 -05:00
if current_user && notes.pluck(:author_id).include?(current_user.id)
"active"
else
""
end
2015-11-18 17:59:07 -05:00
end
2015-12-25 05:08:53 -05:00
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
# Required for Banzai::Filter::IssueReferenceFilter
2015-04-30 17:27:33 -04:00
module_function :url_for_issue
2011-10-08 17:36:38 -04:00
end