Files
HabitTrove/utils/celebrations.ts
2024-12-31 21:51:46 -05:00

77 lines
1.8 KiB
TypeScript

import confetti from 'canvas-confetti'
import JSConfetti from 'js-confetti'
let jsConfetti: JSConfetti | null = null
if (typeof window !== 'undefined') {
jsConfetti = new JSConfetti()
}
export const celebrations = {
emojiParty: () => {
if (jsConfetti) {
// 20% chance to use only coin emoji
const useCoinsOnly = Math.random() < 0.2
jsConfetti.addConfetti({
emojis: useCoinsOnly ? ['💰', '🪙'] : ['🎉', '✨', '🦄', '🌈', '⚡️', '🌸', '💫', '🌟'],
emojiSize: 50,
confettiNumber: useCoinsOnly ? 50 : 30, // More coins when it's coin-only
})
}
},
basic: () => {
confetti({
particleCount: 200,
spread: 70,
origin: { y: 0.6 }
})
},
fireworks: () => {
const duration = 3000
const animationEnd = Date.now() + duration
const defaults = { startVelocity: 30, spread: 360, ticks: 60, zIndex: 0 }
const interval: any = setInterval(function () {
const timeLeft = animationEnd - Date.now()
if (timeLeft <= 0) {
return clearInterval(interval)
}
const particleCount = 50 * (timeLeft / duration)
confetti({
...defaults,
particleCount,
origin: { x: Math.random(), y: Math.random() - 0.2 }
})
}, 250)
},
shower: () => {
const end = Date.now() + 2000
const colors = ['#ff0000', '#00ff00', '#0000ff']
; (function frame() {
confetti({
particleCount: 2,
angle: 60,
spread: 55,
origin: { x: 0 },
colors: colors
})
confetti({
particleCount: 2,
angle: 120,
spread: 55,
origin: { x: 1 },
colors: colors
})
if (Date.now() < end) {
requestAnimationFrame(frame)
}
}())
}
}