62 lines
1.4 KiB
TypeScript

import 'glider-js/glider.min.css';
import { ArrowLeft, ArrowRight } from 'lucide-react';
import React from 'react';
import Glider from 'react-glider';
import './carousel.css';
export interface CarouselItemProps {
children: React.ReactNode
className?: string
}
export const CarouselItem: React.FC<CarouselItemProps> = ({
children,
className = 'ml-2 first:ml-0 lg:ml-4'
}: CarouselItemProps) => {
return <div className={className}>{children}</div>
}
export interface CarouselProps {
children: JSX.Element | JSX.Element[] | any
gliderClasses?: string
hasArrows?: boolean
hasDots?: boolean
slidesToShow?: number
slidesToScroll?: number
responsive?: any
}
export const Carousel: React.FC<CarouselProps> = ({
children,
gliderClasses,
hasArrows = true,
hasDots = true,
slidesToShow = 1,
slidesToScroll = 1,
responsive,
}) => {
return (
<>
<Glider
className={`block relative ${gliderClasses}`}
draggable
slidesToShow={slidesToShow}
scrollLock
slidesToScroll={slidesToScroll}
hasArrows={hasArrows}
hasDots={hasDots}
iconLeft={<ArrowLeft className="stroke-current" />}
iconRight={<ArrowRight className="stroke-current" />}
responsive={[responsive]}
>
{React.Children.map(children, (child) => {
return React.cloneElement(child)
})}
</Glider>
</>
)
}