debian-mirror-gitlab/app/helpers/tab_helper.rb

139 lines
4.2 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2014-09-02 18:07:02 +05:30
module TabHelper
# Navigation link helper
#
# Returns an `li` element with an 'active' class if the supplied
# controller(s) and/or action(s) are currently active. The content of the
# element is the value passed to the block.
#
# options - The options hash used to determine if the element is "active" (default: {})
2018-12-05 23:21:45 +05:30
# :controller - One or more controller names to check, use path notation when namespaced (optional).
2014-09-02 18:07:02 +05:30
# :action - One or more action names to check (optional).
# :path - A shorthand path, such as 'dashboard#index', to check (optional).
# :html_options - Extra options to be passed to the list element (optional).
# block - An optional block that will become the contents of the returned
# `li` element.
#
# When both :controller and :action are specified, BOTH must match in order
# to be marked as active. When only one is given, either can match.
#
# Examples
#
# # Assuming we're on TreeController#show
#
# # Controller matches, but action doesn't
# nav_link(controller: [:tree, :refs], action: :edit) { "Hello" }
# # => '<li>Hello</li>'
#
# # Controller matches
# nav_link(controller: [:tree, :refs]) { "Hello" }
# # => '<li class="active">Hello</li>'
#
2015-04-26 12:48:37 +05:30
# # Several paths
# nav_link(path: ['tree#show', 'profile#show']) { "Hello" }
# # => '<li class="active">Hello</li>'
#
2014-09-02 18:07:02 +05:30
# # Shorthand path
# nav_link(path: 'tree#show') { "Hello" }
# # => '<li class="active">Hello</li>'
#
# # Supplying custom options for the list element
# nav_link(controller: :tree, html_options: {class: 'home'}) { "Hello" }
# # => '<li class="home active">Hello</li>'
#
2018-12-05 23:21:45 +05:30
# # For namespaced controllers like Admin::AppearancesController#show
#
# # Controller and namespace matches
# nav_link(controller: 'admin/appearances') { "Hello" }
# # => '<li class="active">Hello</li>'
#
# # Controller and namespace matches but action doesn't
# nav_link(controller: 'admin/appearances', action: :edit) { "Hello" }
# # => '<li>Hello</li>'
#
# # Shorthand path with namespace
# nav_link(path: 'admin/appearances#show') { "Hello"}
# # => '<li class="active">Hello</li>'
#
2014-09-02 18:07:02 +05:30
# Returns a list item element String
def nav_link(options = {}, &block)
2015-04-26 12:48:37 +05:30
klass = active_nav_link?(options) ? 'active' : ''
2014-09-02 18:07:02 +05:30
# Add our custom class into the html_options, which may or may not exist
# and which may or may not already have a :class key
o = options.delete(:html_options) || {}
2018-12-05 23:21:45 +05:30
o[:class] = [*o[:class], klass].join(' ').strip
2014-09-02 18:07:02 +05:30
if block_given?
content_tag(:li, capture(&block), o)
else
content_tag(:li, nil, o)
end
end
2015-04-26 12:48:37 +05:30
def active_nav_link?(options)
if path = options.delete(:path)
unless path.respond_to?(:each)
path = [path]
end
path.any? do |single_path|
current_path?(single_path)
end
2015-09-25 12:07:36 +05:30
elsif page = options.delete(:page)
unless page.respond_to?(:each)
page = [page]
end
page.any? do |single_page|
current_page?(single_page)
end
2015-04-26 12:48:37 +05:30
else
c = options.delete(:controller)
a = options.delete(:action)
if c && a
# When given both options, make sure BOTH are true
current_controller?(*c) && current_action?(*a)
else
# Otherwise check EITHER option
current_controller?(*c) || current_action?(*a)
end
end
end
def current_path?(path)
c, a, _ = path.split('#')
current_controller?(c) && current_action?(a)
end
2014-09-02 18:07:02 +05:30
def project_tab_class
if controller.controller_path.start_with?('projects')
return 'active'
end
2014-09-02 18:07:02 +05:30
2017-08-17 22:00:37 +05:30
if %w(services hooks deploy_keys protected_branches).include? controller.controller_name
2015-04-26 12:48:37 +05:30
"active"
2014-09-02 18:07:02 +05:30
end
end
def branches_tab_class
if current_controller?(:protected_branches) ||
2017-08-17 22:00:37 +05:30
current_controller?(:branches) ||
2017-09-10 17:25:29 +05:30
current_page?(project_repository_path(@project))
2014-09-02 18:07:02 +05:30
'active'
end
end
2016-06-02 11:05:42 +05:30
def profile_tab_class
if controller.controller_path.start_with?('profiles')
2016-06-02 11:05:42 +05:30
return 'active'
end
'active' if current_controller?('oauth/applications')
end
2014-09-02 18:07:02 +05:30
end
2019-12-04 20:38:33 +05:30
TabHelper.prepend_if_ee('EE::TabHelper')