issues_helper.rb 3.5 KB
Newer Older
G
gitlabhq 已提交
1
module IssuesHelper
2
  def issue_css_classes(issue)
D
Dmitriy Zaporozhets 已提交
3
    classes = "issue"
A
Andrew8xx8 已提交
4
    classes << " closed" if issue.closed?
D
Dmitriy Zaporozhets 已提交
5 6 7
    classes << " today" if issue.today?
    classes
  end
8

9 10 11 12
  # 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
13
    OpenStruct.new(id: 0, title: 'None (backlog)', name: 'Unassigned')
14
  end
15

16
  def url_for_project_issues(project = @project, options = {})
S
skv 已提交
17
    return '' if project.nil?
18

19 20 21 22 23
    if options[:only_path]
      project.issues_tracker.project_path
    else
      project.issues_tracker.project_url
    end
24 25
  end

26
  def url_for_new_issue(project = @project, options = {})
S
skv 已提交
27
    return '' if project.nil?
28

29 30 31 32 33
    if options[:only_path]
      project.issues_tracker.new_issue_path
    else
      project.issues_tracker.new_issue_url
    end
34 35
  end

36
  def url_for_issue(issue_iid, project = @project, options = {})
S
skv 已提交
37
    return '' if project.nil?
A
Andrew8xx8 已提交
38

39 40 41 42 43
    if options[:only_path]
      project.issues_tracker.issue_path(issue_iid)
    else
      project.issues_tracker.issue_url(issue_iid)
    end
44 45
  end

46
  def bulk_update_milestone_options
47 48 49 50
    milestones = project_active_milestones.to_a
    milestones.unshift(Milestone::None)

    options_from_collection_for_select(milestones, 'id', 'title', params[:milestone_id])
51 52
  end

53
  def milestone_options(object)
54 55 56 57
    milestones = object.project.milestones.active.to_a
    milestones.unshift(Milestone::None)

    options_from_collection_for_select(milestones, 'id', 'title', object.milestone_id)
58
  end
D
Dmitriy Zaporozhets 已提交
59

60
  def status_box_class(item)
D
Dmitriy Zaporozhets 已提交
61
    if item.respond_to?(:expired?) && item.expired?
62
      'status-box-expired'
D
Dmitriy Zaporozhets 已提交
63
    elsif item.respond_to?(:merged?) && item.merged?
64
      'status-box-merged'
D
Dmitriy Zaporozhets 已提交
65
    elsif item.closed?
66
      'status-box-closed'
D
Dmitriy Zaporozhets 已提交
67
    else
68
      'status-box-open'
D
Dmitriy Zaporozhets 已提交
69 70
    end
  end
D
Dmitriy Zaporozhets 已提交
71 72 73

  def issue_to_atom(xml, issue)
    xml.entry do
V
Vinnie Okada 已提交
74 75 76 77
      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)
D
Dmitriy Zaporozhets 已提交
78 79
      xml.title   truncate(issue.title, length: 80)
      xml.updated issue.created_at.strftime("%Y-%m-%dT%H:%M:%SZ")
80
      xml.media   :thumbnail, width: "40", height: "40", url: image_url(avatar_icon(issue.author_email))
D
Dmitriy Zaporozhets 已提交
81 82 83 84 85 86 87
      xml.author do |author|
        xml.name issue.author_name
        xml.email issue.author_email
      end
      xml.summary issue.title
    end
  end
R
Robert Speicher 已提交
88

89
  def merge_requests_sentence(merge_requests)
90 91 92 93 94
    # 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 ')
95 96
  end

97 98 99
  def emoji_icon(name, unicode = nil)
    unicode ||= Emoji.emoji_filename(name)

V
Valery Sizov 已提交
100 101 102 103
    content_tag :div, "",
      class: "icon emoji-icon emoji-#{unicode}",
      "data-emoji" => name,
      "data-unicode-name" => unicode
V
Valery Sizov 已提交
104 105
  end

V
Valery Sizov 已提交
106 107
  def emoji_author_list(notes, current_user)
    list = notes.map do |note|
D
Douwe Maan 已提交
108
             note.author == current_user ? "me" : note.author.name
V
Valery Sizov 已提交
109 110 111 112 113
           end

    list.join(", ")
  end

V
Valery Sizov 已提交
114
  def note_active_class(notes, current_user)
V
Valery Sizov 已提交
115 116 117 118 119
    if current_user && notes.pluck(:author_id).include?(current_user.id)
      "active"
    else
      ""
    end
V
Valery Sizov 已提交
120 121
  end

122
  # Required for Banzai::Filter::IssueReferenceFilter
R
Robert Speicher 已提交
123
  module_function :url_for_issue
G
gitlabhq 已提交
124
end