Grid view
data:image/s3,"s3://crabby-images/5176b/5176bd4c9f8787236dbca597ba12f13675145b74" alt="Avo grid view"
Some resources are best displayed in a grid view. We can do that with Avo using a cover_url
, a title
, and a body
.
Enable grid view
To enable grid view for a resource, you need to configure the grid_view
class attribute on the resource. That will add the grid view to the view switcher on the Index
view.
class Avo::Resources::Post < Avo::BaseResource
self.grid_view = {
card: -> do
{
cover_url:
if record.cover_photo.attached?
main_app.url_for(record.cover_photo.url)
end,
title: record.name,
body: record.truncated_body
}
end
}
end
data:image/s3,"s3://crabby-images/9c792/9c792b6654763416204d7122ab9b2e2f0b4a2f1b" alt="Avo view switcher"
Make default view
To make the grid the default way of viewing a resource Index, we have to use the default_view_type
class attribute.
class Avo::Resources::Post < Avo::BaseResource
self.default_view_type = :grid
end
Custom style
You may want to customize the card a little bit. That's possible using the html
option.
class Avo::Resources::Post < Avo::BaseResource
self.grid_view = {
card: -> do
{
cover_url:
if record.cover_photo.attached?
main_app.url_for(record.cover_photo.url)
end,
title: record.name,
body: record.truncated_body
}
end,
html: -> do
{
title: {
index: {
wrapper: {
classes: "bg-blue-50 rounded-md p-2"
}
}
},
body: {
index: {
wrapper: {
classes: "bg-gray-50 rounded-md p-1"
}
}
},
cover: {
index: {
wrapper: {
classes: "blur-sm"
}
}
}
}
end
}
end
data:image/s3,"s3://crabby-images/3bf41/3bf4139534075c874a9287ef692cdc7a554f5c92" alt="Grid html option"
Grid Item Badge
Since v3.15data:image/s3,"s3://crabby-images/427f8/427f86986d37f3172728da106b52fcd6c589a13c" alt="Avo Grid View Badge Element"
One common scenario is to show a badge on top of your grid items. Avo enables you to do that pretty easy using these three options.
-> badge_label
The label is what the user sees on top of your grid item.
self.grid_view = {
card: -> do
{
cover_url: record.image.attached? ? main_app.url_for(record.image.variant(resize: "300x300")) : nil,
title: record.title,
body: simple_format(record.description),
badge_label: (record.updated_at < 1.week.ago ? "New" : "Updated"),
}
end
}
data:image/s3,"s3://crabby-images/dccfb/dccfba0c9c156302dff1115eb037f575a3d19124" alt="Avo Grid View Badge Label"
-> badge_color
You may style it in any TailwindCSS color you prefer.
It only needs to know the color name (green
, blue
, fuchsia
, etc.).
self.grid_view = {
card: -> do
{
cover_url: record.image.attached? ? main_app.url_for(record.image.variant(resize: "300x300")) : nil,
title: record.title,
body: simple_format(record.description),
badge_label: (record.updated_at < 1.week.ago ? "New" : "Updated"),
badge_color: (record.updated_at < 1.week.ago ? "green" : "orange")
}
end
}
data:image/s3,"s3://crabby-images/ce5ae/ce5ae16d54719ae97cad4d91fa5cdac126b2b67d" alt="Avo Grid View Badge Color"
-> badge_title
The title refers to the tooltip that the user gets when they hover over the badge.
self.grid_view = {
card: -> do
{
cover_url: record.image.attached? ? main_app.url_for(record.image.variant(resize: "300x300")) : nil,
title: record.title,
body: simple_format(record.description),
badge_label: (record.updated_at < 1.week.ago ? "New" : "Updated"),
badge_color: (record.updated_at < 1.week.ago ? "green" : "orange"),
badge_title: (record.updated_at < 1.week.ago ? "New product here" : "Updated product here")
}
end
}
data:image/s3,"s3://crabby-images/56366/56366e736c10cd420f691a405cbb3ccb61f7c08e" alt="Avo Grid View Badge Title"