bsd/app/page.tsx

85 lines
2.8 KiB
TypeScript
Raw Normal View History

2024-12-13 19:46:49 +08:00
'use client'
import { useState, useRef, useEffect } from 'react'
import { motion } from 'framer-motion'
import ActivityCard from '@/components/ActivityCard'
import { Input } from "@/components/ui/input"
import { useConfig } from './hooks/useConfig'
export default function Home() {
const { config } = useConfig()
const [searchTerm, setSearchTerm] = useState('')
const videoRef = useRef<HTMLVideoElement>(null)
const filteredActivities = config.activities.filter(activity =>
activity.title.toLowerCase().includes(searchTerm.toLowerCase()) ||
activity.description.toLowerCase().includes(searchTerm.toLowerCase()) ||
activity.organizer.toLowerCase().includes(searchTerm.toLowerCase())
)
useEffect(() => {
if (videoRef.current) {
videoRef.current.play().catch(error => {
console.error("视频自动播放失败:", error)
})
}
}, [])
return (
<main className="min-h-screen">
<section className="h-screen relative overflow-hidden">
<video
ref={videoRef}
autoPlay
loop
muted
playsInline
className="absolute top-0 left-0 w-full h-full object-cover"
>
<source src="https://c.mmeiblog.cn/d/share/newbili/影视星河片头.mp4" type="video/mp4" />
</video>
<div className="absolute top-0 left-0 w-full h-full bg-black opacity-50"></div>
<div className="relative z-10 h-full flex flex-col justify-center items-center text-white">
<motion.div
initial={{ opacity: 0, y: -50 }}
animate={{ opacity: 1, y: 0 }}
transition={{ duration: 1 }}
className="text-center"
>
<h1 className="text-4xl font-bold mb-4"></h1>
<p className="text-xl mb-8"></p>
</motion.div>
</div>
</section>
<section className="py-16 bg-white">
<div className="max-w-7xl mx-auto px-4 sm:px-6 lg:px-8">
<h2 className="text-3xl font-bold mb-8 text-center"></h2>
<div className="mb-6">
<Input
type="text"
placeholder="搜索活动、描述或组织者..."
value={searchTerm}
onChange={(e) => setSearchTerm(e.target.value)}
className="max-w-md mx-auto"
/>
</div>
<div className="grid grid-cols-1 md:grid-cols-2 gap-8">
{filteredActivities.map((activity, index) => (
<ActivityCard
key={index}
activity={{
...activity,
participants: activity.participants.map(participant => participant.name)
}}
/>
))}
</div>
</div>
</section>
</main>
)
}