70 lines
1.8 KiB
Ruby
70 lines
1.8 KiB
Ruby
module TreeHelper
|
|
# Sorts a repository's tree so that folders are before files and renders
|
|
# their corresponding partials
|
|
#
|
|
# contents - A Grit::Tree object for the current tree
|
|
def render_tree(contents)
|
|
# Render Folders before Files/Submodules
|
|
folders, files = contents.partition { |v| v.kind_of?(Grit::Tree) }
|
|
|
|
tree = ""
|
|
|
|
# Render folders if we have any
|
|
tree += render partial: 'tree/tree_item', collection: folders, locals: {type: 'folder'} if folders.present?
|
|
|
|
files.each do |f|
|
|
if f.respond_to?(:url)
|
|
# Object is a Submodule
|
|
tree += render partial: 'tree/submodule_item', object: f
|
|
else
|
|
# Object is a Blob
|
|
tree += render partial: 'tree/tree_item', object: f, locals: {type: 'file'}
|
|
end
|
|
end
|
|
|
|
tree.html_safe
|
|
end
|
|
|
|
# Return an image icon depending on the file type
|
|
#
|
|
# type - String type of the tree item; either 'folder' or 'file'
|
|
def tree_icon(type)
|
|
image = type == 'folder' ? 'file_dir.png' : 'file_txt.png'
|
|
image_tag(image, size: '16x16')
|
|
end
|
|
|
|
def tree_hex_class(content)
|
|
"file_#{hexdigest(content.name)}"
|
|
end
|
|
|
|
# Public: Determines if a given filename is compatible with GitHub::Markup.
|
|
#
|
|
# filename - Filename string to check
|
|
#
|
|
# Returns boolean
|
|
def markup?(filename)
|
|
filename.end_with?(*%w(.textile .rdoc .org .creole
|
|
.mediawiki .rst .asciidoc .pod))
|
|
end
|
|
|
|
def gitlab_markdown?(filename)
|
|
filename.end_with?(*%w(.mdown .md .markdown))
|
|
end
|
|
|
|
def plain_text_readme? filename
|
|
filename == 'README'
|
|
end
|
|
|
|
# Simple shortcut to File.join
|
|
def tree_join(*args)
|
|
File.join(*args)
|
|
end
|
|
|
|
def allowed_tree_edit?
|
|
if @project.protected_branch? @ref
|
|
can?(current_user, :push_code_to_protected_branches, @project)
|
|
else
|
|
can?(current_user, :push_code, @project)
|
|
end
|
|
end
|
|
end
|