projects_helper.rb 8.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)
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 149 150
      nav_tabs << feature if project.send :"#{feature}_enabled"
    end

    nav_tabs.flatten
  end
151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166

  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
167

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

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

217 218 219
  def default_url_to_repo(project = nil)
    project = project || @project
    current_user ? project.url_to_repo : project.http_url_to_repo
220
  end
221

222 223 224
  def default_clone_protocol
    current_user ? "ssh" : "http"
  end
225 226 227

  def project_last_activity(project)
    if project.last_activity_at
228
      time_ago_with_tooltip(project.last_activity_at, 'bottom', 'last_activity_time_ago')
229 230 231 232
    else
      "Never"
    end
  end
D
Dmitriy Zaporozhets 已提交
233 234

  def contribution_guide_url(project)
235
    if project && contribution_guide = project.repository.contribution_guide
V
Vinnie Okada 已提交
236 237 238 239
      namespace_project_blob_path(
        project.namespace,
        project,
        tree_join(project.default_branch,
240 241 242 243 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
                  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 已提交
274
      )
D
Dmitriy Zaporozhets 已提交
275 276
    end
  end
277 278 279

  def hidden_pass_url(original_url)
    result = URI(original_url)
U
uran 已提交
280
    result.password = '*****' unless result.password.nil?
281
    result
U
uran 已提交
282 283
  rescue
    original_url
284
  end
285 286 287

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

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

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

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