'use client' import Link from 'next/link' import moment from "moment"; import { useState } from "react" import { events } from "@/utility/constant.utils"; // <-- import the events array here export default function UpcomingEventData() { const [currentMonth, setCurrentMonth] = useState(moment()); // Get start and end of current month const startOfMonth = currentMonth.clone().startOf("month"); const endOfMonth = currentMonth.clone().endOf("month"); // Generate calendar days const daysInMonth = []; for (let i = 0; i < startOfMonth.day(); i++) { daysInMonth.push(null); } for (let i = 1; i <= endOfMonth.date(); i++) { daysInMonth.push(moment(currentMonth).date(i)); } // Get events for a given date const getEventForDate = (date) => { const dateString = date?.format("YYYY-MM-DD"); return events.filter(event => event.date === dateString); }; // Navigate months const handleMonthChange = (direction) => { setCurrentMonth(currentMonth.clone().add(direction, "months")); }; return (

Events

{/* Calendar (left side) */}
{currentMonth.format("MMMM YYYY")}
{["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"].map((day, index) => ( ))} {Array.from({ length: Math.ceil(daysInMonth.length / 7) }, (_, rowIndex) => ( {daysInMonth .slice(rowIndex * 7, (rowIndex + 1) * 7) .map((day, index) => { const eventList = getEventForDate(day); return ( ); })} ))}
{day}
0 ? "#ce2029" : "white", color: eventList.length > 0 ? "white" : "black", }} title={ eventList.length > 0 ? eventList.map(e => e.title).join("\n") : "" } > {day ? (
{day.date()}
) : ( "" )}
{events.map((event, idx) => { const isEven = (idx + 1) % 2 === 0; return (

{String(idx + 1).padStart(2, "0")}

{!isEven ? ( <>
{event.title}
  • {" "} {event.time ? `${event.time} - ` : ""} {moment(event.date).format("ddd, MMM DD, YYYY")}
  • {" "} {event.location}
{event.title}

{event.desc}

{event.btnText || "Online Tickets"}
) : ( <>
  • {" "} {event.time ? `${event.time} - ` : ""} {moment(event.date).format("ddd, MMM DD, YYYY")}
  • {" "} {event.location}
{event.title}

{event.desc}

{event.btnText || "Online Tickets"}
{event.title}
)}
); })}
) }