From 7506ca41e533ac8030e536731482eec4d5d2d77c Mon Sep 17 00:00:00 2001 From: sebastjanartic <45803536-sebastjanartic@users.noreply.replit.com> Date: Mon, 1 Sep 2025 20:47:18 +0000 Subject: [PATCH] Add a new section for "Die Geschichte des Liedes" videos Integrates a new route and page for "Die Geschichte des Liedes" videos, including filtering, pagination, and navigation links on the homepage and within the app's routing. Replit-Commit-Author: Agent Replit-Commit-Session-Id: 890577b1-c154-40a4-a177-a0c6d55320c3 Replit-Commit-Checkpoint-Type: full_checkpoint Replit-Commit-Screenshot-Url: https://storage.googleapis.com/screenshot-production-us-central1/8cc42625-c1f5-4e43-99bd-77f2c4dedee2/890577b1-c154-40a4-a177-a0c6d55320c3/2xHHKQn --- client/src/App.tsx | 2 + client/src/pages/GeschichteLiedPage.tsx | 248 ++++++++++++++++++++++++ client/src/pages/home.tsx | 13 +- 3 files changed, 262 insertions(+), 1 deletion(-) create mode 100644 client/src/pages/GeschichteLiedPage.tsx diff --git a/client/src/App.tsx b/client/src/App.tsx index 3ad8d7c..d9ccef5 100644 --- a/client/src/App.tsx +++ b/client/src/App.tsx @@ -6,6 +6,7 @@ import { TooltipProvider } from "@/components/ui/tooltip"; import Home from "@/pages/home"; import VideoPage from "@/pages/VideoPage"; import FolxStadlPage from "@/pages/FolxStadlPage"; +import GeschichteLiedPage from "@/pages/GeschichteLiedPage"; import NotFound from "@/pages/not-found"; function Router() { @@ -14,6 +15,7 @@ function Router() { + ); diff --git a/client/src/pages/GeschichteLiedPage.tsx b/client/src/pages/GeschichteLiedPage.tsx new file mode 100644 index 0000000..8ce503e --- /dev/null +++ b/client/src/pages/GeschichteLiedPage.tsx @@ -0,0 +1,248 @@ +import { useQuery } from '@tanstack/react-query'; +import { Link, useLocation } from 'wouter'; +import { ArrowLeft, ChevronLeft, ChevronRight, Menu, X } from 'lucide-react'; +import VideoCard from '@/components/video-card'; +import BunnyVideoModal from '@/components/bunny-video-modal'; +import { Button } from '@/components/ui/button'; +import { useState } from 'react'; +import type { Video } from '@shared/schema'; +import { Input } from '@/components/ui/input'; +import { Search } from 'lucide-react'; + +export default function GeschichteLiedPage() { + const [selectedVideo, setSelectedVideo] = useState