redirect_from: /docs/7-sidebars.html
Sidebar Sections
Sidebars allow you to put whatever content you want on the side the page.
:help do
"Need help? Email us at [email protected]"
end
This will generate a sidebar on every page for that resource. The first argument is used as the title, and can be a symbol, string, or lambda.
You can also use Arbre to define HTML content.
:help do
ul do
li "Second List First Item"
li "Second List Second Item"
end
end
Sidebars can be rendered on a specific action by passing :only
or :except
.
:help, only: :index do
"Need help? Email us at [email protected]"
end
If you want to conditionally display a sidebar section, use the :if option and pass it a proc which will be rendered within the view context.
:help, if: proc{ current_admin_user.super_admin? } do
"Only for super admins!"
end
You can access your model as resource in the sidebar too:
:custom, only: :show do
resource.a_method
end
You can also render a partial:
:help # app/views/admin/posts/_help_sidebar.html.erb
:help, partial: 'custom' # app/views/admin/posts/_custom.html.erb
It's possible to add custom class name to the sidebar parent element by passing
class
option:
:help, class: 'custom_class'
By default sidebars are positioned in the same order as they defined, but it's also possible to specify their position manually:
# will push Help section to the top (above default Filters section)
:help, priority: 0
Default sidebar priority is 10
.