gitlab-org--gitlab-foss/app/helpers/application_helper.rb

321 lines
8.0 KiB
Ruby
Raw Normal View History

2011-10-08 21:36:38 +00:00
require 'digest/md5'
2012-12-06 20:44:22 +00:00
require 'uri'
2012-09-26 19:06:07 +00:00
2011-10-08 21:36:38 +00:00
module ApplicationHelper
COLOR_SCHEMES = {
1 => 'white',
2 => 'dark',
3 => 'solarized-light',
4 => 'solarized-dark',
5 => 'monokai',
}
COLOR_SCHEMES.default = 'white'
# Helper method to access the COLOR_SCHEMES
#
# The keys are the `color_scheme_ids`
# The values are the `name` of the scheme.
#
# The preview images are `name-scheme-preview.png`
# The stylesheets should use the css class `.name`
def color_schemes
COLOR_SCHEMES.freeze
end
# Check if a particular controller is the current one
#
# args - One or more controller names to check
#
# Examples
#
# # On TreeController
# current_controller?(:tree) # => true
# current_controller?(:commits) # => false
# current_controller?(:commits, :tree) # => true
def current_controller?(*args)
args.any? { |v| v.to_s.downcase == controller.controller_name }
end
2013-07-29 10:46:00 +00:00
# Check if a particular action is the current one
2012-09-26 19:06:07 +00:00
#
# args - One or more action names to check
#
# Examples
#
# # On Projects#new
# current_action?(:new) # => true
# current_action?(:create) # => false
# current_action?(:new, :create) # => true
def current_action?(*args)
args.any? { |v| v.to_s.downcase == action_name }
end
def project_icon(project_id, options = {})
project = Project.find_with_namespace(project_id)
if project.avatar.present?
image_tag project.avatar.url, options
elsif project.avatar_in_git
image_tag project_avatar_path(project), options
elsif options[:only_uploaded]
image_tag '/assets/no_project_icon.png', options
else # generated icon
project_identicon(project, options)
end
end
def project_identicon(project, options = {})
options[:class] ||= ''
options[:class] << ' identicon'
bg_color = Digest::MD5.hexdigest(project.name)[0, 6]
brightness = bg_color[0, 2].hex + bg_color[2, 2].hex + bg_color[4, 2].hex
text_color = (brightness > 375) ? '#000' : '#fff'
content_tag(:div, class: options[:class],
style: "background-color: ##{ bg_color }; color: #{ text_color }") do
project.name[0, 1].upcase
end
end
2014-01-27 21:34:05 +00:00
def group_icon(group_path)
group = Group.find_by(path: group_path)
if group && group.avatar.present?
group.avatar.url
else
image_path('no_group_avatar.png')
2014-01-27 21:34:05 +00:00
end
end
2013-10-06 18:13:56 +00:00
def avatar_icon(user_email = '', size = nil)
2014-01-19 18:55:59 +00:00
user = User.find_by(email: user_email)
if user
user.avatar_url(size) || default_avatar
2013-10-06 18:13:56 +00:00
else
gravatar_icon(user_email, size)
end
end
def gravatar_icon(user_email = '', size = nil)
GravatarService.new.execute(user_email, size) ||
default_avatar
end
def default_avatar
image_path('no_avatar.png')
2011-10-08 21:36:38 +00:00
end
def last_commit(project)
if project.repo_exists?
time_ago_with_tooltip(project.repository.commit.committed_date)
else
'Never'
2011-10-08 21:36:38 +00:00
end
2011-11-15 08:34:30 +00:00
rescue
'Never'
2011-10-08 21:36:38 +00:00
end
def grouped_options_refs
2013-01-03 19:09:18 +00:00
repository = @project.repository
2011-11-03 16:28:33 +00:00
options = [
['Branches', repository.branch_names],
['Tags', VersionSorter.rsort(repository.tag_names)]
2011-11-03 16:28:33 +00:00
]
2014-03-09 05:00:43 +00:00
# If reference is commit id - we should add it to branch/tag selectbox
if(@ref && !options.flatten.include?(@ref) &&
@ref =~ /^[0-9a-zA-Z]{6,52}$/)
options << ['Commit', [@ref]]
end
2011-12-12 21:17:28 +00:00
grouped_options_for_select(options, @ref || @project.default_branch)
2011-11-03 16:28:33 +00:00
end
def emoji_autocomplete_source
# should be an array of strings
# so to_s can be called, because it is sufficient and to_json is too slow
2012-10-16 14:26:40 +00:00
Emoji.names.to_s
end
2012-03-01 19:23:50 +00:00
def app_theme
Gitlab::Theme.css_class_by_id(current_user.try(:theme_id))
2014-12-15 01:01:59 +00:00
end
def theme_type
Gitlab::Theme.type_css_class_by_id(current_user.try(:theme_id))
2012-03-01 19:23:50 +00:00
end
2012-06-21 15:41:22 +00:00
2012-11-27 21:49:22 +00:00
def user_color_scheme_class
COLOR_SCHEMES[current_user.try(:color_scheme_id)] if defined?(current_user)
2012-11-27 21:49:22 +00:00
end
# Define whenever show last push event
# with suggestion to create MR
2012-06-21 15:41:22 +00:00
def show_last_push_widget?(event)
# Skip if event is not about added or modified non-master branch
return false unless event && event.last_push_to_non_root? && !event.rm_ref?
project = event.project
# Skip if project repo is empty or MR disabled
return false unless project && !project.empty_repo? && project.merge_requests_enabled
# Skip if user already created appropriate MR
return false if project.merge_requests.where(source_branch: event.branch_name).opened.any?
# Skip if user removed branch right after that
return false unless project.repository.branch_names.include?(event.branch_name)
true
2012-06-21 15:41:22 +00:00
end
2012-07-03 17:52:48 +00:00
def hexdigest(string)
Digest::SHA1.hexdigest string
end
2012-08-30 05:13:36 +00:00
2012-08-03 15:27:39 +00:00
def authbutton(provider, size = 64)
2012-09-12 05:23:20 +00:00
file_name = "#{provider.to_s.split('_').first}_#{size}.png"
image_tag(image_path("authbuttons/#{file_name}"), alt: "Sign in with #{provider.to_s.titleize}")
2012-08-03 15:27:39 +00:00
end
2013-10-20 03:57:34 +00:00
def simple_sanitize(str)
sanitize(str, tags: %w(a span))
end
def body_data_page
path = controller.controller_path.split('/')
namespace = path.first if path.second
[namespace, controller.controller_name, controller.action_name].compact.join(':')
end
# shortcut for gitlab config
def gitlab_config
Gitlab.config.gitlab
end
# shortcut for gitlab extra config
def extra_config
Gitlab.config.extra
end
2013-06-06 11:02:29 +00:00
def search_placeholder
if @project && @project.persisted?
'Search in this project'
elsif @snippet || @snippets || @show_snippets
'Search snippets'
elsif @group && @group.persisted?
'Search in this group'
else
'Search'
end
end
def broadcast_message
BroadcastMessage.current
end
def time_ago_with_tooltip(date, placement = 'top', html_class = 'time_ago')
capture_haml do
haml_tag :time, date.to_s,
class: html_class, datetime: date.getutc.iso8601, title: date.stamp('Aug 21, 2011 9:23pm'),
data: { toggle: 'tooltip', placement: placement }
haml_tag :script, "$('." + html_class + "').timeago().tooltip()"
end.html_safe
end
def render_markup(file_name, file_content)
GitHub::Markup.render(file_name, file_content).
force_encoding(file_content.encoding).html_safe
2014-08-10 11:25:35 +00:00
rescue RuntimeError
simple_format(file_content)
end
def markup?(filename)
Gitlab::MarkdownHelper.markup?(filename)
end
def gitlab_markdown?(filename)
Gitlab::MarkdownHelper.gitlab_markdown?(filename)
end
def spinner(text = nil, visible = false)
css_class = 'loading'
css_class << ' hide' unless visible
content_tag :div, class: css_class do
2014-10-01 22:21:29 +00:00
content_tag(:i, nil, class: 'fa fa-spinner fa-spin') + text
end
end
def link_to(name = nil, options = nil, html_options = nil, &block)
2014-05-30 15:09:31 +00:00
begin
uri = URI(options)
host = uri.host
absolute_uri = uri.absolute?
rescue URI::InvalidURIError, ArgumentError
host = nil
absolute_uri = nil
end
# Add 'nofollow' only to external links
2014-05-30 15:09:31 +00:00
if host && host != Gitlab.config.gitlab.host && absolute_uri
if html_options
if html_options[:rel]
html_options[:rel] << ' nofollow'
2014-05-30 15:09:31 +00:00
else
html_options.merge!(rel: 'nofollow')
2014-05-30 15:09:31 +00:00
end
else
2014-05-30 15:09:31 +00:00
html_options = Hash.new
html_options[:rel] = 'nofollow'
end
end
2014-05-30 15:09:31 +00:00
super
end
def escaped_autolink(text)
auto_link ERB::Util.html_escape(text), link: :urls
end
def promo_host
'about.gitlab.com'
end
def promo_url
'https://' + promo_host
end
def page_filter_path(options={})
exist_opts = {
state: params[:state],
scope: params[:scope],
label_name: params[:label_name],
milestone_id: params[:milestone_id],
assignee_id: params[:assignee_id],
author_id: params[:author_id],
sort: params[:sort],
}
options = exist_opts.merge(options)
path = request.path
path << "?#{options.to_param}"
path
end
def outdated_browser?
browser.ie? && browser.version.to_i < 10
end
def path_to_key(key, admin = false)
if admin
admin_user_key_path(@user, key)
else
profile_key_path(key)
end
end
2011-10-08 21:36:38 +00:00
end