The tailwindcss-primeui plugin is packed with animation utilities.
This example combines tailwindcss-primeui plugin animations with the v-animateonscroll directive of PrimeVue. Since Volt utilizes PrimeVue under the hood, you may take advantage of this directive as well.
import AnimateOnScroll from 'primevue/animateonscroll';
app.directive('animateonscroll', AnimateOnScroll);
<template>
<div class="card flex flex-col items-center overflow-hidden">
<div class="flex flex-col items-center gap-2">
<span class="text-xl font-medium">Scroll Down</span>
<span class="animate-bounce h-8 w-8 bg-primary text-primary-contrast rounded-full inline-flex items-center justify-center">
<i class="pi pi-arrow-down" />
</span>
</div>
<div class="h-[30rem]"></div>
<div class="flex flex-wrap justify-center gap-8">
<div
v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 slide-in-from-l-8 animate-duration-1000', leaveClass: 'animate-leave fade-out-0' }"
class="flex flex-col border border-surface shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4"
>
<div class="rounded-full bg-primary text-primary-contrast w-12 h-12 flex items-center justify-center">
<i class="pi pi-user !text-2xl"></i>
</div>
<span class="text-2xl font-bold">Individual</span>
<span class="text-muted-color text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
<div
v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 animate-duration-1000', leaveClass: 'animate-leave fade-out-0' }"
class="flex flex-col border border-surface shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4"
>
<div class="rounded-full bg-primary text-primary-contrast w-12 h-12 flex items-center justify-center">
<i class="pi pi-users !text-2xl"></i>
</div>
<span class="text-2xl font-bold">Team</span>
<span class="text-muted-color text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
<div
v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 slide-in-from-r-8 animate-duration-1000', leaveClass: 'animate-leave fade-out-0' }"
class="flex flex-col border border-surface shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4"
>
<div class="rounded-full bg-primary text-primary-contrast w-12 h-12 flex items-center justify-center">
<i class="pi pi-building !text-2xl"></i>
</div>
<span class="text-2xl font-bold">Enterprise</span>
<span class="text-muted-color text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
</div>
<div class="h-[30rem]"></div>
<div class="flex flex-wrap justify-center gap-8">
<div v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 slide-in-from-t-20 animate-duration-1000' }" class="flex flex-col border border-primary-200 shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4">
<Avatar image="https://primefaces.org/cdn/primevue/images/avatar/amyelsner.png" shape="circle" size="xlarge" />
<span class="text-2xl font-medium">Jenna Thompson</span>
<span class="text-muted-color text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
<div v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 slide-in-from-b-20 animate-duration-1000' }" class="flex flex-col border border-primary-200 shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4">
<Avatar image="https://primefaces.org/cdn/primevue/images/avatar/asiyajavayant.png" shape="circle" size="xlarge" />
<span class="text-2xl font-medium">Isabel Garcia</span>
<span class="text-muted-color text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
<div v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 slide-in-from-t-20 animate-duration-1000' }" class="flex flex-col border border-primary-200 shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4">
<Avatar image="https://primefaces.org/cdn/primevue/images/avatar/onyamalimba.png" shape="circle" size="xlarge" />
<span class="text-2xl font-medium">Xavier Mason</span>
<span class="text-muted-color text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
</div>
<div class="h-[30rem]"></div>
<div class="flex flex-wrap justify-center gap-8">
<div
v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 spin-in-45 slide-in-from-t-12 animate-duration-1000' }"
class="flex flex-col bg-primary text-primary-contrast border-primary shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4"
>
<span class="bg-white/20 text-xl font-medium rounded-xl px-4 py-2">850K</span>
<span class="text-2xl font-bold">Customers</span>
<span class="text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
<div
v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 zoom-in-50 slide-in-from-t-20 animate-duration-1000' }"
class="flex flex-col bg-primary text-primary-contrast border-primary shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4"
>
<span class="bg-white/20 text-xl font-medium rounded-xl px-4 py-2">$1.5M</span>
<span class="text-2xl font-bold">Revenue</span>
<span class="text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
<div
v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 spin-in-[-45deg] slide-in-from-t-16 animate-duration-1000' }"
class="flex flex-col bg-primary text-primary-contrast border-primary shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4"
>
<span class="bg-white/20 text-xl font-medium rounded-xl px-4 py-2">140K</span>
<span class="text-2xl font-bold">Sales</span>
<span class="text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
</div>
<div class="h-[30rem]"></div>
<div class="flex flex-wrap justify-center gap-8">
<div v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 zoom-in-50 animate-duration-1000' }" class="flex flex-col bg-purple-500 text-white border-purple-500 shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4">
<div class="rounded-full border-2 border-white w-12 h-12 flex items-center justify-center">
<i class="pi pi-wifi !text-2xl"></i>
</div>
<span class="text-2xl font-bold">Bandwidth</span>
<span class="text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
<div v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 zoom-in-75 animate-duration-1000' }" class="flex flex-col bg-teal-500 text-white border-teal-500 shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4">
<div class="rounded-full border-2 border-white w-12 h-12 flex items-center justify-center">
<i class="pi pi-database !text-2xl"></i>
</div>
<span class="text-2xl font-bold">Storage</span>
<span class="text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
<div v-animateonscroll="{ enterClass: 'animate-enter fade-in-10 zoom-in-50 animate-duration-1000' }" class="flex flex-col bg-indigo-500 text-white border-indigo-500 shadow-lg justify-center items-center max-w-80 rounded-2xl p-8 gap-4">
<div class="rounded-full border-2 border-white w-12 h-12 flex items-center justify-center">
<i class="pi pi-arrows-v !text-2xl"></i>
</div>
<span class="text-2xl font-bold">Requests</span>
<span class="text-center">Lorem ipsum dolor sit amet consectetur adipisicing elit.</span>
</div>
</div>
</div>
</template>
<script setup lang="ts">
</script>
Class | Property |
---|---|
animate-enter | animation-name: enter; --p-enter-opacity: initial; --p-enter-scale: initial; --p-enter-rotate: initial; --p-enter-translate-x: initial; --p-enter-translate-y: initial; |
animate-leave | animation-name: leave; --p-leave-opacity: initial; --p-leave-scale: initial; --p-leave-rotate: initial; --p-leave-translate-x: initial; --p-leave-translate-y: initial; |
animate-leave | fadein 0.15s linear |
animate-fadein | fadein 0.15s linear |
animate-fadeout | fadeout 0.15s linear |
animate-slidedown | slidedown 0.45s ease-in-out |
animate-slideup | slideup 0.45s cubic-bezier(0, 1, 0, 1) |
animate-scalein | scalein 0.15s linear |
animate-fadeinleft | fadeinleft 0.15s linear |
animate-fadeoutleft | fadeoutleft 0.15s linear |
animate-fadeinright | fadeinright 0.15s linear |
animate-fadeoutright | fadeoutright 0.15s linear |
animate-fadeinup | fadeinup 0.15s linear |
animate-fadeoutup | fadeoutup 0.15s linear |
animate-fadeindown | fadeindown 0.15s linear |
animate-fadeoutup | fadeoutup 0.15s linear |
animate-width | width 0.15s linear |
animate-flip | flip 0.15s linear |
animate-flipup | flipup 0.15s linear |
animate-flipleft | fadein 0.15s linear |
animate-flipright | flipright 0.15s linear |
animate-zoomin | zoomin 0.15s linear |
animate-zoomindown | zoomindown 0.15s linear |
animate-zoominleft | zoominleft 0.15s linear |
animate-zoominright | zoominright 0.15s linear |
animate-zoominup | zoominup 0.15s linear |
Class | Property |
---|---|
animate-duration-0 | animation-duration: 0s |
animate-duration-75 | animation-duration: 75ms |
animate-duration-100 | animation-duration: 100ms |
animate-duration-200 | animation-duration: 200ms |
animate-duration-300 | animation-duration: 300ms |
animate-duration-400 | animation-duration: 400ms |
animate-duration-500 | animation-duration: 500ms |
animate-duration-700 | animation-duration: 700ms |
animate-duration-1000 | animation-duration: 1000ms |
animate-duration-2000 | animation-duration: 2000ms |
animate-duration-3000 | animation-duration: 300ms |
animate-duration-[value] | animation-duration: value |
Class | Property |
---|---|
animate-delay-none | animation-duration: 0s |
animate-delay-75 | animation-delay: 75ms |
animate-delay-100 | animation-delay: 100ms |
animate-delay-150 | animation-delay: 150ms |
animate-delay-200 | animation-delay: 200ms |
animate-delay-300 | animation-delay: 300ms |
animate-delay-400 | animation-delay: 400ms |
animate-delay-500 | animation-delay: 500ms |
animate-delay-700 | animation-delay: 700ms |
animate-delay-1000 | animation-delay: 1000ms |
Class | Property |
---|---|
animate-infinite | animation-iteration-count: infinite |
animate-once | animation-iteration-count: 1 |
animate-twice | animation-iteration-count: 2 |
Class | Property |
---|---|
animate-normal | animation-direction: normal |
animate-reverse | animation-direction: reverse |
animate-alternate | animation-direction: alternate |
animate-alternate-reverse | animation-direction: alternate-reverse |
Class | Property |
---|---|
animate-ease-linear | animation-timing-function: linear |
animate-ease-in | animation-timing-function: cubic-bezier(0.4, 0, 1, 1) |
animate-ease-out | animation-timing-function: cubic-bezier(0, 0, 0.2, 1) |
animate-ease-in-out | animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1) |
Class | Property |
---|---|
animate-fill-none | animation-fill-mode: normal |
animate-fill-forwards | animation-fill-mode: forwards |
animate-fill-backwards | animation-fill-mode: backwards |
animate-fill-both | animation-fill-mode: both |
Class | Property |
---|---|
animate-running | animation-play-state: running |
animate-paused | animation-play-state: paused |
Class | Property |
---|---|
backface-visible | backface-visibility: visible |
backface-hidden | backface-visibility: hidden |
Values are derived from the Tailwind CSS opacity e.g. fade-in-50 and fade-out-20. Arbitrary values such as fade-in-[15] are also supported.
Class | Property |
---|---|
fade-in-{value} | --p-enter-opacity: {value} |
fade-out-{value} | --p-leave-opacity: {value} |
Values are derived from the Tailwind CSS scale e.g. zoom-in-50 and zoom-out-75. Arbitrary values such as zoom-in-[0.8] are also supported.
Class | Property |
---|---|
zoom-in-{value} | --p-enter-scale: {value} |
zoom-out-{value} | --p-leave-scale: {value} |
Values are derived from the Tailwind CSS rotate e.g. spin-in-45 and spin-out-90. Arbitrary values such as spin-in-[60deg] are also supported.
Class | Property |
---|---|
spin-in-{value} | --p-enter-rotate: {value} |
spin-out-{value} | --p-leave-rotate: {value} |
Values are derived from the Tailwind CSS translate e.g. slide-in-from-t-50 and slide-out-to-l-8. Arbitrary values such as slide-in-from-b-[8px] are also supported.
Class | Property |
---|---|
slide-in-from-t-{value} | --p-enter-translate-y: -{value} |
slide-in-from-b-{value} | --p-enter-translate-y: {value} |
slide-in-from-l-{value} | --p-enter-translate-x: -{value} |
slide-in-from-r-{value} | --p-enter-translate-x: {value} |
slide-out-to-t-{value} | --p-leave-translate-y: -{value} |
slide-out-to-b-{value} | --p-leave-translate-y: {value} |
slide-out-to-l-{value} | --p-leave-translate-x: -{value} |
slide-out-to-r-{value} | --p-leave-translate-x: {value} |