Carousel
A carousel with motion and swipe built using Embla.
Preview
Dependencies
- Embla Carousel: carousel and swiping functionality.
Installation
npx sigma-ui add carousel
Examples
More examples at: Embla Carousel docs
Basic
Sizes
To set the size of the items, you can use the basis
utility class on the <CarouselItem />
.
Example
// 33% of the carousel width.
<Carousel>
<CarouselContent>
<CarouselItem class="basis-1/3">...</CarouselItem>
<CarouselItem class="basis-1/3">...</CarouselItem>
<CarouselItem class="basis-1/3">...</CarouselItem>
</CarouselContent>
</Carousel>
Responsive
// 50% on small screens and 33% on larger screens.
<Carousel>
<CarouselContent>
<CarouselItem class="md:basis-1/2 lg:basis-1/3">...</CarouselItem>
<CarouselItem class="md:basis-1/2 lg:basis-1/3">...</CarouselItem>
<CarouselItem class="md:basis-1/2 lg:basis-1/3">...</CarouselItem>
</CarouselContent>
</Carousel>
Spacing
In this component, the easiest way to set the spacing between items is to use a positive padding on the <CarouselItem />
and a negative margin on the <CarouselContent />
.
Example
<template>
<Carousel>
<CarouselContent class="-ml-4">
<CarouselItem class="pl-4">
...
</CarouselItem>
<CarouselItem class="pl-4">
...
</CarouselItem>
<CarouselItem class="pl-4">
...
</CarouselItem>
</CarouselContent>
</Carousel>
</template>
Responsive
<template>
<Carousel>
<CarouselContent class="-ml-2 md:-ml-4">
<CarouselItem class="pl-2 md:pl-4">
...
</CarouselItem>
<CarouselItem class="pl-2 md:pl-4">
...
</CarouselItem>
<CarouselItem class="pl-2 md:pl-4">
...
</CarouselItem>
</CarouselContent>
</Carousel>
</template>
Orientation
Use the orientation
prop to set the orientation of the carousel.
<Carousel orientation="vertical | horizontal">
...
</Carousel>
Thumbnails
Options
You can pass options to the carousel using the opts
prop. See the Embla Carousel docs for more information.
<template>
<Carousel
:opts="{
align: 'start',
loop: true,
}"
>
<CarouselContent>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
<CarouselItem>...</CarouselItem>
</CarouselContent>
</Carousel>
</template>
API
Method 1
Use the @init-api
emit method on <Carousel />
component to set the instance of the API.
Method 2
You can access it through setting a template ref on the <Carousel />
component.
<script setup>
const carouselContainerRef = ref<InstanceType<typeof Carousel> | null>(null)
function accessApi() {
carouselContainerRef.value?.carouselApi.on('select', () => {})
}
</script>
<template>
<Carousel ref="carouselContainerRef">
...
</Carousel>
</template>
Events
You can listen to events using the API. To get the API instance use the @init-api
emit method on the <Carousel />
component
<script setup>
import { nextTick, ref, watch } from 'vue'
import { useCarousel } from '@/components/ui/carousel'
const api = ref<CarouselApi>()
function setApi(val: CarouselApi) {
api.value = val
}
const stop = watch(api, (api) => {
if (!api) {
return
}
// Watch only once
nextTick(() => stop())
api.on('select', () => {
// Do something on select
})
})
</script>
<template>
<Carousel @init-api="setApi">
...
</Carousel>
</template>
More about events: Embla Carousel docs | Events
Slot Props
You can get the reactive slot props like carouselRef, canScrollNext..Prev, scrollNext..Prev
using the v-slot
directive in the <Carousel v-slot="slotProps" />
component to extend the functionality.
<template>
<Carousel v-slot="{ canScrollNext, canScrollPrev }">
...
<CarouselPrevious v-if="canScrollPrev" />
<CarouselNext v-if="canScrollNext" />
</Carousel>
</template>
Plugins
You can use the plugins
prop to add plugins to the carousel.
npm i embla-carousel-autoplay
<script setup lang="ts">
import Autoplay from 'embla-carousel-autoplay'
</script>
<template>
<Carousel
class="w-full max-w-xs"
:plugins="[Autoplay({
delay: 2000,
})]"
>
...
</Carousel>
</template>
More about plugins: Embla Carousel docs | Plugins