mirror of
https://github.com/supabase/supabase.git
synced 2026-05-08 09:50:33 -04:00
2feda5ee19
* show cms blog posts in www * remove contentlayer from www * outputFileTracingExcludes * update remotePatterns * fetch cms posts server-side with revalidation * add cms env vars to turbo.json * add www env vars to turbo.json * include cms posts in www sitemap * add migration to remove image from cms post * update cms meta image mapping in www
84 lines
2.3 KiB
TypeScript
84 lines
2.3 KiB
TypeScript
'use client'
|
|
|
|
import { PauseCircle, PlayCircle } from 'lucide-react'
|
|
import Image from 'next/image'
|
|
import { useEffect, useState } from 'react'
|
|
import { cn } from 'ui'
|
|
|
|
interface ImageFadeStackProps {
|
|
autoplay?: boolean
|
|
images: string[]
|
|
height?: 'default'
|
|
delay?: number
|
|
altText?: string
|
|
showNavigation?: boolean
|
|
}
|
|
|
|
const ImageFadeStack = ({
|
|
images,
|
|
height = 'default',
|
|
delay = 3000,
|
|
autoplay = false,
|
|
altText = 'Image',
|
|
showNavigation = false,
|
|
}: ImageFadeStackProps) => {
|
|
const [currentImageIndex, setCurrentImageIndex] = useState(0)
|
|
const [isPlaying, setIsPlaying] = useState(autoplay)
|
|
|
|
useEffect(() => {
|
|
if (isPlaying) {
|
|
const intervalId = setInterval(() => {
|
|
setCurrentImageIndex((prevIndex) => (prevIndex + 1) % images.length)
|
|
}, delay)
|
|
|
|
return () => clearInterval(intervalId)
|
|
}
|
|
}, [images, isPlaying])
|
|
|
|
function handleNavClick(index: number) {
|
|
setIsPlaying(false)
|
|
setCurrentImageIndex(index)
|
|
}
|
|
|
|
return (
|
|
<div className={`relative ${height === 'default' ? 'h-[300px]' : 'h-[400px]'} my-6`}>
|
|
{images.map((image, index) => (
|
|
<>
|
|
<Image
|
|
className="absolute top-0 left-0"
|
|
key={index}
|
|
src={image}
|
|
layout="fill"
|
|
alt={altText}
|
|
style={{
|
|
opacity: currentImageIndex === index ? 1 : 0,
|
|
transition: 'opacity 1s ease-in-out',
|
|
}}
|
|
/>
|
|
</>
|
|
))}
|
|
<div className="absolute bottom-4 right-4 flex gap-3">
|
|
{showNavigation &&
|
|
images.map((_, index) => (
|
|
<button className="text-white" onClick={() => handleNavClick(index)}>
|
|
<div
|
|
className={cn(
|
|
'w-2 h-2 rounded-full bg-foreground-muted hover:bg-surface-100 transition-colors',
|
|
currentImageIndex === index && 'bg-border-strong'
|
|
)}
|
|
/>
|
|
</button>
|
|
))}
|
|
<button
|
|
onClick={() => setIsPlaying(!isPlaying)}
|
|
className="text-white bg-foreground-light hover:bg-overlay rounded-full p-0.5 transition-colors"
|
|
>
|
|
{isPlaying ? <PauseCircle size={12} /> : <PlayCircle size={12} />}
|
|
</button>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
|
|
export default ImageFadeStack
|