"use client"; import React, { ChangeEvent, 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 { register } from "module"; import { Switch } from "@/components/ui/switch"; import Cookies from "js-cookie"; import { createMedia, getTagsBySubCategoryId, listEnableCategory, } from "@/service/content/content"; import { getBlog, postBlog } from "@/service/blog/blog"; import { Badge } from "@/components/ui/badge"; const taskSchema = z.object({ title: z.string().min(1, { message: "Judul diperlukan" }), slug: z.string().min(1, { message: "Judul diperlukan" }), metadata: z.string().min(1, { message: "Judul diperlukan" }), narration: z .string() .min(2, { message: "Narasi Penugasan harus lebih dari 2 karakter." }), categoryName: z.string().min(1, { message: "Kategori diperlukan" }), }); type Category = { id: string; categoryName: string; }; type Detail = { id: number; title: string; narration: string; slug: string; metadata: string; categoryName: string; categoryId: string; thumbnailLink: string; tags: string; }; const initialCategories: Category[] = [ { id: "1", categoryName: "Giat Polri", }, { id: "2", categoryName: "Giat Pimpinan", }, { id: "3", categoryName: "Liputan Kegiatan", }, { id: "4", categoryName: "Seputar Prestasi", }, ]; export default function FormBlogUpdate() { const MySwal = withReactContent(Swal); const router = useRouter(); const { id } = useParams() as { id: string }; console.log(id); const editor = useRef(null); type TaskSchema = z.infer; const [selectedFiles, setSelectedFiles] = useState([]); const taskId = Cookies.get("taskId"); const scheduleId = Cookies.get("scheduleId"); const scheduleType = Cookies.get("scheduleType"); const [categories] = useState(initialCategories); const [selectedTarget, setSelectedTarget] = useState(""); const [selectedCategory, setSelectedCategory] = useState(); const [tags, setTags] = useState([]); const [isDraft, setIsDraft] = useState(false); const [detail, setDetail] = useState(); const [refresh, setRefresh] = useState(false); const [unitSelection, setUnitSelection] = useState({ allUnit: false, mabes: false, polda: false, polres: false, }); let fileTypeId = "1"; const { control, handleSubmit, setValue, formState: { errors }, } = useForm({ resolver: zodResolver(taskSchema), }); const handleRemoveTag = (index: any) => { setTags((prevTags) => prevTags.filter((_, i) => i !== index)); }; const handleImageChange = (event: ChangeEvent) => { if (event.target.files) { const files = Array.from(event.target.files); setSelectedFiles((prevImages: any) => [...prevImages, ...files]); console.log("DATAFILE::", selectedFiles); } }; const handleRemoveImage = (index: number) => { setSelectedFiles((prevImages) => prevImages.filter((_, i) => i !== index)); }; useEffect(() => { async function initState() { if (id) { const response = await getBlog(id); const details = response.data?.data; setDetail(details); // Set categoryId dari API ke form dan Select setValue("categoryName", details?.categoryName); setSelectedTarget(details?.categoryId); // Untuk dropdown } } initState(); }, [refresh, setValue]); const save = async (data: TaskSchema) => { const requestData = { ...data, id: detail?.id, title: data.title, narration: data.narration, categoryId: selectedTarget, slug: data.slug, metadata: data.metadata, tags: "siap", isDraft, }; const response = await postBlog(requestData); console.log("Form Data Submitted:", requestData); console.log("response", response); MySwal.fire({ title: "Sukses", text: "Data berhasil disimpan.", icon: "success", confirmButtonColor: "#3085d6", confirmButtonText: "OK", }).then(() => { router.push("/en/contributor/blog"); }); }; const onSubmit = (data: TaskSchema) => { MySwal.fire({ title: "Simpan Data", text: "Apakah Anda yakin ingin menyimpan data ini?", icon: "warning", showCancelButton: true, cancelButtonColor: "#d33", confirmButtonColor: "#3085d6", confirmButtonText: "Simpan", }).then((result) => { if (result.isConfirmed) { save(data); } }); }; const handlePublish = () => { setIsDraft(false); }; const handleSave = () => { setIsDraft(false); }; return (
{detail !== undefined ? (

Update Indeks

{/* Input Title */}
( )} /> {errors.title?.message && (

{errors.title.message}

)}
( )} /> {errors.narration?.message && (

{errors.narration.message}

)}
( )} /> {errors.slug?.message && (

{errors.slug.message}

)}
( )} /> {errors.metadata?.message && (

{errors.metadata.message}

)}
{ // const file = e.target.files[0]; // if (file) { // console.log("Selected File:", file); // // Tambahkan logika jika diperlukan, misalnya upload file ke server // } // }} className="" />
Thumbnail Gambar Utama
( )} />
{detail?.tags?.split(",").map((tag, index) => ( {tag.trim()} ))}
{/*
*/}
) : ( "" )}
); }