Meteors
A meteor shower effect.
Installation
Copy and paste the following code into your project:
vue
<script setup lang="ts">
import { ref, watch } from "vue";
import { cn } from "@/lib/utils";
interface MeteorsProps {
number?: number;
}
const props = withDefaults(defineProps<MeteorsProps>(), {
number: 20,
});
const meteorStyles = ref();
watch(
() => props.number,
(val) => {
const styles = Array.from({ length: val }).map(() => ({
top: -5,
left: `${Math.floor(Math.random() * window.innerWidth)}px`,
animationDelay: `${Math.random() * 1 + 0.2}s`,
animationDuration: `${Math.floor(Math.random() * 8 + 2)}s`,
}));
meteorStyles.value = styles;
},
{
immediate: true,
},
);
</script>
<template>
<div v-for="(style, index) in meteorStyles" :key="index">
<span
:key="index"
:class="
cn(
'pointer-events-none absolute left-1/2 top-1/2 size-0.5 rotate-[215deg] animate-meteor rounded-full bg-slate-500 shadow-[0_0_0_1px_#ffffff10]',
)
"
:style="style"
>
<div
class="pointer-events-none absolute top-1/2 -z-10 h-px w-[50px] -translate-y-1/2 bg-gradient-to-r from-slate-500 to-transparent"
/>
</span>
</div>
</template>Props
| Prop | Type | Description | Default |
|---|---|---|---|
| number | number | Number of meteors | 20 |