Testimonial 17



import { BiSolidStar } from "react-icons/bi";
type ImageProps = {
src: string;
alt?: string;
};
type Testimonial = {
quote: string;
avatar: ImageProps;
name: string;
position: string;
companyName: string;
numberOfStars: number;
};
type Props = {
heading: string;
description: string;
testimonials: Testimonial[];
};
export type Testimonial17Props = React.ComponentPropsWithoutRef<"section"> & Partial<Props>;
export const Testimonial17 = (props: Testimonial17Props) => {
const { heading, description, testimonials } = {
...Testimonial17Defaults,
...props,
};
return (
<section id="relume" className="px-[5%] py-16 md:py-24 lg:py-28">
<div className="container">
<div className="mx-auto mb-12 w-full max-w-lg text-center md:mb-18 lg:mb-20">
<h1 className="mb-5 text-5xl font-bold md:mb-6 md:text-7xl lg:text-8xl">{heading}</h1>
<p className="md:text-md">{description}</p>
</div>
<div className="grid grid-cols-1 gap-8 md:grid-cols-2 lg:grid-cols-3">
{testimonials.map((testimonial, index) => (
<div
key={index}
className="flex w-full flex-col items-start justify-between border border-border-primary p-6 md:p-8"
>
<div className="mb-5 flex md:mb-6">
{Array(testimonial.numberOfStars)
.fill(null)
.map((_, starIndex) => (
<BiSolidStar key={starIndex} className="mr-1 size-6" />
))}
</div>
<blockquote className="md:text-md">{testimonial.quote}</blockquote>
<div className="mt-5 flex w-full flex-col items-start md:mt-6 md:w-fit md:flex-row md:items-center">
<img
src={testimonial.avatar.src}
alt={testimonial.avatar.alt}
className="mb-4 size-12 min-h-12 min-w-12 rounded-full object-cover md:mb-0 md:mr-4"
/>
<div>
<p className="font-semibold">{testimonial.name}</p>
<p>
<span>{testimonial.position}</span>, <span>{testimonial.companyName}</span>
</p>
</div>
</div>
</div>
))}
</div>
</div>
</section>
);
};
export const Testimonial17Defaults: Props = {
heading: "Customer testimonials",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit.",
testimonials: [
{
quote:
'"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse varius enim in eros elementum tristique. Duis cursus, mi quis viverra ornare."',
avatar: {
src: "https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg",
alt: "Testimonial avatar 1",
},
name: "Name Surname",
position: "Position",
companyName: "Company name",
numberOfStars: 5,
},
{
quote:
'"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse varius enim in eros elementum tristique. Duis cursus, mi quis viverra ornare."',
avatar: {
src: "https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg",
alt: "Testimonial avatar 2",
},
name: "Name Surname",
position: "Position",
companyName: "Company name",
numberOfStars: 5,
},
{
quote:
'"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse varius enim in eros elementum tristique. Duis cursus, mi quis viverra ornare."',
avatar: {
src: "https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg",
alt: "Testimonial avatar 3",
},
name: "Name Surname",
position: "Position",
companyName: "Company name",
numberOfStars: 5,
},
],
};
Need help?
For installation guidelines and API information, visit the docs.
Examples
No items found.