Avo::PanelComponent
The panel component is one of the most used components in Avo.
<%= render Avo::PanelComponent.new(title: @product.name, description: @product.description) do |c| %>
<% c.with_tools do %>
<%= a_link(@product.link, icon: 'heroicons/solid/academic-cap', style: :primary, color: :primary) do %>
View product
<% end %>
<% end %>
<% c.with_body do %>
<div class="flex flex-col p-4 min-h-24">
<div class="space-y-4">
<h3>Product information</h3>
<p>Style: shiny</p>
</div>
</div>
<% end %>
<% end %>
data:image/s3,"s3://crabby-images/4069e/4069e13632ad2f92eb9bfb095d9694c4b9b507e3" alt="Avo"
Options
All options are optional. You may render a panel without options.
<%= render Avo::PanelComponent.new do |c| %>
<% c.with_body do %>
Something here.
<% end %>
<% end %>
-> name
-> description
-> classes
-> body_classes
-> data
-> display_breadcrumbs
Slots
The component has a few slots where you customize the content in certain areas.
-> tools
We created this slot as a place to put resource controls like the back, edit, delete, and detach buttons. This slot will collapse under the title and description when the screen resolution falls under 1024px
.
The section is automatically aligned to the right using justify-end
class.
<%= render Avo::PanelComponent.new(name: "Dashboard") do |c| %>
<% c.with_tools do %>
<%= a_link('/admin', icon: 'heroicons/solid/academic-cap', style: :primary) do %>
Admin
<% end %>
<% end %>
<% end %>
data:image/s3,"s3://crabby-images/c69b5/c69b59badcdb788ffee3f5a583d406f0d8d8bcea" alt="Avo"
-> body
This is one of the main slots of the component where the bulk of the content is displayed.
<%= render Avo::PanelComponent.new do |c| %>
<% c.with_body do %>
Something here.
<% end %>
<% end %>
data:image/s3,"s3://crabby-images/32a99/32a9905b3c31626659fb50cd720e3ee19adee3d5" alt="Avo"
-> bare_content
Used when displaying the Grid view, it displays the data flush in the container and with no background.
<%= render Avo::PanelComponent.new do |c| %>
<% c.with_bare_content do %>
Something here.
<% end %>
<% end %>
data:image/s3,"s3://crabby-images/7d86a/7d86aee6e505bcd6dfa3aa7e2beef8d4d7600fbc" alt="Avo"
-> footer_tools
This is pretty much the same slot as tools
but rendered under the body
or bare_content
slots.
<%= render Avo::PanelComponent.new do |c| %>
<% c.with_footer_controls do %>
Something here.
<% end %>
<% end %>
data:image/s3,"s3://crabby-images/6a16e/6a16eae7f1e04bdc7f3bf98b8f6038be07efa9cb" alt="Avo"
-> footer
The lowest available area at the end of the component.
<%= render Avo::PanelComponent.new do |c| %>
<% c.with_footer do %>
Something here.
<% end %>
<% end %>
-> sidebar
The sidebar will conveniently show things in a smaller area on the right of the body
.
<%= render Avo::PanelComponent.new do |c| %>
<% c.with_Sidebar do %>
Something tiny here.
<% end %>
<% end %>
data:image/s3,"s3://crabby-images/5d2bb/5d2bbcef244bce10666179ad59db120caf5c2097" alt="Avo"