2014-07-23 04:34:28 -04:00
|
|
|
# encoding: utf-8
|
2011-10-08 17:36:38 -04:00
|
|
|
module CommitsHelper
|
2013-03-31 16:46:54 -04:00
|
|
|
# Returns a link to the commit author. If the author has a matching user and
|
|
|
|
# is a member of the current @project it will link to the team member page.
|
|
|
|
# Otherwise it will link to the author email as specified in the commit.
|
|
|
|
#
|
|
|
|
# options:
|
|
|
|
# avatar: true will prepend the avatar image
|
|
|
|
# size: size of the avatar image in px
|
|
|
|
def commit_author_link(commit, options = {})
|
|
|
|
commit_person_link(commit, options.merge(source: :author))
|
|
|
|
end
|
|
|
|
|
|
|
|
# Just like #author_link but for the committer.
|
|
|
|
def commit_committer_link(commit, options = {})
|
|
|
|
commit_person_link(commit, options.merge(source: :committer))
|
|
|
|
end
|
|
|
|
|
2012-05-30 14:02:30 -04:00
|
|
|
def image_diff_class(diff)
|
|
|
|
if diff.deleted_file
|
2012-12-01 07:49:21 -05:00
|
|
|
"deleted"
|
2012-05-30 14:02:30 -04:00
|
|
|
elsif diff.new_file
|
2012-12-01 07:49:21 -05:00
|
|
|
"added"
|
2012-05-30 14:02:30 -04:00
|
|
|
else
|
|
|
|
nil
|
|
|
|
end
|
|
|
|
end
|
2012-07-02 16:08:07 -04:00
|
|
|
|
2013-09-10 06:15:49 -04:00
|
|
|
def commit_to_html(commit, project, inline = true)
|
|
|
|
template = inline ? "inline_commit" : "commit"
|
|
|
|
escape_javascript(render "projects/commits/#{template}", commit: commit, project: project) unless commit.nil?
|
2012-10-31 08:29:42 -04:00
|
|
|
end
|
2012-12-24 22:14:05 -05:00
|
|
|
|
2013-03-31 16:46:54 -04:00
|
|
|
# Breadcrumb links for a Project and, if applicable, a tree path
|
|
|
|
def commits_breadcrumbs
|
|
|
|
return unless @project && @ref
|
|
|
|
|
|
|
|
# Add the root project link and the arrow icon
|
|
|
|
crumbs = content_tag(:li) do
|
2015-01-24 13:02:58 -05:00
|
|
|
link_to(
|
|
|
|
@project.path,
|
|
|
|
namespace_project_commits_path(@project.namespace, @project, @ref)
|
|
|
|
)
|
2013-03-31 16:46:54 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
if @path
|
|
|
|
parts = @path.split('/')
|
|
|
|
|
|
|
|
parts.each_with_index do |part, i|
|
2014-10-09 03:47:47 -04:00
|
|
|
crumbs << content_tag(:li) do
|
2013-03-31 16:46:54 -04:00
|
|
|
# The text is just the individual part, but the link needs all the parts before it
|
2015-01-24 13:02:58 -05:00
|
|
|
link_to(
|
|
|
|
part,
|
|
|
|
namespace_project_commits_path(
|
|
|
|
@project.namespace,
|
|
|
|
@project,
|
|
|
|
tree_join(@ref, parts[0..i].join('/'))
|
|
|
|
)
|
|
|
|
)
|
2013-03-31 16:46:54 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
crumbs.html_safe
|
|
|
|
end
|
|
|
|
|
2013-10-15 08:59:48 -04:00
|
|
|
# Return Project default branch, if it present in array
|
|
|
|
# Else - first branch in array (mb last actual branch)
|
|
|
|
def commit_default_branch(project, branches)
|
|
|
|
branches.include?(project.default_branch) ? branches.delete(project.default_branch) : branches.pop
|
|
|
|
end
|
|
|
|
|
|
|
|
# Returns the sorted alphabetically links to branches, separated by a comma
|
|
|
|
def commit_branches_links(project, branches)
|
2015-01-22 14:15:21 -05:00
|
|
|
branches.sort.map do |branch|
|
2015-01-24 13:02:58 -05:00
|
|
|
link_to(
|
|
|
|
namespace_project_tree_path(project.namespace, project, branch)
|
|
|
|
) do
|
2015-01-22 14:15:21 -05:00
|
|
|
content_tag :span, class: 'label label-gray' do
|
2015-01-28 03:32:48 -05:00
|
|
|
icon('code-fork') + ' ' + branch
|
2015-01-22 14:15:21 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end.join(" ").html_safe
|
2013-10-15 08:59:48 -04:00
|
|
|
end
|
|
|
|
|
2015-01-17 08:12:49 -05:00
|
|
|
# Returns the sorted links to tags, separated by a comma
|
|
|
|
def commit_tags_links(project, tags)
|
|
|
|
sorted = VersionSorter.rsort(tags)
|
2015-01-22 14:15:21 -05:00
|
|
|
sorted.map do |tag|
|
2015-01-24 13:02:58 -05:00
|
|
|
link_to(
|
|
|
|
namespace_project_commits_path(project.namespace, project,
|
|
|
|
project.repository.find_tag(tag).name)
|
|
|
|
) do
|
2015-01-22 14:15:21 -05:00
|
|
|
content_tag :span, class: 'label label-gray' do
|
2015-01-28 03:32:48 -05:00
|
|
|
icon('tag') + ' ' + tag
|
2015-01-22 14:15:21 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end.join(" ").html_safe
|
2015-01-17 08:12:49 -05:00
|
|
|
end
|
|
|
|
|
2014-07-08 11:28:02 -04:00
|
|
|
def link_to_browse_code(project, commit)
|
|
|
|
if current_controller?(:projects, :commits)
|
|
|
|
if @repo.blob_at(commit.id, @path)
|
2015-01-24 13:02:58 -05:00
|
|
|
return link_to(
|
|
|
|
"Browse File »",
|
|
|
|
namespace_project_blob_path(project.namespace, project,
|
|
|
|
tree_join(commit.id, @path)),
|
|
|
|
class: "pull-right"
|
|
|
|
)
|
2014-07-09 04:12:02 -04:00
|
|
|
elsif @path.present?
|
2015-01-24 13:02:58 -05:00
|
|
|
return link_to(
|
2015-12-02 08:56:17 -05:00
|
|
|
"Browse Directory »",
|
2015-01-24 13:02:58 -05:00
|
|
|
namespace_project_tree_path(project.namespace, project,
|
|
|
|
tree_join(commit.id, @path)),
|
|
|
|
class: "pull-right"
|
|
|
|
)
|
2014-07-08 11:28:02 -04:00
|
|
|
end
|
|
|
|
end
|
2015-01-24 13:02:58 -05:00
|
|
|
link_to(
|
2015-12-02 08:56:17 -05:00
|
|
|
"Browse Files »",
|
2015-01-24 13:02:58 -05:00
|
|
|
namespace_project_tree_path(project.namespace, project, commit),
|
|
|
|
class: "pull-right"
|
|
|
|
)
|
2014-07-08 11:28:02 -04:00
|
|
|
end
|
|
|
|
|
2016-02-15 14:58:30 -05:00
|
|
|
def revert_commit_link(commit, continue_to_path, btn_class: nil)
|
2016-02-10 16:05:04 -05:00
|
|
|
return unless current_user
|
|
|
|
|
2016-02-15 14:58:30 -05:00
|
|
|
tooltip = "Revert this #{revert_commit_type(commit)} in a new merge request"
|
|
|
|
|
2016-02-13 11:08:01 -05:00
|
|
|
if can_collaborate_with_project?
|
2016-02-10 17:44:20 -05:00
|
|
|
content_tag :span, 'data-toggle' => 'modal', 'data-target' => '#modal-revert-commit' do
|
2016-02-22 06:12:39 -05:00
|
|
|
link_to 'Revert', '#modal-revert-commit', 'data-toggle' => 'tooltip', 'data-container' => 'body', title: tooltip, class: "btn btn-default btn-grouped btn-#{btn_class}"
|
2016-02-10 17:44:20 -05:00
|
|
|
end
|
2016-02-15 14:58:30 -05:00
|
|
|
elsif can?(current_user, :fork_project, @project)
|
2016-02-09 14:50:25 -05:00
|
|
|
continue_params = {
|
|
|
|
to: continue_to_path,
|
|
|
|
notice: edit_in_new_fork_notice + ' Try to revert this commit again.',
|
|
|
|
notice_now: edit_in_new_fork_notice_now
|
|
|
|
}
|
|
|
|
fork_path = namespace_project_forks_path(@project.namespace, @project,
|
2016-02-10 18:02:46 -05:00
|
|
|
namespace_key: current_user.namespace.id,
|
|
|
|
continue: continue_params)
|
2016-02-09 14:50:25 -05:00
|
|
|
|
2016-02-22 06:12:39 -05:00
|
|
|
link_to 'Revert', fork_path, class: 'btn btn-grouped btn-close', method: :post, 'data-toggle' => 'tooltip', 'data-container' => 'body', title: tooltip
|
2016-02-15 14:58:30 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def revert_commit_type(commit)
|
|
|
|
if commit.merged_merge_request
|
|
|
|
'merge request'
|
|
|
|
else
|
|
|
|
'commit'
|
2016-02-09 14:50:25 -05:00
|
|
|
end
|
2016-02-03 16:11:59 -05:00
|
|
|
end
|
|
|
|
|
2013-03-31 16:46:54 -04:00
|
|
|
protected
|
|
|
|
|
|
|
|
# Private: Returns a link to a person. If the person has a matching user and
|
|
|
|
# is a member of the current @project it will link to the team member page.
|
|
|
|
# Otherwise it will link to the person email as specified in the commit.
|
|
|
|
#
|
|
|
|
# options:
|
|
|
|
# source: one of :author or :committer
|
|
|
|
# avatar: true will prepend the avatar image
|
|
|
|
# size: size of the avatar image in px
|
|
|
|
def commit_person_link(commit, options = {})
|
2015-03-27 07:16:34 -04:00
|
|
|
user = commit.send(options[:source])
|
2015-09-23 06:18:16 -04:00
|
|
|
|
2014-11-14 05:08:58 -05:00
|
|
|
source_name = clean(commit.send "#{options[:source]}_name".to_sym)
|
|
|
|
source_email = clean(commit.send "#{options[:source]}_email".to_sym)
|
2014-06-14 12:02:16 -04:00
|
|
|
|
2015-03-27 07:16:34 -04:00
|
|
|
person_name = user.try(:name) || source_name
|
|
|
|
person_email = user.try(:email) || source_email
|
2014-06-14 12:02:16 -04:00
|
|
|
|
2015-02-03 00:38:50 -05:00
|
|
|
text =
|
|
|
|
if options[:avatar]
|
|
|
|
avatar = image_tag(avatar_icon(person_email, options[:size]), class: "avatar #{"s#{options[:size]}" if options[:size]}", width: options[:size], alt: "")
|
|
|
|
%Q{#{avatar} <span class="commit-#{options[:source]}-name">#{person_name}</span>}
|
|
|
|
else
|
|
|
|
person_name
|
|
|
|
end
|
2013-03-31 16:46:54 -04:00
|
|
|
|
2013-07-27 03:40:38 -04:00
|
|
|
options = {
|
|
|
|
class: "commit-#{options[:source]}-link has_tooltip",
|
2016-01-28 05:41:58 -05:00
|
|
|
data: { 'original-title'.to_sym => sanitize(source_email) }
|
2013-07-27 03:40:38 -04:00
|
|
|
}
|
|
|
|
|
2013-03-31 16:46:54 -04:00
|
|
|
if user.nil?
|
2013-07-27 03:40:38 -04:00
|
|
|
mail_to(source_email, text.html_safe, options)
|
2013-03-31 16:46:54 -04:00
|
|
|
else
|
2013-07-27 03:40:38 -04:00
|
|
|
link_to(text.html_safe, user_path(user), options)
|
2013-03-31 16:46:54 -04:00
|
|
|
end
|
|
|
|
end
|
2014-06-14 15:54:56 -04:00
|
|
|
|
2014-08-02 11:12:01 -04:00
|
|
|
def view_file_btn(commit_sha, diff, project)
|
2015-01-24 13:02:58 -05:00
|
|
|
link_to(
|
|
|
|
namespace_project_blob_path(project.namespace, project,
|
|
|
|
tree_join(commit_sha, diff.new_path)),
|
2016-01-21 16:46:49 -05:00
|
|
|
class: 'btn view-file js-view-file'
|
2015-01-24 13:02:58 -05:00
|
|
|
) do
|
2014-08-02 11:12:01 -04:00
|
|
|
raw('View file @') + content_tag(:span, commit_sha[0..6],
|
|
|
|
class: 'commit-short-id')
|
|
|
|
end
|
|
|
|
end
|
2014-10-10 08:39:48 -04:00
|
|
|
|
|
|
|
def truncate_sha(sha)
|
|
|
|
Commit.truncate_sha(sha)
|
|
|
|
end
|
2014-11-14 05:08:58 -05:00
|
|
|
|
|
|
|
def clean(string)
|
|
|
|
Sanitize.clean(string, remove_contents: true)
|
|
|
|
end
|
2016-03-04 09:45:58 -05:00
|
|
|
|
|
|
|
def limited_commits(commits)
|
|
|
|
if commits.size > MergeRequestDiff::COMMITS_SAFE_SIZE
|
|
|
|
[
|
|
|
|
commits.first(MergeRequestDiff::COMMITS_SAFE_SIZE),
|
|
|
|
commits.size - MergeRequestDiff::COMMITS_SAFE_SIZE
|
|
|
|
]
|
|
|
|
else
|
|
|
|
[commits, 0]
|
|
|
|
end
|
|
|
|
end
|
2011-10-08 17:36:38 -04:00
|
|
|
end
|