"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 { Select, SelectContent, SelectItem, SelectTrigger, SelectValue, } from "@/components/ui/select"; import { Checkbox } from "@/components/ui/checkbox"; import { RadioGroup, RadioGroupItem } from "@/components/ui/radio-group"; import JoditEditor from "jodit-react"; import { Switch } from "@/components/ui/switch"; import { Popover, PopoverContent, PopoverTrigger, } from "@/components/ui/popover"; import { cn } from "@/lib/utils"; import { CalendarIcon } from "lucide-react"; import { Calendar } from "@/components/ui/calendar"; import { addDays, format, 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, postSchedule } from "@/service/schedule/schedule"; import { id } from "date-fns/locale"; 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 { title: string; address: string; speakerTitle: string; speakerName: string; addressLat: number; addressLong: number; } export default function FormDetailPressConference(props: { id: any }) { const router = useRouter(); const id = props.id; const [isLiveStreamingEnabled, setIsLiveStreamingEnabled] = useState(false); type TaskSchema = z.infer; const [startTime, setStartTime] = useState("08:00"); const [endTime, setEndTime] = useState("09:00"); const [date, setDate] = React.useState({ from: new Date(2024, 0, 1), }); const handleStartTime = (e: any) => { setStartTime(e.target.value); }; const handleEndTime = (e: any) => { setEndTime(e.target.value); }; const [detail, setDetail] = useState(null); const [dataForm, setDataForm] = useState(null); const [refresh, setRefresh] = useState(false); const { control, handleSubmit, setValue, formState: { errors }, } = useForm({ resolver: zodResolver(taskSchema), defaultValues: { location: "", }, }); useEffect(() => { async function initState() { try { loading(); const response = await detailSchedule(id); const details = response.data?.data; console.log("res", id, response?.data?.data); if (details) { setDetail(details); setValue("title", details.title || ""); setValue("location", details.address || ""); setValue("level", details.speakerTitle || ""); setValue("name", details.speakerName || ""); Cookies.set("map_lat", details.addressLat, { secure: true, sameSite: "strict", }); Cookies.set("map_long", details.addressLong, { secure: true, sameSite: "strict", }); } Swal.close(); } catch (err) { Swal.fire("Error", "Failed to fetch details", "error"); } } initState(); }, [refresh, setValue]); return (

Form Konferensi Pers

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

{errors.title.message}

)}

Aktifkan fitur live streaming

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

{errors.title.message}

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