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

83
  def link_to_toggle_star(title, starred)
P
Phil Hughes 已提交
84
    cls = 'star-btn btn btn-sm btn-default'
85

86 87 88 89 90 91
    toggle_text =
      if starred
        ' Unstar'
      else
        ' Star'
      end
92

93
    toggle_html = content_tag('span', class: 'toggle') do
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
    path = toggle_star_namespace_project_path(@project.namespace, @project)
110

C
Ciro Santilli 已提交
111
    content_tag 'span', class: starred ? 'turn-on' : 'turn-off' do
112
      link_to(path, link_opts) do
D
Dmitriy Zaporozhets 已提交
113
        toggle_html + ' ' + count_html
C
Ciro Santilli 已提交
114 115 116 117
      end
    end
  end

C
Ciro Santilli 已提交
118
  def link_to_toggle_fork
D
Dmitriy Zaporozhets 已提交
119 120 121 122 123
    html = content_tag('span') do
      icon('code-fork') + ' Fork'
    end

    count_html = content_tag(:span, class: 'count') do
C
Ciro Santilli 已提交
124 125
      @project.forks_count.to_s
    end
D
Dmitriy Zaporozhets 已提交
126 127

    html + count_html
C
Ciro Santilli 已提交
128 129
  end

130 131 132 133 134
  private

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

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

151
    if project.issues_enabled || project.merge_requests_enabled
152 153 154
      nav_tabs << [:milestones, :labels]
    end

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

  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
173

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

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

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

228 229 230
  def default_clone_protocol
    current_user ? "ssh" : "http"
  end
231 232 233

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

  def contribution_guide_url(project)
241
    if project && contribution_guide = project.repository.contribution_guide
V
Vinnie Okada 已提交
242 243 244 245
      namespace_project_blob_path(
        project.namespace,
        project,
        tree_join(project.default_branch,
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 278 279
                  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 已提交
280
      )
D
Dmitriy Zaporozhets 已提交
281 282
    end
  end
283 284 285

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

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

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

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

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