projects_helper.rb 8.1 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)
V
Vinnie Okada 已提交
7
    link_to [project.namespace.becomes(Namespace), 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
  def project_title(project)
43
    if project.group
44
      content_tag :span do
V
Vinnie Okada 已提交
45 46 47 48
        link_to(
          simple_sanitize(project.group.name), group_path(project.group)
        ) + ' / ' +
          link_to(simple_sanitize(project.name),
49
                  project_path(project))
50
      end
51
    else
52 53
      owner = project.namespace.owner
      content_tag :span do
V
Vinnie Okada 已提交
54 55 56 57
        link_to(
          simple_sanitize(owner.name), user_path(owner)
        ) + ' / ' +
          link_to(simple_sanitize(project.name),
58
                  project_path(project))
59
      end
60 61
    end
  end
62 63 64 65

  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
66

67 68 69 70
  def transfer_project_message(project)
    "You are going to transfer #{project.name_with_namespace} to another owner. Are you ABSOLUTELY sure?"
  end

71 72 73 74 75 76 77 78
  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

79
  def project_active_milestones
80
    @project.milestones.active.order("due_date, title ASC")
81 82
  end

C
Ciro Santilli 已提交
83
  def link_to_toggle_star(title, starred, signed_in)
D
Dmitriy Zaporozhets 已提交
84
    cls = 'star-btn'
85
    cls << ' disabled' unless signed_in
86 87 88

    toggle_html = content_tag('span', class: 'toggle') do
      toggle_text = if starred
89
                      ' Unstar'
90
                    else
91
                      ' Star'
92 93
                    end

94
      icon('star') + toggle_text
95 96 97 98 99 100 101 102 103 104 105
    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,
106
      data: { type: 'json' }
107 108 109
    }


C
Ciro Santilli 已提交
110
    content_tag 'span', class: starred ? 'turn-on' : 'turn-off' do
V
Vinnie Okada 已提交
111 112 113 114
      link_to(
        toggle_star_namespace_project_path(@project.namespace, @project),
        link_opts
      ) do
D
Dmitriy Zaporozhets 已提交
115
        toggle_html + ' ' + count_html
C
Ciro Santilli 已提交
116 117 118 119
      end
    end
  end

C
Ciro Santilli 已提交
120
  def link_to_toggle_fork
121
    out = icon('code-fork')
C
Ciro Santilli 已提交
122 123 124 125 126 127
    out << ' Fork'
    out << content_tag(:span, class: 'count') do
      @project.forks_count.to_s
    end
  end

128 129 130 131 132
  private

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

133
    if !project.empty_repo? && can?(current_user, :download_code, project)
134 135 136 137 138 139 140 141 142 143 144
      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 已提交
145
    [:issues, :wiki, :snippets].each do |feature|
146 147 148
      nav_tabs << feature if project.send :"#{feature}_enabled"
    end

149 150 151 152
    if project.issues_enabled
      nav_tabs << [:milestones, :labels]
    end

153 154
    nav_tabs.flatten
  end
155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170

  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
171

172
  def repository_size(project = nil)
173
    "#{(project || @project).repository_size} MB"
174 175 176 177 178 179
  rescue
    # In order to prevent 500 error
    # when application cannot allocate memory
    # to calculate repo size - just show 'Unknown'
    'unknown'
  end
180 181 182 183 184 185 186 187

  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)
188
                "Issue ##{@issue.iid} - #{@issue.title} - " + title
189 190 191 192
              else
                "Issues - " + title
              end
            elsif current_controller?(:blob)
D
Dmitriy Zaporozhets 已提交
193 194
              if current_action?(:new) || current_action?(:create)
                "New file at #{@ref}"
195 196
              elsif current_action?(:show)
                "#{@blob.path} at #{@ref}"
D
Dmitriy Zaporozhets 已提交
197 198 199
              elsif @blob
                "Edit file #{@blob.path} at #{@ref}"
              end
200
            elsif current_controller?(:commits)
D
Dmitriy Zaporozhets 已提交
201
              "Commits at #{@ref} - " + title
202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219
            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
220

221 222 223
  def default_url_to_repo(project = nil)
    project = project || @project
    current_user ? project.url_to_repo : project.http_url_to_repo
224
  end
225

226 227 228
  def default_clone_protocol
    current_user ? "ssh" : "http"
  end
229 230 231

  def project_last_activity(project)
    if project.last_activity_at
232
      time_ago_with_tooltip(project.last_activity_at, 'bottom', 'last_activity_time_ago')
233 234 235 236
    else
      "Never"
    end
  end
D
Dmitriy Zaporozhets 已提交
237 238

  def contribution_guide_url(project)
239
    if project && contribution_guide = project.repository.contribution_guide
V
Vinnie Okada 已提交
240 241 242 243
      namespace_project_blob_path(
        project.namespace,
        project,
        tree_join(project.default_branch,
244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277
                  contribution_guide.name)
      )
    end
  end

  def changelog_url(project)
    if project && changelog = project.repository.changelog
      namespace_project_blob_path(
        project.namespace,
        project,
        tree_join(project.default_branch,
                  changelog.name)
      )
    end
  end

  def license_url(project)
    if project && license = project.repository.license
      namespace_project_blob_path(
        project.namespace,
        project,
        tree_join(project.default_branch,
                  license.name)
      )
    end
  end

  def version_url(project)
    if project && version = project.repository.version
      namespace_project_blob_path(
        project.namespace,
        project,
        tree_join(project.default_branch,
                  version.name)
V
Vinnie Okada 已提交
278
      )
D
Dmitriy Zaporozhets 已提交
279 280
    end
  end
281 282 283

  def hidden_pass_url(original_url)
    result = URI(original_url)
U
uran 已提交
284
    result.password = '*****' unless result.password.nil?
285
    result
U
uran 已提交
286 287
  rescue
    original_url
288
  end
289 290 291

  def project_wiki_path_with_version(proj, page, version, is_newest)
    url_params = is_newest ? {} : { version_id: version }
V
Vinnie Okada 已提交
292
    namespace_project_wiki_path(proj.namespace, proj, page, url_params)
293
  end
294

V
Valery Sizov 已提交
295 296 297 298 299 300 301 302 303 304
  def project_status_css_class(status)
    case status
    when "started"
      "active"
    when "failed"
      "danger"
    when "finished"
      "success"
    end
  end
305 306 307 308 309 310 311 312 313 314

  def service_field_value(type, value)
    return value unless type == 'password'

    if value.present?
      "***********"
    else
      nil
    end
  end
R
randx 已提交
315
end