Landing Page Testimonial Grid Component
- Updated on
Use this component to display a grid of testimonials.
This component accepts a title, description and a list of testimonials. They will be placed in a column layout on small screens, then a 2-column layout and finally a 3-column layout on large screens.
Each testimonial can be featured or not. The featured testimonial will stand out with bigger & bolder text.
Testimonials are a great way to show that other people have used your product and are happy with it. Consider adding it high up on your landing page.
Don't take it from us
See what other people have to say.
“After using this, I cannot imagine going back to the old way of doing things.”
data:image/s3,"s3://crabby-images/698c4/698c4ab5c312804815dade610377f6fc81b74d29" alt=""
“Perfect for my use case”
data:image/s3,"s3://crabby-images/bddae/bddaea29404cfe19c2e146f479312a8066a36d94" alt=""
“This is the best thing since sliced bread. I cannot believe I did not think of it myself.”
data:image/s3,"s3://crabby-images/bd388/bd388eb90fd4277360df6fd4fc2fcdcef382702f" alt=""
“Excellent product!”
data:image/s3,"s3://crabby-images/044da/044da38535c8f424798915b68893e40ed4cfc49c" alt=""
“Can easily recommend!”
data:image/s3,"s3://crabby-images/42a5f/42a5f5df307ee3ec1f94d97fe23095a8f11fb351" alt=""
“I am very happy with the results.”
data:image/s3,"s3://crabby-images/81729/8172912b1c702c321fd7d818365c697aaefbec36" alt=""
Usage
import { LandingTestimonialGrid } from '@/components/landing/testimonial/LandingTestimonialGrid';
const testimonialItems = [
{
name: 'Mathew',
text: 'After using this, I cannot imagine going back to the old way of doing things.',
handle: '@heymatt_oo',
imageSrc: 'https://picsum.photos/100/100.webp?random=2',
},
{
name: 'Joshua',
text: 'Perfect for my use case',
handle: '@joshua',
imageSrc: 'https://picsum.photos/100/100.webp?random=3',
},
{
name: 'Parl Coppa',
text: 'This is the best thing since sliced bread. I cannot believe I did not think of it myself.',
handle: '@coppalipse',
imageSrc: 'https://picsum.photos/100/100.webp?random=1',
featured: true, // Feature this testimonial
},
{
name: 'Mandy',
text: 'Excellent product!',
handle: '@mandy',
imageSrc: 'https://picsum.photos/100/100.webp?random=4',
},
{
name: 'Alex',
text: 'Can easily recommend!',
handle: '@alex',
imageSrc: 'https://picsum.photos/100/100.webp?random=5',
},
{
name: 'Sam',
text: 'I am very happy with the results.',
handle: '@sama',
imageSrc: 'https://picsum.photos/100/100.webp?random=6',
},
];
<LandingTestimonialGrid
title="Don't take it from us"
description="See what other people have to say."
testimonialItems={testimonialItems}
/>
Examples
Background, links and features
This component supports different background colors.
Here we set variant to secondary. Testimonials can also be linked + be featured and you can mix and match to send the desired message.
Don't take it from us
See what other people have to say.
“After using this, I cannot imagine going back to the old way of doing things.”
data:image/s3,"s3://crabby-images/698c4/698c4ab5c312804815dade610377f6fc81b74d29" alt=""
“Perfect for my use case”
data:image/s3,"s3://crabby-images/bddae/bddaea29404cfe19c2e146f479312a8066a36d94" alt=""
“This is the best thing since sliced bread. I cannot believe I did not think of it myself.”
data:image/s3,"s3://crabby-images/bd388/bd388eb90fd4277360df6fd4fc2fcdcef382702f" alt=""
“Excellent product!”
data:image/s3,"s3://crabby-images/044da/044da38535c8f424798915b68893e40ed4cfc49c" alt=""
“Can easily recommend this product! I am very happy with the results.”
data:image/s3,"s3://crabby-images/42a5f/42a5f5df307ee3ec1f94d97fe23095a8f11fb351" alt=""
“I am very happy with the results.”
data:image/s3,"s3://crabby-images/81729/8172912b1c702c321fd7d818365c697aaefbec36" alt=""
Background Glow
Don't take it from us
See what other people have to say.
“After using this, I cannot imagine going back to the old way of doing things.”
data:image/s3,"s3://crabby-images/698c4/698c4ab5c312804815dade610377f6fc81b74d29" alt=""
“Perfect for my use case”
data:image/s3,"s3://crabby-images/bddae/bddaea29404cfe19c2e146f479312a8066a36d94" alt=""
“This is the best thing since sliced bread. I cannot believe I did not think of it myself.”
data:image/s3,"s3://crabby-images/bd388/bd388eb90fd4277360df6fd4fc2fcdcef382702f" alt=""
“Excellent product!”
data:image/s3,"s3://crabby-images/044da/044da38535c8f424798915b68893e40ed4cfc49c" alt=""
“Can easily recommend!”
data:image/s3,"s3://crabby-images/42a5f/42a5f5df307ee3ec1f94d97fe23095a8f11fb351" alt=""
“I am very happy with the results.”
data:image/s3,"s3://crabby-images/81729/8172912b1c702c321fd7d818365c697aaefbec36" alt=""
Read more wrapper
If your testimonials exceed 2 rows, you can add a "Read more" wrapper to hide the rest of the content initially.
This is usually a good idea to keep the page clean and focused.
Don't take it from us
See what other people have to say.
“After using this, I cannot imagine going back to the old way of doing things.”
data:image/s3,"s3://crabby-images/698c4/698c4ab5c312804815dade610377f6fc81b74d29" alt=""
“Perfect for my use case”
data:image/s3,"s3://crabby-images/bddae/bddaea29404cfe19c2e146f479312a8066a36d94" alt=""
“This is the best thing since sliced bread. I cannot believe I did not think of it myself.”
data:image/s3,"s3://crabby-images/bd388/bd388eb90fd4277360df6fd4fc2fcdcef382702f" alt=""
“Excellent product!”
data:image/s3,"s3://crabby-images/044da/044da38535c8f424798915b68893e40ed4cfc49c" alt=""
“Can easily recommend!”
data:image/s3,"s3://crabby-images/42a5f/42a5f5df307ee3ec1f94d97fe23095a8f11fb351" alt=""
“I am very happy with the results.”
data:image/s3,"s3://crabby-images/81729/8172912b1c702c321fd7d818365c697aaefbec36" alt=""
API Reference
Prop Name | Prop Type | Required | Default |
---|---|---|---|
title | string ǀ React.ReactNode | No | - |
description | string ǀ React.ReactNode | No | - |
testimonialItems | Array<TestimonialItem> | Yes | - |
featuredTestimonial | TestimonialItem | No | - |
withBackground | boolean | No | - |
variant | 'primary' ǀ 'secondary' | No | 'primary' |
withBackgroundGlow | boolean | No | false |
backgroundGlowVariant | 'primary' ǀ 'secondary' | No | 'primary' |
export interface TestimonialItem {
className?: string;
url?: string;
text: string;
imageSrc: string;
name: string;
handle: string;
featured?: boolean;
verified?: boolean;
size?: 'full' | 'half' | 'third'; // NB: Only applies to testimonials in a list, not grid.
}
More Examples
For more even more examples, see our Landing Page Component Examples page or see complete landing page examples by Exploring Our Landing Page Templates.