projects_helper.rb 7.0 KB
Newer Older
R
randx 已提交
1
module ProjectsHelper
2 3
  def remove_from_project_team_message(project, user)
    "You are going to remove #{user.name} from #{project.name} project team. Are you sure?"
D
Dmitriy Zaporozhets 已提交
4
  end
5 6

  def link_to_project project
7
    link_to project do
8
      title = content_tag(:span, project.name, class: 'project-name')
9 10

      if project.namespace
D
Dmitriy Zaporozhets 已提交
11
        namespace = content_tag(:span, "#{project.namespace.human_name} / ", class: 'namespace-name')
12 13 14 15 16
        title = namespace + title
      end

      title
    end
17
  end
R
randx 已提交
18

19
  def link_to_member(project, author, opts = {})
20
    default_opts = { avatar: true, name: true, size: 16 }
21 22
    opts = default_opts.merge(opts)

23 24
    return "(deleted)" unless author

25 26
    author_html =  ""

27
    # Build avatar image tag
S
Steven Thonus 已提交
28
    author_html << image_tag(avatar_icon(author.try(:email), opts[:size]), width: opts[:size], class: "avatar avatar-inline #{"s#{opts[:size]}" if opts[:size]}", alt:'') if opts[:avatar]
29

30
    # Build name span tag
31
    author_html << content_tag(:span, sanitize(author.name), class: 'author') if opts[:name]
32

33
    author_html = author_html.html_safe
34

35 36 37 38 39
    if opts[:name]
      link_to(author_html, user_path(author), class: "author_link").html_safe
    else
      link_to(author_html, user_path(author), class: "author_link has_tooltip", data: { :'original-title' => sanitize(author.name) } ).html_safe
    end
R
randx 已提交
40
  end
41 42 43

  def project_title project
    if project.group
44
      content_tag :span do
45
        link_to(simple_sanitize(project.group.name), group_path(project.group)) + " / " + project.name
46
      end
47
    else
48 49 50 51
      owner = project.namespace.owner
      content_tag :span do
        link_to(simple_sanitize(owner.name), user_path(owner)) + " / " + project.name
      end
52 53
    end
  end
54 55 56 57

  def remove_project_message(project)
    "You are going to remove #{project.name_with_namespace}.\n Removed project CANNOT be restored!\n Are you ABSOLUTELY sure?"
  end
58 59 60 61 62 63 64 65 66

  def project_nav_tabs
    @nav_tabs ||= get_project_nav_tabs(@project, current_user)
  end

  def project_nav_tab?(name)
    project_nav_tabs.include? name
  end

67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85
  def selected_label?(label_name)
    params[:label_name].to_s.split(',').include?(label_name)
  end

  def labels_filter_path(label_name)
    label_name =
      if selected_label?(label_name)
        params[:label_name].split(',').reject { |l| l == label_name }.join(',')
      elsif params[:label_name].present?
        "#{params[:label_name]},#{label_name}"
      else
        label_name
      end

    project_filter_path(label_name: label_name)
  end

  def label_filter_class(label_name)
    if selected_label?(label_name)
86
      'label-filter-item active'
87
    else
88
      'label-filter-item light'
89 90 91
    end
  end

92 93 94 95 96 97
  def project_filter_path(options={})
    exist_opts = {
      state: params[:state],
      scope: params[:scope],
      label_name: params[:label_name],
      milestone_id: params[:milestone_id],
98 99
      assignee_id: params[:assignee_id],
      sort: params[:sort],
100 101 102 103 104 105 106 107 108 109
    }

    options = exist_opts.merge(options)

    path = request.path
    path << "?#{options.to_param}"
    path
  end

  def project_active_milestones
110
    @project.milestones.active.order("due_date, title ASC")
111 112
  end

113
  def project_issues_trackers(current_tracker = nil)
114 115 116 117 118 119 120 121
    values = Project.issues_tracker.values.map do |tracker_key|
      if tracker_key.to_sym == :gitlab
        ['GitLab', tracker_key]
      else
        [Gitlab.config.issues_tracker[tracker_key]['title'] || tracker_key, tracker_key]
      end
    end

122
    options_for_select(values, current_tracker)
123 124
  end

C
Ciro Santilli 已提交
125
  def link_to_toggle_star(title, starred, signed_in)
126
    cls = 'btn btn-block'
C
Ciro Santilli 已提交
127
    cls += ' disabled' unless signed_in
128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151

    toggle_html = content_tag('span', class: 'toggle') do
      toggle_text = if starred
                      'Unstar'
                    else
                      'Star'
                    end

      content_tag('i', ' ', class: 'icon-star') + toggle_text
    end

    count_html = content_tag('span', class: 'count') do
      @project.star_count.to_s
    end

    link_opts = {
      title: title,
      class: cls,
      method: :post,
      remote: true,
      data: {type: 'json'}
    }


C
Ciro Santilli 已提交
152
    content_tag 'span', class: starred ? 'turn-on' : 'turn-off' do
153 154
      link_to toggle_star_project_path(@project), link_opts do
        toggle_html + count_html
C
Ciro Santilli 已提交
155 156 157 158
      end
    end
  end

159 160 161 162 163
  private

  def get_project_nav_tabs(project, current_user)
    nav_tabs = [:home]

164
    if !project.empty_repo? && can?(current_user, :download_code, project)
165 166 167 168 169 170 171 172 173 174 175
      nav_tabs << [:files, :commits, :network, :graphs]
    end

    if project.repo_exists? && project.merge_requests_enabled
      nav_tabs << :merge_requests
    end

    if can?(current_user, :admin_project, project)
      nav_tabs << :settings
    end

D
Dmitriy Zaporozhets 已提交
176
    [:issues, :wiki, :snippets].each do |feature|
177 178 179 180 181
      nav_tabs << feature if project.send :"#{feature}_enabled"
    end

    nav_tabs.flatten
  end
182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197

  def git_user_name
    if current_user
      current_user.name
    else
      "Your name"
    end
  end

  def git_user_email
    if current_user
      current_user.email
    else
      "your@email.com"
    end
  end
198

199
  def repository_size(project = nil)
200
    "#{(project || @project).repository_size} MB"
201 202 203 204 205 206
  rescue
    # In order to prevent 500 error
    # when application cannot allocate memory
    # to calculate repo size - just show 'Unknown'
    'unknown'
  end
207 208 209 210 211 212 213 214

  def project_head_title
    title = @project.name_with_namespace

    title = if current_controller?(:tree)
              "#{@project.path}\/#{@path} at #{@ref} - " + title
            elsif current_controller?(:issues)
              if current_action?(:show)
215
                "Issue ##{@issue.iid} - #{@issue.title} - " + title
216 217 218 219 220 221
              else
                "Issues - " + title
              end
            elsif current_controller?(:blob)
              "#{@project.path}\/#{@blob.path} at #{@ref} - " + title
            elsif current_controller?(:commits)
D
Dmitriy Zaporozhets 已提交
222
              "Commits at #{@ref} - " + title
223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240
            elsif current_controller?(:merge_requests)
              if current_action?(:show)
                "Merge request ##{@merge_request.iid} - " + title
              else
                "Merge requests - " + title
              end
            elsif current_controller?(:wikis)
              "Wiki - " + title
            elsif current_controller?(:network)
              "Network graph - " + title
            elsif current_controller?(:graphs)
              "Graphs - " + title
            else
              title
            end

    title
  end
241

242 243 244
  def default_url_to_repo(project = nil)
    project = project || @project
    current_user ? project.url_to_repo : project.http_url_to_repo
245
  end
246

247 248 249
  def default_clone_protocol
    current_user ? "ssh" : "http"
  end
250 251 252

  def project_last_activity(project)
    if project.last_activity_at
253
      time_ago_with_tooltip(project.last_activity_at, 'bottom', 'last_activity_time_ago')
254 255 256 257
    else
      "Never"
    end
  end
D
Dmitriy Zaporozhets 已提交
258 259 260 261 262 263

  def contribution_guide_url(project)
    if project && project.repository.contribution_guide
      project_blob_path(project, tree_join(project.default_branch, project.repository.contribution_guide.name))
    end
  end
R
randx 已提交
264
end