"use client"; import React, { useEffect, useRef, useState } from "react"; import { useForm, Controller } from "react-hook-form"; import { Input } from "@/components/ui/input"; import { Button } from "@/components/ui/button"; import { Label } from "@/components/ui/label"; import { Card } from "@/components/ui/card"; import { zodResolver } from "@hookform/resolvers/zod"; import * as z from "zod"; import Swal from "sweetalert2"; import withReactContent from "sweetalert2-react-content"; import { useParams, useRouter } from "next/navigation"; import { Switch } from "@/components/ui/switch"; import { Popover, PopoverContent, PopoverTrigger, } from "@/components/ui/popover"; import { cn } from "@/lib/utils"; import { CalendarIcon, Clock1, Eye, MapPin, Plus, User2 } from "lucide-react"; import { Calendar } from "@/components/ui/calendar"; import { addDays, format, parseISO, setDate } from "date-fns"; import { DateRange } from "react-day-picker"; import TimePicker from "react-time-picker"; import "react-time-picker/dist/TimePicker.css"; import "react-clock/dist/Clock.css"; import MapHome from "@/components/maps/MapHome"; import { Textarea } from "@/components/ui/textarea"; import { error, loading } from "@/lib/swal"; import Cookies from "js-cookie"; import { detailSchedule, getListScheduleAttachment, listScheduleNext, listScheduleToday, postSchedule, } from "@/service/schedule/schedule"; import { Accordion, AccordionContent, AccordionItem, AccordionTrigger, } from "@/components/ui/accordion"; import { formatDate } from "@fullcalendar/core/index.js"; import { Dialog, DialogContent, DialogTrigger } from "@/components/ui/dialog"; import { Link } from "@/i18n/routing"; const taskSchema = z.object({ title: z.string().min(1, { message: "Judul diperlukan" }), level: z.string().min(1, { message: "Judul diperlukan" }), name: z.string().min(1, { message: "Judul diperlukan" }), location: z.string().min(1, { message: "Judul diperlukan" }), }); interface Detail { id: number; title: string; address: string; speakerTitle: string; speakerName: string; addressLat: number; addressLong: number; } interface Attachment { id: any; title: string; fileTypeId: number; type: number; fileTypeName: string; } export default function FormEventDetail() { const [open, setOpen] = useState(false); const { id } = useParams() as { id: string }; console.log(id); const router = useRouter(); const [isLiveStreamingEnabled, setIsLiveStreamingEnabled] = useState(false); type TaskSchema = z.infer; const [startTime, setStartTime] = useState("08:00"); const [endTime, setEndTime] = useState("09:00"); const [date, setDate] = useState(); const [todayList, setTodayList] = useState([]); const [nextDayList, setNextDayList] = useState([]); const [detail, setDetail] = useState(); const [refresh, setRefresh] = useState(false); const { control, handleSubmit, setValue, formState: { errors }, } = useForm({ resolver: zodResolver(taskSchema), defaultValues: { location: "", }, }); const [lampiran, setDataLampiran] = useState([]); async function getDataAttachment() { const response = await getListScheduleAttachment(id); console.log("data attach", response?.data?.data?.content); setDataLampiran(response?.data?.data?.content); } async function getDataByDate() { const resToday = await listScheduleToday(); const today = resToday?.data?.data; setTodayList(today); const resNext = await listScheduleNext(); const next = resNext?.data?.data; setNextDayList(next); } useEffect(() => { async function initState() { if (id) { const response = await detailSchedule(id); const details = response?.data?.data; setDetail(details); if (details) { setDate({ from: parseISO(details.startDate), to: parseISO(details.endDate), }); } if (details) { setStartTime(details.startTime); setEndTime(details.endTime); } getDataByDate(); } } initState(); getDataAttachment(); }, [refresh, setValue]); const handleStartTime = (e: React.ChangeEvent) => { setStartTime(e.target.value); }; const handleEndTime = (e: React.ChangeEvent) => { setEndTime(e.target.value); }; const handleDestinationUpload = ( type: number, id: string | number, setOpen: (open: boolean) => void, router: any ) => { setOpen(false); // Tutup modal dialog if (id !== undefined) { Cookies.set("scheduleId", id.toString(), { expires: 1 }); Cookies.set("scheduleType", "3", { expires: 1 }); const routes: Record = { 1: "/in/contributor/schedule/media/image/create", 2: "/in/contributor/schedule/media/video/create", 3: "/in/contributor/schedule/media/text/create", 4: "/in/contributor/schedule/media/audio/create", }; router.push(routes[type] || "/admin/schedule/media/audio/create"); } }; return (

Form Event

{detail !== undefined ? (
{/* Input Title */}
( )} /> {errors.title?.message && (

{errors.title.message}

)}

Aktifkan fitur live streaming

setIsLiveStreamingEnabled(checked) } />
{isLiveStreamingEnabled && (
( )} /> {errors.title?.message && (

{errors.title.message}

)}
)}
{/* Kirim setValue ke MapHome */} setValue("location", location)} />
(